bgneal@45: /* Functions for the advlink plugin popup */ bgneal@45: bgneal@45: tinyMCEPopup.requireLangPack(); bgneal@45: bgneal@45: var templates = { bgneal@45: "window.open" : "window.open('${url}','${target}','${options}')" bgneal@45: }; bgneal@45: bgneal@45: function preinit() { bgneal@45: var url; bgneal@45: bgneal@45: if (url = tinyMCEPopup.getParam("external_link_list_url")) bgneal@45: document.write(''); bgneal@45: } bgneal@45: bgneal@45: function changeClass() { bgneal@45: var f = document.forms[0]; bgneal@45: bgneal@45: f.classes.value = getSelectValue(f, 'classlist'); bgneal@45: } bgneal@45: bgneal@45: function init() { bgneal@45: tinyMCEPopup.resizeToInnerSize(); bgneal@45: bgneal@45: var formObj = document.forms[0]; bgneal@45: var inst = tinyMCEPopup.editor; bgneal@45: var elm = inst.selection.getNode(); bgneal@45: var action = "insert"; bgneal@45: var html; bgneal@45: bgneal@45: document.getElementById('hrefbrowsercontainer').innerHTML = getBrowserHTML('hrefbrowser','href','file','advlink'); bgneal@45: document.getElementById('popupurlbrowsercontainer').innerHTML = getBrowserHTML('popupurlbrowser','popupurl','file','advlink'); bgneal@45: document.getElementById('linklisthrefcontainer').innerHTML = getLinkListHTML('linklisthref','href'); bgneal@45: document.getElementById('anchorlistcontainer').innerHTML = getAnchorListHTML('anchorlist','href'); bgneal@45: document.getElementById('targetlistcontainer').innerHTML = getTargetListHTML('targetlist','target'); bgneal@45: bgneal@45: // Link list bgneal@45: html = getLinkListHTML('linklisthref','href'); bgneal@45: if (html == "") bgneal@45: document.getElementById("linklisthrefrow").style.display = 'none'; bgneal@45: else bgneal@45: document.getElementById("linklisthrefcontainer").innerHTML = html; bgneal@45: bgneal@45: // Resize some elements bgneal@45: if (isVisible('hrefbrowser')) bgneal@45: document.getElementById('href').style.width = '260px'; bgneal@45: bgneal@45: if (isVisible('popupurlbrowser')) bgneal@45: document.getElementById('popupurl').style.width = '180px'; bgneal@45: bgneal@45: elm = inst.dom.getParent(elm, "A"); bgneal@45: if (elm != null && elm.nodeName == "A") bgneal@45: action = "update"; bgneal@45: bgneal@45: formObj.insert.value = tinyMCEPopup.getLang(action, 'Insert', true); bgneal@45: bgneal@45: setPopupControlsDisabled(true); bgneal@45: bgneal@45: if (action == "update") { bgneal@45: var href = inst.dom.getAttrib(elm, 'href'); bgneal@45: var onclick = inst.dom.getAttrib(elm, 'onclick'); bgneal@45: bgneal@45: // Setup form data bgneal@45: setFormValue('href', href); bgneal@45: setFormValue('title', inst.dom.getAttrib(elm, 'title')); bgneal@45: setFormValue('id', inst.dom.getAttrib(elm, 'id')); bgneal@45: setFormValue('style', inst.dom.getAttrib(elm, "style")); bgneal@45: setFormValue('rel', inst.dom.getAttrib(elm, 'rel')); bgneal@45: setFormValue('rev', inst.dom.getAttrib(elm, 'rev')); bgneal@45: setFormValue('charset', inst.dom.getAttrib(elm, 'charset')); bgneal@45: setFormValue('hreflang', inst.dom.getAttrib(elm, 'hreflang')); bgneal@45: setFormValue('dir', inst.dom.getAttrib(elm, 'dir')); bgneal@45: setFormValue('lang', inst.dom.getAttrib(elm, 'lang')); bgneal@45: setFormValue('tabindex', inst.dom.getAttrib(elm, 'tabindex', typeof(elm.tabindex) != "undefined" ? elm.tabindex : "")); bgneal@45: setFormValue('accesskey', inst.dom.getAttrib(elm, 'accesskey', typeof(elm.accesskey) != "undefined" ? elm.accesskey : "")); bgneal@45: setFormValue('type', inst.dom.getAttrib(elm, 'type')); bgneal@45: setFormValue('onfocus', inst.dom.getAttrib(elm, 'onfocus')); bgneal@45: setFormValue('onblur', inst.dom.getAttrib(elm, 'onblur')); bgneal@45: setFormValue('onclick', onclick); bgneal@45: setFormValue('ondblclick', inst.dom.getAttrib(elm, 'ondblclick')); bgneal@45: setFormValue('onmousedown', inst.dom.getAttrib(elm, 'onmousedown')); bgneal@45: setFormValue('onmouseup', inst.dom.getAttrib(elm, 'onmouseup')); bgneal@45: setFormValue('onmouseover', inst.dom.getAttrib(elm, 'onmouseover')); bgneal@45: setFormValue('onmousemove', inst.dom.getAttrib(elm, 'onmousemove')); bgneal@45: setFormValue('onmouseout', inst.dom.getAttrib(elm, 'onmouseout')); bgneal@45: setFormValue('onkeypress', inst.dom.getAttrib(elm, 'onkeypress')); bgneal@45: setFormValue('onkeydown', inst.dom.getAttrib(elm, 'onkeydown')); bgneal@45: setFormValue('onkeyup', inst.dom.getAttrib(elm, 'onkeyup')); bgneal@45: setFormValue('target', inst.dom.getAttrib(elm, 'target')); bgneal@45: setFormValue('classes', inst.dom.getAttrib(elm, 'class')); bgneal@45: bgneal@45: // Parse onclick data bgneal@45: if (onclick != null && onclick.indexOf('window.open') != -1) bgneal@45: parseWindowOpen(onclick); bgneal@45: else bgneal@45: parseFunction(onclick); bgneal@45: bgneal@45: // Select by the values bgneal@45: selectByValue(formObj, 'dir', inst.dom.getAttrib(elm, 'dir')); bgneal@45: selectByValue(formObj, 'rel', inst.dom.getAttrib(elm, 'rel')); bgneal@45: selectByValue(formObj, 'rev', inst.dom.getAttrib(elm, 'rev')); bgneal@45: selectByValue(formObj, 'linklisthref', href); bgneal@45: bgneal@45: if (href.charAt(0) == '#') bgneal@45: selectByValue(formObj, 'anchorlist', href); bgneal@45: bgneal@45: addClassesToList('classlist', 'advlink_styles'); bgneal@45: bgneal@45: selectByValue(formObj, 'classlist', inst.dom.getAttrib(elm, 'class'), true); bgneal@45: selectByValue(formObj, 'targetlist', inst.dom.getAttrib(elm, 'target'), true); bgneal@45: } else bgneal@45: addClassesToList('classlist', 'advlink_styles'); bgneal@45: } bgneal@45: bgneal@45: function checkPrefix(n) { bgneal@45: if (n.value && Validator.isEmail(n) && !/^\s*mailto:/i.test(n.value) && confirm(tinyMCEPopup.getLang('advlink_dlg.is_email'))) bgneal@45: n.value = 'mailto:' + n.value; bgneal@45: bgneal@45: if (/^\s*www\./i.test(n.value) && confirm(tinyMCEPopup.getLang('advlink_dlg.is_external'))) bgneal@45: n.value = 'http://' + n.value; bgneal@45: } bgneal@45: bgneal@45: function setFormValue(name, value) { bgneal@45: document.forms[0].elements[name].value = value; bgneal@45: } bgneal@45: bgneal@45: function parseWindowOpen(onclick) { bgneal@45: var formObj = document.forms[0]; bgneal@45: bgneal@45: // Preprocess center code bgneal@45: if (onclick.indexOf('return false;') != -1) { bgneal@45: formObj.popupreturn.checked = true; bgneal@45: onclick = onclick.replace('return false;', ''); bgneal@45: } else bgneal@45: formObj.popupreturn.checked = false; bgneal@45: bgneal@45: var onClickData = parseLink(onclick); bgneal@45: bgneal@45: if (onClickData != null) { bgneal@45: formObj.ispopup.checked = true; bgneal@45: setPopupControlsDisabled(false); bgneal@45: bgneal@45: var onClickWindowOptions = parseOptions(onClickData['options']); bgneal@45: var url = onClickData['url']; bgneal@45: bgneal@45: formObj.popupname.value = onClickData['target']; bgneal@45: formObj.popupurl.value = url; bgneal@45: formObj.popupwidth.value = getOption(onClickWindowOptions, 'width'); bgneal@45: formObj.popupheight.value = getOption(onClickWindowOptions, 'height'); bgneal@45: bgneal@45: formObj.popupleft.value = getOption(onClickWindowOptions, 'left'); bgneal@45: formObj.popuptop.value = getOption(onClickWindowOptions, 'top'); bgneal@45: bgneal@45: if (formObj.popupleft.value.indexOf('screen') != -1) bgneal@45: formObj.popupleft.value = "c"; bgneal@45: bgneal@45: if (formObj.popuptop.value.indexOf('screen') != -1) bgneal@45: formObj.popuptop.value = "c"; bgneal@45: bgneal@45: formObj.popuplocation.checked = getOption(onClickWindowOptions, 'location') == "yes"; bgneal@45: formObj.popupscrollbars.checked = getOption(onClickWindowOptions, 'scrollbars') == "yes"; bgneal@45: formObj.popupmenubar.checked = getOption(onClickWindowOptions, 'menubar') == "yes"; bgneal@45: formObj.popupresizable.checked = getOption(onClickWindowOptions, 'resizable') == "yes"; bgneal@45: formObj.popuptoolbar.checked = getOption(onClickWindowOptions, 'toolbar') == "yes"; bgneal@45: formObj.popupstatus.checked = getOption(onClickWindowOptions, 'status') == "yes"; bgneal@45: formObj.popupdependent.checked = getOption(onClickWindowOptions, 'dependent') == "yes"; bgneal@45: bgneal@45: buildOnClick(); bgneal@45: } bgneal@45: } bgneal@45: bgneal@45: function parseFunction(onclick) { bgneal@45: var formObj = document.forms[0]; bgneal@45: var onClickData = parseLink(onclick); bgneal@45: bgneal@45: // TODO: Add stuff here bgneal@45: } bgneal@45: bgneal@45: function getOption(opts, name) { bgneal@45: return typeof(opts[name]) == "undefined" ? "" : opts[name]; bgneal@45: } bgneal@45: bgneal@45: function setPopupControlsDisabled(state) { bgneal@45: var formObj = document.forms[0]; bgneal@45: bgneal@45: formObj.popupname.disabled = state; bgneal@45: formObj.popupurl.disabled = state; bgneal@45: formObj.popupwidth.disabled = state; bgneal@45: formObj.popupheight.disabled = state; bgneal@45: formObj.popupleft.disabled = state; bgneal@45: formObj.popuptop.disabled = state; bgneal@45: formObj.popuplocation.disabled = state; bgneal@45: formObj.popupscrollbars.disabled = state; bgneal@45: formObj.popupmenubar.disabled = state; bgneal@45: formObj.popupresizable.disabled = state; bgneal@45: formObj.popuptoolbar.disabled = state; bgneal@45: formObj.popupstatus.disabled = state; bgneal@45: formObj.popupreturn.disabled = state; bgneal@45: formObj.popupdependent.disabled = state; bgneal@45: bgneal@45: setBrowserDisabled('popupurlbrowser', state); bgneal@45: } bgneal@45: bgneal@45: function parseLink(link) { bgneal@45: link = link.replace(new RegExp(''', 'g'), "'"); bgneal@45: bgneal@45: var fnName = link.replace(new RegExp("\\s*([A-Za-z0-9\.]*)\\s*\\(.*", "gi"), "$1"); bgneal@45: bgneal@45: // Is function name a template function bgneal@45: var template = templates[fnName]; bgneal@45: if (template) { bgneal@45: // Build regexp bgneal@45: var variableNames = template.match(new RegExp("'?\\$\\{[A-Za-z0-9\.]*\\}'?", "gi")); bgneal@45: var regExp = "\\s*[A-Za-z0-9\.]*\\s*\\("; bgneal@45: var replaceStr = ""; bgneal@45: for (var i=0; i'); bgneal@45: for (var i=0; i'; bgneal@45: html += ''; bgneal@45: bgneal@45: for (i=0; i' + name + ''; bgneal@45: } bgneal@45: bgneal@45: html += ''; bgneal@45: bgneal@45: return html; bgneal@45: } bgneal@45: bgneal@45: function insertAction() { bgneal@45: var inst = tinyMCEPopup.editor; bgneal@45: var elm, elementArray, i; bgneal@45: bgneal@45: elm = inst.selection.getNode(); bgneal@45: checkPrefix(document.forms[0].href); bgneal@45: bgneal@45: elm = inst.dom.getParent(elm, "A"); bgneal@45: bgneal@45: // Remove element if there is no href bgneal@45: if (!document.forms[0].href.value) { bgneal@45: tinyMCEPopup.execCommand("mceBeginUndoLevel"); bgneal@45: i = inst.selection.getBookmark(); bgneal@45: inst.dom.remove(elm, 1); bgneal@45: inst.selection.moveToBookmark(i); bgneal@45: tinyMCEPopup.execCommand("mceEndUndoLevel"); bgneal@45: tinyMCEPopup.close(); bgneal@45: return; bgneal@45: } bgneal@45: bgneal@45: tinyMCEPopup.execCommand("mceBeginUndoLevel"); bgneal@45: bgneal@45: // Create new anchor elements bgneal@45: if (elm == null) { bgneal@45: inst.getDoc().execCommand("unlink", false, null); bgneal@45: tinyMCEPopup.execCommand("CreateLink", false, "#mce_temp_url#", {skip_undo : 1}); bgneal@45: bgneal@45: elementArray = tinymce.grep(inst.dom.select("a"), function(n) {return inst.dom.getAttrib(n, 'href') == '#mce_temp_url#';}); bgneal@45: for (i=0; i' + tinyMCELinkList[i][0] + ''; bgneal@45: bgneal@45: html += ''; bgneal@45: bgneal@45: return html; bgneal@45: bgneal@45: // tinyMCE.debug('-- image list start --', html, '-- image list end --'); bgneal@45: } bgneal@45: bgneal@45: function getTargetListHTML(elm_id, target_form_element) { bgneal@45: var targets = tinyMCEPopup.getParam('theme_advanced_link_targets', '').split(';'); bgneal@45: var html = ''; bgneal@45: bgneal@45: html += ''; bgneal@45: bgneal@45: return html; bgneal@45: } bgneal@45: bgneal@45: // While loading bgneal@45: preinit(); bgneal@45: tinyMCEPopup.onInit.add(init);