var action, elm, f = document.forms[0];\r
\r
this.editor = ed;\r
- elm = ed.dom.getParent(ed.selection.getNode(), 'A,IMG');\r
+ elm = ed.dom.getParent(ed.selection.getNode(), 'A');\r
v = ed.dom.getAttrib(elm, 'name');\r
\r
if (v) {\r
},\r
\r
update : function() {\r
- var ed = this.editor;\r
- \r
+ var ed = this.editor, elm, name = document.forms[0].anchorName.value;\r
+\r
+ if (!name || !/^[a-z][a-z0-9\-\_:\.]*$/i.test(name)) {\r
+ tinyMCEPopup.alert('advanced_dlg.anchor_invalid');\r
+ return;\r
+ }\r
+\r
tinyMCEPopup.restoreSelection();\r
\r
if (this.action != 'update')\r
ed.selection.collapse(1);\r
\r
- // Webkit acts weird if empty inline element is inserted so we need to use a image instead\r
- if (tinymce.isWebKit)\r
- ed.execCommand('mceInsertContent', 0, ed.dom.createHTML('img', {mce_name : 'a', name : document.forms[0].anchorName.value, 'class' : 'mceItemAnchor'}));\r
+ elm = ed.dom.getParent(ed.selection.getNode(), 'A');\r
+ if (elm)\r
+ elm.name = name;\r
else\r
- ed.execCommand('mceInsertContent', 0, ed.dom.createHTML('a', {name : document.forms[0].anchorName.value, 'class' : 'mceItemAnchor'}, ''));\r
+ ed.execCommand('mceInsertContent', 0, ed.dom.createHTML('a', {name : name, 'class' : 'mceItemAnchor'}, ''));\r
\r
tinyMCEPopup.close();\r
}\r