+ onChange: function() {
+ panel.trigger('panel:contentChanged', self);
+ },
+ initCallback: function(editor) {
+ // Toolbar
+ $('.toolbar-tabs li', panel).click(function() {
+ var id = $(this).attr('p:button-list');
+ $('.toolbar-tabs li', panel).removeClass('active');
+ $(this).addClass('active');
+ if (!$('.' + id, panel).is(':visible')) {
+ $('.toolbar-buttons ol', panel).not('#' + id).hide();
+ $('.' + id, panel).show();
+ }
+ })
+
+ var keys = {};
+ $('.toolbar-buttons li', panel).each(function() {
+ var tag = $(this).attr('p:tag');
+ var handler = function() {
+ var text = texteditor.selection();
+ editor.replaceSelection('<' + tag + '>' + text + '</' + tag + '>');
+ if (text.length == 0) {
+ var pos = texteditor.cursorPosition();
+ texteditor.selectLines(pos.line, pos.character + tag.length + 2);
+ }
+ $(document).trigger('panel:contentChanged', self);
+ }
+ if ($(this).attr('p:key')) {
+ keys[$(this).attr('p:key')] = handler;
+ }
+ $(this).click(handler)
+ });
+
+ texteditor.grabKeys(function(event) {
+ if (keys[event.keyCode]) {
+ keys[event.keyCode]();
+ }
+ }, function(event) { return event.altKey && keys[event.keyCode]; });
+ }