+++ /dev/null
-/**\r
- * element_common.js\r
- *\r
- * Copyright 2009, Moxiecode Systems AB\r
- * Released under LGPL License.\r
- *\r
- * License: http://tinymce.moxiecode.com/license\r
- * Contributing: http://tinymce.moxiecode.com/contributing\r
- */\r
-\r
-tinyMCEPopup.requireLangPack();\r
-\r
-function initCommonAttributes(elm) {\r
- var formObj = document.forms[0], dom = tinyMCEPopup.editor.dom;\r
-\r
- // Setup form data for common element attributes\r
- setFormValue('title', dom.getAttrib(elm, 'title'));\r
- setFormValue('id', dom.getAttrib(elm, 'id'));\r
- selectByValue(formObj, 'class', dom.getAttrib(elm, 'class'), true);\r
- setFormValue('style', dom.getAttrib(elm, 'style'));\r
- selectByValue(formObj, 'dir', dom.getAttrib(elm, 'dir'));\r
- setFormValue('lang', dom.getAttrib(elm, 'lang'));\r
- setFormValue('onfocus', dom.getAttrib(elm, 'onfocus'));\r
- setFormValue('onblur', dom.getAttrib(elm, 'onblur'));\r
- setFormValue('onclick', dom.getAttrib(elm, 'onclick'));\r
- setFormValue('ondblclick', dom.getAttrib(elm, 'ondblclick'));\r
- setFormValue('onmousedown', dom.getAttrib(elm, 'onmousedown'));\r
- setFormValue('onmouseup', dom.getAttrib(elm, 'onmouseup'));\r
- setFormValue('onmouseover', dom.getAttrib(elm, 'onmouseover'));\r
- setFormValue('onmousemove', dom.getAttrib(elm, 'onmousemove'));\r
- setFormValue('onmouseout', dom.getAttrib(elm, 'onmouseout'));\r
- setFormValue('onkeypress', dom.getAttrib(elm, 'onkeypress'));\r
- setFormValue('onkeydown', dom.getAttrib(elm, 'onkeydown'));\r
- setFormValue('onkeyup', dom.getAttrib(elm, 'onkeyup'));\r
-}\r
-\r
-function setFormValue(name, value) {\r
- if(document.forms[0].elements[name]) document.forms[0].elements[name].value = value;\r
-}\r
-\r
-function insertDateTime(id) {\r
- document.getElementById(id).value = getDateTime(new Date(), "%Y-%m-%dT%H:%M:%S");\r
-}\r
-\r
-function getDateTime(d, fmt) {\r
- fmt = fmt.replace("%D", "%m/%d/%y");\r
- fmt = fmt.replace("%r", "%I:%M:%S %p");\r
- fmt = fmt.replace("%Y", "" + d.getFullYear());\r
- fmt = fmt.replace("%y", "" + d.getYear());\r
- fmt = fmt.replace("%m", addZeros(d.getMonth()+1, 2));\r
- fmt = fmt.replace("%d", addZeros(d.getDate(), 2));\r
- fmt = fmt.replace("%H", "" + addZeros(d.getHours(), 2));\r
- fmt = fmt.replace("%M", "" + addZeros(d.getMinutes(), 2));\r
- fmt = fmt.replace("%S", "" + addZeros(d.getSeconds(), 2));\r
- fmt = fmt.replace("%I", "" + ((d.getHours() + 11) % 12 + 1));\r
- fmt = fmt.replace("%p", "" + (d.getHours() < 12 ? "AM" : "PM"));\r
- fmt = fmt.replace("%%", "%");\r
-\r
- return fmt;\r
-}\r
-\r
-function addZeros(value, len) {\r
- var i;\r
-\r
- value = "" + value;\r
-\r
- if (value.length < len) {\r
- for (i=0; i<(len-value.length); i++)\r
- value = "0" + value;\r
- }\r
-\r
- return value;\r
-}\r
-\r
-function selectByValue(form_obj, field_name, value, add_custom, ignore_case) {\r
- if (!form_obj || !form_obj.elements[field_name])\r
- return;\r
-\r
- var sel = form_obj.elements[field_name];\r
-\r
- var found = false;\r
- for (var i=0; i<sel.options.length; i++) {\r
- var option = sel.options[i];\r
-\r
- if (option.value == value || (ignore_case && option.value.toLowerCase() == value.toLowerCase())) {\r
- option.selected = true;\r
- found = true;\r
- } else\r
- option.selected = false;\r
- }\r
-\r
- if (!found && add_custom && value != '') {\r
- var option = new Option('Value: ' + value, value);\r
- option.selected = true;\r
- sel.options[sel.options.length] = option;\r
- }\r
-\r
- return found;\r
-}\r
-\r
-function setAttrib(elm, attrib, value) {\r
- var formObj = document.forms[0];\r
- var valueElm = formObj.elements[attrib.toLowerCase()];\r
- tinyMCEPopup.editor.dom.setAttrib(elm, attrib, value || valueElm.value);\r
-}\r
-\r
-function setAllCommonAttribs(elm) {\r
- setAttrib(elm, 'title');\r
- setAttrib(elm, 'id');\r
- setAttrib(elm, 'class');\r
- setAttrib(elm, 'style');\r
- setAttrib(elm, 'dir');\r
- setAttrib(elm, 'lang');\r
- /*setAttrib(elm, 'onfocus');\r
- setAttrib(elm, 'onblur');\r
- setAttrib(elm, 'onclick');\r
- setAttrib(elm, 'ondblclick');\r
- setAttrib(elm, 'onmousedown');\r
- setAttrib(elm, 'onmouseup');\r
- setAttrib(elm, 'onmouseover');\r
- setAttrib(elm, 'onmousemove');\r
- setAttrib(elm, 'onmouseout');\r
- setAttrib(elm, 'onkeypress');\r
- setAttrib(elm, 'onkeydown');\r
- setAttrib(elm, 'onkeyup');*/\r
-}\r
-\r
-SXE = {\r
- currentAction : "insert",\r
- inst : tinyMCEPopup.editor,\r
- updateElement : null\r
-}\r
-\r
-SXE.focusElement = SXE.inst.selection.getNode();\r
-\r
-SXE.initElementDialog = function(element_name) {\r
- addClassesToList('class', 'xhtmlxtras_styles');\r
- TinyMCE_EditableSelects.init();\r
-\r
- element_name = element_name.toLowerCase();\r
- var elm = SXE.inst.dom.getParent(SXE.focusElement, element_name.toUpperCase());\r
- if (elm != null && elm.nodeName.toUpperCase() == element_name.toUpperCase()) {\r
- SXE.currentAction = "update";\r
- }\r
-\r
- if (SXE.currentAction == "update") {\r
- initCommonAttributes(elm);\r
- SXE.updateElement = elm;\r
- }\r
-\r
- document.forms[0].insert.value = tinyMCEPopup.getLang(SXE.currentAction, 'Insert', true); \r
-}\r
-\r
-SXE.insertElement = function(element_name) {\r
- var elm = SXE.inst.dom.getParent(SXE.focusElement, element_name.toUpperCase()), h, tagName;\r
-\r
- if (elm == null) {\r
- var s = SXE.inst.selection.getContent();\r
- if(s.length > 0) {\r
- tagName = element_name;\r
-\r
- insertInlineElement(element_name);\r
- var elementArray = tinymce.grep(SXE.inst.dom.select(element_name));\r
- for (var i=0; i<elementArray.length; i++) {\r
- var elm = elementArray[i];\r
-\r
- if (SXE.inst.dom.getAttrib(elm, 'data-mce-new')) {\r
- elm.id = '';\r
- elm.setAttribute('id', '');\r
- elm.removeAttribute('id');\r
- elm.removeAttribute('data-mce-new');\r
-\r
- setAllCommonAttribs(elm);\r
- }\r
- }\r
- }\r
- } else {\r
- setAllCommonAttribs(elm);\r
- }\r
- SXE.inst.nodeChanged();\r
- tinyMCEPopup.execCommand('mceEndUndoLevel');\r
-}\r
-\r
-SXE.removeElement = function(element_name){\r
- element_name = element_name.toLowerCase();\r
- elm = SXE.inst.dom.getParent(SXE.focusElement, element_name.toUpperCase());\r
- if(elm && elm.nodeName.toUpperCase() == element_name.toUpperCase()){\r
- tinyMCE.execCommand('mceRemoveNode', false, elm);\r
- SXE.inst.nodeChanged();\r
- tinyMCEPopup.execCommand('mceEndUndoLevel');\r
- }\r
-}\r
-\r
-SXE.showRemoveButton = function() {\r
- document.getElementById("remove").style.display = '';\r
-}\r
-\r
-SXE.containsClass = function(elm,cl) {\r
- return (elm.className.indexOf(cl) > -1) ? true : false;\r
-}\r
-\r
-SXE.removeClass = function(elm,cl) {\r
- if(elm.className == null || elm.className == "" || !SXE.containsClass(elm,cl)) {\r
- return true;\r
- }\r
- var classNames = elm.className.split(" ");\r
- var newClassNames = "";\r
- for (var x = 0, cnl = classNames.length; x < cnl; x++) {\r
- if (classNames[x] != cl) {\r
- newClassNames += (classNames[x] + " ");\r
- }\r
- }\r
- elm.className = newClassNames.substring(0,newClassNames.length-1); //removes extra space at the end\r
-}\r
-\r
-SXE.addClass = function(elm,cl) {\r
- if(!SXE.containsClass(elm,cl)) elm.className ? elm.className += " " + cl : elm.className = cl;\r
- return true;\r
-}\r
-\r
-function insertInlineElement(en) {\r
- var ed = tinyMCEPopup.editor, dom = ed.dom;\r
-\r
- ed.getDoc().execCommand('FontName', false, 'mceinline');\r
- tinymce.each(dom.select('span,font'), function(n) {\r
- if (n.style.fontFamily == 'mceinline' || n.face == 'mceinline')\r
- dom.replace(dom.create(en, {'data-mce-new' : 1}), n, 1);\r
- });\r
-}\r