bgneal@45: tinyMCEPopup.requireLangPack(); bgneal@45: bgneal@45: var AnchorDialog = { bgneal@45: init : function(ed) { bgneal@45: var action, elm, f = document.forms[0]; bgneal@45: bgneal@45: this.editor = ed; bgneal@45: elm = ed.dom.getParent(ed.selection.getNode(), 'A,IMG'); bgneal@45: v = ed.dom.getAttrib(elm, 'name'); bgneal@45: bgneal@45: if (v) { bgneal@45: this.action = 'update'; bgneal@45: f.anchorName.value = v; bgneal@45: } bgneal@45: bgneal@45: f.insert.value = ed.getLang(elm ? 'update' : 'insert'); bgneal@45: }, bgneal@45: bgneal@45: update : function() { bgneal@45: var ed = this.editor; bgneal@45: bgneal@45: tinyMCEPopup.restoreSelection(); bgneal@45: bgneal@45: if (this.action != 'update') bgneal@45: ed.selection.collapse(1); bgneal@45: bgneal@45: // Webkit acts weird if empty inline element is inserted so we need to use a image instead bgneal@45: if (tinymce.isWebKit) bgneal@45: ed.execCommand('mceInsertContent', 0, ed.dom.createHTML('img', {mce_name : 'a', name : document.forms[0].anchorName.value, 'class' : 'mceItemAnchor'})); bgneal@45: else bgneal@45: ed.execCommand('mceInsertContent', 0, ed.dom.createHTML('a', {name : document.forms[0].anchorName.value, 'class' : 'mceItemAnchor'}, '')); bgneal@45: bgneal@45: tinyMCEPopup.close(); bgneal@45: } bgneal@45: }; bgneal@45: bgneal@45: tinyMCEPopup.onInit.add(AnchorDialog.init, AnchorDialog);