📄 dynamiccss.js
字号:
/**************************************************************** Copyright notice** (c) 2004 systemconcept.de. Authored by Holger Hees, sponsored by http://www.systemconcept.de.* (c) 2004, 2005 Stanislas Rolland <stanislas.rolland(arobas)fructifor.ca>* All rights reserved** This script is part of the TYPO3 project. The TYPO3 project is* free software; you can redistribute it and/or modify* it under the terms of the GNU General Public License as published by* the Free Software Foundation; either version 2 of the License, or* (at your option) any later version.** The GNU General Public License can be found at* http://www.gnu.org/copyleft/gpl.html.* A copy is found in the textfile GPL.txt and important notices to the license* from the author is found in LICENSE.txt distributed with these scripts.*** This script is distributed in the hope that it will be useful,* but WITHOUT ANY WARRANTY; without even the implied warranty of* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the* GNU General Public License for more details.** This script is a modified version of a script published under the htmlArea License.* A copy of the htmlArea License may be found in the textfile HTMLAREA_LICENSE.txt.** This copyright notice MUST APPEAR in all copies of the script!***************************************************************//* * Dynamic CSS Plugin for TYPO3 htmlArea RTE * * TYPO3 CVS ID: $Id: dynamiccss.js 2556 2007-10-15 15:40:59Z stanrolland $ */DynamicCSS = function(editor,args) { this.editor = editor; var cfg = editor.config; var toolbar = cfg.toolbar; var editorNumber = editor._editorNumber; var obj = { id : "DynamicCSS-class", tooltip : DynamicCSS_langArray["DynamicCSSStyleTooltip"], options : {"":""}, action : null, refresh : null, context : "*", cssArray : new Object(), parseCount : 1, loaded : false, timeout : null, lastTag : "", lastClass : "", showTagFreeClasses : RTEarea[editorNumber]["showTagFreeClasses"], classesUrl : RTEarea[editorNumber]["classesUrl"], classesTag : RTEarea[editorNumber]["classesTag"] }; var actionHandlerFunctRef = DynamicCSS.actionHandler(this, obj); obj.action = actionHandlerFunctRef; var refreshHandlerFunctRef = DynamicCSS.refreshHandler(this); obj.refresh = refreshHandlerFunctRef; cfg.registerDropdown(obj);};DynamicCSS.actionHandler = function(instance,obj) { return (function(editor) { instance.onSelect(editor, obj); });};DynamicCSS.refreshHandler = function(instance) { return (function(editor) { instance.generate(editor); });};DynamicCSS.I18N = DynamicCSS_langArray;DynamicCSS.parseStyleSheet = function(editor) { var obj = editor.config.customSelects["DynamicCSS-class"]; var iframe = editor._iframe.contentWindow ? editor._iframe.contentWindow.document : editor._iframe.contentDocument; var newCssArray = new Object(); obj.loaded = true; for (var i = 0; i < iframe.styleSheets.length; i++) { // Mozilla if(HTMLArea.is_gecko){ try { newCssArray = DynamicCSS.applyCSSRule(editor,DynamicCSS.I18N,iframe.styleSheets[i].cssRules,newCssArray); } catch (e) { obj.loaded = false; } } else { try{ // @import StyleSheets (IE) if (iframe.styleSheets[i].imports) newCssArray = DynamicCSS.applyCSSIEImport(editor,DynamicCSS.I18N,iframe.styleSheets[i].imports,newCssArray); if (iframe.styleSheets[i].rules) newCssArray = DynamicCSS.applyCSSRule(editor,DynamicCSS.I18N,iframe.styleSheets[i].rules,newCssArray); } catch (e) { obj.loaded = false; } } } return newCssArray;};DynamicCSS.applyCSSRule=function(editor,i18n,cssRules,cssArray){ var cssElements = new Array(), cssElement = new Array(), newCssArray = new Object(), classParts = new Array(), tagName, className, rule, k, obj = editor.config.customSelects["DynamicCSS-class"]; newCssArray = cssArray; for (rule = 0; rule < cssRules.length; rule++) { // StyleRule if (cssRules[rule].selectorText) { if (cssRules[rule].selectorText.search(/:+/) == -1) { // split equal Styles e.g. head, body {border:0px} cssElements = cssRules[rule].selectorText.split(","); for (k = 0; k < cssElements.length; k++) { cssElement = cssElements[k].split("."); tagName = cssElement[0].toLowerCase().trim(); if (!tagName) tagName = "all"; className = cssElement[1]; if (className) { classParts = className.trim().split(" "); className = classParts[0]; } if (!HTMLArea.reservedClassNames.test(className) && ((tagName == "all" && obj["showTagFreeClasses"] == true) || (tagName != "all" && (!obj["classesTag"] || !obj["classesTag"][tagName])) || (tagName != "all" && obj["classesTag"][tagName].indexOf(className) != -1)) ) { if (!newCssArray[tagName]) newCssArray[tagName] = new Object(); if (className) { cssName = className; if (HTMLArea.classesLabels) cssName = HTMLArea.classesLabels[className] ? HTMLArea.classesLabels[className] : cssName ; if (tagName != 'all') cssName = '<'+cssName+'>'; } else { className='none'; if (tagName=='all') cssName=i18n["Default"]; else cssName='<'+i18n["Default"]+'>'; } newCssArray[tagName][className]=cssName; } } } } else { // ImportRule (Mozilla) if (cssRules[rule].styleSheet) { newCssArray = DynamicCSS.applyCSSRule(editor, i18n, cssRules[rule].styleSheet.cssRules, newCssArray); } // MediaRule (Mozilla) if (cssRules[rule].cssRules) { newCssArray = DynamicCSS.applyCSSRule(editor, i18n, cssRules[rule].cssRules, newCssArray); } } } return newCssArray;};DynamicCSS.applyCSSIEImport = function(editor,i18n,cssIEImport,cssArray){ var newCssArray = new Object(); newCssArray = cssArray; for(var i=0;i<cssIEImport.length;i++){ if(cssIEImport[i].imports){ newCssArray = DynamicCSS.applyCSSIEImport(editor,i18n,cssIEImport[i].imports,newCssArray); } if(cssIEImport[i].rules){ newCssArray = DynamicCSS.applyCSSRule(editor,i18n,cssIEImport[i].rules,newCssArray); } } return newCssArray;};DynamicCSS._pluginInfo = { name : "DynamicCSS", version : "1.9", developer : "Holger Hees & Stanislas Rolland", developer_url : "http://www.fructifor.ca/", c_owner : "Holger Hees & Stanislas Rolland", sponsor : "System Concept GmbH & Fructifor Inc.", sponsor_url : "http://www.fructifor.ca/", license : "GPL"};DynamicCSS.prototype.getSelectedBlocks = function(editor) { var block, range, i = 0, blocks = []; if (HTMLArea.is_gecko && !HTMLArea.is_safari && !HTMLArea.is_opera) { var sel = editor._getSelection(); try { while (range = sel.getRangeAt(i++)) { block = editor.getParentElement(sel, range); blocks.push(block); } } catch(e) { /* finished walking through selection */ } } else { blocks.push(editor.getParentElement()); } return blocks;};DynamicCSS.prototype.onSelect = function(editor, obj) { var tbobj = editor._toolbarObjects[obj.id]; var index = document.getElementById(tbobj.elementId).selectedIndex; var className = document.getElementById(tbobj.elementId).value; editor.focusEditor(); var blocks = this.getSelectedBlocks(editor); for (var k = 0; k < blocks.length; ++k) { var parent = blocks[k]; while (typeof(parent) != "undefined" && !HTMLArea.isBlockElement(parent) && parent.nodeName.toLowerCase() != "img") parent = parent.parentNode; if (!k) var tagName = parent.tagName.toLowerCase(); if (parent.tagName.toLowerCase() == tagName) { var cls = parent.className.trim().split(" "); for (var i = cls.length; i > 0;) if(!HTMLArea.reservedClassNames.test(cls[--i])) HTMLArea._removeClass(parent,cls[i]); if(className != 'none'){ HTMLArea._addClass(parent,className); obj.lastClass = className; } } } editor.updateToolbar();};DynamicCSS.prototype.onGenerate = function() { var editor = this.editor; var obj = editor.config.customSelects["DynamicCSS-class"]; if(HTMLArea.is_gecko) this.generate(editor);};DynamicCSS.prototype.onUpdateToolbar = function() { var editor = this.editor; var obj = editor.config.customSelects["DynamicCSS-class"]; if (HTMLArea.is_gecko && editor._editMode != "textmode") { if(obj.loaded) { this.updateValue(editor,obj); } else { if(obj.timeout) { if(editor._iframe.contentWindow) { editor._iframe.contentWindow.clearTimeout(obj.timeout); } else { window.clearTimeout(obj.timeout); } obj.timeout = null; } this.generate(editor); } } else if (editor._editMode == "textmode") { var select = document.getElementById(editor._toolbarObjects[obj.id].elementId); select.disabled = true; select.className = "buttonDisabled"; }};DynamicCSS.prototype.generate = function(editor) { var obj = editor.config.customSelects["DynamicCSS-class"]; var classesUrl = obj["classesUrl"]; if (classesUrl && typeof(HTMLArea.classesLabels) == "undefined") { var classesData = HTMLArea._getScript(0, false, classesUrl); if (classesData) eval(classesData); } // Let us load the style sheets if(obj.loaded) this.updateValue(editor,obj); else this.getCSSArray(editor);};DynamicCSS.prototype.getCSSArray = function(editor) { var obj = editor.config.customSelects["DynamicCSS-class"]; obj.cssArray = DynamicCSS.parseStyleSheet(editor); if( !obj.loaded && obj.parseCount<17 ) { var getCSSArrayLaterFunctRef = DynamicCSS.getCSSArrayLater(editor, this); obj.timeout = editor._iframe.contentWindow ? editor._iframe.contentWindow.setTimeout(getCSSArrayLaterFunctRef, 200) : window.setTimeout(getCSSArrayLaterFunctRef, 200); obj.parseCount++ ; } else { obj.timeout = null; obj.loaded = true; this.updateValue(editor,obj); }};DynamicCSS.getCSSArrayLater = function(editor,instance) { return (function() { instance.getCSSArray(editor); });};DynamicCSS.prototype.onMode = function(mode) { var editor = this.editor; if (mode == 'wysiwyg'){ var obj = editor.config.customSelects["DynamicCSS-class"]; if (obj.loaded) { this.updateValue(editor,obj); } else { if(obj.timeout) { if (editor._iframe.contentWindow) editor._iframe.contentWindow.clearTimeout(obj.timeout); else window.clearTimeout(obj.timeout); obj.timeout = null; } this.generate(editor); } }};DynamicCSS.prototype.updateValue = function(editor,obj) { var cssClass, i; if(!obj.loaded) { if(obj.timeout) { if(editor._iframe.contentWindow) editor._iframe.contentWindow.clearTimeout(obj.timeout); else window.clearTimeout(obj.timeout); obj.timeout = null; } this.generate(editor); } var cssArray = obj.cssArray; var tagName = "body"; var className = ""; var parent = editor.getParentElement(); while(parent && typeof(parent) != "undefined" && !HTMLArea.isBlockElement(parent) && parent.nodeName.toLowerCase() != "img") parent = parent.parentNode; if(parent) { tagName = parent.nodeName.toLowerCase(); className = parent.className; if(HTMLArea.reservedClassNames.test(className)) { var cls = className.split(" "); for(var i = cls.length; i > 0;) if(!HTMLArea.reservedClassNames.test(cls[--i])) className = cls[i]; } } if(obj.lastTag != tagName || obj.lastClass != className){ obj.lastTag = tagName; obj.lastClass = className; var select = document.getElementById(editor._toolbarObjects[obj.id].elementId); while(select.options.length>0) select.options[select.length-1] = null; select.options[0]=new Option(DynamicCSS.I18N["Default"],'none'); if(cssArray){ // style class only allowed if parent tag is not body or editor is in fullpage mode if(tagName != 'body' || editor.config.fullPage){ if(cssArray[tagName]){ for(cssClass in cssArray[tagName]){ if(cssClass == 'none') { select.options[0] = new Option(cssArray[tagName][cssClass],cssClass); } else { select.options[select.options.length] = new Option(cssArray[tagName][cssClass],cssClass); if (!editor.config.disablePCexamples && HTMLArea.classesValues && HTMLArea.classesValues[cssClass] && !HTMLArea.classesNoShow[cssClass]) select.options[select.options.length-1].setAttribute("style", HTMLArea.classesValues[cssClass]); } } } if(cssArray['all']){ for(cssClass in cssArray['all']){ select.options[select.options.length] = new Option(cssArray['all'][cssClass],cssClass); if (!editor.config.disablePCexamples && HTMLArea.classesValues && HTMLArea.classesValues[cssClass] && !HTMLArea.classesNoShow[cssClass]) select.options[select.options.length-1].setAttribute("style", HTMLArea.classesValues[cssClass]); } } } else { if(cssArray[tagName] && cssArray[tagName]['none']) select.options[0] = new Option(cssArray[tagName]['none'],'none'); } } select.selectedIndex = 0; if (typeof(className) != "undefined" && /\S/.test(className) && !HTMLArea.reservedClassNames.test(className) ) { for (i = select.options.length; --i >= 0;) { var option = select.options[i]; if (className == option.value) { select.selectedIndex = i; break; } } if (select.selectedIndex == 0) { select.options[select.options.length] = new Option(DynamicCSS.I18N["Undefined"],className); select.selectedIndex = select.options.length-1; } } if (select.options.length > 1) { select.disabled = false; } else select.disabled = true; if(HTMLArea.is_gecko) select.removeAttribute('class'); else select.removeAttribute('className'); if (select.disabled) HTMLArea._addClass(select, "buttonDisabled"); }};
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -