diff --git a/application/classes/controller/applicationBlog.php b/application/classes/controller/applicationBlog.php index 20bde7e..d91ff7e 100644 --- a/application/classes/controller/applicationBlog.php +++ b/application/classes/controller/applicationBlog.php @@ -2,7 +2,7 @@ abstract class Controller_ApplicationBlog extends Controller_Template{ - public $template = 'site/template_blog'; + public $template = 'layouts/template_blog'; public function before(){ @@ -11,10 +11,6 @@ public function before(){ parent::before(); View::set_global('site_name', 'Blog com Kohana 3.2'); View::set_global('description', 'Exemplo de blog usando framework kohana'); - View::set_global('X_UA_Compatible', 'IE=edge,chrome=1'); - View::set_global('viewport', 'width=device-width,initial-scale=1'); - View::set_global('author', 'Fabian Carlos'); - View::set_global('reply_to', 'fabian.pow@gmail.com'); View::set_global('shortcut_icon', $icon); $this->template->content = ''; diff --git a/application/views/site/template_blog.php b/application/views/layouts/template_blog.php similarity index 67% rename from application/views/site/template_blog.php rename to application/views/layouts/template_blog.php index c69f2ed..b362feb 100644 --- a/application/views/site/template_blog.php +++ b/application/views/layouts/template_blog.php @@ -2,12 +2,6 @@ - - - - - - <?php echo $site_name; ?> @@ -17,16 +11,13 @@ - - + + - - - - - - -

- CKEditor - Adobe AIR Sample -

-

- This is a sample HTML/JavaScript Adobe AIR application with CKEditor with default features. -

-

- - -

- - - diff --git a/media/ckeditor/_samples/ajax.html b/media/ckeditor/_samples/ajax.html deleted file mode 100644 index 53d853e..0000000 --- a/media/ckeditor/_samples/ajax.html +++ /dev/null @@ -1,98 +0,0 @@ - - - - - Ajax — CKEditor Sample - - - - - - - -

- CKEditor Sample — Create and Destroy Editor Instances for Ajax Applications -

-
-

- This sample shows how to create and destroy CKEditor instances on the fly. After the removal of CKEditor the content created inside the editing - area will be displayed in a <div> element. -

-

- For details of how to create this setup check the source code of this sample page - for JavaScript code responsible for the creation and destruction of a CKEditor instance. -

-
- - -
- -
-

Click the buttons to create and remove a CKEditor instance.

-

- - -

- -
-
- - - - diff --git a/media/ckeditor/_samples/api.html b/media/ckeditor/_samples/api.html deleted file mode 100644 index 98ad687..0000000 --- a/media/ckeditor/_samples/api.html +++ /dev/null @@ -1,192 +0,0 @@ - - - - - API Usage — CKEditor Sample - - - - - - - - -

- CKEditor Sample — Using CKEditor JavaScript API -

-
-

- This sample shows how to use the - CKEditor JavaScript API - to interact with the editor at runtime. -

-

- For details on how to create this setup check the source code of this sample page. -

-
- - -
- -
-
- - - - -
-
- -
- - - diff --git a/media/ckeditor/_samples/api_dialog.html b/media/ckeditor/_samples/api_dialog.html deleted file mode 100644 index f64d5a7..0000000 --- a/media/ckeditor/_samples/api_dialog.html +++ /dev/null @@ -1,198 +0,0 @@ - - - - - Using API to Customize Dialog Windows — CKEditor Sample - - - - - - - - - -

- CKEditor Sample — Using CKEditor Dialog API -

-
-

- This sample shows how to use the - CKEditor Dialog API - to customize CKEditor dialog windows without changing the original editor code. - The following customizations are being done in the example below: -

-
    -
  1. Adding dialog window tabs – "My Tab" in the "Link" dialog window.
  2. -
  3. Removing a dialog window tab – "Target" tab from the "Link" dialog window.
  4. -
  5. Adding dialog window fields – "My Custom Field" in the "Link" dialog window.
  6. -
  7. Removing dialog window fields – "Link Type" and "Browse Server" in the "Link" - dialog window.
  8. -
  9. Setting default values for dialog window fields – "URL" field in the - "Link" dialog window.
  10. -
  11. Creating a custom dialog window – "My Dialog" dialog window opened with the "My Dialog" toolbar button.
  12. -
-

-For details on how to create this setup check the source code of this sample page. -

-
- - - -
- -
- - - - - - diff --git a/media/ckeditor/_samples/api_dialog/my_dialog.js b/media/ckeditor/_samples/api_dialog/my_dialog.js deleted file mode 100644 index 36f44be..0000000 --- a/media/ckeditor/_samples/api_dialog/my_dialog.js +++ /dev/null @@ -1,28 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -CKEDITOR.dialog.add( 'myDialog', function( editor ) -{ - return { - title : 'My Dialog', - minWidth : 400, - minHeight : 200, - contents : [ - { - id : 'tab1', - label : 'First Tab', - title : 'First Tab', - elements : - [ - { - id : 'input1', - type : 'text', - label : 'Input 1' - } - ] - } - ] - }; -} ); diff --git a/media/ckeditor/_samples/asp/advanced.asp b/media/ckeditor/_samples/asp/advanced.asp deleted file mode 100644 index 6e65312..0000000 --- a/media/ckeditor/_samples/asp/advanced.asp +++ /dev/null @@ -1,105 +0,0 @@ -<%@ codepage="65001" language="VBScript" %> -<% Option Explicit %> - -<% - - ' You must set "Enable Parent Paths" on your web site - ' in order for the above relative include to work. - ' Or you can use #INCLUDE VIRTUAL="/full path/ckeditor.asp" - -%> - - - - - Sample - CKEditor - - - - -

- CKEditor Sample -

- -
- -
- -
- Output -
-

-
-

-<% - ' Create class instance. - dim editor, initialValue, code, textareaAttributes - set editor = New CKEditor - - ' Do not print the code directly to the browser, return it instead - editor.returnOutput = true - - ' Path to CKEditor directory, ideally instead of relative dir, use an absolute path: - ' editor.basePath = "/ckeditor/" - ' If not set, CKEditor will default to /ckeditor/ - editor.basePath = "../../" - - ' Set global configuration (will be used by all instances of CKEditor). - editor.config("width") = 600 - - ' Change default textarea attributes - set textareaAttributes = CreateObject("Scripting.Dictionary") - textareaAttributes.Add "rows", 10 - textareaAttributes.Add "cols", 80 - Set editor.textareaAttributes = textareaAttributes - - ' The initial value to be displayed in the editor. - initialValue = "

This is some sample text. You are using CKEditor.

" - - ' Create first instance. - code = editor.editor("editor1", initialValue) - - response.write code -%> -

-
-

-<% -' Configuration that will be used only by the second editor. - -editor.instanceConfig("toolbar") = Array( _ - Array( "Source", "-", "Bold", "Italic", "Underline", "Strike" ), _ - Array( "Image", "Link", "Unlink", "Anchor" ) _ - ) - -editor.instanceConfig("skin") = "v2" - -' Create second instance. -response.write editor.editor("editor2", initialValue) -%> -

- -

-
-
- - - diff --git a/media/ckeditor/_samples/asp/events.asp b/media/ckeditor/_samples/asp/events.asp deleted file mode 100644 index be1dc3e..0000000 --- a/media/ckeditor/_samples/asp/events.asp +++ /dev/null @@ -1,136 +0,0 @@ -<%@ codepage="65001" language="VBScript" %> -<% Option Explicit %> - -<% - - ' You must set "Enable Parent Paths" on your web site - ' in order for the above relative include to work. - ' Or you can use #INCLUDE VIRTUAL="/full path/ckeditor.asp" - -%> - - - - - Sample - CKEditor - - - - -

- CKEditor Sample -

- -
- -
- -
- Output -
-

-
-

-<% - -'' - ' Adds global event, will hide "Target" tab in Link dialog in all instances. - ' -function CKEditorHideLinkTargetTab(editor) - dim functionCode - functionCode = "function (ev) {" & vbcrlf & _ - "// Take the dialog name and its definition from the event data" & vbcrlf & _ - "var dialogName = ev.data.name;" & vbcrlf & _ - "var dialogDefinition = ev.data.definition;" & vbcrlf & _ - "" & vbcrlf & _ - "// Check if the definition is from the Link dialog." & vbcrlf & _ - "if ( dialogName == 'link' )" & vbcrlf & _ - " dialogDefinition.removeContents('target')" & vbcrlf & _ - "}" & vbcrlf - - editor.addGlobalEventHandler "dialogDefinition", functionCode -end function - -'' - ' Adds global event, will notify about opened dialog. - ' -function CKEditorNotifyAboutOpenedDialog(editor) - dim functionCode - functionCode = "function (evt) {" & vbcrlf & _ - "alert('Loading dialog: ' + evt.data.name);" & vbcrlf & _ - "}" - - editor.addGlobalEventHandler "dialogDefinition", functionCode -end function - - -dim editor, initialValue - -' Create class instance. -set editor = new CKEditor - -' Set configuration option for all editors. -editor.config("width") = 750 - -' Path to CKEditor directory, ideally instead of relative dir, use an absolute path: -' editor.basePath = "/ckeditor/" -' If not set, CKEditor will default to /ckeditor/ -editor.basePath = "../../" - -' The initial value to be displayed in the editor. -initialValue = "

This is some sample text. You are using CKEditor.

" - -' Event that will be handled only by the first editor. -editor.addEventHandler "instanceReady", "function (evt) { alert('Loaded editor: ' + evt.editor.name );}" - -' Create first instance. -editor.editor "editor1", initialValue - -' Clear event handlers, instances that will be created later will not have -' the 'instanceReady' listener defined a couple of lines above. -editor.clearEventHandlers empty -%> -

-
-

-<% -' Configuration that will be used only by the second editor. -editor.instanceConfig("width") = 600 -editor.instanceConfig("toolbar") = "Basic" - -' Add some global event handlers (for all editors). -CKEditorHideLinkTargetTab(editor) -CKEditorNotifyAboutOpenedDialog(editor) - -' Event that will be handled only by the second editor. -editor.addInstanceEventHandler "instanceReady", "function (evt) { alert('Loaded second editor: ' + evt.editor.name );}" - -' Create second instance. -editor.editor "editor2", initialValue -%> -

- -

-
-
- - - diff --git a/media/ckeditor/_samples/asp/index.html b/media/ckeditor/_samples/asp/index.html deleted file mode 100644 index d0d51ef..0000000 --- a/media/ckeditor/_samples/asp/index.html +++ /dev/null @@ -1,103 +0,0 @@ - - - - - ASP integration Samples List — CKEditor - - - -

- CKEditor Samples List for ASP — CKEditor Sample -

-

- Overview -

-

The ckeditor.asp file provides a wrapper to ease the work of creating CKEditor instances from classic Asp.

-

To use it, you must first include it into your page: - - <!-- #INCLUDE file="../../ckeditor.asp" --> - - Of course, you should adjust the path to make it point to the correct location, and maybe use a full path (with virtual="" instead of file="") -

-

After that script is included, you can use it in different ways, based on the following pattern:

- -
    -
  1. - Create an instance of the CKEditor class: -
    dim editor
    -set editor = New CKEditor
    -
  2. -
  3. - Set the path to the folder where CKEditor has been installed, by default it will use /ckeditor/ -
    editor.basePath = "../../"
    -
  4. -
  5. - Now use one of the three main methods to create the CKEditor instances: - -
  6. -
-

Before step 3 you can use a number of methods and properties to adjust the behavior of this class and the CKEditor instances -that will be created:

- - -

- Basic Samples -

- -

- Advanced Samples -

- - - - diff --git a/media/ckeditor/_samples/asp/replace.asp b/media/ckeditor/_samples/asp/replace.asp deleted file mode 100644 index 4cfe04c..0000000 --- a/media/ckeditor/_samples/asp/replace.asp +++ /dev/null @@ -1,72 +0,0 @@ -<%@ codepage="65001" language="VBScript" %> -<% Option Explicit %> - -<% - - ' You must set "Enable Parent Paths" on your web site - ' in order for the above relative include to work. - ' Or you can use #INCLUDE VIRTUAL="/full path/ckeditor.asp" - -%> - - - - - Sample - CKEditor - - - - -

- CKEditor Sample -

- -
- -
- -
- Output -
-

-
- -

-

- -

-
-
- - <% - ' Create class instance. - dim editor - set editor = New CKEditor - ' Path to CKEditor directory, ideally instead of relative dir, use an absolute path: - ' editor.basePath = "/ckeditor/" - ' If not set, CKEditor will default to /ckeditor/ - editor.basePath = "../../" - ' Replace textarea with id (or name) "editor1". - editor.replaceInstance "editor1" - %> - - diff --git a/media/ckeditor/_samples/asp/replaceall.asp b/media/ckeditor/_samples/asp/replaceall.asp deleted file mode 100644 index 3160396..0000000 --- a/media/ckeditor/_samples/asp/replaceall.asp +++ /dev/null @@ -1,77 +0,0 @@ -<%@ codepage="65001" language="VBScript" %> -<% Option Explicit %> - -<% - - ' You must set "Enable Parent Paths" on your web site - ' in order for the above relative include to work. - ' Or you can use #INCLUDE VIRTUAL="/full path/ckeditor.asp" - -%> - - - - - Sample - CKEditor - - - - -

- CKEditor Sample -

- -
- -
- -
- Output -
-

-
- -

-

-
- -

-

- -

-
-
- - <% - ' Create class instance. - dim editor - set editor = New CKEditor - ' Path to CKEditor directory, ideally instead of relative dir, use an absolute path: - ' editor.basePath = "/ckeditor/" - ' If not set, CKEditor will default to /ckeditor/ - editor.basePath = "../../" - ' Replace all textareas with CKEditor. - editor.replaceAll empty - %> - - diff --git a/media/ckeditor/_samples/asp/sample_posteddata.asp b/media/ckeditor/_samples/asp/sample_posteddata.asp deleted file mode 100644 index ded6c69..0000000 --- a/media/ckeditor/_samples/asp/sample_posteddata.asp +++ /dev/null @@ -1,46 +0,0 @@ -<%@ codepage="65001" language="VBScript" %> -<% Option Explicit %> - - - - - Sample - CKEditor - - - - -

- CKEditor - Posted Data -

- - - - - - - - - <% - Dim sForm - For Each sForm in Request.Form - %> - - - - - <% Next %> -
Field NameValue
<%=Server.HTMLEncode( sForm )%>
<%=Server.HTMLEncode( Request.Form(sForm) )%>
- - - diff --git a/media/ckeditor/_samples/asp/standalone.asp b/media/ckeditor/_samples/asp/standalone.asp deleted file mode 100644 index e80f6eb..0000000 --- a/media/ckeditor/_samples/asp/standalone.asp +++ /dev/null @@ -1,72 +0,0 @@ -<%@ codepage="65001" language="VBScript" %> -<% Option Explicit %> - -<% - - ' You must set "Enable Parent Paths" on your web site - ' in order for the above relative include to work. - ' Or you can use #INCLUDE VIRTUAL="/full path/ckeditor.asp" - -%> - - - - - Sample - CKEditor - - - - -

- CKEditor Sample -

- -
- -
- -
- Output -
-

- Editor 1: -

-

- <% - dim initialValue, editor - ' The initial value to be displayed in the editor. - initialValue = "

This is some sample text.

" - ' Create class instance. - set editor = New CKEditor - ' Path to CKEditor directory, ideally instead of relative dir, use an absolute path: - ' editor.basePath = "/ckeditor/" - ' If not set, CKEditor will default to /ckeditor/ - editor.basePath = "../../" - ' Create textarea element and attach CKEditor to it. - editor.editor "editor1", initialValue - %> - -

-
-
- - - diff --git a/media/ckeditor/_samples/assets/_posteddata.php b/media/ckeditor/_samples/assets/_posteddata.php deleted file mode 100644 index 61521fe..0000000 --- a/media/ckeditor/_samples/assets/_posteddata.php +++ /dev/null @@ -1,59 +0,0 @@ - - - - - Sample — CKEditor - - - - -

- CKEditor — Posted Data -

- - - - - - - - - $value ) -{ - if ( get_magic_quotes_gpc() ) - $postedValue = htmlspecialchars( stripslashes( $value ) ) ; - else - $postedValue = htmlspecialchars( $value ) ; - -?> - - - - - -
Field NameValue
- - - diff --git a/media/ckeditor/_samples/assets/output_for_flash.fla b/media/ckeditor/_samples/assets/output_for_flash.fla deleted file mode 100644 index 27e68cc..0000000 Binary files a/media/ckeditor/_samples/assets/output_for_flash.fla and /dev/null differ diff --git a/media/ckeditor/_samples/assets/output_for_flash.swf b/media/ckeditor/_samples/assets/output_for_flash.swf deleted file mode 100644 index dbe17b6..0000000 Binary files a/media/ckeditor/_samples/assets/output_for_flash.swf and /dev/null differ diff --git a/media/ckeditor/_samples/assets/output_xhtml.css b/media/ckeditor/_samples/assets/output_xhtml.css deleted file mode 100644 index 95c8656..0000000 --- a/media/ckeditor/_samples/assets/output_xhtml.css +++ /dev/null @@ -1,204 +0,0 @@ -/* - * Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. - * For licensing, see LICENSE.html or http://ckeditor.com/license - * - * Styles used by the XHTML 1.1 sample page (xhtml.html). - */ - -/** - * Basic definitions for the editing area. - */ -body -{ - font-family: Arial, Verdana, sans-serif; - font-size: 80%; - color: #000000; - background-color: #ffffff; - padding: 5px; - margin: 0px; -} - -/** - * Core styles. - */ - -.Bold -{ - font-weight: bold; -} - -.Italic -{ - font-style: italic; -} - -.Underline -{ - text-decoration: underline; -} - -.StrikeThrough -{ - text-decoration: line-through; -} - -.Subscript -{ - vertical-align: sub; - font-size: smaller; -} - -.Superscript -{ - vertical-align: super; - font-size: smaller; -} - -/** - * Font faces. - */ - -.FontComic -{ - font-family: 'Comic Sans MS'; -} - -.FontCourier -{ - font-family: 'Courier New'; -} - -.FontTimes -{ - font-family: 'Times New Roman'; -} - -/** - * Font sizes. - */ - -.FontSmaller -{ - font-size: smaller; -} - -.FontLarger -{ - font-size: larger; -} - -.FontSmall -{ - font-size: 8pt; -} - -.FontBig -{ - font-size: 14pt; -} - -.FontDouble -{ - font-size: 200%; -} - -/** - * Font colors. - */ -.FontColor1 -{ - color: #ff9900; -} - -.FontColor2 -{ - color: #0066cc; -} - -.FontColor3 -{ - color: #ff0000; -} - -.FontColor1BG -{ - background-color: #ff9900; -} - -.FontColor2BG -{ - background-color: #0066cc; -} - -.FontColor3BG -{ - background-color: #ff0000; -} - -/** - * Indentation. - */ - -.Indent1 -{ - margin-left: 40px; -} - -.Indent2 -{ - margin-left: 80px; -} - -.Indent3 -{ - margin-left: 120px; -} - -/** - * Alignment. - */ - -.JustifyLeft -{ - text-align: left; -} - -.JustifyRight -{ - text-align: right; -} - -.JustifyCenter -{ - text-align: center; -} - -.JustifyFull -{ - text-align: justify; -} - -/** - * Other. - */ - -code -{ - font-family: courier, monospace; - background-color: #eeeeee; - padding-left: 1px; - padding-right: 1px; - border: #c0c0c0 1px solid; -} - -kbd -{ - padding: 0px 1px 0px 1px; - border-width: 1px 2px 2px 1px; - border-style: solid; -} - -blockquote -{ - color: #808080; -} diff --git a/media/ckeditor/_samples/assets/parsesample.css b/media/ckeditor/_samples/assets/parsesample.css deleted file mode 100644 index 5d5178c..0000000 --- a/media/ckeditor/_samples/assets/parsesample.css +++ /dev/null @@ -1,70 +0,0 @@ -body -{ - font-family: Arial, Verdana, sans-serif; - font-size: 12px; - color: #222; - background-color: #fff; -} - -/* preserved spaces for rtl list item bullets. (#6249)*/ -ol,ul,dl -{ - padding-right:40px; -} - -h1,h2,h3,h4 -{ - font-family: Georgia, Times, serif; -} - -h1.lightBlue -{ - color: #00A6C7; - font-size: 1.8em; - font-weight:normal; -} - -h3.green -{ - color: #739E39; - font-weight:normal; -} - -span.markYellow { background-color: yellow; } -span.markGreen { background-color: lime; } - -img.left -{ - padding: 5px; - margin-right: 5px; - float:left; - border:2px solid #DDD; -} - -img.right -{ - padding: 5px; - margin-right: 5px; - float:right; - border:2px solid #DDD; -} - -a.green -{ - color:#739E39; -} - -table.grey -{ - background-color : #F5F5F5; -} - -table.grey th -{ - background-color : #DDD; -} - -ul.square -{ - list-style-type : square; -} diff --git a/media/ckeditor/_samples/assets/swfobject.js b/media/ckeditor/_samples/assets/swfobject.js deleted file mode 100644 index a3efbe6..0000000 --- a/media/ckeditor/_samples/assets/swfobject.js +++ /dev/null @@ -1,18 +0,0 @@ -/** - * SWFObject v1.5: Flash Player detection and embed - http://blog.deconcept.com/swfobject/ - * - * SWFObject is (c) 2007 Geoff Stearns and is released under the MIT License: - * http://www.opensource.org/licenses/mit-license.php - * - */ -/* -Copyright (c) 2007 Geoff Stearns - -Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: - -The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - */ -/*jsl:ignoreall*/ -if(typeof deconcept=="undefined"){var deconcept=new Object();}if(typeof deconcept.util=="undefined"){deconcept.util=new Object();}if(typeof deconcept.SWFObjectUtil=="undefined"){deconcept.SWFObjectUtil=new Object();}deconcept.SWFObject=function(_1,id,w,h,_5,c,_7,_8,_9,_a){if(!document.getElementById){return;}this.DETECT_KEY=_a?_a:"detectflash";this.skipDetect=deconcept.util.getRequestParameter(this.DETECT_KEY);this.params=new Object();this.variables=new Object();this.attributes=new Array();if(_1){this.setAttribute("swf",_1);}if(id){this.setAttribute("id",id);}if(w){this.setAttribute("width",w);}if(h){this.setAttribute("height",h);}if(_5){this.setAttribute("version",new deconcept.PlayerVersion(_5.toString().split(".")));}this.installedVer=deconcept.SWFObjectUtil.getPlayerVersion();if(!window.opera&&document.all&&this.installedVer.major>7){deconcept.SWFObject.doPrepUnload=true;}if(c){this.addParam("bgcolor",c);}var q=_7?_7:"high";this.addParam("quality",q);this.setAttribute("useExpressInstall",false);this.setAttribute("doExpressInstall",false);var _c=(_8)?_8:window.location;this.setAttribute("xiRedirectUrl",_c);this.setAttribute("redirectUrl","");if(_9){this.setAttribute("redirectUrl",_9);}};deconcept.SWFObject.prototype={useExpressInstall:function(_d){this.xiSWFPath=!_d?"expressinstall.swf":_d;this.setAttribute("useExpressInstall",true);},setAttribute:function(_e,_f){this.attributes[_e]=_f;},getAttribute:function(_10){return this.attributes[_10];},addParam:function(_11,_12){this.params[_11]=_12;},getParams:function(){return this.params;},addVariable:function(_13,_14){this.variables[_13]=_14;},getVariable:function(_15){return this.variables[_15];},getVariables:function(){return this.variables;},getVariablePairs:function(){var _16=new Array();var key;var _18=this.getVariables();for(key in _18){_16[_16.length]=key+"="+_18[key];}return _16;},getSWFHTML:function(){var _19="";if(navigator.plugins&&navigator.mimeTypes&&navigator.mimeTypes.length){if(this.getAttribute("doExpressInstall")){this.addVariable("MMplayerType","PlugIn");this.setAttribute("swf",this.xiSWFPath);}_19="0){_19+="flashvars=\""+_1c+"\"";}_19+="/>";}else{if(this.getAttribute("doExpressInstall")){this.addVariable("MMplayerType","ActiveX");this.setAttribute("swf",this.xiSWFPath);}_19="";_19+="";var _1d=this.getParams();for(var key in _1d){_19+="";}var _1f=this.getVariablePairs().join("&");if(_1f.length>0){_19+="";}_19+="";}return _19;},write:function(_20){if(this.getAttribute("useExpressInstall")){var _21=new deconcept.PlayerVersion([6,0,65]);if(this.installedVer.versionIsValid(_21)&&!this.installedVer.versionIsValid(this.getAttribute("version"))){this.setAttribute("doExpressInstall",true);this.addVariable("MMredirectURL",escape(this.getAttribute("xiRedirectUrl")));document.title=document.title.slice(0,47)+" - Flash Player Installation";this.addVariable("MMdoctitle",document.title);}}if(this.skipDetect||this.getAttribute("doExpressInstall")||this.installedVer.versionIsValid(this.getAttribute("version"))){var n=(typeof _20=="string")?document.getElementById(_20):_20;n.innerHTML=this.getSWFHTML();return true;}else{if(this.getAttribute("redirectUrl")!=""){document.location.replace(this.getAttribute("redirectUrl"));}}return false;}};deconcept.SWFObjectUtil.getPlayerVersion=function(){var _23=new deconcept.PlayerVersion([0,0,0]);if(navigator.plugins&&navigator.mimeTypes.length){var x=navigator.plugins["Shockwave Flash"];if(x&&x.description){_23=new deconcept.PlayerVersion(x.description.replace(/([a-zA-Z]|\s)+/,"").replace(/(\s+r|\s+b[0-9]+)/,".").split("."));}}else{if(navigator.userAgent&&navigator.userAgent.indexOf("Windows CE")>=0){var axo=1;var _26=3;while(axo){try{_26++;axo=new ActiveXObject("ShockwaveFlash.ShockwaveFlash."+_26);_23=new deconcept.PlayerVersion([_26,0,0]);}catch(e){axo=null;}}}else{try{var axo=new ActiveXObject("ShockwaveFlash.ShockwaveFlash.7");}catch(e){try{var axo=new ActiveXObject("ShockwaveFlash.ShockwaveFlash.6");_23=new deconcept.PlayerVersion([6,0,21]);axo.AllowScriptAccess="always";}catch(e){if(_23.major==6){return _23;}}try{axo=new ActiveXObject("ShockwaveFlash.ShockwaveFlash");}catch(e){}}if(axo!=null){_23=new deconcept.PlayerVersion(axo.GetVariable("$version").split(" ")[1].split(","));}}}return _23;};deconcept.PlayerVersion=function(_29){this.major=_29[0]!=null?parseInt(_29[0]):0;this.minor=_29[1]!=null?parseInt(_29[1]):0;this.rev=_29[2]!=null?parseInt(_29[2]):0;};deconcept.PlayerVersion.prototype.versionIsValid=function(fv){if(this.majorfv.major){return true;}if(this.minorfv.minor){return true;}if(this.rev=0;i--){_2f[i].style.display="none";for(var x in _2f[i]){if(typeof _2f[i][x]=="function"){_2f[i][x]=function(){};}}}};if(deconcept.SWFObject.doPrepUnload){if(!deconcept.unloadSet){deconcept.SWFObjectUtil.prepUnload=function(){__flash_unloadHandler=function(){};__flash_savedUnloadHandler=function(){};window.attachEvent("onunload",deconcept.SWFObjectUtil.cleanupSWFs);};window.attachEvent("onbeforeunload",deconcept.SWFObjectUtil.prepUnload);deconcept.unloadSet=true;}}if(!document.getElementById&&document.all){document.getElementById=function(id){return document.all[id];};}var getQueryParamValue=deconcept.util.getRequestParameter;var FlashObject=deconcept.SWFObject;var SWFObject=deconcept.SWFObject; diff --git a/media/ckeditor/_samples/autogrow.html b/media/ckeditor/_samples/autogrow.html deleted file mode 100644 index 6a7d9df..0000000 --- a/media/ckeditor/_samples/autogrow.html +++ /dev/null @@ -1,108 +0,0 @@ - - - - - AutoGrow Plugin — CKEditor Sample - - - - - - -

- CKEditor Sample — Using AutoGrow Plugin -

-
-

- This sample shows how to configure CKEditor instances to use the - AutoGrow (autogrow) plugin that lets the editor window expand - and shrink depending on the amount and size of content entered in the editing area. -

-

- In its default implementation the AutoGrow feature can expand the - CKEditor window infinitely in order to avoid introducing scrollbars to the editing area. -

-

- It is also possible to set a maximum height for the editor window. Once CKEditor - editing area reaches the value in pixels specified in the - autoGrow_maxHeight - configuration setting, scrollbars will be added and the editor window will no longer expand. -

-

- To add a CKEditor instance using the autogrow plugin and its - autoGrow_maxHeight attribute, insert the following JavaScript call to your code: -

-
CKEDITOR.replace( 'textarea_id',
-	{
-		extraPlugins : 'autogrow',
-		autoGrow_maxHeight : 800,
-		// Remove the Resize plugin as it does not make sense to use it in conjunction with the AutoGrow plugin.
-		removePlugins : 'resize'
-	});
-

- Note that textarea_id in the code above is the id attribute of - the <textarea> element to be replaced with CKEditor. The maximum height should - be given in pixels. -

-
- -
- -
-
-

- - - -

-

- - - -

-

- -

-
- - - diff --git a/media/ckeditor/_samples/bbcode.html b/media/ckeditor/_samples/bbcode.html deleted file mode 100644 index 29ba225..0000000 --- a/media/ckeditor/_samples/bbcode.html +++ /dev/null @@ -1,125 +0,0 @@ - - - - - BBCode Plugin — CKEditor Sample - - - - - - -

- CKEditor Sample — BBCode Plugin -

-
-

- This sample shows how to configure CKEditor to output BBCode format instead of HTML. - Please note that the editor configuration was modified to reflect what is needed in a BBCode editing environment. - Smiley images, for example, were stripped to the emoticons that are commonly used in some BBCode dialects. -

-

- Please note that currently there is no standard for the BBCode markup language, so its implementation - for different platforms (message boards, blogs etc.) can vary. This means that before using CKEditor to - output BBCode you may need to adjust the implementation to your own environment. -

-

- A snippet of the configuration code can be seen below; check the source of this page for - a full definition: -

-
-CKEDITOR.replace( 'editor1',
-	{
-		extraPlugins : 'bbcode',
-		toolbar :
-		[
-			['Source', '-', 'Save','NewPage','-','Undo','Redo'],
-			['Find','Replace','-','SelectAll','RemoveFormat'],
-			['Link', 'Unlink', 'Image'],
-			'/',
-			['FontSize', 'Bold', 'Italic','Underline'],
-			['NumberedList','BulletedList','-','Blockquote'],
-			['TextColor', '-', 'Smiley','SpecialChar', '-', 'Maximize']
-		],
-		... some other configurations omitted here
-	});	
-
- - -
- -
-
-

- - - -

-

- -

-
- - - diff --git a/media/ckeditor/_samples/devtools.html b/media/ckeditor/_samples/devtools.html deleted file mode 100644 index fb9f92a..0000000 --- a/media/ckeditor/_samples/devtools.html +++ /dev/null @@ -1,94 +0,0 @@ - - - - - Using DevTools Plugin — CKEditor Sample - - - - - - -

- CKEditor Sample — Using the Developer Tools Plugin -

-
-

- This sample shows how to configure CKEditor instances to use the - Developer Tools (devtools) plugin that displays - information about dialog window elements, including the name of the dialog window, - tab, and UI element. Please note that the tooltip also contains a link to the - CKEditor JavaScript API - documentation for each of the selected elements. -

-

- This plugin is aimed at developers who would like to customize their CKEditor - instances and create their own plugins. By default it is turned off; it is - usually useful to only turn it on in the development phase. Note that it works with - all CKEditor dialog windows, including the ones that were created by custom plugins. -

-

- To add a CKEditor instance using the devtools plugin, insert - the following JavaScript call into your code: -

-
CKEDITOR.replace( 'textarea_id',
-	{
-		extraPlugins : 'devtools'
-	});
-

- Note that textarea_id in the code above is the id attribute of - the <textarea> element to be replaced with CKEditor. -

-
- - -
- -
-
-

- - - -

-

- -

-
- - - diff --git a/media/ckeditor/_samples/divreplace.html b/media/ckeditor/_samples/divreplace.html deleted file mode 100644 index 595a8d7..0000000 --- a/media/ckeditor/_samples/divreplace.html +++ /dev/null @@ -1,154 +0,0 @@ - - - - - Replace DIV — CKEditor Sample - - - - - - - - - -

- CKEditor Sample — Replace DIV with CKEditor on the Fly -

-
-

- This sample shows how to automatically replace <div> elements - with a CKEditor instance on the fly, following user's doubleclick. The content - that was previously placed inside the <div> element will now - be moved into CKEditor editing area. -

-

- For details on how to create this setup check the source code of this sample page. -

-
- -
- -
-

- Double-click any of the following <div> elements to transform them into - editor instances.

-
-

- Part 1

-

- Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Cras et ipsum quis mi - semper accumsan. Integer pretium dui id massa. Suspendisse in nisl sit amet urna - rutrum imperdiet. Nulla eu tellus. Donec ante nisi, ullamcorper quis, fringilla - nec, sagittis eleifend, pede. Nulla commodo interdum massa. Donec id metus. Fusce - eu ipsum. Suspendisse auctor. Phasellus fermentum porttitor risus. -

-
-
-

- Part 2

-

- Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Cras et ipsum quis mi - semper accumsan. Integer pretium dui id massa. Suspendisse in nisl sit amet urna - rutrum imperdiet. Nulla eu tellus. Donec ante nisi, ullamcorper quis, fringilla - nec, sagittis eleifend, pede. Nulla commodo interdum massa. Donec id metus. Fusce - eu ipsum. Suspendisse auctor. Phasellus fermentum porttitor risus. -

-

- Donec velit. Mauris massa. Vestibulum non nulla. Nam suscipit arcu nec elit. Phasellus - sollicitudin iaculis ante. Ut non mauris et sapien tincidunt adipiscing. Vestibulum - vitae leo. Suspendisse nec mi tristique nulla laoreet vulputate. -

-
-
-

- Part 3

-

- Lorem ipsum dolor sit amet, consectetuer adipiscing elit. Cras et ipsum quis mi - semper accumsan. Integer pretium dui id massa. Suspendisse in nisl sit amet urna - rutrum imperdiet. Nulla eu tellus. Donec ante nisi, ullamcorper quis, fringilla - nec, sagittis eleifend, pede. Nulla commodo interdum massa. Donec id metus. Fusce - eu ipsum. Suspendisse auctor. Phasellus fermentum porttitor risus. -

-
- - - diff --git a/media/ckeditor/_samples/enterkey.html b/media/ckeditor/_samples/enterkey.html deleted file mode 100644 index 093d36e..0000000 --- a/media/ckeditor/_samples/enterkey.html +++ /dev/null @@ -1,115 +0,0 @@ - - - - - ENTER Key Configuration — CKEditor Sample - - - - - - - -

- CKEditor Sample — ENTER Key Configuration -

-
-

- This sample shows how to configure the Enter and Shift+Enter keys - to perform actions specified in the - enterMode - and shiftEnterMode - parameters, respectively. - You can choose from the following options: -

-
    -
  • ENTER_P – new <p> paragraphs are created;
  • -
  • ENTER_BR – lines are broken with <br> elements;
  • -
  • ENTER_DIV – new <div> blocks are created.
  • -
-

- The sample code below shows how to configure CKEditor to create a <div> block when Enter key is pressed. -

-
CKEDITOR.replace( 'textarea_id',
-	{
-		enterMode : CKEDITOR.ENTER_DIV
-	});
-

- Note that textarea_id in the code above is the id attribute of - the <textarea> element to be replaced. -

-
- - -
- -
-
- When Enter is pressed:
- -
-
- When Shift+Enter is pressed:
- -
-
-
-

-
- -

-

- -

-
- - - diff --git a/media/ckeditor/_samples/fullpage.html b/media/ckeditor/_samples/fullpage.html deleted file mode 100644 index 9e0b359..0000000 --- a/media/ckeditor/_samples/fullpage.html +++ /dev/null @@ -1,82 +0,0 @@ - - - - - Full Page Editing with Document Properties Plugin — CKEditor Sample - - - - - - -

- CKEditor Sample — Full Page Editing with Document Properties Plugin -

-
-

- This sample shows how to configure CKEditor to edit entire HTML pages, from the - <html> tag to the </html> tag. -

-

- The Document Properties (docprops) plugin is also turned on. - This plugin allows you to set the metadata of the page, including the page encoding, margins, - meta tags, or background. -

-

- The CKEditor instance below is inserted with a JavaScript call using the following code: -

-
CKEDITOR.replace( 'textarea_id',
-	{
-		fullPage : true,
-		extraPlugins : 'docprops'
-	});
-

- Note that textarea_id in the code above is the id attribute of - the <textarea> element to be replaced. -

-
- - -
- -
-
- - - -

- -

-
- - - diff --git a/media/ckeditor/_samples/index.html b/media/ckeditor/_samples/index.html deleted file mode 100644 index dfb24ed..0000000 --- a/media/ckeditor/_samples/index.html +++ /dev/null @@ -1,116 +0,0 @@ - - - - - CKEditor Samples - - - - -

- CKEditor Samples Site -

-

- Basic Samples -

- -

- Basic Customization -

-
    -
  • Skins
    - Changing the CKEditor skin by adjusting a single configuration option. -
  • -
  • User Interface color
    - Changing CKEditor User Interface color and adding a toolbar button that lets the user set the UI color. -
  • -
  • User Interface languages
    - Changing CKEditor User Interface language and adding a drop-down list that lets the user choose the UI language. -
  • -
-

- Advanced Samples -

- -

- Additional plugins -

-
    -
  • AutoGrow plugin
    - Using the AutoGrow plugin in order to make the editor grow to fit the size of its content. -
  • -
  • Output for BBCode
    - Configuring CKEditor to produce BBCode tags instead of HTML. -
  • -
  • Stylesheet Parser plugin
    - Using the Stylesheet Parser plugin to fill the Styles drop-down list based on the CSS classes available in the document stylesheet. -
  • -
  • Developer Tools plugin
    - Using the Developer Tools plugin to display information about dialog window UI elements to allow for easier customization. -
  • -
  • Placeholder plugin
    - Using the Placeholder plugin to create uneditable sections that can only be created and modified with a proper dialog window. -
  • -
  • TableResize plugin
    - Using the TableResize plugin to enable table column resizing. -
  • -
- - - diff --git a/media/ckeditor/_samples/jqueryadapter.html b/media/ckeditor/_samples/jqueryadapter.html deleted file mode 100644 index f56c7f8..0000000 --- a/media/ckeditor/_samples/jqueryadapter.html +++ /dev/null @@ -1,99 +0,0 @@ - - - - - jQuery Adapter — CKEditor Sample - - - - - - - - - -

- CKEditor Sample — Using jQuery Adapter -

-
-

- This sample shows how to load CKEditor and configure it using the - jQuery adapter. - In this case the jQuery adapter is responsible for transforming a <textarea> - element into a CKEditor instance and setting the configuration of the toolbar. -

-

- CKEditor instance with custom configuration set in jQuery can be inserted with the - following JavaScript code: -

-
$(function()
-{
-	var config = {
-		skin:'v2'
-	};
-
-	$('.textarea_class').ckeditor(config);
-});
-

- Note that textarea_class in the code above is the - class attribute of the <textarea> element to be replaced with - CKEditor. Any other jQuery selector can be used to match the target element. -

-
- - -
- -
- -
-

- - -

-

- -

-
- - - diff --git a/media/ckeditor/_samples/output_for_flash.html b/media/ckeditor/_samples/output_for_flash.html deleted file mode 100644 index 0061697..0000000 --- a/media/ckeditor/_samples/output_for_flash.html +++ /dev/null @@ -1,275 +0,0 @@ - - - - - Output for Flash — CKEditor Sample - - - - - - - - -

- CKEditor Sample — Producing Flash Compliant HTML Output -

-
-

- This sample shows how to configure CKEditor to output - HTML code that can be used with - - Adobe Flash. - The code will contain a subset of standard HTML elements like <b>, - <i>, and <p> as well as HTML attributes. -

-

- To add a CKEditor instance outputting Flash compliant HTML code, load the editor using a standard - JavaScript call, and define CKEditor features to use HTML elements and attributes. -

-

- For details on how to create this setup check the source code of this sample page. -

-
-

- To see how it works, create some content in the editing area of CKEditor on the left - and send it to the Flash object on the right side of the page by using the - Send to Flash button. -

- - -
- -
-
- - - - - -
- - - - -
- - - - diff --git a/media/ckeditor/_samples/output_html.html b/media/ckeditor/_samples/output_html.html deleted file mode 100644 index 08b4756..0000000 --- a/media/ckeditor/_samples/output_html.html +++ /dev/null @@ -1,285 +0,0 @@ - - - - - HTML Compliant Output — CKEditor Sample - - - - - - -

- CKEditor Sample — Producing HTML Compliant Output -

-
-

- This sample shows how to configure CKEditor to output valid - HTML 4.01 code. - Traditional HTML elements like <b>, - <i>, and <font> are used in place of - <strong>, <em>, and CSS styles. -

-

- To add a CKEditor instance outputting legacy HTML 4.01 code, load the editor using a standard - JavaScript call, and define CKEditor features to use the HTML compliant elements and attributes. -

-

- A snippet of the configuration code can be seen below; check the source of this page for - full definition: -

-
CKEDITOR.replace( 'textarea_id',
-	{
-		coreStyles_bold	: { element : 'b' },
-		coreStyles_italic : { element : 'i' },
-
-		fontSize_style :
-			{
-				element		: 'font',
-				attributes	: { 'size' : '#(size)' }
-			}
-
-		// More definitions follow.
-	});
-
- - -
- -
-
-

- - - -

-

- -

-
- - - diff --git a/media/ckeditor/_samples/output_xhtml.html b/media/ckeditor/_samples/output_xhtml.html deleted file mode 100644 index 864e36c..0000000 --- a/media/ckeditor/_samples/output_xhtml.html +++ /dev/null @@ -1,181 +0,0 @@ - - - - - XHTML Compliant Output — CKEditor Sample - - - - - - -

- CKEditor Sample — Producing XHTML Compliant Output -

-
-

- This sample shows how to configure CKEditor to output valid - XHTML 1.1 code. - Deprecated elements (<font>, <u>) or attributes - (size, face) will be replaced with XHTML compliant code. -

-

- To add a CKEditor instance outputting valid XHTML code, load the editor using a standard - JavaScript call and define CKEditor features to use the XHTML compliant elements and styles. -

-

- A snippet of the configuration code can be seen below; check the source of this page for - full definition: -

-
CKEDITOR.replace( 'textarea_id',
-	{
-		contentsCss : 'assets/output_xhtml.css',
-
-		coreStyles_bold	: { element : 'span', attributes : {'class': 'Bold'} },
-		coreStyles_italic : { element : 'span', attributes : {'class': 'Italic'} },
-
-		// More definitions follow.
-	});
-
- - -
- -
-
-

- - - -

-

- -

-
- - - diff --git a/media/ckeditor/_samples/php/advanced.php b/media/ckeditor/_samples/php/advanced.php deleted file mode 100644 index d54c50e..0000000 --- a/media/ckeditor/_samples/php/advanced.php +++ /dev/null @@ -1,120 +0,0 @@ - - - - - Setting Configuration Options — CKEditor Sample - - - - -

- CKEditor Sample — Setting Configuration Options -

-

- This sample shows how to insert a CKEditor instance with custom configuration options. -

-

- To set configuration options, use the config property. To set the attributes of a <textarea> element (which is displayed instead of CKEditor in unsupported browsers), use the textareaAttributes property. -

-
-<?php
-// Include the CKEditor class.
-include_once "ckeditor/ckeditor.php";
-
-// Create a class instance.
-$CKEditor = new CKEditor();
-
-// Path to the CKEditor directory.
-$CKEditor->basePath = '/ckeditor/';
-
-// Set global configuration (used by every instance of CKEditor).
-$CKEditor->config['width'] = 600;
-
-// Change default textarea attributes.
-$CKEditor->textareaAttributes = array("cols" => 80, "rows" => 10);
-
-// The initial value to be displayed in the editor.
-$initialValue = 'This is some sample text.';
-
-// Create the first instance.
-$CKEditor->editor("textarea_id", $initialValue);
-?>
-

- Note that textarea_id in the code above is the name attribute of - the <textarea> element to be created. -

- - -
- -
-
- -returnOutput = true; - -// Path to the CKEditor directory, ideally use an absolute path instead of a relative dir. -// $CKEditor->basePath = '/ckeditor/' -// If not set, CKEditor will try to detect the correct path. -$CKEditor->basePath = '../../'; - -// Set global configuration (will be used by all instances of CKEditor). -$CKEditor->config['width'] = 600; - -// Change default textarea attributes. -$CKEditor->textareaAttributes = array("cols" => 80, "rows" => 10); - -// The initial value to be displayed in the editor. -$initialValue = '

This is some sample text. You are using CKEditor.

'; - -// Create the first instance. -$code = $CKEditor->editor("editor1", $initialValue); - -echo $code; -?> -
- -editor("editor2", $initialValue, $config); -?> -

- -

-
- - - diff --git a/media/ckeditor/_samples/php/events.php b/media/ckeditor/_samples/php/events.php deleted file mode 100644 index e821a93..0000000 --- a/media/ckeditor/_samples/php/events.php +++ /dev/null @@ -1,153 +0,0 @@ - - - - - Adding Event Handlers — CKEditor Sample - - - - -

- CKEditor Sample — Adding Event Handlers -

-
-

- This sample shows how to add event handlers to CKEditor with PHP. -

-

- A snippet of the configuration code can be seen below; check the source code of this page for - the full definition: -

-
<?php
-// Include the CKEditor class.
-include("ckeditor/ckeditor.php");
-
-// Create a class instance.
-$CKEditor = new CKEditor();
-
-// Path to the CKEditor directory.
-$CKEditor->basePath = '/ckeditor/';
-
-// The initial value to be displayed in the editor.
-$initialValue = 'This is some sample text.';
-
-// Add event handler, instanceReady is fired when editor is loaded.
-$CKEditor->addEventHandler('instanceReady', 'function (evt) {
-	alert("Loaded editor: " + evt.editor.name);
-}');
-
-// Create an editor instance.
-$CKEditor->editor("editor1", $initialValue);
-
-
- -
- -
-
- -addGlobalEventHandler('dialogDefinition', $function); -} - -/** - * Adds a global event, will notify about an open dialog window. - */ -function CKEditorNotifyAboutOpenedDialog(&$CKEditor) { - $function = 'function (evt) { - alert("Loading a dialog window: " + evt.data.name); - }'; - - $CKEditor->addGlobalEventHandler('dialogDefinition', $function); -} - -// Include the CKEditor class. -include("../../ckeditor.php"); - -// Create a class instance. -$CKEditor = new CKEditor(); - -// Set a configuration option for all editors. -$CKEditor->config['width'] = 750; - -// Path to the CKEditor directory, ideally use an absolute path instead of a relative dir. -// $CKEditor->basePath = '/ckeditor/' -// If not set, CKEditor will try to detect the correct path. -$CKEditor->basePath = '../../'; - -// The initial value to be displayed in the editor. -$initialValue = '

This is some sample text. You are using CKEditor.

'; - -// Event that will be handled only by the first editor. -$CKEditor->addEventHandler('instanceReady', 'function (evt) { - alert("Loaded editor: " + evt.editor.name); -}'); - -// Create the first instance. -$CKEditor->editor("editor1", $initialValue); - -// Clear event handlers. Instances that will be created later will not have -// the 'instanceReady' listener defined a couple of lines above. -$CKEditor->clearEventHandlers(); -?> -
- -editor("editor2", $initialValue, $config, $events); -?> -

- -

-
- - - diff --git a/media/ckeditor/_samples/php/index.html b/media/ckeditor/_samples/php/index.html deleted file mode 100644 index 6a47991..0000000 --- a/media/ckeditor/_samples/php/index.html +++ /dev/null @@ -1,47 +0,0 @@ - - - - - - CKEditor Samples — PHP Integration - - - -

- CKEditor Samples List for PHP -

-

- Basic Samples -

- -

- Advanced Samples -

- - - - diff --git a/media/ckeditor/_samples/php/replace.php b/media/ckeditor/_samples/php/replace.php deleted file mode 100644 index fcb5b13..0000000 --- a/media/ckeditor/_samples/php/replace.php +++ /dev/null @@ -1,87 +0,0 @@ - - - - - Replace Selected Textarea Elements — CKEditor Sample - - - - -

- CKEditor Sample — Replace Selected Textarea Elements Using PHP Code -

-
-

- This sample shows how to replace a selected <textarea> element - with a CKEditor instance by using PHP code. -

-

- To replace a <textarea> element, place the following call at any point - after the <textarea> element: -

-
-<?php
-// Include the CKEditor class.
-include_once "ckeditor/ckeditor.php";
-
-// Create a class instance.
-$CKEditor = new CKEditor();
-
-// Path to the CKEditor directory.
-$CKEditor->basePath = '/ckeditor/';
-
-// Replace a textarea element with an id (or name) of "textarea_id".
-$CKEditor->replace("textarea_id");
-?>
-

- Note that textarea_id in the code above is the id attribute of - the <textarea> element to be replaced. -

-
- -
- -
-
-

- - -

-

- -

-
- - basePath = '/ckeditor/' - // If not set, CKEditor will try to detect the correct path. - $CKEditor->basePath = '../../'; - // Replace a textarea element with an id (or name) of "editor1". - $CKEditor->replace("editor1"); - ?> - - diff --git a/media/ckeditor/_samples/php/replaceall.php b/media/ckeditor/_samples/php/replaceall.php deleted file mode 100644 index 03b72fa..0000000 --- a/media/ckeditor/_samples/php/replaceall.php +++ /dev/null @@ -1,88 +0,0 @@ - - - - - Replace All Textarea Elements — CKEditor Sample - - - - -

- CKEditor Sample — Replace All Textarea Elements Using PHP Code -

-
-

- This sample shows how to replace all <textarea> elements - with CKEditor by using PHP code. -

-

- To replace all <textarea> elements, place the following call at any point - after the last <textarea> element: -

-
-<?php
-// Include the CKEditor class.
-include("ckeditor/ckeditor.php");
-
-// Create a class instance.
-$CKEditor = new CKEditor();
-
-// Path to the CKEditor directory.
-$CKEditor->basePath = '/ckeditor/';
-
-// Replace all textarea elements with CKEditor.
-$CKEditor->replaceAll();
-?>
-
- -
- -
-
-

- - -

-

- - -

-

- -

-
- - basePath = '/ckeditor/' - // If not set, CKEditor will try to detect the correct path. - $CKEditor->basePath = '../../'; - // Replace all textarea elements with CKEditor. - $CKEditor->replaceAll(); - ?> - - diff --git a/media/ckeditor/_samples/php/standalone.php b/media/ckeditor/_samples/php/standalone.php deleted file mode 100644 index 99bcac5..0000000 --- a/media/ckeditor/_samples/php/standalone.php +++ /dev/null @@ -1,83 +0,0 @@ - - - - - Creating CKEditor Instances — CKEditor Sample - - - - -

- CKEditor Sample — Creating CKEditor Instances -

-
-

- This sample shows how to create a CKEditor instance with PHP. -

-
-<?php
-include_once "ckeditor/ckeditor.php";
-
-// Create a class instance.
-$CKEditor = new CKEditor();
-
-// Path to the CKEditor directory.
-$CKEditor->basePath = '/ckeditor/';
-
-// Create a textarea element and attach CKEditor to it.
-$CKEditor->editor("textarea_id", "This is some sample text");
-?>
-

- Note that textarea_id in the code above is the id and name attribute of - the <textarea> element that will be created. -

-
- -
- -
- -
-

- -

-

- This is some sample text.

'; - // Create a class instance. - $CKEditor = new CKEditor(); - // Path to the CKEditor directory, ideally use an absolute path instead of a relative dir. - // $CKEditor->basePath = '/ckeditor/' - // If not set, CKEditor will try to detect the correct path. - $CKEditor->basePath = '../../'; - // Create a textarea element and attach CKEditor to it. - $CKEditor->editor("editor1", $initialValue); - ?> - -

-
- - - diff --git a/media/ckeditor/_samples/placeholder.html b/media/ckeditor/_samples/placeholder.html deleted file mode 100644 index cd9d01e..0000000 --- a/media/ckeditor/_samples/placeholder.html +++ /dev/null @@ -1,81 +0,0 @@ - - - - - Placeholder Plugin — CKEditor Sample - - - - - - -

- CKEditor Sample — Using the Placeholder Plugin -

-
-

- This sample shows how to configure CKEditor instances to use the - Placeholder plugin that lets you insert read-only elements - into your content. To enter and modify read-only text, use the - Create Placeholder button and its matching dialog window. -

-

- To add a CKEditor instance that uses the placeholder plugin and a related - Create Placeholder toolbar button, insert the following JavaScript - call to your code: -

-
CKEDITOR.replace( 'textarea_id',
-	{
-		extraPlugins : 'placeholder',
-		toolbar : [ [ 'Source', 'Bold' ], ['CreatePlaceholder'] ]
-	});
-

- Note that textarea_id in the code above is the id attribute of - the <textarea> element to be replaced with CKEditor. -

-
- -
- -
-
-

- - - -

-

- -

-
- - - diff --git a/media/ckeditor/_samples/readonly.html b/media/ckeditor/_samples/readonly.html deleted file mode 100644 index c58e3e4..0000000 --- a/media/ckeditor/_samples/readonly.html +++ /dev/null @@ -1,91 +0,0 @@ - - - - - Read-only State — CKEditor Sample - - - - - - - - -

- CKEditor Sample — Using the CKEditor Read-Only API -

-
-

- This sample shows how to use the - setReadOnly - API to put editor into the read-only state that makes it impossible for users to change the editor contents. -

-

- For details on how to create this setup check the source code of this sample page. -

-
- - -
- -
-
-

- -

-

- - -

-
- - - diff --git a/media/ckeditor/_samples/replacebyclass.html b/media/ckeditor/_samples/replacebyclass.html deleted file mode 100644 index 34d10ec..0000000 --- a/media/ckeditor/_samples/replacebyclass.html +++ /dev/null @@ -1,64 +0,0 @@ - - - - - Replace Textareas by Class Name — CKEditor Sample - - - - - - -

- CKEditor Sample — Replace Textarea Elements by Class Name -

-
-

- This sample shows how to automatically replace all <textarea> elements - of a given class with a CKEditor instance. -

-

- To replace a <textarea> element, simply assign it the ckeditor - class, as in the code below: -

-
<textarea class="ckeditor" name="editor1"></textarea>
-

- Note that other <textarea> attributes (like id or name) need to be adjusted to your document. -

-
- - -
- -
-
-

- - -

-

- -

-
- - - diff --git a/media/ckeditor/_samples/replacebycode.html b/media/ckeditor/_samples/replacebycode.html deleted file mode 100644 index 3959dd5..0000000 --- a/media/ckeditor/_samples/replacebycode.html +++ /dev/null @@ -1,97 +0,0 @@ - - - - - Replace Textarea by Code — CKEditor Sample - - - - - - -

- CKEditor Sample — Replace Textarea Elements Using JavaScript Code -

-
-

- This sample shows how to automatically replace all <textarea> elements - with a CKEditor instance by using a JavaScript call. -

-

- To replace a <textarea> element, place the following call at any point - after the <textarea> element or inside a <script> element located - in the <head> section of the page, in a window.onload event handler: -

-
CKEDITOR.replace( 'textarea_id' );
-

- Note that textarea_id in the code above is the id attribute of - the <textarea> element to be replaced. -

-
- - -
- -
-
-

- - - -

-

- - - -

-

- -

-
- - - diff --git a/media/ckeditor/_samples/sample.css b/media/ckeditor/_samples/sample.css deleted file mode 100644 index ed4e261..0000000 --- a/media/ckeditor/_samples/sample.css +++ /dev/null @@ -1,163 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -html, body, h1, h2, h3, h4, h5, h6, div, span, blockquote, p, address, form, fieldset, img, ul, ol, dl, dt, dd, li, hr, table, td, th, strong, em, sup, sub, dfn, ins, del, q, cite, var, samp, code, kbd, tt, pre { - line-height: 1.5em; -} - -body { - padding:10px 30px; -} - -input, textarea, select, option, optgroup, button, td, th { - font-size: 100%; -} - -pre, -code, -kbd, -samp, -tt{ - font-family: monospace,monospace; - font-size: 1em; -} - -h1.samples { - color:#0782C1; - font-size:200%; - font-weight:normal; - margin: 0; - padding: 0; -} - -h2.samples { - color:#000000; - font-size:130%; - margin: 0; - padding: 0; -} - -p, blockquote, address, form, pre, dl, h1.samples, h2.samples { - margin-bottom:15px; -} - -ul.samples { - margin-bottom:15px; -} - -.clear { - clear:both; -} - -fieldset -{ - margin: 0; - padding: 10px; -} - -body, input, textarea { - color: #333333; - font-family: Arial, Helvetica, sans-serif; -} - -body { - font-size: 75%; -} - -a.samples { - color:#189DE1; - text-decoration:none; -} - -a.samples:hover { - text-decoration:underline; -} - -form -{ - margin: 0; - padding: 0; -} - -pre.samples -{ - background-color: #F7F7F7; - border: 1px solid #D7D7D7; - overflow: auto; - padding: 0.25em; -} - -#alerts -{ - color: Red; -} - -#footer hr -{ - margin: 10px 0 15px 0; - height: 1px; - border: solid 1px gray; - border-bottom: none; -} - -#footer p -{ - margin: 0 10px 10px 10px; - float: left; -} - -#footer #copy -{ - float: right; -} - -#outputSample -{ - width: 100%; - table-layout: fixed; -} - -#outputSample thead th -{ - color: #dddddd; - background-color: #999999; - padding: 4px; - white-space: nowrap; -} - -#outputSample tbody th -{ - vertical-align: top; - text-align: left; -} - -#outputSample pre -{ - margin: 0; - padding: 0; - white-space: pre; /* CSS2 */ - white-space: -moz-pre-wrap; /* Mozilla*/ - white-space: -o-pre-wrap; /* Opera 7 */ - white-space: pre-wrap; /* CSS 2.1 */ - white-space: pre-line; /* CSS 3 (and 2.1 as well, actually) */ - word-wrap: break-word; /* IE */ -} - -.description { - border: 1px dotted #B7B7B7; - margin-bottom: 10px; - padding: 10px 10px 0; -} - -label { - display: block; - margin-bottom:6px; -} - -.cke_dialog label -{ - display: inline; - margin-bottom: auto; -} diff --git a/media/ckeditor/_samples/sample.js b/media/ckeditor/_samples/sample.js deleted file mode 100644 index 7842e61..0000000 --- a/media/ckeditor/_samples/sample.js +++ /dev/null @@ -1,65 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -// This file is not required by CKEditor and may be safely ignored. -// It is just a helper file that displays a red message about browser compatibility -// at the top of the samples (if incompatible browser is detected). - -if ( window.CKEDITOR ) -{ - (function() - { - var showCompatibilityMsg = function() - { - var env = CKEDITOR.env; - - var html = '

Your browser is not compatible with CKEditor.'; - - var browsers = - { - gecko : 'Firefox 2.0', - ie : 'Internet Explorer 6.0', - opera : 'Opera 9.5', - webkit : 'Safari 3.0' - }; - - var alsoBrowsers = ''; - - for ( var key in env ) - { - if ( browsers[ key ] ) - { - if ( env[key] ) - html += ' CKEditor is compatible with ' + browsers[ key ] + ' or higher.'; - else - alsoBrowsers += browsers[ key ] + '+, '; - } - } - - alsoBrowsers = alsoBrowsers.replace( /\+,([^,]+), $/, '+ and $1' ); - - html += ' It is also compatible with ' + alsoBrowsers + '.'; - - html += '

With non compatible browsers, you should still be able to see and edit the contents (HTML) in a plain text field.

'; - - var alertsEl = document.getElementById( 'alerts' ); - alertsEl && ( alertsEl.innerHTML = html ); - }; - - var onload = function() - { - // Show a friendly compatibility message as soon as the page is loaded, - // for those browsers that are not compatible with CKEditor. - if ( !CKEDITOR.env.isCompatible ) - showCompatibilityMsg(); - }; - - // Register the onload listener. - if ( window.addEventListener ) - window.addEventListener( 'load', onload, false ); - else if ( window.attachEvent ) - window.attachEvent( 'onload', onload ); - })(); -} diff --git a/media/ckeditor/_samples/sample_posteddata.php b/media/ckeditor/_samples/sample_posteddata.php deleted file mode 100644 index 06b5e2c..0000000 --- a/media/ckeditor/_samples/sample_posteddata.php +++ /dev/null @@ -1,21 +0,0 @@ - diff --git a/media/ckeditor/_samples/sharedspaces.html b/media/ckeditor/_samples/sharedspaces.html deleted file mode 100644 index 52c9c81..0000000 --- a/media/ckeditor/_samples/sharedspaces.html +++ /dev/null @@ -1,153 +0,0 @@ - - - - - Shared Toolbars — CKEditor Sample - - - - - - - -

- CKEditor Sample — Shared Toolbars -

-
-

- This sample shows how to configure multiple CKEditor instances to share some parts of the interface. - You can choose to share the toolbar (topSpace), the elements path - (bottomSpace), or both. -

-

- CKEditor instances with shared spaces can be inserted with a JavaScript call using the following code: -

-
CKEDITOR.replace( 'textarea_id',
-	{
-		sharedSpaces :
-		{
-			top : 'topSpace',
-			bottom : 'bottomSpace'
-		}
-	});
-

- Note that textarea_id in the code above is the id attribute of - the <textarea> element to be replaced with CKEditor. -

-
- -
- -
-
-
-
-

- - -

-

- - -

-

- - -

-

- - -

-

- -

-
-
-
- - - - diff --git a/media/ckeditor/_samples/skins.html b/media/ckeditor/_samples/skins.html deleted file mode 100644 index 491a18b..0000000 --- a/media/ckeditor/_samples/skins.html +++ /dev/null @@ -1,110 +0,0 @@ - - - - - Skins — CKEditor Sample - - - - - - -

- CKEditor Sample — Skins -

-
-

- This sample shows how to automatically replace <textarea> elements - with a CKEditor instance using a specific skin. -

-

- CKEditor with a specified skin (in this case, the "Office 2003" skin) is inserted with a JavaScript call using the following code: -

-
CKEDITOR.replace( 'textarea_id',
-	{
-		skin : 'office2003'
-	});
-

- Note that textarea_id in the code above is the id attribute of - the <textarea> element to be replaced. -

-
- - -
- -
-
-

"Kama" skin

-

The default skin used in CKEditor. No additional configuration is required.

-

- - -

-

"Office 2003" skin

-

Use the following code to configure a CKEditor instance to use the "Office 2003" skin.

-
CKEDITOR.replace( 'textarea_id',
-	{
-		skin : 'office2003'
-	});
-

- - -

-

"V2" skin

-

Use the following code to configure a CKEditor instance to use the "V2" skin.

-
CKEDITOR.replace( 'textarea_id',
-	{
-		skin : 'v2'
-	});
- - -
- - - diff --git a/media/ckeditor/_samples/stylesheetparser.html b/media/ckeditor/_samples/stylesheetparser.html deleted file mode 100644 index c9ef6cc..0000000 --- a/media/ckeditor/_samples/stylesheetparser.html +++ /dev/null @@ -1,93 +0,0 @@ - - - - - Using Stylesheet Parser Plugin — CKEditor Sample - - - - - - -

- CKEditor Sample — Using the Stylesheet Parser Plugin -

-
-

- This sample shows how to configure CKEditor instances to use the - Stylesheet Parser (stylesheetparser) plugin that fills - the Styles drop-down list based on the CSS rules available in the document stylesheet. -

-

- To add a CKEditor instance using the stylesheetparser plugin, insert - the following JavaScript call into your code: -

-
CKEDITOR.replace( 'textarea_id',
-	{
-		extraPlugins : 'stylesheetparser'
-	});
-

- Note that textarea_id in the code above is the id attribute of - the <textarea> element to be replaced with CKEditor. -

-
- - -
- -
-
-

- - - -

-

- -

-
- - - diff --git a/media/ckeditor/_samples/tableresize.html b/media/ckeditor/_samples/tableresize.html deleted file mode 100644 index d01806f..0000000 --- a/media/ckeditor/_samples/tableresize.html +++ /dev/null @@ -1,115 +0,0 @@ - - - - - Using TableResize Plugin — CKEditor Sample - - - - - - -

- CKEditor Sample — Using the TableResize Plugin -

-
-

- This sample shows how to configure CKEditor instances to use the - TableResize (tableresize) plugin that allows - the user to edit table columns by using the mouse. -

-

- The TableResize plugin makes it possible to modify table column width. Hover - your mouse over the column border to see the cursor change to indicate that - the column can be resized. Click and drag your mouse to set the desired width. -

-

- By default the plugin is turned off. To add a CKEditor instance using the - TableResize plugin, insert the following JavaScript call into your code: -

-
CKEDITOR.replace( 'textarea_id',
-	{
-		extraPlugins : 'tableresize'
-	});
-

- Note that textarea_id in the code above is the id attribute of - the <textarea> element to be replaced with CKEditor. -

-
- -
- -
-
-

- - - -

-

- -

-
- - - diff --git a/media/ckeditor/_samples/ui_color.html b/media/ckeditor/_samples/ui_color.html deleted file mode 100644 index 823bbba..0000000 --- a/media/ckeditor/_samples/ui_color.html +++ /dev/null @@ -1,129 +0,0 @@ - - - - - UI Color Picker — CKEditor Sample - - - - - - -

- CKEditor Sample — UI Color Picker -

-
-

- This sample shows how to automatically replace <textarea> elements - with a CKEditor instance with an option to change the color of its user interface. -

-

Setting the User Interface Color

-

- To specify the color of the user interface, set the uiColor property: -

-
CKEDITOR.replace( 'textarea_id',
-	{
-		uiColor: '#EE0000'
-	});
-

- Note that textarea_id in the code above is the id attribute of - the <textarea> element to be replaced. -

-

Enabling the Color Picker

-

- If the uicolor plugin along with the dedicated UIColor - toolbar button is added to CKEditor, the user will also be able to pick the color of the - UI from the color palette available in the UI Color Picker dialog window. -

-

- To insert a CKEditor instance with the uicolor plugin enabled, - use the following JavaScript call: -

-
CKEDITOR.replace( 'textarea_id',
-	{
-		extraPlugins : 'uicolor',
-		toolbar : [ [ 'Bold', 'Italic' ], [ 'UIColor' ] ]
-	});
-
- -
- -
-

- Click the UI Color Picker button to test your color preferences at runtime. -

-

- The first editor instance includes the UI Color Picker toolbar button, - but the default UI color is not defined, so the editor uses the skin color. -

-
-

- - -

-

- The second editor instance includes the UI Color Picker toolbar button. The - default UI color was defined, so the skin color is not used. -

-

- - -

-

- -

-
- - - diff --git a/media/ckeditor/_samples/ui_languages.html b/media/ckeditor/_samples/ui_languages.html deleted file mode 100644 index aefc963..0000000 --- a/media/ckeditor/_samples/ui_languages.html +++ /dev/null @@ -1,134 +0,0 @@ - - - - - User Interface Globalization — CKEditor Sample - - - - - - - -

- CKEditor Sample — User Interface Languages -

-
-

- This sample shows how to automatically replace <textarea> elements - with a CKEditor instance with an option to change the language of its user interface. -

-

- It pulls the language list from CKEditor _languages.js file that contains the list of supported languages and creates - a drop-down list that lets the user change the UI language. -

-

- By default, CKEditor automatically localizes the editor to the language of the user. - The UI language can be controlled with two configuration options: - - language and - defaultLanguage. The defaultLanguage setting specifies the - default CKEditor language to be used when a localization suitable for user's settings is not available. -

-

- To specify the user interface language that will be used no matter what language is - specified in user's browser or operating system, set the language property: -

-
CKEDITOR.replace( 'textarea_id',
-	{
-		// Load the German interface.
-		language: 'de'
-	});
-

- Note that textarea_id in the code above is the id attribute of - the <textarea> element to be replaced. -

-
- -
- -
-
-

- Available languages ( languages!):
- -
- (You may see strange characters if your system does not - support the selected language) -

-

- - -

-
- - - diff --git a/media/ckeditor/_source/adapters/jquery.js b/media/ckeditor/_source/adapters/jquery.js deleted file mode 100644 index b81c13f..0000000 --- a/media/ckeditor/_source/adapters/jquery.js +++ /dev/null @@ -1,306 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @fileOverview jQuery adapter provides easy use of basic CKEditor functions - * and access to internal API. It also integrates some aspects of CKEditor with - * jQuery framework. - * - * Every TEXTAREA, DIV and P elements can be converted to working editor. - * - * Plugin exposes some of editor's event to jQuery event system. All of those are namespaces inside - * ".ckeditor" namespace and can be binded/listened on supported textarea, div and p nodes. - * - * Available jQuery events: - * - instanceReady.ckeditor( editor, rootNode ) - * Triggered when new instance is ready. - * - destroy.ckeditor( editor ) - * Triggered when instance is destroyed. - * - getData.ckeditor( editor, eventData ) - * Triggered when getData event is fired inside editor. It can change returned data using eventData reference. - * - setData.ckeditor( editor ) - * Triggered when getData event is fired inside editor. - * - * @example - * - * - * - */ - -(function() -{ - /** - * Allows CKEditor to override jQuery.fn.val(), making it possible to use the val() - * function on textareas, as usual, having it synchronized with CKEditor.
- *
- * This configuration option is global and executed during the jQuery Adapter loading. - * It can't be customized across editor instances. - * @type Boolean - * @example - * <script> - * CKEDITOR.config.jqueryOverrideVal = true; - * </script> - * <!-- Important: The JQuery adapter is loaded *after* setting jqueryOverrideVal --> - * <script src="/ckeditor/adapters/jquery.js"></script> - * @example - * // ... then later in the code ... - * - * $( 'textarea' ).ckeditor(); - * // ... - * $( 'textarea' ).val( 'New content' ); - */ - CKEDITOR.config.jqueryOverrideVal = typeof CKEDITOR.config.jqueryOverrideVal == 'undefined' - ? true : CKEDITOR.config.jqueryOverrideVal; - - var jQuery = window.jQuery; - - if ( typeof jQuery == 'undefined' ) - return; - - // jQuery object methods. - jQuery.extend( jQuery.fn, - /** @lends jQuery.fn */ - { - /** - * Return existing CKEditor instance for first matched element. - * Allows to easily use internal API. Doesn't return jQuery object. - * - * Raised exception if editor doesn't exist or isn't ready yet. - * - * @name jQuery.ckeditorGet - * @return CKEDITOR.editor - * @see CKEDITOR.editor - */ - ckeditorGet: function() - { - var instance = this.eq( 0 ).data( 'ckeditorInstance' ); - if ( !instance ) - throw "CKEditor not yet initialized, use ckeditor() with callback."; - return instance; - }, - /** - * Triggers creation of CKEditor in all matched elements (reduced to DIV, P and TEXTAREAs). - * Binds callback to instanceReady event of all instances. If editor is already created, than - * callback is fired right away. - * - * Mixed parameter order allowed. - * - * @param callback Function to be run on editor instance. Passed parameters: [ textarea ]. - * Callback is fiered in "this" scope being ckeditor instance and having source textarea as first param. - * - * @param config Configuration options for new instance(s) if not already created. - * See URL - * - * @example - * $( 'textarea' ).ckeditor( function( textarea ) { - * $( textarea ).val( this.getData() ) - * } ); - * - * @name jQuery.fn.ckeditor - * @return jQuery.fn - */ - ckeditor: function( callback, config ) - { - if ( !CKEDITOR.env.isCompatible ) - return this; - - if ( !jQuery.isFunction( callback )) - { - var tmp = config; - config = callback; - callback = tmp; - } - config = config || {}; - - this.filter( 'textarea, div, p' ).each( function() - { - var $element = jQuery( this ), - editor = $element.data( 'ckeditorInstance' ), - instanceLock = $element.data( '_ckeditorInstanceLock' ), - element = this; - - if ( editor && !instanceLock ) - { - if ( callback ) - callback.apply( editor, [ this ] ); - } - else if ( !instanceLock ) - { - // CREATE NEW INSTANCE - - // Handle config.autoUpdateElement inside this plugin if desired. - if ( config.autoUpdateElement - || ( typeof config.autoUpdateElement == 'undefined' && CKEDITOR.config.autoUpdateElement ) ) - { - config.autoUpdateElementJquery = true; - } - - // Always disable config.autoUpdateElement. - config.autoUpdateElement = false; - $element.data( '_ckeditorInstanceLock', true ); - - // Set instance reference in element's data. - editor = CKEDITOR.replace( element, config ); - $element.data( 'ckeditorInstance', editor ); - - // Register callback. - editor.on( 'instanceReady', function( event ) - { - var editor = event.editor; - setTimeout( function() - { - // Delay bit more if editor is still not ready. - if ( !editor.element ) - { - setTimeout( arguments.callee, 100 ); - return; - } - - // Remove this listener. - event.removeListener( 'instanceReady', this.callee ); - - // Forward setData on dataReady. - editor.on( 'dataReady', function() - { - $element.trigger( 'setData' + '.ckeditor', [ editor ] ); - }); - - // Forward getData. - editor.on( 'getData', function( event ) { - $element.trigger( 'getData' + '.ckeditor', [ editor, event.data ] ); - }, 999 ); - - // Forward destroy event. - editor.on( 'destroy', function() - { - $element.trigger( 'destroy.ckeditor', [ editor ] ); - }); - - // Integrate with form submit. - if ( editor.config.autoUpdateElementJquery && $element.is( 'textarea' ) && $element.parents( 'form' ).length ) - { - var onSubmit = function() - { - $element.ckeditor( function() - { - editor.updateElement(); - }); - }; - - // Bind to submit event. - $element.parents( 'form' ).submit( onSubmit ); - - // Bind to form-pre-serialize from jQuery Forms plugin. - $element.parents( 'form' ).bind( 'form-pre-serialize', onSubmit ); - - // Unbind when editor destroyed. - $element.bind( 'destroy.ckeditor', function() - { - $element.parents( 'form' ).unbind( 'submit', onSubmit ); - $element.parents( 'form' ).unbind( 'form-pre-serialize', onSubmit ); - }); - } - - // Garbage collect on destroy. - editor.on( 'destroy', function() - { - $element.data( 'ckeditorInstance', null ); - }); - - // Remove lock. - $element.data( '_ckeditorInstanceLock', null ); - - // Fire instanceReady event. - $element.trigger( 'instanceReady.ckeditor', [ editor ] ); - - // Run given (first) code. - if ( callback ) - callback.apply( editor, [ element ] ); - }, 0 ); - }, null, null, 9999); - } - else - { - // Editor is already during creation process, bind our code to the event. - CKEDITOR.on( 'instanceReady', function( event ) - { - var editor = event.editor; - setTimeout( function() - { - // Delay bit more if editor is still not ready. - if ( !editor.element ) - { - setTimeout( arguments.callee, 100 ); - return; - } - - if ( editor.element.$ == element ) - { - // Run given code. - if ( callback ) - callback.apply( editor, [ element ] ); - } - }, 0 ); - }, null, null, 9999); - } - }); - return this; - } - }); - - // New val() method for objects. - if ( CKEDITOR.config.jqueryOverrideVal ) - { - jQuery.fn.val = CKEDITOR.tools.override( jQuery.fn.val, function( oldValMethod ) - { - /** - * CKEditor-aware val() method. - * - * Acts same as original jQuery val(), but for textareas which have CKEditor instances binded to them, method - * returns editor's content. It also works for settings values. - * - * @param oldValMethod - * @name jQuery.fn.val - */ - return function( newValue, forceNative ) - { - var isSetter = typeof newValue != 'undefined', - result; - - this.each( function() - { - var $this = jQuery( this ), - editor = $this.data( 'ckeditorInstance' ); - - if ( !forceNative && $this.is( 'textarea' ) && editor ) - { - if ( isSetter ) - editor.setData( newValue ); - else - { - result = editor.getData(); - // break; - return null; - } - } - else - { - if ( isSetter ) - oldValMethod.call( $this, newValue ); - else - { - result = oldValMethod.call( $this ); - // break; - return null; - } - } - - return true; - }); - return isSetter ? this : result; - }; - }); - } -})(); diff --git a/media/ckeditor/_source/core/_bootstrap.js b/media/ckeditor/_source/core/_bootstrap.js deleted file mode 100644 index fd5b49b..0000000 --- a/media/ckeditor/_source/core/_bootstrap.js +++ /dev/null @@ -1,87 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @fileOverview API initialization code. - */ - -(function() -{ - // Disable HC detaction in WebKit. (#5429) - if ( CKEDITOR.env.webkit ) - { - CKEDITOR.env.hc = false; - return; - } - - // Check whether high contrast is active by creating a colored border. - var hcDetect = CKEDITOR.dom.element.createFromHtml( - '
', CKEDITOR.document ); - - hcDetect.appendTo( CKEDITOR.document.getHead() ); - - // Update CKEDITOR.env. - // Catch exception needed sometimes for FF. (#4230) - try - { - CKEDITOR.env.hc = hcDetect.getComputedStyle( 'border-top-color' ) == hcDetect.getComputedStyle( 'border-right-color' ); - } - catch (e) - { - CKEDITOR.env.hc = false; - } - - if ( CKEDITOR.env.hc ) - CKEDITOR.env.cssClass += ' cke_hc'; - - hcDetect.remove(); -})(); - -// Load core plugins. -CKEDITOR.plugins.load( CKEDITOR.config.corePlugins.split( ',' ), function() - { - CKEDITOR.status = 'loaded'; - CKEDITOR.fire( 'loaded' ); - - // Process all instances created by the "basic" implementation. - var pending = CKEDITOR._.pending; - if ( pending ) - { - delete CKEDITOR._.pending; - - for ( var i = 0 ; i < pending.length ; i++ ) - CKEDITOR.add( pending[ i ] ); - } - }); - -// Needed for IE6 to not request image (HTTP 200 or 304) for every CSS background. (#6187) -if ( CKEDITOR.env.ie ) -{ - // Remove IE mouse flickering on IE6 because of background images. - try - { - document.execCommand( 'BackgroundImageCache', false, true ); - } - catch (e) - { - // We have been reported about loading problems caused by the above - // line. For safety, let's just ignore errors. - } -} - -/** - * Indicates that CKEditor is running on a High Contrast environment. - * @name CKEDITOR.env.hc - * @example - * if ( CKEDITOR.env.hc ) - * alert( 'You're running on High Contrast mode. The editor interface will get adapted to provide you a better experience.' ); - */ - -/** - * Fired when a CKEDITOR core object is fully loaded and ready for interaction. - * @name CKEDITOR#loaded - * @event - */ diff --git a/media/ckeditor/_source/core/ckeditor.js b/media/ckeditor/_source/core/ckeditor.js deleted file mode 100644 index 3e54930..0000000 --- a/media/ckeditor/_source/core/ckeditor.js +++ /dev/null @@ -1,141 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @fileOverview Contains the third and last part of the {@link CKEDITOR} object - * definition. - */ - -// Remove the CKEDITOR.loadFullCore reference defined on ckeditor_basic. -delete CKEDITOR.loadFullCore; - -/** - * Holds references to all editor instances created. The name of the properties - * in this object correspond to instance names, and their values contains the - * {@link CKEDITOR.editor} object representing them. - * @type {Object} - * @example - * alert( CKEDITOR.instances.editor1.name ); // "editor1" - */ -CKEDITOR.instances = {}; - -/** - * The document of the window holding the CKEDITOR object. - * @type {CKEDITOR.dom.document} - * @example - * alert( CKEDITOR.document.getBody().getName() ); // "body" - */ -CKEDITOR.document = new CKEDITOR.dom.document( document ); - -/** - * Adds an editor instance to the global {@link CKEDITOR} object. This function - * is available for internal use mainly. - * @param {CKEDITOR.editor} editor The editor instance to be added. - * @example - */ -CKEDITOR.add = function( editor ) -{ - CKEDITOR.instances[ editor.name ] = editor; - - editor.on( 'focus', function() - { - if ( CKEDITOR.currentInstance != editor ) - { - CKEDITOR.currentInstance = editor; - CKEDITOR.fire( 'currentInstance' ); - } - }); - - editor.on( 'blur', function() - { - if ( CKEDITOR.currentInstance == editor ) - { - CKEDITOR.currentInstance = null; - CKEDITOR.fire( 'currentInstance' ); - } - }); -}; - -/** - * Removes an editor instance from the global {@link CKEDITOR} object. This function - * is available for internal use only. External code must use {@link CKEDITOR.editor.prototype.destroy} - * to avoid memory leaks. - * @param {CKEDITOR.editor} editor The editor instance to be removed. - * @example - */ -CKEDITOR.remove = function( editor ) -{ - delete CKEDITOR.instances[ editor.name ]; -}; - -/** - * Perform global clean up to free as much memory as possible - * when there are no instances left - */ -CKEDITOR.on( 'instanceDestroyed', function () - { - if ( CKEDITOR.tools.isEmpty( this.instances ) ) - CKEDITOR.fire( 'reset' ); - }); - -// Load the bootstrap script. -CKEDITOR.loader.load( 'core/_bootstrap' ); // @Packager.RemoveLine - -// Tri-state constants. - -/** - * Used to indicate the ON or ACTIVE state. - * @constant - * @example - */ -CKEDITOR.TRISTATE_ON = 1; - -/** - * Used to indicate the OFF or NON ACTIVE state. - * @constant - * @example - */ -CKEDITOR.TRISTATE_OFF = 2; - -/** - * Used to indicate DISABLED state. - * @constant - * @example - */ -CKEDITOR.TRISTATE_DISABLED = 0; - -/** - * The editor which is currently active (have user focus). - * @name CKEDITOR.currentInstance - * @type CKEDITOR.editor - * @see CKEDITOR#currentInstance - * @example - * function showCurrentEditorName() - * { - * if ( CKEDITOR.currentInstance ) - * alert( CKEDITOR.currentInstance.name ); - * else - * alert( 'Please focus an editor first.' ); - * } - */ - -/** - * Fired when the CKEDITOR.currentInstance object reference changes. This may - * happen when setting the focus on different editor instances in the page. - * @name CKEDITOR#currentInstance - * @event - * var editor; // Variable to hold a reference to the current editor. - * CKEDITOR.on( 'currentInstance' , function( e ) - * { - * editor = CKEDITOR.currentInstance; - * }); - */ - -/** - * Fired when the last instance has been destroyed. This event is used to perform - * global memory clean up. - * @name CKEDITOR#reset - * @event - */ diff --git a/media/ckeditor/_source/core/ckeditor_base.js b/media/ckeditor/_source/core/ckeditor_base.js deleted file mode 100644 index e5396ee..0000000 --- a/media/ckeditor/_source/core/ckeditor_base.js +++ /dev/null @@ -1,235 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @fileOverview Contains the first and essential part of the {@link CKEDITOR} - * object definition. - */ - -// #### Compressed Code -// Must be updated on changes in the script as well as updated in the -// ckeditor_source.js and ckeditor_basic_source.js files. - -// if(!window.CKEDITOR)window.CKEDITOR=(function(){var a={timestamp:'',version:'3.6.3',revision:'7474',rnd:Math.floor(Math.random()*900)+100,_:{},status:'unloaded',basePath:(function(){var d=window.CKEDITOR_BASEPATH||'';if(!d){var e=document.getElementsByTagName('script');for(var f=0;f=0?'&':'?')+'t='+this.timestamp;return d;}},b=window.CKEDITOR_GETURL;if(b){var c=a.getUrl;a.getUrl=function(d){return b.call(a,d)||c.call(a,d);};}return a;})(); - -// #### Raw code -// ATTENTION: read the above "Compressed Code" notes when changing this code. - -/* @Packager.RemoveLine -// Avoid having the editor code initialized twice. (#7588) -// Use CKEDITOR.dom to check whether the full ckeditor.js code has been loaded -// or just ckeditor_basic.js. -// Remove these lines when compressing manually. -if ( window.CKEDITOR && window.CKEDITOR.dom ) - return; -@Packager.RemoveLine */ - -if ( !window.CKEDITOR ) -{ - /** - * @name CKEDITOR - * @namespace This is the API entry point. The entire CKEditor code runs under this object. - * @example - */ - window.CKEDITOR = (function() - { - var CKEDITOR = - /** @lends CKEDITOR */ - { - - /** - * A constant string unique for each release of CKEditor. Its value - * is used, by default, to build the URL for all resources loaded - * by the editor code, guaranteeing clean cache results when - * upgrading. - * @type String - * @example - * alert( CKEDITOR.timestamp ); // e.g. '87dm' - */ - // The production implementation contains a fixed timestamp, unique - // for each release and generated by the releaser. - // (Base 36 value of each component of YYMMDDHH - 4 chars total - e.g. 87bm == 08071122) - timestamp : 'C3HA5RM', - - /** - * Contains the CKEditor version number. - * @type String - * @example - * alert( CKEDITOR.version ); // e.g. 'CKEditor 3.4.1' - */ - version : '3.6.3', - - /** - * Contains the CKEditor revision number. - * The revision number is incremented automatically, following each - * modification to the CKEditor source code. - * @type String - * @example - * alert( CKEDITOR.revision ); // e.g. '3975' - */ - revision : '7474', - - /** - * A 3-digit random integer, valid for the entire life of the CKEDITOR object. - * @type Number - * @example - * alert( CKEDITOR.rnd ); // e.g. '319' - */ - rnd : Math.floor( Math.random() * ( 999/*Max*/ - 100/*Min*/ + 1 ) ) + 100/*Min*/, - - /** - * Private object used to hold core stuff. It should not be used outside of - * the API code as properties defined here may change at any time - * without notice. - * @private - */ - _ : {}, - - /** - * Indicates the API loading status. The following statuses are available: - *
    - *
  • unloaded: the API is not yet loaded.
  • - *
  • basic_loaded: the basic API features are available.
  • - *
  • basic_ready: the basic API is ready to load the full core code.
  • - *
  • loading: the full API is being loaded.
  • - *
  • loaded: the API can be fully used.
  • - *
- * @type String - * @example - * if ( CKEDITOR.status == 'loaded' ) - * { - * // The API can now be fully used. - * } - */ - status : 'unloaded', - - /** - * Contains the full URL for the CKEditor installation directory. - * It is possible to manually provide the base path by setting a - * global variable named CKEDITOR_BASEPATH. This global variable - * must be set before the editor script loading. - * @type String - * @example - * alert( CKEDITOR.basePath ); // "http://www.example.com/ckeditor/" (e.g.) - */ - basePath : (function() - { - // ATTENTION: fixes to this code must be ported to - // var basePath in "core/loader.js". - - // Find out the editor directory path, based on its ")' ); - } - } - - return $ && new CKEDITOR.dom.document( $.contentWindow.document ); - }, - - /** - * Copy all the attributes from one node to the other, kinda like a clone - * skipAttributes is an object with the attributes that must NOT be copied. - * @param {CKEDITOR.dom.element} dest The destination element. - * @param {Object} skipAttributes A dictionary of attributes to skip. - * @example - */ - copyAttributes : function( dest, skipAttributes ) - { - var attributes = this.$.attributes; - skipAttributes = skipAttributes || {}; - - for ( var n = 0 ; n < attributes.length ; n++ ) - { - var attribute = attributes[n]; - - // Lowercase attribute name hard rule is broken for - // some attribute on IE, e.g. CHECKED. - var attrName = attribute.nodeName.toLowerCase(), - attrValue; - - // We can set the type only once, so do it with the proper value, not copying it. - if ( attrName in skipAttributes ) - continue; - - if ( attrName == 'checked' && ( attrValue = this.getAttribute( attrName ) ) ) - dest.setAttribute( attrName, attrValue ); - // IE BUG: value attribute is never specified even if it exists. - else if ( attribute.specified || - ( CKEDITOR.env.ie && attribute.nodeValue && attrName == 'value' ) ) - { - attrValue = this.getAttribute( attrName ); - if ( attrValue === null ) - attrValue = attribute.nodeValue; - - dest.setAttribute( attrName, attrValue ); - } - } - - // The style: - if ( this.$.style.cssText !== '' ) - dest.$.style.cssText = this.$.style.cssText; - }, - - /** - * Changes the tag name of the current element. - * @param {String} newTag The new tag for the element. - */ - renameNode : function( newTag ) - { - // If it's already correct exit here. - if ( this.getName() == newTag ) - return; - - var doc = this.getDocument(); - - // Create the new node. - var newNode = new CKEDITOR.dom.element( newTag, doc ); - - // Copy all attributes. - this.copyAttributes( newNode ); - - // Move children to the new node. - this.moveChildren( newNode ); - - // Replace the node. - this.getParent() && this.$.parentNode.replaceChild( newNode.$, this.$ ); - newNode.$[ 'data-cke-expando' ] = this.$[ 'data-cke-expando' ]; - this.$ = newNode.$; - }, - - /** - * Gets a DOM tree descendant under the current node. - * @param {Array|Number} indices The child index or array of child indices under the node. - * @returns {CKEDITOR.dom.node} The specified DOM child under the current node. Null if child does not exist. - * @example - * var strong = p.getChild(0); - */ - getChild : function( indices ) - { - var rawNode = this.$; - - if ( !indices.slice ) - rawNode = rawNode.childNodes[ indices ]; - else - { - while ( indices.length > 0 && rawNode ) - rawNode = rawNode.childNodes[ indices.shift() ]; - } - - return rawNode ? new CKEDITOR.dom.node( rawNode ) : null; - }, - - getChildCount : function() - { - return this.$.childNodes.length; - }, - - disableContextMenu : function() - { - this.on( 'contextmenu', function( event ) - { - // Cancel the browser context menu. - if ( !event.data.getTarget().hasClass( 'cke_enable_context_menu' ) ) - event.data.preventDefault(); - } ); - }, - - /** - * Gets element's direction. Supports both CSS 'direction' prop and 'dir' attr. - */ - getDirection : function( useComputed ) - { - return useComputed ? - this.getComputedStyle( 'direction' ) - // Webkit: offline element returns empty direction (#8053). - || this.getDirection() - || this.getDocument().$.dir - || this.getDocument().getBody().getDirection( 1 ) - : this.getStyle( 'direction' ) || this.getAttribute( 'dir' ); - }, - - /** - * Gets, sets and removes custom data to be stored as HTML5 data-* attributes. - * @param {String} name The name of the attribute, excluding the 'data-' part. - * @param {String} [value] The value to set. If set to false, the attribute will be removed. - * @example - * element.data( 'extra-info', 'test' ); // appended the attribute data-extra-info="test" to the element - * alert( element.data( 'extra-info' ) ); // "test" - * element.data( 'extra-info', false ); // remove the data-extra-info attribute from the element - */ - data : function ( name, value ) - { - name = 'data-' + name; - if ( value === undefined ) - return this.getAttribute( name ); - else if ( value === false ) - this.removeAttribute( name ); - else - this.setAttribute( name, value ); - - return null; - } - }); - -( function() -{ - var sides = { - width : [ "border-left-width", "border-right-width","padding-left", "padding-right" ], - height : [ "border-top-width", "border-bottom-width", "padding-top", "padding-bottom" ] - }; - - function marginAndPaddingSize( type ) - { - var adjustment = 0; - for ( var i = 0, len = sides[ type ].length; i < len; i++ ) - adjustment += parseInt( this.getComputedStyle( sides [ type ][ i ] ) || 0, 10 ) || 0; - return adjustment; - } - - /** - * Sets the element size considering the box model. - * @name CKEDITOR.dom.element.prototype.setSize - * @function - * @param {String} type The dimension to set. It accepts "width" and "height". - * @param {Number} size The length unit in px. - * @param {Boolean} isBorderBox Apply the size based on the border box model. - */ - CKEDITOR.dom.element.prototype.setSize = function( type, size, isBorderBox ) - { - if ( typeof size == 'number' ) - { - if ( isBorderBox && !( CKEDITOR.env.ie && CKEDITOR.env.quirks ) ) - size -= marginAndPaddingSize.call( this, type ); - - this.setStyle( type, size + 'px' ); - } - }; - - /** - * Gets the element size, possibly considering the box model. - * @name CKEDITOR.dom.element.prototype.getSize - * @function - * @param {String} type The dimension to get. It accepts "width" and "height". - * @param {Boolean} isBorderBox Get the size based on the border box model. - */ - CKEDITOR.dom.element.prototype.getSize = function( type, isBorderBox ) - { - var size = Math.max( this.$[ 'offset' + CKEDITOR.tools.capitalize( type ) ], - this.$[ 'client' + CKEDITOR.tools.capitalize( type ) ] ) || 0; - - if ( isBorderBox ) - size -= marginAndPaddingSize.call( this, type ); - - return size; - }; -})(); diff --git a/media/ckeditor/_source/core/dom/elementpath.js b/media/ckeditor/_source/core/dom/elementpath.js deleted file mode 100644 index 95ed334..0000000 --- a/media/ckeditor/_source/core/dom/elementpath.js +++ /dev/null @@ -1,117 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -(function() -{ - // Elements that may be considered the "Block boundary" in an element path. - var pathBlockElements = { address:1,blockquote:1,dl:1,h1:1,h2:1,h3:1,h4:1,h5:1,h6:1,p:1,pre:1,li:1,dt:1,dd:1, legend:1,caption:1 }; - - // Elements that may be considered the "Block limit" in an element path. - var pathBlockLimitElements = { body:1,div:1,table:1,tbody:1,tr:1,td:1,th:1,form:1,fieldset:1 }; - - // Check if an element contains any block element. - var checkHasBlock = function( element ) - { - var childNodes = element.getChildren(); - - for ( var i = 0, count = childNodes.count() ; i < count ; i++ ) - { - var child = childNodes.getItem( i ); - - if ( child.type == CKEDITOR.NODE_ELEMENT && CKEDITOR.dtd.$block[ child.getName() ] ) - return true; - } - - return false; - }; - - /** - * @class - */ - CKEDITOR.dom.elementPath = function( lastNode ) - { - var block = null; - var blockLimit = null; - var elements = []; - - var e = lastNode; - - while ( e ) - { - if ( e.type == CKEDITOR.NODE_ELEMENT ) - { - if ( !this.lastElement ) - this.lastElement = e; - - var elementName = e.getName(); - - if ( !blockLimit ) - { - if ( !block && pathBlockElements[ elementName ] ) - block = e; - - if ( pathBlockLimitElements[ elementName ] ) - { - // DIV is considered the Block, if no block is available (#525) - // and if it doesn't contain other blocks. - if ( !block && elementName == 'div' && !checkHasBlock( e ) ) - block = e; - else - blockLimit = e; - } - } - - elements.push( e ); - - if ( elementName == 'body' ) - break; - } - e = e.getParent(); - } - - this.block = block; - this.blockLimit = blockLimit; - this.elements = elements; - }; -})(); - -CKEDITOR.dom.elementPath.prototype = -{ - /** - * Compares this element path with another one. - * @param {CKEDITOR.dom.elementPath} otherPath The elementPath object to be - * compared with this one. - * @returns {Boolean} "true" if the paths are equal, containing the same - * number of elements and the same elements in the same order. - */ - compare : function( otherPath ) - { - var thisElements = this.elements; - var otherElements = otherPath && otherPath.elements; - - if ( !otherElements || thisElements.length != otherElements.length ) - return false; - - for ( var i = 0 ; i < thisElements.length ; i++ ) - { - if ( !thisElements[ i ].equals( otherElements[ i ] ) ) - return false; - } - - return true; - }, - - contains : function( tagNames ) - { - var elements = this.elements; - for ( var i = 0 ; i < elements.length ; i++ ) - { - if ( elements[ i ].getName() in tagNames ) - return elements[ i ]; - } - - return null; - } -}; diff --git a/media/ckeditor/_source/core/dom/event.js b/media/ckeditor/_source/core/dom/event.js deleted file mode 100644 index ea40ef0..0000000 --- a/media/ckeditor/_source/core/dom/event.js +++ /dev/null @@ -1,145 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @fileOverview Defines the {@link CKEDITOR.dom.event} class, which - * represents the a native DOM event object. - */ - -/** - * Represents a native DOM event object. - * @constructor - * @param {Object} domEvent A native DOM event object. - * @example - */ -CKEDITOR.dom.event = function( domEvent ) -{ - /** - * The native DOM event object represented by this class instance. - * @type Object - * @example - */ - this.$ = domEvent; -}; - -CKEDITOR.dom.event.prototype = -{ - /** - * Gets the key code associated to the event. - * @returns {Number} The key code. - * @example - * alert( event.getKey() ); "65" is "a" has been pressed - */ - getKey : function() - { - return this.$.keyCode || this.$.which; - }, - - /** - * Gets a number represeting the combination of the keys pressed during the - * event. It is the sum with the current key code and the {@link CKEDITOR.CTRL}, - * {@link CKEDITOR.SHIFT} and {@link CKEDITOR.ALT} constants. - * @returns {Number} The number representing the keys combination. - * @example - * alert( event.getKeystroke() == 65 ); // "a" key - * alert( event.getKeystroke() == CKEDITOR.CTRL + 65 ); // CTRL + "a" key - * alert( event.getKeystroke() == CKEDITOR.CTRL + CKEDITOR.SHIFT + 65 ); // CTRL + SHIFT + "a" key - */ - getKeystroke : function() - { - var keystroke = this.getKey(); - - if ( this.$.ctrlKey || this.$.metaKey ) - keystroke += CKEDITOR.CTRL; - - if ( this.$.shiftKey ) - keystroke += CKEDITOR.SHIFT; - - if ( this.$.altKey ) - keystroke += CKEDITOR.ALT; - - return keystroke; - }, - - /** - * Prevents the original behavior of the event to happen. It can optionally - * stop propagating the event in the event chain. - * @param {Boolean} [stopPropagation] Stop propagating this event in the - * event chain. - * @example - * var element = CKEDITOR.document.getById( 'myElement' ); - * element.on( 'click', function( ev ) - * { - * // The DOM event object is passed by the "data" property. - * var domEvent = ev.data; - * // Prevent the click to chave any effect in the element. - * domEvent.preventDefault(); - * }); - */ - preventDefault : function( stopPropagation ) - { - var $ = this.$; - if ( $.preventDefault ) - $.preventDefault(); - else - $.returnValue = false; - - if ( stopPropagation ) - this.stopPropagation(); - }, - - stopPropagation : function() - { - var $ = this.$; - if ( $.stopPropagation ) - $.stopPropagation(); - else - $.cancelBubble = true; - }, - - /** - * Returns the DOM node where the event was targeted to. - * @returns {CKEDITOR.dom.node} The target DOM node. - * @example - * var element = CKEDITOR.document.getById( 'myElement' ); - * element.on( 'click', function( ev ) - * { - * // The DOM event object is passed by the "data" property. - * var domEvent = ev.data; - * // Add a CSS class to the event target. - * domEvent.getTarget().addClass( 'clicked' ); - * }); - */ - - getTarget : function() - { - var rawNode = this.$.target || this.$.srcElement; - return rawNode ? new CKEDITOR.dom.node( rawNode ) : null; - } -}; - -// For the followind constants, we need to go over the Unicode boundaries -// (0x10FFFF) to avoid collision. - -/** - * CTRL key (0x110000). - * @constant - * @example - */ -CKEDITOR.CTRL = 0x110000; - -/** - * SHIFT key (0x220000). - * @constant - * @example - */ -CKEDITOR.SHIFT = 0x220000; - -/** - * ALT key (0x440000). - * @constant - * @example - */ -CKEDITOR.ALT = 0x440000; diff --git a/media/ckeditor/_source/core/dom/node.js b/media/ckeditor/_source/core/dom/node.js deleted file mode 100644 index b7985d1..0000000 --- a/media/ckeditor/_source/core/dom/node.js +++ /dev/null @@ -1,691 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @fileOverview Defines the {@link CKEDITOR.dom.node} class which is the base - * class for classes that represent DOM nodes. - */ - -/** - * Base class for classes representing DOM nodes. This constructor may return - * an instance of a class that inherits from this class, like - * {@link CKEDITOR.dom.element} or {@link CKEDITOR.dom.text}. - * @augments CKEDITOR.dom.domObject - * @param {Object} domNode A native DOM node. - * @constructor - * @see CKEDITOR.dom.element - * @see CKEDITOR.dom.text - * @example - */ -CKEDITOR.dom.node = function( domNode ) -{ - if ( domNode ) - { - var type = domNode.nodeType == CKEDITOR.NODE_DOCUMENT ? 'document' - : domNode.nodeType == CKEDITOR.NODE_ELEMENT ? 'element' - : domNode.nodeType == CKEDITOR.NODE_TEXT ? 'text' - : domNode.nodeType == CKEDITOR.NODE_COMMENT ? 'comment' - : 'domObject'; // Call the base constructor otherwise. - - return new CKEDITOR.dom[ type ]( domNode ); - } - - return this; -}; - -CKEDITOR.dom.node.prototype = new CKEDITOR.dom.domObject(); - -/** - * Element node type. - * @constant - * @example - */ -CKEDITOR.NODE_ELEMENT = 1; - -/** - * Document node type. - * @constant - * @example - */ -CKEDITOR.NODE_DOCUMENT = 9; - -/** - * Text node type. - * @constant - * @example - */ -CKEDITOR.NODE_TEXT = 3; - -/** - * Comment node type. - * @constant - * @example - */ -CKEDITOR.NODE_COMMENT = 8; - -CKEDITOR.NODE_DOCUMENT_FRAGMENT = 11; - -CKEDITOR.POSITION_IDENTICAL = 0; -CKEDITOR.POSITION_DISCONNECTED = 1; -CKEDITOR.POSITION_FOLLOWING = 2; -CKEDITOR.POSITION_PRECEDING = 4; -CKEDITOR.POSITION_IS_CONTAINED = 8; -CKEDITOR.POSITION_CONTAINS = 16; - -CKEDITOR.tools.extend( CKEDITOR.dom.node.prototype, - /** @lends CKEDITOR.dom.node.prototype */ - { - /** - * Makes this node a child of another element. - * @param {CKEDITOR.dom.element} element The target element to which - * this node will be appended. - * @returns {CKEDITOR.dom.element} The target element. - * @example - * var p = new CKEDITOR.dom.element( 'p' ); - * var strong = new CKEDITOR.dom.element( 'strong' ); - * strong.appendTo( p ); - * - * // result: "<p><strong></strong></p>" - */ - appendTo : function( element, toStart ) - { - element.append( this, toStart ); - return element; - }, - - clone : function( includeChildren, cloneId ) - { - var $clone = this.$.cloneNode( includeChildren ); - - var removeIds = function( node ) - { - if ( node.nodeType != CKEDITOR.NODE_ELEMENT ) - return; - - if ( !cloneId ) - node.removeAttribute( 'id', false ); - node.removeAttribute( 'data-cke-expando', false ); - - if ( includeChildren ) - { - var childs = node.childNodes; - for ( var i=0; i < childs.length; i++ ) - removeIds( childs[ i ] ); - } - }; - - // The "id" attribute should never be cloned to avoid duplication. - removeIds( $clone ); - - return new CKEDITOR.dom.node( $clone ); - }, - - hasPrevious : function() - { - return !!this.$.previousSibling; - }, - - hasNext : function() - { - return !!this.$.nextSibling; - }, - - /** - * Inserts this element after a node. - * @param {CKEDITOR.dom.node} node The node that will precede this element. - * @returns {CKEDITOR.dom.node} The node preceding this one after - * insertion. - * @example - * var em = new CKEDITOR.dom.element( 'em' ); - * var strong = new CKEDITOR.dom.element( 'strong' ); - * strong.insertAfter( em ); - * - * // result: "<em></em><strong></strong>" - */ - insertAfter : function( node ) - { - node.$.parentNode.insertBefore( this.$, node.$.nextSibling ); - return node; - }, - - /** - * Inserts this element before a node. - * @param {CKEDITOR.dom.node} node The node that will succeed this element. - * @returns {CKEDITOR.dom.node} The node being inserted. - * @example - * var em = new CKEDITOR.dom.element( 'em' ); - * var strong = new CKEDITOR.dom.element( 'strong' ); - * strong.insertBefore( em ); - * - * // result: "<strong></strong><em></em>" - */ - insertBefore : function( node ) - { - node.$.parentNode.insertBefore( this.$, node.$ ); - return node; - }, - - insertBeforeMe : function( node ) - { - this.$.parentNode.insertBefore( node.$, this.$ ); - return node; - }, - - /** - * Retrieves a uniquely identifiable tree address for this node. - * The tree address returned is an array of integers, with each integer - * indicating a child index of a DOM node, starting from - * document.documentElement. - * - * For example, assuming <body> is the second child - * of <html> (<head> being the first), - * and we would like to address the third child under the - * fourth child of <body>, the tree address returned would be: - * [1, 3, 2] - * - * The tree address cannot be used for finding back the DOM tree node once - * the DOM tree structure has been modified. - */ - getAddress : function( normalized ) - { - var address = []; - var $documentElement = this.getDocument().$.documentElement; - var node = this.$; - - while ( node && node != $documentElement ) - { - var parentNode = node.parentNode; - - if ( parentNode ) - { - // Get the node index. For performance, call getIndex - // directly, instead of creating a new node object. - address.unshift( this.getIndex.call( { $ : node }, normalized ) ); - } - - node = parentNode; - } - - return address; - }, - - /** - * Gets the document containing this element. - * @returns {CKEDITOR.dom.document} The document. - * @example - * var element = CKEDITOR.document.getById( 'example' ); - * alert( element.getDocument().equals( CKEDITOR.document ) ); // "true" - */ - getDocument : function() - { - return new CKEDITOR.dom.document( this.$.ownerDocument || this.$.parentNode.ownerDocument ); - }, - - getIndex : function( normalized ) - { - // Attention: getAddress depends on this.$ - - var current = this.$, - index = 0; - - while ( ( current = current.previousSibling ) ) - { - // When normalizing, do not count it if this is an - // empty text node or if it's a text node following another one. - if ( normalized && current.nodeType == 3 && - ( !current.nodeValue.length || - ( current.previousSibling && current.previousSibling.nodeType == 3 ) ) ) - { - continue; - } - - index++; - } - - return index; - }, - - getNextSourceNode : function( startFromSibling, nodeType, guard ) - { - // If "guard" is a node, transform it in a function. - if ( guard && !guard.call ) - { - var guardNode = guard; - guard = function( node ) - { - return !node.equals( guardNode ); - }; - } - - var node = ( !startFromSibling && this.getFirst && this.getFirst() ), - parent; - - // Guarding when we're skipping the current element( no children or 'startFromSibling' ). - // send the 'moving out' signal even we don't actually dive into. - if ( !node ) - { - if ( this.type == CKEDITOR.NODE_ELEMENT && guard && guard( this, true ) === false ) - return null; - node = this.getNext(); - } - - while ( !node && ( parent = ( parent || this ).getParent() ) ) - { - // The guard check sends the "true" paramenter to indicate that - // we are moving "out" of the element. - if ( guard && guard( parent, true ) === false ) - return null; - - node = parent.getNext(); - } - - if ( !node ) - return null; - - if ( guard && guard( node ) === false ) - return null; - - if ( nodeType && nodeType != node.type ) - return node.getNextSourceNode( false, nodeType, guard ); - - return node; - }, - - getPreviousSourceNode : function( startFromSibling, nodeType, guard ) - { - if ( guard && !guard.call ) - { - var guardNode = guard; - guard = function( node ) - { - return !node.equals( guardNode ); - }; - } - - var node = ( !startFromSibling && this.getLast && this.getLast() ), - parent; - - // Guarding when we're skipping the current element( no children or 'startFromSibling' ). - // send the 'moving out' signal even we don't actually dive into. - if ( !node ) - { - if ( this.type == CKEDITOR.NODE_ELEMENT && guard && guard( this, true ) === false ) - return null; - node = this.getPrevious(); - } - - while ( !node && ( parent = ( parent || this ).getParent() ) ) - { - // The guard check sends the "true" paramenter to indicate that - // we are moving "out" of the element. - if ( guard && guard( parent, true ) === false ) - return null; - - node = parent.getPrevious(); - } - - if ( !node ) - return null; - - if ( guard && guard( node ) === false ) - return null; - - if ( nodeType && node.type != nodeType ) - return node.getPreviousSourceNode( false, nodeType, guard ); - - return node; - }, - - getPrevious : function( evaluator ) - { - var previous = this.$, retval; - do - { - previous = previous.previousSibling; - - // Avoid returning the doc type node. - // http://www.w3.org/TR/REC-DOM-Level-1/level-one-core.html#ID-412266927 - retval = previous && previous.nodeType != 10 && new CKEDITOR.dom.node( previous ); - } - while ( retval && evaluator && !evaluator( retval ) ) - return retval; - }, - - /** - * Gets the node that follows this element in its parent's child list. - * @param {Function} evaluator Filtering the result node. - * @returns {CKEDITOR.dom.node} The next node or null if not available. - * @example - * var element = CKEDITOR.dom.element.createFromHtml( '<div><b>Example</b> <i>next</i></div>' ); - * var first = element.getFirst().getNext(); - * alert( first.getName() ); // "i" - */ - getNext : function( evaluator ) - { - var next = this.$, retval; - do - { - next = next.nextSibling; - retval = next && new CKEDITOR.dom.node( next ); - } - while ( retval && evaluator && !evaluator( retval ) ) - return retval; - }, - - /** - * Gets the parent element for this node. - * @returns {CKEDITOR.dom.element} The parent element. - * @example - * var node = editor.document.getBody().getFirst(); - * var parent = node.getParent(); - * alert( node.getName() ); // "body" - */ - getParent : function() - { - var parent = this.$.parentNode; - return ( parent && parent.nodeType == 1 ) ? new CKEDITOR.dom.node( parent ) : null; - }, - - getParents : function( closerFirst ) - { - var node = this; - var parents = []; - - do - { - parents[ closerFirst ? 'push' : 'unshift' ]( node ); - } - while ( ( node = node.getParent() ) ) - - return parents; - }, - - getCommonAncestor : function( node ) - { - if ( node.equals( this ) ) - return this; - - if ( node.contains && node.contains( this ) ) - return node; - - var start = this.contains ? this : this.getParent(); - - do - { - if ( start.contains( node ) ) - return start; - } - while ( ( start = start.getParent() ) ); - - return null; - }, - - getPosition : function( otherNode ) - { - var $ = this.$; - var $other = otherNode.$; - - if ( $.compareDocumentPosition ) - return $.compareDocumentPosition( $other ); - - // IE and Safari have no support for compareDocumentPosition. - - if ( $ == $other ) - return CKEDITOR.POSITION_IDENTICAL; - - // Only element nodes support contains and sourceIndex. - if ( this.type == CKEDITOR.NODE_ELEMENT && otherNode.type == CKEDITOR.NODE_ELEMENT ) - { - if ( $.contains ) - { - if ( $.contains( $other ) ) - return CKEDITOR.POSITION_CONTAINS + CKEDITOR.POSITION_PRECEDING; - - if ( $other.contains( $ ) ) - return CKEDITOR.POSITION_IS_CONTAINED + CKEDITOR.POSITION_FOLLOWING; - } - - if ( 'sourceIndex' in $ ) - { - return ( $.sourceIndex < 0 || $other.sourceIndex < 0 ) ? CKEDITOR.POSITION_DISCONNECTED : - ( $.sourceIndex < $other.sourceIndex ) ? CKEDITOR.POSITION_PRECEDING : - CKEDITOR.POSITION_FOLLOWING; - } - } - - // For nodes that don't support compareDocumentPosition, contains - // or sourceIndex, their "address" is compared. - - var addressOfThis = this.getAddress(), - addressOfOther = otherNode.getAddress(), - minLevel = Math.min( addressOfThis.length, addressOfOther.length ); - - // Determinate preceed/follow relationship. - for ( var i = 0 ; i <= minLevel - 1 ; i++ ) - { - if ( addressOfThis[ i ] != addressOfOther[ i ] ) - { - if ( i < minLevel ) - { - return addressOfThis[ i ] < addressOfOther[ i ] ? - CKEDITOR.POSITION_PRECEDING : CKEDITOR.POSITION_FOLLOWING; - } - break; - } - } - - // Determinate contains/contained relationship. - return ( addressOfThis.length < addressOfOther.length ) ? - CKEDITOR.POSITION_CONTAINS + CKEDITOR.POSITION_PRECEDING : - CKEDITOR.POSITION_IS_CONTAINED + CKEDITOR.POSITION_FOLLOWING; - }, - - /** - * Gets the closest ancestor node of this node, specified by its name. - * @param {String} reference The name of the ancestor node to search or - * an object with the node names to search for. - * @param {Boolean} [includeSelf] Whether to include the current - * node in the search. - * @returns {CKEDITOR.dom.node} The located ancestor node or null if not found. - * @since 3.6.1 - * @example - * // Suppose we have the following HTML structure: - * // <div id="outer"><div id="inner"><p><b>Some text</b></p></div></div> - * // If node == <b> - * ascendant = node.getAscendant( 'div' ); // ascendant == <div id="inner"> - * ascendant = node.getAscendant( 'b' ); // ascendant == null - * ascendant = node.getAscendant( 'b', true ); // ascendant == <b> - * ascendant = node.getAscendant( { div: 1, p: 1} ); // Searches for the first 'div' or 'p': ascendant == <div id="inner"> - */ - getAscendant : function( reference, includeSelf ) - { - var $ = this.$, - name; - - if ( !includeSelf ) - $ = $.parentNode; - - while ( $ ) - { - if ( $.nodeName && ( name = $.nodeName.toLowerCase(), ( typeof reference == 'string' ? name == reference : name in reference ) ) ) - return new CKEDITOR.dom.node( $ ); - - $ = $.parentNode; - } - return null; - }, - - hasAscendant : function( name, includeSelf ) - { - var $ = this.$; - - if ( !includeSelf ) - $ = $.parentNode; - - while ( $ ) - { - if ( $.nodeName && $.nodeName.toLowerCase() == name ) - return true; - - $ = $.parentNode; - } - return false; - }, - - move : function( target, toStart ) - { - target.append( this.remove(), toStart ); - }, - - /** - * Removes this node from the document DOM. - * @param {Boolean} [preserveChildren] Indicates that the children - * elements must remain in the document, removing only the outer - * tags. - * @example - * var element = CKEDITOR.dom.element.getById( 'MyElement' ); - * element.remove(); - */ - remove : function( preserveChildren ) - { - var $ = this.$; - var parent = $.parentNode; - - if ( parent ) - { - if ( preserveChildren ) - { - // Move all children before the node. - for ( var child ; ( child = $.firstChild ) ; ) - { - parent.insertBefore( $.removeChild( child ), $ ); - } - } - - parent.removeChild( $ ); - } - - return this; - }, - - replace : function( nodeToReplace ) - { - this.insertBefore( nodeToReplace ); - nodeToReplace.remove(); - }, - - trim : function() - { - this.ltrim(); - this.rtrim(); - }, - - ltrim : function() - { - var child; - while ( this.getFirst && ( child = this.getFirst() ) ) - { - if ( child.type == CKEDITOR.NODE_TEXT ) - { - var trimmed = CKEDITOR.tools.ltrim( child.getText() ), - originalLength = child.getLength(); - - if ( !trimmed ) - { - child.remove(); - continue; - } - else if ( trimmed.length < originalLength ) - { - child.split( originalLength - trimmed.length ); - - // IE BUG: child.remove() may raise JavaScript errors here. (#81) - this.$.removeChild( this.$.firstChild ); - } - } - break; - } - }, - - rtrim : function() - { - var child; - while ( this.getLast && ( child = this.getLast() ) ) - { - if ( child.type == CKEDITOR.NODE_TEXT ) - { - var trimmed = CKEDITOR.tools.rtrim( child.getText() ), - originalLength = child.getLength(); - - if ( !trimmed ) - { - child.remove(); - continue; - } - else if ( trimmed.length < originalLength ) - { - child.split( trimmed.length ); - - // IE BUG: child.getNext().remove() may raise JavaScript errors here. - // (#81) - this.$.lastChild.parentNode.removeChild( this.$.lastChild ); - } - } - break; - } - - if ( !CKEDITOR.env.ie && !CKEDITOR.env.opera ) - { - child = this.$.lastChild; - - if ( child && child.type == 1 && child.nodeName.toLowerCase() == 'br' ) - { - // Use "eChildNode.parentNode" instead of "node" to avoid IE bug (#324). - child.parentNode.removeChild( child ) ; - } - } - }, - - /** - * Checks if this node is read-only (should not be changed). - * @returns {Boolean} - * @since 3.5 - * @example - * // For the following HTML: - * // <div contenteditable="false">Some <b>text</b></div> - * - * // If "ele" is the above <div> - * ele.isReadOnly(); // true - */ - isReadOnly : function() - { - var element = this; - if ( this.type != CKEDITOR.NODE_ELEMENT ) - element = this.getParent(); - - if ( element && typeof element.$.isContentEditable != 'undefined' ) - return ! ( element.$.isContentEditable || element.data( 'cke-editable' ) ); - else - { - // Degrade for old browsers which don't support "isContentEditable", e.g. FF3 - var current = element; - while( current ) - { - if ( current.is( 'body' ) || !!current.data( 'cke-editable' ) ) - break; - - if ( current.getAttribute( 'contentEditable' ) == 'false' ) - return true; - else if ( current.getAttribute( 'contentEditable' ) == 'true' ) - break; - - current = current.getParent(); - } - - return false; - } - } - } -); diff --git a/media/ckeditor/_source/core/dom/nodelist.js b/media/ckeditor/_source/core/dom/nodelist.js deleted file mode 100644 index 991c77e..0000000 --- a/media/ckeditor/_source/core/dom/nodelist.js +++ /dev/null @@ -1,26 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @class - */ -CKEDITOR.dom.nodeList = function( nativeList ) -{ - this.$ = nativeList; -}; - -CKEDITOR.dom.nodeList.prototype = -{ - count : function() - { - return this.$.length; - }, - - getItem : function( index ) - { - var $node = this.$[ index ]; - return $node ? new CKEDITOR.dom.node( $node ) : null; - } -}; diff --git a/media/ckeditor/_source/core/dom/range.js b/media/ckeditor/_source/core/dom/range.js deleted file mode 100644 index 2dfacea..0000000 --- a/media/ckeditor/_source/core/dom/range.js +++ /dev/null @@ -1,2068 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * Creates a CKEDITOR.dom.range instance that can be used inside a specific - * DOM Document. - * @class Represents a delimited piece of content in a DOM Document. - * It is contiguous in the sense that it can be characterized as selecting all - * of the content between a pair of boundary-points.
- *
- * This class shares much of the W3C - * Document Object Model Range - * ideas and features, adding several range manipulation tools to it, but it's - * not intended to be compatible with it. - * @param {CKEDITOR.dom.document} document The document into which the range - * features will be available. - * @example - * // Create a range for the entire contents of the editor document body. - * var range = new CKEDITOR.dom.range( editor.document ); - * range.selectNodeContents( editor.document.getBody() ); - * // Delete the contents. - * range.deleteContents(); - */ -CKEDITOR.dom.range = function( document ) -{ - /** - * Node within which the range begins. - * @type {CKEDITOR.NODE_ELEMENT|CKEDITOR.NODE_TEXT} - * @example - * var range = new CKEDITOR.dom.range( editor.document ); - * range.selectNodeContents( editor.document.getBody() ); - * alert( range.startContainer.getName() ); // "body" - */ - this.startContainer = null; - - /** - * Offset within the starting node of the range. - * @type {Number} - * @example - * var range = new CKEDITOR.dom.range( editor.document ); - * range.selectNodeContents( editor.document.getBody() ); - * alert( range.startOffset ); // "0" - */ - this.startOffset = null; - - /** - * Node within which the range ends. - * @type {CKEDITOR.NODE_ELEMENT|CKEDITOR.NODE_TEXT} - * @example - * var range = new CKEDITOR.dom.range( editor.document ); - * range.selectNodeContents( editor.document.getBody() ); - * alert( range.endContainer.getName() ); // "body" - */ - this.endContainer = null; - - /** - * Offset within the ending node of the range. - * @type {Number} - * @example - * var range = new CKEDITOR.dom.range( editor.document ); - * range.selectNodeContents( editor.document.getBody() ); - * alert( range.endOffset ); // == editor.document.getBody().getChildCount() - */ - this.endOffset = null; - - /** - * Indicates that this is a collapsed range. A collapsed range has it's - * start and end boudaries at the very same point so nothing is contained - * in it. - * @example - * var range = new CKEDITOR.dom.range( editor.document ); - * range.selectNodeContents( editor.document.getBody() ); - * alert( range.collapsed ); // "false" - * range.collapse(); - * alert( range.collapsed ); // "true" - */ - this.collapsed = true; - - /** - * The document within which the range can be used. - * @type {CKEDITOR.dom.document} - * @example - * // Selects the body contents of the range document. - * range.selectNodeContents( range.document.getBody() ); - */ - this.document = document; -}; - -(function() -{ - // Updates the "collapsed" property for the given range object. - var updateCollapsed = function( range ) - { - range.collapsed = ( - range.startContainer && - range.endContainer && - range.startContainer.equals( range.endContainer ) && - range.startOffset == range.endOffset ); - }; - - // This is a shared function used to delete, extract and clone the range - // contents. - // V2 - var execContentsAction = function( range, action, docFrag, mergeThen ) - { - range.optimizeBookmark(); - - var startNode = range.startContainer; - var endNode = range.endContainer; - - var startOffset = range.startOffset; - var endOffset = range.endOffset; - - var removeStartNode; - var removeEndNode; - - // For text containers, we must simply split the node and point to the - // second part. The removal will be handled by the rest of the code . - if ( endNode.type == CKEDITOR.NODE_TEXT ) - endNode = endNode.split( endOffset ); - else - { - // If the end container has children and the offset is pointing - // to a child, then we should start from it. - if ( endNode.getChildCount() > 0 ) - { - // If the offset points after the last node. - if ( endOffset >= endNode.getChildCount() ) - { - // Let's create a temporary node and mark it for removal. - endNode = endNode.append( range.document.createText( '' ) ); - removeEndNode = true; - } - else - endNode = endNode.getChild( endOffset ); - } - } - - // For text containers, we must simply split the node. The removal will - // be handled by the rest of the code . - if ( startNode.type == CKEDITOR.NODE_TEXT ) - { - startNode.split( startOffset ); - - // In cases the end node is the same as the start node, the above - // splitting will also split the end, so me must move the end to - // the second part of the split. - if ( startNode.equals( endNode ) ) - endNode = startNode.getNext(); - } - else - { - // If the start container has children and the offset is pointing - // to a child, then we should start from its previous sibling. - - // If the offset points to the first node, we don't have a - // sibling, so let's use the first one, but mark it for removal. - if ( !startOffset ) - { - // Let's create a temporary node and mark it for removal. - startNode = startNode.getFirst().insertBeforeMe( range.document.createText( '' ) ); - removeStartNode = true; - } - else if ( startOffset >= startNode.getChildCount() ) - { - // Let's create a temporary node and mark it for removal. - startNode = startNode.append( range.document.createText( '' ) ); - removeStartNode = true; - } - else - startNode = startNode.getChild( startOffset ).getPrevious(); - } - - // Get the parent nodes tree for the start and end boundaries. - var startParents = startNode.getParents(); - var endParents = endNode.getParents(); - - // Compare them, to find the top most siblings. - var i, topStart, topEnd; - - for ( i = 0 ; i < startParents.length ; i++ ) - { - topStart = startParents[ i ]; - topEnd = endParents[ i ]; - - // The compared nodes will match until we find the top most - // siblings (different nodes that have the same parent). - // "i" will hold the index in the parents array for the top - // most element. - if ( !topStart.equals( topEnd ) ) - break; - } - - var clone = docFrag, levelStartNode, levelClone, currentNode, currentSibling; - - // Remove all successive sibling nodes for every node in the - // startParents tree. - for ( var j = i ; j < startParents.length ; j++ ) - { - levelStartNode = startParents[j]; - - // For Extract and Clone, we must clone this level. - if ( clone && !levelStartNode.equals( startNode ) ) // action = 0 = Delete - levelClone = clone.append( levelStartNode.clone() ); - - currentNode = levelStartNode.getNext(); - - while ( currentNode ) - { - // Stop processing when the current node matches a node in the - // endParents tree or if it is the endNode. - if ( currentNode.equals( endParents[ j ] ) || currentNode.equals( endNode ) ) - break; - - // Cache the next sibling. - currentSibling = currentNode.getNext(); - - // If cloning, just clone it. - if ( action == 2 ) // 2 = Clone - clone.append( currentNode.clone( true ) ); - else - { - // Both Delete and Extract will remove the node. - currentNode.remove(); - - // When Extracting, move the removed node to the docFrag. - if ( action == 1 ) // 1 = Extract - clone.append( currentNode ); - } - - currentNode = currentSibling; - } - - if ( clone ) - clone = levelClone; - } - - clone = docFrag; - - // Remove all previous sibling nodes for every node in the - // endParents tree. - for ( var k = i ; k < endParents.length ; k++ ) - { - levelStartNode = endParents[ k ]; - - // For Extract and Clone, we must clone this level. - if ( action > 0 && !levelStartNode.equals( endNode ) ) // action = 0 = Delete - levelClone = clone.append( levelStartNode.clone() ); - - // The processing of siblings may have already been done by the parent. - if ( !startParents[ k ] || levelStartNode.$.parentNode != startParents[ k ].$.parentNode ) - { - currentNode = levelStartNode.getPrevious(); - - while ( currentNode ) - { - // Stop processing when the current node matches a node in the - // startParents tree or if it is the startNode. - if ( currentNode.equals( startParents[ k ] ) || currentNode.equals( startNode ) ) - break; - - // Cache the next sibling. - currentSibling = currentNode.getPrevious(); - - // If cloning, just clone it. - if ( action == 2 ) // 2 = Clone - clone.$.insertBefore( currentNode.$.cloneNode( true ), clone.$.firstChild ) ; - else - { - // Both Delete and Extract will remove the node. - currentNode.remove(); - - // When Extracting, mode the removed node to the docFrag. - if ( action == 1 ) // 1 = Extract - clone.$.insertBefore( currentNode.$, clone.$.firstChild ); - } - - currentNode = currentSibling; - } - } - - if ( clone ) - clone = levelClone; - } - - if ( action == 2 ) // 2 = Clone. - { - // No changes in the DOM should be done, so fix the split text (if any). - - var startTextNode = range.startContainer; - if ( startTextNode.type == CKEDITOR.NODE_TEXT ) - { - startTextNode.$.data += startTextNode.$.nextSibling.data; - startTextNode.$.parentNode.removeChild( startTextNode.$.nextSibling ); - } - - var endTextNode = range.endContainer; - if ( endTextNode.type == CKEDITOR.NODE_TEXT && endTextNode.$.nextSibling ) - { - endTextNode.$.data += endTextNode.$.nextSibling.data; - endTextNode.$.parentNode.removeChild( endTextNode.$.nextSibling ); - } - } - else - { - // Collapse the range. - - // If a node has been partially selected, collapse the range between - // topStart and topEnd. Otherwise, simply collapse it to the start. (W3C specs). - if ( topStart && topEnd && ( startNode.$.parentNode != topStart.$.parentNode || endNode.$.parentNode != topEnd.$.parentNode ) ) - { - var endIndex = topEnd.getIndex(); - - // If the start node is to be removed, we must correct the - // index to reflect the removal. - if ( removeStartNode && topEnd.$.parentNode == startNode.$.parentNode ) - endIndex--; - - // Merge splitted parents. - if ( mergeThen && topStart.type == CKEDITOR.NODE_ELEMENT ) - { - var span = CKEDITOR.dom.element.createFromHtml( ' ', range.document ); - span.insertAfter( topStart ); - topStart.mergeSiblings( false ); - range.moveToBookmark( { startNode : span } ); - } - else - range.setStart( topEnd.getParent(), endIndex ); - } - - // Collapse it to the start. - range.collapse( true ); - } - - // Cleanup any marked node. - if ( removeStartNode ) - startNode.remove(); - - if ( removeEndNode && endNode.$.parentNode ) - endNode.remove(); - }; - - var inlineChildReqElements = { abbr:1,acronym:1,b:1,bdo:1,big:1,cite:1,code:1,del:1,dfn:1,em:1,font:1,i:1,ins:1,label:1,kbd:1,q:1,samp:1,small:1,span:1,strike:1,strong:1,sub:1,sup:1,tt:1,u:1,'var':1 }; - - // Creates the appropriate node evaluator for the dom walker used inside - // check(Start|End)OfBlock. - function getCheckStartEndBlockEvalFunction( isStart ) - { - var hadBr = false, bookmarkEvaluator = CKEDITOR.dom.walker.bookmark( true ); - return function( node ) - { - // First ignore bookmark nodes. - if ( bookmarkEvaluator( node ) ) - return true; - - if ( node.type == CKEDITOR.NODE_TEXT ) - { - // If there's any visible text, then we're not at the start. - if ( node.hasAscendant( 'pre' ) || CKEDITOR.tools.trim( node.getText() ).length ) - return false; - } - else if ( node.type == CKEDITOR.NODE_ELEMENT ) - { - // If there are non-empty inline elements (e.g. ), then we're not - // at the start. - if ( !inlineChildReqElements[ node.getName() ] ) - { - // If we're working at the end-of-block, forgive the first
in non-IE - // browsers. - if ( !isStart && !CKEDITOR.env.ie && node.getName() == 'br' && !hadBr ) - hadBr = true; - else - return false; - } - } - return true; - }; - } - - - var isBogus = CKEDITOR.dom.walker.bogus(); - // Evaluator for CKEDITOR.dom.element::checkBoundaryOfElement, reject any - // text node and non-empty elements unless it's being bookmark text. - function elementBoundaryEval( checkStart ) - { - return function( node ) - { - // Tolerant bogus br when checking at the end of block. - // Reject any text node unless it's being bookmark - // OR it's spaces. - // Reject any element unless it's being invisible empty. (#3883) - return !checkStart && isBogus( node ) || - ( node.type == CKEDITOR.NODE_TEXT ? - !CKEDITOR.tools.trim( node.getText() ) || !!node.getParent().data( 'cke-bookmark' ) - : node.getName() in CKEDITOR.dtd.$removeEmpty ); - }; - } - - var whitespaceEval = new CKEDITOR.dom.walker.whitespaces(), - bookmarkEval = new CKEDITOR.dom.walker.bookmark(); - - function nonWhitespaceOrBookmarkEval( node ) - { - // Whitespaces and bookmark nodes are to be ignored. - return !whitespaceEval( node ) && !bookmarkEval( node ); - } - - CKEDITOR.dom.range.prototype = - { - clone : function() - { - var clone = new CKEDITOR.dom.range( this.document ); - - clone.startContainer = this.startContainer; - clone.startOffset = this.startOffset; - clone.endContainer = this.endContainer; - clone.endOffset = this.endOffset; - clone.collapsed = this.collapsed; - - return clone; - }, - - collapse : function( toStart ) - { - if ( toStart ) - { - this.endContainer = this.startContainer; - this.endOffset = this.startOffset; - } - else - { - this.startContainer = this.endContainer; - this.startOffset = this.endOffset; - } - - this.collapsed = true; - }, - - /** - * The content nodes of the range are cloned and added to a document fragment, which is returned. - * Note: Text selection may lost after invoking this method. (caused by text node splitting). - */ - cloneContents : function() - { - var docFrag = new CKEDITOR.dom.documentFragment( this.document ); - - if ( !this.collapsed ) - execContentsAction( this, 2, docFrag ); - - return docFrag; - }, - - /** - * Deletes the content nodes of the range permanently from the DOM tree. - * @param {Boolean} [mergeThen] Merge any splitted elements result in DOM true due to partial selection. - */ - deleteContents : function( mergeThen ) - { - if ( this.collapsed ) - return; - - execContentsAction( this, 0, null, mergeThen ); - }, - - /** - * The content nodes of the range are cloned and added to a document fragment, - * meanwhile they're removed permanently from the DOM tree. - * @param {Boolean} [mergeThen] Merge any splitted elements result in DOM true due to partial selection. - */ - extractContents : function( mergeThen ) - { - var docFrag = new CKEDITOR.dom.documentFragment( this.document ); - - if ( !this.collapsed ) - execContentsAction( this, 1, docFrag, mergeThen ); - - return docFrag; - }, - - /** - * Creates a bookmark object, which can be later used to restore the - * range by using the moveToBookmark function. - * This is an "intrusive" way to create a bookmark. It includes tags - * in the range boundaries. The advantage of it is that it is possible to - * handle DOM mutations when moving back to the bookmark. - * Attention: the inclusion of nodes in the DOM is a design choice and - * should not be changed as there are other points in the code that may be - * using those nodes to perform operations. See GetBookmarkNode. - * @param {Boolean} [serializable] Indicates that the bookmark nodes - * must contain ids, which can be used to restore the range even - * when these nodes suffer mutations (like a clonation or innerHTML - * change). - * @returns {Object} And object representing a bookmark. - */ - createBookmark : function( serializable ) - { - var startNode, endNode; - var baseId; - var clone; - var collapsed = this.collapsed; - - startNode = this.document.createElement( 'span' ); - startNode.data( 'cke-bookmark', 1 ); - startNode.setStyle( 'display', 'none' ); - - // For IE, it must have something inside, otherwise it may be - // removed during DOM operations. - startNode.setHtml( ' ' ); - - if ( serializable ) - { - baseId = 'cke_bm_' + CKEDITOR.tools.getNextNumber(); - startNode.setAttribute( 'id', baseId + 'S' ); - } - - // If collapsed, the endNode will not be created. - if ( !collapsed ) - { - endNode = startNode.clone(); - endNode.setHtml( ' ' ); - - if ( serializable ) - endNode.setAttribute( 'id', baseId + 'E' ); - - clone = this.clone(); - clone.collapse(); - clone.insertNode( endNode ); - } - - clone = this.clone(); - clone.collapse( true ); - clone.insertNode( startNode ); - - // Update the range position. - if ( endNode ) - { - this.setStartAfter( startNode ); - this.setEndBefore( endNode ); - } - else - this.moveToPosition( startNode, CKEDITOR.POSITION_AFTER_END ); - - return { - startNode : serializable ? baseId + 'S' : startNode, - endNode : serializable ? baseId + 'E' : endNode, - serializable : serializable, - collapsed : collapsed - }; - }, - - /** - * Creates a "non intrusive" and "mutation sensible" bookmark. This - * kind of bookmark should be used only when the DOM is supposed to - * remain stable after its creation. - * @param {Boolean} [normalized] Indicates that the bookmark must - * normalized. When normalized, the successive text nodes are - * considered a single node. To sucessful load a normalized - * bookmark, the DOM tree must be also normalized before calling - * moveToBookmark. - * @returns {Object} An object representing the bookmark. - */ - createBookmark2 : function( normalized ) - { - var startContainer = this.startContainer, - endContainer = this.endContainer; - - var startOffset = this.startOffset, - endOffset = this.endOffset; - - var collapsed = this.collapsed; - - var child, previous; - - // If there is no range then get out of here. - // It happens on initial load in Safari #962 and if the editor it's - // hidden also in Firefox - if ( !startContainer || !endContainer ) - return { start : 0, end : 0 }; - - if ( normalized ) - { - // Find out if the start is pointing to a text node that will - // be normalized. - if ( startContainer.type == CKEDITOR.NODE_ELEMENT ) - { - child = startContainer.getChild( startOffset ); - - // In this case, move the start information to that text - // node. - if ( child && child.type == CKEDITOR.NODE_TEXT - && startOffset > 0 && child.getPrevious().type == CKEDITOR.NODE_TEXT ) - { - startContainer = child; - startOffset = 0; - } - - // Get the normalized offset. - if ( child && child.type == CKEDITOR.NODE_ELEMENT ) - startOffset = child.getIndex( 1 ); - } - - // Normalize the start. - while ( startContainer.type == CKEDITOR.NODE_TEXT - && ( previous = startContainer.getPrevious() ) - && previous.type == CKEDITOR.NODE_TEXT ) - { - startContainer = previous; - startOffset += previous.getLength(); - } - - // Process the end only if not normalized. - if ( !collapsed ) - { - // Find out if the start is pointing to a text node that - // will be normalized. - if ( endContainer.type == CKEDITOR.NODE_ELEMENT ) - { - child = endContainer.getChild( endOffset ); - - // In this case, move the start information to that - // text node. - if ( child && child.type == CKEDITOR.NODE_TEXT - && endOffset > 0 && child.getPrevious().type == CKEDITOR.NODE_TEXT ) - { - endContainer = child; - endOffset = 0; - } - - // Get the normalized offset. - if ( child && child.type == CKEDITOR.NODE_ELEMENT ) - endOffset = child.getIndex( 1 ); - } - - // Normalize the end. - while ( endContainer.type == CKEDITOR.NODE_TEXT - && ( previous = endContainer.getPrevious() ) - && previous.type == CKEDITOR.NODE_TEXT ) - { - endContainer = previous; - endOffset += previous.getLength(); - } - } - } - - return { - start : startContainer.getAddress( normalized ), - end : collapsed ? null : endContainer.getAddress( normalized ), - startOffset : startOffset, - endOffset : endOffset, - normalized : normalized, - collapsed : collapsed, - is2 : true // It's a createBookmark2 bookmark. - }; - }, - - moveToBookmark : function( bookmark ) - { - if ( bookmark.is2 ) // Created with createBookmark2(). - { - // Get the start information. - var startContainer = this.document.getByAddress( bookmark.start, bookmark.normalized ), - startOffset = bookmark.startOffset; - - // Get the end information. - var endContainer = bookmark.end && this.document.getByAddress( bookmark.end, bookmark.normalized ), - endOffset = bookmark.endOffset; - - // Set the start boundary. - this.setStart( startContainer, startOffset ); - - // Set the end boundary. If not available, collapse it. - if ( endContainer ) - this.setEnd( endContainer, endOffset ); - else - this.collapse( true ); - } - else // Created with createBookmark(). - { - var serializable = bookmark.serializable, - startNode = serializable ? this.document.getById( bookmark.startNode ) : bookmark.startNode, - endNode = serializable ? this.document.getById( bookmark.endNode ) : bookmark.endNode; - - // Set the range start at the bookmark start node position. - this.setStartBefore( startNode ); - - // Remove it, because it may interfere in the setEndBefore call. - startNode.remove(); - - // Set the range end at the bookmark end node position, or simply - // collapse it if it is not available. - if ( endNode ) - { - this.setEndBefore( endNode ); - endNode.remove(); - } - else - this.collapse( true ); - } - }, - - getBoundaryNodes : function() - { - var startNode = this.startContainer, - endNode = this.endContainer, - startOffset = this.startOffset, - endOffset = this.endOffset, - childCount; - - if ( startNode.type == CKEDITOR.NODE_ELEMENT ) - { - childCount = startNode.getChildCount(); - if ( childCount > startOffset ) - startNode = startNode.getChild( startOffset ); - else if ( childCount < 1 ) - startNode = startNode.getPreviousSourceNode(); - else // startOffset > childCount but childCount is not 0 - { - // Try to take the node just after the current position. - startNode = startNode.$; - while ( startNode.lastChild ) - startNode = startNode.lastChild; - startNode = new CKEDITOR.dom.node( startNode ); - - // Normally we should take the next node in DFS order. But it - // is also possible that we've already reached the end of - // document. - startNode = startNode.getNextSourceNode() || startNode; - } - } - if ( endNode.type == CKEDITOR.NODE_ELEMENT ) - { - childCount = endNode.getChildCount(); - if ( childCount > endOffset ) - endNode = endNode.getChild( endOffset ).getPreviousSourceNode( true ); - else if ( childCount < 1 ) - endNode = endNode.getPreviousSourceNode(); - else // endOffset > childCount but childCount is not 0 - { - // Try to take the node just before the current position. - endNode = endNode.$; - while ( endNode.lastChild ) - endNode = endNode.lastChild; - endNode = new CKEDITOR.dom.node( endNode ); - } - } - - // Sometimes the endNode will come right before startNode for collapsed - // ranges. Fix it. (#3780) - if ( startNode.getPosition( endNode ) & CKEDITOR.POSITION_FOLLOWING ) - startNode = endNode; - - return { startNode : startNode, endNode : endNode }; - }, - - /** - * Find the node which fully contains the range. - * @param includeSelf - * @param {Boolean} ignoreTextNode Whether ignore CKEDITOR.NODE_TEXT type. - */ - getCommonAncestor : function( includeSelf , ignoreTextNode ) - { - var start = this.startContainer, - end = this.endContainer, - ancestor; - - if ( start.equals( end ) ) - { - if ( includeSelf - && start.type == CKEDITOR.NODE_ELEMENT - && this.startOffset == this.endOffset - 1 ) - ancestor = start.getChild( this.startOffset ); - else - ancestor = start; - } - else - ancestor = start.getCommonAncestor( end ); - - return ignoreTextNode && !ancestor.is ? ancestor.getParent() : ancestor; - }, - - /** - * Transforms the startContainer and endContainer properties from text - * nodes to element nodes, whenever possible. This is actually possible - * if either of the boundary containers point to a text node, and its - * offset is set to zero, or after the last char in the node. - */ - optimize : function() - { - var container = this.startContainer; - var offset = this.startOffset; - - if ( container.type != CKEDITOR.NODE_ELEMENT ) - { - if ( !offset ) - this.setStartBefore( container ); - else if ( offset >= container.getLength() ) - this.setStartAfter( container ); - } - - container = this.endContainer; - offset = this.endOffset; - - if ( container.type != CKEDITOR.NODE_ELEMENT ) - { - if ( !offset ) - this.setEndBefore( container ); - else if ( offset >= container.getLength() ) - this.setEndAfter( container ); - } - }, - - /** - * Move the range out of bookmark nodes if they'd been the container. - */ - optimizeBookmark: function() - { - var startNode = this.startContainer, - endNode = this.endContainer; - - if ( startNode.is && startNode.is( 'span' ) - && startNode.data( 'cke-bookmark' ) ) - this.setStartAt( startNode, CKEDITOR.POSITION_BEFORE_START ); - if ( endNode && endNode.is && endNode.is( 'span' ) - && endNode.data( 'cke-bookmark' ) ) - this.setEndAt( endNode, CKEDITOR.POSITION_AFTER_END ); - }, - - trim : function( ignoreStart, ignoreEnd ) - { - var startContainer = this.startContainer, - startOffset = this.startOffset, - collapsed = this.collapsed; - if ( ( !ignoreStart || collapsed ) - && startContainer && startContainer.type == CKEDITOR.NODE_TEXT ) - { - // If the offset is zero, we just insert the new node before - // the start. - if ( !startOffset ) - { - startOffset = startContainer.getIndex(); - startContainer = startContainer.getParent(); - } - // If the offset is at the end, we'll insert it after the text - // node. - else if ( startOffset >= startContainer.getLength() ) - { - startOffset = startContainer.getIndex() + 1; - startContainer = startContainer.getParent(); - } - // In other case, we split the text node and insert the new - // node at the split point. - else - { - var nextText = startContainer.split( startOffset ); - - startOffset = startContainer.getIndex() + 1; - startContainer = startContainer.getParent(); - - // Check all necessity of updating the end boundary. - if ( this.startContainer.equals( this.endContainer ) ) - this.setEnd( nextText, this.endOffset - this.startOffset ); - else if ( startContainer.equals( this.endContainer ) ) - this.endOffset += 1; - } - - this.setStart( startContainer, startOffset ); - - if ( collapsed ) - { - this.collapse( true ); - return; - } - } - - var endContainer = this.endContainer; - var endOffset = this.endOffset; - - if ( !( ignoreEnd || collapsed ) - && endContainer && endContainer.type == CKEDITOR.NODE_TEXT ) - { - // If the offset is zero, we just insert the new node before - // the start. - if ( !endOffset ) - { - endOffset = endContainer.getIndex(); - endContainer = endContainer.getParent(); - } - // If the offset is at the end, we'll insert it after the text - // node. - else if ( endOffset >= endContainer.getLength() ) - { - endOffset = endContainer.getIndex() + 1; - endContainer = endContainer.getParent(); - } - // In other case, we split the text node and insert the new - // node at the split point. - else - { - endContainer.split( endOffset ); - - endOffset = endContainer.getIndex() + 1; - endContainer = endContainer.getParent(); - } - - this.setEnd( endContainer, endOffset ); - } - }, - - /** - * Expands the range so that partial units are completely contained. - * @param unit {Number} The unit type to expand with. - * @param {Boolean} [excludeBrs=false] Whether include line-breaks when expanding. - */ - enlarge : function( unit, excludeBrs ) - { - switch ( unit ) - { - case CKEDITOR.ENLARGE_ELEMENT : - - if ( this.collapsed ) - return; - - // Get the common ancestor. - var commonAncestor = this.getCommonAncestor(); - - var body = this.document.getBody(); - - // For each boundary - // a. Depending on its position, find out the first node to be checked (a sibling) or, if not available, to be enlarge. - // b. Go ahead checking siblings and enlarging the boundary as much as possible until the common ancestor is not reached. After reaching the common ancestor, just save the enlargeable node to be used later. - - var startTop, endTop; - - var enlargeable, sibling, commonReached; - - // Indicates that the node can be added only if whitespace - // is available before it. - var needsWhiteSpace = false; - var isWhiteSpace; - var siblingText; - - // Process the start boundary. - - var container = this.startContainer; - var offset = this.startOffset; - - if ( container.type == CKEDITOR.NODE_TEXT ) - { - if ( offset ) - { - // Check if there is any non-space text before the - // offset. Otherwise, container is null. - container = !CKEDITOR.tools.trim( container.substring( 0, offset ) ).length && container; - - // If we found only whitespace in the node, it - // means that we'll need more whitespace to be able - // to expand. For example, can be expanded in - // "A [B]", but not in "A [B]". - needsWhiteSpace = !!container; - } - - if ( container ) - { - if ( !( sibling = container.getPrevious() ) ) - enlargeable = container.getParent(); - } - } - else - { - // If we have offset, get the node preceeding it as the - // first sibling to be checked. - if ( offset ) - sibling = container.getChild( offset - 1 ) || container.getLast(); - - // If there is no sibling, mark the container to be - // enlarged. - if ( !sibling ) - enlargeable = container; - } - - while ( enlargeable || sibling ) - { - if ( enlargeable && !sibling ) - { - // If we reached the common ancestor, mark the flag - // for it. - if ( !commonReached && enlargeable.equals( commonAncestor ) ) - commonReached = true; - - if ( !body.contains( enlargeable ) ) - break; - - // If we don't need space or this element breaks - // the line, then enlarge it. - if ( !needsWhiteSpace || enlargeable.getComputedStyle( 'display' ) != 'inline' ) - { - needsWhiteSpace = false; - - // If the common ancestor has been reached, - // we'll not enlarge it immediately, but just - // mark it to be enlarged later if the end - // boundary also enlarges it. - if ( commonReached ) - startTop = enlargeable; - else - this.setStartBefore( enlargeable ); - } - - sibling = enlargeable.getPrevious(); - } - - // Check all sibling nodes preceeding the enlargeable - // node. The node wil lbe enlarged only if none of them - // blocks it. - while ( sibling ) - { - // This flag indicates that this node has - // whitespaces at the end. - isWhiteSpace = false; - - if ( sibling.type == CKEDITOR.NODE_COMMENT ) - { - sibling = sibling.getPrevious(); - continue; - } - else if ( sibling.type == CKEDITOR.NODE_TEXT ) - { - siblingText = sibling.getText(); - - if ( /[^\s\ufeff]/.test( siblingText ) ) - sibling = null; - - isWhiteSpace = /[\s\ufeff]$/.test( siblingText ); - } - else - { - // If this is a visible element. - // We need to check for the bookmark attribute because IE insists on - // rendering the display:none nodes we use for bookmarks. (#3363) - // Line-breaks (br) are rendered with zero width, which we don't want to include. (#7041) - if ( ( sibling.$.offsetWidth > 0 || excludeBrs && sibling.is( 'br' ) ) && !sibling.data( 'cke-bookmark' ) ) - { - // We'll accept it only if we need - // whitespace, and this is an inline - // element with whitespace only. - if ( needsWhiteSpace && CKEDITOR.dtd.$removeEmpty[ sibling.getName() ] ) - { - // It must contains spaces and inline elements only. - - siblingText = sibling.getText(); - - if ( (/[^\s\ufeff]/).test( siblingText ) ) // Spaces + Zero Width No-Break Space (U+FEFF) - sibling = null; - else - { - var allChildren = sibling.$.getElementsByTagName( '*' ); - for ( var i = 0, child ; child = allChildren[ i++ ] ; ) - { - if ( !CKEDITOR.dtd.$removeEmpty[ child.nodeName.toLowerCase() ] ) - { - sibling = null; - break; - } - } - } - - if ( sibling ) - isWhiteSpace = !!siblingText.length; - } - else - sibling = null; - } - } - - // A node with whitespaces has been found. - if ( isWhiteSpace ) - { - // Enlarge the last enlargeable node, if we - // were waiting for spaces. - if ( needsWhiteSpace ) - { - if ( commonReached ) - startTop = enlargeable; - else if ( enlargeable ) - this.setStartBefore( enlargeable ); - } - else - needsWhiteSpace = true; - } - - if ( sibling ) - { - var next = sibling.getPrevious(); - - if ( !enlargeable && !next ) - { - // Set the sibling as enlargeable, so it's - // parent will be get later outside this while. - enlargeable = sibling; - sibling = null; - break; - } - - sibling = next; - } - else - { - // If sibling has been set to null, then we - // need to stop enlarging. - enlargeable = null; - } - } - - if ( enlargeable ) - enlargeable = enlargeable.getParent(); - } - - // Process the end boundary. This is basically the same - // code used for the start boundary, with small changes to - // make it work in the oposite side (to the right). This - // makes it difficult to reuse the code here. So, fixes to - // the above code are likely to be replicated here. - - container = this.endContainer; - offset = this.endOffset; - - // Reset the common variables. - enlargeable = sibling = null; - commonReached = needsWhiteSpace = false; - - if ( container.type == CKEDITOR.NODE_TEXT ) - { - // Check if there is any non-space text after the - // offset. Otherwise, container is null. - container = !CKEDITOR.tools.trim( container.substring( offset ) ).length && container; - - // If we found only whitespace in the node, it - // means that we'll need more whitespace to be able - // to expand. For example, can be expanded in - // "A [B]", but not in "A [B]". - needsWhiteSpace = !( container && container.getLength() ); - - if ( container ) - { - if ( !( sibling = container.getNext() ) ) - enlargeable = container.getParent(); - } - } - else - { - // Get the node right after the boudary to be checked - // first. - sibling = container.getChild( offset ); - - if ( !sibling ) - enlargeable = container; - } - - while ( enlargeable || sibling ) - { - if ( enlargeable && !sibling ) - { - if ( !commonReached && enlargeable.equals( commonAncestor ) ) - commonReached = true; - - if ( !body.contains( enlargeable ) ) - break; - - if ( !needsWhiteSpace || enlargeable.getComputedStyle( 'display' ) != 'inline' ) - { - needsWhiteSpace = false; - - if ( commonReached ) - endTop = enlargeable; - else if ( enlargeable ) - this.setEndAfter( enlargeable ); - } - - sibling = enlargeable.getNext(); - } - - while ( sibling ) - { - isWhiteSpace = false; - - if ( sibling.type == CKEDITOR.NODE_TEXT ) - { - siblingText = sibling.getText(); - - if ( /[^\s\ufeff]/.test( siblingText ) ) - sibling = null; - - isWhiteSpace = /^[\s\ufeff]/.test( siblingText ); - } - else if ( sibling.type == CKEDITOR.NODE_ELEMENT ) - { - // If this is a visible element. - // We need to check for the bookmark attribute because IE insists on - // rendering the display:none nodes we use for bookmarks. (#3363) - // Line-breaks (br) are rendered with zero width, which we don't want to include. (#7041) - if ( ( sibling.$.offsetWidth > 0 || excludeBrs && sibling.is( 'br' ) ) && !sibling.data( 'cke-bookmark' ) ) - { - // We'll accept it only if we need - // whitespace, and this is an inline - // element with whitespace only. - if ( needsWhiteSpace && CKEDITOR.dtd.$removeEmpty[ sibling.getName() ] ) - { - // It must contains spaces and inline elements only. - - siblingText = sibling.getText(); - - if ( (/[^\s\ufeff]/).test( siblingText ) ) - sibling = null; - else - { - allChildren = sibling.$.getElementsByTagName( '*' ); - for ( i = 0 ; child = allChildren[ i++ ] ; ) - { - if ( !CKEDITOR.dtd.$removeEmpty[ child.nodeName.toLowerCase() ] ) - { - sibling = null; - break; - } - } - } - - if ( sibling ) - isWhiteSpace = !!siblingText.length; - } - else - sibling = null; - } - } - else - isWhiteSpace = 1; - - if ( isWhiteSpace ) - { - if ( needsWhiteSpace ) - { - if ( commonReached ) - endTop = enlargeable; - else - this.setEndAfter( enlargeable ); - } - } - - if ( sibling ) - { - next = sibling.getNext(); - - if ( !enlargeable && !next ) - { - enlargeable = sibling; - sibling = null; - break; - } - - sibling = next; - } - else - { - // If sibling has been set to null, then we - // need to stop enlarging. - enlargeable = null; - } - } - - if ( enlargeable ) - enlargeable = enlargeable.getParent(); - } - - // If the common ancestor can be enlarged by both boundaries, then include it also. - if ( startTop && endTop ) - { - commonAncestor = startTop.contains( endTop ) ? endTop : startTop; - - this.setStartBefore( commonAncestor ); - this.setEndAfter( commonAncestor ); - } - break; - - case CKEDITOR.ENLARGE_BLOCK_CONTENTS: - case CKEDITOR.ENLARGE_LIST_ITEM_CONTENTS: - - // Enlarging the start boundary. - var walkerRange = new CKEDITOR.dom.range( this.document ); - - body = this.document.getBody(); - - walkerRange.setStartAt( body, CKEDITOR.POSITION_AFTER_START ); - walkerRange.setEnd( this.startContainer, this.startOffset ); - - var walker = new CKEDITOR.dom.walker( walkerRange ), - blockBoundary, // The node on which the enlarging should stop. - tailBr, // In case BR as block boundary. - notBlockBoundary = CKEDITOR.dom.walker.blockBoundary( - ( unit == CKEDITOR.ENLARGE_LIST_ITEM_CONTENTS ) ? { br : 1 } : null ), - // Record the encountered 'blockBoundary' for later use. - boundaryGuard = function( node ) - { - var retval = notBlockBoundary( node ); - if ( !retval ) - blockBoundary = node; - return retval; - }, - // Record the encounted 'tailBr' for later use. - tailBrGuard = function( node ) - { - var retval = boundaryGuard( node ); - if ( !retval && node.is && node.is( 'br' ) ) - tailBr = node; - return retval; - }; - - walker.guard = boundaryGuard; - - enlargeable = walker.lastBackward(); - - // It's the body which stop the enlarging if no block boundary found. - blockBoundary = blockBoundary || body; - - // Start the range either after the end of found block (

...

[text) - // or at the start of block (

[text...), by comparing the document position - // with 'enlargeable' node. - this.setStartAt( - blockBoundary, - !blockBoundary.is( 'br' ) && - ( !enlargeable && this.checkStartOfBlock() - || enlargeable && blockBoundary.contains( enlargeable ) ) ? - CKEDITOR.POSITION_AFTER_START : - CKEDITOR.POSITION_AFTER_END ); - - // Avoid enlarging the range further when end boundary spans right after the BR. (#7490) - if ( unit == CKEDITOR.ENLARGE_LIST_ITEM_CONTENTS ) - { - var theRange = this.clone(); - walker = new CKEDITOR.dom.walker( theRange ); - - var whitespaces = CKEDITOR.dom.walker.whitespaces(), - bookmark = CKEDITOR.dom.walker.bookmark(); - - walker.evaluator = function( node ) { return !whitespaces( node ) && !bookmark( node ); }; - var previous = walker.previous(); - if ( previous && previous.type == CKEDITOR.NODE_ELEMENT && previous.is( 'br' ) ) - return; - } - - - // Enlarging the end boundary. - walkerRange = this.clone(); - walkerRange.collapse(); - walkerRange.setEndAt( body, CKEDITOR.POSITION_BEFORE_END ); - walker = new CKEDITOR.dom.walker( walkerRange ); - - // tailBrGuard only used for on range end. - walker.guard = ( unit == CKEDITOR.ENLARGE_LIST_ITEM_CONTENTS ) ? - tailBrGuard : boundaryGuard; - blockBoundary = null; - // End the range right before the block boundary node. - - enlargeable = walker.lastForward(); - - // It's the body which stop the enlarging if no block boundary found. - blockBoundary = blockBoundary || body; - - // Close the range either before the found block start (text]

...

) or at the block end (...text]

) - // by comparing the document position with 'enlargeable' node. - this.setEndAt( - blockBoundary, - ( !enlargeable && this.checkEndOfBlock() - || enlargeable && blockBoundary.contains( enlargeable ) ) ? - CKEDITOR.POSITION_BEFORE_END : - CKEDITOR.POSITION_BEFORE_START ); - // We must include the
at the end of range if there's - // one and we're expanding list item contents - if ( tailBr ) - this.setEndAfter( tailBr ); - } - }, - - /** - * Descrease the range to make sure that boundaries - * always anchor beside text nodes or innermost element. - * @param {Number} mode ( CKEDITOR.SHRINK_ELEMENT | CKEDITOR.SHRINK_TEXT ) The shrinking mode. - *
- *
CKEDITOR.SHRINK_ELEMENT
- *
Shrink the range boundaries to the edge of the innermost element.
- *
CKEDITOR.SHRINK_TEXT
- *
Shrink the range boudaries to anchor by the side of enclosed text node, range remains if there's no text nodes on boundaries at all.
- *
- * @param {Boolean} selectContents Whether result range anchors at the inner OR outer boundary of the node. - */ - shrink : function( mode, selectContents ) - { - // Unable to shrink a collapsed range. - if ( !this.collapsed ) - { - mode = mode || CKEDITOR.SHRINK_TEXT; - - var walkerRange = this.clone(); - - var startContainer = this.startContainer, - endContainer = this.endContainer, - startOffset = this.startOffset, - endOffset = this.endOffset, - collapsed = this.collapsed; - - // Whether the start/end boundary is moveable. - var moveStart = 1, - moveEnd = 1; - - if ( startContainer && startContainer.type == CKEDITOR.NODE_TEXT ) - { - if ( !startOffset ) - walkerRange.setStartBefore( startContainer ); - else if ( startOffset >= startContainer.getLength( ) ) - walkerRange.setStartAfter( startContainer ); - else - { - // Enlarge the range properly to avoid walker making - // DOM changes caused by triming the text nodes later. - walkerRange.setStartBefore( startContainer ); - moveStart = 0; - } - } - - if ( endContainer && endContainer.type == CKEDITOR.NODE_TEXT ) - { - if ( !endOffset ) - walkerRange.setEndBefore( endContainer ); - else if ( endOffset >= endContainer.getLength( ) ) - walkerRange.setEndAfter( endContainer ); - else - { - walkerRange.setEndAfter( endContainer ); - moveEnd = 0; - } - } - - var walker = new CKEDITOR.dom.walker( walkerRange ), - isBookmark = CKEDITOR.dom.walker.bookmark(); - - walker.evaluator = function( node ) - { - return node.type == ( mode == CKEDITOR.SHRINK_ELEMENT ? - CKEDITOR.NODE_ELEMENT : CKEDITOR.NODE_TEXT ); - }; - - var currentElement; - walker.guard = function( node, movingOut ) - { - if ( isBookmark( node ) ) - return true; - - // Stop when we're shrink in element mode while encountering a text node. - if ( mode == CKEDITOR.SHRINK_ELEMENT && node.type == CKEDITOR.NODE_TEXT ) - return false; - - // Stop when we've already walked "through" an element. - if ( movingOut && node.equals( currentElement ) ) - return false; - - if ( !movingOut && node.type == CKEDITOR.NODE_ELEMENT ) - currentElement = node; - - return true; - }; - - if ( moveStart ) - { - var textStart = walker[ mode == CKEDITOR.SHRINK_ELEMENT ? 'lastForward' : 'next'](); - textStart && this.setStartAt( textStart, selectContents ? CKEDITOR.POSITION_AFTER_START : CKEDITOR.POSITION_BEFORE_START ); - } - - if ( moveEnd ) - { - walker.reset(); - var textEnd = walker[ mode == CKEDITOR.SHRINK_ELEMENT ? 'lastBackward' : 'previous'](); - textEnd && this.setEndAt( textEnd, selectContents ? CKEDITOR.POSITION_BEFORE_END : CKEDITOR.POSITION_AFTER_END ); - } - - return !!( moveStart || moveEnd ); - } - }, - - /** - * Inserts a node at the start of the range. The range will be expanded - * the contain the node. - */ - insertNode : function( node ) - { - this.optimizeBookmark(); - this.trim( false, true ); - - var startContainer = this.startContainer; - var startOffset = this.startOffset; - - var nextNode = startContainer.getChild( startOffset ); - - if ( nextNode ) - node.insertBefore( nextNode ); - else - startContainer.append( node ); - - // Check if we need to update the end boundary. - if ( node.getParent().equals( this.endContainer ) ) - this.endOffset++; - - // Expand the range to embrace the new node. - this.setStartBefore( node ); - }, - - moveToPosition : function( node, position ) - { - this.setStartAt( node, position ); - this.collapse( true ); - }, - - selectNodeContents : function( node ) - { - this.setStart( node, 0 ); - this.setEnd( node, node.type == CKEDITOR.NODE_TEXT ? node.getLength() : node.getChildCount() ); - }, - - /** - * Sets the start position of a Range. - * @param {CKEDITOR.dom.node} startNode The node to start the range. - * @param {Number} startOffset An integer greater than or equal to zero - * representing the offset for the start of the range from the start - * of startNode. - */ - setStart : function( startNode, startOffset ) - { - // W3C requires a check for the new position. If it is after the end - // boundary, the range should be collapsed to the new start. It seams - // we will not need this check for our use of this class so we can - // ignore it for now. - - // Fixing invalid range start inside dtd empty elements. - if( startNode.type == CKEDITOR.NODE_ELEMENT - && CKEDITOR.dtd.$empty[ startNode.getName() ] ) - startOffset = startNode.getIndex(), startNode = startNode.getParent(); - - this.startContainer = startNode; - this.startOffset = startOffset; - - if ( !this.endContainer ) - { - this.endContainer = startNode; - this.endOffset = startOffset; - } - - updateCollapsed( this ); - }, - - /** - * Sets the end position of a Range. - * @param {CKEDITOR.dom.node} endNode The node to end the range. - * @param {Number} endOffset An integer greater than or equal to zero - * representing the offset for the end of the range from the start - * of endNode. - */ - setEnd : function( endNode, endOffset ) - { - // W3C requires a check for the new position. If it is before the start - // boundary, the range should be collapsed to the new end. It seams we - // will not need this check for our use of this class so we can ignore - // it for now. - - // Fixing invalid range end inside dtd empty elements. - if( endNode.type == CKEDITOR.NODE_ELEMENT - && CKEDITOR.dtd.$empty[ endNode.getName() ] ) - endOffset = endNode.getIndex() + 1, endNode = endNode.getParent(); - - this.endContainer = endNode; - this.endOffset = endOffset; - - if ( !this.startContainer ) - { - this.startContainer = endNode; - this.startOffset = endOffset; - } - - updateCollapsed( this ); - }, - - setStartAfter : function( node ) - { - this.setStart( node.getParent(), node.getIndex() + 1 ); - }, - - setStartBefore : function( node ) - { - this.setStart( node.getParent(), node.getIndex() ); - }, - - setEndAfter : function( node ) - { - this.setEnd( node.getParent(), node.getIndex() + 1 ); - }, - - setEndBefore : function( node ) - { - this.setEnd( node.getParent(), node.getIndex() ); - }, - - setStartAt : function( node, position ) - { - switch( position ) - { - case CKEDITOR.POSITION_AFTER_START : - this.setStart( node, 0 ); - break; - - case CKEDITOR.POSITION_BEFORE_END : - if ( node.type == CKEDITOR.NODE_TEXT ) - this.setStart( node, node.getLength() ); - else - this.setStart( node, node.getChildCount() ); - break; - - case CKEDITOR.POSITION_BEFORE_START : - this.setStartBefore( node ); - break; - - case CKEDITOR.POSITION_AFTER_END : - this.setStartAfter( node ); - } - - updateCollapsed( this ); - }, - - setEndAt : function( node, position ) - { - switch( position ) - { - case CKEDITOR.POSITION_AFTER_START : - this.setEnd( node, 0 ); - break; - - case CKEDITOR.POSITION_BEFORE_END : - if ( node.type == CKEDITOR.NODE_TEXT ) - this.setEnd( node, node.getLength() ); - else - this.setEnd( node, node.getChildCount() ); - break; - - case CKEDITOR.POSITION_BEFORE_START : - this.setEndBefore( node ); - break; - - case CKEDITOR.POSITION_AFTER_END : - this.setEndAfter( node ); - } - - updateCollapsed( this ); - }, - - fixBlock : function( isStart, blockTag ) - { - var bookmark = this.createBookmark(), - fixedBlock = this.document.createElement( blockTag ); - - this.collapse( isStart ); - - this.enlarge( CKEDITOR.ENLARGE_BLOCK_CONTENTS ); - - this.extractContents().appendTo( fixedBlock ); - fixedBlock.trim(); - - if ( !CKEDITOR.env.ie ) - fixedBlock.appendBogus(); - - this.insertNode( fixedBlock ); - - this.moveToBookmark( bookmark ); - - return fixedBlock; - }, - - splitBlock : function( blockTag ) - { - var startPath = new CKEDITOR.dom.elementPath( this.startContainer ), - endPath = new CKEDITOR.dom.elementPath( this.endContainer ); - - var startBlockLimit = startPath.blockLimit, - endBlockLimit = endPath.blockLimit; - - var startBlock = startPath.block, - endBlock = endPath.block; - - var elementPath = null; - // Do nothing if the boundaries are in different block limits. - if ( !startBlockLimit.equals( endBlockLimit ) ) - return null; - - // Get or fix current blocks. - if ( blockTag != 'br' ) - { - if ( !startBlock ) - { - startBlock = this.fixBlock( true, blockTag ); - endBlock = new CKEDITOR.dom.elementPath( this.endContainer ).block; - } - - if ( !endBlock ) - endBlock = this.fixBlock( false, blockTag ); - } - - // Get the range position. - var isStartOfBlock = startBlock && this.checkStartOfBlock(), - isEndOfBlock = endBlock && this.checkEndOfBlock(); - - // Delete the current contents. - // TODO: Why is 2.x doing CheckIsEmpty()? - this.deleteContents(); - - if ( startBlock && startBlock.equals( endBlock ) ) - { - if ( isEndOfBlock ) - { - elementPath = new CKEDITOR.dom.elementPath( this.startContainer ); - this.moveToPosition( endBlock, CKEDITOR.POSITION_AFTER_END ); - endBlock = null; - } - else if ( isStartOfBlock ) - { - elementPath = new CKEDITOR.dom.elementPath( this.startContainer ); - this.moveToPosition( startBlock, CKEDITOR.POSITION_BEFORE_START ); - startBlock = null; - } - else - { - endBlock = this.splitElement( startBlock ); - - // In Gecko, the last child node must be a bogus
. - // Note: bogus
added under
    or
      would cause - // lists to be incorrectly rendered. - if ( !CKEDITOR.env.ie && !startBlock.is( 'ul', 'ol') ) - startBlock.appendBogus() ; - } - } - - return { - previousBlock : startBlock, - nextBlock : endBlock, - wasStartOfBlock : isStartOfBlock, - wasEndOfBlock : isEndOfBlock, - elementPath : elementPath - }; - }, - - /** - * Branch the specified element from the collapsed range position and - * place the caret between the two result branches. - * Note: The range must be collapsed and been enclosed by this element. - * @param {CKEDITOR.dom.element} element - * @return {CKEDITOR.dom.element} Root element of the new branch after the split. - */ - splitElement : function( toSplit ) - { - if ( !this.collapsed ) - return null; - - // Extract the contents of the block from the selection point to the end - // of its contents. - this.setEndAt( toSplit, CKEDITOR.POSITION_BEFORE_END ); - var documentFragment = this.extractContents(); - - // Duplicate the element after it. - var clone = toSplit.clone( false ); - - // Place the extracted contents into the duplicated element. - documentFragment.appendTo( clone ); - clone.insertAfter( toSplit ); - this.moveToPosition( toSplit, CKEDITOR.POSITION_AFTER_END ); - return clone; - }, - - /** - * Check whether a range boundary is at the inner boundary of a given - * element. - * @param {CKEDITOR.dom.element} element The target element to check. - * @param {Number} checkType The boundary to check for both the range - * and the element. It can be CKEDITOR.START or CKEDITOR.END. - * @returns {Boolean} "true" if the range boundary is at the inner - * boundary of the element. - */ - checkBoundaryOfElement : function( element, checkType ) - { - var checkStart = ( checkType == CKEDITOR.START ); - - // Create a copy of this range, so we can manipulate it for our checks. - var walkerRange = this.clone(); - - // Collapse the range at the proper size. - walkerRange.collapse( checkStart ); - - // Expand the range to element boundary. - walkerRange[ checkStart ? 'setStartAt' : 'setEndAt' ] - ( element, checkStart ? CKEDITOR.POSITION_AFTER_START : CKEDITOR.POSITION_BEFORE_END ); - - // Create the walker, which will check if we have anything useful - // in the range. - var walker = new CKEDITOR.dom.walker( walkerRange ); - walker.evaluator = elementBoundaryEval( checkStart ); - - return walker[ checkStart ? 'checkBackward' : 'checkForward' ](); - }, - - // Calls to this function may produce changes to the DOM. The range may - // be updated to reflect such changes. - checkStartOfBlock : function() - { - var startContainer = this.startContainer, - startOffset = this.startOffset; - - // If the starting node is a text node, and non-empty before the offset, - // then we're surely not at the start of block. - if ( startOffset && startContainer.type == CKEDITOR.NODE_TEXT ) - { - var textBefore = CKEDITOR.tools.ltrim( startContainer.substring( 0, startOffset ) ); - if ( textBefore.length ) - return false; - } - - // Antecipate the trim() call here, so the walker will not make - // changes to the DOM, which would not get reflected into this - // range otherwise. - this.trim(); - - // We need to grab the block element holding the start boundary, so - // let's use an element path for it. - var path = new CKEDITOR.dom.elementPath( this.startContainer ); - - // Creates a range starting at the block start until the range start. - var walkerRange = this.clone(); - walkerRange.collapse( true ); - walkerRange.setStartAt( path.block || path.blockLimit, CKEDITOR.POSITION_AFTER_START ); - - var walker = new CKEDITOR.dom.walker( walkerRange ); - walker.evaluator = getCheckStartEndBlockEvalFunction( true ); - - return walker.checkBackward(); - }, - - checkEndOfBlock : function() - { - var endContainer = this.endContainer, - endOffset = this.endOffset; - - // If the ending node is a text node, and non-empty after the offset, - // then we're surely not at the end of block. - if ( endContainer.type == CKEDITOR.NODE_TEXT ) - { - var textAfter = CKEDITOR.tools.rtrim( endContainer.substring( endOffset ) ); - if ( textAfter.length ) - return false; - } - - // Antecipate the trim() call here, so the walker will not make - // changes to the DOM, which would not get reflected into this - // range otherwise. - this.trim(); - - // We need to grab the block element holding the start boundary, so - // let's use an element path for it. - var path = new CKEDITOR.dom.elementPath( this.endContainer ); - - // Creates a range starting at the block start until the range start. - var walkerRange = this.clone(); - walkerRange.collapse( false ); - walkerRange.setEndAt( path.block || path.blockLimit, CKEDITOR.POSITION_BEFORE_END ); - - var walker = new CKEDITOR.dom.walker( walkerRange ); - walker.evaluator = getCheckStartEndBlockEvalFunction( false ); - - return walker.checkForward(); - }, - - /** - * Check if elements at which the range boundaries anchor are read-only, - * with respect to "contenteditable" attribute. - */ - checkReadOnly : ( function() - { - function checkNodesEditable( node, anotherEnd ) - { - while( node ) - { - if ( node.type == CKEDITOR.NODE_ELEMENT ) - { - if ( node.getAttribute( 'contentEditable' ) == 'false' - && !node.data( 'cke-editable' ) ) - { - return 0; - } - // Range enclosed entirely in an editable element. - else if ( node.is( 'html' ) - || node.getAttribute( 'contentEditable' ) == 'true' - && ( node.contains( anotherEnd ) || node.equals( anotherEnd ) ) ) - { - break; - } - } - node = node.getParent(); - } - - return 1; - } - - return function() - { - var startNode = this.startContainer, - endNode = this.endContainer; - - // Check if elements path at both boundaries are editable. - return !( checkNodesEditable( startNode, endNode ) && checkNodesEditable( endNode, startNode ) ); - }; - })(), - - /** - * Moves the range boundaries to the first/end editing point inside an - * element. For example, in an element tree like - * "<p><b><i></i></b> Text</p>", the start editing point is - * "<p><b><i>^</i></b> Text</p>" (inside <i>). - * @param {CKEDITOR.dom.element} el The element into which look for the - * editing spot. - * @param {Boolean} isMoveToEnd Whether move to the end editable position. - */ - moveToElementEditablePosition : function( el, isMoveToEnd ) - { - function nextDFS( node, childOnly ) - { - var next; - - if ( node.type == CKEDITOR.NODE_ELEMENT - && node.isEditable( false ) - && !CKEDITOR.dtd.$nonEditable[ node.getName() ] ) - { - next = node[ isMoveToEnd ? 'getLast' : 'getFirst' ]( nonWhitespaceOrBookmarkEval ); - } - - if ( !childOnly && !next ) - next = node[ isMoveToEnd ? 'getPrevious' : 'getNext' ]( nonWhitespaceOrBookmarkEval ); - - return next; - } - - var found = 0; - - while ( el ) - { - // Stop immediately if we've found a text node. - if ( el.type == CKEDITOR.NODE_TEXT ) - { - this.moveToPosition( el, isMoveToEnd ? - CKEDITOR.POSITION_AFTER_END : - CKEDITOR.POSITION_BEFORE_START ); - found = 1; - break; - } - - // If an editable element is found, move inside it, but not stop the searching. - if ( el.type == CKEDITOR.NODE_ELEMENT ) - { - if ( el.isEditable() ) - { - this.moveToPosition( el, isMoveToEnd ? - CKEDITOR.POSITION_BEFORE_END : - CKEDITOR.POSITION_AFTER_START ); - found = 1; - } - } - - el = nextDFS( el, found ); - } - - return !!found; - }, - - /** - *@see {CKEDITOR.dom.range.moveToElementEditablePosition} - */ - moveToElementEditStart : function( target ) - { - return this.moveToElementEditablePosition( target ); - }, - - /** - *@see {CKEDITOR.dom.range.moveToElementEditablePosition} - */ - moveToElementEditEnd : function( target ) - { - return this.moveToElementEditablePosition( target, true ); - }, - - /** - * Get the single node enclosed within the range if there's one. - */ - getEnclosedNode : function() - { - var walkerRange = this.clone(); - - // Optimize and analyze the range to avoid DOM destructive nature of walker. (#5780) - walkerRange.optimize(); - if ( walkerRange.startContainer.type != CKEDITOR.NODE_ELEMENT - || walkerRange.endContainer.type != CKEDITOR.NODE_ELEMENT ) - return null; - - var walker = new CKEDITOR.dom.walker( walkerRange ), - isNotBookmarks = CKEDITOR.dom.walker.bookmark( true ), - isNotWhitespaces = CKEDITOR.dom.walker.whitespaces( true ), - evaluator = function( node ) - { - return isNotWhitespaces( node ) && isNotBookmarks( node ); - }; - walkerRange.evaluator = evaluator; - var node = walker.next(); - walker.reset(); - return node && node.equals( walker.previous() ) ? node : null; - }, - - getTouchedStartNode : function() - { - var container = this.startContainer ; - - if ( this.collapsed || container.type != CKEDITOR.NODE_ELEMENT ) - return container ; - - return container.getChild( this.startOffset ) || container ; - }, - - getTouchedEndNode : function() - { - var container = this.endContainer ; - - if ( this.collapsed || container.type != CKEDITOR.NODE_ELEMENT ) - return container ; - - return container.getChild( this.endOffset - 1 ) || container ; - } - }; -})(); - -CKEDITOR.POSITION_AFTER_START = 1; // ^contents "^text" -CKEDITOR.POSITION_BEFORE_END = 2; // contents^ "text^" -CKEDITOR.POSITION_BEFORE_START = 3; // ^contents ^"text" -CKEDITOR.POSITION_AFTER_END = 4; // contents^ "text" - -CKEDITOR.ENLARGE_ELEMENT = 1; -CKEDITOR.ENLARGE_BLOCK_CONTENTS = 2; -CKEDITOR.ENLARGE_LIST_ITEM_CONTENTS = 3; - -// Check boundary types. -// @see CKEDITOR.dom.range.prototype.checkBoundaryOfElement -CKEDITOR.START = 1; -CKEDITOR.END = 2; -CKEDITOR.STARTEND = 3; - -// Shrink range types. -// @see CKEDITOR.dom.range.prototype.shrink -CKEDITOR.SHRINK_ELEMENT = 1; -CKEDITOR.SHRINK_TEXT = 2; diff --git a/media/ckeditor/_source/core/dom/rangelist.js b/media/ckeditor/_source/core/dom/rangelist.js deleted file mode 100644 index 9257b2c..0000000 --- a/media/ckeditor/_source/core/dom/rangelist.js +++ /dev/null @@ -1,213 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -(function() -{ - /** - * Represents a list os CKEDITOR.dom.range objects, which can be easily - * iterated sequentially. - * @constructor - * @param {CKEDITOR.dom.range|Array} [ranges] The ranges contained on this list. - * Note that, if an array of ranges is specified, the range sequence - * should match its DOM order. This class will not help to sort them. - */ - CKEDITOR.dom.rangeList = function( ranges ) - { - if ( ranges instanceof CKEDITOR.dom.rangeList ) - return ranges; - - if ( !ranges ) - ranges = []; - else if ( ranges instanceof CKEDITOR.dom.range ) - ranges = [ ranges ]; - - return CKEDITOR.tools.extend( ranges, mixins ); - }; - - var mixins = - /** @lends CKEDITOR.dom.rangeList.prototype */ - { - /** - * Creates an instance of the rangeList iterator, it should be used - * only when the ranges processing could be DOM intrusive, which - * means it may pollute and break other ranges in this list. - * Otherwise, it's enough to just iterate over this array in a for loop. - * @returns {CKEDITOR.dom.rangeListIterator} - */ - createIterator : function() - { - var rangeList = this, - bookmark = CKEDITOR.dom.walker.bookmark(), - guard = function( node ) { return ! ( node.is && node.is( 'tr' ) ); }, - bookmarks = [], - current; - - /** - * @lends CKEDITOR.dom.rangeListIterator.prototype - */ - return { - - /** - * Retrieves the next range in the list. - * @param {Boolean} mergeConsequent Whether join two adjacent ranges into single, e.g. consequent table cells. - */ - getNextRange : function( mergeConsequent ) - { - current = current == undefined ? 0 : current + 1; - - var range = rangeList[ current ]; - - // Multiple ranges might be mangled by each other. - if ( range && rangeList.length > 1 ) - { - // Bookmarking all other ranges on the first iteration, - // the range correctness after it doesn't matter since we'll - // restore them before the next iteration. - if ( !current ) - { - // Make sure bookmark correctness by reverse processing. - for ( var i = rangeList.length - 1; i >= 0; i-- ) - bookmarks.unshift( rangeList[ i ].createBookmark( true ) ); - } - - if ( mergeConsequent ) - { - // Figure out how many ranges should be merged. - var mergeCount = 0; - while ( rangeList[ current + mergeCount + 1 ] ) - { - var doc = range.document, - found = 0, - left = doc.getById( bookmarks[ mergeCount ].endNode ), - right = doc.getById( bookmarks[ mergeCount + 1 ].startNode ), - next; - - // Check subsequent range. - while ( 1 ) - { - next = left.getNextSourceNode( false ); - if ( !right.equals( next ) ) - { - // This could be yet another bookmark or - // walking across block boundaries. - if ( bookmark( next ) || ( next.type == CKEDITOR.NODE_ELEMENT && next.isBlockBoundary() ) ) - { - left = next; - continue; - } - } - else - found = 1; - - break; - } - - if ( !found ) - break; - - mergeCount++; - } - } - - range.moveToBookmark( bookmarks.shift() ); - - // Merge ranges finally after moving to bookmarks. - while( mergeCount-- ) - { - next = rangeList[ ++current ]; - next.moveToBookmark( bookmarks.shift() ); - range.setEnd( next.endContainer, next.endOffset ); - } - } - - return range; - } - }; - }, - - createBookmarks : function( serializable ) - { - var retval = [], bookmark; - for ( var i = 0; i < this.length ; i++ ) - { - retval.push( bookmark = this[ i ].createBookmark( serializable, true) ); - - // Updating the container & offset values for ranges - // that have been touched. - for ( var j = i + 1; j < this.length; j++ ) - { - this[ j ] = updateDirtyRange( bookmark, this[ j ] ); - this[ j ] = updateDirtyRange( bookmark, this[ j ], true ); - } - } - return retval; - }, - - createBookmarks2 : function( normalized ) - { - var bookmarks = []; - - for ( var i = 0 ; i < this.length ; i++ ) - bookmarks.push( this[ i ].createBookmark2( normalized ) ); - - return bookmarks; - }, - - /** - * Move each range in the list to the position specified by a list of bookmarks. - * @param {Array} bookmarks The list of bookmarks, each one matching a range in the list. - */ - moveToBookmarks : function( bookmarks ) - { - for ( var i = 0 ; i < this.length ; i++ ) - this[ i ].moveToBookmark( bookmarks[ i ] ); - } - }; - - // Update the specified range which has been mangled by previous insertion of - // range bookmark nodes.(#3256) - function updateDirtyRange( bookmark, dirtyRange, checkEnd ) - { - var serializable = bookmark.serializable, - container = dirtyRange[ checkEnd ? 'endContainer' : 'startContainer' ], - offset = checkEnd ? 'endOffset' : 'startOffset'; - - var bookmarkStart = serializable ? - dirtyRange.document.getById( bookmark.startNode ) - : bookmark.startNode; - - var bookmarkEnd = serializable ? - dirtyRange.document.getById( bookmark.endNode ) - : bookmark.endNode; - - if ( container.equals( bookmarkStart.getPrevious() ) ) - { - dirtyRange.startOffset = dirtyRange.startOffset - - container.getLength() - - bookmarkEnd.getPrevious().getLength(); - container = bookmarkEnd.getNext(); - } - else if ( container.equals( bookmarkEnd.getPrevious() ) ) - { - dirtyRange.startOffset = dirtyRange.startOffset - container.getLength(); - container = bookmarkEnd.getNext(); - } - - container.equals( bookmarkStart.getParent() ) && dirtyRange[ offset ]++; - container.equals( bookmarkEnd.getParent() ) && dirtyRange[ offset ]++; - - // Update and return this range. - dirtyRange[ checkEnd ? 'endContainer' : 'startContainer' ] = container; - return dirtyRange; - } -})(); - -/** - * (Virtual Class) Do not call this constructor. This class is not really part - * of the API. It just describes the return type of {@link CKEDITOR.dom.rangeList#createIterator}. - * @name CKEDITOR.dom.rangeListIterator - * @constructor - * @example - */ diff --git a/media/ckeditor/_source/core/dom/text.js b/media/ckeditor/_source/core/dom/text.js deleted file mode 100644 index a0d2ca1..0000000 --- a/media/ckeditor/_source/core/dom/text.js +++ /dev/null @@ -1,128 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @fileOverview Defines the {@link CKEDITOR.dom.text} class, which represents - * a DOM text node. - */ - -/** - * Represents a DOM text node. - * @constructor - * @augments CKEDITOR.dom.node - * @param {Object|String} text A native DOM text node or a string containing - * the text to use to create a new text node. - * @param {CKEDITOR.dom.document} [ownerDocument] The document that will contain - * the node in case of new node creation. Defaults to the current document. - * @example - * var nativeNode = document.createTextNode( 'Example' ); - * var text = CKEDITOR.dom.text( nativeNode ); - * @example - * var text = CKEDITOR.dom.text( 'Example' ); - */ -CKEDITOR.dom.text = function( text, ownerDocument ) -{ - if ( typeof text == 'string' ) - text = ( ownerDocument ? ownerDocument.$ : document ).createTextNode( text ); - - // Theoretically, we should call the base constructor here - // (not CKEDITOR.dom.node though). But, IE doesn't support expando - // properties on text node, so the features provided by domObject will not - // work for text nodes (which is not a big issue for us). - // - // CKEDITOR.dom.domObject.call( this, element ); - - /** - * The native DOM text node represented by this class instance. - * @type Object - * @example - * var element = new CKEDITOR.dom.text( 'Example' ); - * alert( element.$.nodeType ); // "3" - */ - this.$ = text; -}; - -CKEDITOR.dom.text.prototype = new CKEDITOR.dom.node(); - -CKEDITOR.tools.extend( CKEDITOR.dom.text.prototype, - /** @lends CKEDITOR.dom.text.prototype */ - { - /** - * The node type. This is a constant value set to - * {@link CKEDITOR.NODE_TEXT}. - * @type Number - * @example - */ - type : CKEDITOR.NODE_TEXT, - - getLength : function() - { - return this.$.nodeValue.length; - }, - - getText : function() - { - return this.$.nodeValue; - }, - - setText : function( text ) - { - this.$.nodeValue = text; - }, - - /** - * Breaks this text node into two nodes at the specified offset, - * keeping both in the tree as siblings. This node then only contains - * all the content up to the offset point. A new text node, which is - * inserted as the next sibling of this node, contains all the content - * at and after the offset point. When the offset is equal to the - * length of this node, the new node has no data. - * @param {Number} The position at which to split, starting from zero. - * @returns {CKEDITOR.dom.text} The new text node. - */ - split : function( offset ) - { - // If the offset is after the last char, IE creates the text node - // on split, but don't include it into the DOM. So, we have to do - // that manually here. - if ( CKEDITOR.env.ie && offset == this.getLength() ) - { - var next = this.getDocument().createText( '' ); - next.insertAfter( this ); - return next; - } - - var doc = this.getDocument(); - var retval = new CKEDITOR.dom.text( this.$.splitText( offset ), doc ); - - // IE BUG: IE8 does not update the childNodes array in DOM after splitText(), - // we need to make some DOM changes to make it update. (#3436) - if ( CKEDITOR.env.ie8 ) - { - var workaround = new CKEDITOR.dom.text( '', doc ); - workaround.insertAfter( retval ); - workaround.remove(); - } - - return retval; - }, - - /** - * Extracts characters from indexA up to but not including indexB. - * @param {Number} indexA An integer between 0 and one less than the - * length of the text. - * @param {Number} [indexB] An integer between 0 and the length of the - * string. If omitted, extracts characters to the end of the text. - */ - substring : function( indexA, indexB ) - { - // We need the following check due to a Firefox bug - // https://bugzilla.mozilla.org/show_bug.cgi?id=458886 - if ( typeof indexB != 'number' ) - return this.$.nodeValue.substr( indexA ); - else - return this.$.nodeValue.substring( indexA, indexB ); - } - }); diff --git a/media/ckeditor/_source/core/dom/walker.js b/media/ckeditor/_source/core/dom/walker.js deleted file mode 100644 index 506ea3c..0000000 --- a/media/ckeditor/_source/core/dom/walker.js +++ /dev/null @@ -1,496 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -(function() -{ - // This function is to be called under a "walker" instance scope. - function iterate( rtl, breakOnFalse ) - { - var range = this.range; - - // Return null if we have reached the end. - if ( this._.end ) - return null; - - // This is the first call. Initialize it. - if ( !this._.start ) - { - this._.start = 1; - - // A collapsed range must return null at first call. - if ( range.collapsed ) - { - this.end(); - return null; - } - - // Move outside of text node edges. - range.optimize(); - } - - var node, - startCt = range.startContainer, - endCt = range.endContainer, - startOffset = range.startOffset, - endOffset = range.endOffset, - guard, - userGuard = this.guard, - type = this.type, - getSourceNodeFn = ( rtl ? 'getPreviousSourceNode' : 'getNextSourceNode' ); - - // Create the LTR guard function, if necessary. - if ( !rtl && !this._.guardLTR ) - { - // The node that stops walker from moving up. - var limitLTR = endCt.type == CKEDITOR.NODE_ELEMENT ? - endCt : - endCt.getParent(); - - // The node that stops the walker from going to next. - var blockerLTR = endCt.type == CKEDITOR.NODE_ELEMENT ? - endCt.getChild( endOffset ) : - endCt.getNext(); - - this._.guardLTR = function( node, movingOut ) - { - return ( ( !movingOut || !limitLTR.equals( node ) ) - && ( !blockerLTR || !node.equals( blockerLTR ) ) - && ( node.type != CKEDITOR.NODE_ELEMENT || !movingOut || node.getName() != 'body' ) ); - }; - } - - // Create the RTL guard function, if necessary. - if ( rtl && !this._.guardRTL ) - { - // The node that stops walker from moving up. - var limitRTL = startCt.type == CKEDITOR.NODE_ELEMENT ? - startCt : - startCt.getParent(); - - // The node that stops the walker from going to next. - var blockerRTL = startCt.type == CKEDITOR.NODE_ELEMENT ? - startOffset ? - startCt.getChild( startOffset - 1 ) : null : - startCt.getPrevious(); - - this._.guardRTL = function( node, movingOut ) - { - return ( ( !movingOut || !limitRTL.equals( node ) ) - && ( !blockerRTL || !node.equals( blockerRTL ) ) - && ( node.type != CKEDITOR.NODE_ELEMENT || !movingOut || node.getName() != 'body' ) ); - }; - } - - // Define which guard function to use. - var stopGuard = rtl ? this._.guardRTL : this._.guardLTR; - - // Make the user defined guard function participate in the process, - // otherwise simply use the boundary guard. - if ( userGuard ) - { - guard = function( node, movingOut ) - { - if ( stopGuard( node, movingOut ) === false ) - return false; - - return userGuard( node, movingOut ); - }; - } - else - guard = stopGuard; - - if ( this.current ) - node = this.current[ getSourceNodeFn ]( false, type, guard ); - else - { - // Get the first node to be returned. - if ( rtl ) - { - node = endCt; - - if ( node.type == CKEDITOR.NODE_ELEMENT ) - { - if ( endOffset > 0 ) - node = node.getChild( endOffset - 1 ); - else - node = ( guard ( node, true ) === false ) ? - null : node.getPreviousSourceNode( true, type, guard ); - } - } - else - { - node = startCt; - - if ( node.type == CKEDITOR.NODE_ELEMENT ) - { - if ( ! ( node = node.getChild( startOffset ) ) ) - node = ( guard ( startCt, true ) === false ) ? - null : startCt.getNextSourceNode( true, type, guard ) ; - } - } - - if ( node && guard( node ) === false ) - node = null; - } - - while ( node && !this._.end ) - { - this.current = node; - - if ( !this.evaluator || this.evaluator( node ) !== false ) - { - if ( !breakOnFalse ) - return node; - } - else if ( breakOnFalse && this.evaluator ) - return false; - - node = node[ getSourceNodeFn ]( false, type, guard ); - } - - this.end(); - return this.current = null; - } - - function iterateToLast( rtl ) - { - var node, last = null; - - while ( ( node = iterate.call( this, rtl ) ) ) - last = node; - - return last; - } - - CKEDITOR.dom.walker = CKEDITOR.tools.createClass( - { - /** - * Utility class to "walk" the DOM inside a range boundaries. If - * necessary, partially included nodes (text nodes) are broken to - * reflect the boundaries limits, so DOM and range changes may happen. - * Outside changes to the range may break the walker. - * - * The walker may return nodes that are not totaly included into the - * range boundaires. Let's take the following range representation, - * where the square brackets indicate the boundaries: - * - * [<p>Some <b>sample] text</b> - * - * While walking forward into the above range, the following nodes are - * returned: <p>, "Some ", <b> and "sample". Going - * backwards instead we have: "sample" and "Some ". So note that the - * walker always returns nodes when "entering" them, but not when - * "leaving" them. The guard function is instead called both when - * entering and leaving nodes. - * - * @constructor - * @param {CKEDITOR.dom.range} range The range within which walk. - */ - $ : function( range ) - { - this.range = range; - - /** - * A function executed for every matched node, to check whether - * it's to be considered into the walk or not. If not provided, all - * matched nodes are considered good. - * If the function returns "false" the node is ignored. - * @name CKEDITOR.dom.walker.prototype.evaluator - * @property - * @type Function - */ - // this.evaluator = null; - - /** - * A function executed for every node the walk pass by to check - * whether the walk is to be finished. It's called when both - * entering and exiting nodes, as well as for the matched nodes. - * If this function returns "false", the walking ends and no more - * nodes are evaluated. - * @name CKEDITOR.dom.walker.prototype.guard - * @property - * @type Function - */ - // this.guard = null; - - /** @private */ - this._ = {}; - }, - -// statics : -// { -// /* Creates a CKEDITOR.dom.walker instance to walk inside DOM boundaries set by nodes. -// * @param {CKEDITOR.dom.node} startNode The node from wich the walk -// * will start. -// * @param {CKEDITOR.dom.node} [endNode] The last node to be considered -// * in the walk. No more nodes are retrieved after touching or -// * passing it. If not provided, the walker stops at the -// * <body> closing boundary. -// * @returns {CKEDITOR.dom.walker} A DOM walker for the nodes between the -// * provided nodes. -// */ -// createOnNodes : function( startNode, endNode, startInclusive, endInclusive ) -// { -// var range = new CKEDITOR.dom.range(); -// if ( startNode ) -// range.setStartAt( startNode, startInclusive ? CKEDITOR.POSITION_BEFORE_START : CKEDITOR.POSITION_AFTER_END ) ; -// else -// range.setStartAt( startNode.getDocument().getBody(), CKEDITOR.POSITION_AFTER_START ) ; -// -// if ( endNode ) -// range.setEndAt( endNode, endInclusive ? CKEDITOR.POSITION_AFTER_END : CKEDITOR.POSITION_BEFORE_START ) ; -// else -// range.setEndAt( startNode.getDocument().getBody(), CKEDITOR.POSITION_BEFORE_END ) ; -// -// return new CKEDITOR.dom.walker( range ); -// } -// }, -// - proto : - { - /** - * Stop walking. No more nodes are retrieved if this function gets - * called. - */ - end : function() - { - this._.end = 1; - }, - - /** - * Retrieves the next node (at right). - * @returns {CKEDITOR.dom.node} The next node or null if no more - * nodes are available. - */ - next : function() - { - return iterate.call( this ); - }, - - /** - * Retrieves the previous node (at left). - * @returns {CKEDITOR.dom.node} The previous node or null if no more - * nodes are available. - */ - previous : function() - { - return iterate.call( this, 1 ); - }, - - /** - * Check all nodes at right, executing the evaluation fuction. - * @returns {Boolean} "false" if the evaluator function returned - * "false" for any of the matched nodes. Otherwise "true". - */ - checkForward : function() - { - return iterate.call( this, 0, 1 ) !== false; - }, - - /** - * Check all nodes at left, executing the evaluation fuction. - * @returns {Boolean} "false" if the evaluator function returned - * "false" for any of the matched nodes. Otherwise "true". - */ - checkBackward : function() - { - return iterate.call( this, 1, 1 ) !== false; - }, - - /** - * Executes a full walk forward (to the right), until no more nodes - * are available, returning the last valid node. - * @returns {CKEDITOR.dom.node} The last node at the right or null - * if no valid nodes are available. - */ - lastForward : function() - { - return iterateToLast.call( this ); - }, - - /** - * Executes a full walk backwards (to the left), until no more nodes - * are available, returning the last valid node. - * @returns {CKEDITOR.dom.node} The last node at the left or null - * if no valid nodes are available. - */ - lastBackward : function() - { - return iterateToLast.call( this, 1 ); - }, - - reset : function() - { - delete this.current; - this._ = {}; - } - - } - }); - - /* - * Anything whose display computed style is block, list-item, table, - * table-row-group, table-header-group, table-footer-group, table-row, - * table-column-group, table-column, table-cell, table-caption, or whose node - * name is hr, br (when enterMode is br only) is a block boundary. - */ - var blockBoundaryDisplayMatch = - { - block : 1, - 'list-item' : 1, - table : 1, - 'table-row-group' : 1, - 'table-header-group' : 1, - 'table-footer-group' : 1, - 'table-row' : 1, - 'table-column-group' : 1, - 'table-column' : 1, - 'table-cell' : 1, - 'table-caption' : 1 - }; - - CKEDITOR.dom.element.prototype.isBlockBoundary = function( customNodeNames ) - { - var nodeNameMatches = customNodeNames ? - CKEDITOR.tools.extend( {}, CKEDITOR.dtd.$block, customNodeNames || {} ) : - CKEDITOR.dtd.$block; - - // Don't consider floated formatting as block boundary, fall back to dtd check in that case. (#6297) - return this.getComputedStyle( 'float' ) == 'none' && blockBoundaryDisplayMatch[ this.getComputedStyle( 'display' ) ] - || nodeNameMatches[ this.getName() ]; - }; - - CKEDITOR.dom.walker.blockBoundary = function( customNodeNames ) - { - return function( node , type ) - { - return ! ( node.type == CKEDITOR.NODE_ELEMENT - && node.isBlockBoundary( customNodeNames ) ); - }; - }; - - CKEDITOR.dom.walker.listItemBoundary = function() - { - return this.blockBoundary( { br : 1 } ); - }; - - /** - * Whether the to-be-evaluated node is a bookmark node OR bookmark node - * inner contents. - * @param {Boolean} contentOnly Whether only test againt the text content of - * bookmark node instead of the element itself(default). - * @param {Boolean} isReject Whether should return 'false' for the bookmark - * node instead of 'true'(default). - */ - CKEDITOR.dom.walker.bookmark = function( contentOnly, isReject ) - { - function isBookmarkNode( node ) - { - return ( node && node.getName - && node.getName() == 'span' - && node.data( 'cke-bookmark' ) ); - } - - return function( node ) - { - var isBookmark, parent; - // Is bookmark inner text node? - isBookmark = ( node && !node.getName && ( parent = node.getParent() ) - && isBookmarkNode( parent ) ); - // Is bookmark node? - isBookmark = contentOnly ? isBookmark : isBookmark || isBookmarkNode( node ); - return !! ( isReject ^ isBookmark ); - }; - }; - - /** - * Whether the node is a text node containing only whitespaces characters. - * @param isReject - */ - CKEDITOR.dom.walker.whitespaces = function( isReject ) - { - return function( node ) - { - var isWhitespace = node && ( node.type == CKEDITOR.NODE_TEXT ) - && !CKEDITOR.tools.trim( node.getText() ); - return !! ( isReject ^ isWhitespace ); - }; - }; - - /** - * Whether the node is invisible in wysiwyg mode. - * @param isReject - */ - CKEDITOR.dom.walker.invisible = function( isReject ) - { - var whitespace = CKEDITOR.dom.walker.whitespaces(); - return function( node ) - { - // Nodes that take no spaces in wysiwyg: - // 1. White-spaces but not including NBSP; - // 2. Empty inline elements, e.g. we're checking here - // 'offsetHeight' instead of 'offsetWidth' for properly excluding - // all sorts of empty paragraph, e.g.
      . - var isInvisible = whitespace( node ) || node.is && !node.$.offsetHeight; - return !! ( isReject ^ isInvisible ); - }; - }; - - CKEDITOR.dom.walker.nodeType = function( type, isReject ) - { - return function( node ) - { - return !! ( isReject ^ ( node.type == type ) ); - }; - }; - - CKEDITOR.dom.walker.bogus = function( type, isReject ) - { - function nonEmpty( node ) - { - return !isWhitespaces( node ) && !isBookmark( node ); - } - - return function( node ) - { - var parent = node.getParent(), - isBogus = !CKEDITOR.env.ie ? node.is && node.is( 'br' ) : - node.getText && tailNbspRegex.test( node.getText() ); - - isBogus = isBogus && parent.isBlockBoundary() && !!parent.getLast( nonEmpty ); - - return !! ( isReject ^ isBogus ); - }; - }; - - var tailNbspRegex = /^[\t\r\n ]*(?: |\xa0)$/, - isWhitespaces = CKEDITOR.dom.walker.whitespaces(), - isBookmark = CKEDITOR.dom.walker.bookmark(), - toSkip = function( node ) - { - return isBookmark( node ) - || isWhitespaces( node ) - || node.type == CKEDITOR.NODE_ELEMENT - && node.getName() in CKEDITOR.dtd.$inline - && !( node.getName() in CKEDITOR.dtd.$empty ); - }; - - // Check if there's a filler node at the end of an element, and return it. - CKEDITOR.dom.element.prototype.getBogus = function() - { - // Bogus are not always at the end, e.g.

      text

      (#7070). - var tail = this; - do { tail = tail.getPreviousSourceNode(); } - while ( toSkip( tail ) ) - - if ( tail && ( !CKEDITOR.env.ie ? tail.is && tail.is( 'br' ) - : tail.getText && tailNbspRegex.test( tail.getText() ) ) ) - { - return tail; - } - return false; - }; - -})(); diff --git a/media/ckeditor/_source/core/dom/window.js b/media/ckeditor/_source/core/dom/window.js deleted file mode 100644 index 728be35..0000000 --- a/media/ckeditor/_source/core/dom/window.js +++ /dev/null @@ -1,96 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @fileOverview Defines the {@link CKEDITOR.dom.document} class, which - * represents a DOM document. - */ - -/** - * Represents a DOM window. - * @constructor - * @augments CKEDITOR.dom.domObject - * @param {Object} domWindow A native DOM window. - * @example - * var document = new CKEDITOR.dom.window( window ); - */ -CKEDITOR.dom.window = function( domWindow ) -{ - CKEDITOR.dom.domObject.call( this, domWindow ); -}; - -CKEDITOR.dom.window.prototype = new CKEDITOR.dom.domObject(); - -CKEDITOR.tools.extend( CKEDITOR.dom.window.prototype, - /** @lends CKEDITOR.dom.window.prototype */ - { - /** - * Moves the selection focus to this window. - * @function - * @example - * var win = new CKEDITOR.dom.window( window ); - * win.focus(); - */ - focus : function() - { - // Webkit is sometimes failed to focus iframe, blur it first(#3835). - if ( CKEDITOR.env.webkit && this.$.parent ) - this.$.parent.focus(); - this.$.focus(); - }, - - /** - * Gets the width and height of this window's viewable area. - * @function - * @returns {Object} An object with the "width" and "height" - * properties containing the size. - * @example - * var win = new CKEDITOR.dom.window( window ); - * var size = win.getViewPaneSize(); - * alert( size.width ); - * alert( size.height ); - */ - getViewPaneSize : function() - { - var doc = this.$.document, - stdMode = doc.compatMode == 'CSS1Compat'; - return { - width : ( stdMode ? doc.documentElement.clientWidth : doc.body.clientWidth ) || 0, - height : ( stdMode ? doc.documentElement.clientHeight : doc.body.clientHeight ) || 0 - }; - }, - - /** - * Gets the current position of the window's scroll. - * @function - * @returns {Object} An object with the "x" and "y" properties - * containing the scroll position. - * @example - * var win = new CKEDITOR.dom.window( window ); - * var pos = win.getScrollPosition(); - * alert( pos.x ); - * alert( pos.y ); - */ - getScrollPosition : function() - { - var $ = this.$; - - if ( 'pageXOffset' in $ ) - { - return { - x : $.pageXOffset || 0, - y : $.pageYOffset || 0 - }; - } - else - { - var doc = $.document; - return { - x : doc.documentElement.scrollLeft || doc.body.scrollLeft || 0, - y : doc.documentElement.scrollTop || doc.body.scrollTop || 0 - }; - } - } - }); diff --git a/media/ckeditor/_source/core/dtd.js b/media/ckeditor/_source/core/dtd.js deleted file mode 100644 index a73099a..0000000 --- a/media/ckeditor/_source/core/dtd.js +++ /dev/null @@ -1,266 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @fileOverview Defines the {@link CKEDITOR.dtd} object, which holds the DTD - * mapping for XHTML 1.0 Transitional. This file was automatically - * generated from the file: xhtml1-transitional.dtd. - */ - -/** - * @namespace Holds and object representation of the HTML DTD to be used by the - * editor in its internal operations.
      - *
      - * Each element in the DTD is represented by a property in this object. Each - * property contains the list of elements that can be contained by the element. - * Text is represented by the "#" property.
      - *
      - * Several special grouping properties are also available. Their names start - * with the "$" character. - * @example - * // Check if "div" can be contained in a "p" element. - * alert( !!CKEDITOR.dtd[ 'p' ][ 'div' ] ); "false" - * @example - * // Check if "p" can be contained in a "div" element. - * alert( !!CKEDITOR.dtd[ 'div' ][ 'p' ] ); "true" - * @example - * // Check if "p" is a block element. - * alert( !!CKEDITOR.dtd.$block[ 'p' ] ); "true" - */ -CKEDITOR.dtd = (function() -{ - var X = CKEDITOR.tools.extend, - - A = {isindex:1,fieldset:1}, - B = {input:1,button:1,select:1,textarea:1,label:1}, - C = X({a:1},B), - D = X({iframe:1},C), - E = {hr:1,ul:1,menu:1,div:1,section:1,header:1,footer:1,nav:1,article:1,aside:1,figure:1,dialog:1,hgroup:1,mark:1,time:1,meter:1,command:1,keygen:1,output:1,progress:1,audio:1,video:1,details:1,datagrid:1,datalist:1,blockquote:1,noscript:1,table:1,center:1,address:1,dir:1,pre:1,h5:1,dl:1,h4:1,noframes:1,h6:1,ol:1,h1:1,h3:1,h2:1}, - F = {ins:1,del:1,script:1,style:1}, - G = X({b:1,acronym:1,bdo:1,'var':1,'#':1,abbr:1,code:1,br:1,i:1,cite:1,kbd:1,u:1,strike:1,s:1,tt:1,strong:1,q:1,samp:1,em:1,dfn:1,span:1,wbr:1},F), - H = X({sub:1,img:1,object:1,sup:1,basefont:1,map:1,applet:1,font:1,big:1,small:1,mark:1},G), - I = X({p:1},H), - J = X({iframe:1},H,B), - K = {img:1,noscript:1,br:1,kbd:1,center:1,button:1,basefont:1,h5:1,h4:1,samp:1,h6:1,ol:1,h1:1,h3:1,h2:1,form:1,font:1,'#':1,select:1,menu:1,ins:1,abbr:1,label:1,code:1,table:1,script:1,cite:1,input:1,iframe:1,strong:1,textarea:1,noframes:1,big:1,small:1,span:1,hr:1,sub:1,bdo:1,'var':1,div:1,section:1,header:1,footer:1,nav:1,article:1,aside:1,figure:1,dialog:1,hgroup:1,mark:1,time:1,meter:1,menu:1,command:1,keygen:1,output:1,progress:1,audio:1,video:1,details:1,datagrid:1,datalist:1,object:1,sup:1,strike:1,dir:1,map:1,dl:1,applet:1,del:1,isindex:1,fieldset:1,ul:1,b:1,acronym:1,a:1,blockquote:1,i:1,u:1,s:1,tt:1,address:1,q:1,pre:1,p:1,em:1,dfn:1}, - - L = X({a:1},J), - M = {tr:1}, - N = {'#':1}, - O = X({param:1},K), - P = X({form:1},A,D,E,I), - Q = {li:1}, - R = {style:1,script:1}, - S = {base:1,link:1,meta:1,title:1}, - T = X(S,R), - U = {head:1,body:1}, - V = {html:1}; - - var block = {address:1,blockquote:1,center:1,dir:1,div:1,section:1,header:1,footer:1,nav:1,article:1,aside:1,figure:1,dialog:1,hgroup:1,time:1,meter:1,menu:1,command:1,keygen:1,output:1,progress:1,audio:1,video:1,details:1,datagrid:1,datalist:1,dl:1,fieldset:1,form:1,h1:1,h2:1,h3:1,h4:1,h5:1,h6:1,hr:1,isindex:1,noframes:1,ol:1,p:1,pre:1,table:1,ul:1}; - - return /** @lends CKEDITOR.dtd */ { - - // The "$" items have been added manually. - - // List of elements living outside body. - $nonBodyContent: X(V,U,S), - - /** - * List of block elements, like "p" or "div". - * @type Object - * @example - */ - $block : block, - - /** - * List of block limit elements. - * @type Object - * @example - */ - $blockLimit : { body:1,div:1,section:1,header:1,footer:1,nav:1,article:1,aside:1,figure:1,dialog:1,hgroup:1,time:1,meter:1,menu:1,command:1,keygen:1,output:1,progress:1,audio:1,video:1,details:1,datagrid:1,datalist:1,td:1,th:1,caption:1,form:1 }, - - /** - * List of inline (<span> like) elements. - */ - $inline : L, // Just like span. - - /** - * list of elements that can be children at <body>. - */ - $body : X({script:1,style:1}, block), - - $cdata : {script:1,style:1}, - - /** - * List of empty (self-closing) elements, like "br" or "img". - * @type Object - * @example - */ - $empty : {area:1,base:1,br:1,col:1,hr:1,img:1,input:1,link:1,meta:1,param:1,wbr:1}, - - /** - * List of list item elements, like "li" or "dd". - * @type Object - * @example - */ - $listItem : {dd:1,dt:1,li:1}, - - /** - * List of list root elements. - * @type Object - * @example - */ - $list: {ul:1,ol:1,dl:1}, - - /** - * Elements that accept text nodes, but are not possible to edit into - * the browser. - * @type Object - * @example - */ - $nonEditable : {applet:1,button:1,embed:1,iframe:1,map:1,object:1,option:1,script:1,textarea:1,param:1,audio:1,video:1}, - - /** - * List of block tags with each one a singleton element lives in the corresponding structure for description. - */ - $captionBlock : { caption:1, legend:1 }, - - /** - * List of elements that can be ignored if empty, like "b" or "span". - * @type Object - * @example - */ - $removeEmpty : {abbr:1,acronym:1,address:1,b:1,bdo:1,big:1,cite:1,code:1,del:1,dfn:1,em:1,font:1,i:1,ins:1,label:1,kbd:1,q:1,s:1,samp:1,small:1,span:1,strike:1,strong:1,sub:1,sup:1,tt:1,u:1,'var':1,mark:1}, - - /** - * List of elements that have tabindex set to zero by default. - * @type Object - * @example - */ - $tabIndex : {a:1,area:1,button:1,input:1,object:1,select:1,textarea:1}, - - /** - * List of elements used inside the "table" element, like "tbody" or "td". - * @type Object - * @example - */ - $tableContent : {caption:1,col:1,colgroup:1,tbody:1,td:1,tfoot:1,th:1,thead:1,tr:1}, - - html: U, - head: T, - style: N, - script: N, - body: P, - base: {}, - link: {}, - meta: {}, - title: N, - col : {}, - tr : {td:1,th:1}, - img : {}, - colgroup : {col:1}, - noscript : P, - td : P, - br : {}, - wbr : {}, - th : P, - center : P, - kbd : L, - button : X(I,E), - basefont : {}, - h5 : L, - h4 : L, - samp : L, - h6 : L, - ol : Q, - h1 : L, - h3 : L, - option : N, - h2 : L, - form : X(A,D,E,I), - select : {optgroup:1,option:1}, - font : L, - ins : L, - menu : Q, - abbr : L, - label : L, - table : {thead:1,col:1,tbody:1,tr:1,colgroup:1,caption:1,tfoot:1}, - code : L, - tfoot : M, - cite : L, - li : P, - input : {}, - iframe : P, - strong : L, - textarea : N, - noframes : P, - big : L, - small : L, - span : L, - hr : {}, - dt : L, - sub : L, - optgroup : {option:1}, - param : {}, - bdo : L, - 'var' : L, - div : P, - object : O, - sup : L, - dd : P, - strike : L, - area : {}, - dir : Q, - map : X({area:1,form:1,p:1},A,F,E), - applet : O, - dl : {dt:1,dd:1}, - del : L, - isindex : {}, - fieldset : X({legend:1},K), - thead : M, - ul : Q, - acronym : L, - b : L, - a : J, - blockquote : P, - caption : L, - i : L, - u : L, - tbody : M, - s : L, - address : X(D,I), - tt : L, - legend : L, - q : L, - pre : X(G,C), - p : L, - em : L, - dfn : L, - //HTML5 - section : P, - header : P, - footer : P, - nav : P, - article : P, - aside : P, - figure: P, - dialog : P, - hgroup : P, - mark : L, - time : L, - meter : L, - menu : L, - command : L, - keygen : L, - output : L, - progress : O, - audio : O, - video : O, - details : O, - datagrid : O, - datalist : O - }; -})(); - -// PACKAGER_RENAME( CKEDITOR.dtd ) diff --git a/media/ckeditor/_source/core/editor.js b/media/ckeditor/_source/core/editor.js deleted file mode 100644 index 87062e0..0000000 --- a/media/ckeditor/_source/core/editor.js +++ /dev/null @@ -1,1059 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @fileOverview Defines the {@link CKEDITOR.editor} class, which represents an - * editor instance. - */ - -(function() -{ - // The counter for automatic instance names. - var nameCounter = 0; - - var getNewName = function() - { - var name = 'editor' + ( ++nameCounter ); - return ( CKEDITOR.instances && CKEDITOR.instances[ name ] ) ? getNewName() : name; - }; - - // ##### START: Config Privates - - // These function loads custom configuration files and cache the - // CKEDITOR.editorConfig functions defined on them, so there is no need to - // download them more than once for several instances. - var loadConfigLoaded = {}; - var loadConfig = function( editor ) - { - var customConfig = editor.config.customConfig; - - // Check if there is a custom config to load. - if ( !customConfig ) - return false; - - customConfig = CKEDITOR.getUrl( customConfig ); - - var loadedConfig = loadConfigLoaded[ customConfig ] || ( loadConfigLoaded[ customConfig ] = {} ); - - // If the custom config has already been downloaded, reuse it. - if ( loadedConfig.fn ) - { - // Call the cached CKEDITOR.editorConfig defined in the custom - // config file for the editor instance depending on it. - loadedConfig.fn.call( editor, editor.config ); - - // If there is no other customConfig in the chain, fire the - // "configLoaded" event. - if ( CKEDITOR.getUrl( editor.config.customConfig ) == customConfig || !loadConfig( editor ) ) - editor.fireOnce( 'customConfigLoaded' ); - } - else - { - // Load the custom configuration file. - CKEDITOR.scriptLoader.load( customConfig, function() - { - // If the CKEDITOR.editorConfig function has been properly - // defined in the custom configuration file, cache it. - if ( CKEDITOR.editorConfig ) - loadedConfig.fn = CKEDITOR.editorConfig; - else - loadedConfig.fn = function(){}; - - // Call the load config again. This time the custom - // config is already cached and so it will get loaded. - loadConfig( editor ); - }); - } - - return true; - }; - - var initConfig = function( editor, instanceConfig ) - { - // Setup the lister for the "customConfigLoaded" event. - editor.on( 'customConfigLoaded', function() - { - if ( instanceConfig ) - { - // Register the events that may have been set at the instance - // configuration object. - if ( instanceConfig.on ) - { - for ( var eventName in instanceConfig.on ) - { - editor.on( eventName, instanceConfig.on[ eventName ] ); - } - } - - // Overwrite the settings from the in-page config. - CKEDITOR.tools.extend( editor.config, instanceConfig, true ); - - delete editor.config.on; - } - - onConfigLoaded( editor ); - }); - - // The instance config may override the customConfig setting to avoid - // loading the default ~/config.js file. - if ( instanceConfig && instanceConfig.customConfig != undefined ) - editor.config.customConfig = instanceConfig.customConfig; - - // Load configs from the custom configuration files. - if ( !loadConfig( editor ) ) - editor.fireOnce( 'customConfigLoaded' ); - }; - - // ##### END: Config Privates - - var onConfigLoaded = function( editor ) - { - // Set config related properties. - - var skin = editor.config.skin.split( ',' ), - skinName = skin[ 0 ], - skinPath = CKEDITOR.getUrl( skin[ 1 ] || ( - '_source/' + // @Packager.RemoveLine - 'skins/' + skinName + '/' ) ); - - /** - * The name of the skin used by this editor instance. The skin name can - * be set through the {@link CKEDITOR.config.skin} setting. - * @name CKEDITOR.editor.prototype.skinName - * @type String - * @example - * alert( editor.skinName ); // E.g. "kama" - */ - editor.skinName = skinName; - - /** - * The full URL of the skin directory. - * @name CKEDITOR.editor.prototype.skinPath - * @type String - * @example - * alert( editor.skinPath ); // E.g. "http://example.com/ckeditor/skins/kama/" - */ - editor.skinPath = skinPath; - - /** - * The CSS class name used for skin identification purposes. - * @name CKEDITOR.editor.prototype.skinClass - * @type String - * @example - * alert( editor.skinClass ); // E.g. "cke_skin_kama" - */ - editor.skinClass = 'cke_skin_' + skinName; - - /** - * The tabbing - * navigation order that has been calculated for this editor - * instance. This can be set by the {@link CKEDITOR.config.tabIndex} - * setting or taken from the tabindex attribute of the - * {@link #element} associated with the editor. - * @name CKEDITOR.editor.prototype.tabIndex - * @type Number - * @default 0 (zero) - * @example - * alert( editor.tabIndex ); // E.g. "0" - */ - editor.tabIndex = editor.config.tabIndex || editor.element.getAttribute( 'tabindex' ) || 0; - - /** - * Indicates the read-only state of this editor. This is a read-only property. - * @name CKEDITOR.editor.prototype.readOnly - * @type Boolean - * @since 3.6 - * @see CKEDITOR.editor#setReadOnly - */ - editor.readOnly = !!( editor.config.readOnly || editor.element.getAttribute( 'disabled' ) ); - - // Fire the "configLoaded" event. - editor.fireOnce( 'configLoaded' ); - - // Load language file. - loadSkin( editor ); - }; - - var loadLang = function( editor ) - { - CKEDITOR.lang.load( editor.config.language, editor.config.defaultLanguage, function( languageCode, lang ) - { - /** - * The code for the language resources that have been loaded - * for the user interface elements of this editor instance. - * @name CKEDITOR.editor.prototype.langCode - * @type String - * @example - * alert( editor.langCode ); // E.g. "en" - */ - editor.langCode = languageCode; - - /** - * An object that contains all language strings used by the editor - * interface. - * @name CKEDITOR.editor.prototype.lang - * @type CKEDITOR.lang - * @example - * alert( editor.lang.bold ); // E.g. "Negrito" (if the language is set to Portuguese) - */ - // As we'll be adding plugin specific entries that could come - // from different language code files, we need a copy of lang, - // not a direct reference to it. - editor.lang = CKEDITOR.tools.prototypedCopy( lang ); - - // We're not able to support RTL in Firefox 2 at this time. - if ( CKEDITOR.env.gecko && CKEDITOR.env.version < 10900 && editor.lang.dir == 'rtl' ) - editor.lang.dir = 'ltr'; - - editor.fire( 'langLoaded' ); - - var config = editor.config; - config.contentsLangDirection == 'ui' && ( config.contentsLangDirection = editor.lang.dir ); - - loadPlugins( editor ); - }); - }; - - var loadPlugins = function( editor ) - { - var config = editor.config, - plugins = config.plugins, - extraPlugins = config.extraPlugins, - removePlugins = config.removePlugins; - - if ( extraPlugins ) - { - // Remove them first to avoid duplications. - var removeRegex = new RegExp( '(?:^|,)(?:' + extraPlugins.replace( /\s*,\s*/g, '|' ) + ')(?=,|$)' , 'g' ); - plugins = plugins.replace( removeRegex, '' ); - - plugins += ',' + extraPlugins; - } - - if ( removePlugins ) - { - removeRegex = new RegExp( '(?:^|,)(?:' + removePlugins.replace( /\s*,\s*/g, '|' ) + ')(?=,|$)' , 'g' ); - plugins = plugins.replace( removeRegex, '' ); - } - - // Load the Adobe AIR plugin conditionally. - CKEDITOR.env.air && ( plugins += ',adobeair' ); - - // Load all plugins defined in the "plugins" setting. - CKEDITOR.plugins.load( plugins.split( ',' ), function( plugins ) - { - // The list of plugins. - var pluginsArray = []; - - // The language code to get loaded for each plugin. Null - // entries will be appended for plugins with no language files. - var languageCodes = []; - - // The list of URLs to language files. - var languageFiles = []; - - /** - * An object that contains references to all plugins used by this - * editor instance. - * @name CKEDITOR.editor.prototype.plugins - * @type Object - * @example - * alert( editor.plugins.dialog.path ); // E.g. "http://example.com/ckeditor/plugins/dialog/" - */ - editor.plugins = plugins; - - // Loop through all plugins, to build the list of language - // files to get loaded. - for ( var pluginName in plugins ) - { - var plugin = plugins[ pluginName ], - pluginLangs = plugin.lang, - pluginPath = CKEDITOR.plugins.getPath( pluginName ), - lang = null; - - // Set the plugin path in the plugin. - plugin.path = pluginPath; - - // If the plugin has "lang". - if ( pluginLangs ) - { - // Resolve the plugin language. If the current language - // is not available, get the first one (default one). - lang = ( CKEDITOR.tools.indexOf( pluginLangs, editor.langCode ) >= 0 ? editor.langCode : pluginLangs[ 0 ] ); - - if ( !plugin.langEntries || !plugin.langEntries[ lang ] ) - { - // Put the language file URL into the list of files to - // get downloaded. - languageFiles.push( CKEDITOR.getUrl( pluginPath + 'lang/' + lang + '.js' ) ); - } - else - { - CKEDITOR.tools.extend( editor.lang, plugin.langEntries[ lang ] ); - lang = null; - } - } - - // Save the language code, so we know later which - // language has been resolved to this plugin. - languageCodes.push( lang ); - - pluginsArray.push( plugin ); - } - - // Load all plugin specific language files in a row. - CKEDITOR.scriptLoader.load( languageFiles, function() - { - // Initialize all plugins that have the "beforeInit" and "init" methods defined. - var methods = [ 'beforeInit', 'init', 'afterInit' ]; - for ( var m = 0 ; m < methods.length ; m++ ) - { - for ( var i = 0 ; i < pluginsArray.length ; i++ ) - { - var plugin = pluginsArray[ i ]; - - // Uses the first loop to update the language entries also. - if ( m === 0 && languageCodes[ i ] && plugin.lang ) - CKEDITOR.tools.extend( editor.lang, plugin.langEntries[ languageCodes[ i ] ] ); - - // Call the plugin method (beforeInit and init). - if ( plugin[ methods[ m ] ] ) - plugin[ methods[ m ] ]( editor ); - } - } - - // Load the editor skin. - editor.fire( 'pluginsLoaded' ); - loadTheme( editor ); - }); - }); - }; - - var loadSkin = function( editor ) - { - CKEDITOR.skins.load( editor, 'editor', function() - { - loadLang( editor ); - }); - }; - - var loadTheme = function( editor ) - { - var theme = editor.config.theme; - CKEDITOR.themes.load( theme, function() - { - /** - * The theme used by this editor instance. - * @name CKEDITOR.editor.prototype.theme - * @type CKEDITOR.theme - * @example - * alert( editor.theme ); // E.g. "http://example.com/ckeditor/themes/default/" - */ - var editorTheme = editor.theme = CKEDITOR.themes.get( theme ); - editorTheme.path = CKEDITOR.themes.getPath( theme ); - editorTheme.build( editor ); - - if ( editor.config.autoUpdateElement ) - attachToForm( editor ); - }); - }; - - var attachToForm = function( editor ) - { - var element = editor.element; - - // If are replacing a textarea, we must - if ( editor.elementMode == CKEDITOR.ELEMENT_MODE_REPLACE && element.is( 'textarea' ) ) - { - var form = element.$.form && new CKEDITOR.dom.element( element.$.form ); - if ( form ) - { - function onSubmit() - { - editor.updateElement(); - } - form.on( 'submit',onSubmit ); - - // Setup the submit function because it doesn't fire the - // "submit" event. - if ( !form.$.submit.nodeName && !form.$.submit.length ) - { - form.$.submit = CKEDITOR.tools.override( form.$.submit, function( originalSubmit ) - { - return function() - { - editor.updateElement(); - - // For IE, the DOM submit function is not a - // function, so we need thid check. - if ( originalSubmit.apply ) - originalSubmit.apply( this, arguments ); - else - originalSubmit(); - }; - }); - } - - // Remove 'submit' events registered on form element before destroying.(#3988) - editor.on( 'destroy', function() - { - form.removeListener( 'submit', onSubmit ); - } ); - } - } - }; - - function updateCommands() - { - var command, - commands = this._.commands, - mode = this.mode; - - if ( !mode ) - return; - - for ( var name in commands ) - { - command = commands[ name ]; - command[ command.startDisabled ? 'disable' : - this.readOnly && !command.readOnly ? 'disable' : command.modes[ mode ] ? 'enable' : 'disable' ](); - } - } - - /** - * Initializes the editor instance. This function is called by the editor - * contructor (editor_basic.js). - * @private - */ - CKEDITOR.editor.prototype._init = function() - { - // Get the properties that have been saved in the editor_base - // implementation. - var element = CKEDITOR.dom.element.get( this._.element ), - instanceConfig = this._.instanceConfig; - delete this._.element; - delete this._.instanceConfig; - - this._.commands = {}; - this._.styles = []; - - /** - * The DOM element that was replaced by this editor instance. This - * element stores the editor data on load and post. - * @name CKEDITOR.editor.prototype.element - * @type CKEDITOR.dom.element - * @example - * var editor = CKEDITOR.instances.editor1; - * alert( editor.element.getName() ); // E.g. "textarea" - */ - this.element = element; - - /** - * The editor instance name. It may be the replaced element ID, name, or - * a default name using the progressive counter (editor1, - * editor2, ...). - * @name CKEDITOR.editor.prototype.name - * @type String - * @example - * var editor = CKEDITOR.instances.editor1; - * alert( editor.name ); // "editor1" - */ - this.name = ( element && ( this.elementMode == CKEDITOR.ELEMENT_MODE_REPLACE ) - && ( element.getId() || element.getNameAtt() ) ) - || getNewName(); - - if ( this.name in CKEDITOR.instances ) - throw '[CKEDITOR.editor] The instance "' + this.name + '" already exists.'; - - /** - * A unique random string assigned to each editor instance on the page. - * @name CKEDITOR.editor.prototype.id - * @type String - */ - this.id = CKEDITOR.tools.getNextId(); - - /** - * The configurations for this editor instance. It inherits all - * settings defined in (@link CKEDITOR.config}, combined with settings - * loaded from custom configuration files and those defined inline in - * the page when creating the editor. - * @name CKEDITOR.editor.prototype.config - * @type Object - * @example - * var editor = CKEDITOR.instances.editor1; - * alert( editor.config.theme ); // E.g. "default" - */ - this.config = CKEDITOR.tools.prototypedCopy( CKEDITOR.config ); - - /** - * The namespace containing UI features related to this editor instance. - * @name CKEDITOR.editor.prototype.ui - * @type CKEDITOR.ui - * @example - */ - this.ui = new CKEDITOR.ui( this ); - - /** - * Controls the focus state of this editor instance. This property - * is rarely used for normal API operations. It is mainly - * intended for developers adding UI elements to the editor interface. - * @name CKEDITOR.editor.prototype.focusManager - * @type CKEDITOR.focusManager - * @example - */ - this.focusManager = new CKEDITOR.focusManager( this ); - - CKEDITOR.fire( 'instanceCreated', null, this ); - - this.on( 'mode', updateCommands, null, null, 1 ); - this.on( 'readOnly', updateCommands, null, null, 1 ); - - initConfig( this, instanceConfig ); - }; -})(); - -CKEDITOR.tools.extend( CKEDITOR.editor.prototype, - /** @lends CKEDITOR.editor.prototype */ - { - /** - * Adds a command definition to the editor instance. Commands added with - * this function can be executed later with the {@link #execCommand} method. - * @param {String} commandName The indentifier name of the command. - * @param {CKEDITOR.commandDefinition} commandDefinition The command definition. - * @example - * editorInstance.addCommand( 'sample', - * { - * exec : function( editor ) - * { - * alert( 'Executing a command for the editor name "' + editor.name + '"!' ); - * } - * }); - */ - addCommand : function( commandName, commandDefinition ) - { - return this._.commands[ commandName ] = new CKEDITOR.command( this, commandDefinition ); - }, - - /** - * Adds a piece of CSS code to the editor which will be applied to the WYSIWYG editing document. - * This CSS would not be added to the output, and is there mainly for editor-specific editing requirements. - * Note: This function should be called before the editor is loaded to take effect. - * @param css {String} CSS text. - * @example - * editorInstance.addCss( 'body { background-color: grey; }' ); - */ - addCss : function( css ) - { - this._.styles.push( css ); - }, - - /** - * Destroys the editor instance, releasing all resources used by it. - * If the editor replaced an element, the element will be recovered. - * @param {Boolean} [noUpdate] If the instance is replacing a DOM - * element, this parameter indicates whether or not to update the - * element with the instance contents. - * @example - * alert( CKEDITOR.instances.editor1 ); // E.g "object" - * CKEDITOR.instances.editor1.destroy(); - * alert( CKEDITOR.instances.editor1 ); // "undefined" - */ - destroy : function( noUpdate ) - { - if ( !noUpdate ) - this.updateElement(); - - this.fire( 'destroy' ); - this.theme && this.theme.destroy( this ); - - CKEDITOR.remove( this ); - CKEDITOR.fire( 'instanceDestroyed', null, this ); - }, - - /** - * Executes a command associated with the editor. - * @param {String} commandName The indentifier name of the command. - * @param {Object} [data] Data to be passed to the command. - * @returns {Boolean} true if the command was executed - * successfully, otherwise false. - * @see CKEDITOR.editor.addCommand - * @example - * editorInstance.execCommand( 'bold' ); - */ - execCommand : function( commandName, data ) - { - var command = this.getCommand( commandName ); - - var eventData = - { - name: commandName, - commandData: data, - command: command - }; - - if ( command && command.state != CKEDITOR.TRISTATE_DISABLED ) - { - if ( this.fire( 'beforeCommandExec', eventData ) !== true ) - { - eventData.returnValue = command.exec( eventData.commandData ); - - // Fire the 'afterCommandExec' immediately if command is synchronous. - if ( !command.async && this.fire( 'afterCommandExec', eventData ) !== true ) - return eventData.returnValue; - } - } - - // throw 'Unknown command name "' + commandName + '"'; - return false; - }, - - /** - * Gets one of the registered commands. Note that after registering a - * command definition with {@link #addCommand}, it is - * transformed internally into an instance of - * {@link CKEDITOR.command}, which will then be returned - * by this function. - * @param {String} commandName The name of the command to be returned. - * This is the same name that is used to register the command with - * addCommand. - * @returns {CKEDITOR.command} The command object identified by the - * provided name. - */ - getCommand : function( commandName ) - { - return this._.commands[ commandName ]; - }, - - /** - * Gets the editor data. The data will be in raw format. It is the same - * data that is posted by the editor. - * @type String - * @returns (String) The editor data. - * @example - * if ( CKEDITOR.instances.editor1.getData() == '' ) - * alert( 'There is no data available' ); - */ - getData : function() - { - this.fire( 'beforeGetData' ); - - var eventData = this._.data; - - if ( typeof eventData != 'string' ) - { - var element = this.element; - if ( element && this.elementMode == CKEDITOR.ELEMENT_MODE_REPLACE ) - eventData = element.is( 'textarea' ) ? element.getValue() : element.getHtml(); - else - eventData = ''; - } - - eventData = { dataValue : eventData }; - - // Fire "getData" so data manipulation may happen. - this.fire( 'getData', eventData ); - - return eventData.dataValue; - }, - - /** - * Gets the "raw data" currently available in the editor. This is a - * fast method which returns the data as is, without processing, so it is - * not recommended to use it on resulting pages. Instead it can be used - * combined with the {@link #loadSnapshot} method in order - * to be able to automatically save the editor data from time to time - * while the user is using the editor, to avoid data loss, without risking - * performance issues. - * @see CKEDITOR.editor.getData - * @example - * alert( editor.getSnapshot() ); - */ - getSnapshot : function() - { - var data = this.fire( 'getSnapshot' ); - - if ( typeof data != 'string' ) - { - var element = this.element; - if ( element && this.elementMode == CKEDITOR.ELEMENT_MODE_REPLACE ) - data = element.is( 'textarea' ) ? element.getValue() : element.getHtml(); - } - - return data; - }, - - /** - * Loads "raw data" into the editor. The data is loaded with processing - * straight to the editing area. It should not be used as a way to load - * any kind of data, but instead in combination with - * {@link #getSnapshot} produced data. - * @see CKEDITOR.editor.setData - * @example - * var data = editor.getSnapshot(); - * editor.loadSnapshot( data ); - */ - loadSnapshot : function( snapshot ) - { - this.fire( 'loadSnapshot', snapshot ); - }, - - /** - * Sets the editor data. The data must be provided in the raw format (HTML).
      - *
      - * Note that this method is asynchronous. The callback parameter must - * be used if interaction with the editor is needed after setting the data. - * @param {String} data HTML code to replace the curent content in the - * editor. - * @param {Function} callback Function to be called after the setData - * is completed. - *@param {Boolean} internal Whether to suppress any event firing when copying data - * internally inside the editor. - * @example - * CKEDITOR.instances.editor1.setData( '<p>This is the editor data.</p>' ); - * @example - * CKEDITOR.instances.editor1.setData( '<p>Some other editor data.</p>', function() - * { - * this.checkDirty(); // true - * }); - */ - setData : function( data , callback, internal ) - { - if( callback ) - { - this.on( 'dataReady', function( evt ) - { - evt.removeListener(); - callback.call( evt.editor ); - } ); - } - - // Fire "setData" so data manipulation may happen. - var eventData = { dataValue : data }; - !internal && this.fire( 'setData', eventData ); - - this._.data = eventData.dataValue; - - !internal && this.fire( 'afterSetData', eventData ); - }, - - /** - * Puts or restores the editor into read-only state. When in read-only, - * the user is not able to change the editor contents, but can still use - * some editor features. This function sets the {@link CKEDITOR.config.readOnly} - * property of the editor, firing the {@link CKEDITOR.editor#readOnly} event.

      - * Note: the current editing area will be reloaded. - * @param {Boolean} [isReadOnly] Indicates that the editor must go - * read-only (true, default) or be restored and made editable - * (false). - * @since 3.6 - */ - setReadOnly : function( isReadOnly ) - { - isReadOnly = ( isReadOnly == undefined ) || isReadOnly; - - if ( this.readOnly != isReadOnly ) - { - this.readOnly = isReadOnly; - - // Fire the readOnly event so the editor features can update - // their state accordingly. - this.fire( 'readOnly' ); - } - }, - - /** - * Inserts HTML code into the currently selected position in the editor in WYSIWYG mode. - * @param {String} data HTML code to be inserted into the editor. - * @example - * CKEDITOR.instances.editor1.insertHtml( '<p>This is a new paragraph.</p>' ); - */ - insertHtml : function( data ) - { - this.fire( 'insertHtml', data ); - }, - - /** - * Insert text content into the currently selected position in the - * editor in WYSIWYG mode. The styles of the selected element will be applied to the inserted text. - * Spaces around the text will be leaving untouched. - * Note: two subsequent line-breaks will introduce one paragraph. This depends on {@link CKEDITOR.config.enterMode}; - * A single line-break will be instead translated into one <br />. - * @since 3.5 - * @param {String} text Text to be inserted into the editor. - * @example - * CKEDITOR.instances.editor1.insertText( ' line1 \n\n line2' ); - */ - insertText : function( text ) - { - this.fire( 'insertText', text ); - }, - - /** - * Inserts an element into the currently selected position in the - * editor in WYSIWYG mode. - * @param {CKEDITOR.dom.element} element The element to be inserted - * into the editor. - * @example - * var element = CKEDITOR.dom.element.createFromHtml( '<img src="hello.png" border="0" title="Hello" />' ); - * CKEDITOR.instances.editor1.insertElement( element ); - */ - insertElement : function( element ) - { - this.fire( 'insertElement', element ); - }, - - /** - * Checks whether the current editor contents contain changes when - * compared to the contents loaded into the editor at startup, or to - * the contents available in the editor when {@link #resetDirty} - * was called. - * @returns {Boolean} "true" is the contents contain changes. - * @example - * function beforeUnload( e ) - * { - * if ( CKEDITOR.instances.editor1.checkDirty() ) - * return e.returnValue = "You will lose the changes made in the editor."; - * } - * - * if ( window.addEventListener ) - * window.addEventListener( 'beforeunload', beforeUnload, false ); - * else - * window.attachEvent( 'onbeforeunload', beforeUnload ); - */ - checkDirty : function() - { - return ( this.mayBeDirty && this._.previousValue !== this.getSnapshot() ); - }, - - /** - * Resets the "dirty state" of the editor so subsequent calls to - * {@link #checkDirty} will return false if the user will not - * have made further changes to the contents. - * @example - * alert( editor.checkDirty() ); // E.g. "true" - * editor.resetDirty(); - * alert( editor.checkDirty() ); // "false" - */ - resetDirty : function() - { - if ( this.mayBeDirty ) - this._.previousValue = this.getSnapshot(); - }, - - /** - * Updates the <textarea> element that was replaced by the editor with - * the current data available in the editor. - * @see CKEDITOR.editor.element - * @example - * CKEDITOR.instances.editor1.updateElement(); - * alert( document.getElementById( 'editor1' ).value ); // The current editor data. - */ - updateElement : function() - { - var element = this.element; - if ( element && this.elementMode == CKEDITOR.ELEMENT_MODE_REPLACE ) - { - var data = this.getData(); - - if ( this.config.htmlEncodeOutput ) - data = CKEDITOR.tools.htmlEncode( data ); - - if ( element.is( 'textarea' ) ) - element.setValue( data ); - else - element.setHtml( data ); - } - } - }); - -CKEDITOR.on( 'loaded', function() - { - // Run the full initialization for pending editors. - var pending = CKEDITOR.editor._pending; - if ( pending ) - { - delete CKEDITOR.editor._pending; - - for ( var i = 0 ; i < pending.length ; i++ ) - pending[ i ]._init(); - } - }); - -/** - * Whether to escape HTML when the editor updates the original input element. - * @name CKEDITOR.config.htmlEncodeOutput - * @since 3.1 - * @type Boolean - * @default false - * @example - * config.htmlEncodeOutput = true; - */ - -/** - * If true, makes the editor start in read-only state. Otherwise, it will check - * if the linked <textarea> element has the disabled attribute. - * @name CKEDITOR.config.readOnly - * @see CKEDITOR.editor#setReadOnly - * @type Boolean - * @default false - * @since 3.6 - * @example - * config.readOnly = true; - */ - -/** - * Fired when a CKEDITOR instance is created, but still before initializing it. - * To interact with a fully initialized instance, use the - * {@link CKEDITOR#instanceReady} event instead. - * @name CKEDITOR#instanceCreated - * @event - * @param {CKEDITOR.editor} editor The editor instance that has been created. - */ - -/** - * Fired when a CKEDITOR instance is destroyed. - * @name CKEDITOR#instanceDestroyed - * @event - * @param {CKEDITOR.editor} editor The editor instance that has been destroyed. - */ - -/** - * Fired when the language is loaded into the editor instance. - * @name CKEDITOR.editor#langLoaded - * @event - * @since 3.6.1 - * @param {CKEDITOR.editor} editor This editor instance. - */ - -/** - * Fired when all plugins are loaded and initialized into the editor instance. - * @name CKEDITOR.editor#pluginsLoaded - * @event - * @param {CKEDITOR.editor} editor This editor instance. - */ - -/** - * Fired before the command execution when {@link #execCommand} is called. - * @name CKEDITOR.editor#beforeCommandExec - * @event - * @param {CKEDITOR.editor} editor This editor instance. - * @param {String} data.name The command name. - * @param {Object} data.commandData The data to be sent to the command. This - * can be manipulated by the event listener. - * @param {CKEDITOR.command} data.command The command itself. - */ - -/** - * Fired after the command execution when {@link #execCommand} is called. - * @name CKEDITOR.editor#afterCommandExec - * @event - * @param {CKEDITOR.editor} editor This editor instance. - * @param {String} data.name The command name. - * @param {Object} data.commandData The data sent to the command. - * @param {CKEDITOR.command} data.command The command itself. - * @param {Object} data.returnValue The value returned by the command execution. - */ - -/** - * Fired when the custom configuration file is loaded, before the final - * configurations initialization.
      - *
      - * Custom configuration files can be loaded thorugh the - * {@link CKEDITOR.config.customConfig} setting. Several files can be loaded - * by changing this setting. - * @name CKEDITOR.editor#customConfigLoaded - * @event - * @param {CKEDITOR.editor} editor This editor instance. - */ - -/** - * Fired once the editor configuration is ready (loaded and processed). - * @name CKEDITOR.editor#configLoaded - * @event - * @param {CKEDITOR.editor} editor This editor instance. - */ - -/** - * Fired when this editor instance is destroyed. The editor at this - * point is not usable and this event should be used to perform the clean-up - * in any plugin. - * @name CKEDITOR.editor#destroy - * @event - */ - -/** - * Internal event to get the current data. - * @name CKEDITOR.editor#beforeGetData - * @event - */ - -/** - * Internal event to perform the #getSnapshot call. - * @name CKEDITOR.editor#getSnapshot - * @event - */ - -/** - * Internal event to perform the #loadSnapshot call. - * @name CKEDITOR.editor#loadSnapshot - * @event - */ - -/** - * Event fired before the #getData call returns allowing additional manipulation. - * @name CKEDITOR.editor#getData - * @event - * @param {CKEDITOR.editor} editor This editor instance. - * @param {String} data.dataValue The data that will be returned. - */ - -/** - * Event fired before the #setData call is executed allowing additional manipulation. - * @name CKEDITOR.editor#setData - * @event - * @param {CKEDITOR.editor} editor This editor instance. - * @param {String} data.dataValue The data that will be used. - */ - -/** - * Event fired at the end of the #setData call execution. Usually it is better to use the - * {@link CKEDITOR.editor.prototype.dataReady} event. - * @name CKEDITOR.editor#afterSetData - * @event - * @param {CKEDITOR.editor} editor This editor instance. - * @param {String} data.dataValue The data that has been set. - */ - -/** - * Internal event to perform the #insertHtml call - * @name CKEDITOR.editor#insertHtml - * @event - * @param {CKEDITOR.editor} editor This editor instance. - * @param {String} data The HTML to insert. - */ - -/** - * Internal event to perform the #insertText call - * @name CKEDITOR.editor#insertText - * @event - * @param {CKEDITOR.editor} editor This editor instance. - * @param {String} text The text to insert. - */ - -/** - * Internal event to perform the #insertElement call - * @name CKEDITOR.editor#insertElement - * @event - * @param {CKEDITOR.editor} editor This editor instance. - * @param {Object} element The element to insert. - */ - -/** - * Event fired after the {@link CKEDITOR.editor#readOnly} property changes. - * @name CKEDITOR.editor#readOnly - * @event - * @since 3.6 - * @param {CKEDITOR.editor} editor This editor instance. - */ diff --git a/media/ckeditor/_source/core/editor_basic.js b/media/ckeditor/_source/core/editor_basic.js deleted file mode 100644 index ec9cf01..0000000 --- a/media/ckeditor/_source/core/editor_basic.js +++ /dev/null @@ -1,186 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -if ( !CKEDITOR.editor ) -{ - /** - * No element is linked to the editor instance. - * @constant - * @example - */ - CKEDITOR.ELEMENT_MODE_NONE = 0; - - /** - * The element is to be replaced by the editor instance. - * @constant - * @example - */ - CKEDITOR.ELEMENT_MODE_REPLACE = 1; - - /** - * The editor is to be created inside the element. - * @constant - * @example - */ - CKEDITOR.ELEMENT_MODE_APPENDTO = 2; - - /** - * Creates an editor class instance. This constructor should be rarely - * used, in favor of the {@link CKEDITOR} editor creation functions. - * @ class Represents an editor instance. - * @param {Object} instanceConfig Configuration values for this specific - * instance. - * @param {CKEDITOR.dom.element} [element] The element linked to this - * instance. - * @param {Number} [mode] The mode in which the element is linked to this - * instance. See {@link #elementMode}. - * @param {String} [data] Since 3.3. Initial value for the instance. - * @augments CKEDITOR.event - * @example - */ - CKEDITOR.editor = function( instanceConfig, element, mode, data ) - { - this._ = - { - // Save the config to be processed later by the full core code. - instanceConfig : instanceConfig, - element : element, - data : data - }; - - /** - * The mode in which the {@link #element} is linked to this editor - * instance. It can be any of the following values: - *
        - *
      • {@link CKEDITOR.ELEMENT_MODE_NONE}: No element is linked to the - * editor instance.
      • - *
      • {@link CKEDITOR.ELEMENT_MODE_REPLACE}: The element is to be - * replaced by the editor instance.
      • - *
      • {@link CKEDITOR.ELEMENT_MODE_APPENDTO}: The editor is to be - * created inside the element.
      • - *
      - * @name CKEDITOR.editor.prototype.elementMode - * @type Number - * @example - * var editor = CKEDITOR.replace( 'editor1' ); - * alert( editor.elementMode ); "1" - */ - this.elementMode = mode || CKEDITOR.ELEMENT_MODE_NONE; - - // Call the CKEDITOR.event constructor to initialize this instance. - CKEDITOR.event.call( this ); - - this._init(); - }; - - /** - * Replaces a <textarea> or a DOM element (DIV) with a CKEditor - * instance. For textareas, the initial value in the editor will be the - * textarea value. For DOM elements, their innerHTML will be used - * instead. We recommend using TEXTAREA and DIV elements only. Do not use - * this function directly. Use {@link CKEDITOR.replace} instead. - * @param {Object|String} elementOrIdOrName The DOM element (textarea), its - * ID or name. - * @param {Object} [config] The specific configurations to apply to this - * editor instance. Configurations set here will override global CKEditor - * settings. - * @returns {CKEDITOR.editor} The editor instance created. - * @example - */ - CKEDITOR.editor.replace = function( elementOrIdOrName, config ) - { - var element = elementOrIdOrName; - - if ( typeof element != 'object' ) - { - // Look for the element by id. We accept any kind of element here. - element = document.getElementById( elementOrIdOrName ); - - // Elements that should go into head are unacceptable (#6791). - if ( element && element.tagName.toLowerCase() in {style:1,script:1,base:1,link:1,meta:1,title:1} ) - element = null; - - // If not found, look for elements by name. In this case we accept only - // textareas. - if ( !element ) - { - var i = 0, - textareasByName = document.getElementsByName( elementOrIdOrName ); - - while ( ( element = textareasByName[ i++ ] ) && element.tagName.toLowerCase() != 'textarea' ) - { /*jsl:pass*/ } - } - - if ( !element ) - throw '[CKEDITOR.editor.replace] The element with id or name "' + elementOrIdOrName + '" was not found.'; - } - - // Do not replace the textarea right now, just hide it. The effective - // replacement will be done by the _init function. - element.style.visibility = 'hidden'; - - // Create the editor instance. - return new CKEDITOR.editor( config, element, CKEDITOR.ELEMENT_MODE_REPLACE ); - }; - - /** - * Creates a new editor instance inside a specific DOM element. Do not use - * this function directly. Use {@link CKEDITOR.appendTo} instead. - * @param {Object|String} elementOrId The DOM element or its ID. - * @param {Object} [config] The specific configurations to apply to this - * editor instance. Configurations set here will override global CKEditor - * settings. - * @param {String} [data] Since 3.3. Initial value for the instance. - * @returns {CKEDITOR.editor} The editor instance created. - * @example - */ - CKEDITOR.editor.appendTo = function( elementOrId, config, data ) - { - var element = elementOrId; - if ( typeof element != 'object' ) - { - element = document.getElementById( elementOrId ); - - if ( !element ) - throw '[CKEDITOR.editor.appendTo] The element with id "' + elementOrId + '" was not found.'; - } - - // Create the editor instance. - return new CKEDITOR.editor( config, element, CKEDITOR.ELEMENT_MODE_APPENDTO, data ); - }; - - CKEDITOR.editor.prototype = - { - /** - * Initializes the editor instance. This function will be overriden by the - * full CKEDITOR.editor implementation (editor.js). - * @private - */ - _init : function() - { - var pending = CKEDITOR.editor._pending || ( CKEDITOR.editor._pending = [] ); - pending.push( this ); - }, - - // Both fire and fireOnce will always pass this editor instance as the - // "editor" param in CKEDITOR.event.fire. So, we override it to do that - // automaticaly. - - /** @ignore */ - fire : function( eventName, data ) - { - return CKEDITOR.event.prototype.fire.call( this, eventName, data, this ); - }, - - /** @ignore */ - fireOnce : function( eventName, data ) - { - return CKEDITOR.event.prototype.fireOnce.call( this, eventName, data, this ); - } - }; - - // "Inherit" (copy actually) from CKEDITOR.event. - CKEDITOR.event.implementOn( CKEDITOR.editor.prototype, true ); -} diff --git a/media/ckeditor/_source/core/env.js b/media/ckeditor/_source/core/env.js deleted file mode 100644 index e31af9f..0000000 --- a/media/ckeditor/_source/core/env.js +++ /dev/null @@ -1,305 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @fileOverview Defines the {@link CKEDITOR.env} object, which constains - * environment and browser information. - */ - -if ( !CKEDITOR.env ) -{ - /** - * @namespace Environment and browser information. - */ - CKEDITOR.env = (function() - { - var agent = navigator.userAgent.toLowerCase(); - var opera = window.opera; - - var env = - /** @lends CKEDITOR.env */ - { - /** - * Indicates that CKEditor is running on Internet Explorer. - * @type Boolean - * @example - * if ( CKEDITOR.env.ie ) - * alert( "I'm on IE!" ); - */ - ie : /*@cc_on!@*/false, - - /** - * Indicates that CKEditor is running on Opera. - * @type Boolean - * @example - * if ( CKEDITOR.env.opera ) - * alert( "I'm on Opera!" ); - */ - opera : ( !!opera && opera.version ), - - /** - * Indicates that CKEditor is running on a WebKit based browser, like - * Safari. - * @type Boolean - * @example - * if ( CKEDITOR.env.webkit ) - * alert( "I'm on WebKit!" ); - */ - webkit : ( agent.indexOf( ' applewebkit/' ) > -1 ), - - /** - * Indicates that CKEditor is running on Adobe AIR. - * @type Boolean - * @example - * if ( CKEDITOR.env.air ) - * alert( "I'm on AIR!" ); - */ - air : ( agent.indexOf( ' adobeair/' ) > -1 ), - - /** - * Indicates that CKEditor is running on Macintosh. - * @type Boolean - * @example - * if ( CKEDITOR.env.mac ) - * alert( "I love apples!" ); - */ - mac : ( agent.indexOf( 'macintosh' ) > -1 ), - - /** - * Indicates that CKEditor is running on a quirks mode environemnt. - * @type Boolean - * @example - * if ( CKEDITOR.env.quirks ) - * alert( "Nooooo!" ); - */ - quirks : ( document.compatMode == 'BackCompat' ), - - /** - * Indicates that CKEditor is running on a mobile like environemnt. - * @type Boolean - * @example - * if ( CKEDITOR.env.mobile ) - * alert( "I'm running with CKEditor today!" ); - */ - mobile : ( agent.indexOf( 'mobile' ) > -1 ), - - /** - * Indicates that CKEditor is running on Apple iPhone/iPad/iPod devices. - * @type Boolean - * @example - * if ( CKEDITOR.env.iOS ) - * alert( "I like little apples!" ); - */ - iOS : /(ipad|iphone|ipod)/.test(agent), - - /** - * Indicates that the browser has a custom domain enabled. This has - * been set with "document.domain". - * @returns {Boolean} "true" if a custom domain is enabled. - * @example - * if ( CKEDITOR.env.isCustomDomain() ) - * alert( "I'm in a custom domain!" ); - */ - isCustomDomain : function() - { - if ( !this.ie ) - return false; - - var domain = document.domain, - hostname = window.location.hostname; - - return domain != hostname && - domain != ( '[' + hostname + ']' ); // IPv6 IP support (#5434) - }, - - /** - * Indicates that page is running under an encrypted connection. - * @returns {Boolean} "true" if the page has an encrypted connection. - * @example - * if ( CKEDITOR.env.secure ) - * alert( "I'm in SSL!" ); - */ - secure : location.protocol == 'https:' - }; - - /** - * Indicates that CKEditor is running on a Gecko based browser, like - * Firefox. - * @name CKEDITOR.env.gecko - * @type Boolean - * @example - * if ( CKEDITOR.env.gecko ) - * alert( "I'm riding a gecko!" ); - */ - env.gecko = ( navigator.product == 'Gecko' && !env.webkit && !env.opera ); - - var version = 0; - - // Internet Explorer 6.0+ - if ( env.ie ) - { - version = parseFloat( agent.match( /msie (\d+)/ )[1] ); - - /** - * Indicates that CKEditor is running on Internet Explorer 8. - * @name CKEDITOR.env.ie8 - * @type Boolean - * @example - * if ( CKEDITOR.env.ie8 ) - * alert( "I'm on IE8!" ); - */ - env.ie8 = !!document.documentMode; - - /** - * Indicates that CKEditor is running on Internet Explorer 8 on - * standards mode. - * @name CKEDITOR.env.ie8Compat - * @type Boolean - * @example - * if ( CKEDITOR.env.ie8Compat ) - * alert( "Now I'm on IE8, for real!" ); - */ - env.ie8Compat = document.documentMode == 8; - - /** - * Indicates that CKEditor is running on Internet Explorer 9's standards mode. - * @name CKEDITOR.env.ie9Compat - * @type Boolean - * @example - * if ( CKEDITOR.env.ie9Compat ) - * alert( "IE9, the beauty of the web!" ); - */ - env.ie9Compat = document.documentMode == 9; - - /** - * Indicates that CKEditor is running on an IE7-like environment, which - * includes IE7 itself and IE8's IE7 document mode. - * @name CKEDITOR.env.ie7Compat - * @type Boolean - * @example - * if ( CKEDITOR.env.ie8Compat ) - * alert( "I'm on IE7 or on an IE7 like IE8!" ); - */ - env.ie7Compat = ( ( version == 7 && !document.documentMode ) - || document.documentMode == 7 ); - - /** - * Indicates that CKEditor is running on an IE6-like environment, which - * includes IE6 itself and IE7 and IE8 quirks mode. - * @name CKEDITOR.env.ie6Compat - * @type Boolean - * @example - * if ( CKEDITOR.env.ie6Compat ) - * alert( "I'm on IE6 or quirks mode!" ); - */ - env.ie6Compat = ( version < 7 || env.quirks ); - } - - // Gecko. - if ( env.gecko ) - { - var geckoRelease = agent.match( /rv:([\d\.]+)/ ); - if ( geckoRelease ) - { - geckoRelease = geckoRelease[1].split( '.' ); - version = geckoRelease[0] * 10000 + ( geckoRelease[1] || 0 ) * 100 + ( geckoRelease[2] || 0 ) * 1; - } - } - - // Opera 9.50+ - if ( env.opera ) - version = parseFloat( opera.version() ); - - // Adobe AIR 1.0+ - // Checked before Safari because AIR have the WebKit rich text editor - // features from Safari 3.0.4, but the version reported is 420. - if ( env.air ) - version = parseFloat( agent.match( / adobeair\/(\d+)/ )[1] ); - - // WebKit 522+ (Safari 3+) - if ( env.webkit ) - version = parseFloat( agent.match( / applewebkit\/(\d+)/ )[1] ); - - /** - * Contains the browser version.
      - *
      - * For gecko based browsers (like Firefox) it contains the revision - * number with first three parts concatenated with a padding zero - * (e.g. for revision 1.9.0.2 we have 10900).
      - *
      - * For webkit based browser (like Safari and Chrome) it contains the - * WebKit build version (e.g. 522). - * @name CKEDITOR.env.version - * @type Boolean - * @example - * if ( CKEDITOR.env.ie && CKEDITOR.env.version <= 6 ) - * alert( "Ouch!" ); - */ - env.version = version; - - /** - * Indicates that CKEditor is running on a compatible browser. - * @name CKEDITOR.env.isCompatible - * @type Boolean - * @example - * if ( CKEDITOR.env.isCompatible ) - * alert( "Your browser is pretty cool!" ); - */ - env.isCompatible = - - // White list of mobile devices that supports. - env.iOS && version >= 534 || - - !env.mobile && ( - - ( env.ie && version >= 6 ) || - ( env.gecko && version >= 10801 ) || - ( env.opera && version >= 9.5 ) || - ( env.air && version >= 1 ) || - ( env.webkit && version >= 522 ) || - false ); - - /** - * The CSS class to be appended on the main UI containers, making it - * easy to apply browser specific styles to it. - * @name CKEDITOR.env.cssClass - * @type String - * @example - * myDiv.className = CKEDITOR.env.cssClass; - */ - env.cssClass = - 'cke_browser_' + ( - env.ie ? 'ie' : - env.gecko ? 'gecko' : - env.opera ? 'opera' : - env.webkit ? 'webkit' : - 'unknown' ); - - if ( env.quirks ) - env.cssClass += ' cke_browser_quirks'; - - if ( env.ie ) - { - env.cssClass += ' cke_browser_ie' + ( - env.version < 7 ? '6' : - env.version >= 8 ? document.documentMode: - '7' ); - - if ( env.quirks ) - env.cssClass += ' cke_browser_iequirks'; - } - - if ( env.gecko && version < 10900 ) - env.cssClass += ' cke_browser_gecko18'; - - if ( env.air ) - env.cssClass += ' cke_browser_air'; - - return env; - })(); -} - -// PACKAGER_RENAME( CKEDITOR.env ) -// PACKAGER_RENAME( CKEDITOR.env.ie ) diff --git a/media/ckeditor/_source/core/event.js b/media/ckeditor/_source/core/event.js deleted file mode 100644 index 1dcd2dd..0000000 --- a/media/ckeditor/_source/core/event.js +++ /dev/null @@ -1,342 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @fileOverview Defines the {@link CKEDITOR.event} class, which serves as the - * base for classes and objects that require event handling features. - */ - -if ( !CKEDITOR.event ) -{ - /** - * Creates an event class instance. This constructor is rearely used, being - * the {@link #.implementOn} function used in class prototypes directly - * instead. - * @class This is a base class for classes and objects that require event - * handling features.
      - *
      - * Do not confuse this class with {@link CKEDITOR.dom.event} which is - * instead used for DOM events. The CKEDITOR.event class implements the - * internal event system used by the CKEditor to fire API related events. - * @example - */ - CKEDITOR.event = function() - {}; - - /** - * Implements the {@link CKEDITOR.event} features in an object. - * @param {Object} targetObject The object into which implement the features. - * @example - * var myObject = { message : 'Example' }; - * CKEDITOR.event.implementOn( myObject }; - * myObject.on( 'testEvent', function() - * { - * alert( this.message ); // "Example" - * }); - * myObject.fire( 'testEvent' ); - */ - CKEDITOR.event.implementOn = function( targetObject ) - { - var eventProto = CKEDITOR.event.prototype; - - for ( var prop in eventProto ) - { - if ( targetObject[ prop ] == undefined ) - targetObject[ prop ] = eventProto[ prop ]; - } - }; - - CKEDITOR.event.prototype = (function() - { - // Returns the private events object for a given object. - var getPrivate = function( obj ) - { - var _ = ( obj.getPrivate && obj.getPrivate() ) || obj._ || ( obj._ = {} ); - return _.events || ( _.events = {} ); - }; - - var eventEntry = function( eventName ) - { - this.name = eventName; - this.listeners = []; - }; - - eventEntry.prototype = - { - // Get the listener index for a specified function. - // Returns -1 if not found. - getListenerIndex : function( listenerFunction ) - { - for ( var i = 0, listeners = this.listeners ; i < listeners.length ; i++ ) - { - if ( listeners[i].fn == listenerFunction ) - return i; - } - return -1; - } - }; - - return /** @lends CKEDITOR.event.prototype */ { - /** - * Registers a listener to a specific event in the current object. - * @param {String} eventName The event name to which listen. - * @param {Function} listenerFunction The function listening to the - * event. A single {@link CKEDITOR.eventInfo} object instanced - * is passed to this function containing all the event data. - * @param {Object} [scopeObj] The object used to scope the listener - * call (the this object. If omitted, the current object is used. - * @param {Object} [listenerData] Data to be sent as the - * {@link CKEDITOR.eventInfo#listenerData} when calling the - * listener. - * @param {Number} [priority] The listener priority. Lower priority - * listeners are called first. Listeners with the same priority - * value are called in registration order. Defaults to 10. - * @example - * someObject.on( 'someEvent', function() - * { - * alert( this == someObject ); // "true" - * }); - * @example - * someObject.on( 'someEvent', function() - * { - * alert( this == anotherObject ); // "true" - * } - * , anotherObject ); - * @example - * someObject.on( 'someEvent', function( event ) - * { - * alert( event.listenerData ); // "Example" - * } - * , null, 'Example' ); - * @example - * someObject.on( 'someEvent', function() { ... } ); // 2nd called - * someObject.on( 'someEvent', function() { ... }, null, null, 100 ); // 3rd called - * someObject.on( 'someEvent', function() { ... }, null, null, 1 ); // 1st called - */ - on : function( eventName, listenerFunction, scopeObj, listenerData, priority ) - { - // Get the event entry (create it if needed). - var events = getPrivate( this ), - event = events[ eventName ] || ( events[ eventName ] = new eventEntry( eventName ) ); - - if ( event.getListenerIndex( listenerFunction ) < 0 ) - { - // Get the listeners. - var listeners = event.listeners; - - // Fill the scope. - if ( !scopeObj ) - scopeObj = this; - - // Default the priority, if needed. - if ( isNaN( priority ) ) - priority = 10; - - var me = this; - - // Create the function to be fired for this listener. - var listenerFirer = function( editor, publisherData, stopFn, cancelFn ) - { - var ev = - { - name : eventName, - sender : this, - editor : editor, - data : publisherData, - listenerData : listenerData, - stop : stopFn, - cancel : cancelFn, - removeListener : function() - { - me.removeListener( eventName, listenerFunction ); - } - }; - - listenerFunction.call( scopeObj, ev ); - - return ev.data; - }; - listenerFirer.fn = listenerFunction; - listenerFirer.priority = priority; - - // Search for the right position for this new listener, based on its - // priority. - for ( var i = listeners.length - 1 ; i >= 0 ; i-- ) - { - // Find the item which should be before the new one. - if ( listeners[ i ].priority <= priority ) - { - // Insert the listener in the array. - listeners.splice( i + 1, 0, listenerFirer ); - return; - } - } - - // If no position has been found (or zero length), put it in - // the front of list. - listeners.unshift( listenerFirer ); - } - }, - - /** - * Fires an specific event in the object. All registered listeners are - * called at this point. - * @function - * @param {String} eventName The event name to fire. - * @param {Object} [data] Data to be sent as the - * {@link CKEDITOR.eventInfo#data} when calling the - * listeners. - * @param {CKEDITOR.editor} [editor] The editor instance to send as the - * {@link CKEDITOR.eventInfo#editor} when calling the - * listener. - * @returns {Boolean|Object} A booloan indicating that the event is to be - * canceled, or data returned by one of the listeners. - * @example - * someObject.on( 'someEvent', function() { ... } ); - * someObject.on( 'someEvent', function() { ... } ); - * someObject.fire( 'someEvent' ); // both listeners are called - * @example - * someObject.on( 'someEvent', function( event ) - * { - * alert( event.data ); // "Example" - * }); - * someObject.fire( 'someEvent', 'Example' ); - */ - fire : (function() - { - // Create the function that marks the event as stopped. - var stopped = false; - var stopEvent = function() - { - stopped = true; - }; - - // Create the function that marks the event as canceled. - var canceled = false; - var cancelEvent = function() - { - canceled = true; - }; - - return function( eventName, data, editor ) - { - // Get the event entry. - var event = getPrivate( this )[ eventName ]; - - // Save the previous stopped and cancelled states. We may - // be nesting fire() calls. - var previousStopped = stopped, - previousCancelled = canceled; - - // Reset the stopped and canceled flags. - stopped = canceled = false; - - if ( event ) - { - var listeners = event.listeners; - - if ( listeners.length ) - { - // As some listeners may remove themselves from the - // event, the original array length is dinamic. So, - // let's make a copy of all listeners, so we are - // sure we'll call all of them. - listeners = listeners.slice( 0 ); - - // Loop through all listeners. - for ( var i = 0 ; i < listeners.length ; i++ ) - { - // Call the listener, passing the event data. - var retData = listeners[i].call( this, editor, data, stopEvent, cancelEvent ); - - if ( typeof retData != 'undefined' ) - data = retData; - - // No further calls is stopped or canceled. - if ( stopped || canceled ) - break; - } - } - } - - var ret = canceled || ( typeof data == 'undefined' ? false : data ); - - // Restore the previous stopped and canceled states. - stopped = previousStopped; - canceled = previousCancelled; - - return ret; - }; - })(), - - /** - * Fires an specific event in the object, releasing all listeners - * registered to that event. The same listeners are not called again on - * successive calls of it or of {@link #fire}. - * @param {String} eventName The event name to fire. - * @param {Object} [data] Data to be sent as the - * {@link CKEDITOR.eventInfo#data} when calling the - * listeners. - * @param {CKEDITOR.editor} [editor] The editor instance to send as the - * {@link CKEDITOR.eventInfo#editor} when calling the - * listener. - * @returns {Boolean|Object} A booloan indicating that the event is to be - * canceled, or data returned by one of the listeners. - * @example - * someObject.on( 'someEvent', function() { ... } ); - * someObject.fire( 'someEvent' ); // above listener called - * someObject.fireOnce( 'someEvent' ); // above listener called - * someObject.fire( 'someEvent' ); // no listeners called - */ - fireOnce : function( eventName, data, editor ) - { - var ret = this.fire( eventName, data, editor ); - delete getPrivate( this )[ eventName ]; - return ret; - }, - - /** - * Unregisters a listener function from being called at the specified - * event. No errors are thrown if the listener has not been - * registered previously. - * @param {String} eventName The event name. - * @param {Function} listenerFunction The listener function to unregister. - * @example - * var myListener = function() { ... }; - * someObject.on( 'someEvent', myListener ); - * someObject.fire( 'someEvent' ); // myListener called - * someObject.removeListener( 'someEvent', myListener ); - * someObject.fire( 'someEvent' ); // myListener not called - */ - removeListener : function( eventName, listenerFunction ) - { - // Get the event entry. - var event = getPrivate( this )[ eventName ]; - - if ( event ) - { - var index = event.getListenerIndex( listenerFunction ); - if ( index >= 0 ) - event.listeners.splice( index, 1 ); - } - }, - - /** - * Checks if there is any listener registered to a given event. - * @param {String} eventName The event name. - * @example - * var myListener = function() { ... }; - * someObject.on( 'someEvent', myListener ); - * alert( someObject.hasListeners( 'someEvent' ) ); // "true" - * alert( someObject.hasListeners( 'noEvent' ) ); // "false" - */ - hasListeners : function( eventName ) - { - var event = getPrivate( this )[ eventName ]; - return ( event && event.listeners.length > 0 ) ; - } - }; - })(); -} diff --git a/media/ckeditor/_source/core/eventInfo.js b/media/ckeditor/_source/core/eventInfo.js deleted file mode 100644 index fcb79f2..0000000 --- a/media/ckeditor/_source/core/eventInfo.js +++ /dev/null @@ -1,120 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @fileOverview Defines the "virtual" {@link CKEDITOR.eventInfo} class, which - * contains the defintions of the event object passed to event listeners. - * This file is for documentation purposes only. - */ - -/** - * (Virtual Class) Do not call this constructor. This class is not really part - * of the API. - * @class Virtual class that illustrates the features of the event object to be - * passed to event listeners by a {@link CKEDITOR.event} based object. - * @name CKEDITOR.eventInfo - * @example - * // Do not do this. - * var myEvent = new CKEDITOR.eventInfo(); // Error: CKEDITOR.eventInfo is undefined - */ - -/** - * The event name. - * @name CKEDITOR.eventInfo.prototype.name - * @field - * @type String - * @example - * someObject.on( 'someEvent', function( event ) - * { - * alert( event.name ); // "someEvent" - * }); - * someObject.fire( 'someEvent' ); - */ - -/** - * The object that publishes (sends) the event. - * @name CKEDITOR.eventInfo.prototype.sender - * @field - * @type Object - * @example - * someObject.on( 'someEvent', function( event ) - * { - * alert( event.sender == someObject ); // "true" - * }); - * someObject.fire( 'someEvent' ); - */ - -/** - * The editor instance that holds the sender. May be the same as sender. May be - * null if the sender is not part of an editor instance, like a component - * running in standalone mode. - * @name CKEDITOR.eventInfo.prototype.editor - * @field - * @type CKEDITOR.editor - * @example - * myButton.on( 'someEvent', function( event ) - * { - * alert( event.editor == myEditor ); // "true" - * }); - * myButton.fire( 'someEvent', null, myEditor ); - */ - -/** - * Any kind of additional data. Its format and usage is event dependent. - * @name CKEDITOR.eventInfo.prototype.data - * @field - * @type Object - * @example - * someObject.on( 'someEvent', function( event ) - * { - * alert( event.data ); // "Example" - * }); - * someObject.fire( 'someEvent', 'Example' ); - */ - -/** - * Any extra data appended during the listener registration. - * @name CKEDITOR.eventInfo.prototype.listenerData - * @field - * @type Object - * @example - * someObject.on( 'someEvent', function( event ) - * { - * alert( event.listenerData ); // "Example" - * } - * , null, 'Example' ); - */ - -/** - * Indicates that no further listeners are to be called. - * @name CKEDITOR.eventInfo.prototype.stop - * @function - * @example - * someObject.on( 'someEvent', function( event ) - * { - * event.stop(); - * }); - * someObject.on( 'someEvent', function( event ) - * { - * // This one will not be called. - * }); - * alert( someObject.fire( 'someEvent' ) ); // "false" - */ - -/** - * Indicates that the event is to be cancelled (if cancelable). - * @name CKEDITOR.eventInfo.prototype.cancel - * @function - * @example - * someObject.on( 'someEvent', function( event ) - * { - * event.cancel(); - * }); - * someObject.on( 'someEvent', function( event ) - * { - * // This one will not be called. - * }); - * alert( someObject.fire( 'someEvent' ) ); // "true" - */ diff --git a/media/ckeditor/_source/core/focusmanager.js b/media/ckeditor/_source/core/focusmanager.js deleted file mode 100644 index 6963fb0..0000000 --- a/media/ckeditor/_source/core/focusmanager.js +++ /dev/null @@ -1,152 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @fileOverview Defines the {@link CKEDITOR.focusManager} class, which is used - * to handle the focus on editor instances.. - */ - -/** - * Creates a focusManager class instance. - * @class Manages the focus activity in an editor instance. This class is to be - * used mainly by UI elements coders when adding interface elements that need - * to set the focus state of the editor. - * @param {CKEDITOR.editor} editor The editor instance. - * @example - * var focusManager = new CKEDITOR.focusManager( editor ); - * focusManager.focus(); - */ -CKEDITOR.focusManager = function( editor ) -{ - if ( editor.focusManager ) - return editor.focusManager; - - /** - * Indicates that the editor instance has focus. - * @type Boolean - * @example - * alert( CKEDITOR.instances.editor1.focusManager.hasFocus ); // e.g "true" - */ - this.hasFocus = false; - - /** - * Object used to hold private stuff. - * @private - */ - this._ = - { - editor : editor - }; - - return this; -}; - -CKEDITOR.focusManager.prototype = -{ - /** - * Used to indicate that the editor instance has the focus.
      - *
      - * Note that this function will not explicitelly set the focus in the - * editor (for example, making the caret blinking on it). Use - * {@link CKEDITOR.editor#focus} for it instead. - * @example - * var editor = CKEDITOR.instances.editor1; - * editor.focusManager.focus(); - */ - focus : function() - { - if ( this._.timer ) - clearTimeout( this._.timer ); - - if ( !this.hasFocus ) - { - // If another editor has the current focus, we first "blur" it. In - // this way the events happen in a more logical sequence, like: - // "focus 1" > "blur 1" > "focus 2" - // ... instead of: - // "focus 1" > "focus 2" > "blur 1" - if ( CKEDITOR.currentInstance ) - CKEDITOR.currentInstance.focusManager.forceBlur(); - - var editor = this._.editor; - - editor.container.getChild( 1 ).addClass( 'cke_focus' ); - - this.hasFocus = true; - editor.fire( 'focus' ); - } - }, - - /** - * Used to indicate that the editor instance has lost the focus.
      - *
      - * Note that this functions acts asynchronously with a delay of 100ms to - * avoid subsequent blur/focus effects. If you want the "blur" to happen - * immediately, use the {@link #forceBlur} function instead. - * @example - * var editor = CKEDITOR.instances.editor1; - * editor.focusManager.blur(); - */ - blur : function() - { - var focusManager = this; - - if ( focusManager._.timer ) - clearTimeout( focusManager._.timer ); - - focusManager._.timer = setTimeout( - function() - { - delete focusManager._.timer; - focusManager.forceBlur(); - } - , 100 ); - }, - - /** - * Used to indicate that the editor instance has lost the focus. Unlike - * {@link #blur}, this function is synchronous, marking the instance as - * "blured" immediately. - * @example - * var editor = CKEDITOR.instances.editor1; - * editor.focusManager.forceBlur(); - */ - forceBlur : function() - { - if ( this.hasFocus ) - { - var editor = this._.editor; - - editor.container.getChild( 1 ).removeClass( 'cke_focus' ); - - this.hasFocus = false; - editor.fire( 'blur' ); - } - } -}; - -/** - * Fired when the editor instance receives the input focus. - * @name CKEDITOR.editor#focus - * @event - * @param {CKEDITOR.editor} editor The editor instance. - * @example - * editor.on( 'focus', function( e ) - * { - * alert( 'The editor named ' + e.editor.name + ' is now focused' ); - * }); - */ - -/** - * Fired when the editor instance loses the input focus. - * @name CKEDITOR.editor#blur - * @event - * @param {CKEDITOR.editor} editor The editor instance. - * @example - * editor.on( 'blur', function( e ) - * { - * alert( 'The editor named ' + e.editor.name + ' lost the focus' ); - * }); - */ diff --git a/media/ckeditor/_source/core/htmlparser.js b/media/ckeditor/_source/core/htmlparser.js deleted file mode 100644 index 253e299..0000000 --- a/media/ckeditor/_source/core/htmlparser.js +++ /dev/null @@ -1,224 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * Creates a {@link CKEDITOR.htmlParser} class instance. - * @class Provides an "event like" system to parse strings of HTML data. - * @example - * var parser = new CKEDITOR.htmlParser(); - * parser.onTagOpen = function( tagName, attributes, selfClosing ) - * { - * alert( tagName ); - * }; - * parser.parse( '<p>Some <b>text</b>.</p>' ); - */ -CKEDITOR.htmlParser = function() -{ - this._ = - { - htmlPartsRegex : new RegExp( '<(?:(?:\\/([^>]+)>)|(?:!--([\\S|\\s]*?)-->)|(?:([^\\s>]+)\\s*((?:(?:"[^"]*")|(?:\'[^\']*\')|[^"\'>])*)\\/?>))', 'g' ) - }; -}; - -(function() -{ - var attribsRegex = /([\w\-:.]+)(?:(?:\s*=\s*(?:(?:"([^"]*)")|(?:'([^']*)')|([^\s>]+)))|(?=\s|$))/g, - emptyAttribs = {checked:1,compact:1,declare:1,defer:1,disabled:1,ismap:1,multiple:1,nohref:1,noresize:1,noshade:1,nowrap:1,readonly:1,selected:1}; - - CKEDITOR.htmlParser.prototype = - { - /** - * Function to be fired when a tag opener is found. This function - * should be overriden when using this class. - * @param {String} tagName The tag name. The name is guarantted to be - * lowercased. - * @param {Object} attributes An object containing all tag attributes. Each - * property in this object represent and attribute name and its - * value is the attribute value. - * @param {Boolean} selfClosing true if the tag closes itself, false if the - * tag doesn't. - * @example - * var parser = new CKEDITOR.htmlParser(); - * parser.onTagOpen = function( tagName, attributes, selfClosing ) - * { - * alert( tagName ); // e.g. "b" - * }); - * parser.parse( "<!-- Example --><b>Hello</b>" ); - */ - onTagOpen : function() {}, - - /** - * Function to be fired when a tag closer is found. This function - * should be overriden when using this class. - * @param {String} tagName The tag name. The name is guarantted to be - * lowercased. - * @example - * var parser = new CKEDITOR.htmlParser(); - * parser.onTagClose = function( tagName ) - * { - * alert( tagName ); // e.g. "b" - * }); - * parser.parse( "<!-- Example --><b>Hello</b>" ); - */ - onTagClose : function() {}, - - /** - * Function to be fired when text is found. This function - * should be overriden when using this class. - * @param {String} text The text found. - * @example - * var parser = new CKEDITOR.htmlParser(); - * parser.onText = function( text ) - * { - * alert( text ); // e.g. "Hello" - * }); - * parser.parse( "<!-- Example --><b>Hello</b>" ); - */ - onText : function() {}, - - /** - * Function to be fired when CDATA section is found. This function - * should be overriden when using this class. - * @param {String} cdata The CDATA been found. - * @example - * var parser = new CKEDITOR.htmlParser(); - * parser.onCDATA = function( cdata ) - * { - * alert( cdata ); // e.g. "var hello;" - * }); - * parser.parse( "<script>var hello;</script>" ); - */ - onCDATA : function() {}, - - /** - * Function to be fired when a commend is found. This function - * should be overriden when using this class. - * @param {String} comment The comment text. - * @example - * var parser = new CKEDITOR.htmlParser(); - * parser.onComment = function( comment ) - * { - * alert( comment ); // e.g. " Example " - * }); - * parser.parse( "<!-- Example --><b>Hello</b>" ); - */ - onComment : function() {}, - - /** - * Parses text, looking for HTML tokens, like tag openers or closers, - * or comments. This function fires the onTagOpen, onTagClose, onText - * and onComment function during its execution. - * @param {String} html The HTML to be parsed. - * @example - * var parser = new CKEDITOR.htmlParser(); - * // The onTagOpen, onTagClose, onText and onComment should be overriden - * // at this point. - * parser.parse( "<!-- Example --><b>Hello</b>" ); - */ - parse : function( html ) - { - var parts, - tagName, - nextIndex = 0, - cdata; // The collected data inside a CDATA section. - - while ( ( parts = this._.htmlPartsRegex.exec( html ) ) ) - { - var tagIndex = parts.index; - if ( tagIndex > nextIndex ) - { - var text = html.substring( nextIndex, tagIndex ); - - if ( cdata ) - cdata.push( text ); - else - this.onText( text ); - } - - nextIndex = this._.htmlPartsRegex.lastIndex; - - /* - "parts" is an array with the following items: - 0 : The entire match for opening/closing tags and comments. - 1 : Group filled with the tag name for closing tags. - 2 : Group filled with the comment text. - 3 : Group filled with the tag name for opening tags. - 4 : Group filled with the attributes part of opening tags. - */ - - // Closing tag - if ( ( tagName = parts[ 1 ] ) ) - { - tagName = tagName.toLowerCase(); - - if ( cdata && CKEDITOR.dtd.$cdata[ tagName ] ) - { - // Send the CDATA data. - this.onCDATA( cdata.join('') ); - cdata = null; - } - - if ( !cdata ) - { - this.onTagClose( tagName ); - continue; - } - } - - // If CDATA is enabled, just save the raw match. - if ( cdata ) - { - cdata.push( parts[ 0 ] ); - continue; - } - - // Opening tag - if ( ( tagName = parts[ 3 ] ) ) - { - tagName = tagName.toLowerCase(); - - // There are some tag names that can break things, so let's - // simply ignore them when parsing. (#5224) - if ( /="/.test( tagName ) ) - continue; - - var attribs = {}, - attribMatch, - attribsPart = parts[ 4 ], - selfClosing = !!( attribsPart && attribsPart.charAt( attribsPart.length - 1 ) == '/' ); - - if ( attribsPart ) - { - while ( ( attribMatch = attribsRegex.exec( attribsPart ) ) ) - { - var attName = attribMatch[1].toLowerCase(), - attValue = attribMatch[2] || attribMatch[3] || attribMatch[4] || ''; - - if ( !attValue && emptyAttribs[ attName ] ) - attribs[ attName ] = attName; - else - attribs[ attName ] = attValue; - } - } - - this.onTagOpen( tagName, attribs, selfClosing ); - - // Open CDATA mode when finding the appropriate tags. - if ( !cdata && CKEDITOR.dtd.$cdata[ tagName ] ) - cdata = []; - - continue; - } - - // Comment - if ( ( tagName = parts[ 2 ] ) ) - this.onComment( tagName ); - } - - if ( html.length > nextIndex ) - this.onText( html.substring( nextIndex, html.length ) ); - } - }; -})(); diff --git a/media/ckeditor/_source/core/htmlparser/basicwriter.js b/media/ckeditor/_source/core/htmlparser/basicwriter.js deleted file mode 100644 index 5296bf0..0000000 --- a/media/ckeditor/_source/core/htmlparser/basicwriter.js +++ /dev/null @@ -1,145 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -CKEDITOR.htmlParser.basicWriter = CKEDITOR.tools.createClass( -{ - $ : function() - { - this._ = - { - output : [] - }; - }, - - proto : - { - /** - * Writes the tag opening part for a opener tag. - * @param {String} tagName The element name for this tag. - * @param {Object} attributes The attributes defined for this tag. The - * attributes could be used to inspect the tag. - * @example - * // Writes "<p". - * writer.openTag( 'p', { class : 'MyClass', id : 'MyId' } ); - */ - openTag : function( tagName, attributes ) - { - this._.output.push( '<', tagName ); - }, - - /** - * Writes the tag closing part for a opener tag. - * @param {String} tagName The element name for this tag. - * @param {Boolean} isSelfClose Indicates that this is a self-closing tag, - * like "br" or "img". - * @example - * // Writes ">". - * writer.openTagClose( 'p', false ); - * @example - * // Writes " />". - * writer.openTagClose( 'br', true ); - */ - openTagClose : function( tagName, isSelfClose ) - { - if ( isSelfClose ) - this._.output.push( ' />' ); - else - this._.output.push( '>' ); - }, - - /** - * Writes an attribute. This function should be called after opening the - * tag with {@link #openTagClose}. - * @param {String} attName The attribute name. - * @param {String} attValue The attribute value. - * @example - * // Writes ' class="MyClass"'. - * writer.attribute( 'class', 'MyClass' ); - */ - attribute : function( attName, attValue ) - { - // Browsers don't always escape special character in attribute values. (#4683, #4719). - if ( typeof attValue == 'string' ) - attValue = CKEDITOR.tools.htmlEncodeAttr( attValue ); - - this._.output.push( ' ', attName, '="', attValue, '"' ); - }, - - /** - * Writes a closer tag. - * @param {String} tagName The element name for this tag. - * @example - * // Writes "</p>". - * writer.closeTag( 'p' ); - */ - closeTag : function( tagName ) - { - this._.output.push( '' ); - }, - - /** - * Writes text. - * @param {String} text The text value - * @example - * // Writes "Hello Word". - * writer.text( 'Hello Word' ); - */ - text : function( text ) - { - this._.output.push( text ); - }, - - /** - * Writes a comment. - * @param {String} comment The comment text. - * @example - * // Writes "<!-- My comment -->". - * writer.comment( ' My comment ' ); - */ - comment : function( comment ) - { - this._.output.push( '' ); - }, - - /** - * Writes any kind of data to the ouput. - * @example - * writer.write( 'This is an <b>example</b>.' ); - */ - write : function( data ) - { - this._.output.push( data ); - }, - - /** - * Empties the current output buffer. - * @example - * writer.reset(); - */ - reset : function() - { - this._.output = []; - this._.indent = false; - }, - - /** - * Empties the current output buffer. - * @param {Boolean} reset Indicates that the {@link reset} function is to - * be automatically called after retrieving the HTML. - * @returns {String} The HTML written to the writer so far. - * @example - * var html = writer.getHtml(); - */ - getHtml : function( reset ) - { - var html = this._.output.join( '' ); - - if ( reset ) - this.reset(); - - return html; - } - } -}); diff --git a/media/ckeditor/_source/core/htmlparser/cdata.js b/media/ckeditor/_source/core/htmlparser/cdata.js deleted file mode 100644 index dd685de..0000000 --- a/media/ckeditor/_source/core/htmlparser/cdata.js +++ /dev/null @@ -1,43 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -(function() -{ - - /** - * A lightweight representation of HTML text. - * @constructor - * @example - */ - CKEDITOR.htmlParser.cdata = function( value ) - { - /** - * The CDATA value. - * @type String - * @example - */ - this.value = value; - }; - - CKEDITOR.htmlParser.cdata.prototype = - { - /** - * CDATA has the same type as {@link CKEDITOR.htmlParser.text} This is - * a constant value set to {@link CKEDITOR.NODE_TEXT}. - * @type Number - * @example - */ - type : CKEDITOR.NODE_TEXT, - - /** - * Writes write the CDATA with no special manipulations. - * @param {CKEDITOR.htmlWriter} writer The writer to which write the HTML. - */ - writeHtml : function( writer ) - { - writer.write( this.value ); - } - }; -})(); diff --git a/media/ckeditor/_source/core/htmlparser/comment.js b/media/ckeditor/_source/core/htmlparser/comment.js deleted file mode 100644 index 4f365ff..0000000 --- a/media/ckeditor/_source/core/htmlparser/comment.js +++ /dev/null @@ -1,60 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * A lightweight representation of an HTML comment. - * @constructor - * @example - */ -CKEDITOR.htmlParser.comment = function( value ) -{ - /** - * The comment text. - * @type String - * @example - */ - this.value = value; - - /** @private */ - this._ = - { - isBlockLike : false - }; -}; - -CKEDITOR.htmlParser.comment.prototype = -{ - /** - * The node type. This is a constant value set to {@link CKEDITOR.NODE_COMMENT}. - * @type Number - * @example - */ - type : CKEDITOR.NODE_COMMENT, - - /** - * Writes the HTML representation of this comment to a CKEDITOR.htmlWriter. - * @param {CKEDITOR.htmlWriter} writer The writer to which write the HTML. - * @example - */ - writeHtml : function( writer, filter ) - { - var comment = this.value; - - if ( filter ) - { - if ( !( comment = filter.onComment( comment, this ) ) ) - return; - - if ( typeof comment != 'string' ) - { - comment.parent = this.parent; - comment.writeHtml( writer, filter ); - return; - } - } - - writer.comment( comment ); - } -}; diff --git a/media/ckeditor/_source/core/htmlparser/element.js b/media/ckeditor/_source/core/htmlparser/element.js deleted file mode 100644 index 9e22418..0000000 --- a/media/ckeditor/_source/core/htmlparser/element.js +++ /dev/null @@ -1,308 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * A lightweight representation of an HTML element. - * @param {String} name The element name. - * @param {Object} attributes And object holding all attributes defined for - * this element. - * @constructor - * @example - */ -CKEDITOR.htmlParser.element = function( name, attributes ) -{ - /** - * The element name. - * @type String - * @example - */ - this.name = name; - - /** - * Holds the attributes defined for this element. - * @type Object - * @example - */ - this.attributes = attributes || ( attributes = {} ); - - /** - * The nodes that are direct children of this element. - * @type Array - * @example - */ - this.children = []; - - var tagName = attributes[ 'data-cke-real-element-type' ] || name || ''; - - // Reveal the real semantic of our internal custom tag name (#6639). - var internalTag = tagName.match( /^cke:(.*)/ ); - internalTag && ( tagName = internalTag[ 1 ] ); - - var dtd = CKEDITOR.dtd, - isBlockLike = !!( dtd.$nonBodyContent[ tagName ] - || dtd.$block[ tagName ] - || dtd.$listItem[ tagName ] - || dtd.$tableContent[ tagName ] - || dtd.$nonEditable[ tagName ] - || tagName == 'br' ), - isEmpty = !!dtd.$empty[ name ]; - - this.isEmpty = isEmpty; - this.isUnknown = !dtd[ name ]; - - /** @private */ - this._ = - { - isBlockLike : isBlockLike, - hasInlineStarted : isEmpty || !isBlockLike - }; -}; - -/** - * Object presentation of CSS style declaration text. - * @param {CKEDITOR.htmlParser.element|String} elementOrStyleText A html parser element or the inline style text. - */ -CKEDITOR.htmlParser.cssStyle = function() -{ - var styleText, - arg = arguments[ 0 ], - rules = {}; - - styleText = arg instanceof CKEDITOR.htmlParser.element ? arg.attributes.style : arg; - - // html-encoded quote might be introduced by 'font-family' - // from MS-Word which confused the following regexp. e.g. - //'font-family: "Lucida, Console"' - ( styleText || '' ) - .replace( /"/g, '"' ) - .replace( /\s*([^ :;]+)\s*:\s*([^;]+)\s*(?=;|$)/g, - function( match, name, value ) - { - name == 'font-family' && ( value = value.replace( /["']/g, '' ) ); - rules[ name.toLowerCase() ] = value; - }); - - return { - - rules : rules, - - /** - * Apply the styles onto the specified element or object. - * @param {CKEDITOR.htmlParser.element|CKEDITOR.dom.element|Object} obj - */ - populate : function( obj ) - { - var style = this.toString(); - if ( style ) - { - obj instanceof CKEDITOR.dom.element ? - obj.setAttribute( 'style', style ) : - obj instanceof CKEDITOR.htmlParser.element ? - obj.attributes.style = style : - obj.style = style; - } - }, - - toString : function() - { - var output = []; - for ( var i in rules ) - rules[ i ] && output.push( i, ':', rules[ i ], ';' ); - return output.join( '' ); - } - }; -}; - -(function() -{ - // Used to sort attribute entries in an array, where the first element of - // each object is the attribute name. - var sortAttribs = function( a, b ) - { - a = a[0]; - b = b[0]; - return a < b ? -1 : a > b ? 1 : 0; - }; - - CKEDITOR.htmlParser.element.prototype = - { - /** - * The node type. This is a constant value set to {@link CKEDITOR.NODE_ELEMENT}. - * @type Number - * @example - */ - type : CKEDITOR.NODE_ELEMENT, - - /** - * Adds a node to the element children list. - * @param {Object} node The node to be added. It can be any of of the - * following types: {@link CKEDITOR.htmlParser.element}, - * {@link CKEDITOR.htmlParser.text} and - * {@link CKEDITOR.htmlParser.comment}. - * @function - * @example - */ - add : CKEDITOR.htmlParser.fragment.prototype.add, - - /** - * Clone this element. - * @returns {CKEDITOR.htmlParser.element} The element clone. - * @example - */ - clone : function() - { - return new CKEDITOR.htmlParser.element( this.name, this.attributes ); - }, - - /** - * Writes the element HTML to a CKEDITOR.htmlWriter. - * @param {CKEDITOR.htmlWriter} writer The writer to which write the HTML. - * @example - */ - writeHtml : function( writer, filter ) - { - var attributes = this.attributes; - - // Ignore cke: prefixes when writing HTML. - var element = this, - writeName = element.name, - a, newAttrName, value; - - var isChildrenFiltered; - - /** - * Providing an option for bottom-up filtering order ( element - * children to be pre-filtered before the element itself ). - */ - element.filterChildren = function() - { - if ( !isChildrenFiltered ) - { - var writer = new CKEDITOR.htmlParser.basicWriter(); - CKEDITOR.htmlParser.fragment.prototype.writeChildrenHtml.call( element, writer, filter ); - element.children = new CKEDITOR.htmlParser.fragment.fromHtml( writer.getHtml(), 0, element.clone() ).children; - isChildrenFiltered = 1; - } - }; - - if ( filter ) - { - while ( true ) - { - if ( !( writeName = filter.onElementName( writeName ) ) ) - return; - - element.name = writeName; - - if ( !( element = filter.onElement( element ) ) ) - return; - - element.parent = this.parent; - - if ( element.name == writeName ) - break; - - // If the element has been replaced with something of a - // different type, then make the replacement write itself. - if ( element.type != CKEDITOR.NODE_ELEMENT ) - { - element.writeHtml( writer, filter ); - return; - } - - writeName = element.name; - - // This indicate that the element has been dropped by - // filter but not the children. - if ( !writeName ) - { - // Fix broken parent refs. - for ( var c = 0, length = this.children.length ; c < length ; c++ ) - this.children[ c ].parent = element.parent; - - this.writeChildrenHtml.call( element, writer, isChildrenFiltered ? null : filter ); - return; - } - } - - // The element may have been changed, so update the local - // references. - attributes = element.attributes; - } - - // Open element tag. - writer.openTag( writeName, attributes ); - - // Copy all attributes to an array. - var attribsArray = []; - // Iterate over the attributes twice since filters may alter - // other attributes. - for ( var i = 0 ; i < 2; i++ ) - { - for ( a in attributes ) - { - newAttrName = a; - value = attributes[ a ]; - if ( i == 1 ) - attribsArray.push( [ a, value ] ); - else if ( filter ) - { - while ( true ) - { - if ( !( newAttrName = filter.onAttributeName( a ) ) ) - { - delete attributes[ a ]; - break; - } - else if ( newAttrName != a ) - { - delete attributes[ a ]; - a = newAttrName; - continue; - } - else - break; - } - if ( newAttrName ) - { - if ( ( value = filter.onAttribute( element, newAttrName, value ) ) === false ) - delete attributes[ newAttrName ]; - else - attributes [ newAttrName ] = value; - } - } - } - } - // Sort the attributes by name. - if ( writer.sortAttributes ) - attribsArray.sort( sortAttribs ); - - // Send the attributes. - var len = attribsArray.length; - for ( i = 0 ; i < len ; i++ ) - { - var attrib = attribsArray[ i ]; - writer.attribute( attrib[0], attrib[1] ); - } - - // Close the tag. - writer.openTagClose( writeName, element.isEmpty ); - - if ( !element.isEmpty ) - { - this.writeChildrenHtml.call( element, writer, isChildrenFiltered ? null : filter ); - // Close the element. - writer.closeTag( writeName ); - } - }, - - writeChildrenHtml : function( writer, filter ) - { - // Send children. - CKEDITOR.htmlParser.fragment.prototype.writeChildrenHtml.apply( this, arguments ); - - } - }; -})(); diff --git a/media/ckeditor/_source/core/htmlparser/filter.js b/media/ckeditor/_source/core/htmlparser/filter.js deleted file mode 100644 index ded9280..0000000 --- a/media/ckeditor/_source/core/htmlparser/filter.js +++ /dev/null @@ -1,288 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -(function() -{ - CKEDITOR.htmlParser.filter = CKEDITOR.tools.createClass( - { - $ : function( rules ) - { - this._ = - { - elementNames : [], - attributeNames : [], - elements : { $length : 0 }, - attributes : { $length : 0 } - }; - - if ( rules ) - this.addRules( rules, 10 ); - }, - - proto : - { - addRules : function( rules, priority ) - { - if ( typeof priority != 'number' ) - priority = 10; - - // Add the elementNames. - addItemsToList( this._.elementNames, rules.elementNames, priority ); - - // Add the attributeNames. - addItemsToList( this._.attributeNames, rules.attributeNames, priority ); - - // Add the elements. - addNamedItems( this._.elements, rules.elements, priority ); - - // Add the attributes. - addNamedItems( this._.attributes, rules.attributes, priority ); - - // Add the text. - this._.text = transformNamedItem( this._.text, rules.text, priority ) || this._.text; - - // Add the comment. - this._.comment = transformNamedItem( this._.comment, rules.comment, priority ) || this._.comment; - - // Add root fragment. - this._.root = transformNamedItem( this._.root, rules.root, priority ) || this._.root; - }, - - onElementName : function( name ) - { - return filterName( name, this._.elementNames ); - }, - - onAttributeName : function( name ) - { - return filterName( name, this._.attributeNames ); - }, - - onText : function( text ) - { - var textFilter = this._.text; - return textFilter ? textFilter.filter( text ) : text; - }, - - onComment : function( commentText, comment ) - { - var textFilter = this._.comment; - return textFilter ? textFilter.filter( commentText, comment ) : commentText; - }, - - onFragment : function( element ) - { - var rootFilter = this._.root; - return rootFilter ? rootFilter.filter( element ) : element; - }, - - onElement : function( element ) - { - // We must apply filters set to the specific element name as - // well as those set to the generic $ name. So, add both to an - // array and process them in a small loop. - var filters = [ this._.elements[ '^' ], this._.elements[ element.name ], this._.elements.$ ], - filter, ret; - - for ( var i = 0 ; i < 3 ; i++ ) - { - filter = filters[ i ]; - if ( filter ) - { - ret = filter.filter( element, this ); - - if ( ret === false ) - return null; - - if ( ret && ret != element ) - return this.onNode( ret ); - - // The non-root element has been dismissed by one of the filters. - if ( element.parent && !element.name ) - break; - } - } - - return element; - }, - - onNode : function( node ) - { - var type = node.type; - - return type == CKEDITOR.NODE_ELEMENT ? this.onElement( node ) : - type == CKEDITOR.NODE_TEXT ? new CKEDITOR.htmlParser.text( this.onText( node.value ) ) : - type == CKEDITOR.NODE_COMMENT ? new CKEDITOR.htmlParser.comment( this.onComment( node.value ) ): - null; - }, - - onAttribute : function( element, name, value ) - { - var filter = this._.attributes[ name ]; - - if ( filter ) - { - var ret = filter.filter( value, element, this ); - - if ( ret === false ) - return false; - - if ( typeof ret != 'undefined' ) - return ret; - } - - return value; - } - } - }); - - function filterName( name, filters ) - { - for ( var i = 0 ; name && i < filters.length ; i++ ) - { - var filter = filters[ i ]; - name = name.replace( filter[ 0 ], filter[ 1 ] ); - } - return name; - } - - function addItemsToList( list, items, priority ) - { - if ( typeof items == 'function' ) - items = [ items ]; - - var i, j, - listLength = list.length, - itemsLength = items && items.length; - - if ( itemsLength ) - { - // Find the index to insert the items at. - for ( i = 0 ; i < listLength && list[ i ].pri < priority ; i++ ) - { /*jsl:pass*/ } - - // Add all new items to the list at the specific index. - for ( j = itemsLength - 1 ; j >= 0 ; j-- ) - { - var item = items[ j ]; - if ( item ) - { - item.pri = priority; - list.splice( i, 0, item ); - } - } - } - } - - function addNamedItems( hashTable, items, priority ) - { - if ( items ) - { - for ( var name in items ) - { - var current = hashTable[ name ]; - - hashTable[ name ] = - transformNamedItem( - current, - items[ name ], - priority ); - - if ( !current ) - hashTable.$length++; - } - } - } - - function transformNamedItem( current, item, priority ) - { - if ( item ) - { - item.pri = priority; - - if ( current ) - { - // If the current item is not an Array, transform it. - if ( !current.splice ) - { - if ( current.pri > priority ) - current = [ item, current ]; - else - current = [ current, item ]; - - current.filter = callItems; - } - else - addItemsToList( current, item, priority ); - - return current; - } - else - { - item.filter = item; - return item; - } - } - } - - // Invoke filters sequentially on the array, break the iteration - // when it doesn't make sense to continue anymore. - function callItems( currentEntry ) - { - var isNode = currentEntry.type - || currentEntry instanceof CKEDITOR.htmlParser.fragment; - - for ( var i = 0 ; i < this.length ; i++ ) - { - // Backup the node info before filtering. - if ( isNode ) - { - var orgType = currentEntry.type, - orgName = currentEntry.name; - } - - var item = this[ i ], - ret = item.apply( window, arguments ); - - if ( ret === false ) - return ret; - - // We're filtering node (element/fragment). - if ( isNode ) - { - // No further filtering if it's not anymore - // fitable for the subsequent filters. - if ( ret && ( ret.name != orgName - || ret.type != orgType ) ) - { - return ret; - } - } - // Filtering value (nodeName/textValue/attrValue). - else - { - // No further filtering if it's not - // any more values. - if ( typeof ret != 'string' ) - return ret; - } - - ret != undefined && ( currentEntry = ret ); - } - - return currentEntry; - } -})(); - -// "entities" plugin -/* -{ - text : function( text ) - { - // TODO : Process entities. - return text.toUpperCase(); - } -}; -*/ diff --git a/media/ckeditor/_source/core/htmlparser/fragment.js b/media/ckeditor/_source/core/htmlparser/fragment.js deleted file mode 100644 index 56ef1a3..0000000 --- a/media/ckeditor/_source/core/htmlparser/fragment.js +++ /dev/null @@ -1,537 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * A lightweight representation of an HTML DOM structure. - * @constructor - * @example - */ -CKEDITOR.htmlParser.fragment = function() -{ - /** - * The nodes contained in the root of this fragment. - * @type Array - * @example - * var fragment = CKEDITOR.htmlParser.fragment.fromHtml( 'Sample Text' ); - * alert( fragment.children.length ); "2" - */ - this.children = []; - - /** - * Get the fragment parent. Should always be null. - * @type Object - * @default null - * @example - */ - this.parent = null; - - /** @private */ - this._ = - { - isBlockLike : true, - hasInlineStarted : false - }; -}; - -(function() -{ - // Block-level elements whose internal structure should be respected during - // parser fixing. - var nonBreakingBlocks = CKEDITOR.tools.extend( { table:1,ul:1,ol:1,dl:1 }, CKEDITOR.dtd.table, CKEDITOR.dtd.ul, CKEDITOR.dtd.ol, CKEDITOR.dtd.dl ); - - // IE < 8 don't output the close tag on definition list items. (#6975) - var optionalCloseTags = CKEDITOR.env.ie && CKEDITOR.env.version < 8 ? { dd : 1, dt :1 } : {}; - - var listBlocks = { ol:1, ul:1 }; - - // Dtd of the fragment element, basically it accept anything except for intermediate structure, e.g. orphan
    1. . - var rootDtd = CKEDITOR.tools.extend( {}, { html: 1 }, CKEDITOR.dtd.html, CKEDITOR.dtd.body, CKEDITOR.dtd.head, { style:1,script:1 } ); - - function isRemoveEmpty( node ) - { - // Empty link is to be removed when empty but not anchor. (#7894) - return node.name == 'a' && node.attributes.href - || CKEDITOR.dtd.$removeEmpty[ node.name ]; - } - - /** - * Creates a {@link CKEDITOR.htmlParser.fragment} from an HTML string. - * @param {String} fragmentHtml The HTML to be parsed, filling the fragment. - * @param {Number} [fixForBody=false] Wrap body with specified element if needed. - * @param {CKEDITOR.htmlParser.element} contextNode Parse the html as the content of this element. - * @returns CKEDITOR.htmlParser.fragment The fragment created. - * @example - * var fragment = CKEDITOR.htmlParser.fragment.fromHtml( 'Sample Text' ); - * alert( fragment.children[0].name ); "b" - * alert( fragment.children[1].value ); " Text" - */ - CKEDITOR.htmlParser.fragment.fromHtml = function( fragmentHtml, fixForBody, contextNode ) - { - var parser = new CKEDITOR.htmlParser(), - fragment = contextNode || new CKEDITOR.htmlParser.fragment(), - pendingInline = [], - pendingBRs = [], - currentNode = fragment, - // Indicate we're inside a ' ); - return html.join( '' ); - }; - CKEDITOR.ui.dialog.labeledElement.call( this, dialog, elementDefinition, htmlList, innerHTML ); - }, - - /** - * A single checkbox with a label on the right. - * @constructor - * @extends CKEDITOR.ui.dialog.uiElement - * @example - * @param {CKEDITOR.dialog} dialog - * Parent dialog object. - * @param {CKEDITOR.dialog.definition.uiElement} elementDefinition - * The element definition. Accepted fields: - *
        - *
      • checked (Optional) Whether the checkbox is checked - * on instantiation. Defaults to false.
      • - *
      • validate (Optional) The validation function.
      • - *
      • label (Optional) The checkbox label.
      • - *
      - * @param {Array} htmlList - * List of HTML code to output to. - */ - checkbox : function( dialog, elementDefinition, htmlList ) - { - if ( arguments.length < 3 ) - return; - - var _ = initPrivateObject.call( this, elementDefinition, { 'default' : !!elementDefinition[ 'default' ] } ); - - if ( elementDefinition.validate ) - this.validate = elementDefinition.validate; - - /** @ignore */ - var innerHTML = function() - { - var myDefinition = CKEDITOR.tools.extend( {}, elementDefinition, - { - id : elementDefinition.id ? elementDefinition.id + '_checkbox' : CKEDITOR.tools.getNextId() + '_checkbox' - }, true ), - html = []; - - var labelId = CKEDITOR.tools.getNextId() + '_label'; - var attributes = { 'class' : 'cke_dialog_ui_checkbox_input', type : 'checkbox', 'aria-labelledby' : labelId }; - cleanInnerDefinition( myDefinition ); - if ( elementDefinition[ 'default' ] ) - attributes.checked = 'checked'; - - if ( typeof myDefinition.inputStyle != 'undefined' ) - myDefinition.style = myDefinition.inputStyle; - - _.checkbox = new CKEDITOR.ui.dialog.uiElement( dialog, myDefinition, html, 'input', null, attributes ); - html.push( ' ' ); - return html.join( '' ); - }; - - CKEDITOR.ui.dialog.uiElement.call( this, dialog, elementDefinition, htmlList, 'span', null, null, innerHTML ); - }, - - /** - * A group of radio buttons. - * @constructor - * @example - * @extends CKEDITOR.ui.dialog.labeledElement - * @param {CKEDITOR.dialog} dialog - * Parent dialog object. - * @param {CKEDITOR.dialog.definition.uiElement} elementDefinition - * The element definition. Accepted fields: - *
        - *
      • default (Required) The default value.
      • - *
      • validate (Optional) The validation function.
      • - *
      • items (Required) An array of options. Each option - * is a 1- or 2-item array of format [ 'Description', 'Value' ]. If 'Value' - * is missing, then the value would be assumed to be the same as the - * description.
      • - *
      - * @param {Array} htmlList - * List of HTML code to output to. - */ - radio : function( dialog, elementDefinition, htmlList ) - { - if ( arguments.length < 3) - return; - - initPrivateObject.call( this, elementDefinition ); - if ( !this._['default'] ) - this._['default'] = this._.initValue = elementDefinition.items[0][1]; - if ( elementDefinition.validate ) - this.validate = elementDefinition.valdiate; - var children = [], me = this; - - /** @ignore */ - var innerHTML = function() - { - var inputHtmlList = [], html = [], - commonAttributes = { 'class' : 'cke_dialog_ui_radio_item', 'aria-labelledby' : this._.labelId }, - commonName = elementDefinition.id ? elementDefinition.id + '_radio' : CKEDITOR.tools.getNextId() + '_radio'; - for ( var i = 0 ; i < elementDefinition.items.length ; i++ ) - { - var item = elementDefinition.items[i], - title = item[2] !== undefined ? item[2] : item[0], - value = item[1] !== undefined ? item[1] : item[0], - inputId = CKEDITOR.tools.getNextId() + '_radio_input', - labelId = inputId + '_label', - inputDefinition = CKEDITOR.tools.extend( {}, elementDefinition, - { - id : inputId, - title : null, - type : null - }, true ), - labelDefinition = CKEDITOR.tools.extend( {}, inputDefinition, - { - title : title - }, true ), - inputAttributes = - { - type : 'radio', - 'class' : 'cke_dialog_ui_radio_input', - name : commonName, - value : value, - 'aria-labelledby' : labelId - }, - inputHtml = []; - if ( me._['default'] == value ) - inputAttributes.checked = 'checked'; - cleanInnerDefinition( inputDefinition ); - cleanInnerDefinition( labelDefinition ); - - if ( typeof inputDefinition.inputStyle != 'undefined' ) - inputDefinition.style = inputDefinition.inputStyle; - - children.push( new CKEDITOR.ui.dialog.uiElement( dialog, inputDefinition, inputHtml, 'input', null, inputAttributes ) ); - inputHtml.push( ' ' ); - new CKEDITOR.ui.dialog.uiElement( dialog, labelDefinition, inputHtml, 'label', null, { id : labelId, 'for' : inputAttributes.id }, - item[0] ); - inputHtmlList.push( inputHtml.join( '' ) ); - } - new CKEDITOR.ui.dialog.hbox( dialog, children, inputHtmlList, html ); - return html.join( '' ); - }; - - CKEDITOR.ui.dialog.labeledElement.call( this, dialog, elementDefinition, htmlList, innerHTML ); - this._.children = children; - }, - - /** - * A button with a label inside. - * @constructor - * @example - * @extends CKEDITOR.ui.dialog.uiElement - * @param {CKEDITOR.dialog} dialog - * Parent dialog object. - * @param {CKEDITOR.dialog.definition.uiElement} elementDefinition - * The element definition. Accepted fields: - *
        - *
      • label (Required) The button label.
      • - *
      • disabled (Optional) Set to true if you want the - * button to appear in disabled state.
      • - *
      - * @param {Array} htmlList - * List of HTML code to output to. - */ - button : function( dialog, elementDefinition, htmlList ) - { - if ( !arguments.length ) - return; - - if ( typeof elementDefinition == 'function' ) - elementDefinition = elementDefinition( dialog.getParentEditor() ); - - initPrivateObject.call( this, elementDefinition, { disabled : elementDefinition.disabled || false } ); - - // Add OnClick event to this input. - CKEDITOR.event.implementOn( this ); - - var me = this; - - // Register an event handler for processing button clicks. - dialog.on( 'load', function( eventInfo ) - { - var element = this.getElement(); - - (function() - { - element.on( 'click', function( evt ) - { - me.fire( 'click', { dialog : me.getDialog() } ); - evt.data.preventDefault(); - } ); - - element.on( 'keydown', function( evt ) - { - if ( evt.data.getKeystroke() in { 32:1 } ) - { - me.click(); - evt.data.preventDefault(); - } - } ); - })(); - - element.unselectable(); - }, this ); - - var outerDefinition = CKEDITOR.tools.extend( {}, elementDefinition ); - delete outerDefinition.style; - - var labelId = CKEDITOR.tools.getNextId() + '_label'; - CKEDITOR.ui.dialog.uiElement.call( - this, - dialog, - outerDefinition, - htmlList, - 'a', - null, - { - style : elementDefinition.style, - href : 'javascript:void(0)', - title : elementDefinition.label, - hidefocus : 'true', - 'class' : elementDefinition['class'], - role : 'button', - 'aria-labelledby' : labelId - }, - '' + - CKEDITOR.tools.htmlEncode( elementDefinition.label ) + - '' ); - }, - - /** - * A select box. - * @extends CKEDITOR.ui.dialog.uiElement - * @example - * @constructor - * @param {CKEDITOR.dialog} dialog - * Parent dialog object. - * @param {CKEDITOR.dialog.definition.uiElement} elementDefinition - * The element definition. Accepted fields: - *
        - *
      • default (Required) The default value.
      • - *
      • validate (Optional) The validation function.
      • - *
      • items (Required) An array of options. Each option - * is a 1- or 2-item array of format [ 'Description', 'Value' ]. If 'Value' - * is missing, then the value would be assumed to be the same as the - * description.
      • - *
      • multiple (Optional) Set this to true if you'd like - * to have a multiple-choice select box.
      • - *
      • size (Optional) The number of items to display in - * the select box.
      • - *
      - * @param {Array} htmlList - * List of HTML code to output to. - */ - select : function( dialog, elementDefinition, htmlList ) - { - if ( arguments.length < 3 ) - return; - - var _ = initPrivateObject.call( this, elementDefinition ); - - if ( elementDefinition.validate ) - this.validate = elementDefinition.validate; - - _.inputId = CKEDITOR.tools.getNextId() + '_select'; - /** @ignore */ - var innerHTML = function() - { - var myDefinition = CKEDITOR.tools.extend( {}, elementDefinition, - { - id : elementDefinition.id ? elementDefinition.id + '_select' : CKEDITOR.tools.getNextId() + '_select' - }, true ), - html = [], - innerHTML = [], - attributes = { 'id' : _.inputId, 'class' : 'cke_dialog_ui_input_select', 'aria-labelledby' : this._.labelId }; - - // Add multiple and size attributes from element definition. - if ( elementDefinition.size != undefined ) - attributes.size = elementDefinition.size; - if ( elementDefinition.multiple != undefined ) - attributes.multiple = elementDefinition.multiple; - - cleanInnerDefinition( myDefinition ); - for ( var i = 0, item ; i < elementDefinition.items.length && ( item = elementDefinition.items[i] ) ; i++ ) - { - innerHTML.push( '
    2. child (nested - // lists) or the next sibling
    3. . - - this._.nextNode = ( block.equals( lastNode ) ? null : getNextSourceNode( range.getBoundaryNodes().endNode, 1, lastNode ) ); - } - } - - if ( removePreviousBr ) - { - var previousSibling = block.getPrevious(); - if ( previousSibling && previousSibling.type == CKEDITOR.NODE_ELEMENT ) - { - if ( previousSibling.getName() == 'br' ) - previousSibling.remove(); - else if ( previousSibling.getLast() && previousSibling.getLast().$.nodeName.toLowerCase() == 'br' ) - previousSibling.getLast().remove(); - } - } - - if ( removeLastBr ) - { - var lastChild = block.getLast(); - if ( lastChild && lastChild.type == CKEDITOR.NODE_ELEMENT && lastChild.getName() == 'br' ) - { - // Take care not to remove the block expanding
      in non-IE browsers. - if ( CKEDITOR.env.ie - || lastChild.getPrevious( bookmarkGuard ) - || lastChild.getNext( bookmarkGuard ) ) - lastChild.remove(); - } - } - - // Get a reference for the next element. This is important because the - // above block can be removed or changed, so we can rely on it for the - // next interation. - if ( !this._.nextNode ) - { - this._.nextNode = ( isLast || block.equals( lastNode ) || !lastNode ) ? null : - getNextSourceNode( block, 1, lastNode ); - } - - return block; - } - }; - - CKEDITOR.dom.range.prototype.createIterator = function() - { - return new iterator( this ); - }; -})(); diff --git a/media/ckeditor/_source/plugins/editingblock/plugin.js b/media/ckeditor/_source/plugins/editingblock/plugin.js deleted file mode 100644 index 273c34e..0000000 --- a/media/ckeditor/_source/plugins/editingblock/plugin.js +++ /dev/null @@ -1,278 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @fileOverview The default editing block plugin, which holds the editing area - * and source view. - */ - -(function() -{ - // This is a semaphore used to avoid recursive calls between - // the following data handling functions. - var isHandlingData; - - CKEDITOR.plugins.add( 'editingblock', - { - init : function( editor ) - { - if ( !editor.config.editingBlock ) - return; - - editor.on( 'themeSpace', function( event ) - { - if ( event.data.space == 'contents' ) - event.data.html += '
      '; - }); - - editor.on( 'themeLoaded', function() - { - editor.fireOnce( 'editingBlockReady' ); - }); - - editor.on( 'uiReady', function() - { - editor.setMode( editor.config.startupMode ); - }); - - editor.on( 'afterSetData', function() - { - if ( !isHandlingData ) - { - function setData() - { - isHandlingData = true; - editor.getMode().loadData( editor.getData() ); - isHandlingData = false; - } - - if ( editor.mode ) - setData(); - else - { - editor.on( 'mode', function() - { - if ( editor.mode ) - { - setData(); - editor.removeListener( 'mode', arguments.callee ); - } - }); - } - } - }); - - editor.on( 'beforeGetData', function() - { - if ( !isHandlingData && editor.mode ) - { - isHandlingData = true; - editor.setData( editor.getMode().getData(), null, 1 ); - isHandlingData = false; - } - }); - - editor.on( 'getSnapshot', function( event ) - { - if ( editor.mode ) - event.data = editor.getMode().getSnapshotData(); - }); - - editor.on( 'loadSnapshot', function( event ) - { - if ( editor.mode ) - editor.getMode().loadSnapshotData( event.data ); - }); - - // For the first "mode" call, we'll also fire the "instanceReady" - // event. - editor.on( 'mode', function( event ) - { - // Do that once only. - event.removeListener(); - - // Redirect the focus into editor for webkit. (#5713) - CKEDITOR.env.webkit && editor.container.on( 'focus', function() - { - editor.focus(); - }); - - if ( editor.config.startupFocus ) - editor.focus(); - - // Fire instanceReady for both the editor and CKEDITOR, but - // defer this until the whole execution has completed - // to guarantee the editor is fully responsible. - setTimeout( function(){ - editor.fireOnce( 'instanceReady' ); - CKEDITOR.fire( 'instanceReady', null, editor ); - }, 0 ); - }); - - editor.on( 'destroy', function () - { - // -> currentMode.unload( holderElement ); - if ( this.mode ) - this._.modes[ this.mode ].unload( this.getThemeSpace( 'contents' ) ); - }); - } - }); - - /** - * The current editing mode. An editing mode is basically a viewport for - * editing or content viewing. By default the possible values for this - * property are "wysiwyg" and "source". - * @type String - * @example - * alert( CKEDITOR.instances.editor1.mode ); // "wysiwyg" (e.g.) - */ - CKEDITOR.editor.prototype.mode = ''; - - /** - * Registers an editing mode. This function is to be used mainly by plugins. - * @param {String} mode The mode name. - * @param {Object} modeEditor The mode editor definition. - * @example - */ - CKEDITOR.editor.prototype.addMode = function( mode, modeEditor ) - { - modeEditor.name = mode; - ( this._.modes || ( this._.modes = {} ) )[ mode ] = modeEditor; - }; - - /** - * Sets the current editing mode in this editor instance. - * @param {String} mode A registered mode name. - * @example - * // Switch to "source" view. - * CKEDITOR.instances.editor1.setMode( 'source' ); - */ - CKEDITOR.editor.prototype.setMode = function( mode ) - { - this.fire( 'beforeSetMode', { newMode : mode } ); - - var data, - holderElement = this.getThemeSpace( 'contents' ), - isDirty = this.checkDirty(); - - // Unload the previous mode. - if ( this.mode ) - { - if ( mode == this.mode ) - return; - - this._.previousMode = this.mode; - - this.fire( 'beforeModeUnload' ); - - var currentMode = this.getMode(); - data = currentMode.getData(); - currentMode.unload( holderElement ); - this.mode = ''; - } - - holderElement.setHtml( '' ); - - // Load required mode. - var modeEditor = this.getMode( mode ); - if ( !modeEditor ) - throw '[CKEDITOR.editor.setMode] Unknown mode "' + mode + '".'; - - if ( !isDirty ) - { - this.on( 'mode', function() - { - this.resetDirty(); - this.removeListener( 'mode', arguments.callee ); - }); - } - - modeEditor.load( holderElement, ( typeof data ) != 'string' ? this.getData() : data ); - }; - - /** - * Gets the current or any of the objects that represent the editing - * area modes. The two most common editing modes are "wysiwyg" and "source". - * @param {String} [mode] The mode to be retrieved. If not specified, the - * current one is returned. - */ - CKEDITOR.editor.prototype.getMode = function( mode ) - { - return this._.modes && this._.modes[ mode || this.mode ]; - }; - - /** - * Moves the selection focus to the editing are space in the editor. - */ - CKEDITOR.editor.prototype.focus = function() - { - this.forceNextSelectionCheck(); - var mode = this.getMode(); - if ( mode ) - mode.focus(); - }; -})(); - -/** - * The mode to load at the editor startup. It depends on the plugins - * loaded. By default, the "wysiwyg" and "source" modes are available. - * @type String - * @default 'wysiwyg' - * @example - * config.startupMode = 'source'; - */ -CKEDITOR.config.startupMode = 'wysiwyg'; - -/** - * Sets whether the editor should have the focus when the page loads. - * @name CKEDITOR.config.startupFocus - * @type Boolean - * @default false - * @example - * config.startupFocus = true; - */ - -/** - * Whether to render or not the editing block area in the editor interface. - * @type Boolean - * @default true - * @example - * config.editingBlock = false; - */ -CKEDITOR.config.editingBlock = true; - -/** - * Fired when a CKEDITOR instance is created, fully initialized and ready for interaction. - * @name CKEDITOR#instanceReady - * @event - * @param {CKEDITOR.editor} editor The editor instance that has been created. - */ - -/** - * Fired when the CKEDITOR instance is created, fully initialized and ready for interaction. - * @name CKEDITOR.editor#instanceReady - * @event - */ - -/** - * Fired before changing the editing mode. See also CKEDITOR.editor#beforeSetMode and CKEDITOR.editor#mode - * @name CKEDITOR.editor#beforeModeUnload - * @event - */ - - /** - * Fired before the editor mode is set. See also CKEDITOR.editor#mode and CKEDITOR.editor#beforeModeUnload - * @name CKEDITOR.editor#beforeSetMode - * @event - * @since 3.5.3 - * @param {String} newMode The name of the mode which is about to be set. - */ - -/** - * Fired after setting the editing mode. See also CKEDITOR.editor#beforeSetMode and CKEDITOR.editor#beforeModeUnload - * @name CKEDITOR.editor#mode - * @event - * @param {String} previousMode The previous mode of the editor. - */ diff --git a/media/ckeditor/_source/plugins/elementspath/plugin.js b/media/ckeditor/_source/plugins/elementspath/plugin.js deleted file mode 100644 index c1d68ec..0000000 --- a/media/ckeditor/_source/plugins/elementspath/plugin.js +++ /dev/null @@ -1,218 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @fileOverview The "elementspath" plugin. It shows all elements in the DOM - * parent tree relative to the current selection in the editing area. - */ - -(function() -{ - var commands = - { - toolbarFocus : - { - editorFocus : false, - readOnly : 1, - exec : function( editor ) - { - var idBase = editor._.elementsPath.idBase; - var element = CKEDITOR.document.getById( idBase + '0' ); - - // Make the first button focus accessible for IE. (#3417) - // Adobe AIR instead need while of delay. - element && element.focus( CKEDITOR.env.ie || CKEDITOR.env.air ); - } - } - }; - - var emptyHtml = ' '; - - CKEDITOR.plugins.add( 'elementspath', - { - requires : [ 'selection' ], - - init : function( editor ) - { - var spaceId = 'cke_path_' + editor.name; - var spaceElement; - var getSpaceElement = function() - { - if ( !spaceElement ) - spaceElement = CKEDITOR.document.getById( spaceId ); - return spaceElement; - }; - - var idBase = 'cke_elementspath_' + CKEDITOR.tools.getNextNumber() + '_'; - - editor._.elementsPath = { idBase : idBase, filters : [] }; - - editor.on( 'themeSpace', function( event ) - { - if ( event.data.space == 'bottom' ) - { - event.data.html += - '' + editor.lang.elementsPath.eleLabel + '' + - '
      ' + emptyHtml + '
      '; - } - }); - - function onClick( elementIndex ) - { - editor.focus(); - var element = editor._.elementsPath.list[ elementIndex ]; - if ( element.is( 'body' ) ) - { - var range = new CKEDITOR.dom.range( editor.document ); - range.selectNodeContents( element ); - range.select(); - } - else - editor.getSelection().selectElement( element ); - } - - var onClickHanlder = CKEDITOR.tools.addFunction( onClick ); - - var onKeyDownHandler = CKEDITOR.tools.addFunction( function( elementIndex, ev ) - { - var idBase = editor._.elementsPath.idBase, - element; - - ev = new CKEDITOR.dom.event( ev ); - - var rtl = editor.lang.dir == 'rtl'; - switch ( ev.getKeystroke() ) - { - case rtl ? 39 : 37 : // LEFT-ARROW - case 9 : // TAB - element = CKEDITOR.document.getById( idBase + ( elementIndex + 1 ) ); - if ( !element ) - element = CKEDITOR.document.getById( idBase + '0' ); - element.focus(); - return false; - - case rtl ? 37 : 39 : // RIGHT-ARROW - case CKEDITOR.SHIFT + 9 : // SHIFT + TAB - element = CKEDITOR.document.getById( idBase + ( elementIndex - 1 ) ); - if ( !element ) - element = CKEDITOR.document.getById( idBase + ( editor._.elementsPath.list.length - 1 ) ); - element.focus(); - return false; - - case 27 : // ESC - editor.focus(); - return false; - - case 13 : // ENTER // Opera - case 32 : // SPACE - onClick( elementIndex ); - return false; - } - return true; - }); - - editor.on( 'selectionChange', function( ev ) - { - var env = CKEDITOR.env, - selection = ev.data.selection, - element = selection.getStartElement(), - html = [], - editor = ev.editor, - elementsList = editor._.elementsPath.list = [], - filters = editor._.elementsPath.filters; - - while ( element ) - { - var ignore = 0, - name; - - if ( element.data( 'cke-display-name' ) ) - name = element.data( 'cke-display-name' ); - else if ( element.data( 'cke-real-element-type' ) ) - name = element.data( 'cke-real-element-type' ); - else - name = element.getName(); - - for ( var i = 0; i < filters.length; i++ ) - { - var ret = filters[ i ]( element, name ); - if ( ret === false ) - { - ignore = 1; - break; - } - name = ret || name; - } - - if ( !ignore ) - { - var index = elementsList.push( element ) - 1; - - // Use this variable to add conditional stuff to the - // HTML (because we are doing it in reverse order... unshift). - var extra = ''; - - // Some browsers don't cancel key events in the keydown but in the - // keypress. - // TODO: Check if really needed for Gecko+Mac. - if ( env.opera || ( env.gecko && env.mac ) ) - extra += ' onkeypress="return false;"'; - - // With Firefox, we need to force the button to redraw, otherwise it - // will remain in the focus state. - if ( env.gecko ) - extra += ' onblur="this.style.cssText = this.style.cssText;"'; - - var label = editor.lang.elementsPath.eleTitle.replace( /%1/, name ); - html.unshift( - '', - name, - '' + label + '', - '' ); - - } - - if ( name == 'body' ) - break; - - element = element.getParent(); - } - - var space = getSpaceElement(); - space.setHtml( html.join('') + emptyHtml ); - editor.fire( 'elementsPathUpdate', { space : space } ); - }); - - function empty() - { - spaceElement && spaceElement.setHtml( emptyHtml ); - delete editor._.elementsPath.list; - } - - editor.on( 'readOnly', empty ); - editor.on( 'contentDomUnload', empty ); - - editor.addCommand( 'elementsPathFocus', commands.toolbarFocus ); - } - }); -})(); - -/** - * Fired when the contents of the elementsPath are changed - * @name CKEDITOR.editor#elementsPathUpdate - * @event - * @param {Object} eventData.space The elementsPath container - */ diff --git a/media/ckeditor/_source/plugins/enterkey/plugin.js b/media/ckeditor/_source/plugins/enterkey/plugin.js deleted file mode 100644 index c97509d..0000000 --- a/media/ckeditor/_source/plugins/enterkey/plugin.js +++ /dev/null @@ -1,433 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -(function() -{ - CKEDITOR.plugins.add( 'enterkey', - { - requires : [ 'keystrokes', 'indent' ], - - init : function( editor ) - { - editor.addCommand( 'enter', { - modes : { wysiwyg:1 }, - editorFocus : false, - exec : function( editor ){ enter( editor ); } - }); - - editor.addCommand( 'shiftEnter', { - modes : { wysiwyg:1 }, - editorFocus : false, - exec : function( editor ){ shiftEnter( editor ); } - }); - - var keystrokes = editor.keystrokeHandler.keystrokes; - keystrokes[ 13 ] = 'enter'; - keystrokes[ CKEDITOR.SHIFT + 13 ] = 'shiftEnter'; - } - }); - - CKEDITOR.plugins.enterkey = - { - enterBlock : function( editor, mode, range, forceMode ) - { - // Get the range for the current selection. - range = range || getRange( editor ); - - // We may not have valid ranges to work on, like when inside a - // contenteditable=false element. - if ( !range ) - return; - - var doc = range.document; - - var atBlockStart = range.checkStartOfBlock(), - atBlockEnd = range.checkEndOfBlock(), - path = new CKEDITOR.dom.elementPath( range.startContainer ), - block = path.block; - - if ( atBlockStart && atBlockEnd ) - { - // Exit the list when we're inside an empty list item block. (#5376) - if ( block && ( block.is( 'li' ) || block.getParent().is( 'li' ) ) ) - { - editor.execCommand( 'outdent' ); - return; - } - - if ( block && block.getParent().is( 'blockquote' ) ) - { - block.breakParent( block.getParent() ); - - // If we were at the start of
      , there will be an empty element before it now. - if ( !block.getPrevious().getFirst( CKEDITOR.dom.walker.invisible(1) ) ) - block.getPrevious().remove(); - - // If we were at the end of
      , there will be an empty element after it now. - if ( !block.getNext().getFirst( CKEDITOR.dom.walker.invisible(1) ) ) - block.getNext().remove(); - - range.moveToElementEditStart( block ); - range.select(); - return; - } - } - // Don't split
       if we're in the middle of it, act as shift enter key.
      -			else if ( block && block.is( 'pre' ) )
      -			{
      -				if ( !atBlockEnd )
      -				{
      -					enterBr( editor, mode, range, forceMode );
      -					return;
      -				}
      -			}
      -			// Don't split caption blocks. (#7944)
      -			else if ( block && CKEDITOR.dtd.$captionBlock[ block.getName() ] )
      -			{
      -				enterBr( editor, mode, range, forceMode );
      -				return;
      -			}
      -
      -			// Determine the block element to be used.
      -			var blockTag = ( mode == CKEDITOR.ENTER_DIV ? 'div' : 'p' );
      -
      -			// Split the range.
      -			var splitInfo = range.splitBlock( blockTag );
      -
      -			if ( !splitInfo )
      -				return;
      -
      -			// Get the current blocks.
      -			var previousBlock	= splitInfo.previousBlock,
      -				nextBlock		= splitInfo.nextBlock;
      -
      -			var isStartOfBlock	= splitInfo.wasStartOfBlock,
      -				isEndOfBlock	= splitInfo.wasEndOfBlock;
      -
      -			var node;
      -
      -			// If this is a block under a list item, split it as well. (#1647)
      -			if ( nextBlock )
      -			{
      -				node = nextBlock.getParent();
      -				if ( node.is( 'li' ) )
      -				{
      -					nextBlock.breakParent( node );
      -					nextBlock.move( nextBlock.getNext(), 1 );
      -				}
      -			}
      -			else if ( previousBlock && ( node = previousBlock.getParent() ) && node.is( 'li' ) )
      -			{
      -				previousBlock.breakParent( node );
      -				node = previousBlock.getNext();
      -				range.moveToElementEditStart( node );
      -				previousBlock.move( previousBlock.getPrevious() );
      -			}
      -
      -			// If we have both the previous and next blocks, it means that the
      -			// boundaries were on separated blocks, or none of them where on the
      -			// block limits (start/end).
      -			if ( !isStartOfBlock && !isEndOfBlock )
      -			{
      -				// If the next block is an 
    4. with another list tree as the first - // child, we'll need to append a filler (
      /NBSP) or the list item - // wouldn't be editable. (#1420) - if ( nextBlock.is( 'li' ) - && ( node = nextBlock.getFirst( CKEDITOR.dom.walker.invisible( true ) ) ) - && node.is && node.is( 'ul', 'ol' ) ) - ( CKEDITOR.env.ie ? doc.createText( '\xa0' ) : doc.createElement( 'br' ) ).insertBefore( node ); - - // Move the selection to the end block. - if ( nextBlock ) - range.moveToElementEditStart( nextBlock ); - } - else - { - var newBlock, - newBlockDir; - - if ( previousBlock ) - { - // Do not enter this block if it's a header tag, or we are in - // a Shift+Enter (#77). Create a new block element instead - // (later in the code). - if ( previousBlock.is( 'li' ) || - ! ( headerTagRegex.test( previousBlock.getName() ) || previousBlock.is( 'pre' ) ) ) - { - // Otherwise, duplicate the previous block. - newBlock = previousBlock.clone(); - } - } - else if ( nextBlock ) - newBlock = nextBlock.clone(); - - if ( !newBlock ) - { - // We have already created a new list item. (#6849) - if ( node && node.is( 'li' ) ) - newBlock = node; - else - { - newBlock = doc.createElement( blockTag ); - if ( previousBlock && ( newBlockDir = previousBlock.getDirection() ) ) - newBlock.setAttribute( 'dir', newBlockDir ); - } - } - // Force the enter block unless we're talking of a list item. - else if ( forceMode && !newBlock.is( 'li' ) ) - newBlock.renameNode( blockTag ); - - // Recreate the inline elements tree, which was available - // before hitting enter, so the same styles will be available in - // the new block. - var elementPath = splitInfo.elementPath; - if ( elementPath ) - { - for ( var i = 0, len = elementPath.elements.length ; i < len ; i++ ) - { - var element = elementPath.elements[ i ]; - - if ( element.equals( elementPath.block ) || element.equals( elementPath.blockLimit ) ) - break; - - if ( CKEDITOR.dtd.$removeEmpty[ element.getName() ] ) - { - element = element.clone(); - newBlock.moveChildren( element ); - newBlock.append( element ); - } - } - } - - if ( !CKEDITOR.env.ie ) - newBlock.appendBogus(); - - if ( !newBlock.getParent() ) - range.insertNode( newBlock ); - - // list item start number should not be duplicated (#7330), but we need - // to remove the attribute after it's onto the DOM tree because of old IEs (#7581). - newBlock.is( 'li' ) && newBlock.removeAttribute( 'value' ); - - // This is tricky, but to make the new block visible correctly - // we must select it. - // The previousBlock check has been included because it may be - // empty if we have fixed a block-less space (like ENTER into an - // empty table cell). - if ( CKEDITOR.env.ie && isStartOfBlock && ( !isEndOfBlock || !previousBlock.getChildCount() ) ) - { - // Move the selection to the new block. - range.moveToElementEditStart( isEndOfBlock ? previousBlock : newBlock ); - range.select(); - } - - // Move the selection to the new block. - range.moveToElementEditStart( isStartOfBlock && !isEndOfBlock ? nextBlock : newBlock ); - } - - if ( !CKEDITOR.env.ie ) - { - if ( nextBlock ) - { - // If we have split the block, adds a temporary span at the - // range position and scroll relatively to it. - var tmpNode = doc.createElement( 'span' ); - - // We need some content for Safari. - tmpNode.setHtml( ' ' ); - - range.insertNode( tmpNode ); - tmpNode.scrollIntoView(); - range.deleteContents(); - } - else - { - // We may use the above scroll logic for the new block case - // too, but it gives some weird result with Opera. - newBlock.scrollIntoView(); - } - } - - range.select(); - }, - - enterBr : function( editor, mode, range, forceMode ) - { - // Get the range for the current selection. - range = range || getRange( editor ); - - // We may not have valid ranges to work on, like when inside a - // contenteditable=false element. - if ( !range ) - return; - - var doc = range.document; - - // Determine the block element to be used. - var blockTag = ( mode == CKEDITOR.ENTER_DIV ? 'div' : 'p' ); - - var isEndOfBlock = range.checkEndOfBlock(); - - var elementPath = new CKEDITOR.dom.elementPath( editor.getSelection().getStartElement() ); - - var startBlock = elementPath.block, - startBlockTag = startBlock && elementPath.block.getName(); - - var isPre = false; - - if ( !forceMode && startBlockTag == 'li' ) - { - enterBlock( editor, mode, range, forceMode ); - return; - } - - // If we are at the end of a header block. - if ( !forceMode && isEndOfBlock && headerTagRegex.test( startBlockTag ) ) - { - var newBlock, - newBlockDir; - - if ( ( newBlockDir = startBlock.getDirection() ) ) - { - newBlock = doc.createElement( 'div' ); - newBlock.setAttribute( 'dir', newBlockDir ); - newBlock.insertAfter( startBlock ); - range.setStart( newBlock, 0 ); - } - else - { - // Insert a
      after the current paragraph. - doc.createElement( 'br' ).insertAfter( startBlock ); - - // A text node is required by Gecko only to make the cursor blink. - if ( CKEDITOR.env.gecko ) - doc.createText( '' ).insertAfter( startBlock ); - - // IE has different behaviors regarding position. - range.setStartAt( startBlock.getNext(), CKEDITOR.env.ie ? CKEDITOR.POSITION_BEFORE_START : CKEDITOR.POSITION_AFTER_START ); - } - } - else - { - var lineBreak; - - isPre = ( startBlockTag == 'pre' ); - - // Gecko prefers
      as line-break inside
       (#4711).
      -				if ( isPre && !CKEDITOR.env.gecko )
      -					lineBreak = doc.createText( CKEDITOR.env.ie ? '\r' : '\n' );
      -				else
      -					lineBreak = doc.createElement( 'br' );
      -
      -				range.deleteContents();
      -				range.insertNode( lineBreak );
      -
      -				// IE has different behavior regarding position.
      -				if ( CKEDITOR.env.ie )
      -					range.setStartAt( lineBreak, CKEDITOR.POSITION_AFTER_END );
      -				else
      -				{
      -					// A text node is required by Gecko only to make the cursor blink.
      -					// We need some text inside of it, so the bogus 
      is properly - // created. - doc.createText( '\ufeff' ).insertAfter( lineBreak ); - - // If we are at the end of a block, we must be sure the bogus node is available in that block. - if ( isEndOfBlock ) - lineBreak.getParent().appendBogus(); - - // Now we can remove the text node contents, so the caret doesn't - // stop on it. - lineBreak.getNext().$.nodeValue = ''; - - range.setStartAt( lineBreak.getNext(), CKEDITOR.POSITION_AFTER_START ); - - // Scroll into view, for non IE. - var dummy = null; - - // BR is not positioned in Opera and Webkit. - if ( !CKEDITOR.env.gecko ) - { - dummy = doc.createElement( 'span' ); - // We need have some contents for Webkit to position it - // under parent node. ( #3681) - dummy.setHtml(' '); - } - else - dummy = doc.createElement( 'br' ); - - dummy.insertBefore( lineBreak.getNext() ); - dummy.scrollIntoView(); - dummy.remove(); - } - } - - // This collapse guarantees the cursor will be blinking. - range.collapse( true ); - - range.select( isPre ); - } - }; - - var plugin = CKEDITOR.plugins.enterkey, - enterBr = plugin.enterBr, - enterBlock = plugin.enterBlock, - headerTagRegex = /^h[1-6]$/; - - function shiftEnter( editor ) - { - // Only effective within document. - if ( editor.mode != 'wysiwyg' ) - return false; - - // On SHIFT+ENTER: - // 1. We want to enforce the mode to be respected, instead - // of cloning the current block. (#77) - return enter( editor, editor.config.shiftEnterMode, 1 ); - } - - function enter( editor, mode, forceMode ) - { - forceMode = editor.config.forceEnterMode || forceMode; - - // Only effective within document. - if ( editor.mode != 'wysiwyg' ) - return false; - - if ( !mode ) - mode = editor.config.enterMode; - - // Use setTimout so the keys get cancelled immediatelly. - setTimeout( function() - { - editor.fire( 'saveSnapshot' ); // Save undo step. - - if ( mode == CKEDITOR.ENTER_BR ) - enterBr( editor, mode, null, forceMode ); - else - enterBlock( editor, mode, null, forceMode ); - - editor.fire( 'saveSnapshot' ); - - }, 0 ); - - return true; - } - - function getRange( editor ) - { - // Get the selection ranges. - var ranges = editor.getSelection().getRanges( true ); - - // Delete the contents of all ranges except the first one. - for ( var i = ranges.length - 1 ; i > 0 ; i-- ) - { - ranges[ i ].deleteContents(); - } - - // Return the first range. - return ranges[ 0 ]; - } -})(); diff --git a/media/ckeditor/_source/plugins/entities/plugin.js b/media/ckeditor/_source/plugins/entities/plugin.js deleted file mode 100644 index 80a4ebe..0000000 --- a/media/ckeditor/_source/plugins/entities/plugin.js +++ /dev/null @@ -1,254 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -(function() -{ - // Base HTML entities. - var htmlbase = 'nbsp,gt,lt,amp'; - - var entities = - // Latin-1 Entities - 'quot,iexcl,cent,pound,curren,yen,brvbar,sect,uml,copy,ordf,laquo,' + - 'not,shy,reg,macr,deg,plusmn,sup2,sup3,acute,micro,para,middot,' + - 'cedil,sup1,ordm,raquo,frac14,frac12,frac34,iquest,times,divide,' + - - // Symbols - 'fnof,bull,hellip,prime,Prime,oline,frasl,weierp,image,real,trade,' + - 'alefsym,larr,uarr,rarr,darr,harr,crarr,lArr,uArr,rArr,dArr,hArr,' + - 'forall,part,exist,empty,nabla,isin,notin,ni,prod,sum,minus,lowast,' + - 'radic,prop,infin,ang,and,or,cap,cup,int,there4,sim,cong,asymp,ne,' + - 'equiv,le,ge,sub,sup,nsub,sube,supe,oplus,otimes,perp,sdot,lceil,' + - 'rceil,lfloor,rfloor,lang,rang,loz,spades,clubs,hearts,diams,' + - - // Other Special Characters - 'circ,tilde,ensp,emsp,thinsp,zwnj,zwj,lrm,rlm,ndash,mdash,lsquo,' + - 'rsquo,sbquo,ldquo,rdquo,bdquo,dagger,Dagger,permil,lsaquo,rsaquo,' + - 'euro'; - - // Latin Letters Entities - var latin = - 'Agrave,Aacute,Acirc,Atilde,Auml,Aring,AElig,Ccedil,Egrave,Eacute,' + - 'Ecirc,Euml,Igrave,Iacute,Icirc,Iuml,ETH,Ntilde,Ograve,Oacute,Ocirc,' + - 'Otilde,Ouml,Oslash,Ugrave,Uacute,Ucirc,Uuml,Yacute,THORN,szlig,' + - 'agrave,aacute,acirc,atilde,auml,aring,aelig,ccedil,egrave,eacute,' + - 'ecirc,euml,igrave,iacute,icirc,iuml,eth,ntilde,ograve,oacute,ocirc,' + - 'otilde,ouml,oslash,ugrave,uacute,ucirc,uuml,yacute,thorn,yuml,' + - 'OElig,oelig,Scaron,scaron,Yuml'; - - // Greek Letters Entities. - var greek = - 'Alpha,Beta,Gamma,Delta,Epsilon,Zeta,Eta,Theta,Iota,Kappa,Lambda,Mu,' + - 'Nu,Xi,Omicron,Pi,Rho,Sigma,Tau,Upsilon,Phi,Chi,Psi,Omega,alpha,' + - 'beta,gamma,delta,epsilon,zeta,eta,theta,iota,kappa,lambda,mu,nu,xi,' + - 'omicron,pi,rho,sigmaf,sigma,tau,upsilon,phi,chi,psi,omega,thetasym,' + - 'upsih,piv'; - - /** - * Create a mapping table between one character and its entity form from a list of entity names. - * @param reverse {Boolean} Whether to create a reverse map from the entity string form to an actual character. - */ - function buildTable( entities, reverse ) - { - var table = {}, - regex = []; - - // Entities that the browsers DOM don't transform to the final char - // automatically. - var specialTable = - { - nbsp : '\u00A0', // IE | FF - shy : '\u00AD', // IE - gt : '\u003E', // IE | FF | -- | Opera - lt : '\u003C', // IE | FF | Safari | Opera - amp : '\u0026', // ALL - apos : '\u0027', // IE - quot : '\u0022' // IE - }; - - entities = entities.replace( /\b(nbsp|shy|gt|lt|amp|apos|quot)(?:,|$)/g, function( match, entity ) - { - var org = reverse ? '&' + entity + ';' : specialTable[ entity ], - result = reverse ? specialTable[ entity ] : '&' + entity + ';'; - - table[ org ] = result; - regex.push( org ); - return ''; - }); - - if ( !reverse && entities ) - { - // Transforms the entities string into an array. - entities = entities.split( ',' ); - - // Put all entities inside a DOM element, transforming them to their - // final chars. - var div = document.createElement( 'div' ), - chars; - div.innerHTML = '&' + entities.join( ';&' ) + ';'; - chars = div.innerHTML; - div = null; - - // Add all chars to the table. - for ( var i = 0 ; i < chars.length ; i++ ) - { - var charAt = chars.charAt( i ); - table[ charAt ] = '&' + entities[ i ] + ';'; - regex.push( charAt ); - } - } - - table.regex = regex.join( reverse ? '|' : '' ); - - return table; - } - - CKEDITOR.plugins.add( 'entities', - { - afterInit : function( editor ) - { - var config = editor.config; - - var dataProcessor = editor.dataProcessor, - htmlFilter = dataProcessor && dataProcessor.htmlFilter; - - if ( htmlFilter ) - { - // Mandatory HTML base entities. - var selectedEntities = []; - - if ( config.basicEntities !== false ) - selectedEntities.push( htmlbase ); - - if ( config.entities ) - { - if ( selectedEntities.length ) - selectedEntities.push( entities ); - - if ( config.entities_latin ) - selectedEntities.push( latin ); - - if ( config.entities_greek ) - selectedEntities.push( greek ); - - if ( config.entities_additional ) - selectedEntities.push( config.entities_additional ); - } - - var entitiesTable = buildTable( selectedEntities.join( ',' ) ); - - // Create the Regex used to find entities in the text, leave it matches nothing if entities are empty. - var entitiesRegex = entitiesTable.regex ? '[' + entitiesTable.regex + ']' : 'a^'; - delete entitiesTable.regex; - - if ( config.entities && config.entities_processNumerical ) - entitiesRegex = '[^ -~]|' + entitiesRegex ; - - entitiesRegex = new RegExp( entitiesRegex, 'g' ); - - function getEntity( character ) - { - return config.entities_processNumerical == 'force' || !entitiesTable[ character ] ? - '&#' + character.charCodeAt(0) + ';' - : entitiesTable[ character ]; - } - - // Decode entities that the browsers has transformed - // at first place. - var baseEntitiesTable = buildTable( [ htmlbase, 'shy' ].join( ',' ) , true ), - baseEntitiesRegex = new RegExp( baseEntitiesTable.regex, 'g' ); - - function getChar( character ) - { - return baseEntitiesTable[ character ]; - } - - htmlFilter.addRules( - { - text : function( text ) - { - return text.replace( baseEntitiesRegex, getChar ) - .replace( entitiesRegex, getEntity ); - } - }); - } - } - }); -})(); - -/** - * Whether to escape basic HTML entities in the document, including: - *
        - *
      • nbsp
      • - *
      • gt
      • - *
      • lt
      • - *
      • amp
      • - *
      - * Note: It should not be subject to change unless when outputting a non-HTML data format like BBCode. - * @type Boolean - * @default true - * @example - * config.basicEntities = false; - */ -CKEDITOR.config.basicEntities = true; - -/** - * Whether to use HTML entities in the output. - * @name CKEDITOR.config.entities - * @type Boolean - * @default true - * @example - * config.entities = false; - */ -CKEDITOR.config.entities = true; - -/** - * Whether to convert some Latin characters (Latin alphabet No. 1, ISO 8859-1) - * to HTML entities. The list of entities can be found in the - * W3C HTML 4.01 Specification, section 24.2.1. - * @name CKEDITOR.config.entities_latin - * @type Boolean - * @default true - * @example - * config.entities_latin = false; - */ -CKEDITOR.config.entities_latin = true; - -/** - * Whether to convert some symbols, mathematical symbols, and Greek letters to - * HTML entities. This may be more relevant for users typing text written in Greek. - * The list of entities can be found in the - * W3C HTML 4.01 Specification, section 24.3.1. - * @name CKEDITOR.config.entities_greek - * @type Boolean - * @default true - * @example - * config.entities_greek = false; - */ -CKEDITOR.config.entities_greek = true; - -/** - * Whether to convert all remaining characters not included in the ASCII - * character table to their relative decimal numeric representation of HTML entity. - * When set to force, it will convert all entities into this format. - * For example the phrase "This is Chinese: 汉语." is output - * as "This is Chinese: &#27721;&#35821;." - * @name CKEDITOR.config.entities_processNumerical - * @type Boolean|String - * @default false - * @example - * config.entities_processNumerical = true; - * config.entities_processNumerical = 'force'; //Converts from " " into " "; - */ - -/** - * A comma separated list of additional entities to be used. Entity names - * or numbers must be used in a form that excludes the "&" prefix and the ";" ending. - * @name CKEDITOR.config.entities_additional - * @default '#39' (The single quote (') character.) - * @type String - * @example - * config.entities_additional = '#1049'; // Adds Cyrillic capital letter Short I (Й). - */ -CKEDITOR.config.entities_additional = '#39'; diff --git a/media/ckeditor/_source/plugins/fakeobjects/plugin.js b/media/ckeditor/_source/plugins/fakeobjects/plugin.js deleted file mode 100644 index 237c5e0..0000000 --- a/media/ckeditor/_source/plugins/fakeobjects/plugin.js +++ /dev/null @@ -1,175 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -(function() -{ - var cssStyle = CKEDITOR.htmlParser.cssStyle, - cssLength = CKEDITOR.tools.cssLength; - - var cssLengthRegex = /^((?:\d*(?:\.\d+))|(?:\d+))(.*)?$/i; - - /* - * Replacing the former CSS length value with the later one, with - * adjustment to the length unit. - */ - function replaceCssLength( length1, length2 ) - { - var parts1 = cssLengthRegex.exec( length1 ), - parts2 = cssLengthRegex.exec( length2 ); - - // Omit pixel length unit when necessary, - // e.g. replaceCssLength( 10, '20px' ) -> 20 - if ( parts1 ) - { - if ( !parts1[ 2 ] && parts2[ 2 ] == 'px' ) - return parts2[ 1 ]; - if ( parts1[ 2 ] == 'px' && !parts2[ 2 ] ) - return parts2[ 1 ] + 'px'; - } - - return length2; - } - - var htmlFilterRules = - { - elements : - { - $ : function( element ) - { - var attributes = element.attributes, - realHtml = attributes && attributes[ 'data-cke-realelement' ], - realFragment = realHtml && new CKEDITOR.htmlParser.fragment.fromHtml( decodeURIComponent( realHtml ) ), - realElement = realFragment && realFragment.children[ 0 ]; - - // Width/height in the fake object are subjected to clone into the real element. - if ( realElement && element.attributes[ 'data-cke-resizable' ] ) - { - var styles = new cssStyle( element ).rules, - realAttrs = realElement.attributes, - width = styles.width, - height = styles.height; - - width && ( realAttrs.width = replaceCssLength( realAttrs.width, width ) ); - height && ( realAttrs.height = replaceCssLength( realAttrs.height, height ) ); - } - - return realElement; - } - } - }; - - CKEDITOR.plugins.add( 'fakeobjects', - { - requires : [ 'htmlwriter' ], - - afterInit : function( editor ) - { - var dataProcessor = editor.dataProcessor, - htmlFilter = dataProcessor && dataProcessor.htmlFilter; - - if ( htmlFilter ) - htmlFilter.addRules( htmlFilterRules ); - } - }); - - CKEDITOR.editor.prototype.createFakeElement = function( realElement, className, realElementType, isResizable ) - { - var lang = this.lang.fakeobjects, - label = lang[ realElementType ] || lang.unknown; - - var attributes = - { - 'class' : className, - src : CKEDITOR.getUrl( 'images/spacer.gif' ), - 'data-cke-realelement' : encodeURIComponent( realElement.getOuterHtml() ), - 'data-cke-real-node-type' : realElement.type, - alt : label, - title : label, - align : realElement.getAttribute( 'align' ) || '' - }; - - if ( realElementType ) - attributes[ 'data-cke-real-element-type' ] = realElementType; - - if ( isResizable ) - { - attributes[ 'data-cke-resizable' ] = isResizable; - - var fakeStyle = new cssStyle(); - - var width = realElement.getAttribute( 'width' ), - height = realElement.getAttribute( 'height' ); - - width && ( fakeStyle.rules.width = cssLength( width ) ); - height && ( fakeStyle.rules.height = cssLength( height ) ); - fakeStyle.populate( attributes ); - } - - return this.document.createElement( 'img', { attributes : attributes } ); - }; - - CKEDITOR.editor.prototype.createFakeParserElement = function( realElement, className, realElementType, isResizable ) - { - var lang = this.lang.fakeobjects, - label = lang[ realElementType ] || lang.unknown, - html; - - var writer = new CKEDITOR.htmlParser.basicWriter(); - realElement.writeHtml( writer ); - html = writer.getHtml(); - - var attributes = - { - 'class' : className, - src : CKEDITOR.getUrl( 'images/spacer.gif' ), - 'data-cke-realelement' : encodeURIComponent( html ), - 'data-cke-real-node-type' : realElement.type, - alt : label, - title : label, - align : realElement.attributes.align || '' - }; - - if ( realElementType ) - attributes[ 'data-cke-real-element-type' ] = realElementType; - - if ( isResizable ) - { - attributes[ 'data-cke-resizable' ] = isResizable; - var realAttrs = realElement.attributes, - fakeStyle = new cssStyle(); - - var width = realAttrs.width, - height = realAttrs.height; - - width != undefined && ( fakeStyle.rules.width = cssLength( width ) ); - height != undefined && ( fakeStyle.rules.height = cssLength ( height ) ); - fakeStyle.populate( attributes ); - } - - return new CKEDITOR.htmlParser.element( 'img', attributes ); - }; - - CKEDITOR.editor.prototype.restoreRealElement = function( fakeElement ) - { - if ( fakeElement.data( 'cke-real-node-type' ) != CKEDITOR.NODE_ELEMENT ) - return null; - - var element = CKEDITOR.dom.element.createFromHtml( - decodeURIComponent( fakeElement.data( 'cke-realelement' ) ), - this.document ); - - if ( fakeElement.data( 'cke-resizable') ) - { - var width = fakeElement.getStyle( 'width' ), - height = fakeElement.getStyle( 'height' ); - - width && element.setAttribute( 'width', replaceCssLength( element.getAttribute( 'width' ), width ) ); - height && element.setAttribute( 'height', replaceCssLength( element.getAttribute( 'height' ), height ) ); - } - - return element; - }; - -})(); diff --git a/media/ckeditor/_source/plugins/filebrowser/plugin.js b/media/ckeditor/_source/plugins/filebrowser/plugin.js deleted file mode 100644 index c00eafc..0000000 --- a/media/ckeditor/_source/plugins/filebrowser/plugin.js +++ /dev/null @@ -1,533 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @fileOverview The "filebrowser" plugin that adds support for file uploads and - * browsing. - * - * When a file is uploaded or selected inside the file browser, its URL is - * inserted automatically into a field defined in the filebrowser - * attribute. In order to specify a field that should be updated, pass the tab ID and - * the element ID, separated with a colon.

      - * - * Example 1: (Browse) - * - *
      - * {
      - * 	type : 'button',
      - * 	id : 'browse',
      - * 	filebrowser : 'tabId:elementId',
      - * 	label : editor.lang.common.browseServer
      - * }
      - * 
      - * - * If you set the filebrowser attribute for an element other than - * the fileButton, the Browse action will be triggered.

      - * - * Example 2: (Quick Upload) - * - *
      - * {
      - * 	type : 'fileButton',
      - * 	id : 'uploadButton',
      - * 	filebrowser : 'tabId:elementId',
      - * 	label : editor.lang.common.uploadSubmit,
      - * 	'for' : [ 'upload', 'upload' ]
      - * }
      - * 
      - * - * If you set the filebrowser attribute for a fileButton - * element, the QuickUpload action will be executed.

      - * - * The filebrowser plugin also supports more advanced configuration performed through - * a JavaScript object. - * - * The following settings are supported: - * - *
        - *
      • actionBrowse or QuickUpload.
      • - *
      • target – the field to update in the tabId:elementId format.
      • - *
      • params – additional arguments to be passed to the server connector (optional).
      • - *
      • onSelect – a function to execute when the file is selected/uploaded (optional).
      • - *
      • url – the URL to be called (optional).
      • - *
      - * - * Example 3: (Quick Upload) - * - *
      - * {
      - * 	type : 'fileButton',
      - * 	label : editor.lang.common.uploadSubmit,
      - * 	id : 'buttonId',
      - * 	filebrowser :
      - * 	{
      - * 		action : 'QuickUpload', // required
      - * 		target : 'tab1:elementId', // required
      - * 		params : // optional
      - * 		{
      - * 			type : 'Files',
      - * 			currentFolder : '/folder/'
      - * 		},
      - * 		onSelect : function( fileUrl, errorMessage ) // optional
      - * 		{
      - * 			// Do not call the built-in selectFuntion.
      - * 			// return false;
      - * 		}
      - * 	},
      - * 	'for' : [ 'tab1', 'myFile' ]
      - * }
      - * 
      - * - * Suppose you have a file element with an ID of myFile, a text - * field with an ID of elementId and a fileButton. - * If the filebowser.url attribute is not specified explicitly, - * the form action will be set to filebrowser[DialogWindowName]UploadUrl - * or, if not specified, to filebrowserUploadUrl. Additional parameters - * from the params object will be added to the query string. It is - * possible to create your own uploadHandler and cancel the built-in - * updateTargetElement command.

      - * - * Example 4: (Browse) - * - *
      - * {
      - * 	type : 'button',
      - * 	id : 'buttonId',
      - * 	label : editor.lang.common.browseServer,
      - * 	filebrowser :
      - * 	{
      - * 		action : 'Browse',
      - * 		url : '/ckfinder/ckfinder.html&type=Images',
      - * 		target : 'tab1:elementId'
      - * 	}
      - * }
      - * 
      - * - * In this example, when the button is pressed, the file browser will be opened in a - * popup window. If you do not specify the filebrowser.url attribute, - * filebrowser[DialogName]BrowseUrl or - * filebrowserBrowseUrl will be used. After selecting a file in the file - * browser, an element with an ID of elementId will be updated. Just - * like in the third example, a custom onSelect function may be defined. - */ -( function() -{ - /* - * Adds (additional) arguments to given url. - * - * @param {String} - * url The url. - * @param {Object} - * params Additional parameters. - */ - function addQueryString( url, params ) - { - var queryString = []; - - if ( !params ) - return url; - else - { - for ( var i in params ) - queryString.push( i + "=" + encodeURIComponent( params[ i ] ) ); - } - - return url + ( ( url.indexOf( "?" ) != -1 ) ? "&" : "?" ) + queryString.join( "&" ); - } - - /* - * Make a string's first character uppercase. - * - * @param {String} - * str String. - */ - function ucFirst( str ) - { - str += ''; - var f = str.charAt( 0 ).toUpperCase(); - return f + str.substr( 1 ); - } - - /* - * The onlick function assigned to the 'Browse Server' button. Opens the - * file browser and updates target field when file is selected. - * - * @param {CKEDITOR.event} - * evt The event object. - */ - function browseServer( evt ) - { - var dialog = this.getDialog(); - var editor = dialog.getParentEditor(); - - editor._.filebrowserSe = this; - - var width = editor.config[ 'filebrowser' + ucFirst( dialog.getName() ) + 'WindowWidth' ] - || editor.config.filebrowserWindowWidth || '80%'; - var height = editor.config[ 'filebrowser' + ucFirst( dialog.getName() ) + 'WindowHeight' ] - || editor.config.filebrowserWindowHeight || '70%'; - - var params = this.filebrowser.params || {}; - params.CKEditor = editor.name; - params.CKEditorFuncNum = editor._.filebrowserFn; - if ( !params.langCode ) - params.langCode = editor.langCode; - - var url = addQueryString( this.filebrowser.url, params ); - // TODO: V4: Remove backward compatibility (#8163). - editor.popup( url, width, height, editor.config.filebrowserWindowFeatures || editor.config.fileBrowserWindowFeatures ); - } - - /* - * The onlick function assigned to the 'Upload' button. Makes the final - * decision whether form is really submitted and updates target field when - * file is uploaded. - * - * @param {CKEDITOR.event} - * evt The event object. - */ - function uploadFile( evt ) - { - var dialog = this.getDialog(); - var editor = dialog.getParentEditor(); - - editor._.filebrowserSe = this; - - // If user didn't select the file, stop the upload. - if ( !dialog.getContentElement( this[ 'for' ][ 0 ], this[ 'for' ][ 1 ] ).getInputElement().$.value ) - return false; - - if ( !dialog.getContentElement( this[ 'for' ][ 0 ], this[ 'for' ][ 1 ] ).getAction() ) - return false; - - return true; - } - - /* - * Setups the file element. - * - * @param {CKEDITOR.ui.dialog.file} - * fileInput The file element used during file upload. - * @param {Object} - * filebrowser Object containing filebrowser settings assigned to - * the fileButton associated with this file element. - */ - function setupFileElement( editor, fileInput, filebrowser ) - { - var params = filebrowser.params || {}; - params.CKEditor = editor.name; - params.CKEditorFuncNum = editor._.filebrowserFn; - if ( !params.langCode ) - params.langCode = editor.langCode; - - fileInput.action = addQueryString( filebrowser.url, params ); - fileInput.filebrowser = filebrowser; - } - - /* - * Traverse through the content definition and attach filebrowser to - * elements with 'filebrowser' attribute. - * - * @param String - * dialogName Dialog name. - * @param {CKEDITOR.dialog.definitionObject} - * definition Dialog definition. - * @param {Array} - * elements Array of {@link CKEDITOR.dialog.definition.content} - * objects. - */ - function attachFileBrowser( editor, dialogName, definition, elements ) - { - var element, fileInput; - - for ( var i in elements ) - { - element = elements[ i ]; - - if ( element.type == 'hbox' || element.type == 'vbox' || element.type == 'fieldset' ) - attachFileBrowser( editor, dialogName, definition, element.children ); - - if ( !element.filebrowser ) - continue; - - if ( typeof element.filebrowser == 'string' ) - { - var fb = - { - action : ( element.type == 'fileButton' ) ? 'QuickUpload' : 'Browse', - target : element.filebrowser - }; - element.filebrowser = fb; - } - - if ( element.filebrowser.action == 'Browse' ) - { - var url = element.filebrowser.url; - if ( url === undefined ) - { - url = editor.config[ 'filebrowser' + ucFirst( dialogName ) + 'BrowseUrl' ]; - if ( url === undefined ) - url = editor.config.filebrowserBrowseUrl; - } - - if ( url ) - { - element.onClick = browseServer; - element.filebrowser.url = url; - element.hidden = false; - } - } - else if ( element.filebrowser.action == 'QuickUpload' && element[ 'for' ] ) - { - url = element.filebrowser.url; - if ( url === undefined ) - { - url = editor.config[ 'filebrowser' + ucFirst( dialogName ) + 'UploadUrl' ]; - if ( url === undefined ) - url = editor.config.filebrowserUploadUrl; - } - - if ( url ) - { - var onClick = element.onClick; - element.onClick = function( evt ) - { - // "element" here means the definition object, so we need to find the correct - // button to scope the event call - var sender = evt.sender; - if ( onClick && onClick.call( sender, evt ) === false ) - return false; - - return uploadFile.call( sender, evt ); - }; - - element.filebrowser.url = url; - element.hidden = false; - setupFileElement( editor, definition.getContents( element[ 'for' ][ 0 ] ).get( element[ 'for' ][ 1 ] ), element.filebrowser ); - } - } - } - } - - /* - * Updates the target element with the url of uploaded/selected file. - * - * @param {String} - * url The url of a file. - */ - function updateTargetElement( url, sourceElement ) - { - var dialog = sourceElement.getDialog(); - var targetElement = sourceElement.filebrowser.target || null; - - // If there is a reference to targetElement, update it. - if ( targetElement ) - { - var target = targetElement.split( ':' ); - var element = dialog.getContentElement( target[ 0 ], target[ 1 ] ); - if ( element ) - { - element.setValue( url ); - dialog.selectPage( target[ 0 ] ); - } - } - } - - /* - * Returns true if filebrowser is configured in one of the elements. - * - * @param {CKEDITOR.dialog.definitionObject} - * definition Dialog definition. - * @param String - * tabId The tab id where element(s) can be found. - * @param String - * elementId The element id (or ids, separated with a semicolon) to check. - */ - function isConfigured( definition, tabId, elementId ) - { - if ( elementId.indexOf( ";" ) !== -1 ) - { - var ids = elementId.split( ";" ); - for ( var i = 0 ; i < ids.length ; i++ ) - { - if ( isConfigured( definition, tabId, ids[i] ) ) - return true; - } - return false; - } - - var elementFileBrowser = definition.getContents( tabId ).get( elementId ).filebrowser; - return ( elementFileBrowser && elementFileBrowser.url ); - } - - function setUrl( fileUrl, data ) - { - var dialog = this._.filebrowserSe.getDialog(), - targetInput = this._.filebrowserSe[ 'for' ], - onSelect = this._.filebrowserSe.filebrowser.onSelect; - - if ( targetInput ) - dialog.getContentElement( targetInput[ 0 ], targetInput[ 1 ] ).reset(); - - if ( typeof data == 'function' && data.call( this._.filebrowserSe ) === false ) - return; - - if ( onSelect && onSelect.call( this._.filebrowserSe, fileUrl, data ) === false ) - return; - - // The "data" argument may be used to pass the error message to the editor. - if ( typeof data == 'string' && data ) - alert( data ); - - if ( fileUrl ) - updateTargetElement( fileUrl, this._.filebrowserSe ); - } - - CKEDITOR.plugins.add( 'filebrowser', - { - init : function( editor, pluginPath ) - { - editor._.filebrowserFn = CKEDITOR.tools.addFunction( setUrl, editor ); - editor.on( 'destroy', function () { CKEDITOR.tools.removeFunction( this._.filebrowserFn ); } ); - } - } ); - - CKEDITOR.on( 'dialogDefinition', function( evt ) - { - var definition = evt.data.definition, - element; - // Associate filebrowser to elements with 'filebrowser' attribute. - for ( var i in definition.contents ) - { - if ( ( element = definition.contents[ i ] ) ) - { - attachFileBrowser( evt.editor, evt.data.name, definition, element.elements ); - if ( element.hidden && element.filebrowser ) - { - element.hidden = !isConfigured( definition, element[ 'id' ], element.filebrowser ); - } - } - } - } ); - -} )(); - -/** - * The location of an external file browser that should be launched when the Browse Server - * button is pressed. If configured, the Browse Server button will appear in the - * Link, Image, and Flash dialog windows. - * @see The File Browser/Uploader documentation. - * @name CKEDITOR.config.filebrowserBrowseUrl - * @since 3.0 - * @type String - * @default '' (empty string = disabled) - * @example - * config.filebrowserBrowseUrl = '/browser/browse.php'; - */ - -/** - * The location of the script that handles file uploads. - * If set, the Upload tab will appear in the Link, Image, - * and Flash dialog windows. - * @name CKEDITOR.config.filebrowserUploadUrl - * @see The File Browser/Uploader documentation. - * @since 3.0 - * @type String - * @default '' (empty string = disabled) - * @example - * config.filebrowserUploadUrl = '/uploader/upload.php'; - */ - -/** - * The location of an external file browser that should be launched when the Browse Server - * button is pressed in the Image dialog window. - * If not set, CKEditor will use {@link CKEDITOR.config.filebrowserBrowseUrl}. - * @name CKEDITOR.config.filebrowserImageBrowseUrl - * @since 3.0 - * @type String - * @default '' (empty string = disabled) - * @example - * config.filebrowserImageBrowseUrl = '/browser/browse.php?type=Images'; - */ - -/** - * The location of an external file browser that should be launched when the Browse Server - * button is pressed in the Flash dialog window. - * If not set, CKEditor will use {@link CKEDITOR.config.filebrowserBrowseUrl}. - * @name CKEDITOR.config.filebrowserFlashBrowseUrl - * @since 3.0 - * @type String - * @default '' (empty string = disabled) - * @example - * config.filebrowserFlashBrowseUrl = '/browser/browse.php?type=Flash'; - */ - -/** - * The location of the script that handles file uploads in the Image dialog window. - * If not set, CKEditor will use {@link CKEDITOR.config.filebrowserUploadUrl}. - * @name CKEDITOR.config.filebrowserImageUploadUrl - * @since 3.0 - * @type String - * @default '' (empty string = disabled) - * @example - * config.filebrowserImageUploadUrl = '/uploader/upload.php?type=Images'; - */ - -/** - * The location of the script that handles file uploads in the Flash dialog window. - * If not set, CKEditor will use {@link CKEDITOR.config.filebrowserUploadUrl}. - * @name CKEDITOR.config.filebrowserFlashUploadUrl - * @since 3.0 - * @type String - * @default '' (empty string = disabled) - * @example - * config.filebrowserFlashUploadUrl = '/uploader/upload.php?type=Flash'; - */ - -/** - * The location of an external file browser that should be launched when the Browse Server - * button is pressed in the Link tab of the Image dialog window. - * If not set, CKEditor will use {@link CKEDITOR.config.filebrowserBrowseUrl}. - * @name CKEDITOR.config.filebrowserImageBrowseLinkUrl - * @since 3.2 - * @type String - * @default '' (empty string = disabled) - * @example - * config.filebrowserImageBrowseLinkUrl = '/browser/browse.php'; - */ - -/** - * The features to use in the file browser popup window. - * @name CKEDITOR.config.filebrowserWindowFeatures - * @since 3.4.1 - * @type String - * @default 'location=no,menubar=no,toolbar=no,dependent=yes,minimizable=no,modal=yes,alwaysRaised=yes,resizable=yes,scrollbars=yes' - * @example - * config.filebrowserWindowFeatures = 'resizable=yes,scrollbars=no'; - */ - -/** - * The width of the file browser popup window. It can be a number denoting a value in - * pixels or a percent string. - * @name CKEDITOR.config.filebrowserWindowWidth - * @type Number|String - * @default '80%' - * @example - * config.filebrowserWindowWidth = 750; - * @example - * config.filebrowserWindowWidth = '50%'; - */ - -/** - * The height of the file browser popup window. It can be a number denoting a value in - * pixels or a percent string. - * @name CKEDITOR.config.filebrowserWindowHeight - * @type Number|String - * @default '70%' - * @example - * config.filebrowserWindowHeight = 580; - * @example - * config.filebrowserWindowHeight = '50%'; - */ diff --git a/media/ckeditor/_source/plugins/find/dialogs/find.js b/media/ckeditor/_source/plugins/find/dialogs/find.js deleted file mode 100644 index afb0dbe..0000000 --- a/media/ckeditor/_source/plugins/find/dialogs/find.js +++ /dev/null @@ -1,915 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -(function() -{ - var isReplace; - - function findEvaluator( node ) - { - return node.type == CKEDITOR.NODE_TEXT && node.getLength() > 0 && ( !isReplace || !node.isReadOnly() ); - } - - /** - * Elements which break characters been considered as sequence. - */ - function nonCharactersBoundary( node ) - { - return !( node.type == CKEDITOR.NODE_ELEMENT && node.isBlockBoundary( - CKEDITOR.tools.extend( {}, CKEDITOR.dtd.$empty, CKEDITOR.dtd.$nonEditable ) ) ); - } - - /** - * Get the cursor object which represent both current character and it's dom - * position thing. - */ - var cursorStep = function() - { - return { - textNode : this.textNode, - offset : this.offset, - character : this.textNode ? - this.textNode.getText().charAt( this.offset ) : null, - hitMatchBoundary : this._.matchBoundary - }; - }; - - var pages = [ 'find', 'replace' ], - fieldsMapping = [ - [ 'txtFindFind', 'txtFindReplace' ], - [ 'txtFindCaseChk', 'txtReplaceCaseChk' ], - [ 'txtFindWordChk', 'txtReplaceWordChk' ], - [ 'txtFindCyclic', 'txtReplaceCyclic' ] ]; - - /** - * Synchronize corresponding filed values between 'replace' and 'find' pages. - * @param {String} currentPageId The page id which receive values. - */ - function syncFieldsBetweenTabs( currentPageId ) - { - var sourceIndex, targetIndex, - sourceField, targetField; - - sourceIndex = currentPageId === 'find' ? 1 : 0; - targetIndex = 1 - sourceIndex; - var i, l = fieldsMapping.length; - for ( i = 0 ; i < l ; i++ ) - { - sourceField = this.getContentElement( pages[ sourceIndex ], - fieldsMapping[ i ][ sourceIndex ] ); - targetField = this.getContentElement( pages[ targetIndex ], - fieldsMapping[ i ][ targetIndex ] ); - - targetField.setValue( sourceField.getValue() ); - } - } - - var findDialog = function( editor, startupPage ) - { - // Style object for highlights: (#5018) - // 1. Defined as full match style to avoid compromising ordinary text color styles. - // 2. Must be apply onto inner-most text to avoid conflicting with ordinary text color styles visually. - var highlightStyle = new CKEDITOR.style( - CKEDITOR.tools.extend( { attributes : { 'data-cke-highlight': 1 }, fullMatch : 1, ignoreReadonly : 1, childRule : function(){ return 0; } }, - editor.config.find_highlight, true ) ); - - /** - * Iterator which walk through the specified range char by char. By - * default the walking will not stop at the character boundaries, until - * the end of the range is encountered. - * @param { CKEDITOR.dom.range } range - * @param {Boolean} matchWord Whether the walking will stop at character boundary. - */ - var characterWalker = function( range , matchWord ) - { - var self = this; - var walker = - new CKEDITOR.dom.walker( range ); - walker.guard = matchWord ? nonCharactersBoundary : function( node ) - { - !nonCharactersBoundary( node ) && ( self._.matchBoundary = true ); - }; - walker[ 'evaluator' ] = findEvaluator; - walker.breakOnFalse = 1; - - if ( range.startContainer.type == CKEDITOR.NODE_TEXT ) - { - this.textNode = range.startContainer; - this.offset = range.startOffset - 1; - } - - this._ = { - matchWord : matchWord, - walker : walker, - matchBoundary : false - }; - }; - - characterWalker.prototype = { - next : function() - { - return this.move(); - }, - - back : function() - { - return this.move( true ); - }, - - move : function( rtl ) - { - var currentTextNode = this.textNode; - // Already at the end of document, no more character available. - if ( currentTextNode === null ) - return cursorStep.call( this ); - - this._.matchBoundary = false; - - // There are more characters in the text node, step forward. - if ( currentTextNode - && rtl - && this.offset > 0 ) - { - this.offset--; - return cursorStep.call( this ); - } - else if ( currentTextNode - && this.offset < currentTextNode.getLength() - 1 ) - { - this.offset++; - return cursorStep.call( this ); - } - else - { - currentTextNode = null; - // At the end of the text node, walking foward for the next. - while ( !currentTextNode ) - { - currentTextNode = - this._.walker[ rtl ? 'previous' : 'next' ].call( this._.walker ); - - // Stop searching if we're need full word match OR - // already reach document end. - if ( this._.matchWord && !currentTextNode - || this._.walker._.end ) - break; - } - // Found a fresh text node. - this.textNode = currentTextNode; - if ( currentTextNode ) - this.offset = rtl ? currentTextNode.getLength() - 1 : 0; - else - this.offset = 0; - } - - return cursorStep.call( this ); - } - - }; - - /** - * A range of cursors which represent a trunk of characters which try to - * match, it has the same length as the pattern string. - */ - var characterRange = function( characterWalker, rangeLength ) - { - this._ = { - walker : characterWalker, - cursors : [], - rangeLength : rangeLength, - highlightRange : null, - isMatched : 0 - }; - }; - - characterRange.prototype = { - /** - * Translate this range to {@link CKEDITOR.dom.range} - */ - toDomRange : function() - { - var range = new CKEDITOR.dom.range( editor.document ); - var cursors = this._.cursors; - if ( cursors.length < 1 ) - { - var textNode = this._.walker.textNode; - if ( textNode ) - range.setStartAfter( textNode ); - else - return null; - } - else - { - var first = cursors[0], - last = cursors[ cursors.length - 1 ]; - - range.setStart( first.textNode, first.offset ); - range.setEnd( last.textNode, last.offset + 1 ); - } - - return range; - }, - /** - * Reflect the latest changes from dom range. - */ - updateFromDomRange : function( domRange ) - { - var cursor, - walker = new characterWalker( domRange ); - this._.cursors = []; - do - { - cursor = walker.next(); - if ( cursor.character ) - this._.cursors.push( cursor ); - } - while ( cursor.character ); - this._.rangeLength = this._.cursors.length; - }, - - setMatched : function() - { - this._.isMatched = true; - }, - - clearMatched : function() - { - this._.isMatched = false; - }, - - isMatched : function() - { - return this._.isMatched; - }, - - /** - * Hightlight the current matched chunk of text. - */ - highlight : function() - { - // Do not apply if nothing is found. - if ( this._.cursors.length < 1 ) - return; - - // Remove the previous highlight if there's one. - if ( this._.highlightRange ) - this.removeHighlight(); - - // Apply the highlight. - var range = this.toDomRange(), - bookmark = range.createBookmark(); - highlightStyle.applyToRange( range ); - range.moveToBookmark( bookmark ); - this._.highlightRange = range; - - // Scroll the editor to the highlighted area. - var element = range.startContainer; - if ( element.type != CKEDITOR.NODE_ELEMENT ) - element = element.getParent(); - element.scrollIntoView(); - - // Update the character cursors. - this.updateFromDomRange( range ); - }, - - /** - * Remove highlighted find result. - */ - removeHighlight : function() - { - if ( !this._.highlightRange ) - return; - - var bookmark = this._.highlightRange.createBookmark(); - highlightStyle.removeFromRange( this._.highlightRange ); - this._.highlightRange.moveToBookmark( bookmark ); - this.updateFromDomRange( this._.highlightRange ); - this._.highlightRange = null; - }, - - isReadOnly : function() - { - if ( !this._.highlightRange ) - return 0; - - return this._.highlightRange.startContainer.isReadOnly(); - }, - - moveBack : function() - { - var retval = this._.walker.back(), - cursors = this._.cursors; - - if ( retval.hitMatchBoundary ) - this._.cursors = cursors = []; - - cursors.unshift( retval ); - if ( cursors.length > this._.rangeLength ) - cursors.pop(); - - return retval; - }, - - moveNext : function() - { - var retval = this._.walker.next(), - cursors = this._.cursors; - - // Clear the cursors queue if we've crossed a match boundary. - if ( retval.hitMatchBoundary ) - this._.cursors = cursors = []; - - cursors.push( retval ); - if ( cursors.length > this._.rangeLength ) - cursors.shift(); - - return retval; - }, - - getEndCharacter : function() - { - var cursors = this._.cursors; - if ( cursors.length < 1 ) - return null; - - return cursors[ cursors.length - 1 ].character; - }, - - getNextCharacterRange : function( maxLength ) - { - var lastCursor, - nextRangeWalker, - cursors = this._.cursors; - - if ( ( lastCursor = cursors[ cursors.length - 1 ] ) && lastCursor.textNode ) - nextRangeWalker = new characterWalker( getRangeAfterCursor( lastCursor ) ); - // In case it's an empty range (no cursors), figure out next range from walker (#4951). - else - nextRangeWalker = this._.walker; - - return new characterRange( nextRangeWalker, maxLength ); - }, - - getCursors : function() - { - return this._.cursors; - } - }; - - - // The remaining document range after the character cursor. - function getRangeAfterCursor( cursor , inclusive ) - { - var range = new CKEDITOR.dom.range(); - range.setStart( cursor.textNode, - ( inclusive ? cursor.offset : cursor.offset + 1 ) ); - range.setEndAt( editor.document.getBody(), - CKEDITOR.POSITION_BEFORE_END ); - return range; - } - - // The document range before the character cursor. - function getRangeBeforeCursor( cursor ) - { - var range = new CKEDITOR.dom.range(); - range.setStartAt( editor.document.getBody(), - CKEDITOR.POSITION_AFTER_START ); - range.setEnd( cursor.textNode, cursor.offset ); - return range; - } - - var KMP_NOMATCH = 0, - KMP_ADVANCED = 1, - KMP_MATCHED = 2; - /** - * Examination the occurrence of a word which implement KMP algorithm. - */ - var kmpMatcher = function( pattern, ignoreCase ) - { - var overlap = [ -1 ]; - if ( ignoreCase ) - pattern = pattern.toLowerCase(); - for ( var i = 0 ; i < pattern.length ; i++ ) - { - overlap.push( overlap[i] + 1 ); - while ( overlap[ i + 1 ] > 0 - && pattern.charAt( i ) != pattern - .charAt( overlap[ i + 1 ] - 1 ) ) - overlap[ i + 1 ] = overlap[ overlap[ i + 1 ] - 1 ] + 1; - } - - this._ = { - overlap : overlap, - state : 0, - ignoreCase : !!ignoreCase, - pattern : pattern - }; - }; - - kmpMatcher.prototype = - { - feedCharacter : function( c ) - { - if ( this._.ignoreCase ) - c = c.toLowerCase(); - - while ( true ) - { - if ( c == this._.pattern.charAt( this._.state ) ) - { - this._.state++; - if ( this._.state == this._.pattern.length ) - { - this._.state = 0; - return KMP_MATCHED; - } - return KMP_ADVANCED; - } - else if ( !this._.state ) - return KMP_NOMATCH; - else - this._.state = this._.overlap[ this._.state ]; - } - - return null; - }, - - reset : function() - { - this._.state = 0; - } - }; - - var wordSeparatorRegex = - /[.,"'?!;: \u0085\u00a0\u1680\u280e\u2028\u2029\u202f\u205f\u3000]/; - - var isWordSeparator = function( c ) - { - if ( !c ) - return true; - var code = c.charCodeAt( 0 ); - return ( code >= 9 && code <= 0xd ) - || ( code >= 0x2000 && code <= 0x200a ) - || wordSeparatorRegex.test( c ); - }; - - var finder = { - searchRange : null, - matchRange : null, - find : function( pattern, matchCase, matchWord, matchCyclic, highlightMatched, cyclicRerun ) - { - if ( !this.matchRange ) - this.matchRange = - new characterRange( - new characterWalker( this.searchRange ), - pattern.length ); - else - { - this.matchRange.removeHighlight(); - this.matchRange = this.matchRange.getNextCharacterRange( pattern.length ); - } - - var matcher = new kmpMatcher( pattern, !matchCase ), - matchState = KMP_NOMATCH, - character = '%'; - - while ( character !== null ) - { - this.matchRange.moveNext(); - while ( ( character = this.matchRange.getEndCharacter() ) ) - { - matchState = matcher.feedCharacter( character ); - if ( matchState == KMP_MATCHED ) - break; - if ( this.matchRange.moveNext().hitMatchBoundary ) - matcher.reset(); - } - - if ( matchState == KMP_MATCHED ) - { - if ( matchWord ) - { - var cursors = this.matchRange.getCursors(), - tail = cursors[ cursors.length - 1 ], - head = cursors[ 0 ]; - - var headWalker = new characterWalker( getRangeBeforeCursor( head ), true ), - tailWalker = new characterWalker( getRangeAfterCursor( tail ), true ); - - if ( ! ( isWordSeparator( headWalker.back().character ) - && isWordSeparator( tailWalker.next().character ) ) ) - continue; - } - this.matchRange.setMatched(); - if ( highlightMatched !== false ) - this.matchRange.highlight(); - return true; - } - } - - this.matchRange.clearMatched(); - this.matchRange.removeHighlight(); - // Clear current session and restart with the default search - // range. - // Re-run the finding once for cyclic.(#3517) - if ( matchCyclic && !cyclicRerun ) - { - this.searchRange = getSearchRange( 1 ); - this.matchRange = null; - return arguments.callee.apply( this, - Array.prototype.slice.call( arguments ).concat( [ true ] ) ); - } - - return false; - }, - - /** - * Record how much replacement occurred toward one replacing. - */ - replaceCounter : 0, - - replace : function( dialog, pattern, newString, matchCase, matchWord, - matchCyclic , isReplaceAll ) - { - isReplace = 1; - - // Successiveness of current replace/find. - var result = 0; - - // 1. Perform the replace when there's already a match here. - // 2. Otherwise perform the find but don't replace it immediately. - if ( this.matchRange && this.matchRange.isMatched() - && !this.matchRange._.isReplaced && !this.matchRange.isReadOnly() ) - { - // Turn off highlight for a while when saving snapshots. - this.matchRange.removeHighlight(); - var domRange = this.matchRange.toDomRange(); - var text = editor.document.createText( newString ); - if ( !isReplaceAll ) - { - // Save undo snaps before and after the replacement. - var selection = editor.getSelection(); - selection.selectRanges( [ domRange ] ); - editor.fire( 'saveSnapshot' ); - } - domRange.deleteContents(); - domRange.insertNode( text ); - if ( !isReplaceAll ) - { - selection.selectRanges( [ domRange ] ); - editor.fire( 'saveSnapshot' ); - } - this.matchRange.updateFromDomRange( domRange ); - if ( !isReplaceAll ) - this.matchRange.highlight(); - this.matchRange._.isReplaced = true; - this.replaceCounter++; - result = 1; - } - else - result = this.find( pattern, matchCase, matchWord, matchCyclic, !isReplaceAll ); - - isReplace = 0; - - return result; - } - }; - - /** - * The range in which find/replace happened, receive from user - * selection prior. - */ - function getSearchRange( isDefault ) - { - var searchRange, - sel = editor.getSelection(), - body = editor.document.getBody(); - if ( sel && !isDefault ) - { - searchRange = sel.getRanges()[ 0 ].clone(); - searchRange.collapse( true ); - } - else - { - searchRange = new CKEDITOR.dom.range(); - searchRange.setStartAt( body, CKEDITOR.POSITION_AFTER_START ); - } - searchRange.setEndAt( body, CKEDITOR.POSITION_BEFORE_END ); - return searchRange; - } - - var lang = editor.lang.findAndReplace; - return { - title : lang.title, - resizable : CKEDITOR.DIALOG_RESIZE_NONE, - minWidth : 350, - minHeight : 170, - buttons : [ CKEDITOR.dialog.cancelButton ], // Cancel button only. - contents : [ - { - id : 'find', - label : lang.find, - title : lang.find, - accessKey : '', - elements : [ - { - type : 'hbox', - widths : [ '230px', '90px' ], - children : - [ - { - type : 'text', - id : 'txtFindFind', - label : lang.findWhat, - isChanged : false, - labelLayout : 'horizontal', - accessKey : 'F' - }, - { - type : 'button', - id : 'btnFind', - align : 'left', - style : 'width:100%', - label : lang.find, - onClick : function() - { - var dialog = this.getDialog(); - if ( !finder.find( dialog.getValueOf( 'find', 'txtFindFind' ), - dialog.getValueOf( 'find', 'txtFindCaseChk' ), - dialog.getValueOf( 'find', 'txtFindWordChk' ), - dialog.getValueOf( 'find', 'txtFindCyclic' ) ) ) - alert( lang - .notFoundMsg ); - } - } - ] - }, - { - type : 'fieldset', - label : CKEDITOR.tools.htmlEncode( lang.findOptions ), - style : 'margin-top:29px', - children : - [ - { - type : 'vbox', - padding : 0, - children : - [ - { - type : 'checkbox', - id : 'txtFindCaseChk', - isChanged : false, - label : lang.matchCase - }, - { - type : 'checkbox', - id : 'txtFindWordChk', - isChanged : false, - label : lang.matchWord - }, - { - type : 'checkbox', - id : 'txtFindCyclic', - isChanged : false, - 'default' : true, - label : lang.matchCyclic - } - ] - } - ] - } - ] - }, - { - id : 'replace', - label : lang.replace, - accessKey : 'M', - elements : [ - { - type : 'hbox', - widths : [ '230px', '90px' ], - children : - [ - { - type : 'text', - id : 'txtFindReplace', - label : lang.findWhat, - isChanged : false, - labelLayout : 'horizontal', - accessKey : 'F' - }, - { - type : 'button', - id : 'btnFindReplace', - align : 'left', - style : 'width:100%', - label : lang.replace, - onClick : function() - { - var dialog = this.getDialog(); - if ( !finder.replace( dialog, - dialog.getValueOf( 'replace', 'txtFindReplace' ), - dialog.getValueOf( 'replace', 'txtReplace' ), - dialog.getValueOf( 'replace', 'txtReplaceCaseChk' ), - dialog.getValueOf( 'replace', 'txtReplaceWordChk' ), - dialog.getValueOf( 'replace', 'txtReplaceCyclic' ) ) ) - alert( lang - .notFoundMsg ); - } - } - ] - }, - { - type : 'hbox', - widths : [ '230px', '90px' ], - children : - [ - { - type : 'text', - id : 'txtReplace', - label : lang.replaceWith, - isChanged : false, - labelLayout : 'horizontal', - accessKey : 'R' - }, - { - type : 'button', - id : 'btnReplaceAll', - align : 'left', - style : 'width:100%', - label : lang.replaceAll, - isChanged : false, - onClick : function() - { - var dialog = this.getDialog(); - var replaceNums; - - finder.replaceCounter = 0; - - // Scope to full document. - finder.searchRange = getSearchRange( 1 ); - if ( finder.matchRange ) - { - finder.matchRange.removeHighlight(); - finder.matchRange = null; - } - editor.fire( 'saveSnapshot' ); - while ( finder.replace( dialog, - dialog.getValueOf( 'replace', 'txtFindReplace' ), - dialog.getValueOf( 'replace', 'txtReplace' ), - dialog.getValueOf( 'replace', 'txtReplaceCaseChk' ), - dialog.getValueOf( 'replace', 'txtReplaceWordChk' ), - false, true ) ) - { /*jsl:pass*/ } - - if ( finder.replaceCounter ) - { - alert( lang.replaceSuccessMsg.replace( /%1/, finder.replaceCounter ) ); - editor.fire( 'saveSnapshot' ); - } - else - alert( lang.notFoundMsg ); - } - } - ] - }, - { - type : 'fieldset', - label : CKEDITOR.tools.htmlEncode( lang.findOptions ), - children : - [ - { - type : 'vbox', - padding : 0, - children : - [ - { - type : 'checkbox', - id : 'txtReplaceCaseChk', - isChanged : false, - label : lang.matchCase - }, - { - type : 'checkbox', - id : 'txtReplaceWordChk', - isChanged : false, - label : lang.matchWord - }, - { - type : 'checkbox', - id : 'txtReplaceCyclic', - isChanged : false, - 'default' : true, - label : lang.matchCyclic - } - ] - } - ] - } - ] - } - ], - onLoad : function() - { - var dialog = this; - - // Keep track of the current pattern field in use. - var patternField, wholeWordChkField; - - // Ignore initial page select on dialog show - var isUserSelect = 0; - this.on( 'hide', function() - { - isUserSelect = 0; - }); - this.on( 'show', function() - { - isUserSelect = 1; - }); - - this.selectPage = CKEDITOR.tools.override( this.selectPage, function( originalFunc ) - { - return function( pageId ) - { - originalFunc.call( dialog, pageId ); - - var currPage = dialog._.tabs[ pageId ]; - var patternFieldInput, patternFieldId, wholeWordChkFieldId; - patternFieldId = pageId === 'find' ? 'txtFindFind' : 'txtFindReplace'; - wholeWordChkFieldId = pageId === 'find' ? 'txtFindWordChk' : 'txtReplaceWordChk'; - - patternField = dialog.getContentElement( pageId, - patternFieldId ); - wholeWordChkField = dialog.getContentElement( pageId, - wholeWordChkFieldId ); - - // Prepare for check pattern text filed 'keyup' event - if ( !currPage.initialized ) - { - patternFieldInput = CKEDITOR.document - .getById( patternField._.inputId ); - currPage.initialized = true; - } - - // Synchronize fields on tab switch. - if ( isUserSelect ) - syncFieldsBetweenTabs.call( this, pageId ); - }; - } ); - - }, - onShow : function() - { - // Establish initial searching start position. - finder.searchRange = getSearchRange(); - - // Fill in the find field with selected text. - var selectedText = this.getParentEditor().getSelection().getSelectedText(), - patternFieldId = ( startupPage == 'find' ? 'txtFindFind' : 'txtFindReplace' ); - - var field = this.getContentElement( startupPage, patternFieldId ); - field.setValue( selectedText ); - field.select(); - - this.selectPage( startupPage ); - - this[ ( startupPage == 'find' && this._.editor.readOnly? 'hide' : 'show' ) + 'Page' ]( 'replace'); - }, - onHide : function() - { - var range; - if ( finder.matchRange && finder.matchRange.isMatched() ) - { - finder.matchRange.removeHighlight(); - editor.focus(); - - range = finder.matchRange.toDomRange(); - if ( range ) - editor.getSelection().selectRanges( [ range ] ); - } - - // Clear current session before dialog close - delete finder.matchRange; - }, - onFocus : function() - { - if ( startupPage == 'replace' ) - return this.getContentElement( 'replace', 'txtFindReplace' ); - else - return this.getContentElement( 'find', 'txtFindFind' ); - } - }; - }; - - CKEDITOR.dialog.add( 'find', function( editor ) - { - return findDialog( editor, 'find' ); - }); - - CKEDITOR.dialog.add( 'replace', function( editor ) - { - return findDialog( editor, 'replace' ); - }); -})(); diff --git a/media/ckeditor/_source/plugins/find/plugin.js b/media/ckeditor/_source/plugins/find/plugin.js deleted file mode 100644 index fb3d662..0000000 --- a/media/ckeditor/_source/plugins/find/plugin.js +++ /dev/null @@ -1,47 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -CKEDITOR.plugins.add( 'find', -{ - init : function( editor ) - { - var forms = CKEDITOR.plugins.find; - editor.ui.addButton( 'Find', - { - label : editor.lang.findAndReplace.find, - command : 'find' - }); - var findCommand = editor.addCommand( 'find', new CKEDITOR.dialogCommand( 'find' ) ); - findCommand.canUndo = false; - findCommand.readOnly = 1; - - editor.ui.addButton( 'Replace', - { - label : editor.lang.findAndReplace.replace, - command : 'replace' - }); - var replaceCommand = editor.addCommand( 'replace', new CKEDITOR.dialogCommand( 'replace' ) ); - replaceCommand.canUndo = false; - - CKEDITOR.dialog.add( 'find', this.path + 'dialogs/find.js' ); - CKEDITOR.dialog.add( 'replace', this.path + 'dialogs/find.js' ); - }, - - requires : [ 'styles' ] -} ); - -/** - * Defines the style to be used to highlight results with the find dialog. - * @type Object - * @default { element : 'span', styles : { 'background-color' : '#004', 'color' : '#fff' } } - * @example - * // Highlight search results with blue on yellow. - * config.find_highlight = - * { - * element : 'span', - * styles : { 'background-color' : '#ff0', 'color' : '#00f' } - * }; - */ -CKEDITOR.config.find_highlight = { element : 'span', styles : { 'background-color' : '#004', 'color' : '#fff' } }; diff --git a/media/ckeditor/_source/plugins/flash/dialogs/flash.js b/media/ckeditor/_source/plugins/flash/dialogs/flash.js deleted file mode 100644 index acf6fe7..0000000 --- a/media/ckeditor/_source/plugins/flash/dialogs/flash.js +++ /dev/null @@ -1,674 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -(function() -{ - /* - * It is possible to set things in three different places. - * 1. As attributes in the object tag. - * 2. As param tags under the object tag. - * 3. As attributes in the embed tag. - * It is possible for a single attribute to be present in more than one place. - * So let's define a mapping between a sementic attribute and its syntactic - * equivalents. - * Then we'll set and retrieve attribute values according to the mapping, - * instead of having to check and set each syntactic attribute every time. - * - * Reference: http://kb.adobe.com/selfservice/viewContent.do?externalId=tn_12701 - */ - var ATTRTYPE_OBJECT = 1, - ATTRTYPE_PARAM = 2, - ATTRTYPE_EMBED = 4; - - var attributesMap = - { - id : [ { type : ATTRTYPE_OBJECT, name : 'id' } ], - classid : [ { type : ATTRTYPE_OBJECT, name : 'classid' } ], - codebase : [ { type : ATTRTYPE_OBJECT, name : 'codebase'} ], - pluginspage : [ { type : ATTRTYPE_EMBED, name : 'pluginspage' } ], - src : [ { type : ATTRTYPE_PARAM, name : 'movie' }, { type : ATTRTYPE_EMBED, name : 'src' }, { type : ATTRTYPE_OBJECT, name : 'data' } ], - name : [ { type : ATTRTYPE_EMBED, name : 'name' } ], - align : [ { type : ATTRTYPE_OBJECT, name : 'align' } ], - title : [ { type : ATTRTYPE_OBJECT, name : 'title' }, { type : ATTRTYPE_EMBED, name : 'title' } ], - 'class' : [ { type : ATTRTYPE_OBJECT, name : 'class' }, { type : ATTRTYPE_EMBED, name : 'class'} ], - width : [ { type : ATTRTYPE_OBJECT, name : 'width' }, { type : ATTRTYPE_EMBED, name : 'width' } ], - height : [ { type : ATTRTYPE_OBJECT, name : 'height' }, { type : ATTRTYPE_EMBED, name : 'height' } ], - hSpace : [ { type : ATTRTYPE_OBJECT, name : 'hSpace' }, { type : ATTRTYPE_EMBED, name : 'hSpace' } ], - vSpace : [ { type : ATTRTYPE_OBJECT, name : 'vSpace' }, { type : ATTRTYPE_EMBED, name : 'vSpace' } ], - style : [ { type : ATTRTYPE_OBJECT, name : 'style' }, { type : ATTRTYPE_EMBED, name : 'style' } ], - type : [ { type : ATTRTYPE_EMBED, name : 'type' } ] - }; - - var names = [ 'play', 'loop', 'menu', 'quality', 'scale', 'salign', 'wmode', 'bgcolor', 'base', 'flashvars', 'allowScriptAccess', - 'allowFullScreen' ]; - for ( var i = 0 ; i < names.length ; i++ ) - attributesMap[ names[i] ] = [ { type : ATTRTYPE_EMBED, name : names[i] }, { type : ATTRTYPE_PARAM, name : names[i] } ]; - names = [ 'allowFullScreen', 'play', 'loop', 'menu' ]; - for ( i = 0 ; i < names.length ; i++ ) - attributesMap[ names[i] ][0]['default'] = attributesMap[ names[i] ][1]['default'] = true; - - var defaultToPixel = CKEDITOR.tools.cssLength; - - function loadValue( objectNode, embedNode, paramMap ) - { - var attributes = attributesMap[ this.id ]; - if ( !attributes ) - return; - - var isCheckbox = ( this instanceof CKEDITOR.ui.dialog.checkbox ); - for ( var i = 0 ; i < attributes.length ; i++ ) - { - var attrDef = attributes[ i ]; - switch ( attrDef.type ) - { - case ATTRTYPE_OBJECT: - if ( !objectNode ) - continue; - if ( objectNode.getAttribute( attrDef.name ) !== null ) - { - var value = objectNode.getAttribute( attrDef.name ); - if ( isCheckbox ) - this.setValue( value.toLowerCase() == 'true' ); - else - this.setValue( value ); - return; - } - else if ( isCheckbox ) - this.setValue( !!attrDef[ 'default' ] ); - break; - case ATTRTYPE_PARAM: - if ( !objectNode ) - continue; - if ( attrDef.name in paramMap ) - { - value = paramMap[ attrDef.name ]; - if ( isCheckbox ) - this.setValue( value.toLowerCase() == 'true' ); - else - this.setValue( value ); - return; - } - else if ( isCheckbox ) - this.setValue( !!attrDef[ 'default' ] ); - break; - case ATTRTYPE_EMBED: - if ( !embedNode ) - continue; - if ( embedNode.getAttribute( attrDef.name ) ) - { - value = embedNode.getAttribute( attrDef.name ); - if ( isCheckbox ) - this.setValue( value.toLowerCase() == 'true' ); - else - this.setValue( value ); - return; - } - else if ( isCheckbox ) - this.setValue( !!attrDef[ 'default' ] ); - } - } - } - - function commitValue( objectNode, embedNode, paramMap ) - { - var attributes = attributesMap[ this.id ]; - if ( !attributes ) - return; - - var isRemove = ( this.getValue() === '' ), - isCheckbox = ( this instanceof CKEDITOR.ui.dialog.checkbox ); - - for ( var i = 0 ; i < attributes.length ; i++ ) - { - var attrDef = attributes[i]; - switch ( attrDef.type ) - { - case ATTRTYPE_OBJECT: - // Avoid applying the data attribute when not needed (#7733) - if ( !objectNode || ( attrDef.name == 'data' && embedNode && !objectNode.hasAttribute( 'data' ) ) ) - continue; - var value = this.getValue(); - if ( isRemove || isCheckbox && value === attrDef[ 'default' ] ) - objectNode.removeAttribute( attrDef.name ); - else - objectNode.setAttribute( attrDef.name, value ); - break; - case ATTRTYPE_PARAM: - if ( !objectNode ) - continue; - value = this.getValue(); - if ( isRemove || isCheckbox && value === attrDef[ 'default' ] ) - { - if ( attrDef.name in paramMap ) - paramMap[ attrDef.name ].remove(); - } - else - { - if ( attrDef.name in paramMap ) - paramMap[ attrDef.name ].setAttribute( 'value', value ); - else - { - var param = CKEDITOR.dom.element.createFromHtml( '', objectNode.getDocument() ); - param.setAttributes( { name : attrDef.name, value : value } ); - if ( objectNode.getChildCount() < 1 ) - param.appendTo( objectNode ); - else - param.insertBefore( objectNode.getFirst() ); - } - } - break; - case ATTRTYPE_EMBED: - if ( !embedNode ) - continue; - value = this.getValue(); - if ( isRemove || isCheckbox && value === attrDef[ 'default' ]) - embedNode.removeAttribute( attrDef.name ); - else - embedNode.setAttribute( attrDef.name, value ); - } - } - } - - CKEDITOR.dialog.add( 'flash', function( editor ) - { - var makeObjectTag = !editor.config.flashEmbedTagOnly, - makeEmbedTag = editor.config.flashAddEmbedTag || editor.config.flashEmbedTagOnly; - - var previewPreloader, - previewAreaHtml = '
      ' + CKEDITOR.tools.htmlEncode( editor.lang.common.preview ) +'
      ' + - '' + - '
      '; - - return { - title : editor.lang.flash.title, - minWidth : 420, - minHeight : 310, - onShow : function() - { - // Clear previously saved elements. - this.fakeImage = this.objectNode = this.embedNode = null; - previewPreloader = new CKEDITOR.dom.element( 'embed', editor.document ); - - // Try to detect any embed or object tag that has Flash parameters. - var fakeImage = this.getSelectedElement(); - if ( fakeImage && fakeImage.data( 'cke-real-element-type' ) && fakeImage.data( 'cke-real-element-type' ) == 'flash' ) - { - this.fakeImage = fakeImage; - - var realElement = editor.restoreRealElement( fakeImage ), - objectNode = null, embedNode = null, paramMap = {}; - if ( realElement.getName() == 'cke:object' ) - { - objectNode = realElement; - var embedList = objectNode.getElementsByTag( 'embed', 'cke' ); - if ( embedList.count() > 0 ) - embedNode = embedList.getItem( 0 ); - var paramList = objectNode.getElementsByTag( 'param', 'cke' ); - for ( var i = 0, length = paramList.count() ; i < length ; i++ ) - { - var item = paramList.getItem( i ), - name = item.getAttribute( 'name' ), - value = item.getAttribute( 'value' ); - paramMap[ name ] = value; - } - } - else if ( realElement.getName() == 'cke:embed' ) - embedNode = realElement; - - this.objectNode = objectNode; - this.embedNode = embedNode; - - this.setupContent( objectNode, embedNode, paramMap, fakeImage ); - } - }, - onOk : function() - { - // If there's no selected object or embed, create one. Otherwise, reuse the - // selected object and embed nodes. - var objectNode = null, - embedNode = null, - paramMap = null; - if ( !this.fakeImage ) - { - if ( makeObjectTag ) - { - objectNode = CKEDITOR.dom.element.createFromHtml( '', editor.document ); - var attributes = { - classid : 'clsid:d27cdb6e-ae6d-11cf-96b8-444553540000', - codebase : 'http://download.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=6,0,40,0' - }; - objectNode.setAttributes( attributes ); - } - if ( makeEmbedTag ) - { - embedNode = CKEDITOR.dom.element.createFromHtml( '', editor.document ); - embedNode.setAttributes( - { - type : 'application/x-shockwave-flash', - pluginspage : 'http://www.macromedia.com/go/getflashplayer' - } ); - if ( objectNode ) - embedNode.appendTo( objectNode ); - } - } - else - { - objectNode = this.objectNode; - embedNode = this.embedNode; - } - - // Produce the paramMap if there's an object tag. - if ( objectNode ) - { - paramMap = {}; - var paramList = objectNode.getElementsByTag( 'param', 'cke' ); - for ( var i = 0, length = paramList.count() ; i < length ; i++ ) - paramMap[ paramList.getItem( i ).getAttribute( 'name' ) ] = paramList.getItem( i ); - } - - // A subset of the specified attributes/styles - // should also be applied on the fake element to - // have better visual effect. (#5240) - var extraStyles = {}, extraAttributes = {}; - this.commitContent( objectNode, embedNode, paramMap, extraStyles, extraAttributes ); - - // Refresh the fake image. - var newFakeImage = editor.createFakeElement( objectNode || embedNode, 'cke_flash', 'flash', true ); - newFakeImage.setAttributes( extraAttributes ); - newFakeImage.setStyles( extraStyles ); - if ( this.fakeImage ) - { - newFakeImage.replace( this.fakeImage ); - editor.getSelection().selectElement( newFakeImage ); - } - else - editor.insertElement( newFakeImage ); - }, - - onHide : function() - { - if ( this.preview ) - this.preview.setHtml(''); - }, - - contents : [ - { - id : 'info', - label : editor.lang.common.generalTab, - accessKey : 'I', - elements : - [ - { - type : 'vbox', - padding : 0, - children : - [ - { - type : 'hbox', - widths : [ '280px', '110px' ], - align : 'right', - children : - [ - { - id : 'src', - type : 'text', - label : editor.lang.common.url, - required : true, - validate : CKEDITOR.dialog.validate.notEmpty( editor.lang.flash.validateSrc ), - setup : loadValue, - commit : commitValue, - onLoad : function() - { - var dialog = this.getDialog(), - updatePreview = function( src ){ - // Query the preloader to figure out the url impacted by based href. - previewPreloader.setAttribute( 'src', src ); - dialog.preview.setHtml( '' ); - }; - // Preview element - dialog.preview = dialog.getContentElement( 'info', 'preview' ).getElement().getChild( 3 ); - - // Sync on inital value loaded. - this.on( 'change', function( evt ){ - - if ( evt.data && evt.data.value ) - updatePreview( evt.data.value ); - } ); - // Sync when input value changed. - this.getInputElement().on( 'change', function( evt ){ - - updatePreview( this.getValue() ); - }, this ); - } - }, - { - type : 'button', - id : 'browse', - filebrowser : 'info:src', - hidden : true, - // v-align with the 'src' field. - // TODO: We need something better than a fixed size here. - style : 'display:inline-block;margin-top:10px;', - label : editor.lang.common.browseServer - } - ] - } - ] - }, - { - type : 'hbox', - widths : [ '25%', '25%', '25%', '25%', '25%' ], - children : - [ - { - type : 'text', - id : 'width', - style : 'width:95px', - label : editor.lang.common.width, - validate : CKEDITOR.dialog.validate.htmlLength( editor.lang.common.invalidHtmlLength.replace( '%1', editor.lang.common.width ) ), - setup : loadValue, - commit : commitValue - }, - { - type : 'text', - id : 'height', - style : 'width:95px', - label : editor.lang.common.height, - validate : CKEDITOR.dialog.validate.htmlLength( editor.lang.common.invalidHtmlLength.replace( '%1', editor.lang.common.height ) ), - setup : loadValue, - commit : commitValue - }, - { - type : 'text', - id : 'hSpace', - style : 'width:95px', - label : editor.lang.flash.hSpace, - validate : CKEDITOR.dialog.validate.integer( editor.lang.flash.validateHSpace ), - setup : loadValue, - commit : commitValue - }, - { - type : 'text', - id : 'vSpace', - style : 'width:95px', - label : editor.lang.flash.vSpace, - validate : CKEDITOR.dialog.validate.integer( editor.lang.flash.validateVSpace ), - setup : loadValue, - commit : commitValue - } - ] - }, - - { - type : 'vbox', - children : - [ - { - type : 'html', - id : 'preview', - style : 'width:95%;', - html : previewAreaHtml - } - ] - } - ] - }, - { - id : 'Upload', - hidden : true, - filebrowser : 'uploadButton', - label : editor.lang.common.upload, - elements : - [ - { - type : 'file', - id : 'upload', - label : editor.lang.common.upload, - size : 38 - }, - { - type : 'fileButton', - id : 'uploadButton', - label : editor.lang.common.uploadSubmit, - filebrowser : 'info:src', - 'for' : [ 'Upload', 'upload' ] - } - ] - }, - { - id : 'properties', - label : editor.lang.flash.propertiesTab, - elements : - [ - { - type : 'hbox', - widths : [ '50%', '50%' ], - children : - [ - { - id : 'scale', - type : 'select', - label : editor.lang.flash.scale, - 'default' : '', - style : 'width : 100%;', - items : - [ - [ editor.lang.common.notSet , ''], - [ editor.lang.flash.scaleAll, 'showall' ], - [ editor.lang.flash.scaleNoBorder, 'noborder' ], - [ editor.lang.flash.scaleFit, 'exactfit' ] - ], - setup : loadValue, - commit : commitValue - }, - { - id : 'allowScriptAccess', - type : 'select', - label : editor.lang.flash.access, - 'default' : '', - style : 'width : 100%;', - items : - [ - [ editor.lang.common.notSet , ''], - [ editor.lang.flash.accessAlways, 'always' ], - [ editor.lang.flash.accessSameDomain, 'samedomain' ], - [ editor.lang.flash.accessNever, 'never' ] - ], - setup : loadValue, - commit : commitValue - } - ] - }, - { - type : 'hbox', - widths : [ '50%', '50%' ], - children : - [ - { - id : 'wmode', - type : 'select', - label : editor.lang.flash.windowMode, - 'default' : '', - style : 'width : 100%;', - items : - [ - [ editor.lang.common.notSet , '' ], - [ editor.lang.flash.windowModeWindow, 'window' ], - [ editor.lang.flash.windowModeOpaque, 'opaque' ], - [ editor.lang.flash.windowModeTransparent, 'transparent' ] - ], - setup : loadValue, - commit : commitValue - }, - { - id : 'quality', - type : 'select', - label : editor.lang.flash.quality, - 'default' : 'high', - style : 'width : 100%;', - items : - [ - [ editor.lang.common.notSet , '' ], - [ editor.lang.flash.qualityBest, 'best' ], - [ editor.lang.flash.qualityHigh, 'high' ], - [ editor.lang.flash.qualityAutoHigh, 'autohigh' ], - [ editor.lang.flash.qualityMedium, 'medium' ], - [ editor.lang.flash.qualityAutoLow, 'autolow' ], - [ editor.lang.flash.qualityLow, 'low' ] - ], - setup : loadValue, - commit : commitValue - } - ] - }, - { - type : 'hbox', - widths : [ '50%', '50%' ], - children : - [ - { - id : 'align', - type : 'select', - label : editor.lang.common.align, - 'default' : '', - style : 'width : 100%;', - items : - [ - [ editor.lang.common.notSet , ''], - [ editor.lang.common.alignLeft , 'left'], - [ editor.lang.flash.alignAbsBottom , 'absBottom'], - [ editor.lang.flash.alignAbsMiddle , 'absMiddle'], - [ editor.lang.flash.alignBaseline , 'baseline'], - [ editor.lang.common.alignBottom , 'bottom'], - [ editor.lang.common.alignMiddle , 'middle'], - [ editor.lang.common.alignRight , 'right'], - [ editor.lang.flash.alignTextTop , 'textTop'], - [ editor.lang.common.alignTop , 'top'] - ], - setup : loadValue, - commit : function( objectNode, embedNode, paramMap, extraStyles, extraAttributes ) - { - var value = this.getValue(); - commitValue.apply( this, arguments ); - value && ( extraAttributes.align = value ); - } - }, - { - type : 'html', - html : '
      ' - } - ] - }, - { - type : 'fieldset', - label : CKEDITOR.tools.htmlEncode( editor.lang.flash.flashvars ), - children : - [ - { - type : 'vbox', - padding : 0, - children : - [ - { - type : 'checkbox', - id : 'menu', - label : editor.lang.flash.chkMenu, - 'default' : true, - setup : loadValue, - commit : commitValue - }, - { - type : 'checkbox', - id : 'play', - label : editor.lang.flash.chkPlay, - 'default' : true, - setup : loadValue, - commit : commitValue - }, - { - type : 'checkbox', - id : 'loop', - label : editor.lang.flash.chkLoop, - 'default' : true, - setup : loadValue, - commit : commitValue - }, - { - type : 'checkbox', - id : 'allowFullScreen', - label : editor.lang.flash.chkFull, - 'default' : true, - setup : loadValue, - commit : commitValue - } - ] - } - ] - } - ] - }, - { - id : 'advanced', - label : editor.lang.common.advancedTab, - elements : - [ - { - type : 'hbox', - widths : [ '45%', '55%' ], - children : - [ - { - type : 'text', - id : 'id', - label : editor.lang.common.id, - setup : loadValue, - commit : commitValue - }, - { - type : 'text', - id : 'title', - label : editor.lang.common.advisoryTitle, - setup : loadValue, - commit : commitValue - } - ] - }, - { - type : 'hbox', - widths : [ '45%', '55%' ], - children : - [ - { - type : 'text', - id : 'bgcolor', - label : editor.lang.flash.bgcolor, - setup : loadValue, - commit : commitValue - }, - { - type : 'text', - id : 'class', - label : editor.lang.common.cssClass, - setup : loadValue, - commit : commitValue - } - ] - }, - { - type : 'text', - id : 'style', - validate : CKEDITOR.dialog.validate.inlineStyle( editor.lang.common.invalidInlineStyle ), - label : editor.lang.common.cssStyle, - setup : loadValue, - commit : commitValue - } - ] - } - ] - }; - } ); -})(); diff --git a/media/ckeditor/_source/plugins/flash/images/placeholder.png b/media/ckeditor/_source/plugins/flash/images/placeholder.png deleted file mode 100644 index 0bc6caa..0000000 Binary files a/media/ckeditor/_source/plugins/flash/images/placeholder.png and /dev/null differ diff --git a/media/ckeditor/_source/plugins/flash/plugin.js b/media/ckeditor/_source/plugins/flash/plugin.js deleted file mode 100644 index 2937eaf..0000000 --- a/media/ckeditor/_source/plugins/flash/plugin.js +++ /dev/null @@ -1,154 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -(function() -{ - var flashFilenameRegex = /\.swf(?:$|\?)/i; - - function isFlashEmbed( element ) - { - var attributes = element.attributes; - - return ( attributes.type == 'application/x-shockwave-flash' || flashFilenameRegex.test( attributes.src || '' ) ); - } - - function createFakeElement( editor, realElement ) - { - return editor.createFakeParserElement( realElement, 'cke_flash', 'flash', true ); - } - - CKEDITOR.plugins.add( 'flash', - { - init : function( editor ) - { - editor.addCommand( 'flash', new CKEDITOR.dialogCommand( 'flash' ) ); - editor.ui.addButton( 'Flash', - { - label : editor.lang.common.flash, - command : 'flash' - }); - CKEDITOR.dialog.add( 'flash', this.path + 'dialogs/flash.js' ); - - editor.addCss( - 'img.cke_flash' + - '{' + - 'background-image: url(' + CKEDITOR.getUrl( this.path + 'images/placeholder.png' ) + ');' + - 'background-position: center center;' + - 'background-repeat: no-repeat;' + - 'border: 1px solid #a9a9a9;' + - 'width: 80px;' + - 'height: 80px;' + - '}' - ); - - // If the "menu" plugin is loaded, register the menu items. - if ( editor.addMenuItems ) - { - editor.addMenuItems( - { - flash : - { - label : editor.lang.flash.properties, - command : 'flash', - group : 'flash' - } - }); - } - - editor.on( 'doubleclick', function( evt ) - { - var element = evt.data.element; - - if ( element.is( 'img' ) && element.data( 'cke-real-element-type' ) == 'flash' ) - evt.data.dialog = 'flash'; - }); - - // If the "contextmenu" plugin is loaded, register the listeners. - if ( editor.contextMenu ) - { - editor.contextMenu.addListener( function( element, selection ) - { - if ( element && element.is( 'img' ) && !element.isReadOnly() - && element.data( 'cke-real-element-type' ) == 'flash' ) - return { flash : CKEDITOR.TRISTATE_OFF }; - }); - } - }, - - afterInit : function( editor ) - { - var dataProcessor = editor.dataProcessor, - dataFilter = dataProcessor && dataProcessor.dataFilter; - - if ( dataFilter ) - { - dataFilter.addRules( - { - elements : - { - 'cke:object' : function( element ) - { - var attributes = element.attributes, - classId = attributes.classid && String( attributes.classid ).toLowerCase(); - - if ( !classId && !isFlashEmbed( element ) ) - { - // Look for the inner - for ( var i = 0 ; i < element.children.length ; i++ ) - { - if ( element.children[ i ].name == 'cke:embed' ) - { - if ( !isFlashEmbed( element.children[ i ] ) ) - return null; - - return createFakeElement( editor, element ); - } - } - return null; - } - - return createFakeElement( editor, element ); - }, - - 'cke:embed' : function( element ) - { - if ( !isFlashEmbed( element ) ) - return null; - - return createFakeElement( editor, element ); - } - } - }, - 5); - } - }, - - requires : [ 'fakeobjects' ] - }); -})(); - -CKEDITOR.tools.extend( CKEDITOR.config, -{ - /** - * Save as EMBED tag only. This tag is unrecommended. - * @type Boolean - * @default false - */ - flashEmbedTagOnly : false, - - /** - * Add EMBED tag as alternative: <object><embed></embed></object> - * @type Boolean - * @default false - */ - flashAddEmbedTag : true, - - /** - * Use embedTagOnly and addEmbedTag values on edit. - * @type Boolean - * @default false - */ - flashConvertOnEdit : false -} ); diff --git a/media/ckeditor/_source/plugins/floatpanel/plugin.js b/media/ckeditor/_source/plugins/floatpanel/plugin.js deleted file mode 100644 index fa6afc0..0000000 --- a/media/ckeditor/_source/plugins/floatpanel/plugin.js +++ /dev/null @@ -1,476 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -CKEDITOR.plugins.add( 'floatpanel', -{ - requires : [ 'panel' ] -}); - -(function() -{ - var panels = {}; - var isShowing = false; - - function getPanel( editor, doc, parentElement, definition, level ) - { - // Generates the panel key: docId-eleId-skinName-langDir[-uiColor][-CSSs][-level] - var key = CKEDITOR.tools.genKey( doc.getUniqueId(), parentElement.getUniqueId(), editor.skinName, editor.lang.dir, - editor.uiColor || '', definition.css || '', level || '' ); - - var panel = panels[ key ]; - - if ( !panel ) - { - panel = panels[ key ] = new CKEDITOR.ui.panel( doc, definition ); - panel.element = parentElement.append( CKEDITOR.dom.element.createFromHtml( panel.renderHtml( editor ), doc ) ); - - panel.element.setStyles( - { - display : 'none', - position : 'absolute' - }); - } - - return panel; - } - - CKEDITOR.ui.floatPanel = CKEDITOR.tools.createClass( - { - $ : function( editor, parentElement, definition, level ) - { - definition.forceIFrame = 1; - - var doc = parentElement.getDocument(), - panel = getPanel( editor, doc, parentElement, definition, level || 0 ), - element = panel.element, - iframe = element.getFirst().getFirst(); - - // Disable native browser menu. (#4825) - element.disableContextMenu(); - - this.element = element; - - this._ = - { - editor : editor, - // The panel that will be floating. - panel : panel, - parentElement : parentElement, - definition : definition, - document : doc, - iframe : iframe, - children : [], - dir : editor.lang.dir - }; - - editor.on( 'mode', function(){ this.hide(); }, this ); - }, - - proto : - { - addBlock : function( name, block ) - { - return this._.panel.addBlock( name, block ); - }, - - addListBlock : function( name, multiSelect ) - { - return this._.panel.addListBlock( name, multiSelect ); - }, - - getBlock : function( name ) - { - return this._.panel.getBlock( name ); - }, - - /* - corner (LTR): - 1 = top-left - 2 = top-right - 3 = bottom-right - 4 = bottom-left - - corner (RTL): - 1 = top-right - 2 = top-left - 3 = bottom-left - 4 = bottom-right - */ - showBlock : function( name, offsetParent, corner, offsetX, offsetY ) - { - var panel = this._.panel, - block = panel.showBlock( name ); - - this.allowBlur( false ); - isShowing = 1; - - // Record from where the focus is when open panel. - this._.returnFocus = this._.editor.focusManager.hasFocus ? this._.editor : new CKEDITOR.dom.element( CKEDITOR.document.$.activeElement ); - - - var element = this.element, - iframe = this._.iframe, - definition = this._.definition, - position = offsetParent.getDocumentPosition( element.getDocument() ), - rtl = this._.dir == 'rtl'; - - var left = position.x + ( offsetX || 0 ), - top = position.y + ( offsetY || 0 ); - - // Floating panels are off by (-1px, 0px) in RTL mode. (#3438) - if ( rtl && ( corner == 1 || corner == 4 ) ) - left += offsetParent.$.offsetWidth; - else if ( !rtl && ( corner == 2 || corner == 3 ) ) - left += offsetParent.$.offsetWidth - 1; - - if ( corner == 3 || corner == 4 ) - top += offsetParent.$.offsetHeight - 1; - - // Memorize offsetParent by it's ID. - this._.panel._.offsetParentId = offsetParent.getId(); - - element.setStyles( - { - top : top + 'px', - left: 0, - display : '' - }); - - // Don't use display or visibility style because we need to - // calculate the rendering layout later and focus the element. - element.setOpacity( 0 ); - - // To allow the context menu to decrease back their width - element.getFirst().removeStyle( 'width' ); - - // Configure the IFrame blur event. Do that only once. - if ( !this._.blurSet ) - { - // Non IE prefer the event into a window object. - var focused = CKEDITOR.env.ie ? iframe : new CKEDITOR.dom.window( iframe.$.contentWindow ); - - // With addEventListener compatible browsers, we must - // useCapture when registering the focus/blur events to - // guarantee they will be firing in all situations. (#3068, #3222 ) - CKEDITOR.event.useCapture = true; - - focused.on( 'blur', function( ev ) - { - if ( !this.allowBlur() ) - return; - - // As we are using capture to register the listener, - // the blur event may get fired even when focusing - // inside the window itself, so we must ensure the - // target is out of it. - var target = ev.data.getTarget() ; - if ( target.getName && target.getName() != 'iframe' ) - return; - - if ( this.visible && !this._.activeChild && !isShowing ) - { - // Panel close is caused by user's navigating away the focus, e.g. click outside the panel. - // DO NOT restore focus in this case. - delete this._.returnFocus; - this.hide(); - } - }, - this ); - - focused.on( 'focus', function() - { - this._.focused = true; - this.hideChild(); - this.allowBlur( true ); - }, - this ); - - CKEDITOR.event.useCapture = false; - - this._.blurSet = 1; - } - - panel.onEscape = CKEDITOR.tools.bind( function( keystroke ) - { - if ( this.onEscape && this.onEscape( keystroke ) === false ) - return false; - }, - this ); - - CKEDITOR.tools.setTimeout( function() - { - var panelLoad = CKEDITOR.tools.bind( function () - { - var target = element.getFirst(); - - if ( block.autoSize ) - { - // We must adjust first the width or IE6 could include extra lines in the height computation - var widthNode = block.element.$; - - if ( CKEDITOR.env.gecko || CKEDITOR.env.opera ) - widthNode = widthNode.parentNode; - - if ( CKEDITOR.env.ie ) - widthNode = widthNode.document.body; - - var width = widthNode.scrollWidth; - // Account for extra height needed due to IE quirks box model bug: - // http://en.wikipedia.org/wiki/Internet_Explorer_box_model_bug - // (#3426) - if ( CKEDITOR.env.ie && CKEDITOR.env.quirks && width > 0 ) - width += ( target.$.offsetWidth || 0 ) - ( target.$.clientWidth || 0 ) + 3; - // A little extra at the end. - // If not present, IE6 might break into the next line, but also it looks better this way - width += 4 ; - - target.setStyle( 'width', width + 'px' ); - - // IE doesn't compute the scrollWidth if a filter is applied previously - block.element.addClass( 'cke_frameLoaded' ); - - var height = block.element.$.scrollHeight; - - // Account for extra height needed due to IE quirks box model bug: - // http://en.wikipedia.org/wiki/Internet_Explorer_box_model_bug - // (#3426) - if ( CKEDITOR.env.ie && CKEDITOR.env.quirks && height > 0 ) - height += ( target.$.offsetHeight || 0 ) - ( target.$.clientHeight || 0 ) + 3; - - target.setStyle( 'height', height + 'px' ); - - // Fix IE < 8 visibility. - panel._.currentBlock.element.setStyle( 'display', 'none' ).removeStyle( 'display' ); - } - else - target.removeStyle( 'height' ); - - // Flip panel layout horizontally in RTL with known width. - if ( rtl ) - left -= element.$.offsetWidth; - - // Pop the style now for measurement. - element.setStyle( 'left', left + 'px' ); - - /* panel layout smartly fit the viewport size. */ - var panelElement = panel.element, - panelWindow = panelElement.getWindow(), - rect = element.$.getBoundingClientRect(), - viewportSize = panelWindow.getViewPaneSize(); - - // Compensation for browsers that dont support "width" and "height". - var rectWidth = rect.width || rect.right - rect.left, - rectHeight = rect.height || rect.bottom - rect.top; - - // Check if default horizontal layout is impossible. - var spaceAfter = rtl ? rect.right : viewportSize.width - rect.left, - spaceBefore = rtl ? viewportSize.width - rect.right : rect.left; - - if ( rtl ) - { - if ( spaceAfter < rectWidth ) - { - // Flip to show on right. - if ( spaceBefore > rectWidth ) - left += rectWidth; - // Align to window left. - else if ( viewportSize.width > rectWidth ) - left = left - rect.left; - // Align to window right, never cutting the panel at right. - else - left = left - rect.right + viewportSize.width; - } - } - else if ( spaceAfter < rectWidth ) - { - // Flip to show on left. - if ( spaceBefore > rectWidth ) - left -= rectWidth; - // Align to window right. - else if ( viewportSize.width > rectWidth ) - left = left - rect.right + viewportSize.width; - // Align to window left, never cutting the panel at left. - else - left = left - rect.left; - } - - - // Check if the default vertical layout is possible. - var spaceBelow = viewportSize.height - rect.top, - spaceAbove = rect.top; - - if ( spaceBelow < rectHeight ) - { - // Flip to show above. - if ( spaceAbove > rectHeight ) - top -= rectHeight; - // Align to window bottom. - else if ( viewportSize.height > rectHeight ) - top = top - rect.bottom + viewportSize.height; - // Align to top, never cutting the panel at top. - else - top = top - rect.top; - } - - // If IE is in RTL, we have troubles with absolute - // position and horizontal scrolls. Here we have a - // series of hacks to workaround it. (#6146) - if ( CKEDITOR.env.ie ) - { - var offsetParent = new CKEDITOR.dom.element( element.$.offsetParent ), - scrollParent = offsetParent; - - // Quirks returns , but standards returns . - if ( scrollParent.getName() == 'html' ) - scrollParent = scrollParent.getDocument().getBody(); - - if ( scrollParent.getComputedStyle( 'direction' ) == 'rtl' ) - { - // For IE8, there is not much logic on this, but it works. - if ( CKEDITOR.env.ie8Compat ) - left -= element.getDocument().getDocumentElement().$.scrollLeft * 2; - else - left -= ( offsetParent.$.scrollWidth - offsetParent.$.clientWidth ); - } - } - - // Trigger the onHide event of the previously active panel to prevent - // incorrect styles from being applied (#6170) - var innerElement = element.getFirst(), - activePanel; - if ( ( activePanel = innerElement.getCustomData( 'activePanel' ) ) ) - activePanel.onHide && activePanel.onHide.call( this, 1 ); - innerElement.setCustomData( 'activePanel', this ); - - element.setStyles( - { - top : top + 'px', - left : left + 'px' - } ); - element.setOpacity( 1 ); - } , this ); - - panel.isLoaded ? panelLoad() : panel.onLoad = panelLoad; - - // Set the panel frame focus, so the blur event gets fired. - CKEDITOR.tools.setTimeout( function() - { - iframe.$.contentWindow.focus(); - // We need this get fired manually because of unfired focus() function. - this.allowBlur( true ); - }, 0, this); - }, CKEDITOR.env.air ? 200 : 0, this); - this.visible = 1; - - if ( this.onShow ) - this.onShow.call( this ); - - isShowing = 0; - }, - - hide : function( returnFocus ) - { - if ( this.visible && ( !this.onHide || this.onHide.call( this ) !== true ) ) - { - this.hideChild(); - // Blur previously focused element. (#6671) - CKEDITOR.env.gecko && this._.iframe.getFrameDocument().$.activeElement.blur(); - this.element.setStyle( 'display', 'none' ); - this.visible = 0; - this.element.getFirst().removeCustomData( 'activePanel' ); - - // Return focus properly. (#6247) - var focusReturn = returnFocus !== false && this._.returnFocus; - if ( focusReturn ) - { - // Webkit requires focus moved out panel iframe first. - if ( CKEDITOR.env.webkit && focusReturn.type ) - focusReturn.getWindow().$.focus(); - - focusReturn.focus(); - } - } - }, - - allowBlur : function( allow ) // Prevent editor from hiding the panel. #3222. - { - var panel = this._.panel; - if ( allow != undefined ) - panel.allowBlur = allow; - - return panel.allowBlur; - }, - - showAsChild : function( panel, blockName, offsetParent, corner, offsetX, offsetY ) - { - // Skip reshowing of child which is already visible. - if ( this._.activeChild == panel && panel._.panel._.offsetParentId == offsetParent.getId() ) - return; - - this.hideChild(); - - panel.onHide = CKEDITOR.tools.bind( function() - { - // Use a timeout, so we give time for this menu to get - // potentially focused. - CKEDITOR.tools.setTimeout( function() - { - if ( !this._.focused ) - this.hide(); - }, - 0, this ); - }, - this ); - - this._.activeChild = panel; - this._.focused = false; - - panel.showBlock( blockName, offsetParent, corner, offsetX, offsetY ); - - /* #3767 IE: Second level menu may not have borders */ - if ( CKEDITOR.env.ie7Compat || ( CKEDITOR.env.ie8 && CKEDITOR.env.ie6Compat ) ) - { - setTimeout(function() - { - panel.element.getChild( 0 ).$.style.cssText += ''; - }, 100); - } - }, - - hideChild : function() - { - var activeChild = this._.activeChild; - - if ( activeChild ) - { - delete activeChild.onHide; - // Sub panels don't manage focus. (#7881) - delete activeChild._.returnFocus; - delete this._.activeChild; - activeChild.hide(); - } - } - } - }); - - CKEDITOR.on( 'instanceDestroyed', function() - { - var isLastInstance = CKEDITOR.tools.isEmpty( CKEDITOR.instances ); - - for ( var i in panels ) - { - var panel = panels[ i ]; - // Safe to destroy it since there're no more instances.(#4241) - if ( isLastInstance ) - panel.destroy(); - // Panel might be used by other instances, just hide them.(#4552) - else - panel.element.hide(); - } - // Remove the registration. - isLastInstance && ( panels = {} ); - - } ); -})(); diff --git a/media/ckeditor/_source/plugins/font/plugin.js b/media/ckeditor/_source/plugins/font/plugin.js deleted file mode 100644 index 643654c..0000000 --- a/media/ckeditor/_source/plugins/font/plugin.js +++ /dev/null @@ -1,234 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -(function() -{ - function addCombo( editor, comboName, styleType, lang, entries, defaultLabel, styleDefinition ) - { - var config = editor.config; - - // Gets the list of fonts from the settings. - var names = entries.split( ';' ), - values = []; - - // Create style objects for all fonts. - var styles = {}; - for ( var i = 0 ; i < names.length ; i++ ) - { - var parts = names[ i ]; - - if ( parts ) - { - parts = parts.split( '/' ); - - var vars = {}, - name = names[ i ] = parts[ 0 ]; - - vars[ styleType ] = values[ i ] = parts[ 1 ] || name; - - styles[ name ] = new CKEDITOR.style( styleDefinition, vars ); - styles[ name ]._.definition.name = name; - } - else - names.splice( i--, 1 ); - } - - editor.ui.addRichCombo( comboName, - { - label : lang.label, - title : lang.panelTitle, - className : 'cke_' + ( styleType == 'size' ? 'fontSize' : 'font' ), - panel : - { - css : editor.skin.editor.css.concat( config.contentsCss ), - multiSelect : false, - attributes : { 'aria-label' : lang.panelTitle } - }, - - init : function() - { - this.startGroup( lang.panelTitle ); - - for ( var i = 0 ; i < names.length ; i++ ) - { - var name = names[ i ]; - - // Add the tag entry to the panel list. - this.add( name, styles[ name ].buildPreview(), name ); - } - }, - - onClick : function( value ) - { - editor.focus(); - editor.fire( 'saveSnapshot' ); - - var style = styles[ value ]; - - if ( this.getValue() == value ) - style.remove( editor.document ); - else - style.apply( editor.document ); - - editor.fire( 'saveSnapshot' ); - }, - - onRender : function() - { - editor.on( 'selectionChange', function( ev ) - { - var currentValue = this.getValue(); - - var elementPath = ev.data.path, - elements = elementPath.elements; - - // For each element into the elements path. - for ( var i = 0, element ; i < elements.length ; i++ ) - { - element = elements[i]; - - // Check if the element is removable by any of - // the styles. - for ( var value in styles ) - { - if ( styles[ value ].checkElementRemovable( element, true ) ) - { - if ( value != currentValue ) - this.setValue( value ); - return; - } - } - } - - // If no styles match, just empty it. - this.setValue( '', defaultLabel ); - }, - this); - } - }); - } - - CKEDITOR.plugins.add( 'font', - { - requires : [ 'richcombo', 'styles' ], - - init : function( editor ) - { - var config = editor.config; - - addCombo( editor, 'Font', 'family', editor.lang.font, config.font_names, config.font_defaultLabel, config.font_style ); - addCombo( editor, 'FontSize', 'size', editor.lang.fontSize, config.fontSize_sizes, config.fontSize_defaultLabel, config.fontSize_style ); - } - }); -})(); - -/** - * The list of fonts names to be displayed in the Font combo in the toolbar. - * Entries are separated by semi-colons (;), while it's possible to have more - * than one font for each entry, in the HTML way (separated by comma). - * - * A display name may be optionally defined by prefixing the entries with the - * name and the slash character. For example, "Arial/Arial, Helvetica, sans-serif" - * will be displayed as "Arial" in the list, but will be outputted as - * "Arial, Helvetica, sans-serif". - * @type String - * @example - * config.font_names = - * 'Arial/Arial, Helvetica, sans-serif;' + - * 'Times New Roman/Times New Roman, Times, serif;' + - * 'Verdana'; - * @example - * config.font_names = 'Arial;Times New Roman;Verdana'; - */ -CKEDITOR.config.font_names = - 'Arial/Arial, Helvetica, sans-serif;' + - 'Comic Sans MS/Comic Sans MS, cursive;' + - 'Courier New/Courier New, Courier, monospace;' + - 'Georgia/Georgia, serif;' + - 'Lucida Sans Unicode/Lucida Sans Unicode, Lucida Grande, sans-serif;' + - 'Tahoma/Tahoma, Geneva, sans-serif;' + - 'Times New Roman/Times New Roman, Times, serif;' + - 'Trebuchet MS/Trebuchet MS, Helvetica, sans-serif;' + - 'Verdana/Verdana, Geneva, sans-serif'; - -/** - * The text to be displayed in the Font combo is none of the available values - * matches the current cursor position or text selection. - * @type String - * @example - * // If the default site font is Arial, we may making it more explicit to the end user. - * config.font_defaultLabel = 'Arial'; - */ -CKEDITOR.config.font_defaultLabel = ''; - -/** - * The style definition to be used to apply the font in the text. - * @type Object - * @example - * // This is actually the default value for it. - * config.font_style = - * { - * element : 'span', - * styles : { 'font-family' : '#(family)' }, - * overrides : [ { element : 'font', attributes : { 'face' : null } } ] - * }; - */ -CKEDITOR.config.font_style = - { - element : 'span', - styles : { 'font-family' : '#(family)' }, - overrides : [ { element : 'font', attributes : { 'face' : null } } ] - }; - -/** - * The list of fonts size to be displayed in the Font Size combo in the - * toolbar. Entries are separated by semi-colons (;). - * - * Any kind of "CSS like" size can be used, like "12px", "2.3em", "130%", - * "larger" or "x-small". - * - * A display name may be optionally defined by prefixing the entries with the - * name and the slash character. For example, "Bigger Font/14px" will be - * displayed as "Bigger Font" in the list, but will be outputted as "14px". - * @type String - * @default '8/8px;9/9px;10/10px;11/11px;12/12px;14/14px;16/16px;18/18px;20/20px;22/22px;24/24px;26/26px;28/28px;36/36px;48/48px;72/72px' - * @example - * config.fontSize_sizes = '16/16px;24/24px;48/48px;'; - * @example - * config.fontSize_sizes = '12px;2.3em;130%;larger;x-small'; - * @example - * config.fontSize_sizes = '12 Pixels/12px;Big/2.3em;30 Percent More/130%;Bigger/larger;Very Small/x-small'; - */ -CKEDITOR.config.fontSize_sizes = - '8/8px;9/9px;10/10px;11/11px;12/12px;14/14px;16/16px;18/18px;20/20px;22/22px;24/24px;26/26px;28/28px;36/36px;48/48px;72/72px'; - -/** - * The text to be displayed in the Font Size combo is none of the available - * values matches the current cursor position or text selection. - * @type String - * @example - * // If the default site font size is 12px, we may making it more explicit to the end user. - * config.fontSize_defaultLabel = '12px'; - */ -CKEDITOR.config.fontSize_defaultLabel = ''; - -/** - * The style definition to be used to apply the font size in the text. - * @type Object - * @example - * // This is actually the default value for it. - * config.fontSize_style = - * { - * element : 'span', - * styles : { 'font-size' : '#(size)' }, - * overrides : [ { element : 'font', attributes : { 'size' : null } } ] - * }; - */ -CKEDITOR.config.fontSize_style = - { - element : 'span', - styles : { 'font-size' : '#(size)' }, - overrides : [ { element : 'font', attributes : { 'size' : null } } ] - }; diff --git a/media/ckeditor/_source/plugins/format/plugin.js b/media/ckeditor/_source/plugins/format/plugin.js deleted file mode 100644 index 5ddd8ff..0000000 --- a/media/ckeditor/_source/plugins/format/plugin.js +++ /dev/null @@ -1,197 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -CKEDITOR.plugins.add( 'format', -{ - requires : [ 'richcombo', 'styles' ], - - init : function( editor ) - { - var config = editor.config, - lang = editor.lang.format; - - // Gets the list of tags from the settings. - var tags = config.format_tags.split( ';' ); - - // Create style objects for all defined styles. - var styles = {}; - for ( var i = 0 ; i < tags.length ; i++ ) - { - var tag = tags[ i ]; - styles[ tag ] = new CKEDITOR.style( config[ 'format_' + tag ] ); - styles[ tag ]._.enterMode = editor.config.enterMode; - } - - editor.ui.addRichCombo( 'Format', - { - label : lang.label, - title : lang.panelTitle, - className : 'cke_format', - panel : - { - css : editor.skin.editor.css.concat( config.contentsCss ), - multiSelect : false, - attributes : { 'aria-label' : lang.panelTitle } - }, - - init : function() - { - this.startGroup( lang.panelTitle ); - - for ( var tag in styles ) - { - var label = lang[ 'tag_' + tag ]; - - // Add the tag entry to the panel list. - this.add( tag, styles[tag].buildPreview( label ), label ); - } - }, - - onClick : function( value ) - { - editor.focus(); - editor.fire( 'saveSnapshot' ); - - var style = styles[ value ], - elementPath = new CKEDITOR.dom.elementPath( editor.getSelection().getStartElement() ); - - style[ style.checkActive( elementPath ) ? 'remove' : 'apply' ]( editor.document ); - - // Save the undo snapshot after all changes are affected. (#4899) - setTimeout( function() - { - editor.fire( 'saveSnapshot' ); - }, 0 ); - }, - - onRender : function() - { - editor.on( 'selectionChange', function( ev ) - { - var currentTag = this.getValue(); - - var elementPath = ev.data.path; - - for ( var tag in styles ) - { - if ( styles[ tag ].checkActive( elementPath ) ) - { - if ( tag != currentTag ) - this.setValue( tag, editor.lang.format[ 'tag_' + tag ] ); - return; - } - } - - // If no styles match, just empty it. - this.setValue( '' ); - }, - this); - } - }); - } -}); - -/** - * A list of semi colon separated style names (by default tags) representing - * the style definition for each entry to be displayed in the Format combo in - * the toolbar. Each entry must have its relative definition configuration in a - * setting named "format_(tagName)". For example, the "p" entry has its - * definition taken from config.format_p. - * @type String - * @default 'p;h1;h2;h3;h4;h5;h6;pre;address;div' - * @example - * config.format_tags = 'p;h2;h3;pre' - */ -CKEDITOR.config.format_tags = 'p;h1;h2;h3;h4;h5;h6;pre;address;div'; - -/** - * The style definition to be used to apply the "Normal" format. - * @type Object - * @default { element : 'p' } - * @example - * config.format_p = { element : 'p', attributes : { 'class' : 'normalPara' } }; - */ -CKEDITOR.config.format_p = { element : 'p' }; - -/** - * The style definition to be used to apply the "Normal (DIV)" format. - * @type Object - * @default { element : 'div' } - * @example - * config.format_div = { element : 'div', attributes : { 'class' : 'normalDiv' } }; - */ -CKEDITOR.config.format_div = { element : 'div' }; - -/** - * The style definition to be used to apply the "Formatted" format. - * @type Object - * @default { element : 'pre' } - * @example - * config.format_pre = { element : 'pre', attributes : { 'class' : 'code' } }; - */ -CKEDITOR.config.format_pre = { element : 'pre' }; - -/** - * The style definition to be used to apply the "Address" format. - * @type Object - * @default { element : 'address' } - * @example - * config.format_address = { element : 'address', attributes : { 'class' : 'styledAddress' } }; - */ -CKEDITOR.config.format_address = { element : 'address' }; - -/** - * The style definition to be used to apply the "Heading 1" format. - * @type Object - * @default { element : 'h1' } - * @example - * config.format_h1 = { element : 'h1', attributes : { 'class' : 'contentTitle1' } }; - */ -CKEDITOR.config.format_h1 = { element : 'h1' }; - -/** - * The style definition to be used to apply the "Heading 1" format. - * @type Object - * @default { element : 'h2' } - * @example - * config.format_h2 = { element : 'h2', attributes : { 'class' : 'contentTitle2' } }; - */ -CKEDITOR.config.format_h2 = { element : 'h2' }; - -/** - * The style definition to be used to apply the "Heading 1" format. - * @type Object - * @default { element : 'h3' } - * @example - * config.format_h3 = { element : 'h3', attributes : { 'class' : 'contentTitle3' } }; - */ -CKEDITOR.config.format_h3 = { element : 'h3' }; - -/** - * The style definition to be used to apply the "Heading 1" format. - * @type Object - * @default { element : 'h4' } - * @example - * config.format_h4 = { element : 'h4', attributes : { 'class' : 'contentTitle4' } }; - */ -CKEDITOR.config.format_h4 = { element : 'h4' }; - -/** - * The style definition to be used to apply the "Heading 1" format. - * @type Object - * @default { element : 'h5' } - * @example - * config.format_h5 = { element : 'h5', attributes : { 'class' : 'contentTitle5' } }; - */ -CKEDITOR.config.format_h5 = { element : 'h5' }; - -/** - * The style definition to be used to apply the "Heading 1" format. - * @type Object - * @default { element : 'h6' } - * @example - * config.format_h6 = { element : 'h6', attributes : { 'class' : 'contentTitle6' } }; - */ -CKEDITOR.config.format_h6 = { element : 'h6' }; diff --git a/media/ckeditor/_source/plugins/forms/dialogs/button.js b/media/ckeditor/_source/plugins/forms/dialogs/button.js deleted file mode 100644 index cba69e1..0000000 --- a/media/ckeditor/_source/plugins/forms/dialogs/button.js +++ /dev/null @@ -1,118 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ -CKEDITOR.dialog.add( 'button', function( editor ) -{ - function commitAttributes( element ) - { - var val = this.getValue(); - if ( val ) - { - element.attributes[ this.id ] = val; - if ( this.id == 'name' ) - element.attributes[ 'data-cke-saved-name' ] = val; - } - else - { - delete element.attributes[ this.id ]; - if ( this.id == 'name' ) - delete element.attributes[ 'data-cke-saved-name' ]; - } - } - - return { - title : editor.lang.button.title, - minWidth : 350, - minHeight : 150, - onShow : function() - { - delete this.button; - var element = this.getParentEditor().getSelection().getSelectedElement(); - if ( element && element.is( 'input' ) ) - { - var type = element.getAttribute( 'type' ); - if ( type in { button:1, reset:1, submit:1 } ) - { - this.button = element; - this.setupContent( element ); - } - } - }, - onOk : function() - { - var editor = this.getParentEditor(), - element = this.button, - isInsertMode = !element; - - var fake = element ? CKEDITOR.htmlParser.fragment.fromHtml( element.getOuterHtml() ).children[ 0 ] - : new CKEDITOR.htmlParser.element( 'input' ); - this.commitContent( fake ); - - var writer = new CKEDITOR.htmlParser.basicWriter(); - fake.writeHtml( writer ); - var newElement = CKEDITOR.dom.element.createFromHtml( writer.getHtml(), editor.document ); - - if ( isInsertMode ) - editor.insertElement( newElement ); - else - { - newElement.replace( element ); - editor.getSelection().selectElement( newElement ); - } - }, - contents : [ - { - id : 'info', - label : editor.lang.button.title, - title : editor.lang.button.title, - elements : [ - { - id : 'name', - type : 'text', - label : editor.lang.common.name, - 'default' : '', - setup : function( element ) - { - this.setValue( - element.data( 'cke-saved-name' ) || - element.getAttribute( 'name' ) || - '' ); - }, - commit : commitAttributes - }, - { - id : 'value', - type : 'text', - label : editor.lang.button.text, - accessKey : 'V', - 'default' : '', - setup : function( element ) - { - this.setValue( element.getAttribute( 'value' ) || '' ); - }, - commit : commitAttributes - }, - { - id : 'type', - type : 'select', - label : editor.lang.button.type, - 'default' : 'button', - accessKey : 'T', - items : - [ - [ editor.lang.button.typeBtn, 'button' ], - [ editor.lang.button.typeSbm, 'submit' ], - [ editor.lang.button.typeRst, 'reset' ] - ], - setup : function( element ) - { - this.setValue( element.getAttribute( 'type' ) || '' ); - }, - commit : commitAttributes - } - ] - } - ] - }; -}); diff --git a/media/ckeditor/_source/plugins/forms/dialogs/checkbox.js b/media/ckeditor/_source/plugins/forms/dialogs/checkbox.js deleted file mode 100644 index 9f0f2a3..0000000 --- a/media/ckeditor/_source/plugins/forms/dialogs/checkbox.js +++ /dev/null @@ -1,153 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ -CKEDITOR.dialog.add( 'checkbox', function( editor ) -{ - return { - title : editor.lang.checkboxAndRadio.checkboxTitle, - minWidth : 350, - minHeight : 140, - onShow : function() - { - delete this.checkbox; - - var element = this.getParentEditor().getSelection().getSelectedElement(); - - if ( element && element.getAttribute( 'type' ) == 'checkbox' ) - { - this.checkbox = element; - this.setupContent( element ); - } - }, - onOk : function() - { - var editor, - element = this.checkbox, - isInsertMode = !element; - - if ( isInsertMode ) - { - editor = this.getParentEditor(); - element = editor.document.createElement( 'input' ); - element.setAttribute( 'type', 'checkbox' ); - editor.insertElement( element ); - } - this.commitContent( { element : element } ); - }, - contents : [ - { - id : 'info', - label : editor.lang.checkboxAndRadio.checkboxTitle, - title : editor.lang.checkboxAndRadio.checkboxTitle, - startupFocus : 'txtName', - elements : [ - { - id : 'txtName', - type : 'text', - label : editor.lang.common.name, - 'default' : '', - accessKey : 'N', - setup : function( element ) - { - this.setValue( - element.data( 'cke-saved-name' ) || - element.getAttribute( 'name' ) || - '' ); - }, - commit : function( data ) - { - var element = data.element; - - // IE failed to update 'name' property on input elements, protect it now. - if ( this.getValue() ) - element.data( 'cke-saved-name', this.getValue() ); - else - { - element.data( 'cke-saved-name', false ); - element.removeAttribute( 'name' ); - } - } - }, - { - id : 'txtValue', - type : 'text', - label : editor.lang.checkboxAndRadio.value, - 'default' : '', - accessKey : 'V', - setup : function( element ) - { - var value = element.getAttribute( 'value' ); - // IE Return 'on' as default attr value. - this.setValue( CKEDITOR.env.ie && value == 'on' ? '' : value ); - }, - commit : function( data ) - { - var element = data.element, - value = this.getValue(); - - if ( value && !( CKEDITOR.env.ie && value == 'on' ) ) - element.setAttribute( 'value', value ); - else - { - if ( CKEDITOR.env.ie ) - { - // Remove attribute 'value' of checkbox (#4721). - var checkbox = new CKEDITOR.dom.element( 'input', element.getDocument() ); - element.copyAttributes( checkbox, { value: 1 } ); - checkbox.replace( element ); - editor.getSelection().selectElement( checkbox ); - data.element = checkbox; - } - else - element.removeAttribute( 'value' ); - } - } - }, - { - id : 'cmbSelected', - type : 'checkbox', - label : editor.lang.checkboxAndRadio.selected, - 'default' : '', - accessKey : 'S', - value : "checked", - setup : function( element ) - { - this.setValue( element.getAttribute( 'checked' ) ); - }, - commit : function( data ) - { - var element = data.element; - - if ( CKEDITOR.env.ie ) - { - var isElementChecked = !!element.getAttribute( 'checked' ), - isChecked = !!this.getValue(); - - if ( isElementChecked != isChecked ) - { - var replace = CKEDITOR.dom.element.createFromHtml( '', editor.document ); - - element.copyAttributes( replace, { type : 1, checked : 1 } ); - replace.replace( element ); - editor.getSelection().selectElement( replace ); - data.element = replace; - } - } - else - { - var value = this.getValue(); - if ( value ) - element.setAttribute( 'checked', 'checked' ); - else - element.removeAttribute( 'checked' ); - } - } - } - ] - } - ] - }; -}); diff --git a/media/ckeditor/_source/plugins/forms/dialogs/form.js b/media/ckeditor/_source/plugins/forms/dialogs/form.js deleted file mode 100644 index 764b3e6..0000000 --- a/media/ckeditor/_source/plugins/forms/dialogs/form.js +++ /dev/null @@ -1,177 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ -CKEDITOR.dialog.add( 'form', function( editor ) -{ - var autoAttributes = - { - action : 1, - id : 1, - method : 1, - enctype : 1, - target : 1 - }; - - return { - title : editor.lang.form.title, - minWidth : 350, - minHeight : 200, - onShow : function() - { - delete this.form; - - var element = this.getParentEditor().getSelection().getStartElement(); - var form = element && element.getAscendant( 'form', true ); - if ( form ) - { - this.form = form; - this.setupContent( form ); - } - }, - onOk : function() - { - var editor, - element = this.form, - isInsertMode = !element; - - if ( isInsertMode ) - { - editor = this.getParentEditor(); - element = editor.document.createElement( 'form' ); - !CKEDITOR.env.ie && element.append( editor.document.createElement( 'br' ) ); - } - - if ( isInsertMode ) - editor.insertElement( element ); - this.commitContent( element ); - }, - onLoad : function() - { - function autoSetup( element ) - { - this.setValue( element.getAttribute( this.id ) || '' ); - } - - function autoCommit( element ) - { - if ( this.getValue() ) - element.setAttribute( this.id, this.getValue() ); - else - element.removeAttribute( this.id ); - } - - this.foreach( function( contentObj ) - { - if ( autoAttributes[ contentObj.id ] ) - { - contentObj.setup = autoSetup; - contentObj.commit = autoCommit; - } - } ); - }, - contents : [ - { - id : 'info', - label : editor.lang.form.title, - title : editor.lang.form.title, - elements : [ - { - id : 'txtName', - type : 'text', - label : editor.lang.common.name, - 'default' : '', - accessKey : 'N', - setup : function( element ) - { - this.setValue( element.data( 'cke-saved-name' ) || - element.getAttribute( 'name' ) || - '' ); - }, - commit : function( element ) - { - if ( this.getValue() ) - element.data( 'cke-saved-name', this.getValue() ); - else - { - element.data( 'cke-saved-name', false ); - element.removeAttribute( 'name' ); - } - } - }, - { - id : 'action', - type : 'text', - label : editor.lang.form.action, - 'default' : '', - accessKey : 'T' - }, - { - type : 'hbox', - widths : [ '45%', '55%' ], - children : - [ - { - id : 'id', - type : 'text', - label : editor.lang.common.id, - 'default' : '', - accessKey : 'I' - }, - { - id : 'enctype', - type : 'select', - label : editor.lang.form.encoding, - style : 'width:100%', - accessKey : 'E', - 'default' : '', - items : - [ - [ '' ], - [ 'text/plain' ], - [ 'multipart/form-data' ], - [ 'application/x-www-form-urlencoded' ] - ] - } - ] - }, - { - type : 'hbox', - widths : [ '45%', '55%' ], - children : - [ - { - id : 'target', - type : 'select', - label : editor.lang.common.target, - style : 'width:100%', - accessKey : 'M', - 'default' : '', - items : - [ - [ editor.lang.common.notSet, '' ], - [ editor.lang.common.targetNew, '_blank' ], - [ editor.lang.common.targetTop, '_top' ], - [ editor.lang.common.targetSelf, '_self' ], - [ editor.lang.common.targetParent, '_parent' ] - ] - }, - { - id : 'method', - type : 'select', - label : editor.lang.form.method, - accessKey : 'M', - 'default' : 'GET', - items : - [ - [ 'GET', 'get' ], - [ 'POST', 'post' ] - ] - } - ] - } - ] - } - ] - }; -}); diff --git a/media/ckeditor/_source/plugins/forms/dialogs/hiddenfield.js b/media/ckeditor/_source/plugins/forms/dialogs/hiddenfield.js deleted file mode 100644 index f2a1da4..0000000 --- a/media/ckeditor/_source/plugins/forms/dialogs/hiddenfield.js +++ /dev/null @@ -1,100 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ -CKEDITOR.dialog.add( 'hiddenfield', function( editor ) -{ - return { - title : editor.lang.hidden.title, - hiddenField : null, - minWidth : 350, - minHeight : 110, - onShow : function() - { - delete this.hiddenField; - - var editor = this.getParentEditor(), - selection = editor.getSelection(), - element = selection.getSelectedElement(); - - if ( element && element.data( 'cke-real-element-type' ) && element.data( 'cke-real-element-type' ) == 'hiddenfield' ) - { - this.hiddenField = element; - element = editor.restoreRealElement( this.hiddenField ); - this.setupContent( element ); - selection.selectElement( this.hiddenField ); - } - }, - onOk : function() - { - var name = this.getValueOf( 'info', '_cke_saved_name' ), - value = this.getValueOf( 'info', 'value' ), - editor = this.getParentEditor(), - element = CKEDITOR.env.ie && !( CKEDITOR.document.$.documentMode >= 8 ) ? - editor.document.createElement( '' ) - : editor.document.createElement( 'input' ); - - element.setAttribute( 'type', 'hidden' ); - this.commitContent( element ); - var fakeElement = editor.createFakeElement( element, 'cke_hidden', 'hiddenfield' ); - if ( !this.hiddenField ) - editor.insertElement( fakeElement ); - else - { - fakeElement.replace( this.hiddenField ); - editor.getSelection().selectElement( fakeElement ); - } - return true; - }, - contents : [ - { - id : 'info', - label : editor.lang.hidden.title, - title : editor.lang.hidden.title, - elements : [ - { - id : '_cke_saved_name', - type : 'text', - label : editor.lang.hidden.name, - 'default' : '', - accessKey : 'N', - setup : function( element ) - { - this.setValue( - element.data( 'cke-saved-name' ) || - element.getAttribute( 'name' ) || - '' ); - }, - commit : function( element ) - { - if ( this.getValue() ) - element.setAttribute( 'name', this.getValue() ); - else - { - element.removeAttribute( 'name' ); - } - } - }, - { - id : 'value', - type : 'text', - label : editor.lang.hidden.value, - 'default' : '', - accessKey : 'V', - setup : function( element ) - { - this.setValue( element.getAttribute( 'value' ) || '' ); - }, - commit : function( element ) - { - if ( this.getValue() ) - element.setAttribute( 'value', this.getValue() ); - else - element.removeAttribute( 'value' ); - } - } - ] - } - ] - }; -}); diff --git a/media/ckeditor/_source/plugins/forms/dialogs/radio.js b/media/ckeditor/_source/plugins/forms/dialogs/radio.js deleted file mode 100644 index efcbbf7..0000000 --- a/media/ckeditor/_source/plugins/forms/dialogs/radio.js +++ /dev/null @@ -1,135 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ -CKEDITOR.dialog.add( 'radio', function( editor ) -{ - return { - title : editor.lang.checkboxAndRadio.radioTitle, - minWidth : 350, - minHeight : 140, - onShow : function() - { - delete this.radioButton; - - var element = this.getParentEditor().getSelection().getSelectedElement(); - if ( element && element.getName() == 'input' && element.getAttribute( 'type' ) == 'radio' ) - { - this.radioButton = element; - this.setupContent( element ); - } - }, - onOk : function() - { - var editor, - element = this.radioButton, - isInsertMode = !element; - - if ( isInsertMode ) - { - editor = this.getParentEditor(); - element = editor.document.createElement( 'input' ); - element.setAttribute( 'type', 'radio' ); - } - - if ( isInsertMode ) - editor.insertElement( element ); - this.commitContent( { element : element } ); - }, - contents : [ - { - id : 'info', - label : editor.lang.checkboxAndRadio.radioTitle, - title : editor.lang.checkboxAndRadio.radioTitle, - elements : [ - { - id : 'name', - type : 'text', - label : editor.lang.common.name, - 'default' : '', - accessKey : 'N', - setup : function( element ) - { - this.setValue( - element.data( 'cke-saved-name' ) || - element.getAttribute( 'name' ) || - '' ); - }, - commit : function( data ) - { - var element = data.element; - - if ( this.getValue() ) - element.data( 'cke-saved-name', this.getValue() ); - else - { - element.data( 'cke-saved-name', false ); - element.removeAttribute( 'name' ); - } - } - }, - { - id : 'value', - type : 'text', - label : editor.lang.checkboxAndRadio.value, - 'default' : '', - accessKey : 'V', - setup : function( element ) - { - this.setValue( element.getAttribute( 'value' ) || '' ); - }, - commit : function( data ) - { - var element = data.element; - - if ( this.getValue() ) - element.setAttribute( 'value', this.getValue() ); - else - element.removeAttribute( 'value' ); - } - }, - { - id : 'checked', - type : 'checkbox', - label : editor.lang.checkboxAndRadio.selected, - 'default' : '', - accessKey : 'S', - value : "checked", - setup : function( element ) - { - this.setValue( element.getAttribute( 'checked' ) ); - }, - commit : function( data ) - { - var element = data.element; - - if ( !( CKEDITOR.env.ie || CKEDITOR.env.opera ) ) - { - if ( this.getValue() ) - element.setAttribute( 'checked', 'checked' ); - else - element.removeAttribute( 'checked' ); - } - else - { - var isElementChecked = element.getAttribute( 'checked' ); - var isChecked = !!this.getValue(); - - if ( isElementChecked != isChecked ) - { - var replace = CKEDITOR.dom.element.createFromHtml( '', editor.document ); - element.copyAttributes( replace, { type : 1, checked : 1 } ); - replace.replace( element ); - editor.getSelection().selectElement( replace ); - data.element = replace; - } - } - } - } - ] - } - ] - }; -}); diff --git a/media/ckeditor/_source/plugins/forms/dialogs/select.js b/media/ckeditor/_source/plugins/forms/dialogs/select.js deleted file mode 100644 index c5d6940..0000000 --- a/media/ckeditor/_source/plugins/forms/dialogs/select.js +++ /dev/null @@ -1,558 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ -CKEDITOR.dialog.add( 'select', function( editor ) -{ - // Add a new option to a SELECT object (combo or list). - function addOption( combo, optionText, optionValue, documentObject, index ) - { - combo = getSelect( combo ); - var oOption; - if ( documentObject ) - oOption = documentObject.createElement( "OPTION" ); - else - oOption = document.createElement( "OPTION" ); - - if ( combo && oOption && oOption.getName() == 'option' ) - { - if ( CKEDITOR.env.ie ) { - if ( !isNaN( parseInt( index, 10) ) ) - combo.$.options.add( oOption.$, index ); - else - combo.$.options.add( oOption.$ ); - - oOption.$.innerHTML = optionText.length > 0 ? optionText : ''; - oOption.$.value = optionValue; - } - else - { - if ( index !== null && index < combo.getChildCount() ) - combo.getChild( index < 0 ? 0 : index ).insertBeforeMe( oOption ); - else - combo.append( oOption ); - - oOption.setText( optionText.length > 0 ? optionText : '' ); - oOption.setValue( optionValue ); - } - } - else - return false; - - return oOption; - } - // Remove all selected options from a SELECT object. - function removeSelectedOptions( combo ) - { - combo = getSelect( combo ); - - // Save the selected index - var iSelectedIndex = getSelectedIndex( combo ); - - // Remove all selected options. - for ( var i = combo.getChildren().count() - 1 ; i >= 0 ; i-- ) - { - if ( combo.getChild( i ).$.selected ) - combo.getChild( i ).remove(); - } - - // Reset the selection based on the original selected index. - setSelectedIndex( combo, iSelectedIndex ); - } - //Modify option from a SELECT object. - function modifyOption( combo, index, title, value ) - { - combo = getSelect( combo ); - if ( index < 0 ) - return false; - var child = combo.getChild( index ); - child.setText( title ); - child.setValue( value ); - return child; - } - function removeAllOptions( combo ) - { - combo = getSelect( combo ); - while ( combo.getChild( 0 ) && combo.getChild( 0 ).remove() ) - { /*jsl:pass*/ } - } - // Moves the selected option by a number of steps (also negative). - function changeOptionPosition( combo, steps, documentObject ) - { - combo = getSelect( combo ); - var iActualIndex = getSelectedIndex( combo ); - if ( iActualIndex < 0 ) - return false; - - var iFinalIndex = iActualIndex + steps; - iFinalIndex = ( iFinalIndex < 0 ) ? 0 : iFinalIndex; - iFinalIndex = ( iFinalIndex >= combo.getChildCount() ) ? combo.getChildCount() - 1 : iFinalIndex; - - if ( iActualIndex == iFinalIndex ) - return false; - - var oOption = combo.getChild( iActualIndex ), - sText = oOption.getText(), - sValue = oOption.getValue(); - - oOption.remove(); - - oOption = addOption( combo, sText, sValue, ( !documentObject ) ? null : documentObject, iFinalIndex ); - setSelectedIndex( combo, iFinalIndex ); - return oOption; - } - function getSelectedIndex( combo ) - { - combo = getSelect( combo ); - return combo ? combo.$.selectedIndex : -1; - } - function setSelectedIndex( combo, index ) - { - combo = getSelect( combo ); - if ( index < 0 ) - return null; - var count = combo.getChildren().count(); - combo.$.selectedIndex = ( index >= count ) ? ( count - 1 ) : index; - return combo; - } - function getOptions( combo ) - { - combo = getSelect( combo ); - return combo ? combo.getChildren() : false; - } - function getSelect( obj ) - { - if ( obj && obj.domId && obj.getInputElement().$ ) // Dialog element. - return obj.getInputElement(); - else if ( obj && obj.$ ) - return obj; - return false; - } - - return { - title : editor.lang.select.title, - minWidth : CKEDITOR.env.ie ? 460 : 395, - minHeight : CKEDITOR.env.ie ? 320 : 300, - onShow : function() - { - delete this.selectBox; - this.setupContent( 'clear' ); - var element = this.getParentEditor().getSelection().getSelectedElement(); - if ( element && element.getName() == "select" ) - { - this.selectBox = element; - this.setupContent( element.getName(), element ); - - // Load Options into dialog. - var objOptions = getOptions( element ); - for ( var i = 0 ; i < objOptions.count() ; i++ ) - this.setupContent( 'option', objOptions.getItem( i ) ); - } - }, - onOk : function() - { - var editor = this.getParentEditor(), - element = this.selectBox, - isInsertMode = !element; - - if ( isInsertMode ) - element = editor.document.createElement( 'select' ); - this.commitContent( element ); - - if ( isInsertMode ) - { - editor.insertElement( element ); - if ( CKEDITOR.env.ie ) - { - var sel = editor.getSelection(), - bms = sel.createBookmarks(); - setTimeout(function() - { - sel.selectBookmarks( bms ); - }, 0 ); - } - } - }, - contents : [ - { - id : 'info', - label : editor.lang.select.selectInfo, - title : editor.lang.select.selectInfo, - accessKey : '', - elements : [ - { - id : 'txtName', - type : 'text', - widths : [ '25%','75%' ], - labelLayout : 'horizontal', - label : editor.lang.common.name, - 'default' : '', - accessKey : 'N', - style : 'width:350px', - setup : function( name, element ) - { - if ( name == 'clear' ) - this.setValue( this[ 'default' ] || '' ); - else if ( name == 'select' ) - { - this.setValue( - element.data( 'cke-saved-name' ) || - element.getAttribute( 'name' ) || - '' ); - } - }, - commit : function( element ) - { - if ( this.getValue() ) - element.data( 'cke-saved-name', this.getValue() ); - else - { - element.data( 'cke-saved-name', false ); - element.removeAttribute( 'name' ); - } - } - }, - { - id : 'txtValue', - type : 'text', - widths : [ '25%','75%' ], - labelLayout : 'horizontal', - label : editor.lang.select.value, - style : 'width:350px', - 'default' : '', - className : 'cke_disabled', - onLoad : function() - { - this.getInputElement().setAttribute( 'readOnly', true ); - }, - setup : function( name, element ) - { - if ( name == 'clear' ) - this.setValue( '' ); - else if ( name == 'option' && element.getAttribute( 'selected' ) ) - this.setValue( element.$.value ); - } - }, - { - type : 'hbox', - widths : [ '175px', '170px' ], - children : - [ - { - id : 'txtSize', - type : 'text', - labelLayout : 'horizontal', - label : editor.lang.select.size, - 'default' : '', - accessKey : 'S', - style : 'width:175px', - validate: function() - { - var func = CKEDITOR.dialog.validate.integer( editor.lang.common.validateNumberFailed ); - return ( ( this.getValue() === '' ) || func.apply( this ) ); - }, - setup : function( name, element ) - { - if ( name == 'select' ) - this.setValue( element.getAttribute( 'size' ) || '' ); - if ( CKEDITOR.env.webkit ) - this.getInputElement().setStyle( 'width', '86px' ); - }, - commit : function( element ) - { - if ( this.getValue() ) - element.setAttribute( 'size', this.getValue() ); - else - element.removeAttribute( 'size' ); - } - }, - { - type : 'html', - html : '' + CKEDITOR.tools.htmlEncode( editor.lang.select.lines ) + '' - } - ] - }, - { - type : 'html', - html : '' + CKEDITOR.tools.htmlEncode( editor.lang.select.opAvail ) + '' - }, - { - type : 'hbox', - widths : [ '115px', '115px' ,'100px' ], - children : - [ - { - type : 'vbox', - children : - [ - { - id : 'txtOptName', - type : 'text', - label : editor.lang.select.opText, - style : 'width:115px', - setup : function( name, element ) - { - if ( name == 'clear' ) - this.setValue( "" ); - } - }, - { - type : 'select', - id : 'cmbName', - label : '', - title : '', - size : 5, - style : 'width:115px;height:75px', - items : [], - onChange : function() - { - var dialog = this.getDialog(), - values = dialog.getContentElement( 'info', 'cmbValue' ), - optName = dialog.getContentElement( 'info', 'txtOptName' ), - optValue = dialog.getContentElement( 'info', 'txtOptValue' ), - iIndex = getSelectedIndex( this ); - - setSelectedIndex( values, iIndex ); - optName.setValue( this.getValue() ); - optValue.setValue( values.getValue() ); - }, - setup : function( name, element ) - { - if ( name == 'clear' ) - removeAllOptions( this ); - else if ( name == 'option' ) - addOption( this, element.getText(), element.getText(), - this.getDialog().getParentEditor().document ); - }, - commit : function( element ) - { - var dialog = this.getDialog(), - optionsNames = getOptions( this ), - optionsValues = getOptions( dialog.getContentElement( 'info', 'cmbValue' ) ), - selectValue = dialog.getContentElement( 'info', 'txtValue' ).getValue(); - - removeAllOptions( element ); - - for ( var i = 0 ; i < optionsNames.count() ; i++ ) - { - var oOption = addOption( element, optionsNames.getItem( i ).getValue(), - optionsValues.getItem( i ).getValue(), dialog.getParentEditor().document ); - if ( optionsValues.getItem( i ).getValue() == selectValue ) - { - oOption.setAttribute( 'selected', 'selected' ); - oOption.selected = true; - } - } - } - } - ] - }, - { - type : 'vbox', - children : - [ - { - id : 'txtOptValue', - type : 'text', - label : editor.lang.select.opValue, - style : 'width:115px', - setup : function( name, element ) - { - if ( name == 'clear' ) - this.setValue( "" ); - } - }, - { - type : 'select', - id : 'cmbValue', - label : '', - size : 5, - style : 'width:115px;height:75px', - items : [], - onChange : function() - { - var dialog = this.getDialog(), - names = dialog.getContentElement( 'info', 'cmbName' ), - optName = dialog.getContentElement( 'info', 'txtOptName' ), - optValue = dialog.getContentElement( 'info', 'txtOptValue' ), - iIndex = getSelectedIndex( this ); - - setSelectedIndex( names, iIndex ); - optName.setValue( names.getValue() ); - optValue.setValue( this.getValue() ); - }, - setup : function( name, element ) - { - if ( name == 'clear' ) - removeAllOptions( this ); - else if ( name == 'option' ) - { - var oValue = element.getValue(); - addOption( this, oValue, oValue, - this.getDialog().getParentEditor().document ); - if ( element.getAttribute( 'selected' ) == 'selected' ) - this.getDialog().getContentElement( 'info', 'txtValue' ).setValue( oValue ); - } - } - } - ] - }, - { - type : 'vbox', - padding : 5, - children : - [ - { - type : 'button', - id : 'btnAdd', - style : '', - label : editor.lang.select.btnAdd, - title : editor.lang.select.btnAdd, - style : 'width:100%;', - onClick : function() - { - //Add new option. - var dialog = this.getDialog(), - parentEditor = dialog.getParentEditor(), - optName = dialog.getContentElement( 'info', 'txtOptName' ), - optValue = dialog.getContentElement( 'info', 'txtOptValue' ), - names = dialog.getContentElement( 'info', 'cmbName' ), - values = dialog.getContentElement( 'info', 'cmbValue' ); - - addOption(names, optName.getValue(), optName.getValue(), dialog.getParentEditor().document ); - addOption(values, optValue.getValue(), optValue.getValue(), dialog.getParentEditor().document ); - - optName.setValue( "" ); - optValue.setValue( "" ); - } - }, - { - type : 'button', - id : 'btnModify', - label : editor.lang.select.btnModify, - title : editor.lang.select.btnModify, - style : 'width:100%;', - onClick : function() - { - //Modify selected option. - var dialog = this.getDialog(), - optName = dialog.getContentElement( 'info', 'txtOptName' ), - optValue = dialog.getContentElement( 'info', 'txtOptValue' ), - names = dialog.getContentElement( 'info', 'cmbName' ), - values = dialog.getContentElement( 'info', 'cmbValue' ), - iIndex = getSelectedIndex( names ); - - if ( iIndex >= 0 ) - { - modifyOption( names, iIndex, optName.getValue(), optName.getValue() ); - modifyOption( values, iIndex, optValue.getValue(), optValue.getValue() ); - } - } - }, - { - type : 'button', - id : 'btnUp', - style : 'width:100%;', - label : editor.lang.select.btnUp, - title : editor.lang.select.btnUp, - onClick : function() - { - //Move up. - var dialog = this.getDialog(), - names = dialog.getContentElement( 'info', 'cmbName' ), - values = dialog.getContentElement( 'info', 'cmbValue' ); - - changeOptionPosition( names, -1, dialog.getParentEditor().document ); - changeOptionPosition( values, -1, dialog.getParentEditor().document ); - } - }, - { - type : 'button', - id : 'btnDown', - style : 'width:100%;', - label : editor.lang.select.btnDown, - title : editor.lang.select.btnDown, - onClick : function() - { - //Move down. - var dialog = this.getDialog(), - names = dialog.getContentElement( 'info', 'cmbName' ), - values = dialog.getContentElement( 'info', 'cmbValue' ); - - changeOptionPosition( names, 1, dialog.getParentEditor().document ); - changeOptionPosition( values, 1, dialog.getParentEditor().document ); - } - } - ] - } - ] - }, - { - type : 'hbox', - widths : [ '40%', '20%', '40%' ], - children : - [ - { - type : 'button', - id : 'btnSetValue', - label : editor.lang.select.btnSetValue, - title : editor.lang.select.btnSetValue, - onClick : function() - { - //Set as default value. - var dialog = this.getDialog(), - values = dialog.getContentElement( 'info', 'cmbValue' ), - txtValue = dialog.getContentElement( 'info', 'txtValue' ); - txtValue.setValue( values.getValue() ); - } - }, - { - type : 'button', - id : 'btnDelete', - label : editor.lang.select.btnDelete, - title : editor.lang.select.btnDelete, - onClick : function() - { - // Delete option. - var dialog = this.getDialog(), - names = dialog.getContentElement( 'info', 'cmbName' ), - values = dialog.getContentElement( 'info', 'cmbValue' ), - optName = dialog.getContentElement( 'info', 'txtOptName' ), - optValue = dialog.getContentElement( 'info', 'txtOptValue' ); - - removeSelectedOptions( names ); - removeSelectedOptions( values ); - - optName.setValue( "" ); - optValue.setValue( "" ); - } - }, - { - id : 'chkMulti', - type : 'checkbox', - label : editor.lang.select.chkMulti, - 'default' : '', - accessKey : 'M', - value : "checked", - setup : function( name, element ) - { - if ( name == 'select' ) - this.setValue( element.getAttribute( 'multiple' ) ); - if ( CKEDITOR.env.webkit ) - this.getElement().getParent().setStyle( 'vertical-align', 'middle' ); - }, - commit : function( element ) - { - if ( this.getValue() ) - element.setAttribute( 'multiple', this.getValue() ); - else - element.removeAttribute( 'multiple' ); - } - } - ] - } - ] - } - ] - }; -}); diff --git a/media/ckeditor/_source/plugins/forms/dialogs/textarea.js b/media/ckeditor/_source/plugins/forms/dialogs/textarea.js deleted file mode 100644 index 09996ff..0000000 --- a/media/ckeditor/_source/plugins/forms/dialogs/textarea.js +++ /dev/null @@ -1,135 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ -CKEDITOR.dialog.add( 'textarea', function( editor ) -{ - return { - title : editor.lang.textarea.title, - minWidth : 350, - minHeight : 220, - onShow : function() - { - delete this.textarea; - - var element = this.getParentEditor().getSelection().getSelectedElement(); - if ( element && element.getName() == "textarea" ) - { - this.textarea = element; - this.setupContent( element ); - } - }, - onOk : function() - { - var editor, - element = this.textarea, - isInsertMode = !element; - - if ( isInsertMode ) - { - editor = this.getParentEditor(); - element = editor.document.createElement( 'textarea' ); - } - this.commitContent( element ); - - if ( isInsertMode ) - editor.insertElement( element ); - }, - contents : [ - { - id : 'info', - label : editor.lang.textarea.title, - title : editor.lang.textarea.title, - elements : [ - { - id : '_cke_saved_name', - type : 'text', - label : editor.lang.common.name, - 'default' : '', - accessKey : 'N', - setup : function( element ) - { - this.setValue( - element.data( 'cke-saved-name' ) || - element.getAttribute( 'name' ) || - '' ); - }, - commit : function( element ) - { - if ( this.getValue() ) - element.data( 'cke-saved-name', this.getValue() ); - else - { - element.data( 'cke-saved-name', false ); - element.removeAttribute( 'name' ); - } - } - }, - { - type : 'hbox', - widths:['50%','50%'], - children:[ - { - id : 'cols', - type : 'text', - label : editor.lang.textarea.cols, - 'default' : '', - accessKey : 'C', - style : 'width:50px', - validate : CKEDITOR.dialog.validate.integer( editor.lang.common.validateNumberFailed ), - setup : function( element ) - { - var value = element.hasAttribute( 'cols' ) && element.getAttribute( 'cols' ); - this.setValue( value || '' ); - }, - commit : function( element ) - { - if ( this.getValue() ) - element.setAttribute( 'cols', this.getValue() ); - else - element.removeAttribute( 'cols' ); - } - }, - { - id : 'rows', - type : 'text', - label : editor.lang.textarea.rows, - 'default' : '', - accessKey : 'R', - style : 'width:50px', - validate : CKEDITOR.dialog.validate.integer( editor.lang.common.validateNumberFailed ), - setup : function( element ) - { - var value = element.hasAttribute( 'rows' ) && element.getAttribute( 'rows' ); - this.setValue( value || '' ); - }, - commit : function( element ) - { - if ( this.getValue() ) - element.setAttribute( 'rows', this.getValue() ); - else - element.removeAttribute( 'rows' ); - } - } - ] - }, - { - id : 'value', - type : 'textarea', - label : editor.lang.textfield.value, - 'default' : '', - setup : function( element ) - { - this.setValue( element.$.defaultValue ); - }, - commit : function( element ) - { - element.$.value = element.$.defaultValue = this.getValue() ; - } - } - - ] - } - ] - }; -}); diff --git a/media/ckeditor/_source/plugins/forms/dialogs/textfield.js b/media/ckeditor/_source/plugins/forms/dialogs/textfield.js deleted file mode 100644 index 1edcdf2..0000000 --- a/media/ckeditor/_source/plugins/forms/dialogs/textfield.js +++ /dev/null @@ -1,199 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ -CKEDITOR.dialog.add( 'textfield', function( editor ) -{ - var autoAttributes = - { - value : 1, - size : 1, - maxLength : 1 - }; - - var acceptedTypes = - { - text : 1, - password : 1 - }; - - return { - title : editor.lang.textfield.title, - minWidth : 350, - minHeight : 150, - onShow : function() - { - delete this.textField; - - var element = this.getParentEditor().getSelection().getSelectedElement(); - if ( element && element.getName() == "input" && - ( acceptedTypes[ element.getAttribute( 'type' ) ] || !element.getAttribute( 'type' ) ) ) - { - this.textField = element; - this.setupContent( element ); - } - }, - onOk : function() - { - var editor, - element = this.textField, - isInsertMode = !element; - - if ( isInsertMode ) - { - editor = this.getParentEditor(); - element = editor.document.createElement( 'input' ); - element.setAttribute( 'type', 'text' ); - } - - if ( isInsertMode ) - editor.insertElement( element ); - this.commitContent( { element : element } ); - }, - onLoad : function() - { - var autoSetup = function( element ) - { - var value = element.hasAttribute( this.id ) && element.getAttribute( this.id ); - this.setValue( value || '' ); - }; - - var autoCommit = function( data ) - { - var element = data.element; - var value = this.getValue(); - - if ( value ) - element.setAttribute( this.id, value ); - else - element.removeAttribute( this.id ); - }; - - this.foreach( function( contentObj ) - { - if ( autoAttributes[ contentObj.id ] ) - { - contentObj.setup = autoSetup; - contentObj.commit = autoCommit; - } - } ); - }, - contents : [ - { - id : 'info', - label : editor.lang.textfield.title, - title : editor.lang.textfield.title, - elements : [ - { - type : 'hbox', - widths : [ '50%', '50%' ], - children : - [ - { - id : '_cke_saved_name', - type : 'text', - label : editor.lang.textfield.name, - 'default' : '', - accessKey : 'N', - setup : function( element ) - { - this.setValue( - element.data( 'cke-saved-name' ) || - element.getAttribute( 'name' ) || - '' ); - }, - commit : function( data ) - { - var element = data.element; - - if ( this.getValue() ) - element.data( 'cke-saved-name', this.getValue() ); - else - { - element.data( 'cke-saved-name', false ); - element.removeAttribute( 'name' ); - } - } - }, - { - id : 'value', - type : 'text', - label : editor.lang.textfield.value, - 'default' : '', - accessKey : 'V' - } - ] - }, - { - type : 'hbox', - widths : [ '50%', '50%' ], - children : - [ - { - id : 'size', - type : 'text', - label : editor.lang.textfield.charWidth, - 'default' : '', - accessKey : 'C', - style : 'width:50px', - validate : CKEDITOR.dialog.validate.integer( editor.lang.common.validateNumberFailed ) - }, - { - id : 'maxLength', - type : 'text', - label : editor.lang.textfield.maxChars, - 'default' : '', - accessKey : 'M', - style : 'width:50px', - validate : CKEDITOR.dialog.validate.integer( editor.lang.common.validateNumberFailed ) - } - ], - onLoad : function() - { - // Repaint the style for IE7 (#6068) - if ( CKEDITOR.env.ie7Compat ) - this.getElement().setStyle( 'zoom', '100%' ); - } - }, - { - id : 'type', - type : 'select', - label : editor.lang.textfield.type, - 'default' : 'text', - accessKey : 'M', - items : - [ - [ editor.lang.textfield.typeText, 'text' ], - [ editor.lang.textfield.typePass, 'password' ] - ], - setup : function( element ) - { - this.setValue( element.getAttribute( 'type' ) ); - }, - commit : function( data ) - { - var element = data.element; - - if ( CKEDITOR.env.ie ) - { - var elementType = element.getAttribute( 'type' ); - var myType = this.getValue(); - - if ( elementType != myType ) - { - var replace = CKEDITOR.dom.element.createFromHtml( '', editor.document ); - element.copyAttributes( replace, { type : 1 } ); - replace.replace( element ); - editor.getSelection().selectElement( replace ); - data.element = replace; - } - } - else - element.setAttribute( 'type', this.getValue() ); - } - } - ] - } - ] - }; -}); diff --git a/media/ckeditor/_source/plugins/forms/images/hiddenfield.gif b/media/ckeditor/_source/plugins/forms/images/hiddenfield.gif deleted file mode 100644 index 953f643..0000000 Binary files a/media/ckeditor/_source/plugins/forms/images/hiddenfield.gif and /dev/null differ diff --git a/media/ckeditor/_source/plugins/forms/plugin.js b/media/ckeditor/_source/plugins/forms/plugin.js deleted file mode 100644 index 1c06559..0000000 --- a/media/ckeditor/_source/plugins/forms/plugin.js +++ /dev/null @@ -1,288 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @file Forms Plugin - */ - -CKEDITOR.plugins.add( 'forms', -{ - init : function( editor ) - { - var lang = editor.lang; - - editor.addCss( - 'form' + - '{' + - 'border: 1px dotted #FF0000;' + - 'padding: 2px;' + - '}\n' ); - - editor.addCss( - 'img.cke_hidden' + - '{' + - 'background-image: url(' + CKEDITOR.getUrl( this.path + 'images/hiddenfield.gif' ) + ');' + - 'background-position: center center;' + - 'background-repeat: no-repeat;' + - 'border: 1px solid #a9a9a9;' + - 'width: 16px !important;' + - 'height: 16px !important;' + - '}' ); - - // All buttons use the same code to register. So, to avoid - // duplications, let's use this tool function. - var addButtonCommand = function( buttonName, commandName, dialogFile ) - { - editor.addCommand( commandName, new CKEDITOR.dialogCommand( commandName ) ); - - editor.ui.addButton( buttonName, - { - label : lang.common[ buttonName.charAt(0).toLowerCase() + buttonName.slice(1) ], - command : commandName - }); - CKEDITOR.dialog.add( commandName, dialogFile ); - }; - - var dialogPath = this.path + 'dialogs/'; - addButtonCommand( 'Form', 'form', dialogPath + 'form.js' ); - addButtonCommand( 'Checkbox', 'checkbox', dialogPath + 'checkbox.js' ); - addButtonCommand( 'Radio', 'radio', dialogPath + 'radio.js' ); - addButtonCommand( 'TextField', 'textfield', dialogPath + 'textfield.js' ); - addButtonCommand( 'Textarea', 'textarea', dialogPath + 'textarea.js' ); - addButtonCommand( 'Select', 'select', dialogPath + 'select.js' ); - addButtonCommand( 'Button', 'button', dialogPath + 'button.js' ); - addButtonCommand( 'ImageButton', 'imagebutton', CKEDITOR.plugins.getPath('image') + 'dialogs/image.js' ); - addButtonCommand( 'HiddenField', 'hiddenfield', dialogPath + 'hiddenfield.js' ); - - // If the "menu" plugin is loaded, register the menu items. - if ( editor.addMenuItems ) - { - editor.addMenuItems( - { - form : - { - label : lang.form.menu, - command : 'form', - group : 'form' - }, - - checkbox : - { - label : lang.checkboxAndRadio.checkboxTitle, - command : 'checkbox', - group : 'checkbox' - }, - - radio : - { - label : lang.checkboxAndRadio.radioTitle, - command : 'radio', - group : 'radio' - }, - - textfield : - { - label : lang.textfield.title, - command : 'textfield', - group : 'textfield' - }, - - hiddenfield : - { - label : lang.hidden.title, - command : 'hiddenfield', - group : 'hiddenfield' - }, - - imagebutton : - { - label : lang.image.titleButton, - command : 'imagebutton', - group : 'imagebutton' - }, - - button : - { - label : lang.button.title, - command : 'button', - group : 'button' - }, - - select : - { - label : lang.select.title, - command : 'select', - group : 'select' - }, - - textarea : - { - label : lang.textarea.title, - command : 'textarea', - group : 'textarea' - } - }); - } - - // If the "contextmenu" plugin is loaded, register the listeners. - if ( editor.contextMenu ) - { - editor.contextMenu.addListener( function( element ) - { - if ( element && element.hasAscendant( 'form', true ) && !element.isReadOnly() ) - return { form : CKEDITOR.TRISTATE_OFF }; - }); - - editor.contextMenu.addListener( function( element ) - { - if ( element && !element.isReadOnly() ) - { - var name = element.getName(); - - if ( name == 'select' ) - return { select : CKEDITOR.TRISTATE_OFF }; - - if ( name == 'textarea' ) - return { textarea : CKEDITOR.TRISTATE_OFF }; - - if ( name == 'input' ) - { - switch( element.getAttribute( 'type' ) ) - { - case 'button' : - case 'submit' : - case 'reset' : - return { button : CKEDITOR.TRISTATE_OFF }; - - case 'checkbox' : - return { checkbox : CKEDITOR.TRISTATE_OFF }; - - case 'radio' : - return { radio : CKEDITOR.TRISTATE_OFF }; - - case 'image' : - return { imagebutton : CKEDITOR.TRISTATE_OFF }; - - default : - return { textfield : CKEDITOR.TRISTATE_OFF }; - } - } - - if ( name == 'img' && element.data( 'cke-real-element-type' ) == 'hiddenfield' ) - return { hiddenfield : CKEDITOR.TRISTATE_OFF }; - } - }); - } - - editor.on( 'doubleclick', function( evt ) - { - var element = evt.data.element; - - if ( element.is( 'form' ) ) - evt.data.dialog = 'form'; - else if ( element.is( 'select' ) ) - evt.data.dialog = 'select'; - else if ( element.is( 'textarea' ) ) - evt.data.dialog = 'textarea'; - else if ( element.is( 'img' ) && element.data( 'cke-real-element-type' ) == 'hiddenfield' ) - evt.data.dialog = 'hiddenfield'; - else if ( element.is( 'input' ) ) - { - switch ( element.getAttribute( 'type' ) ) - { - case 'button' : - case 'submit' : - case 'reset' : - evt.data.dialog = 'button'; - break; - case 'checkbox' : - evt.data.dialog = 'checkbox'; - break; - case 'radio' : - evt.data.dialog = 'radio'; - break; - case 'image' : - evt.data.dialog = 'imagebutton'; - break; - default : - evt.data.dialog = 'textfield'; - break; - } - } - }); - }, - - afterInit : function( editor ) - { - var dataProcessor = editor.dataProcessor, - htmlFilter = dataProcessor && dataProcessor.htmlFilter, - dataFilter = dataProcessor && dataProcessor.dataFilter; - - // Cleanup certain IE form elements default values. - if ( CKEDITOR.env.ie ) - { - htmlFilter && htmlFilter.addRules( - { - elements : - { - input : function( input ) - { - var attrs = input.attributes, - type = attrs.type; - // Old IEs don't provide type for Text inputs #5522 - if ( !type ) - attrs.type = 'text'; - if ( type == 'checkbox' || type == 'radio' ) - attrs.value == 'on' && delete attrs.value; - } - } - } ); - } - - if ( dataFilter ) - { - dataFilter.addRules( - { - elements : - { - input : function( element ) - { - if ( element.attributes.type == 'hidden' ) - return editor.createFakeParserElement( element, 'cke_hidden', 'hiddenfield' ); - } - } - } ); - } - }, - requires : [ 'image', 'fakeobjects' ] -} ); - -if ( CKEDITOR.env.ie ) -{ - CKEDITOR.dom.element.prototype.hasAttribute = CKEDITOR.tools.override( CKEDITOR.dom.element.prototype.hasAttribute, - function( original ) - { - return function( name ) - { - var $attr = this.$.attributes.getNamedItem( name ); - - if ( this.getName() == 'input' ) - { - switch ( name ) - { - case 'class' : - return this.$.className.length > 0; - case 'checked' : - return !!this.$.checked; - case 'value' : - var type = this.getAttribute( 'type' ); - return type == 'checkbox' || type == 'radio' ? this.$.value != 'on' : this.$.value; - } - } - - return original.apply( this, arguments ); - }; - }); -} diff --git a/media/ckeditor/_source/plugins/horizontalrule/plugin.js b/media/ckeditor/_source/plugins/horizontalrule/plugin.js deleted file mode 100644 index 59e73a3..0000000 --- a/media/ckeditor/_source/plugins/horizontalrule/plugin.js +++ /dev/null @@ -1,48 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -/** - * @file Horizontal Rule plugin. - */ - -(function() -{ - var horizontalruleCmd = - { - canUndo : false, // The undo snapshot will be handled by 'insertElement'. - exec : function( editor ) - { - var hr = editor.document.createElement( 'hr' ), - range = new CKEDITOR.dom.range( editor.document ); - - editor.insertElement( hr ); - - // If there's nothing or a non-editable block followed by, establish a new paragraph - // to make sure cursor is not trapped. - range.moveToPosition( hr, CKEDITOR.POSITION_AFTER_END ); - var next = hr.getNext(); - if ( !next || next.type == CKEDITOR.NODE_ELEMENT && !next.isEditable() ) - range.fixBlock( true, editor.config.enterMode == CKEDITOR.ENTER_DIV ? 'div' : 'p' ); - - range.select(); - } - }; - - var pluginName = 'horizontalrule'; - - // Register a plugin named "horizontalrule". - CKEDITOR.plugins.add( pluginName, - { - init : function( editor ) - { - editor.addCommand( pluginName, horizontalruleCmd ); - editor.ui.addButton( 'HorizontalRule', - { - label : editor.lang.horizontalrule, - command : pluginName - }); - } - }); -})(); diff --git a/media/ckeditor/_source/plugins/htmldataprocessor/plugin.js b/media/ckeditor/_source/plugins/htmldataprocessor/plugin.js deleted file mode 100644 index 1e50fd4..0000000 --- a/media/ckeditor/_source/plugins/htmldataprocessor/plugin.js +++ /dev/null @@ -1,600 +0,0 @@ -/* -Copyright (c) 2003-2012, CKSource - Frederico Knabben. All rights reserved. -For licensing, see LICENSE.html or http://ckeditor.com/license -*/ - -(function() -{ - // Regex to scan for   at the end of blocks, which are actually placeholders. - // Safari transforms the   to \xa0. (#4172) - var tailNbspRegex = /^[\t\r\n ]*(?: |\xa0)$/; - - var protectedSourceMarker = '{cke_protected}'; - - // Return the last non-space child node of the block (#4344). - function lastNoneSpaceChild( block ) - { - var lastIndex = block.children.length, - last = block.children[ lastIndex - 1 ]; - while ( last && last.type == CKEDITOR.NODE_TEXT && !CKEDITOR.tools.trim( last.value ) ) - last = block.children[ --lastIndex ]; - return last; - } - - function trimFillers( block, fromSource ) - { - // If the current node is a block, and if we're converting from source or - // we're not in IE then search for and remove any tailing BR node. - // - // Also, any   at the end of blocks are fillers, remove them as well. - // (#2886) - var children = block.children, lastChild = lastNoneSpaceChild( block ); - if ( lastChild ) - { - if ( ( fromSource || !CKEDITOR.env.ie ) && lastChild.type == CKEDITOR.NODE_ELEMENT && lastChild.name == 'br' ) - children.pop(); - if ( lastChild.type == CKEDITOR.NODE_TEXT && tailNbspRegex.test( lastChild.value ) ) - children.pop(); - } - } - - function blockNeedsExtension( block, fromSource, extendEmptyBlock ) - { - if( !fromSource && ( !extendEmptyBlock || - typeof extendEmptyBlock == 'function' && ( extendEmptyBlock( block ) === false ) ) ) - return false; - - // 1. For IE version >=8, empty blocks are displayed correctly themself in wysiwiyg; - // 2. For the rest, at least table cell and list item need no filler space. - // (#6248) - if ( fromSource && CKEDITOR.env.ie && - ( document.documentMode > 7 - || block.name in CKEDITOR.dtd.tr - || block.name in CKEDITOR.dtd.$listItem ) ) - return false; - - var lastChild = lastNoneSpaceChild( block ); - - return !lastChild || lastChild && - ( lastChild.type == CKEDITOR.NODE_ELEMENT && lastChild.name == 'br' - // Some of the controls in form needs extension too, - // to move cursor at the end of the form. (#4791) - || block.name == 'form' && lastChild.name == 'input' ); - } - - function getBlockExtension( isOutput, emptyBlockFiller ) - { - return function( node ) - { - trimFillers( node, !isOutput ); - - if ( blockNeedsExtension( node, !isOutput, emptyBlockFiller ) ) - { - if ( isOutput || CKEDITOR.env.ie ) - node.add( new CKEDITOR.htmlParser.text( '\xa0' ) ); - else - node.add( new CKEDITOR.htmlParser.element( 'br', {} ) ); - } - }; - } - - var dtd = CKEDITOR.dtd; - - // Define orders of table elements. - var tableOrder = [ 'caption', 'colgroup', 'col', 'thead', 'tfoot', 'tbody' ]; - - // Find out the list of block-like tags that can contain
      . - var blockLikeTags = CKEDITOR.tools.extend( {}, dtd.$block, dtd.$listItem, dtd.$tableContent ); - for ( var i in blockLikeTags ) - { - if ( ! ( 'br' in dtd[i] ) ) - delete blockLikeTags[i]; - } - // We just avoid filler in
       right now.
      -	// TODO: Support filler for 
      , line break is also occupy line height.
      -	delete blockLikeTags.pre;
      -	var defaultDataFilterRules =
      -	{
      -		elements : {},
      -		attributeNames :
      -		[
      -			// Event attributes (onXYZ) must not be directly set. They can become
      -			// active in the editing area (IE|WebKit).
      -			[ ( /^on/ ), 'data-cke-pa-on' ]
      -		]
      -	};
      -
      -	var defaultDataBlockFilterRules = { elements : {} };
      -
      -	for ( i in blockLikeTags )
      -		defaultDataBlockFilterRules.elements[ i ] = getBlockExtension();
      -
      -	var defaultHtmlFilterRules =
      -		{
      -			elementNames :
      -			[
      -				// Remove the "cke:" namespace prefix.
      -				[ ( /^cke:/ ), '' ],
      -
      -				// Ignore  tags.
      -				[ ( /^\?xml:namespace$/ ), '' ]
      -			],
      -
      -			attributeNames :
      -			[
      -				// Attributes saved for changes and protected attributes.
      -				[ ( /^data-cke-(saved|pa)-/ ), '' ],
      -
      -				// All "data-cke-" attributes are to be ignored.
      -				[ ( /^data-cke-.*/ ), '' ],
      -
      -				[ 'hidefocus', '' ]
      -			],
      -
      -			elements :
      -			{
      -				$ : function( element )
      -				{
      -					var attribs = element.attributes;
      -
      -					if ( attribs )
      -					{
      -						// Elements marked as temporary are to be ignored.
      -						if ( attribs[ 'data-cke-temp' ] )
      -							return false;
      -
      -						// Remove duplicated attributes - #3789.
      -						var attributeNames = [ 'name', 'href', 'src' ],
      -							savedAttributeName;
      -						for ( var i = 0 ; i < attributeNames.length ; i++ )
      -						{
      -							savedAttributeName = 'data-cke-saved-' + attributeNames[ i ];
      -							savedAttributeName in attribs && ( delete attribs[ attributeNames[ i ] ] );
      -						}
      -					}
      -
      -					return element;
      -				},
      -
      -				// The contents of table should be in correct order (#4809).
      -				table : function( element )
      -				{
      -					var children = element.children;
      -					children.sort( function ( node1, node2 )
      -								   {
      -									   return node1.type == CKEDITOR.NODE_ELEMENT && node2.type == node1.type ?
      -											CKEDITOR.tools.indexOf( tableOrder, node1.name )  > CKEDITOR.tools.indexOf( tableOrder, node2.name ) ? 1 : -1 : 0;
      -								   } );
      -				},
      -
      -				embed : function( element )
      -				{
      -					var parent = element.parent;
      -
      -					// If the  is child of a , copy the width
      -					// and height attributes from it.
      -					if ( parent && parent.name == 'object' )
      -					{
      -						var parentWidth = parent.attributes.width,
      -							parentHeight = parent.attributes.height;
      -						parentWidth && ( element.attributes.width = parentWidth );
      -						parentHeight && ( element.attributes.height = parentHeight );
      -					}
      -				},
      -				// Restore param elements into self-closing.
      -				param : function( param )
      -				{
      -					param.children = [];
      -					param.isEmpty = true;
      -					return param;
      -				},
      -
      -				// Remove empty link but not empty anchor.(#3829)
      -				a : function( element )
      -				{
      -					if ( !( element.children.length ||
      -							element.attributes.name ||
      -							element.attributes[ 'data-cke-saved-name' ] ) )
      -					{
      -						return false;
      -					}
      -				},
      -
      -				// Remove dummy span in webkit.
      -				span: function( element )
      -				{
      -					if ( element.attributes[ 'class' ] == 'Apple-style-span' )
      -						delete element.name;
      -				},
      -
      -				// Empty 
       in IE is reported with filler node ( ).
      -				pre : function( element ) { CKEDITOR.env.ie && trimFillers( element ); },
      -
      -				html : function( element )
      -				{
      -					delete element.attributes.contenteditable;
      -					delete element.attributes[ 'class' ];
      -				},
      -
      -				body : function( element )
      -				{
      -					delete element.attributes.spellcheck;
      -					delete element.attributes.contenteditable;
      -				},
      -
      -				style : function( element )
      -				{
      -					var child = element.children[ 0 ];
      -					child && child.value && ( child.value = CKEDITOR.tools.trim( child.value ));
      -
      -					if ( !element.attributes.type )
      -						element.attributes.type = 'text/css';
      -				},
      -
      -				title : function( element )
      -				{
      -					var titleText = element.children[ 0 ];
      -					titleText && ( titleText.value = element.attributes[ 'data-cke-title' ] || '' );
      -				}
      -			},
      -
      -			attributes :
      -			{
      -				'class' : function( value, element )
      -				{
      -					// Remove all class names starting with "cke_".
      -					return CKEDITOR.tools.ltrim( value.replace( /(?:^|\s+)cke_[^\s]*/g, '' ) ) || false;
      -				}
      -			}
      -		};
      -
      -	if ( CKEDITOR.env.ie )
      -	{
      -		// IE outputs style attribute in capital letters. We should convert
      -		// them back to lower case, while not hurting the values (#5930)
      -		defaultHtmlFilterRules.attributes.style = function( value, element )
      -		{
      -			return value.replace( /(^|;)([^\:]+)/g, function( match )
      -				{
      -					return match.toLowerCase();
      -				});
      -		};
      -	}
      -
      -	function protectReadOnly( element )
      -	{
      -		var attrs = element.attributes;
      -
      -		// We should flag that the element was locked by our code so
      -		// it'll be editable by the editor functions (#6046).
      -		if ( attrs.contenteditable != "false" )
      -			attrs[ 'data-cke-editable' ] = attrs.contenteditable ? 'true' : 1;
      -
      -		attrs.contenteditable = "false";
      -	}
      -	function unprotectReadyOnly( element )
      -	{
      -		var attrs = element.attributes;
      -		switch( attrs[ 'data-cke-editable' ] )
      -		{
      -			case 'true':	attrs.contenteditable = 'true';	break;
      -			case '1':		delete attrs.contenteditable;	break;
      -		}
      -	}
      -	// Disable form elements editing mode provided by some browers. (#5746)
      -	for ( i in { input : 1, textarea : 1 } )
      -	{
      -		defaultDataFilterRules.elements[ i ] = protectReadOnly;
      -		defaultHtmlFilterRules.elements[ i ] = unprotectReadyOnly;
      -	}
      -
      -	var protectElementRegex = /<(a|area|img|input)\b([^>]*)>/gi,
      -		protectAttributeRegex = /\b(on\w+|href|src|name)\s*=\s*(?:(?:"[^"]*")|(?:'[^']*')|(?:[^ "'>]+))/gi;
      -
      -	var protectElementsRegex = /(?:])[^>]*>[\s\S]*<\/style>)|(?:<(:?link|meta|base)[^>]*>)/gi,
      -		encodedElementsRegex = /([^<]*)<\/cke:encoded>/gi;
      -
      -	var protectElementNamesRegex = /(<\/?)((?:object|embed|param|html|body|head|title)[^>]*>)/gi,
      -		unprotectElementNamesRegex = /(<\/?)cke:((?:html|body|head|title)[^>]*>)/gi;
      -
      -	var protectSelfClosingRegex = /]*?)\/?>(?!\s*<\/cke:\1)/gi;
      -
      -	function protectAttributes( html )
      -	{
      -		return html.replace( protectElementRegex, function( element, tag, attributes )
      -		{
      -			return '<' +  tag + attributes.replace( protectAttributeRegex, function( fullAttr, attrName )
      -			{
      -				// Avoid corrupting the inline event attributes (#7243).
      -				// We should not rewrite the existed protected attributes, e.g. clipboard content from editor. (#5218)
      -				if ( !( /^on/ ).test( attrName ) && attributes.indexOf( 'data-cke-saved-' + attrName ) == -1 )
      -					return ' data-cke-saved-' + fullAttr + ' data-cke-' + CKEDITOR.rnd + '-' + fullAttr;
      -
      -				return fullAttr;
      -			}) + '>';
      -		});
      -	}
      -
      -	function protectElements( html )
      -	{
      -		return html.replace( protectElementsRegex, function( match )
      -			{
      -				return '' + encodeURIComponent( match ) + '';
      -			});
      -	}
      -
      -	function unprotectElements( html )
      -	{
      -		return html.replace( encodedElementsRegex, function( match, encoded )
      -			{
      -				return decodeURIComponent( encoded );
      -			});
      -	}
      -
      -	function protectElementsNames( html )
      -	{
      -		return html.replace( protectElementNamesRegex, '$1cke:$2');
      -	}
      -
      -	function unprotectElementNames( html )
      -	{
      -		return html.replace( unprotectElementNamesRegex, '$1$2' );
      -	}
      -
      -	function protectSelfClosingElements( html )
      -	{
      -		return html.replace( protectSelfClosingRegex, '' );
      -	}
      -
      -	function protectPreFormatted( html )
      -	{
      -		return html.replace( /(]*>)(\r\n|\n)/g, '$1$2$2' );
      -	}
      -
      -	function protectRealComments( html )
      -	{
      -		return html.replace( //g, function( match )
      -			{
      -				return '';
      -			});
      -	}
      -
      -	function unprotectRealComments( html )
      -	{
      -		return html.replace( //g, function( match, data )
      -			{
      -				return decodeURIComponent( data );
      -			});
      -	}
      -
      -	function unprotectSource( html, editor )
      -	{
      -		var store = editor._.dataStore;
      -
      -		return html.replace( //g, function( match, data )
      -			{
      -				return decodeURIComponent( data );
      -			}).replace( /\{cke_protected_(\d+)\}/g, function( match, id )
      -			{
      -				return store && store[ id ] || '';
      -			});
      -	}
      -
      -	function protectSource( data, editor )
      -	{
      -		var protectedHtml = [],
      -			protectRegexes = editor.config.protectedSource,
      -			store = editor._.dataStore || ( editor._.dataStore = { id : 1 } ),
      -			tempRegex = /<\!--\{cke_temp(comment)?\}(\d*?)-->/g;
      -
      -		var regexes =
      -			[
      -				// Script tags will also be forced to be protected, otherwise
      -				// IE will execute them.
      -				( //gi ),
      -
      -				//