]> scripts.mit.edu Git - autoinstalls/wordpress.git/blobdiff - wp-includes/js/tinymce/utils/editable_selects.js
Wordpress 2.5.1
[autoinstalls/wordpress.git] / wp-includes / js / tinymce / utils / editable_selects.js
index e72336541ebe28cc8e8196e8d9a6390d88b358b8..7f58dfc31e9c12a240ee8245a4e05b32c38f3f75 100644 (file)
@@ -1,61 +1,61 @@
-/**\r
- * $Id: editable_selects.js 162 2007-01-03 16:16:52Z spocke $\r
- *\r
- * Makes select boxes editable.\r
- *\r
- * @author Moxiecode\r
- * @copyright Copyright © 2004-2007, Moxiecode Systems AB, All rights reserved.\r
- */\r
-\r
-var TinyMCE_EditableSelects = {\r
-       editSelectElm : null,\r
-\r
-       init : function() {\r
-               var nl = document.getElementsByTagName("select"), i, d = document, o;\r
-\r
-               for (i=0; i<nl.length; i++) {\r
-                       if (nl[i].className.indexOf('mceEditableSelect') != -1) {\r
-                               o = new Option('(value)', '__mce_add_custom__');\r
-\r
-                               o.className = 'mceAddSelectValue';\r
-\r
-                               nl[i].options[nl[i].options.length] = o;\r
-                               nl[i].setAttribute('onchange', 'TinyMCE_EditableSelects.onChangeEditableSelect(this);');\r
-                       }\r
-               }\r
-       },\r
-\r
-       onChangeEditableSelect : function(se) {\r
-               var d = document, ne;\r
-\r
-               if (se.options[se.selectedIndex].value == '__mce_add_custom__') {\r
-                       ne = d.createElement("input");\r
-                       ne.id = se.id + "_custom";\r
-                       ne.name = se.name + "_custom";\r
-                       ne.type = "text";\r
-\r
-                       ne.style.width = se.clientWidth;\r
-                       se.parentNode.insertBefore(ne, se);\r
-                       se.style.display = 'none';\r
-                       ne.focus();\r
-                       ne.onblur = TinyMCE_EditableSelects.onBlurEditableSelectInput;\r
-                       TinyMCE_EditableSelects.editSelectElm = se;\r
-               }\r
-       },\r
-\r
-       onBlurEditableSelectInput : function() {\r
-               var se = TinyMCE_EditableSelects.editSelectElm;\r
-\r
-               if (se) {\r
-                       if (se.previousSibling.value != '') {\r
-                               addSelectValue(document.forms[0], se.id, se.previousSibling.value, se.previousSibling.value);\r
-                               selectByValue(document.forms[0], se.id, se.previousSibling.value);\r
-                       } else\r
-                               selectByValue(document.forms[0], se.id, '');\r
-\r
-                       se.style.display = 'inline';\r
-                       se.parentNode.removeChild(se.previousSibling);\r
-                       TinyMCE_EditableSelects.editSelectElm = null;\r
-               }\r
-       }\r
-};\r
+/**
+ * $Id: editable_selects.js 520 2008-01-07 16:30:32Z spocke $
+ *
+ * Makes select boxes editable.
+ *
+ * @author Moxiecode
+ * @copyright Copyright © 2004-2008, Moxiecode Systems AB, All rights reserved.
+ */
+
+var TinyMCE_EditableSelects = {
+       editSelectElm : null,
+
+       init : function() {
+               var nl = document.getElementsByTagName("select"), i, d = document, o;
+
+               for (i=0; i<nl.length; i++) {
+                       if (nl[i].className.indexOf('mceEditableSelect') != -1) {
+                               o = new Option('(value)', '__mce_add_custom__');
+
+                               o.className = 'mceAddSelectValue';
+
+                               nl[i].options[nl[i].options.length] = o;
+                               nl[i].onchange = TinyMCE_EditableSelects.onChangeEditableSelect;
+                       }
+               }
+       },
+
+       onChangeEditableSelect : function(e) {
+               var d = document, ne, se = window.event ? window.event.srcElement : e.target;
+
+               if (se.options[se.selectedIndex].value == '__mce_add_custom__') {
+                       ne = d.createElement("input");
+                       ne.id = se.id + "_custom";
+                       ne.name = se.name + "_custom";
+                       ne.type = "text";
+
+                       ne.style.width = se.offsetWidth + 'px';
+                       se.parentNode.insertBefore(ne, se);
+                       se.style.display = 'none';
+                       ne.focus();
+                       ne.onblur = TinyMCE_EditableSelects.onBlurEditableSelectInput;
+                       TinyMCE_EditableSelects.editSelectElm = se;
+               }
+       },
+
+       onBlurEditableSelectInput : function() {
+               var se = TinyMCE_EditableSelects.editSelectElm;
+
+               if (se) {
+                       if (se.previousSibling.value != '') {
+                               addSelectValue(document.forms[0], se.id, se.previousSibling.value, se.previousSibling.value);
+                               selectByValue(document.forms[0], se.id, se.previousSibling.value);
+                       } else
+                               selectByValue(document.forms[0], se.id, '');
+
+                       se.style.display = 'inline';
+                       se.parentNode.removeChild(se.previousSibling);
+                       TinyMCE_EditableSelects.editSelectElm = null;
+               }
+       }
+};