bgneal@183: /** bgneal@183: * element_common.js bgneal@45: * bgneal@183: * Copyright 2009, Moxiecode Systems AB bgneal@183: * Released under LGPL License. bgneal@183: * bgneal@183: * License: http://tinymce.moxiecode.com/license bgneal@183: * Contributing: http://tinymce.moxiecode.com/contributing bgneal@45: */ bgneal@45: bgneal@45: tinyMCEPopup.requireLangPack(); bgneal@45: bgneal@45: function initCommonAttributes(elm) { bgneal@45: var formObj = document.forms[0], dom = tinyMCEPopup.editor.dom; bgneal@45: bgneal@45: // Setup form data for common element attributes bgneal@45: setFormValue('title', dom.getAttrib(elm, 'title')); bgneal@45: setFormValue('id', dom.getAttrib(elm, 'id')); bgneal@45: selectByValue(formObj, 'class', dom.getAttrib(elm, 'class'), true); bgneal@45: setFormValue('style', dom.getAttrib(elm, 'style')); bgneal@45: selectByValue(formObj, 'dir', dom.getAttrib(elm, 'dir')); bgneal@45: setFormValue('lang', dom.getAttrib(elm, 'lang')); bgneal@45: setFormValue('onfocus', dom.getAttrib(elm, 'onfocus')); bgneal@45: setFormValue('onblur', dom.getAttrib(elm, 'onblur')); bgneal@45: setFormValue('onclick', dom.getAttrib(elm, 'onclick')); bgneal@45: setFormValue('ondblclick', dom.getAttrib(elm, 'ondblclick')); bgneal@45: setFormValue('onmousedown', dom.getAttrib(elm, 'onmousedown')); bgneal@45: setFormValue('onmouseup', dom.getAttrib(elm, 'onmouseup')); bgneal@45: setFormValue('onmouseover', dom.getAttrib(elm, 'onmouseover')); bgneal@45: setFormValue('onmousemove', dom.getAttrib(elm, 'onmousemove')); bgneal@45: setFormValue('onmouseout', dom.getAttrib(elm, 'onmouseout')); bgneal@45: setFormValue('onkeypress', dom.getAttrib(elm, 'onkeypress')); bgneal@45: setFormValue('onkeydown', dom.getAttrib(elm, 'onkeydown')); bgneal@45: setFormValue('onkeyup', dom.getAttrib(elm, 'onkeyup')); bgneal@45: } bgneal@45: bgneal@45: function setFormValue(name, value) { bgneal@45: if(document.forms[0].elements[name]) document.forms[0].elements[name].value = value; bgneal@45: } bgneal@45: bgneal@45: function insertDateTime(id) { bgneal@45: document.getElementById(id).value = getDateTime(new Date(), "%Y-%m-%dT%H:%M:%S"); bgneal@45: } bgneal@45: bgneal@45: function getDateTime(d, fmt) { bgneal@45: fmt = fmt.replace("%D", "%m/%d/%y"); bgneal@45: fmt = fmt.replace("%r", "%I:%M:%S %p"); bgneal@45: fmt = fmt.replace("%Y", "" + d.getFullYear()); bgneal@45: fmt = fmt.replace("%y", "" + d.getYear()); bgneal@45: fmt = fmt.replace("%m", addZeros(d.getMonth()+1, 2)); bgneal@45: fmt = fmt.replace("%d", addZeros(d.getDate(), 2)); bgneal@45: fmt = fmt.replace("%H", "" + addZeros(d.getHours(), 2)); bgneal@45: fmt = fmt.replace("%M", "" + addZeros(d.getMinutes(), 2)); bgneal@45: fmt = fmt.replace("%S", "" + addZeros(d.getSeconds(), 2)); bgneal@45: fmt = fmt.replace("%I", "" + ((d.getHours() + 11) % 12 + 1)); bgneal@45: fmt = fmt.replace("%p", "" + (d.getHours() < 12 ? "AM" : "PM")); bgneal@45: fmt = fmt.replace("%%", "%"); bgneal@45: bgneal@45: return fmt; bgneal@45: } bgneal@45: bgneal@45: function addZeros(value, len) { bgneal@45: var i; bgneal@45: bgneal@45: value = "" + value; bgneal@45: bgneal@45: if (value.length < len) { bgneal@45: for (i=0; i<(len-value.length); i++) bgneal@45: value = "0" + value; bgneal@45: } bgneal@45: bgneal@45: return value; bgneal@45: } bgneal@45: bgneal@45: function selectByValue(form_obj, field_name, value, add_custom, ignore_case) { bgneal@45: if (!form_obj || !form_obj.elements[field_name]) bgneal@45: return; bgneal@45: bgneal@45: var sel = form_obj.elements[field_name]; bgneal@45: bgneal@45: var found = false; bgneal@45: for (var i=0; i 0) { bgneal@45: tagName = element_name; bgneal@45: bgneal@45: insertInlineElement(element_name); bgneal@45: var elementArray = tinymce.grep(SXE.inst.dom.select(element_name)); bgneal@45: for (var i=0; i -1) ? true : false; bgneal@45: } bgneal@45: bgneal@45: SXE.removeClass = function(elm,cl) { bgneal@45: if(elm.className == null || elm.className == "" || !SXE.containsClass(elm,cl)) { bgneal@45: return true; bgneal@45: } bgneal@45: var classNames = elm.className.split(" "); bgneal@45: var newClassNames = ""; bgneal@45: for (var x = 0, cnl = classNames.length; x < cnl; x++) { bgneal@45: if (classNames[x] != cl) { bgneal@45: newClassNames += (classNames[x] + " "); bgneal@45: } bgneal@45: } bgneal@45: elm.className = newClassNames.substring(0,newClassNames.length-1); //removes extra space at the end bgneal@45: } bgneal@45: bgneal@45: SXE.addClass = function(elm,cl) { bgneal@45: if(!SXE.containsClass(elm,cl)) elm.className ? elm.className += " " + cl : elm.className = cl; bgneal@45: return true; bgneal@45: } bgneal@45: bgneal@45: function insertInlineElement(en) { bgneal@45: var ed = tinyMCEPopup.editor, dom = ed.dom; bgneal@45: bgneal@45: ed.getDoc().execCommand('FontName', false, 'mceinline'); bgneal@45: tinymce.each(dom.select('span,font'), function(n) { bgneal@45: if (n.style.fontFamily == 'mceinline' || n.face == 'mceinline') bgneal@45: dom.replace(dom.create(en, {_mce_new : 1}), n, 1); bgneal@45: }); bgneal@45: }