@ -1,15 +1,15 @@
/ *
Copyright ( c ) 2003 - 2023 , CKSource Holding sp . z o . o . All rights reserved .
CKEditor 4 LTS ( "Long Term Support" ) is available under the terms of the Extended Support Model .
For licensing , see LICENSE . md or https : //ckeditor.com/legal/ckeditor-oss-license/
* /
( function ( ) { if ( window . CKEDITOR && window . CKEDITOR . dom ) return ; window . CKEDITOR || ( window . CKEDITOR = function ( ) { var a = /(^|.*[\\\/])ckeditor\.js(?:\?.*|;.*)?$/i , d = { timestamp : "N 7OC", version : "4.23.0-lts" , revision : "7282fa87bc ", rnd : Math . floor ( 900 * Math . random ( ) ) + 100 , _ : { pending : [ ] , basePathSrcPattern : a } , status : "unloaded" , basePath : function ( ) { var b = window . CKEDITOR _BASEPATH || "" ; if ( ! b ) for ( var c = document . getElementsByTagName ( "script" ) , d = 0 ; d < c . length ; d ++ ) { var k = c [ d ] . src . match ( a ) ; if ( k) { b = k [ 1 ] ; break } } - 1 == b . indexOf ( ":/" ) && "//" != b . slice ( 0 , 2 ) && ( b = 0 === b . indexOf ( "/" ) ? location . href . match ( /^.*?:\/\/[^\/]*/ ) [ 0 ] +
( function ( ) { if ( window . CKEDITOR && window . CKEDITOR . dom ) return ; window . CKEDITOR || ( window . CKEDITOR = function ( ) { var a = /(^|.*[\\\/])ckeditor\.js(?:\?.*|;.*)?$/i , d = { timestamp : "N 5UC", version : "4.22.1" , revision : "4a1fb11f44 ", rnd : Math . floor ( 900 * Math . random ( ) ) + 100 , _ : { pending : [ ] , basePathSrcPattern : a } , status : "unloaded" , basePath : function ( ) { var b = window . CKEDITOR _BASEPATH || "" ; if ( ! b ) for ( var c = document . getElementsByTagName ( "script" ) , d = 0 ; d < c . length ; d ++ ) { var h = c [ d ] . src . match ( a ) ; if ( h) { b = h [ 1 ] ; break } } - 1 == b . indexOf ( ":/" ) && "//" != b . slice ( 0 , 2 ) && ( b = 0 === b . indexOf ( "/" ) ? location . href . match ( /^.*?:\/\/[^\/]*/ ) [ 0 ] +
b : location . href . match ( /^[^\?]*\/(?:)/ ) [ 0 ] + b ) ; if ( ! b ) throw 'The CKEditor installation path could not be automatically detected. Please set the global variable "CKEDITOR_BASEPATH" before creating editor instances.' ; return b } ( ) , getUrl : function ( a ) { - 1 == a . indexOf ( ":/" ) && 0 !== a . indexOf ( "/" ) && ( a = this . basePath + a ) ; return a = this . appendTimestamp ( a ) } , appendTimestamp : function ( a ) { if ( ! this . timestamp || "/" === a . charAt ( a . length - 1 ) || /[&?]t=/ . test ( a ) ) return a ; var b = 0 <= a . indexOf ( "?" ) ? "\x26" : "?" ; return a + b + "t\x3d" + this . timestamp } ,
domReady : function ( ) { function a ( ) { try { document . addEventListener ? ( document . removeEventListener ( "DOMContentLoaded" , a , ! 1 ) , window . removeEventListener ( "load" , a , ! 1 ) , b ( ) ) : document . attachEvent && "complete" === document . readyState && ( document . detachEvent ( "onreadystatechange" , a ) , window . detachEvent ( "onload" , a ) , b ( ) ) } catch ( c ) { } } function b ( ) { for ( var a ; a = c . shift ( ) ; ) a ( ) } var c = [ ] ; return function ( b ) { function e ( ) { try { document . documentElement . doScroll ( "left" ) } catch ( b ) { setTimeout ( e , 1 ) ; return } a ( ) } c . push ( b ) ; "complete" === document . readyState &&
setTimeout ( a , 1 ) ; if ( 1 == c . length ) if ( document . addEventListener ) document . addEventListener ( "DOMContentLoaded" , a , ! 1 ) , window . addEventListener ( "load" , a , ! 1 ) ; else if ( document . attachEvent ) { document . attachEvent ( "onreadystatechange" , a ) ; window . attachEvent ( "onload" , a ) ; b = ! 1 ; try { b = ! window . frameElement } catch ( d ) { } document . documentElement . doScroll && b && e ( ) } } } ( ) } , b = window . CKEDITOR _GETURL ; if ( b ) { var c = d . getUrl ; d . getUrl = function ( a ) { return b . call ( d , a ) || c . call ( d , a ) } } return d } ( ) ) ;
( function ( ) { var a = { } ; CKEDITOR . event || ( CKEDITOR . event = function ( ) { } , CKEDITOR . event . implementOn = function ( a ) { var b = CKEDITOR . event . prototype , c ; for ( c in b ) null == a [ c ] && ( a [ c ] = b [ c ] ) } , CKEDITOR . event . prototype = function ( ) { function d ( a ) { var e = b ( this ) ; return e [ a ] || ( e [ a ] = new c ( a ) ) } var b = function ( a ) { a = a . getPrivate && a . getPrivate ( ) || a . _ || ( a . _ = { } ) ; return a . events || ( a . events = { } ) } , c = function ( a ) { this . name = a ; this . listeners = [ ] } ; c . prototype = { getListenerIndex : function ( a ) { for ( var b = 0 , c = this . listeners ; b < c . length ; b ++ ) if ( c [ b ] . fn ==
a ) return b ; return - 1 } } ; return { define : function ( a , b ) { var c = d . call ( this , a ) ; CKEDITOR . tools . extend ( c , b , ! 0 ) } , on : function ( b , c , h, k , l ) { function q ( w , B , y , l ) { w = { name : b , sender : this , editor : w, data : B , listenerData : k , stop : y , cancel : l , removeListener : f } ; return ! 1 === c . call ( h, w ) ? a : w . data } function f ( ) { w . removeListener ( b , c ) } var w= this , B = d . call ( this , b ) ; if ( 0 > B. getListenerIndex ( c ) ) { B = B . listeners ; h || ( h = this ) ; isNaN ( l ) && ( l = 10 ) ; q . fn = c ; q . priority = l ; for ( var y = B . length - 1 ; 0 <= y ; y -- ) if ( B [ y ] . priority <= l ) return B . splice ( y + 1 , 0 , q ) , { removeListener : f } ;
B. unshift ( q ) } return { removeListener : f } } , once : function ( ) { var a = Array . prototype . slice . call ( arguments ) , b = a [ 1 ] ; a [ 1 ] = function ( a ) { a . removeListener ( ) ; return b . apply ( this , arguments ) } ; return this . on . apply ( this , a ) } , capture : function ( ) { CKEDITOR . event . useCapture = 1 ; var a = this . on . apply ( this , arguments ) ; CKEDITOR . event . useCapture = 0 ; return a } , fire : function ( ) { var c = 0 , e = function ( ) { c = 1 } , d = 0 , k = function ( ) { d = 1 } ; return function ( l, q , f ) { var w = b ( this ) [ l ] ; l = c ; var B = d ; c = d = 0 ; if ( w) { var y = w . listeners ; if ( y . length ) for ( var y = y . slice ( 0 ) ,
F, r = 0 ; r < y . length ; r ++ ) { if ( w . errorProof ) try { F = y [ r ] . call ( this , f , q , e , k ) } catch ( m ) { } else F = y [ r ] . call ( this , f , q , e , k ) ; F === a ? d = 1 : "undefined" != typeof F&& ( q = F ) ; if ( c || d ) break } } q = d ? ! 1 : "undefined" == typeof q? ! 0 : q ; c = l ; d = B ; return q } } ( ) , fireOnce : function ( a , c , d ) { c = this . fire ( a , c , d ) ; delete b ( this ) [ a ] ; return c } , removeListener : function ( a , c ) { var d = b ( this ) [ a ] ; if ( d ) { var k = d . getListenerIndex ( c ) ; 0 <= k&& d . listeners . splice ( k , 1 ) } } , removeAllListeners : function ( ) { var a = b ( this ) , c ; for ( c in a ) delete a [ c ] } , hasListeners : function ( a ) { return ( a =
a ) return b ; return - 1 } } ; return { define : function ( a , b ) { var c = d . call ( this , a ) ; CKEDITOR . tools . extend ( c , b , ! 0 ) } , on : function ( b , c , k, h , n ) { function l ( x , y , z , n ) { x = { name : b , sender : this , editor : x, data : y , listenerData : h , stop : z , cancel : n , removeListener : g } ; return ! 1 === c . call ( k, x ) ? a : x . data } function g ( ) { x . removeListener ( b , c ) } var x= this , y = d . call ( this , b ) ; if ( 0 > y. getListenerIndex ( c ) ) { y = y . listeners ; k || ( k = this ) ; isNaN ( n ) && ( n = 10 ) ; l . fn = c ; l . priority = n ; for ( var z = y . length - 1 ; 0 <= z ; z -- ) if ( y [ z ] . priority <= n ) return y . splice ( z + 1 , 0 , l ) , { removeListener : g } ;
y. unshift ( l ) } return { removeListener : g } } , once : function ( ) { var a = Array . prototype . slice . call ( arguments ) , b = a [ 1 ] ; a [ 1 ] = function ( a ) { a . removeListener ( ) ; return b . apply ( this , arguments ) } ; return this . on . apply ( this , a ) } , capture : function ( ) { CKEDITOR . event . useCapture = 1 ; var a = this . on . apply ( this , arguments ) ; CKEDITOR . event . useCapture = 0 ; return a } , fire : function ( ) { var c = 0 , e = function ( ) { c = 1 } , d = 0 , h = function ( ) { d = 1 } ; return function ( n, l , g ) { var x = b ( this ) [ n ] ; n = c ; var y = d ; c = d = 0 ; if ( x) { var z = x . listeners ; if ( z . length ) for ( var z = z . slice ( 0 ) ,
G, v = 0 ; v < z . length ; v ++ ) { if ( x . errorProof ) try { G = z [ v ] . call ( this , g , l , e , h ) } catch ( m ) { } else G = z [ v ] . call ( this , g , l , e , h ) ; G === a ? d = 1 : "undefined" != typeof G&& ( l = G ) ; if ( c || d ) break } } l = d ? ! 1 : "undefined" == typeof l? ! 0 : l ; c = n ; d = y ; return l } } ( ) , fireOnce : function ( a , c , d ) { c = this . fire ( a , c , d ) ; delete b ( this ) [ a ] ; return c } , removeListener : function ( a , c ) { var d = b ( this ) [ a ] ; if ( d ) { var h = d . getListenerIndex ( c ) ; 0 <= h&& d . listeners . splice ( h , 1 ) } } , removeAllListeners : function ( ) { var a = b ( this ) , c ; for ( c in a ) delete a [ c ] } , hasListeners : function ( a ) { return ( a =
b ( this ) [ a ] ) && 0 < a . listeners . length } } } ( ) ) } ) ( ) ; CKEDITOR . editor || ( CKEDITOR . editor = function ( ) { CKEDITOR . _ . pending . push ( [ this , arguments ] ) ; CKEDITOR . event . call ( this ) } , CKEDITOR . editor . prototype . fire = function ( a , d ) { a in { instanceReady : 1 , loaded : 1 } && ( this [ a ] = ! 0 ) ; return CKEDITOR . event . prototype . fire . call ( this , a , d , this ) } , CKEDITOR . editor . prototype . fireOnce = function ( a , d ) { a in { instanceReady : 1 , loaded : 1 } && ( this [ a ] = ! 0 ) ; return CKEDITOR . event . prototype . fireOnce . call ( this , a , d , this ) } , CKEDITOR . event . implementOn ( CKEDITOR . editor . prototype ) ) ;
CKEDITOR . env || ( CKEDITOR . env = function ( ) { var a = navigator . userAgent . toLowerCase ( ) , d = a . match ( /edge[ \/](\d+.?\d*)/ ) , b = - 1 < a . indexOf ( "trident/" ) , b = ! ( ! d && ! b ) , b = { ie : b , edge : ! ! d , webkit : ! b && - 1 < a . indexOf ( " applewebkit/" ) , air : - 1 < a . indexOf ( " adobeair/" ) , mac : - 1 < a . indexOf ( "macintosh" ) , quirks : "BackCompat" == document . compatMode && ( ! document . documentMode || 10 > document . documentMode ) , mobile : - 1 < a . indexOf ( "mobile" ) , iOS : /(ipad|iphone|ipod)/ . test ( a ) , isCustomDomain : function ( ) { if ( ! this . ie ) return ! 1 ; var a = document . domain , b = window . location . hostname ;
return a != b && a != "[" + b + "]" } , secure : "https:" == location . protocol } ; b . gecko = "Gecko" == navigator . product && ! b . webkit && ! b . ie ; b . webkit && ( - 1 < a . indexOf ( "chrome" ) ? b . chrome = ! 0 : b . safari = ! 0 ) ; var c = 0 ; b . ie && ( c = d ? parseFloat ( d [ 1 ] ) : b . quirks || ! document . documentMode ? parseFloat ( a . match ( /msie (\d+)/ ) [ 1 ] ) : document . documentMode , b . ie9Compat = 9 == c , b . ie8Compat = 8 == c , b . ie7Compat = 7 == c , b . ie6Compat = 7 > c || b . quirks ) ; b . gecko && ( d = a . match ( /rv:([\d\.]+)/ ) ) && ( d = d [ 1 ] . split ( "." ) , c = 1E4 * d [ 0 ] + 100 * ( d [ 1 ] || 0 ) + 1 * ( d [ 2 ] || 0 ) ) ; b . air && ( c = parseFloat ( a . match ( / adobeair\/(\d+)/ ) [ 1 ] ) ) ;
@ -19,46 +19,46 @@ b.iOS&&(b.cssClass+=" cke_browser_ios");b.hidpi&&(b.cssClass+=" cke_hidpi");retu
CKEDITOR . loadFullCore , d = CKEDITOR . loadFullCoreTimeout ; a && ( CKEDITOR . status = "basic_ready" , a && a . _load ? a ( ) : d && setTimeout ( function ( ) { CKEDITOR . loadFullCore && CKEDITOR . loadFullCore ( ) } , 1E3 * d ) ) } ) } ) ( ) ; CKEDITOR . status = "basic_loaded" } ( ) ; "use strict" ; CKEDITOR . VERBOSITY _WARN = 1 ; CKEDITOR . VERBOSITY _ERROR = 2 ; CKEDITOR . verbosity = CKEDITOR . VERBOSITY _WARN | CKEDITOR . VERBOSITY _ERROR ; CKEDITOR . warn = function ( a , d ) { CKEDITOR . verbosity & CKEDITOR . VERBOSITY _WARN && CKEDITOR . fire ( "log" , { type : "warn" , errorCode : a , additionalData : d } ) } ;
CKEDITOR . error = function ( a , d ) { CKEDITOR . verbosity & CKEDITOR . VERBOSITY _ERROR && CKEDITOR . fire ( "log" , { type : "error" , errorCode : a , additionalData : d } ) } ;
CKEDITOR . on ( "log" , function ( a ) { if ( window . console && window . console . log ) { var d = console [ a . data . type ] ? a . data . type : "log" , b = a . data . errorCode ; if ( a = a . data . additionalData ) console [ d ] ( "[CKEDITOR] Error code: " + b + "." , a ) ; else console [ d ] ( "[CKEDITOR] Error code: " + b + "." ) ; console [ d ] ( "[CKEDITOR] For more information about this error go to https://ckeditor.com/docs/ckeditor4/latest/guide/dev_errors.html#" + b ) } } , null , null , 999 ) ; CKEDITOR . dom = { } ;
( function ( ) { function a ( a , b, c ) { this . _minInterval = a ; this . _context = c ; this . _lastOutput = this . _scheduledTimer = 0 ; this . _output = CKEDITOR . tools . bind ( b, c || { } ) ; var f = this ; this . input = function ( ) { function a ( ) { f . _lastOutput = ( new Date ) . getTime ( ) ; f. _scheduledTimer = 0 ; f . _call ( ) } if ( ! f . _scheduledTimer || ! 1 !== f . _reschedule ( ) ) { var w = ( new Date ) . getTime ( ) - f. _lastOutput ; w < f . _minInterval ? f . _scheduledTimer = setTimeout ( a , f . _minInterval - w ) : a ( ) } } } function d ( w, b , c ) { a . call ( this , w , b , c ) ; this . _args = [ ] ; var f = this ; this . input = CKEDITOR . tools . override ( this . input ,
function ( a ) { return function ( ) { f . _args = Array . prototype . slice . call ( arguments ) ; a . call ( this ) } } ) } var b = [ ] , c = CKEDITOR . env . gecko ? "-moz-" : CKEDITOR . env . webkit ? "-webkit-" : CKEDITOR . env . ie ? "-ms-" : "" , g= /&/g , e = />/g , h = /</g , k = /"/g , l = /&(lt|gt|amp|quot|nbsp|shy|#\d{1,5});/g , q = { lt : "\x3c" , gt : "\x3e" , amp : "\x26" , quot : '"' , nbsp : " " , shy : " " } , f= function ( a , b ) { return "#" == b [ 0 ] ? String . fromCharCode ( parseInt ( b . slice ( 1 ) , 10 ) ) : q[ b ] } ; CKEDITOR . on ( "reset" , function ( ) { b = [ ] } ) ; CKEDITOR . tools = { arrayCompare : function ( a , b) { if ( ! a && ! b ) return ! 0 ;
if ( ! a || ! b|| a . length != b . length ) return ! 1 ; for ( var c= 0 ; c < a . length ; c ++ ) if ( a [ c ] != b [ c ] ) return ! 1 ; return ! 0 } , getIndex : function ( a , b) { for ( var c = 0 ; c < a . length ; ++ c ) if ( b ( a [ c ] ) ) return c ; return - 1 } , clone : function ( a ) { var b ; if ( a && a instanceof Array ) { b = [ ] ; for ( var c = 0 ; c < a . length ; c ++ ) b [ c ] = CKEDITOR . tools . clone ( a [ c ] ) ; return b } if ( null === a || "object" != typeof a || a instanceof String || a instanceof Number || a instanceof Boolean || a instanceof Date || a instanceof RegExp || a . nodeType || a . window === a ) return a ; b = new a . constructor ; for ( c in a ) b [ c ] =
CKEDITOR . tools . clone ( a [ c ] ) ; return b } , capitalize : function ( a , b ) { return a . charAt ( 0 ) . toUpperCase ( ) + ( b ? a . slice ( 1 ) : a . slice ( 1 ) . toLowerCase ( ) ) } , extend : function ( a ) { var b = arguments . length , c , f ; "boolean" == typeof ( c = arguments [ b - 1 ] ) ? b -- : "boolean" == typeof ( c = arguments [ b - 2 ] ) && ( f = arguments [ b - 1 ] , b -= 2 ) ; for ( var k= 1 ; k < b ; k ++ ) { var m = arguments [ k ] || { } ; CKEDITOR . tools . array . forEach ( CKEDITOR . tools . object . keys ( m ) , function ( b ) { if ( ! 0 === c || null == a [ b ] ) if ( ! f|| b in f ) a [ b ] = m [ b ] } ) } return a } , prototypedCopy : function ( a ) { var b = function ( ) { } ;
b . prototype = a ; return new b } , copy : function ( a ) { var b = { } , c ; for ( c in a ) b [ c ] = a [ c ] ; return b } , isArray : function ( a ) { return "[object Array]" == Object . prototype . toString . call ( a ) } , isEmpty : function ( a ) { for ( var b in a ) if ( a . hasOwnProperty ( b ) ) return ! 1 ; return ! 0 } , cssVendorPrefix : function ( a , b , f) { if ( f ) return c + a + ":" + b + ";" + a + ":" + b ; f= { } ; f [ a ] = b ; f [ c + a ] = b ; return f } , cssStyleToDomStyle : function ( ) { var a = document . createElement ( "div" ) . style , b = "undefined" != typeof a . cssFloat ? "cssFloat" : "undefined" != typeof a . styleFloat ? "styleFloat" :
"float" ; return function ( a ) { return "float" == a ? b : a . replace ( /-./g , function ( a ) { return a . substr ( 1 ) . toUpperCase ( ) } ) } } ( ) , buildStyleHtml : function ( a ) { a = [ ] . concat ( a ) ; for ( var b , c = [ ] , f= 0 ; f < a . length ; f ++ ) if ( b = a [ f ] ) / @ import | [ { } ] / . test ( b ) ? c . push ( "\x3cstyle\x3e" + b + "\x3c/style\x3e" ) : ( b = CKEDITOR . appendTimestamp ( b ) , c . push ( '\x3clink type\x3d"text/css" rel\x3dstylesheet href\x3d"' + b + '"\x3e' ) ) ; return c . join ( "" ) } , htmlEncode : function ( a ) { return void 0 === a || null === a ? "" : String ( a ) . replace ( g , "\x26amp;" ) . replace ( e , "\x26gt;" ) . replace ( h ,
"\x26lt;" ) } , htmlDecode : function ( a ) { return a . replace ( l, f ) } , htmlEncodeAttr : function ( a ) { return CKEDITOR . tools . htmlEncode ( a ) . replace ( k , "\x26quot;" ) } , htmlDecodeAttr : function ( a ) { return CKEDITOR . tools . htmlDecode ( a ) } , transformPlainTextToHtml : function ( a , b ) { var c = b == CKEDITOR . ENTER _BR , f = this . htmlEncode ( a . replace ( /\r\n/g , "\n" ) ) , f= f . replace ( /\t/g , "\x26nbsp;\x26nbsp; \x26nbsp;" ) , k = b == CKEDITOR . ENTER _P ? "p" : "div" ; if ( ! c ) { var m = /\n{2}/g ; if ( m . test ( f) ) var l = "\x3c" + k + "\x3e" , e = "\x3c/" + k + "\x3e" , f = l + f . replace ( m , function ( ) { return e +
l} ) + e } f = f . replace ( /\n/g , "\x3cbr\x3e" ) ; c || ( f= f . replace ( new RegExp ( "\x3cbr\x3e(?\x3d\x3c/" + k + "\x3e)" ) , function ( a ) { return CKEDITOR . tools . repeat ( a , 2 ) } ) ) ; f= f . replace ( /^ | $/g , "\x26nbsp;" ) ; return f= f . replace ( /(>|\s) /g , function ( a , b ) { return b + "\x26nbsp;" } ) . replace ( / (?=<)/g , "\x26nbsp;" ) } , getNextNumber : function ( ) { var a = 0 ; return function ( ) { return ++ a } } ( ) , getNextId : function ( ) { return "cke_" + this . getNextNumber ( ) } , getUniqueId : function ( ) { for ( var a = "e" , b = 0 ; 8 > b ; b ++ ) a += Math . floor ( 65536 * ( 1 + Math . random ( ) ) ) . toString ( 16 ) . substring ( 1 ) ;
return a } , override : function ( a , b ) { var c = b ( a ) ; c . prototype = a . prototype ; return c } , setTimeout : function ( a , b , c , f, k ) { k || ( k = window ) ; c || ( c = k ) ; return k . setTimeout ( function ( ) { f ? a . apply ( c , [ ] . concat ( f ) ) : a . apply ( c ) } , b || 0 ) } , debounce : function ( a , b ) { var c ; return function ( ) { var f= this , k = arguments ; clearTimeout ( c ) ; c = setTimeout ( function ( ) { c = null ; a . apply ( f, k ) } , b ) } } , throttle : function ( a , b , c ) { return new this . buffers . throttle ( a , b , c ) } , trim : function ( ) { var a = /(?:^[ \t\n\r]+)|(?:[ \t\n\r]+$)/g ; return function ( b ) { return b . replace ( a ,
"" ) } } ( ) , ltrim : function ( ) { var a = /^[ \t\n\r]+/g ; return function ( b ) { return b . replace ( a , "" ) } } ( ) , rtrim : function ( ) { var a = /[ \t\n\r]+$/g ; return function ( b ) { return b . replace ( a , "" ) } } ( ) , indexOf : function ( a , b ) { if ( "function" == typeof b ) for ( var c = 0 , f= a . length ; c < f ; c ++ ) { if ( b ( a [ c ] ) ) return c } else { if ( a . indexOf ) return a . indexOf ( b ) ; c = 0 ; for ( f= a . length ; c < f ; c ++ ) if ( a [ c ] === b ) return c } return - 1 } , search : function ( a , b ) { var c = CKEDITOR . tools . indexOf ( a , b ) ; return 0 <= c ? a [ c ] : null } , bind : function ( a , b ) { var c = Array . prototype . slice . call ( arguments ,
2 ) ; return function ( ) { return a . apply ( b , c . concat ( Array . prototype . slice . call ( arguments ) ) ) } } , createClass : function ( a ) { var b = a . $ , c = a . base , f= a . privates || a . _ , k = a . proto ; a = a . statics ; ! b && ( b = function ( ) { c && this . base . apply ( this , arguments ) } ) ; if ( f ) var m = b , b = function ( ) { var a = this . _ || ( this . _ = { } ) , b ; for ( b in f) { var c = f [ b ] ; a [ b ] = "function" == typeof c ? CKEDITOR . tools . bind ( c , this ) : c } m . apply ( this , arguments ) } ; c && ( b . prototype = this . prototypedCopy ( c . prototype ) , b . prototype . constructor = b , b . base = c , b . baseProto = c . prototype , b . prototype . base =
function v ( ) { this . base = c . prototype . base ; c . apply ( this , arguments ) ; this . base = v} ) ; k && this . extend ( b . prototype , k , ! 0 ) ; a && this . extend ( b , a , ! 0 ) ; return b } , addFunction : function ( a , c ) { return b . push ( function ( ) { return a . apply ( c || this , arguments ) } ) - 1 } , removeFunction : function ( a ) { b [ a ] = null } , callFunction : function ( a ) { var c = b [ a ] ; return c && c . apply ( window , Array . prototype . slice . call ( arguments , 1 ) ) } , cssLength : function ( ) { var a = /^-?\d+\.?\d*px$/ , b ; return function ( c ) { b = CKEDITOR . tools . trim ( c + "" ) + "px" ; return a . test ( b ) ? b : c || "" } } ( ) ,
convertToPx : function ( ) { var a , b ; return function ( c ) { if ( ! a || a . isDetached ( ) ) a = CKEDITOR . dom . element . createFromHtml ( '\x3cdiv style\x3d"position:absolute;left:-9999px;top:-9999px;margin:0px;padding:0px;border:0px;"\x3e\x3c/div\x3e' , CKEDITOR . document ) , CKEDITOR . document . getBody ( ) . append ( a ) ; if ( ! /%$/ . test ( c ) ) { var f= 0 > parseFloat ( c ) ; f && ( c = c . replace ( "-" , "" ) ) ; a . setStyle ( "width" , c ) ; b = a . getClientRect ( ) ; c = Math . round ( b . width ) ; return f ? - c : c } return c } } ( ) , repeat : function ( a , b ) { return Array ( b + 1 ) . join ( a ) } , tryThese : function ( ) { for ( var a ,
b = 0 , c = arguments . length ; b < c ; b ++ ) { var f = arguments [ b ] ; try { a = f( ) ; break } catch ( k ) { } } return a } , genKey : function ( ) { return Array . prototype . slice . call ( arguments ) . join ( "-" ) } , defer : function ( a ) { return function ( ) { var b = arguments , c = this ; window . setTimeout ( function ( ) { a . apply ( c , b ) } , 0 ) } } , normalizeCssText : function ( a , b ) { var c = [ ] , f, k = CKEDITOR . tools . parseCssText ( a , ! 0 , b ) ; for ( f in k ) c . push ( f + ":" + k [ f ] ) ; c . sort ( ) ; return c . length ? c . join ( ";" ) + ";" : "" } , convertRgbToHex : function ( a ) { return a . replace ( /(?:rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\))/gi ,
function ( a , b , c , f) { a = [ b , c , f ] ; for ( b = 0 ; 3 > b ; b ++ ) a [ b ] = ( "0" + parseInt ( a [ b ] , 10 ) . toString ( 16 ) ) . slice ( - 2 ) ; return "#" + a . join ( "" ) } ) } , normalizeHex : function ( a ) { return a . replace ( /#(([0-9a-f]{3}){1,2})($|;|\s+)/gi , function ( a , b , c , f ) { a = b . toLowerCase ( ) ; 3 == a . length && ( a = a . split ( "" ) , a = [ a [ 0 ] , a [ 0 ] , a [ 1 ] , a [ 1 ] , a [ 2 ] , a [ 2 ] ] . join ( "" ) ) ; return "#" + a + f } ) } , _isValidColorFormat : function ( a ) { if ( ! a ) return ! 1 ; a = a . replace ( /\s+/g , "" ) ; return /^[a-z0-9()#%,./]+$/i . test ( a ) } , parseCssText : function ( a , b , c ) { var f = { } ; c && ( a = ( new CKEDITOR . dom . element ( "span" ) ) . setAttribute ( "style" ,
a ) . getAttribute ( "style" ) || "" ) ; a && ( a = CKEDITOR . tools . normalizeHex ( CKEDITOR . tools . convertRgbToHex ( a ) ) ) ; if ( ! a || ";" == a ) return f ; a . replace ( /"/g , '"' ) . replace ( /\s*([^:;\s]+)\s*:\s*([^;]+)\s*(?=;|$)/g , function ( a , c , w ) { b && ( c = c . toLowerCase ( ) , "font-family" == c && ( w= w . replace ( /\s*,\s*/g , "," ) ) , w= CKEDITOR . tools . trim ( w ) ) ; f [ c ] = w } ) ; return f } , writeCssText : function ( a , b ) { var c , f = [ ] ; for ( c in a ) f . push ( c + ":" + a [ c ] ) ; b && f. sort ( ) ; return f . join ( "; " ) } , objectCompare : function ( a , b , c ) { var f ; if ( ! a && ! b ) return ! 0 ; if ( ! a || ! b ) return ! 1 ;
for ( f in a ) if ( a [ f ] != b [ f ] ) return ! 1 ; if ( ! c ) for ( f in b ) if ( a [ f ] != b [ f ] ) return ! 1 ; return ! 0 } , objectKeys : function ( a ) { return CKEDITOR . tools . object . keys ( a ) } , convertArrayToObject : function ( a , b ) { var c = { } ; 1 == arguments . length && ( b = ! 0 ) ; for ( var f= 0 , k = a . length ; f < k ; ++ f ) c [ a [ f ] ] = b ; return c } , getStyledSpans : function ( a , b ) { var c = CKEDITOR . env . ie && 8 == CKEDITOR . env . version ? a . toUpperCase ( ) : a , c = b . find ( "span[style*\x3d" + c + "]" ) . toArray ( ) ; return CKEDITOR . tools . array . filter ( c , function ( b ) { return ! ! b . getStyle ( a ) } ) } , fixDomain : function ( ) { for ( var a ; ; ) try { a =
window . parent . document . domain ; break } catch ( b ) { a = a ? a . replace ( /.+?(?:\.|$)/ , "" ) : document . domain ; if ( ! a ) break ; document . domain = a } return ! ! a } , eventsBuffer : function ( a , b , c ) { return new this . buffers . event ( a , b , c ) } , enableHtml5Elements : function ( a , b ) { for ( var c = "abbr article aside audio bdi canvas data datalist details figcaption figure footer header hgroup main mark meter nav output progress section summary time video" . split ( " " ) , f= c . length , k ; f -- ; ) k = a . createElement ( c [ f ] ) , b && a . appendChild ( k ) } , checkIfAnyArrayItemMatches : function ( a ,
b ) { for ( var c = 0 , f= a . length ; c < f ; ++ c ) if ( a [ c ] . match ( b ) ) return ! 0 ; return ! 1 } , checkIfAnyObjectPropertyMatches : function ( a , b ) { for ( var c in a ) if ( c . match ( b ) ) return ! 0 ; return ! 1 } , keystrokeToString : function ( a , b ) { var c = this . keystrokeToArray ( a , b ) ; c . display = c . display . join ( "+" ) ; c . aria = c . aria . join ( "+" ) ; return c } , keystrokeToArray : function ( a , b ) { var c = b & 16711680 , f= b & 65535 , k = CKEDITOR . env . mac , m = [ ] , l = [ ] ; c & CKEDITOR . CTRL && ( m . push ( k ? "⌘" : a [ 17 ] ) , l. push ( k ? a [ 224 ] : a [ 17 ] ) ) ; c & CKEDITOR . ALT && ( m . push ( k ? "⌥" : a [ 18 ] ) , l . push ( a [ 18 ] ) ) ; c & CKEDITOR . SHIFT &&
( m . push ( k ? "⇧" : a [ 16 ] ) , l . push ( a [ 16 ] ) ) ; f&& ( a [ f ] ? ( m . push ( a [ f ] ) , l . push ( a [ f ] ) ) : ( m . push ( String . fromCharCode ( f) ) , l . push ( String . fromCharCode ( f ) ) ) ) ; return { display : m , aria : l } } , transparentImageData : "\x3d\x3d" , getCookie : function ( a ) { a = a . toLowerCase ( ) ; for ( var b = document . cookie . split ( ";" ) , c , f, k = 0 ; k < b . length ; k ++ ) if ( c = b [ k ] . split ( "\x3d" ) , f = decodeURIComponent ( CKEDITOR . tools . trim ( c [ 0 ] ) . toLowerCase ( ) ) , f === a ) return decodeURIComponent ( 1 < c . length ?
c [ 1 ] : "" ) ; return null } , setCookie : function ( a , b ) { document . cookie = encodeURIComponent ( a ) + "\x3d" + encodeURIComponent ( b ) + ";path\x3d/" } , getCsrfToken : function ( ) { var a = CKEDITOR . tools . getCookie ( "ckCsrfToken" ) ; if ( ! a || 40 != a . length ) { var a = [ ] , b = "" ; if ( window . crypto && window . crypto . getRandomValues ) a = new Uint8Array ( 40 ) , window . crypto . getRandomValues ( a ) ; else for ( var c = 0 ; 40 > c ; c ++ ) a . push ( Math . floor ( 256 * Math . random ( ) ) ) ; for ( c = 0 ; c < a . length ; c ++ ) var f = "abcdefghijklmnopqrstuvwxyz0123456789" . charAt ( a [ c ] % 36 ) , b = b + ( . 5 < Math . random ( ) ?
f. toUpperCase ( ) : f ) ; a = b ; CKEDITOR . tools . setCookie ( "ckCsrfToken" , a ) } return a } , escapeCss : function ( a ) { if ( a ) if ( window . CSS && CSS . escape ) a = CSS . escape ( a ) ; else { a = String ( a ) ; for ( var b = a . length , c = - 1 , f, k = "" , m = a . charCodeAt ( 0 ) ; ++ c < b ; ) f= a . charCodeAt ( c ) , k = 0 == f ? k + "<22> " : 127 == f || 1 <= f && 31 >= f || 0 == c && 48 <= f && 57 >= f || 1 == c && 48 <= f && 57 >= f && 45 == m ? k + ( "\\" + f . toString ( 16 ) + " " ) : 0 == c && 1 == b && 45 == f? k + ( "\\" + a . charAt ( c ) ) : 128 <= f|| 45 == f || 95 == f || 48 <= f && 57 >= f || 65 <= f && 90 >= f || 97 <= f && 122 >= f ? k + a . charAt ( c ) : k + ( "\\" + a . charAt ( c ) ) ; a = k } else a = "" ; return a } ,
getMouseButton : function ( a ) { return ( a = a && a . data ? a . data . $ : a ) ? CKEDITOR . tools . normalizeMouseButton ( a . button ) : ! 1 } , normalizeMouseButton : function ( a , b ) { if ( ! CKEDITOR . env . ie || 9 <= CKEDITOR . env . version && ! CKEDITOR . env . ie6Compat ) return a ; for ( var c = [ [ CKEDITOR . MOUSE _BUTTON _LEFT , 1 ] , [ CKEDITOR . MOUSE _BUTTON _MIDDLE , 4 ] , [ CKEDITOR . MOUSE _BUTTON _RIGHT , 2 ] ] , f= 0 ; f < c . length ; f ++ ) { var k = c [ f ] ; if ( k [ 0 ] === a && b ) return k[ 1 ] ; if ( ! b && k [ 1 ] === a ) return k [ 0 ] } } , convertHexStringToBytes : function ( a ) { var b = [ ] , c = a . length / 2 , f; for ( f = 0 ; f < c ; f ++ ) b . push ( parseInt ( a . substr ( 2 *
f , 2 ) , 16 ) ) ; return b } , convertBytesToBase64 : function ( a ) { var b = "" , c = a . length , f; for ( f = 0 ; f < c ; f += 3 ) { var k = a . slice ( f , f + 3 ) , m = k . length , l = [ ] , e ; if ( 3 > m ) for ( e = m ; 3 > e ; e ++ ) k [ e ] = 0 ; l [ 0 ] = ( k [ 0 ] & 252 ) >> 2 ; l[ 1 ] = ( k [ 0 ] & 3 ) << 4 | k [ 1 ] >> 4 ; l [ 2 ] = ( k [ 1 ] & 15 ) << 2 | ( k [ 2 ] & 192 ) >> 6 ; l[ 3 ] = k [ 2 ] & 63 ; for ( e = 0 ; 4 > e ; e ++ ) b = e <= m ? b + "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/" . charAt ( l[ e ] ) : b + "\x3d" } return b } , style : { parse : { _borderStyle : "none hidden dotted dashed solid double groove ridge inset outset" . split ( " " ) , _widthRegExp : /^(thin|medium|thick|[\+-]?\d+(\.\d+)?[a-z%]+|[\+-]?0+(\.0+)?|\.\d+[a-z%]+)$/ ,
( function ( ) { function a ( a , y, b ) { this . _minInterval = a ; this . _context = b ; this . _lastOutput = this . _scheduledTimer = 0 ; this . _output = CKEDITOR . tools . bind ( y, b || { } ) ; var c = this ; this . input = function ( ) { function a ( ) { c . _lastOutput = ( new Date ) . getTime ( ) ; c. _scheduledTimer = 0 ; c . _call ( ) } if ( ! c . _scheduledTimer || ! 1 !== c . _reschedule ( ) ) { var x = ( new Date ) . getTime ( ) - c. _lastOutput ; x < c . _minInterval ? c . _scheduledTimer = setTimeout ( a , c . _minInterval - x ) : a ( ) } } } function d ( x, y , b ) { a . call ( this , x , y , b ) ; this . _args = [ ] ; var c = this ; this . input = CKEDITOR . tools . override ( this . input ,
function ( a ) { return function ( ) { c . _args = Array . prototype . slice . call ( arguments ) ; a . call ( this ) } } ) } var b = [ ] , c = CKEDITOR . env . gecko ? "-moz-" : CKEDITOR . env . webkit ? "-webkit-" : CKEDITOR . env . ie ? "-ms-" : "" , f= /&/g , e = />/g , k = /</g , h = /"/g , n = /&(lt|gt|amp|quot|nbsp|shy|#\d{1,5});/g , l = { lt : "\x3c" , gt : "\x3e" , amp : "\x26" , quot : '"' , nbsp : " " , shy : " " } , g= function ( a , y ) { return "#" == y [ 0 ] ? String . fromCharCode ( parseInt ( y . slice ( 1 ) , 10 ) ) : l[ y ] } ; CKEDITOR . on ( "reset" , function ( ) { b = [ ] } ) ; CKEDITOR . tools = { arrayCompare : function ( a , y) { if ( ! a && ! y ) return ! 0 ;
if ( ! a || ! y|| a . length != y . length ) return ! 1 ; for ( var b= 0 ; b < a . length ; b ++ ) if ( a [ b ] != y [ b ] ) return ! 1 ; return ! 0 } , getIndex : function ( a , y) { for ( var b = 0 ; b < a . length ; ++ b ) if ( y ( a [ b ] ) ) return b ; return - 1 } , clone : function ( a ) { var b ; if ( a && a instanceof Array ) { b = [ ] ; for ( var c = 0 ; c < a . length ; c ++ ) b [ c ] = CKEDITOR . tools . clone ( a [ c ] ) ; return b } if ( null === a || "object" != typeof a || a instanceof String || a instanceof Number || a instanceof Boolean || a instanceof Date || a instanceof RegExp || a . nodeType || a . window === a ) return a ; b = new a . constructor ; for ( c in a ) b [ c ] =
CKEDITOR . tools . clone ( a [ c ] ) ; return b } , capitalize : function ( a , b ) { return a . charAt ( 0 ) . toUpperCase ( ) + ( b ? a . slice ( 1 ) : a . slice ( 1 ) . toLowerCase ( ) ) } , extend : function ( a ) { var b = arguments . length , c , g ; "boolean" == typeof ( c = arguments [ b - 1 ] ) ? b -- : "boolean" == typeof ( c = arguments [ b - 2 ] ) && ( g = arguments [ b - 1 ] , b -= 2 ) ; for ( var h= 1 ; h < b ; h ++ ) { var m = arguments [ h ] || { } ; CKEDITOR . tools . array . forEach ( CKEDITOR . tools . object . keys ( m ) , function ( b ) { if ( ! 0 === c || null == a [ b ] ) if ( ! g|| b in g ) a [ b ] = m [ b ] } ) } return a } , prototypedCopy : function ( a ) { var b = function ( ) { } ;
b . prototype = a ; return new b } , copy : function ( a ) { var b = { } , c ; for ( c in a ) b [ c ] = a [ c ] ; return b } , isArray : function ( a ) { return "[object Array]" == Object . prototype . toString . call ( a ) } , isEmpty : function ( a ) { for ( var b in a ) if ( a . hasOwnProperty ( b ) ) return ! 1 ; return ! 0 } , cssVendorPrefix : function ( a , b , g) { if ( g ) return c + a + ":" + b + ";" + a + ":" + b ; g= { } ; g [ a ] = b ; g [ c + a ] = b ; return g } , cssStyleToDomStyle : function ( ) { var a = document . createElement ( "div" ) . style , b = "undefined" != typeof a . cssFloat ? "cssFloat" : "undefined" != typeof a . styleFloat ? "styleFloat" :
"float" ; return function ( a ) { return "float" == a ? b : a . replace ( /-./g , function ( a ) { return a . substr ( 1 ) . toUpperCase ( ) } ) } } ( ) , buildStyleHtml : function ( a ) { a = [ ] . concat ( a ) ; for ( var b , c = [ ] , g= 0 ; g < a . length ; g ++ ) if ( b = a [ g ] ) / @ import | [ { } ] / . test ( b ) ? c . push ( "\x3cstyle\x3e" + b + "\x3c/style\x3e" ) : ( b = CKEDITOR . appendTimestamp ( b ) , c . push ( '\x3clink type\x3d"text/css" rel\x3dstylesheet href\x3d"' + b + '"\x3e' ) ) ; return c . join ( "" ) } , htmlEncode : function ( a ) { return void 0 === a || null === a ? "" : String ( a ) . replace ( f , "\x26amp;" ) . replace ( e , "\x26gt;" ) . replace ( k ,
"\x26lt;" ) } , htmlDecode : function ( a ) { return a . replace ( n, g ) } , htmlEncodeAttr : function ( a ) { return CKEDITOR . tools . htmlEncode ( a ) . replace ( h , "\x26quot;" ) } , htmlDecodeAttr : function ( a ) { return CKEDITOR . tools . htmlDecode ( a ) } , transformPlainTextToHtml : function ( a , b ) { var c = b == CKEDITOR . ENTER _BR , g = this . htmlEncode ( a . replace ( /\r\n/g , "\n" ) ) , g= g . replace ( /\t/g , "\x26nbsp;\x26nbsp; \x26nbsp;" ) , h = b == CKEDITOR . ENTER _P ? "p" : "div" ; if ( ! c ) { var m = /\n{2}/g ; if ( m . test ( g) ) var e = "\x3c" + h + "\x3e" , d = "\x3c/" + h + "\x3e" , g = e + g . replace ( m , function ( ) { return d +
e} ) + d } g = g . replace ( /\n/g , "\x3cbr\x3e" ) ; c || ( g= g . replace ( new RegExp ( "\x3cbr\x3e(?\x3d\x3c/" + h + "\x3e)" ) , function ( a ) { return CKEDITOR . tools . repeat ( a , 2 ) } ) ) ; g= g . replace ( /^ | $/g , "\x26nbsp;" ) ; return g= g . replace ( /(>|\s) /g , function ( a , b ) { return b + "\x26nbsp;" } ) . replace ( / (?=<)/g , "\x26nbsp;" ) } , getNextNumber : function ( ) { var a = 0 ; return function ( ) { return ++ a } } ( ) , getNextId : function ( ) { return "cke_" + this . getNextNumber ( ) } , getUniqueId : function ( ) { for ( var a = "e" , b = 0 ; 8 > b ; b ++ ) a += Math . floor ( 65536 * ( 1 + Math . random ( ) ) ) . toString ( 16 ) . substring ( 1 ) ;
return a } , override : function ( a , b ) { var c = b ( a ) ; c . prototype = a . prototype ; return c } , setTimeout : function ( a , b , c , g, h ) { h || ( h = window ) ; c || ( c = h ) ; return h . setTimeout ( function ( ) { g ? a . apply ( c , [ ] . concat ( g ) ) : a . apply ( c ) } , b || 0 ) } , debounce : function ( a , b ) { var c ; return function ( ) { var g= this , h = arguments ; clearTimeout ( c ) ; c = setTimeout ( function ( ) { c = null ; a . apply ( g, h ) } , b ) } } , throttle : function ( a , b , c ) { return new this . buffers . throttle ( a , b , c ) } , trim : function ( ) { var a = /(?:^[ \t\n\r]+)|(?:[ \t\n\r]+$)/g ; return function ( b ) { return b . replace ( a ,
"" ) } } ( ) , ltrim : function ( ) { var a = /^[ \t\n\r]+/g ; return function ( b ) { return b . replace ( a , "" ) } } ( ) , rtrim : function ( ) { var a = /[ \t\n\r]+$/g ; return function ( b ) { return b . replace ( a , "" ) } } ( ) , indexOf : function ( a , b ) { if ( "function" == typeof b ) for ( var c = 0 , g= a . length ; c < g ; c ++ ) { if ( b ( a [ c ] ) ) return c } else { if ( a . indexOf ) return a . indexOf ( b ) ; c = 0 ; for ( g= a . length ; c < g ; c ++ ) if ( a [ c ] === b ) return c } return - 1 } , search : function ( a , b ) { var c = CKEDITOR . tools . indexOf ( a , b ) ; return 0 <= c ? a [ c ] : null } , bind : function ( a , b ) { var c = Array . prototype . slice . call ( arguments ,
2 ) ; return function ( ) { return a . apply ( b , c . concat ( Array . prototype . slice . call ( arguments ) ) ) } } , createClass : function ( a ) { var b = a . $ , c = a . base , g= a . privates || a . _ , h = a . proto ; a = a . statics ; ! b && ( b = function ( ) { c && this . base . apply ( this , arguments ) } ) ; if ( g ) var m = b , b = function ( ) { var a = this . _ || ( this . _ = { } ) , b ; for ( b in g) { var c = g [ b ] ; a [ b ] = "function" == typeof c ? CKEDITOR . tools . bind ( c , this ) : c } m . apply ( this , arguments ) } ; c && ( b . prototype = this . prototypedCopy ( c . prototype ) , b . prototype . constructor = b , b . base = c , b . baseProto = c . prototype , b . prototype . base =
function w ( ) { this . base = c . prototype . base ; c . apply ( this , arguments ) ; this . base = w} ) ; h && this . extend ( b . prototype , h , ! 0 ) ; a && this . extend ( b , a , ! 0 ) ; return b } , addFunction : function ( a , c ) { return b . push ( function ( ) { return a . apply ( c || this , arguments ) } ) - 1 } , removeFunction : function ( a ) { b [ a ] = null } , callFunction : function ( a ) { var c = b [ a ] ; return c && c . apply ( window , Array . prototype . slice . call ( arguments , 1 ) ) } , cssLength : function ( ) { var a = /^-?\d+\.?\d*px$/ , b ; return function ( c ) { b = CKEDITOR . tools . trim ( c + "" ) + "px" ; return a . test ( b ) ? b : c || "" } } ( ) ,
convertToPx : function ( ) { var a , b ; return function ( c ) { if ( ! a || a . isDetached ( ) ) a = CKEDITOR . dom . element . createFromHtml ( '\x3cdiv style\x3d"position:absolute;left:-9999px;top:-9999px;margin:0px;padding:0px;border:0px;"\x3e\x3c/div\x3e' , CKEDITOR . document ) , CKEDITOR . document . getBody ( ) . append ( a ) ; if ( ! /%$/ . test ( c ) ) { var g= 0 > parseFloat ( c ) ; g && ( c = c . replace ( "-" , "" ) ) ; a . setStyle ( "width" , c ) ; b = a . getClientRect ( ) ; c = Math . round ( b . width ) ; return g ? - c : c } return c } } ( ) , repeat : function ( a , b ) { return Array ( b + 1 ) . join ( a ) } , tryThese : function ( ) { for ( var a ,
b = 0 , c = arguments . length ; b < c ; b ++ ) { var g = arguments [ b ] ; try { a = g( ) ; break } catch ( h ) { } } return a } , genKey : function ( ) { return Array . prototype . slice . call ( arguments ) . join ( "-" ) } , defer : function ( a ) { return function ( ) { var b = arguments , c = this ; window . setTimeout ( function ( ) { a . apply ( c , b ) } , 0 ) } } , normalizeCssText : function ( a , b ) { var c = [ ] , g, h = CKEDITOR . tools . parseCssText ( a , ! 0 , b ) ; for ( g in h ) c . push ( g + ":" + h [ g ] ) ; c . sort ( ) ; return c . length ? c . join ( ";" ) + ";" : "" } , convertRgbToHex : function ( a ) { return a . replace ( /(?:rgb\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\))/gi ,
function ( a , b , c , g) { a = [ b , c , g ] ; for ( b = 0 ; 3 > b ; b ++ ) a [ b ] = ( "0" + parseInt ( a [ b ] , 10 ) . toString ( 16 ) ) . slice ( - 2 ) ; return "#" + a . join ( "" ) } ) } , normalizeHex : function ( a ) { return a . replace ( /#(([0-9a-f]{3}){1,2})($|;|\s+)/gi , function ( a , b , c , g ) { a = b . toLowerCase ( ) ; 3 == a . length && ( a = a . split ( "" ) , a = [ a [ 0 ] , a [ 0 ] , a [ 1 ] , a [ 1 ] , a [ 2 ] , a [ 2 ] ] . join ( "" ) ) ; return "#" + a + g } ) } , _isValidColorFormat : function ( a ) { if ( ! a ) return ! 1 ; a = a . replace ( /\s+/g , "" ) ; return /^[a-z0-9()#%,./]+$/i . test ( a ) } , parseCssText : function ( a , b , c ) { var g = { } ; c && ( a = ( new CKEDITOR . dom . element ( "span" ) ) . setAttribute ( "style" ,
a ) . getAttribute ( "style" ) || "" ) ; a && ( a = CKEDITOR . tools . normalizeHex ( CKEDITOR . tools . convertRgbToHex ( a ) ) ) ; if ( ! a || ";" == a ) return g ; a . replace ( /"/g , '"' ) . replace ( /\s*([^:;\s]+)\s*:\s*([^;]+)\s*(?=;|$)/g , function ( a , c , x ) { b && ( c = c . toLowerCase ( ) , "font-family" == c && ( x= x . replace ( /\s*,\s*/g , "," ) ) , x= CKEDITOR . tools . trim ( x ) ) ; g [ c ] = x } ) ; return g } , writeCssText : function ( a , b ) { var c , g = [ ] ; for ( c in a ) g . push ( c + ":" + a [ c ] ) ; b && g. sort ( ) ; return g . join ( "; " ) } , objectCompare : function ( a , b , c ) { var g ; if ( ! a && ! b ) return ! 0 ; if ( ! a || ! b ) return ! 1 ;
for ( g in a ) if ( a [ g ] != b [ g ] ) return ! 1 ; if ( ! c ) for ( g in b ) if ( a [ g ] != b [ g ] ) return ! 1 ; return ! 0 } , objectKeys : function ( a ) { return CKEDITOR . tools . object . keys ( a ) } , convertArrayToObject : function ( a , b ) { var c = { } ; 1 == arguments . length && ( b = ! 0 ) ; for ( var g= 0 , h = a . length ; g < h ; ++ g ) c [ a [ g ] ] = b ; return c } , getStyledSpans : function ( a , b ) { var c = CKEDITOR . env . ie && 8 == CKEDITOR . env . version ? a . toUpperCase ( ) : a , c = b . find ( "span[style*\x3d" + c + "]" ) . toArray ( ) ; return CKEDITOR . tools . array . filter ( c , function ( b ) { return ! ! b . getStyle ( a ) } ) } , fixDomain : function ( ) { for ( var a ; ; ) try { a =
window . parent . document . domain ; break } catch ( b ) { a = a ? a . replace ( /.+?(?:\.|$)/ , "" ) : document . domain ; if ( ! a ) break ; document . domain = a } return ! ! a } , eventsBuffer : function ( a , b , c ) { return new this . buffers . event ( a , b , c ) } , enableHtml5Elements : function ( a , b ) { for ( var c = "abbr article aside audio bdi canvas data datalist details figcaption figure footer header hgroup main mark meter nav output progress section summary time video" . split ( " " ) , g= c . length , h ; g -- ; ) h = a . createElement ( c [ g ] ) , b && a . appendChild ( h ) } , checkIfAnyArrayItemMatches : function ( a ,
b ) { for ( var c = 0 , g= a . length ; c < g ; ++ c ) if ( a [ c ] . match ( b ) ) return ! 0 ; return ! 1 } , checkIfAnyObjectPropertyMatches : function ( a , b ) { for ( var c in a ) if ( c . match ( b ) ) return ! 0 ; return ! 1 } , keystrokeToString : function ( a , b ) { var c = this . keystrokeToArray ( a , b ) ; c . display = c . display . join ( "+" ) ; c . aria = c . aria . join ( "+" ) ; return c } , keystrokeToArray : function ( a , b ) { var c = b & 16711680 , g= b & 65535 , h = CKEDITOR . env . mac , m = [ ] , e = [ ] ; c & CKEDITOR . CTRL && ( m . push ( h ? "⌘" : a [ 17 ] ) , e. push ( h ? a [ 224 ] : a [ 17 ] ) ) ; c & CKEDITOR . ALT && ( m . push ( h ? "⌥" : a [ 18 ] ) , e . push ( a [ 18 ] ) ) ; c & CKEDITOR . SHIFT &&
( m . push ( h ? "⇧" : a [ 16 ] ) , e . push ( a [ 16 ] ) ) ; g&& ( a [ g ] ? ( m . push ( a [ g ] ) , e . push ( a [ g ] ) ) : ( m . push ( String . fromCharCode ( g) ) , e . push ( String . fromCharCode ( g ) ) ) ) ; return { display : m , aria : e } } , transparentImageData : "\x3d\x3d" , getCookie : function ( a ) { a = a . toLowerCase ( ) ; for ( var b = document . cookie . split ( ";" ) , c , g, h = 0 ; h < b . length ; h ++ ) if ( c = b [ h ] . split ( "\x3d" ) , g = decodeURIComponent ( CKEDITOR . tools . trim ( c [ 0 ] ) . toLowerCase ( ) ) , g === a ) return decodeURIComponent ( 1 < c . length ?
c [ 1 ] : "" ) ; return null } , setCookie : function ( a , b ) { document . cookie = encodeURIComponent ( a ) + "\x3d" + encodeURIComponent ( b ) + ";path\x3d/" } , getCsrfToken : function ( ) { var a = CKEDITOR . tools . getCookie ( "ckCsrfToken" ) ; if ( ! a || 40 != a . length ) { var a = [ ] , b = "" ; if ( window . crypto && window . crypto . getRandomValues ) a = new Uint8Array ( 40 ) , window . crypto . getRandomValues ( a ) ; else for ( var c = 0 ; 40 > c ; c ++ ) a . push ( Math . floor ( 256 * Math . random ( ) ) ) ; for ( c = 0 ; c < a . length ; c ++ ) var g = "abcdefghijklmnopqrstuvwxyz0123456789" . charAt ( a [ c ] % 36 ) , b = b + ( . 5 < Math . random ( ) ?
g. toUpperCase ( ) : g ) ; a = b ; CKEDITOR . tools . setCookie ( "ckCsrfToken" , a ) } return a } , escapeCss : function ( a ) { if ( a ) if ( window . CSS && CSS . escape ) a = CSS . escape ( a ) ; else { a = String ( a ) ; for ( var b = a . length , c = - 1 , g, h = "" , m = a . charCodeAt ( 0 ) ; ++ c < b ; ) g= a . charCodeAt ( c ) , h = 0 == g ? h + "<22> " : 127 == g || 1 <= g && 31 >= g || 0 == c && 48 <= g && 57 >= g || 1 == c && 48 <= g && 57 >= g && 45 == m ? h + ( "\\" + g . toString ( 16 ) + " " ) : 0 == c && 1 == b && 45 == g? h + ( "\\" + a . charAt ( c ) ) : 128 <= g|| 45 == g || 95 == g || 48 <= g && 57 >= g || 65 <= g && 90 >= g || 97 <= g && 122 >= g ? h + a . charAt ( c ) : h + ( "\\" + a . charAt ( c ) ) ; a = h } else a = "" ; return a } ,
getMouseButton : function ( a ) { return ( a = a && a . data ? a . data . $ : a ) ? CKEDITOR . tools . normalizeMouseButton ( a . button ) : ! 1 } , normalizeMouseButton : function ( a , b ) { if ( ! CKEDITOR . env . ie || 9 <= CKEDITOR . env . version && ! CKEDITOR . env . ie6Compat ) return a ; for ( var c = [ [ CKEDITOR . MOUSE _BUTTON _LEFT , 1 ] , [ CKEDITOR . MOUSE _BUTTON _MIDDLE , 4 ] , [ CKEDITOR . MOUSE _BUTTON _RIGHT , 2 ] ] , g= 0 ; g < c . length ; g ++ ) { var h = c [ g ] ; if ( h [ 0 ] === a && b ) return h[ 1 ] ; if ( ! b && h [ 1 ] === a ) return h [ 0 ] } } , convertHexStringToBytes : function ( a ) { var b = [ ] , c = a . length / 2 , g; for ( g = 0 ; g < c ; g ++ ) b . push ( parseInt ( a . substr ( 2 *
g , 2 ) , 16 ) ) ; return b } , convertBytesToBase64 : function ( a ) { var b = "" , c = a . length , g; for ( g = 0 ; g < c ; g += 3 ) { var h = a . slice ( g , g + 3 ) , m = h . length , e = [ ] , d ; if ( 3 > m ) for ( d = m ; 3 > d ; d ++ ) h [ d ] = 0 ; e [ 0 ] = ( h [ 0 ] & 252 ) >> 2 ; e[ 1 ] = ( h [ 0 ] & 3 ) << 4 | h [ 1 ] >> 4 ; e [ 2 ] = ( h [ 1 ] & 15 ) << 2 | ( h [ 2 ] & 192 ) >> 6 ; e[ 3 ] = h [ 2 ] & 63 ; for ( d = 0 ; 4 > d ; d ++ ) b = d <= m ? b + "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/" . charAt ( e[ d ] ) : b + "\x3d" } return b } , style : { parse : { _borderStyle : "none hidden dotted dashed solid double groove ridge inset outset" . split ( " " ) , _widthRegExp : /^(thin|medium|thick|[\+-]?\d+(\.\d+)?[a-z%]+|[\+-]?0+(\.0+)?|\.\d+[a-z%]+)$/ ,
_rgbaRegExp : /rgba?\(\s*\d+%?\s*,\s*\d+%?\s*,\s*\d+%?\s*(?:,\s*[0-9.]+\s*)?\)/gi , _hslaRegExp : /hsla?\(\s*[0-9.]+\s*,\s*\d+%\s*,\s*\d+%\s*(?:,\s*[0-9.]+\s*)?\)/gi , background : function ( a ) { var b = { } , c = this . _findColor ( a ) ; c . length && ( b . color = c [ 0 ] , CKEDITOR . tools . array . forEach ( c , function ( b ) { a = a . replace ( b , "" ) } ) ) ; if ( a = CKEDITOR . tools . trim ( a ) ) b . unprocessed = a ; return b } , margin : function ( a ) { return CKEDITOR . tools . style . parse . sideShorthand ( a , function ( a ) { return a . match ( /(?:\-?[\.\d]+(?:%|\w*)|auto|inherit|initial|unset|revert)/g ) ||
[ "0px" ] } ) } , sideShorthand : function ( a , b ) { function c ( a ) { f. top = k [ a [ 0 ] ] ; f . right = k [ a [ 1 ] ] ; f . bottom = k [ a [ 2 ] ] ; f . left = k [ a [ 3 ] ] } var f = { } , k = b ? b ( a ) : a . split ( /\s+/ ) ; switch ( k . length ) { case 1 : c ( [ 0 , 0 , 0 , 0 ] ) ; break ; case 2 : c ( [ 0 , 1 , 0 , 1 ] ) ; break ; case 3 : c ( [ 0 , 1 , 2 , 1 ] ) ; break ; case 4 : c ( [ 0 , 1 , 2 , 3 ] ) } return f } , border : function ( a ) { return CKEDITOR . tools . style . border . fromCssRule ( a ) } , _findColor : function ( a ) { var b = [ ] , c = CKEDITOR . tools . array , b = b . concat ( a . match ( this . _rgbaRegExp ) || [ ] ) , b = b . concat ( a . match ( this . _hslaRegExp ) || [ ] ) ; return b = b . concat ( c . filter ( a . split ( /\s+/ ) ,
function ( a ) { return a . match ( /^\#[a-f0-9]{3}(?:[a-f0-9]{3})?$/gi ) ? ! 0 : a . toLowerCase ( ) in CKEDITOR . tools . style . parse . _colors } ) ) } } } , array : { filter : function ( a , b , c ) { var f = [ ] ; this . forEach ( a , function ( k, m ) { b . call ( c , k , m , a ) && f . push ( k ) } ) ; return f } , find : function ( a , b , c ) { for ( var f= a . length , k = 0 ; k < f ; ) { if ( b . call ( c , a [ k] , k , a ) ) return a [ k ] ; k ++ } } , forEach : function ( a , b , c ) { var f= a . length , k ; for ( k = 0 ; k < f ; k ++ ) b . call ( c , a [ k] , k , a ) } , map : function ( a , b , c ) { for ( var f= [ ] , k = 0 ; k < a . length ; k ++ ) f . push ( b . call ( c , a [ k] , k , a ) ) ; return f } , reduce : function ( a ,
b , c , f) { for ( var k = 0 ; k < a . length ; k ++ ) c = b . call ( f , c , a [ k ] , k , a ) ; return c } , every : function ( a , b , c ) { if ( ! a . length ) return ! 0 ; b = this . filter ( a , b , c ) ; return a . length === b . length } , some : function ( a , b , c ) { for ( var f= 0 ; f < a . length ; f ++ ) if ( b . call ( c , a [ f] , f , a ) ) return ! 0 ; return ! 1 } , zip : function ( a , b ) { return CKEDITOR . tools . array . map ( a , function ( a , c ) { return [ a , b [ c ] ] } ) } , unique : function ( a ) { return this . filter ( a , function ( b , c ) { return c === CKEDITOR . tools . array . indexOf ( a , b ) } ) } } , object : { DONT _ENUMS : "toString toLocaleString valueOf hasOwnProperty isPrototypeOf propertyIsEnumerable constructor" . split ( " " ) ,
entries : function ( a ) { return CKEDITOR . tools . array . map ( CKEDITOR . tools . object . keys ( a ) , function ( b ) { return [ b , a [ b ] ] } ) } , values : function ( a ) { return CKEDITOR . tools . array . map ( CKEDITOR . tools . object . keys ( a ) , function ( b ) { return a [ b ] } ) } , keys : function ( a ) { var b = Object . prototype . hasOwnProperty , c = [ ] , f = CKEDITOR . tools . object . DONT _ENUMS ; if ( CKEDITOR . env . ie && 9 > CKEDITOR . env . version && ( ! a || "object" !== typeof a ) ) { b = [ ] ; if ( "string" === typeof a ) for ( c = 0 ; c < a . length ; c ++ ) b . push ( String ( c ) ) ; return b } for ( var k in a ) c . push ( k ) ; if ( CKEDITOR . env . ie &&
9 > CKEDITOR . env . version ) for ( k= 0 ; k < f . length ; k ++ ) b . call ( a , f [ k ] ) && c . push ( f [ k ] ) ; return c } , findKey : function ( a , b ) { if ( "object" !== typeof a ) return null ; for ( var c in a ) if ( a [ c ] === b ) return c ; return null } , merge : function ( a , b ) { var c = CKEDITOR . tools , f= c . clone ( a ) , k = c . clone ( b ) ; c . array . forEach ( c . object . keys ( k) , function ( a ) { f [ a ] = "object" === typeof k [ a ] && "object" === typeof f [ a ] ? c . object . merge ( f[ a ] , k [ a ] ) : k [ a ] } ) ; return f } } , getAbsoluteRectPosition : function ( a , b ) { function c ( a ) { if ( a ) { var b = a . getClientRect ( ) ; f. top += b . top ; f . left +=
b . left ; "x" in f&& "y" in f && ( f . x += b . x , f . y += b . y ) ; c ( a . getWindow ( ) . getFrame ( ) ) } } var f = CKEDITOR . tools . copy ( b ) ; c ( a . getFrame ( ) ) ; var k = CKEDITOR . document . getWindow ( ) . getScrollPosition ( ) ; f. top += k . y ; f . left += k . x ; "x" in f && "y" in f && ( f . y += k . y , f . x += k . x ) ; f . right = f . left + f . width ; f . bottom = f . top + f . height ; return f } } ; a . prototype = { reset : function ( ) { this . _lastOutput = 0 ; this . _clearTimer ( ) } , _reschedule : function ( ) { return ! 1 } , _call : function ( ) { this . _output ( ) } , _clearTimer : function ( ) { this . _scheduledTimer && clearTimeout ( this . _scheduledTimer ) ;
[ "0px" ] } ) } , sideShorthand : function ( a , b ) { function c ( a ) { g. top = h [ a [ 0 ] ] ; g . right = h [ a [ 1 ] ] ; g . bottom = h [ a [ 2 ] ] ; g . left = h [ a [ 3 ] ] } var g = { } , h = b ? b ( a ) : a . split ( /\s+/ ) ; switch ( h . length ) { case 1 : c ( [ 0 , 0 , 0 , 0 ] ) ; break ; case 2 : c ( [ 0 , 1 , 0 , 1 ] ) ; break ; case 3 : c ( [ 0 , 1 , 2 , 1 ] ) ; break ; case 4 : c ( [ 0 , 1 , 2 , 3 ] ) } return g } , border : function ( a ) { return CKEDITOR . tools . style . border . fromCssRule ( a ) } , _findColor : function ( a ) { var b = [ ] , c = CKEDITOR . tools . array , b = b . concat ( a . match ( this . _rgbaRegExp ) || [ ] ) , b = b . concat ( a . match ( this . _hslaRegExp ) || [ ] ) ; return b = b . concat ( c . filter ( a . split ( /\s+/ ) ,
function ( a ) { return a . match ( /^\#[a-f0-9]{3}(?:[a-f0-9]{3})?$/gi ) ? ! 0 : a . toLowerCase ( ) in CKEDITOR . tools . style . parse . _colors } ) ) } } } , array : { filter : function ( a , b , c ) { var g = [ ] ; this . forEach ( a , function ( h, e ) { b . call ( c , h , e , a ) && g . push ( h ) } ) ; return g } , find : function ( a , b , c ) { for ( var g= a . length , h = 0 ; h < g ; ) { if ( b . call ( c , a [ h] , h , a ) ) return a [ h ] ; h ++ } } , forEach : function ( a , b , c ) { var g= a . length , h ; for ( h = 0 ; h < g ; h ++ ) b . call ( c , a [ h] , h , a ) } , map : function ( a , b , c ) { for ( var g= [ ] , h = 0 ; h < a . length ; h ++ ) g . push ( b . call ( c , a [ h] , h , a ) ) ; return g } , reduce : function ( a ,
b , c , g) { for ( var h = 0 ; h < a . length ; h ++ ) c = b . call ( g , c , a [ h ] , h , a ) ; return c } , every : function ( a , b , c ) { if ( ! a . length ) return ! 0 ; b = this . filter ( a , b , c ) ; return a . length === b . length } , some : function ( a , b , c ) { for ( var g= 0 ; g < a . length ; g ++ ) if ( b . call ( c , a [ g] , g , a ) ) return ! 0 ; return ! 1 } , zip : function ( a , b ) { return CKEDITOR . tools . array . map ( a , function ( a , c ) { return [ a , b [ c ] ] } ) } , unique : function ( a ) { return this . filter ( a , function ( b , c ) { return c === CKEDITOR . tools . array . indexOf ( a , b ) } ) } } , object : { DONT _ENUMS : "toString toLocaleString valueOf hasOwnProperty isPrototypeOf propertyIsEnumerable constructor" . split ( " " ) ,
entries : function ( a ) { return CKEDITOR . tools . array . map ( CKEDITOR . tools . object . keys ( a ) , function ( b ) { return [ b , a [ b ] ] } ) } , values : function ( a ) { return CKEDITOR . tools . array . map ( CKEDITOR . tools . object . keys ( a ) , function ( b ) { return a [ b ] } ) } , keys : function ( a ) { var b = Object . prototype . hasOwnProperty , c = [ ] , g = CKEDITOR . tools . object . DONT _ENUMS ; if ( CKEDITOR . env . ie && 9 > CKEDITOR . env . version && ( ! a || "object" !== typeof a ) ) { b = [ ] ; if ( "string" === typeof a ) for ( c = 0 ; c < a . length ; c ++ ) b . push ( String ( c ) ) ; return b } for ( var h in a ) c . push ( h ) ; if ( CKEDITOR . env . ie &&
9 > CKEDITOR . env . version ) for ( h= 0 ; h < g . length ; h ++ ) b . call ( a , g [ h ] ) && c . push ( g [ h ] ) ; return c } , findKey : function ( a , b ) { if ( "object" !== typeof a ) return null ; for ( var c in a ) if ( a [ c ] === b ) return c ; return null } , merge : function ( a , b ) { var c = CKEDITOR . tools , g= c . clone ( a ) , h = c . clone ( b ) ; c . array . forEach ( c . object . keys ( h) , function ( a ) { g [ a ] = "object" === typeof h [ a ] && "object" === typeof g [ a ] ? c . object . merge ( g[ a ] , h [ a ] ) : h [ a ] } ) ; return g } } , getAbsoluteRectPosition : function ( a , b ) { function c ( a ) { if ( a ) { var b = a . getClientRect ( ) ; g. top += b . top ; g . left +=
b . left ; "x" in g&& "y" in g && ( g . x += b . x , g . y += b . y ) ; c ( a . getWindow ( ) . getFrame ( ) ) } } var g = CKEDITOR . tools . copy ( b ) ; c ( a . getFrame ( ) ) ; var h = CKEDITOR . document . getWindow ( ) . getScrollPosition ( ) ; g. top += h . y ; g . left += h . x ; "x" in g && "y" in g && ( g . y += h . y , g . x += h . x ) ; g . right = g . left + g . width ; g . bottom = g . top + g . height ; return g } } ; a . prototype = { reset : function ( ) { this . _lastOutput = 0 ; this . _clearTimer ( ) } , _reschedule : function ( ) { return ! 1 } , _call : function ( ) { this . _output ( ) } , _clearTimer : function ( ) { this . _scheduledTimer && clearTimeout ( this . _scheduledTimer ) ;
this . _scheduledTimer = 0 } } ; d . prototype = CKEDITOR . tools . prototypedCopy ( a . prototype ) ; d . prototype . _reschedule = function ( ) { this . _scheduledTimer && this . _clearTimer ( ) } ; d . prototype . _call = function ( ) { this . _output . apply ( this . _context , this . _args ) } ; CKEDITOR . tools . buffers = { } ; CKEDITOR . tools . buffers . event = a ; CKEDITOR . tools . buffers . throttle = d ; CKEDITOR . tools . style . border = CKEDITOR . tools . createClass ( { $ : function ( a ) { a = a || { } ; this . width = a . width ; this . style = a . style ; this . color = a . color ; this . _ . normalize ( ) } , _ : { normalizeMap : { color : [ [ /windowtext/g ,
"black" ] ] } , normalize : function ( ) { for ( var a in this . _ . normalizeMap ) { var b = this [ a ] ; b && ( this [ a ] = CKEDITOR . tools . array . reduce ( this . _ . normalizeMap [ a ] , function ( a , b ) { return a . replace ( b [ 0 ] , b [ 1 ] ) } , b ) ) } } } , proto : { toString : function ( ) { return CKEDITOR . tools . array . filter ( [ this . width , this . style , this . color ] , function ( a ) { return ! ! a } ) . join ( " " ) } } , statics : { fromCssRule : function ( a ) { var b = { } , c = a . split ( /\s+/g ) ; a = CKEDITOR . tools . style . parse . _findColor ( a ) ; a . length && ( b . color = a [ 0 ] ) ; CKEDITOR . tools . array . forEach ( c , function ( a ) { b . style ||
- 1 === CKEDITOR . tools . indexOf ( CKEDITOR . tools . style . parse . _borderStyle , a ) ? ! b . width && CKEDITOR . tools . style . parse . _widthRegExp . test ( a ) && ( b . width = a ) : b . style = a } ) ; return new CKEDITOR . tools . style . border ( b ) } , splitCssValues : function ( a , b ) { b = b || { } ; var c = CKEDITOR . tools . array . reduce ( [ "width" , "style" , "color" ] , function ( c , f) { var k = a [ "border-" + f ] || b [ f ] ; c [ f ] = k ? CKEDITOR . tools . style . parse . sideShorthand ( k ) : null ; return c } , { } ) ; return CKEDITOR . tools . array . reduce ( [ "top" , "right" , "bottom" , "left" ] , function ( b , f) { var k = { } , l ; for ( l in c ) { var e =
a [ "border-" + f+ "-" + l ] ; k [ l ] = e ? e : c [ l ] && c [ l ] [ f ] } b [ "border-" + f ] = new CKEDITOR . tools . style . border ( k ) ; return b } , { } ) } } } ) ; CKEDITOR . tools . array . indexOf = CKEDITOR . tools . indexOf ; CKEDITOR . tools . array . isArray = CKEDITOR . tools . isArray ; CKEDITOR . MOUSE _BUTTON _LEFT = 0 ; CKEDITOR . MOUSE _BUTTON _MIDDLE = 1 ; CKEDITOR . MOUSE _BUTTON _RIGHT = 2 } ) ( ) ;
CKEDITOR . dtd = function ( ) { var a = CKEDITOR . tools . extend , d = function ( a , b ) { for ( var c = CKEDITOR . tools . clone ( a ) , k= 1 ; k < arguments . length ; k ++ ) { b = arguments [ k ] ; for ( var l in b ) delete c [ l ] } return c } , b = { } , c = { } , g = { address : 1 , article : 1 , aside : 1 , blockquote : 1 , details : 1 , div : 1 , dl : 1 , fieldset : 1 , figure : 1 , footer : 1 , form : 1 , h1 : 1 , h2 : 1 , h3 : 1 , h4 : 1 , h5 : 1 , h6 : 1 , header : 1 , hgroup : 1 , hr : 1 , main : 1 , menu : 1 , nav : 1 , ol : 1 , p : 1 , pre : 1 , section : 1 , table : 1 , ul : 1 } , e = { command : 1 , link : 1 , meta : 1 , noscript : 1 , script : 1 , style : 1 } , h= { } , k = { "#" : 1 } , l = { center : 1 , dir : 1 , noframes : 1 } ;
a ( b , { a : 1 , abbr : 1 , area : 1 , audio : 1 , b : 1 , bdi : 1 , bdo : 1 , br : 1 , button : 1 , canvas : 1 , cite : 1 , code : 1 , command : 1 , datalist : 1 , del : 1 , dfn : 1 , em : 1 , embed : 1 , i : 1 , iframe : 1 , img : 1 , input : 1 , ins : 1 , kbd : 1 , keygen : 1 , label : 1 , map : 1 , mark : 1 , meter : 1 , noscript : 1 , object : 1 , output : 1 , progress : 1 , q : 1 , ruby : 1 , s : 1 , samp : 1 , script : 1 , select : 1 , small : 1 , span : 1 , strong : 1 , sub : 1 , sup : 1 , textarea : 1 , time : 1 , u : 1 , "var" : 1 , video : 1 , wbr : 1 } , k , { acronym : 1 , applet : 1 , basefont : 1 , big : 1 , font : 1 , isindex : 1 , strike : 1 , style : 1 , tt : 1 } ) ; a ( c , g, b , l ) ; d = { a : d ( b , { a : 1 , button : 1 } ) , abbr : b , address : c ,
area : h , article : c , aside : c , audio : a ( { source : 1 , track : 1 } , c ) , b : b , base : h , bdi : b , bdo : b , blockquote : c , body : c , br : h , button : d ( b , { a : 1 , button : 1 } ) , canvas : b , caption : c , cite : b , code : b , col : h , colgroup : { col : 1 } , command : h , datalist : a ( { option : 1 } , b ) , dd : c , del : b , details : a ( { summary : 1 } , c ) , dfn : b , div : c , dl : { dt : 1 , dd : 1 } , dt : c , em : b , embed : h , fieldset : a ( { legend : 1 } , c ) , figcaption : c , figure : a ( { figcaption : 1 } , c ) , footer : c , form : c , h1 : b , h2 : b , h3 : b , h4 : b , h5 : b , h6 : b , head : a ( { title : 1 , base : 1 } , e ) , header : c , hgroup : { h1 : 1 , h2 : 1 , h3 : 1 , h4 : 1 , h5 : 1 , h6 : 1 } , hr : h , html : a ( { head : 1 ,
body : 1 } , c , e ) , i : b , iframe : k, img : h , input : h , ins : b , kbd : b , keygen : h , label : b , legend : b , li : c , link : h , main : c , map : c , mark : b , menu : a ( { li : 1 } , c ) , meta : h , meter : d ( b , { meter : 1 } ) , nav : c , noscript : a ( { link : 1 , meta : 1 , style : 1 } , b ) , object : a ( { param : 1 } , b ) , ol : { li : 1 } , optgroup : { option : 1 } , option : k , output : b , p : b , param : h , pre : b , progress : d ( b , { progress : 1 } ) , q : b , rp : b , rt : b , ruby : a ( { rp : 1 , rt : 1 } , b ) , s : b , samp : b , script : k , section : c , select : { optgroup : 1 , option : 1 } , small : b , source : h , span : b , strong : b , style : k , sub : b , summary : a ( { h1 : 1 , h2 : 1 , h3 : 1 , h4 : 1 , h5 : 1 , h6 : 1 } , b ) ,
sup : b , table : { caption : 1 , colgroup : 1 , thead : 1 , tfoot : 1 , tbody : 1 , tr : 1 } , tbody : { tr : 1 } , td : c , textarea : k , tfoot : { tr : 1 } , th : c , thead : { tr : 1 } , time : d ( b , { time : 1 } ) , title : k , tr : { th : 1 , td : 1 } , track : h , u : b , ul : { li : 1 } , "var" : b , video : a ( { source : 1 , track : 1 } , c ) , wbr : h , acronym : b , applet : a ( { param : 1 } , c ) , basefont : h , big : b , center : c , dialog : h , dir : { li : 1 } , font : b , isindex : h , noframes : c , strike : b , tt : b } ; a ( d , { $block : a ( { audio : 1 , dd : 1 , dt : 1 , figcaption : 1 , li : 1 , video : 1 } , g, l ) , $blockLimit : { article : 1 , aside : 1 , audio : 1 , body : 1 , caption : 1 , details : 1 , dir : 1 , div : 1 , dl : 1 ,
- 1 === CKEDITOR . tools . indexOf ( CKEDITOR . tools . style . parse . _borderStyle , a ) ? ! b . width && CKEDITOR . tools . style . parse . _widthRegExp . test ( a ) && ( b . width = a ) : b . style = a } ) ; return new CKEDITOR . tools . style . border ( b ) } , splitCssValues : function ( a , b ) { b = b || { } ; var c = CKEDITOR . tools . array . reduce ( [ "width" , "style" , "color" ] , function ( c , g) { var h = a [ "border-" + g ] || b [ g ] ; c [ g ] = h ? CKEDITOR . tools . style . parse . sideShorthand ( h ) : null ; return c } , { } ) ; return CKEDITOR . tools . array . reduce ( [ "top" , "right" , "bottom" , "left" ] , function ( b , g) { var h = { } , e ; for ( e in c ) { var d =
a [ "border-" + g+ "-" + e ] ; h [ e ] = d ? d : c [ e ] && c [ e ] [ g ] } b [ "border-" + g ] = new CKEDITOR . tools . style . border ( h ) ; return b } , { } ) } } } ) ; CKEDITOR . tools . array . indexOf = CKEDITOR . tools . indexOf ; CKEDITOR . tools . array . isArray = CKEDITOR . tools . isArray ; CKEDITOR . MOUSE _BUTTON _LEFT = 0 ; CKEDITOR . MOUSE _BUTTON _MIDDLE = 1 ; CKEDITOR . MOUSE _BUTTON _RIGHT = 2 } ) ( ) ;
CKEDITOR . dtd = function ( ) { var a = CKEDITOR . tools . extend , d = function ( a , b ) { for ( var c = CKEDITOR . tools . clone ( a ) , h= 1 ; h < arguments . length ; h ++ ) { b = arguments [ h ] ; for ( var e in b ) delete c [ e ] } return c } , b = { } , c = { } , f = { address : 1 , article : 1 , aside : 1 , blockquote : 1 , details : 1 , div : 1 , dl : 1 , fieldset : 1 , figure : 1 , footer : 1 , form : 1 , h1 : 1 , h2 : 1 , h3 : 1 , h4 : 1 , h5 : 1 , h6 : 1 , header : 1 , hgroup : 1 , hr : 1 , main : 1 , menu : 1 , nav : 1 , ol : 1 , p : 1 , pre : 1 , section : 1 , table : 1 , ul : 1 } , e = { command : 1 , link : 1 , meta : 1 , noscript : 1 , script : 1 , style : 1 } , k= { } , h = { "#" : 1 } , n = { center : 1 , dir : 1 , noframes : 1 } ;
a ( b , { a : 1 , abbr : 1 , area : 1 , audio : 1 , b : 1 , bdi : 1 , bdo : 1 , br : 1 , button : 1 , canvas : 1 , cite : 1 , code : 1 , command : 1 , datalist : 1 , del : 1 , dfn : 1 , em : 1 , embed : 1 , i : 1 , iframe : 1 , img : 1 , input : 1 , ins : 1 , kbd : 1 , keygen : 1 , label : 1 , map : 1 , mark : 1 , meter : 1 , noscript : 1 , object : 1 , output : 1 , progress : 1 , q : 1 , ruby : 1 , s : 1 , samp : 1 , script : 1 , select : 1 , small : 1 , span : 1 , strong : 1 , sub : 1 , sup : 1 , textarea : 1 , time : 1 , u : 1 , "var" : 1 , video : 1 , wbr : 1 } , h , { acronym : 1 , applet : 1 , basefont : 1 , big : 1 , font : 1 , isindex : 1 , strike : 1 , style : 1 , tt : 1 } ) ; a ( c , f, b , n ) ; d = { a : d ( b , { a : 1 , button : 1 } ) , abbr : b , address : c ,
area : k , article : c , aside : c , audio : a ( { source : 1 , track : 1 } , c ) , b : b , base : k , bdi : b , bdo : b , blockquote : c , body : c , br : k , button : d ( b , { a : 1 , button : 1 } ) , canvas : b , caption : c , cite : b , code : b , col : k , colgroup : { col : 1 } , command : k , datalist : a ( { option : 1 } , b ) , dd : c , del : b , details : a ( { summary : 1 } , c ) , dfn : b , div : c , dl : { dt : 1 , dd : 1 } , dt : c , em : b , embed : k , fieldset : a ( { legend : 1 } , c ) , figcaption : c , figure : a ( { figcaption : 1 } , c ) , footer : c , form : c , h1 : b , h2 : b , h3 : b , h4 : b , h5 : b , h6 : b , head : a ( { title : 1 , base : 1 } , e ) , header : c , hgroup : { h1 : 1 , h2 : 1 , h3 : 1 , h4 : 1 , h5 : 1 , h6 : 1 } , hr : k , html : a ( { head : 1 ,
body : 1 } , c , e ) , i : b , iframe : h, img : k , input : k , ins : b , kbd : b , keygen : k , label : b , legend : b , li : c , link : k , main : c , map : c , mark : b , menu : a ( { li : 1 } , c ) , meta : k , meter : d ( b , { meter : 1 } ) , nav : c , noscript : a ( { link : 1 , meta : 1 , style : 1 } , b ) , object : a ( { param : 1 } , b ) , ol : { li : 1 } , optgroup : { option : 1 } , option : h , output : b , p : b , param : k , pre : b , progress : d ( b , { progress : 1 } ) , q : b , rp : b , rt : b , ruby : a ( { rp : 1 , rt : 1 } , b ) , s : b , samp : b , script : h , section : c , select : { optgroup : 1 , option : 1 } , small : b , source : k , span : b , strong : b , style : h , sub : b , summary : a ( { h1 : 1 , h2 : 1 , h3 : 1 , h4 : 1 , h5 : 1 , h6 : 1 } , b ) ,
sup : b , table : { caption : 1 , colgroup : 1 , thead : 1 , tfoot : 1 , tbody : 1 , tr : 1 } , tbody : { tr : 1 } , td : c , textarea : h , tfoot : { tr : 1 } , th : c , thead : { tr : 1 } , time : d ( b , { time : 1 } ) , title : h , tr : { th : 1 , td : 1 } , track : k , u : b , ul : { li : 1 } , "var" : b , video : a ( { source : 1 , track : 1 } , c ) , wbr : k , acronym : b , applet : a ( { param : 1 } , c ) , basefont : k , big : b , center : c , dialog : k , dir : { li : 1 } , font : b , isindex : k , noframes : c , strike : b , tt : b } ; a ( d , { $block : a ( { audio : 1 , dd : 1 , dt : 1 , figcaption : 1 , li : 1 , video : 1 } , f, n ) , $blockLimit : { article : 1 , aside : 1 , audio : 1 , body : 1 , caption : 1 , details : 1 , dir : 1 , div : 1 , dl : 1 ,
fieldset : 1 , figcaption : 1 , figure : 1 , footer : 1 , form : 1 , header : 1 , hgroup : 1 , main : 1 , menu : 1 , nav : 1 , ol : 1 , section : 1 , table : 1 , td : 1 , th : 1 , tr : 1 , ul : 1 , video : 1 } , $cdata : { script : 1 , style : 1 } , $editable : { address : 1 , article : 1 , aside : 1 , blockquote : 1 , body : 1 , details : 1 , div : 1 , fieldset : 1 , figcaption : 1 , footer : 1 , form : 1 , h1 : 1 , h2 : 1 , h3 : 1 , h4 : 1 , h5 : 1 , h6 : 1 , header : 1 , hgroup : 1 , main : 1 , nav : 1 , p : 1 , pre : 1 , section : 1 } , $empty : { area : 1 , base : 1 , basefont : 1 , br : 1 , col : 1 , command : 1 , dialog : 1 , embed : 1 , hr : 1 , img : 1 , input : 1 , isindex : 1 , keygen : 1 , link : 1 , meta : 1 , param : 1 , source : 1 ,
track : 1 , wbr : 1 } , $inline : b , $list : { dl : 1 , ol : 1 , ul : 1 } , $listItem : { dd : 1 , dt : 1 , li : 1 } , $nonBodyContent : a ( { body : 1 , head : 1 , html : 1 } , d . head ) , $nonEditable : { applet : 1 , audio : 1 , button : 1 , embed : 1 , iframe : 1 , map : 1 , object : 1 , option : 1 , param : 1 , script : 1 , textarea : 1 , video : 1 } , $object : { applet : 1 , audio : 1 , button : 1 , hr : 1 , iframe : 1 , img : 1 , input : 1 , object : 1 , select : 1 , table : 1 , textarea : 1 , video : 1 } , $removeEmpty : { abbr : 1 , acronym : 1 , b : 1 , bdi : 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 , mark : 1 , meter : 1 , output : 1 , q : 1 , ruby : 1 ,
s : 1 , samp : 1 , small : 1 , span : 1 , strike : 1 , strong : 1 , sub : 1 , sup : 1 , time : 1 , tt : 1 , u : 1 , "var" : 1 } , $tabIndex : { a : 1 , area : 1 , button : 1 , input : 1 , object : 1 , select : 1 , textarea : 1 } , $tableContent : { caption : 1 , col : 1 , colgroup : 1 , tbody : 1 , td : 1 , tfoot : 1 , th : 1 , thead : 1 , tr : 1 } , $transparent : { a : 1 , audio : 1 , canvas : 1 , del : 1 , ins : 1 , map : 1 , noscript : 1 , object : 1 , video : 1 } , $intermediate : { caption : 1 , colgroup : 1 , dd : 1 , dt : 1 , figcaption : 1 , legend : 1 , li : 1 , optgroup : 1 , option : 1 , rp : 1 , rt : 1 , summary : 1 , tbody : 1 , td : 1 , tfoot : 1 , th : 1 , thead : 1 , tr : 1 } } ) ; return d } ( ) ;
@ -68,20 +68,20 @@ this.$.target||this.$.srcElement;return a?new CKEDITOR.dom.node(a):null},getPhas
CKEDITOR . EVENT _PHASE _BUBBLING = 3 ; CKEDITOR . HISTORY _NATIVE = 1 ; CKEDITOR . HISTORY _HASH = 2 ; CKEDITOR . HISTORY _OFF = 0 ; CKEDITOR . dom . domObject = function ( a ) { a && ( this . $ = a ) } ;
CKEDITOR . dom . domObject . prototype = function ( ) { var a = function ( a , b ) { return function ( c ) { "undefined" != typeof CKEDITOR && a . fire ( b , new CKEDITOR . dom . event ( c ) ) } } ; return { getPrivate : function ( ) { var a ; ( a = this . getCustomData ( "_" ) ) || this . setCustomData ( "_" , a = { } ) ; return a } , on : function ( d ) { var b = this . getCustomData ( "_cke_nativeListeners" ) ; b || ( b = { } , this . setCustomData ( "_cke_nativeListeners" , b ) ) ; b [ d ] || ( b = b [ d ] = a ( this , d ) , this . $ . addEventListener ? this . $ . addEventListener ( d , b , ! ! CKEDITOR . event . useCapture ) : this . $ . attachEvent && this . $ . attachEvent ( "on" +
d , b ) ) ; return CKEDITOR . event . prototype . on . apply ( this , arguments ) } , removeListener : function ( a ) { CKEDITOR . event . prototype . removeListener . apply ( this , arguments ) ; if ( ! this . hasListeners ( a ) ) { var b = this . getCustomData ( "_cke_nativeListeners" ) , c = b && b [ a ] ; c && ( this . $ . removeEventListener ? this . $ . removeEventListener ( a , c , ! 1 ) : this . $ . detachEvent && this . $ . detachEvent ( "on" + a , c ) , delete b [ a ] ) } } , removeAllListeners : function ( ) { try { var a = this . getCustomData ( "_cke_nativeListeners" ) , b ; for ( b in a ) { var c = a [ b ] ; this . $ . detachEvent ? this . $ . detachEvent ( "on" +
b , c ) : this . $ . removeEventListener && this . $ . removeEventListener ( b , c , ! 1 ) ; delete a [ b ] } } catch ( g ) { if ( ! CKEDITOR . env . edge || - 2146828218 !== g. number ) throw g ; } CKEDITOR . event . prototype . removeAllListeners . call ( this ) } } } ( ) ;
( function ( a ) { var d = { } ; CKEDITOR . on ( "reset" , function ( ) { d = { } } ) ; a . equals = function ( a ) { try { return a && a . $ === this . $ } catch ( c ) { return ! 1 } } ; a . setCustomData = function ( a , c ) { var g = this . getUniqueId ( ) ; ( d [ g] || ( d [ g ] = { } ) ) [ a ] = c ; return this } ; a . getCustomData = function ( a ) { var c = this . $ [ "data-cke-expando" ] ; return ( c = c && d [ c ] ) && a in c ? c [ a ] : null } ; a . removeCustomData = function ( a ) { var c = this . $ [ "data-cke-expando" ] , c = c && d [ c ] , g, e ; c && ( g = c [ a ] , e = a in c , delete c [ a ] ) ; return e ? g : null } ; a . clearCustomData = function ( ) { this . removeAllListeners ( ) ; var a =
b , c ) : this . $ . removeEventListener && this . $ . removeEventListener ( b , c , ! 1 ) ; delete a [ b ] } } catch ( f ) { if ( ! CKEDITOR . env . edge || - 2146828218 !== f. number ) throw f ; } CKEDITOR . event . prototype . removeAllListeners . call ( this ) } } } ( ) ;
( function ( a ) { var d = { } ; CKEDITOR . on ( "reset" , function ( ) { d = { } } ) ; a . equals = function ( a ) { try { return a && a . $ === this . $ } catch ( c ) { return ! 1 } } ; a . setCustomData = function ( a , c ) { var f = this . getUniqueId ( ) ; ( d [ f] || ( d [ f ] = { } ) ) [ a ] = c ; return this } ; a . getCustomData = function ( a ) { var c = this . $ [ "data-cke-expando" ] ; return ( c = c && d [ c ] ) && a in c ? c [ a ] : null } ; a . removeCustomData = function ( a ) { var c = this . $ [ "data-cke-expando" ] , c = c && d [ c ] , f, e ; c && ( f = c [ a ] , e = a in c , delete c [ a ] ) ; return e ? f : null } ; a . clearCustomData = function ( ) { this . removeAllListeners ( ) ; var a =
this . getUniqueId ( ) ; a && delete d [ a ] } ; a . getUniqueId = function ( ) { return this . $ [ "data-cke-expando" ] || ( this . $ [ "data-cke-expando" ] = CKEDITOR . tools . getNextNumber ( ) ) } ; CKEDITOR . event . implementOn ( a ) } ) ( CKEDITOR . dom . domObject . prototype ) ;
CKEDITOR . dom . node = function ( a ) { return a ? new CKEDITOR . dom [ a . nodeType == CKEDITOR . NODE _DOCUMENT ? "document" : a . nodeType == CKEDITOR . NODE _ELEMENT ? "element" : a . nodeType == CKEDITOR . NODE _TEXT ? "text" : a . nodeType == CKEDITOR . NODE _COMMENT ? "comment" : a . nodeType == CKEDITOR . NODE _DOCUMENT _FRAGMENT ? "documentFragment" : "domObject" ] ( a ) : this } ; CKEDITOR . dom . node . prototype = new CKEDITOR . dom . domObject ; CKEDITOR . NODE _ELEMENT = 1 ; CKEDITOR . NODE _DOCUMENT = 9 ; CKEDITOR . NODE _TEXT = 3 ; 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 , { appendTo : function ( a , d ) { a . append ( this , d ) ; return a } , clone : function ( a , d ) { function b ( c ) { c [ "data-cke-expando" ] && ( c [ "data-cke-expando" ] = ! 1 ) ; if ( c . nodeType == CKEDITOR . NODE _ELEMENT || c . nodeType == CKEDITOR . NODE _DOCUMENT _FRAGMENT ) if ( d || c . nodeType != CKEDITOR . NODE _ELEMENT || c . removeAttribute ( "id" , ! 1 ) , a ) { c = c . childNodes ; for ( var g= 0 ; g < c . length ; g ++ ) b ( c [ g ] ) } } function c ( b ) { if ( b . type == CKEDITOR . NODE _ELEMENT || b . type == CKEDITOR . NODE _DOCUMENT _FRAGMENT ) { if ( b . type != CKEDITOR . NODE _DOCUMENT _FRAGMENT ) { var d =
b . getName ( ) ; ":" == d [ 0 ] && b . renameNode ( d . substring ( 1 ) ) } if ( a ) for ( d = 0 ; d < b . getChildCount ( ) ; d ++ ) c ( b . getChild ( d ) ) } } var g = this . $ . cloneNode ( a ) ; b ( g) ; g = new CKEDITOR . dom . node ( g ) ; CKEDITOR . env . ie && 9 > CKEDITOR . env . version && ( this . type == CKEDITOR . NODE _ELEMENT || this . type == CKEDITOR . NODE _DOCUMENT _FRAGMENT ) && c ( g) ; return g } , hasPrevious : function ( ) { return ! ! this . $ . previousSibling } , hasNext : function ( ) { return ! ! this . $ . nextSibling } , insertAfter : function ( a ) { a . $ . parentNode . insertBefore ( this . $ , a . $ . nextSibling ) ; return a } , insertBefore : function ( a ) { a . $ . parentNode . insertBefore ( this . $ ,
a . $ ) ; return a } , insertBeforeMe : function ( a ) { this . $ . parentNode . insertBefore ( a . $ , this . $ ) ; return a } , getAddress : function ( a ) { for ( var d = [ ] , b = this . getDocument ( ) . $ . documentElement , c = this ; c && c != b ; ) { var g= c . getParent ( ) ; g && d . unshift ( this . getIndex . call ( c , a ) ) ; c = g } return d } , getDocument : function ( ) { return new CKEDITOR . dom . document ( this . $ . ownerDocument || this . $ . parentNode . ownerDocument ) } , getIndex : function ( a ) { function d ( a , b ) { var c = b ? a . getNext ( ) : a . getPrevious ( ) ; return c && c . type == CKEDITOR . NODE _TEXT ? c . isEmpty ( ) ? d ( c , b ) : c :
null } var b = this , c = - 1 , g ; if ( ! this . getParent ( ) || a && b . type == CKEDITOR . NODE _TEXT && b . isEmpty ( ) && ! d ( b ) && ! d ( b , ! 0 ) ) return - 1 ; do if ( ! a || b . equals ( this ) || b . type != CKEDITOR . NODE _TEXT || ! g && ! b . isEmpty ( ) ) c ++ , g = b . type == CKEDITOR . NODE _TEXT ; while ( b = b . getPrevious ( ) ) ; return c } , getNextSourceNode : function ( a , d , b ) { if ( b && ! b . call ) { var c = b ; b = function ( a ) { return ! a . equals ( c ) } } a = ! a && this . getFirst && this . getFirst ( ) ; var g ; if ( ! a ) { if ( this . type == CKEDITOR . NODE _ELEMENT && b && ! 1 === b ( this , ! 0 ) ) return null ; a = this . getNext ( ) } for ( ; ! a && ( g= ( g || this ) . getParent ( ) ) ; ) { if ( b &&
! 1 === b ( g , ! 0 ) ) return null ; a = g . getNext ( ) } return ! a || b && ! 1 === b ( a ) ? null : d && d != a . type ? a . getNextSourceNode ( ! 1 , d , b ) : a } , getPreviousSourceNode : function ( a , d , b ) { if ( b && ! b . call ) { var c = b ; b = function ( a ) { return ! a . equals ( c ) } } a = ! a && this . getLast && this . getLast ( ) ; var g ; if ( ! a ) { if ( this . type == CKEDITOR . NODE _ELEMENT && b && ! 1 === b ( this , ! 0 ) ) return null ; a = this . getPrevious ( ) } for ( ; ! a && ( g= ( g || this ) . getParent ( ) ) ; ) { if ( b && ! 1 === b ( g , ! 0 ) ) return null ; a = g . getPrevious ( ) } return ! a || b && ! 1 === b ( a ) ? null : d && a . type != d ? a . getPreviousSourceNode ( ! 1 , d , b ) :
CKEDITOR . tools . extend ( CKEDITOR . dom . node . prototype , { appendTo : function ( a , d ) { a . append ( this , d ) ; return a } , clone : function ( a , d ) { function b ( c ) { c [ "data-cke-expando" ] && ( c [ "data-cke-expando" ] = ! 1 ) ; if ( c . nodeType == CKEDITOR . NODE _ELEMENT || c . nodeType == CKEDITOR . NODE _DOCUMENT _FRAGMENT ) if ( d || c . nodeType != CKEDITOR . NODE _ELEMENT || c . removeAttribute ( "id" , ! 1 ) , a ) { c = c . childNodes ; for ( var f= 0 ; f < c . length ; f ++ ) b ( c [ f ] ) } } function c ( b ) { if ( b . type == CKEDITOR . NODE _ELEMENT || b . type == CKEDITOR . NODE _DOCUMENT _FRAGMENT ) { if ( b . type != CKEDITOR . NODE _DOCUMENT _FRAGMENT ) { var d =
b . getName ( ) ; ":" == d [ 0 ] && b . renameNode ( d . substring ( 1 ) ) } if ( a ) for ( d = 0 ; d < b . getChildCount ( ) ; d ++ ) c ( b . getChild ( d ) ) } } var f = this . $ . cloneNode ( a ) ; b ( f) ; f = new CKEDITOR . dom . node ( f ) ; CKEDITOR . env . ie && 9 > CKEDITOR . env . version && ( this . type == CKEDITOR . NODE _ELEMENT || this . type == CKEDITOR . NODE _DOCUMENT _FRAGMENT ) && c ( f) ; return f } , hasPrevious : function ( ) { return ! ! this . $ . previousSibling } , hasNext : function ( ) { return ! ! this . $ . nextSibling } , insertAfter : function ( a ) { a . $ . parentNode . insertBefore ( this . $ , a . $ . nextSibling ) ; return a } , insertBefore : function ( a ) { a . $ . parentNode . insertBefore ( this . $ ,
a . $ ) ; return a } , insertBeforeMe : function ( a ) { this . $ . parentNode . insertBefore ( a . $ , this . $ ) ; return a } , getAddress : function ( a ) { for ( var d = [ ] , b = this . getDocument ( ) . $ . documentElement , c = this ; c && c != b ; ) { var f= c . getParent ( ) ; f && d . unshift ( this . getIndex . call ( c , a ) ) ; c = f } return d } , getDocument : function ( ) { return new CKEDITOR . dom . document ( this . $ . ownerDocument || this . $ . parentNode . ownerDocument ) } , getIndex : function ( a ) { function d ( a , b ) { var c = b ? a . getNext ( ) : a . getPrevious ( ) ; return c && c . type == CKEDITOR . NODE _TEXT ? c . isEmpty ( ) ? d ( c , b ) : c :
null } var b = this , c = - 1 , f ; if ( ! this . getParent ( ) || a && b . type == CKEDITOR . NODE _TEXT && b . isEmpty ( ) && ! d ( b ) && ! d ( b , ! 0 ) ) return - 1 ; do if ( ! a || b . equals ( this ) || b . type != CKEDITOR . NODE _TEXT || ! f && ! b . isEmpty ( ) ) c ++ , f = b . type == CKEDITOR . NODE _TEXT ; while ( b = b . getPrevious ( ) ) ; return c } , getNextSourceNode : function ( a , d , b ) { if ( b && ! b . call ) { var c = b ; b = function ( a ) { return ! a . equals ( c ) } } a = ! a && this . getFirst && this . getFirst ( ) ; var f ; if ( ! a ) { if ( this . type == CKEDITOR . NODE _ELEMENT && b && ! 1 === b ( this , ! 0 ) ) return null ; a = this . getNext ( ) } for ( ; ! a && ( f= ( f || this ) . getParent ( ) ) ; ) { if ( b &&
! 1 === b ( f , ! 0 ) ) return null ; a = f . getNext ( ) } return ! a || b && ! 1 === b ( a ) ? null : d && d != a . type ? a . getNextSourceNode ( ! 1 , d , b ) : a } , getPreviousSourceNode : function ( a , d , b ) { if ( b && ! b . call ) { var c = b ; b = function ( a ) { return ! a . equals ( c ) } } a = ! a && this . getLast && this . getLast ( ) ; var f ; if ( ! a ) { if ( this . type == CKEDITOR . NODE _ELEMENT && b && ! 1 === b ( this , ! 0 ) ) return null ; a = this . getPrevious ( ) } for ( ; ! a && ( f= ( f || this ) . getParent ( ) ) ; ) { if ( b && ! 1 === b ( f , ! 0 ) ) return null ; a = f . getPrevious ( ) } return ! a || b && ! 1 === b ( a ) ? null : d && a . type != d ? a . getPreviousSourceNode ( ! 1 , d , b ) :
a } , getPrevious : function ( a ) { var d = this . $ , b ; do b = ( d = d . previousSibling ) && 10 != d . nodeType && new CKEDITOR . dom . node ( d ) ; while ( b && a && ! a ( b ) ) ; return b } , getNext : function ( a ) { var d = this . $ , b ; do b = ( d = d . nextSibling ) && new CKEDITOR . dom . node ( d ) ; while ( b && a && ! a ( b ) ) ; return b } , getParent : function ( a ) { var d = this . $ . parentNode ; return d && ( d . nodeType == CKEDITOR . NODE _ELEMENT || a && d . nodeType == CKEDITOR . NODE _DOCUMENT _FRAGMENT ) ? new CKEDITOR . dom . node ( d ) : null } , getParents : function ( a ) { var d = this , b = [ ] ; do b [ a ? "push" : "unshift" ] ( d ) ; while ( d = d . getParent ( ) ) ;
return b } , getCommonAncestor : function ( a ) { if ( a . equals ( this ) ) return this ; if ( a . contains && a . contains ( this ) ) return a ; var d = this . contains ? this : this . getParent ( ) ; do if ( d . contains ( a ) ) return d ; while ( d = d . getParent ( ) ) ; return null } , getPosition : function ( a ) { var d = this . $ , b = a . $ ; if ( d . compareDocumentPosition ) return d . compareDocumentPosition ( b ) ; if ( d == b ) return CKEDITOR . POSITION _IDENTICAL ; if ( this . type == CKEDITOR . NODE _ELEMENT && a . type == CKEDITOR . NODE _ELEMENT ) { if ( d . contains ) { if ( d . contains ( b ) ) return CKEDITOR . POSITION _CONTAINS +
CKEDITOR . POSITION _PRECEDING ; if ( b . contains ( d ) ) return CKEDITOR . POSITION _IS _CONTAINED + CKEDITOR . POSITION _FOLLOWING } if ( "sourceIndex" in d ) return 0 > d . sourceIndex || 0 > b . sourceIndex ? CKEDITOR . POSITION _DISCONNECTED : d . sourceIndex < b . sourceIndex ? CKEDITOR . POSITION _PRECEDING : CKEDITOR . POSITION _FOLLOWING } d = this . getAddress ( ) ; a = a . getAddress ( ) ; for ( var b = Math . min ( d . length , a . length ) , c = 0 ; c < b ; c ++ ) if ( d [ c ] != a [ c ] ) return d [ c ] < a [ c ] ? CKEDITOR . POSITION _PRECEDING : CKEDITOR . POSITION _FOLLOWING ; return d . length < a . length ? CKEDITOR . POSITION _CONTAINS +
CKEDITOR . POSITION _PRECEDING : CKEDITOR . POSITION _IS _CONTAINED + CKEDITOR . POSITION _FOLLOWING } , getAscendant : function ( a , d ) { var b = this . $ , c , g ; d || ( b = b . parentNode ) ; "function" == typeof a ? ( g= ! 0 , c = a ) : ( g = ! 1 , c = function ( b ) { b = "string" == typeof b . nodeName ? b . nodeName . toLowerCase ( ) : "" ; return "string" == typeof a ? b == a : b in a } ) ; for ( ; b ; ) { if ( c ( g ? new CKEDITOR . dom . node ( b ) : b ) ) return new CKEDITOR . dom . node ( b ) ; try { b = b . parentNode } catch ( e ) { b = null } } return null } , hasAscendant : function ( a , d ) { var b = this . $ ; d || ( b = b . parentNode ) ; for ( ; b ; ) { if ( b . nodeName &&
CKEDITOR . POSITION _PRECEDING : CKEDITOR . POSITION _IS _CONTAINED + CKEDITOR . POSITION _FOLLOWING } , getAscendant : function ( a , d ) { var b = this . $ , c , f ; d || ( b = b . parentNode ) ; "function" == typeof a ? ( f= ! 0 , c = a ) : ( f = ! 1 , c = function ( b ) { b = "string" == typeof b . nodeName ? b . nodeName . toLowerCase ( ) : "" ; return "string" == typeof a ? b == a : b in a } ) ; for ( ; b ; ) { if ( c ( f ? new CKEDITOR . dom . node ( b ) : b ) ) return new CKEDITOR . dom . node ( b ) ; try { b = b . parentNode } catch ( e ) { b = null } } return null } , hasAscendant : function ( a , d ) { var b = this . $ ; d || ( b = b . parentNode ) ; for ( ; b ; ) { if ( b . nodeName &&
b . nodeName . toLowerCase ( ) == a ) return ! 0 ; b = b . parentNode } return ! 1 } , move : function ( a , d ) { a . append ( this . remove ( ) , d ) } , remove : function ( a ) { var d = this . $ , b = d . parentNode ; if ( b ) { if ( a ) for ( ; a = d . firstChild ; ) b . insertBefore ( d . removeChild ( a ) , d ) ; b . removeChild ( d ) } return this } , replace : function ( a ) { this . insertBefore ( a ) ; a . remove ( ) } , trim : function ( ) { this . ltrim ( ) ; this . rtrim ( ) } , ltrim : function ( ) { for ( var a ; this . getFirst && ( a = this . getFirst ( ) ) ; ) { if ( a . type == CKEDITOR . NODE _TEXT ) { var d = CKEDITOR . tools . ltrim ( a . getText ( ) ) , b = a . getLength ( ) ; if ( d ) d . length <
b && ( a . split ( b - d . length ) , this . $ . removeChild ( this . $ . firstChild ) ) ; else { a . remove ( ) ; continue } } break } } , rtrim : function ( ) { for ( var a ; this . getLast && ( a = this . getLast ( ) ) ; ) { if ( a . type == CKEDITOR . NODE _TEXT ) { var d = CKEDITOR . tools . rtrim ( a . getText ( ) ) , b = a . getLength ( ) ; if ( d ) d . length < b && ( a . split ( d . length ) , this . $ . lastChild . parentNode . removeChild ( this . $ . lastChild ) ) ; else { a . remove ( ) ; continue } } break } CKEDITOR . env . needsBrFiller && ( a = this . $ . lastChild ) && 1 == a . type && "br" == a . nodeName . toLowerCase ( ) && a . parentNode . removeChild ( a ) } , isReadOnly : function ( a ) { var d =
this ; this . type != CKEDITOR . NODE _ELEMENT && ( d = this . getParent ( ) ) ; CKEDITOR . env . edge && d && d . is ( "textarea" , "input" ) && ( a = ! 0 ) ; if ( ! a && d && "undefined" != typeof d . $ . isContentEditable ) return ! ( d . $ . isContentEditable || d . data ( "cke-editable" ) ) ; for ( ; d ; ) { if ( d . data ( "cke-editable" ) ) return ! 1 ; if ( d . hasAttribute ( "contenteditable" ) ) return "false" == d . getAttribute ( "contenteditable" ) ; d = d . getParent ( ) } return ! 0 } } ) ; CKEDITOR . dom . window = function ( a ) { CKEDITOR . dom . domObject . call ( this , a ) } ; CKEDITOR . dom . window . prototype = new CKEDITOR . dom . domObject ;
@ -89,471 +89,466 @@ CKEDITOR.tools.extend(CKEDITOR.dom.window.prototype,{focus:function(){this.$.foc
a . body . scrollTop || 0 } } , getFrame : function ( ) { var a = this . $ . frameElement ; return a ? new CKEDITOR . dom . element . get ( a ) : null } } ) ; CKEDITOR . dom . document = function ( a ) { CKEDITOR . dom . domObject . call ( this , a ) } ; CKEDITOR . dom . document . prototype = new CKEDITOR . dom . domObject ;
CKEDITOR . tools . extend ( CKEDITOR . dom . document . prototype , { type : CKEDITOR . NODE _DOCUMENT , appendStyleSheet : function ( a ) { a = CKEDITOR . appendTimestamp ( a ) ; if ( this . $ . createStyleSheet ) this . $ . createStyleSheet ( a ) ; else { var d = new CKEDITOR . dom . element ( "link" ) ; d . setAttributes ( { rel : "stylesheet" , type : "text/css" , href : a } ) ; this . getHead ( ) . append ( d ) } } , appendStyleText : function ( a ) { if ( this . $ . createStyleSheet ) { var d = this . $ . createStyleSheet ( "" ) ; d . cssText = a } else { var b = new CKEDITOR . dom . element ( "style" , this ) ; b . append ( new CKEDITOR . dom . text ( a ,
this ) ) ; this . getHead ( ) . append ( b ) } return d || b . $ . sheet } , createElement : function ( a , d ) { var b = new CKEDITOR . dom . element ( a , this ) ; d && ( d . attributes && b . setAttributes ( d . attributes ) , d . styles && b . setStyles ( d . styles ) ) ; return b } , createText : function ( a ) { return new CKEDITOR . dom . text ( a , this ) } , focus : function ( ) { this . getWindow ( ) . focus ( ) } , getActive : function ( ) { var a ; try { a = this . $ . activeElement } catch ( d ) { return null } return new CKEDITOR . dom . element ( a ) } , getById : function ( a ) { return ( a = this . $ . getElementById ( a ) ) ? new CKEDITOR . dom . element ( a ) :
null } , getByAddress : function ( a , d ) { for ( var b = this . $ . documentElement , c = 0 ; b && c < a . length ; c ++ ) { var g = a [ c ] ; if ( d ) for ( var e = - 1 , h= 0 ; h < b . childNodes . length ; h ++ ) { var k = b . childNodes [ h ] ; if ( ! 0 !== d || 3 != k. nodeType || ! k . previousSibling || 3 != k . previousSibling . nodeType ) if ( e ++ , e == g) { b = k ; break } } else b = b . childNodes [ g ] } return b ? new CKEDITOR . dom . node ( b ) : null } , getElementsByTag : function ( a , d ) { CKEDITOR . env . ie && 8 >= document . documentMode || ! d || ( a = d + ":" + a ) ; return new CKEDITOR . dom . nodeList ( this . $ . getElementsByTagName ( a ) ) } , getHead : function ( ) { var a =
null } , getByAddress : function ( a , d ) { for ( var b = this . $ . documentElement , c = 0 ; b && c < a . length ; c ++ ) { var f = a [ c ] ; if ( d ) for ( var e = - 1 , k= 0 ; k < b . childNodes . length ; k ++ ) { var h = b . childNodes [ k ] ; if ( ! 0 !== d || 3 != h. nodeType || ! h . previousSibling || 3 != h . previousSibling . nodeType ) if ( e ++ , e == f) { b = h ; break } } else b = b . childNodes [ f ] } return b ? new CKEDITOR . dom . node ( b ) : null } , getElementsByTag : function ( a , d ) { CKEDITOR . env . ie && 8 >= document . documentMode || ! d || ( a = d + ":" + a ) ; return new CKEDITOR . dom . nodeList ( this . $ . getElementsByTagName ( a ) ) } , getHead : function ( ) { var a =
this . $ . getElementsByTagName ( "head" ) [ 0 ] ; return a = a ? new CKEDITOR . dom . element ( a ) : this . getDocumentElement ( ) . append ( new CKEDITOR . dom . element ( "head" ) , ! 0 ) } , getBody : function ( ) { return new CKEDITOR . dom . element ( this . $ . body ) } , getDocumentElement : function ( ) { return new CKEDITOR . dom . element ( this . $ . documentElement ) } , getWindow : function ( ) { return new CKEDITOR . dom . window ( this . $ . parentWindow || this . $ . defaultView ) } , write : function ( a ) { this . $ . open ( "text/html" , "replace" ) ; CKEDITOR . env . ie && ( a = a . replace ( /(?:^\s*<!DOCTYPE[^>]*?>)|^/i ,
'$\x26\n\x3cscript data-cke-temp\x3d"1"\x3e(' + CKEDITOR . tools . fixDomain + ")();\x3c/script\x3e" ) ) ; this . $ . write ( a ) ; this . $ . close ( ) } , find : function ( a ) { return new CKEDITOR . dom . nodeList ( this . $ . querySelectorAll ( a ) ) } , findOne : function ( a ) { return ( a = this . $ . querySelector ( a ) ) ? new CKEDITOR . dom . element ( a ) : null } , _getHtml5ShivFrag : function ( ) { var a = this . getCustomData ( "html5ShivFrag" ) ; a || ( a = this . $ . createDocumentFragment ( ) , CKEDITOR . tools . enableHtml5Elements ( a , ! 0 ) , this . setCustomData ( "html5ShivFrag" , a ) ) ; return a } } ) ;
CKEDITOR . dom . nodeList = function ( a ) { this . $ = a } ; CKEDITOR . dom . nodeList . prototype = { count : function ( ) { return this . $ . length } , getItem : function ( a ) { return 0 > a || a >= this . $ . length ? null : ( a = this . $ [ a ] ) ? new CKEDITOR . dom . node ( a ) : null } , toArray : function ( ) { return CKEDITOR . tools . array . map ( this . $ , function ( a ) { return new CKEDITOR . dom . node ( a ) } ) } } ; CKEDITOR . dom . element = function ( a , d ) { "string" == typeof a && ( a = ( d ? d . $ : document ) . createElement ( a ) ) ; CKEDITOR . dom . domObject . call ( this , a ) } ;
CKEDITOR . dom . element . get = function ( a ) { return ( a = "string" == typeof a ? document . getElementById ( a ) || document . getElementsByName ( a ) [ 0 ] : a ) && ( a . $ ? a : new CKEDITOR . dom . element ( a ) ) } ; CKEDITOR . dom . element . prototype = new CKEDITOR . dom . node ; CKEDITOR . dom . element . createFromHtml = function ( a , d ) { var b = new CKEDITOR . dom . element ( "div" , d ) ; b . setHtml ( a ) ; return b . getFirst ( ) . remove ( ) } ;
CKEDITOR . dom . element . setMarker = function ( a , d , b , c ) { var g = d . getCustomData ( "list_marker_id" ) || d . setCustomData ( "list_marker_id" , CKEDITOR . tools . getNextNumber ( ) ) . getCustomData ( "list_marker_id" ) , e = d . getCustomData ( "list_marker_names" ) || d . setCustomData ( "list_marker_names" , { } ) . getCustomData ( "list_marker_names" ) ; a [ g ] = d ; e [ b ] = 1 ; return d . setCustomData ( b , c ) } ; CKEDITOR . dom . element . clearAllMarkers = function ( a ) { for ( var d in a ) CKEDITOR . dom . element . clearMarkers ( a , a [ d ] , 1 ) } ;
CKEDITOR . dom . element . clearMarkers = function ( a , d , b ) { var c = d . getCustomData ( "list_marker_names" ) , g = d . getCustomData ( "list_marker_id" ) , e ; for ( e in c ) d . removeCustomData ( e ) ; d . removeCustomData ( "list_marker_names" ) ; b && ( d . removeCustomData ( "list_marker_id" ) , delete a [ g ] ) } ;
( function ( ) { function a ( a , b ) { return - 1 < ( " " + a + " " ) . replace ( e , " " ) . indexOf ( " " + b + " " ) } function d ( a ) { var b = ! 0 ; a . $ . id || ( a . $ . id = "cke_tmp_" + CKEDITOR . tools . getNextNumber ( ) , b = ! 1 ) ; return function ( ) { b || a . removeAttribute ( "id" ) } } function b ( a , b ) { var c = CKEDITOR . tools . escapeCss ( a . $ . id ) ; return "#" + c + " " + b . split ( /,\s*/ ) . join ( ", #" + c + " " ) } function c ( a ) { for ( var b = 0 , c = 0 , f= h [ a ] . length ; c < f ; c ++ ) b += parseFloat ( this . getComputedStyle ( h [ a ] [ c ] ) || 0 , 10 ) || 0 ; return b } var g = document . createElement ( "_" ) . classList , g= "undefined" !== typeof g &&
null !== String ( g . add ) . match ( /\[Native code\]/gi ) , e = /[\n\t\r]/g ; CKEDITOR . tools . extend ( CKEDITOR . dom . element . prototype , { type : CKEDITOR . NODE _ELEMENT , addClass : g ? function ( a ) { this . $ . classList . add ( a ) ; return this } : function ( b ) { var c = this . $ . className ; c && ( a ( c , b ) || ( c += " " + b ) ) ; this . $ . className = c || b ; return this } , removeClass : g ? function ( a ) { var b = this . $ ; b . classList . remove ( a ) ; b . className || b . removeAttribute ( "class" ) ; return this } : function ( b ) { var c = this . getAttribute ( "class" ) ; c && a ( c , b ) && ( ( c = c . replace ( new RegExp ( "(?:^|\\s+)" +
CKEDITOR . dom . element . setMarker = function ( a , d , b , c ) { var f = d . getCustomData ( "list_marker_id" ) || d . setCustomData ( "list_marker_id" , CKEDITOR . tools . getNextNumber ( ) ) . getCustomData ( "list_marker_id" ) , e = d . getCustomData ( "list_marker_names" ) || d . setCustomData ( "list_marker_names" , { } ) . getCustomData ( "list_marker_names" ) ; a [ f ] = d ; e [ b ] = 1 ; return d . setCustomData ( b , c ) } ; CKEDITOR . dom . element . clearAllMarkers = function ( a ) { for ( var d in a ) CKEDITOR . dom . element . clearMarkers ( a , a [ d ] , 1 ) } ;
CKEDITOR . dom . element . clearMarkers = function ( a , d , b ) { var c = d . getCustomData ( "list_marker_names" ) , f = d . getCustomData ( "list_marker_id" ) , e ; for ( e in c ) d . removeCustomData ( e ) ; d . removeCustomData ( "list_marker_names" ) ; b && ( d . removeCustomData ( "list_marker_id" ) , delete a [ f ] ) } ;
( function ( ) { function a ( a , b ) { return - 1 < ( " " + a + " " ) . replace ( e , " " ) . indexOf ( " " + b + " " ) } function d ( a ) { var b = ! 0 ; a . $ . id || ( a . $ . id = "cke_tmp_" + CKEDITOR . tools . getNextNumber ( ) , b = ! 1 ) ; return function ( ) { b || a . removeAttribute ( "id" ) } } function b ( a , b ) { var c = CKEDITOR . tools . escapeCss ( a . $ . id ) ; return "#" + c + " " + b . split ( /,\s*/ ) . join ( ", #" + c + " " ) } function c ( a ) { for ( var b = 0 , c = 0 , g= k [ a ] . length ; c < g ; c ++ ) b += parseFloat ( this . getComputedStyle ( k [ a ] [ c ] ) || 0 , 10 ) || 0 ; return b } var f = document . createElement ( "_" ) . classList , f= "undefined" !== typeof f &&
null !== String ( f . add ) . match ( /\[Native code\]/gi ) , e = /[\n\t\r]/g ; CKEDITOR . tools . extend ( CKEDITOR . dom . element . prototype , { type : CKEDITOR . NODE _ELEMENT , addClass : f ? function ( a ) { this . $ . classList . add ( a ) ; return this } : function ( b ) { var c = this . $ . className ; c && ( a ( c , b ) || ( c += " " + b ) ) ; this . $ . className = c || b ; return this } , removeClass : f ? function ( a ) { var b = this . $ ; b . classList . remove ( a ) ; b . className || b . removeAttribute ( "class" ) ; return this } : function ( b ) { var c = this . getAttribute ( "class" ) ; c && a ( c , b ) && ( ( c = c . replace ( new RegExp ( "(?:^|\\s+)" +
b + "(?\x3d\\s|$)" ) , "" ) . replace ( /^\s+/ , "" ) ) ? this . setAttribute ( "class" , c ) : this . removeAttribute ( "class" ) ) ; return this } , hasClass : function ( b ) { return a ( this . $ . className , b ) } , append : function ( a , b ) { "string" == typeof a && ( a = this . getDocument ( ) . createElement ( a ) ) ; b ? this . $ . insertBefore ( a . $ , this . $ . firstChild ) : this . $ . appendChild ( a . $ ) ; return a } , appendHtml : function ( a ) { if ( this . $ . childNodes . length ) { var b = new CKEDITOR . dom . element ( "div" , this . getDocument ( ) ) ; b . setHtml ( a ) ; b . moveChildren ( this ) } else this . setHtml ( a ) } , appendText : function ( a ) { null !=
this . $ . text && CKEDITOR . env . ie && 9 > CKEDITOR . env . version ? this . $ . text += a : this . append ( new CKEDITOR . dom . text ( a ) ) } , appendBogus : function ( a ) { if ( a || CKEDITOR . env . needsBrFiller ) { for ( a = this . getLast ( ) ; a && a . type == CKEDITOR . NODE _TEXT && ! CKEDITOR . tools . rtrim ( a . getText ( ) ) ; ) a = a . getPrevious ( ) ; a && a . is && a . is ( "br" ) || ( a = this . getDocument ( ) . createElement ( "br" ) , CKEDITOR . env . gecko && a . setAttribute ( "type" , "_moz" ) , this . append ( a ) ) } } , breakParent : function ( a , b ) { var c = new CKEDITOR . dom . range ( this . getDocument ( ) ) ; c . setStartAfter ( this ) ; c . setEndAfter ( a ) ;
var f = c . extractContents ( ! 1 , b || ! 1 ) , e ; c . insertNode ( this . remove ( ) ) ; if ( CKEDITOR . env . ie && ! CKEDITOR . env . edge ) { for ( c = new CKEDITOR . dom . element ( "div" ) ; e = f . getFirst ( ) ; ) e . $ . style . backgroundColor && ( e . $ . style . backgroundColor = e . $ . style . backgroundColor ) , c . append ( e ) ; c . insertAfter ( this ) ; c . remove ( ! 0 ) } else f . insertAfterNode ( this ) } , contains : document . compareDocumentPosition ? function ( a ) { return ! ! ( this . $ . compareDocumentPosition ( a . $ ) & 16 ) } : function ( a ) { var b = this . $ ; return a . type != CKEDITOR . NODE _ELEMENT ? b . contains ( a . getParent ( ) . $ ) :
var g = c . extractContents ( ! 1 , b || ! 1 ) , e ; c . insertNode ( this . remove ( ) ) ; if ( CKEDITOR . env . ie && ! CKEDITOR . env . edge ) { for ( c = new CKEDITOR . dom . element ( "div" ) ; e = g . getFirst ( ) ; ) e . $ . style . backgroundColor && ( e . $ . style . backgroundColor = e . $ . style . backgroundColor ) , c . append ( e ) ; c . insertAfter ( this ) ; c . remove ( ! 0 ) } else g . insertAfterNode ( this ) } , contains : document . compareDocumentPosition ? function ( a ) { return ! ! ( this . $ . compareDocumentPosition ( a . $ ) & 16 ) } : function ( a ) { var b = this . $ ; return a . type != CKEDITOR . NODE _ELEMENT ? b . contains ( a . getParent ( ) . $ ) :
b != a . $ && b . contains ( a . $ ) } , focus : function ( ) { function a ( ) { try { this . $ . focus ( ) } catch ( b ) { } } return function ( b ) { b ? CKEDITOR . tools . setTimeout ( a , 100 , this ) : a . call ( this ) } } ( ) , getHtml : function ( ) { var a = this . $ . innerHTML ; return CKEDITOR . env . ie ? a . replace ( /<\?[^>]*>/g , "" ) : a } , getOuterHtml : function ( ) { if ( this . $ . outerHTML ) return this . $ . outerHTML . replace ( /<\?[^>]*>/ , "" ) ; var a = this . $ . ownerDocument . createElement ( "div" ) ; a . appendChild ( this . $ . cloneNode ( ! 0 ) ) ; return a . innerHTML } , getClientRect : function ( a ) { var b = CKEDITOR . tools . extend ( { } ,
this . $ . getBoundingClientRect ( ) ) ; ! b . width && ( b . width = b . right - b . left ) ; ! b . height && ( b . height = b . bottom - b . top ) ; return a ? CKEDITOR . tools . getAbsoluteRectPosition ( this . getWindow ( ) , b ) : b } , setHtml : CKEDITOR . env . ie && 9 > CKEDITOR . env . version ? function ( a ) { try { var b = this . $ ; if ( this . getParent ( ) ) return b . innerHTML = a ; var c = this . getDocument ( ) . _getHtml5ShivFrag ( ) ; c . appendChild ( b ) ; b . innerHTML = a ; c . removeChild ( b ) ; return a } catch ( f ) { this . $ . innerHTML = "" ; b = new CKEDITOR . dom . element ( "body" , this . getDocument ( ) ) ; b . $ . innerHTML = a ; for ( b = b . getChildren ( ) ; b . count ( ) ; ) this . append ( b . getItem ( 0 ) ) ;
this . $ . getBoundingClientRect ( ) ) ; ! b . width && ( b . width = b . right - b . left ) ; ! b . height && ( b . height = b . bottom - b . top ) ; return a ? CKEDITOR . tools . getAbsoluteRectPosition ( this . getWindow ( ) , b ) : b } , setHtml : CKEDITOR . env . ie && 9 > CKEDITOR . env . version ? function ( a ) { try { var b = this . $ ; if ( this . getParent ( ) ) return b . innerHTML = a ; var c = this . getDocument ( ) . _getHtml5ShivFrag ( ) ; c . appendChild ( b ) ; b . innerHTML = a ; c . removeChild ( b ) ; return a } catch ( g ) { this . $ . innerHTML = "" ; b = new CKEDITOR . dom . element ( "body" , this . getDocument ( ) ) ; b . $ . innerHTML = a ; for ( b = b . getChildren ( ) ; b . count ( ) ; ) this . append ( b . getItem ( 0 ) ) ;
return a } } : function ( a ) { return this . $ . innerHTML = a } , setText : function ( ) { var a = document . createElement ( "p" ) ; a . innerHTML = "x" ; a = a . textContent ; return function ( b ) { this . $ [ a ? "textContent" : "innerText" ] = b } } ( ) , getAttribute : function ( ) { var a = function ( a ) { return this . $ . getAttribute ( a , 2 ) } ; return CKEDITOR . env . ie && ( CKEDITOR . env . ie7Compat || CKEDITOR . env . quirks ) ? function ( a ) { switch ( a ) { case "class" : a = "className" ; break ; case "http-equiv" : a = "httpEquiv" ; break ; case "name" : return this . $ . name ; case "tabindex" : return a = this . $ . getAttribute ( a ,
2 ) , 0 !== a && 0 === this . $ . tabIndex && ( a = null ) , a ; case "checked" : return a = this . $ . attributes . getNamedItem ( a ) , ( a . specified ? a . nodeValue : this . $ . checked ) ? "checked" : null ; case "hspace" : case "value" : return this . $ [ a ] ; case "style" : return this . $ . style . cssText ; case "contenteditable" : case "contentEditable" : return this . $ . attributes . getNamedItem ( "contentEditable" ) . specified ? this . $ . getAttribute ( "contentEditable" ) : null } return this . $ . getAttribute ( a , 2 ) } : a } ( ) , getAttributes : function ( a ) { var b = { } , c = this . $ . attributes , f ; a = CKEDITOR . tools . isArray ( a ) ?
a : [ ] ; for ( f= 0 ; f < c . length ; f ++ ) - 1 === CKEDITOR . tools . indexOf ( a , c [ f ] . name ) && ( b [ c [ f] . name ] = c [ f ] . value ) ; return b } , getChildren : function ( ) { return new CKEDITOR . dom . nodeList ( this . $ . childNodes ) } , getClientSize : function ( ) { return { width : this . $ . clientWidth , height : this . $ . clientHeight } } , getComputedStyle : document . defaultView && document . defaultView . getComputedStyle ? function ( a ) { var b = this . getWindow ( ) . $ . getComputedStyle ( this . $ , null ) ; return b ? b . getPropertyValue ( a ) : "" } : function ( a ) { return this . $ . currentStyle [ CKEDITOR . tools . cssStyleToDomStyle ( a ) ] } ,
2 ) , 0 !== a && 0 === this . $ . tabIndex && ( a = null ) , a ; case "checked" : return a = this . $ . attributes . getNamedItem ( a ) , ( a . specified ? a . nodeValue : this . $ . checked ) ? "checked" : null ; case "hspace" : case "value" : return this . $ [ a ] ; case "style" : return this . $ . style . cssText ; case "contenteditable" : case "contentEditable" : return this . $ . attributes . getNamedItem ( "contentEditable" ) . specified ? this . $ . getAttribute ( "contentEditable" ) : null } return this . $ . getAttribute ( a , 2 ) } : a } ( ) , getAttributes : function ( a ) { var b = { } , c = this . $ . attributes , g ; a = CKEDITOR . tools . isArray ( a ) ?
a : [ ] ; for ( g= 0 ; g < c . length ; g ++ ) - 1 === CKEDITOR . tools . indexOf ( a , c [ g ] . name ) && ( b [ c [ g] . name ] = c [ g ] . value ) ; return b } , getChildren : function ( ) { return new CKEDITOR . dom . nodeList ( this . $ . childNodes ) } , getClientSize : function ( ) { return { width : this . $ . clientWidth , height : this . $ . clientHeight } } , getComputedStyle : document . defaultView && document . defaultView . getComputedStyle ? function ( a ) { var b = this . getWindow ( ) . $ . getComputedStyle ( this . $ , null ) ; return b ? b . getPropertyValue ( a ) : "" } : function ( a ) { return this . $ . currentStyle [ CKEDITOR . tools . cssStyleToDomStyle ( a ) ] } ,
getDtd : function ( ) { var a = CKEDITOR . dtd [ this . getName ( ) ] ; this . getDtd = function ( ) { return a } ; return a } , getElementsByTag : CKEDITOR . dom . document . prototype . getElementsByTag , getTabIndex : function ( ) { var a = this . $ . tabIndex ; return 0 !== a || CKEDITOR . dtd . $tabIndex [ this . getName ( ) ] || 0 === parseInt ( this . getAttribute ( "tabindex" ) , 10 ) ? a : - 1 } , getText : function ( ) { return this . $ . textContent || this . $ . innerText || "" } , getWindow : function ( ) { return this . getDocument ( ) . getWindow ( ) } , getId : function ( ) { return this . $ . id || null } , getNameAtt : function ( ) { return this . $ . name ||
null } , getName : function ( ) { var a = this . $ . nodeName . toLowerCase ( ) ; if ( CKEDITOR . env . ie && 8 >= document . documentMode ) { var b = this . $ . scopeName ; "HTML" != b && ( a = b . toLowerCase ( ) + ":" + a ) } this . getName = function ( ) { return a } ; return this . getName ( ) } , getValue : function ( ) { return this . $ . value } , getFirst : function ( a ) { var b = this . $ . firstChild ; ( b = b && new CKEDITOR . dom . node ( b ) ) && a && ! a ( b ) && ( b = b . getNext ( a ) ) ; return b } , getLast : function ( a ) { var b = this . $ . lastChild ; ( b = b && new CKEDITOR . dom . node ( b ) ) && a && ! a ( b ) && ( b = b . getPrevious ( a ) ) ; return b } , getStyle : function ( a ) { return this . $ . style [ CKEDITOR . tools . cssStyleToDomStyle ( a ) ] } ,
is : function ( ) { var a = this . getName ( ) ; if ( "object" == typeof arguments [ 0 ] ) return ! ! arguments [ 0 ] [ a ] ; for ( var b = 0 ; b < arguments . length ; b ++ ) if ( arguments [ b ] == a ) return ! 0 ; return ! 1 } , isEditable : function ( a ) { var b = this . getName ( ) ; return this . isReadOnly ( ) || "none" == this . getComputedStyle ( "display" ) || "hidden" == this . getComputedStyle ( "visibility" ) || CKEDITOR . dtd . $nonEditable [ b ] || CKEDITOR . dtd . $empty [ b ] || this . is ( "a" ) && ( this . data ( "cke-saved-name" ) || this . hasAttribute ( "name" ) ) && ! this . getChildCount ( ) ? ! 1 : ! 1 !== a ? ( a = CKEDITOR . dtd [ b ] ||
CKEDITOR . dtd . span , ! ( ! a || ! a [ "#" ] ) ) : ! 0 } , isIdentical : function ( a ) { var b = this . clone ( 0 , 1 ) ; a = a . clone ( 0 , 1 ) ; b . removeAttributes ( [ "_moz_dirty" , "data-cke-expando" , "data-cke-saved-href" , "data-cke-saved-name" ] ) ; a . removeAttributes ( [ "_moz_dirty" , "data-cke-expando" , "data-cke-saved-href" , "data-cke-saved-name" ] ) ; if ( b . $ . isEqualNode ) return b . $ . style . cssText = CKEDITOR . tools . normalizeCssText ( b . $ . style . cssText ) , a . $ . style . cssText = CKEDITOR . tools . normalizeCssText ( a . $ . style . cssText ) , b . $ . isEqualNode ( a . $ ) ; b = b . getOuterHtml ( ) ; a =
a . getOuterHtml ( ) ; if ( CKEDITOR . env . ie && 9 > CKEDITOR . env . version && this . is ( "a" ) ) { var c = this . getParent ( ) ; c . type == CKEDITOR . NODE _ELEMENT && ( c = c . clone ( ) , c . setHtml ( b ) , b = c . getHtml ( ) , c . setHtml ( a ) , a = c . getHtml ( ) ) } return b == a } , isVisible : function ( ) { var a = ( this . $ . offsetHeight || this . $ . offsetWidth ) && "hidden" != this . getComputedStyle ( "visibility" ) , b , c ; a && CKEDITOR . env . webkit && ( b = this . getWindow ( ) , ! b . equals ( CKEDITOR . document . getWindow ( ) ) && ( c = b . $ . frameElement ) && ( a = ( new CKEDITOR . dom . element ( c ) ) . isVisible ( ) ) ) ; return ! ! a } , isEmptyInlineRemoveable : function ( ) { if ( ! CKEDITOR . dtd . $removeEmpty [ this . getName ( ) ] ) return ! 1 ;
for ( var a = this . getChildren ( ) , b = 0 , c = a . count ( ) ; b < c ; b ++ ) { var f = a . getItem ( b ) ; if ( f . type != CKEDITOR . NODE _ELEMENT || ! f . data ( "cke-bookmark" ) ) if ( f . type == CKEDITOR . NODE _ELEMENT && ! f. isEmptyInlineRemoveable ( ) || f . type == CKEDITOR . NODE _TEXT && CKEDITOR . tools . trim ( f . getText ( ) ) ) return ! 1 } return ! 0 } , hasAttributes : CKEDITOR . env . ie && ( CKEDITOR . env . ie7Compat || CKEDITOR . env . quirks ) ? function ( ) { for ( var a = this . $ . attributes , b = 0 ; b < a . length ; b ++ ) { var c = a [ b ] ; switch ( c . nodeName ) { case "class" : if ( this . getAttribute ( "class" ) ) return ! 0 ; case "data-cke-expando" : continue ;
for ( var a = this . getChildren ( ) , b = 0 , c = a . count ( ) ; b < c ; b ++ ) { var g = a . getItem ( b ) ; if ( g . type != CKEDITOR . NODE _ELEMENT || ! g . data ( "cke-bookmark" ) ) if ( g . type == CKEDITOR . NODE _ELEMENT && ! g. isEmptyInlineRemoveable ( ) || g . type == CKEDITOR . NODE _TEXT && CKEDITOR . tools . trim ( g . getText ( ) ) ) return ! 1 } return ! 0 } , hasAttributes : CKEDITOR . env . ie && ( CKEDITOR . env . ie7Compat || CKEDITOR . env . quirks ) ? function ( ) { for ( var a = this . $ . attributes , b = 0 ; b < a . length ; b ++ ) { var c = a [ b ] ; switch ( c . nodeName ) { case "class" : if ( this . getAttribute ( "class" ) ) return ! 0 ; case "data-cke-expando" : continue ;
default : if ( c . specified ) return ! 0 } } return ! 1 } : function ( ) { var a = this . $ . attributes , b = a . length , c = { "data-cke-expando" : 1 , _moz _dirty : 1 } ; return 0 < b && ( 2 < b || ! c [ a [ 0 ] . nodeName ] || 2 == b && ! c [ a [ 1 ] . nodeName ] ) } , hasAttribute : function ( ) { function a ( b ) { var c = this . $ . attributes . getNamedItem ( b ) ; if ( "input" == this . getName ( ) ) switch ( b ) { case "class" : return 0 < this . $ . className . length ; case "checked" : return ! ! this . $ . checked ; case "value" : return b = this . getAttribute ( "type" ) , "checkbox" == b || "radio" == b ? "on" != this . $ . value : ! ! this . $ . value } return c ?
c . specified : ! 1 } return CKEDITOR . env . ie ? 8 > CKEDITOR . env . version ? function ( b ) { return "name" == b ? ! ! this . $ . name : a . call ( this , b ) } : a : function ( a ) { return ! ! this . $ . attributes . getNamedItem ( a ) } } ( ) , hide : function ( ) { this . setStyle ( "display" , "none" ) } , moveChildren : function ( a , b ) { var c = this . $ ; a = a . $ ; if ( c != a ) { var f; if ( b ) for ( ; f = c . lastChild ; ) a . insertBefore ( c . removeChild ( f ) , a . firstChild ) ; else for ( ; f = c . firstChild ; ) a . appendChild ( c . removeChild ( f ) ) } } , mergeSiblings : function ( ) { function a ( b , c , f ) { if ( c && c . type == CKEDITOR . NODE _ELEMENT ) { for ( var e =
[ ] ; c . data ( "cke-bookmark" ) || c . isEmptyInlineRemoveable ( ) ; ) if ( e . push ( c ) , c = f ? c . getNext ( ) : c . getPrevious ( ) , ! c || c . type != CKEDITOR . NODE _ELEMENT ) return ; if ( b . isIdentical ( c ) ) { for ( var k= f ? b . getLast ( ) : b . getFirst ( ) ; e . length ; ) e . shift ( ) . move ( b , ! f ) ; c . moveChildren ( b , ! f) ; c . remove ( ) ; k && k . type == CKEDITOR . NODE _ELEMENT && k . mergeSiblings ( ) } } } return function ( b ) { if ( ! 1 === b || CKEDITOR . dtd . $removeEmpty [ this . getName ( ) ] || this . is ( "a" ) ) a ( this , this . getNext ( ) , ! 0 ) , a ( this , this . getPrevious ( ) ) } } ( ) , show : function ( ) { this . setStyles ( { display : "" ,
c . specified : ! 1 } return CKEDITOR . env . ie ? 8 > CKEDITOR . env . version ? function ( b ) { return "name" == b ? ! ! this . $ . name : a . call ( this , b ) } : a : function ( a ) { return ! ! this . $ . attributes . getNamedItem ( a ) } } ( ) , hide : function ( ) { this . setStyle ( "display" , "none" ) } , moveChildren : function ( a , b ) { var c = this . $ ; a = a . $ ; if ( c != a ) { var g; if ( b ) for ( ; g = c . lastChild ; ) a . insertBefore ( c . removeChild ( g ) , a . firstChild ) ; else for ( ; g = c . firstChild ; ) a . appendChild ( c . removeChild ( g ) ) } } , mergeSiblings : function ( ) { function a ( b , c , g ) { if ( c && c . type == CKEDITOR . NODE _ELEMENT ) { for ( var e =
[ ] ; c . data ( "cke-bookmark" ) || c . isEmptyInlineRemoveable ( ) ; ) if ( e . push ( c ) , c = g ? c . getNext ( ) : c . getPrevious ( ) , ! c || c . type != CKEDITOR . NODE _ELEMENT ) return ; if ( b . isIdentical ( c ) ) { for ( var h= g ? b . getLast ( ) : b . getFirst ( ) ; e . length ; ) e . shift ( ) . move ( b , ! g ) ; c . moveChildren ( b , ! g) ; c . remove ( ) ; h && h . type == CKEDITOR . NODE _ELEMENT && h . mergeSiblings ( ) } } } return function ( b ) { if ( ! 1 === b || CKEDITOR . dtd . $removeEmpty [ this . getName ( ) ] || this . is ( "a" ) ) a ( this , this . getNext ( ) , ! 0 ) , a ( this , this . getPrevious ( ) ) } } ( ) , show : function ( ) { this . setStyles ( { display : "" ,
visibility : "" } ) } , setAttribute : function ( ) { var a = function ( a , b ) { this . $ . setAttribute ( a , b ) ; return this } ; return CKEDITOR . env . ie && ( CKEDITOR . env . ie7Compat || CKEDITOR . env . quirks ) ? function ( b , c ) { "class" == b ? this . $ . className = c : "style" == b ? this . $ . style . cssText = c : "tabindex" == b ? this . $ . tabIndex = c : "checked" == b ? this . $ . checked = c : "contenteditable" == b ? a . call ( this , "contentEditable" , c ) : a . apply ( this , arguments ) ; return this } : CKEDITOR . env . ie8Compat && CKEDITOR . env . secure ? function ( b , c ) { if ( "src" == b && c . match ( /^http:\/\// ) ) try { a . apply ( this ,
arguments ) } catch ( f ) { } else a . apply ( this , arguments ) ; return this } : a } ( ) , setAttributes : function ( a ) { for ( var b in a ) this . setAttribute ( b , a [ b ] ) ; return this } , setValue : function ( a ) { this . $ . value = a ; return this } , removeAttribute : function ( ) { var a = function ( a ) { this . $ . removeAttribute ( a ) } ; return CKEDITOR . env . ie && ( CKEDITOR . env . ie7Compat || CKEDITOR . env . quirks ) ? function ( a ) { "class" == a ? a = "className" : "tabindex" == a ? a = "tabIndex" : "contenteditable" == a && ( a = "contentEditable" ) ; this . $ . removeAttribute ( a ) } : a } ( ) , removeAttributes : function ( a ) { if ( CKEDITOR . tools . isArray ( a ) ) for ( var b =
0 ; b < a . length ; b ++ ) this . removeAttribute ( a [ b ] ) ; else for ( b in a = a || this . getAttributes ( ) , a ) a . hasOwnProperty ( b ) && this . removeAttribute ( b ) } , removeStyle : function ( a ) { var b = this . $ . style ; if ( b . removeProperty || "border" != a && "margin" != a && "padding" != a ) b . removeProperty ? b . removeProperty ( a ) : b . removeAttribute ( CKEDITOR . tools . cssStyleToDomStyle ( a ) ) , this . $ . style . cssText || this . removeAttribute ( "style" ) ; else { var c = [ "top" , "left" , "right" , "bottom" ] , f; "border" == a && ( f = [ "color" , "style" , "width" ] ) ; for ( var b = [ ] , e = 0 ; e < c . length ; e ++ ) if ( f ) for ( var d =
0 ; d < f . length ; d ++ ) b . push ( [ a , c [ e ] , f [ d ] ] . join ( "-" ) ) ; else b . push ( [ a , c [ e ] ] . join ( "-" ) ) ; for ( a = 0 ; a < b . length ; a ++ ) this . removeStyle ( b [ a ] ) } } , setStyle : function ( a , b ) { this . $ . style [ CKEDITOR . tools . cssStyleToDomStyle ( a ) ] = b ; return this } , setStyles : function ( a ) { for ( var b in a ) this . setStyle ( b , a [ b ] ) ; return this } , setOpacity : function ( a ) { CKEDITOR . env . ie && 9 > CKEDITOR . env . version ? ( a = Math . round ( 100 * a ) , this . setStyle ( "filter" , 100 <= a ? "" : "progid:DXImageTransform.Microsoft.Alpha(opacity\x3d" + a + ")" ) ) : this . setStyle ( "opacity" , a ) } , unselectable : function ( ) { this . setStyles ( CKEDITOR . tools . cssVendorPrefix ( "user-select" ,
"none" ) ) ; if ( CKEDITOR . env . ie ) { this . setAttribute ( "unselectable" , "on" ) ; for ( var a , b = this . getElementsByTag ( "*" ) , c = 0 , f= b . count ( ) ; c < f ; c ++ ) a = b . getItem ( c ) , a . setAttribute ( "unselectable" , "on" ) } } , getPositionedAncestor : function ( ) { for ( var a = this ; "html" != a . getName ( ) ; ) { if ( "static" != a . getComputedStyle ( "position" ) ) return a ; a = a . getParent ( ) } return null } , getDocumentPosition : function ( a ) { var b = 0 , c = 0 , f = this . getDocument ( ) , e = f . getBody ( ) , d = "BackCompat" == f . $ . compatMode ; if ( document . documentElement . getBoundingClientRect && ( CKEDITOR . env . ie ?
8 !== CKEDITOR . env . version : 1 ) ) { var g = this . $ . getBoundingClientRect ( ) , h= f . $ . documentElement , r = h . clientTop || e . $ . clientTop || 0 , m = h . clientLeft || e . $ . clientLeft || 0 , L = ! 0 ; CKEDITOR . env . ie && ( L= f . getDocumentElement ( ) . contains ( this ) , f= f . getBody ( ) . contains ( this ) , L= d && f || ! d && L ) ; L && ( CKEDITOR . env . webkit || CKEDITOR . env . ie && 12 <= CKEDITOR . env . version ? ( b = e . $ . scrollLeft || h . scrollLeft , c = e . $ . scrollTop || h . scrollTop ) : ( c = d ? e . $ : h , b = c . scrollLeft , c = c . scrollTop ) , b = g. left + b - m , c = g . top + c - r ) } else for ( r = this , m = null ; r && "body" != r . getName ( ) &&
"html" != r. getName ( ) ; ) { b += r . $ . offsetLeft - r . $ . scrollLeft ; c += r . $ . offsetTop - r . $ . scrollTop ; r . equals ( this ) || ( b += r . $ . clientLeft || 0 , c += r . $ . clientTop || 0 ) ; for ( ; m && ! m . equals ( r ) ; ) b -= m . $ . scrollLeft , c -= m . $ . scrollTop , m = m . getParent ( ) ; m = r; r = ( g = r . $ . offsetParent ) ? new CKEDITOR . dom . element ( g) : null } a && ( g = this . getWindow ( ) , r = a . getWindow ( ) , ! g . equals ( r ) && g . $ . frameElement && ( a = ( new CKEDITOR . dom . element ( g . $ . frameElement ) ) . getDocumentPosition ( a ) , b += a . x , c += a . y ) ) ; document . documentElement . getBoundingClientRect || ! CKEDITOR . env . gecko ||
d || ( b += this . $ . clientLeft ? 1 : 0 , c += this . $ . clientTop ? 1 : 0 ) ; return { x : b , y : c } } , scrollIntoView : function ( a ) { var b = this . getParent ( ) ; if ( b ) { do if ( ( b . $ . clientWidth && b . $ . clientWidth < b . $ . scrollWidth || b . $ . clientHeight && b . $ . clientHeight < b . $ . scrollHeight ) && ! b . is ( "body" ) && this . scrollIntoParent ( b , a , 1 ) , b . is ( "html" ) ) { var c = b . getWindow ( ) ; try { var f= c . $ . frameElement ; f && ( b = new CKEDITOR . dom . element ( f ) ) } catch ( e ) { } } while ( b = b . getParent ( ) ) } } , scrollIntoParent : function ( a , b , c ) { var f, e , d , g ; function h ( b , c ) { /body|html/ . test ( a . getName ( ) ) ?
a . getWindow ( ) . $ . scrollBy ( b , c ) : ( a . $ . scrollLeft += b , a . $ . scrollTop += c ) } function r ( a , b ) { var c = { x : 0 , y : 0 } ; if ( ! a . is ( L ? "body" : "html" ) ) { var f = a . $ . getBoundingClientRect ( ) ; c . x = f. left ; c . y = f . top } f = a . getWindow ( ) ; f . equals ( b ) || ( f = r ( CKEDITOR . dom . element . get ( f . $ . frameElement ) , b ) , c . x += f. x , c . y += f . y ) ; return c } function m ( a , b ) { return parseInt ( a . getComputedStyle ( "margin-" + b ) || 0 , 10 ) || 0 } ! a && ( a = this . getWindow ( ) ) ; d = a . getDocument ( ) ; var L = "BackCompat" == d . $ . compatMode ; a instanceof CKEDITOR . dom . window && ( a = L ? d . getBody ( ) : d . getDocumentElement ( ) ) ;
CKEDITOR . env . webkit && ( d = this . getEditor ( ! 1 ) ) && ( d . _ . previousScrollTop = null ) ; d = a . getWindow ( ) ; e = r( this , d ) ; var v = r ( a , d ) , J = this . $ . offsetHeight ; f= this . $ . offsetWidth ; var G = a . $ . clientHeight , p = a . $ . clientWidth ; d = e . x - m ( this , "left" ) - v. x || 0 ; g = e . y - m ( this , "top" ) - v. y || 0 ; f = e . x + f + m ( this , "right" ) - ( v. x + p ) || 0 ; e = e . y + J + m ( this , "bottom" ) - ( v. y + G ) || 0 ; ( 0 > g || 0 < e ) && h ( 0 , ! 0 === b ? g : ! 1 === b ? e : 0 > g? g : e ) ; c && ( 0 > d || 0 < f) && h ( 0 > d ? d : f , 0 ) } , setState : function ( a , b , c ) { b = b || "cke" ; switch ( a ) { case CKEDITOR . TRISTATE _ON : this . addClass ( b + "_on" ) ; this . removeClass ( b +
arguments ) } catch ( g ) { } else a . apply ( this , arguments ) ; return this } : a } ( ) , setAttributes : function ( a ) { for ( var b in a ) this . setAttribute ( b , a [ b ] ) ; return this } , setValue : function ( a ) { this . $ . value = a ; return this } , removeAttribute : function ( ) { var a = function ( a ) { this . $ . removeAttribute ( a ) } ; return CKEDITOR . env . ie && ( CKEDITOR . env . ie7Compat || CKEDITOR . env . quirks ) ? function ( a ) { "class" == a ? a = "className" : "tabindex" == a ? a = "tabIndex" : "contenteditable" == a && ( a = "contentEditable" ) ; this . $ . removeAttribute ( a ) } : a } ( ) , removeAttributes : function ( a ) { if ( CKEDITOR . tools . isArray ( a ) ) for ( var b =
0 ; b < a . length ; b ++ ) this . removeAttribute ( a [ b ] ) ; else for ( b in a = a || this . getAttributes ( ) , a ) a . hasOwnProperty ( b ) && this . removeAttribute ( b ) } , removeStyle : function ( a ) { var b = this . $ . style ; if ( b . removeProperty || "border" != a && "margin" != a && "padding" != a ) b . removeProperty ? b . removeProperty ( a ) : b . removeAttribute ( CKEDITOR . tools . cssStyleToDomStyle ( a ) ) , this . $ . style . cssText || this . removeAttribute ( "style" ) ; else { var c = [ "top" , "left" , "right" , "bottom" ] , g; "border" == a && ( g = [ "color" , "style" , "width" ] ) ; for ( var b = [ ] , e = 0 ; e < c . length ; e ++ ) if ( g ) for ( var d =
0 ; d < g . length ; d ++ ) b . push ( [ a , c [ e ] , g [ d ] ] . join ( "-" ) ) ; else b . push ( [ a , c [ e ] ] . join ( "-" ) ) ; for ( a = 0 ; a < b . length ; a ++ ) this . removeStyle ( b [ a ] ) } } , setStyle : function ( a , b ) { this . $ . style [ CKEDITOR . tools . cssStyleToDomStyle ( a ) ] = b ; return this } , setStyles : function ( a ) { for ( var b in a ) this . setStyle ( b , a [ b ] ) ; return this } , setOpacity : function ( a ) { CKEDITOR . env . ie && 9 > CKEDITOR . env . version ? ( a = Math . round ( 100 * a ) , this . setStyle ( "filter" , 100 <= a ? "" : "progid:DXImageTransform.Microsoft.Alpha(opacity\x3d" + a + ")" ) ) : this . setStyle ( "opacity" , a ) } , unselectable : function ( ) { this . setStyles ( CKEDITOR . tools . cssVendorPrefix ( "user-select" ,
"none" ) ) ; if ( CKEDITOR . env . ie ) { this . setAttribute ( "unselectable" , "on" ) ; for ( var a , b = this . getElementsByTag ( "*" ) , c = 0 , g= b . count ( ) ; c < g ; c ++ ) a = b . getItem ( c ) , a . setAttribute ( "unselectable" , "on" ) } } , getPositionedAncestor : function ( ) { for ( var a = this ; "html" != a . getName ( ) ; ) { if ( "static" != a . getComputedStyle ( "position" ) ) return a ; a = a . getParent ( ) } return null } , getDocumentPosition : function ( a ) { var b = 0 , c = 0 , g = this . getDocument ( ) , e = g . getBody ( ) , d = "BackCompat" == g . $ . compatMode ; if ( document . documentElement . getBoundingClientRect && ( CKEDITOR . env . ie ?
8 !== CKEDITOR . env . version : 1 ) ) { var f = this . $ . getBoundingClientRect ( ) , k= g . $ . documentElement , v = k . clientTop || e . $ . clientTop || 0 , m = k . clientLeft || e . $ . clientLeft || 0 , M = ! 0 ; CKEDITOR . env . ie && ( M= g . getDocumentElement ( ) . contains ( this ) , g= g . getBody ( ) . contains ( this ) , M= d && g || ! d && M ) ; M && ( CKEDITOR . env . webkit || CKEDITOR . env . ie && 12 <= CKEDITOR . env . version ? ( b = e . $ . scrollLeft || k . scrollLeft , c = e . $ . scrollTop || k . scrollTop ) : ( c = d ? e . $ : k , b = c . scrollLeft , c = c . scrollTop ) , b = f. left + b - m , c = f . top + c - v ) } else for ( v = this , m = null ; v && "body" != v . getName ( ) &&
"html" != v. getName ( ) ; ) { b += v . $ . offsetLeft - v . $ . scrollLeft ; c += v . $ . offsetTop - v . $ . scrollTop ; v . equals ( this ) || ( b += v . $ . clientLeft || 0 , c += v . $ . clientTop || 0 ) ; for ( ; m && ! m . equals ( v ) ; ) b -= m . $ . scrollLeft , c -= m . $ . scrollTop , m = m . getParent ( ) ; m = v; v = ( f = v . $ . offsetParent ) ? new CKEDITOR . dom . element ( f) : null } a && ( f = this . getWindow ( ) , v = a . getWindow ( ) , ! f . equals ( v ) && f . $ . frameElement && ( a = ( new CKEDITOR . dom . element ( f . $ . frameElement ) ) . getDocumentPosition ( a ) , b += a . x , c += a . y ) ) ; document . documentElement . getBoundingClientRect || ! CKEDITOR . env . gecko ||
d || ( b += this . $ . clientLeft ? 1 : 0 , c += this . $ . clientTop ? 1 : 0 ) ; return { x : b , y : c } } , scrollIntoView : function ( a ) { var b = this . getParent ( ) ; if ( b ) { do if ( ( b . $ . clientWidth && b . $ . clientWidth < b . $ . scrollWidth || b . $ . clientHeight && b . $ . clientHeight < b . $ . scrollHeight ) && ! b . is ( "body" ) && this . scrollIntoParent ( b , a , 1 ) , b . is ( "html" ) ) { var c = b . getWindow ( ) ; try { var g= c . $ . frameElement ; g && ( b = new CKEDITOR . dom . element ( g ) ) } catch ( e ) { } } while ( b = b . getParent ( ) ) } } , scrollIntoParent : function ( a , b , c ) { var g, e , d , f ; function k ( b , c ) { /body|html/ . test ( a . getName ( ) ) ?
a . getWindow ( ) . $ . scrollBy ( b , c ) : ( a . $ . scrollLeft += b , a . $ . scrollTop += c ) } function v ( a , b ) { var c = { x : 0 , y : 0 } ; if ( ! a . is ( M ? "body" : "html" ) ) { var g = a . $ . getBoundingClientRect ( ) ; c . x = g. left ; c . y = g . top } g = a . getWindow ( ) ; g . equals ( b ) || ( g = v ( CKEDITOR . dom . element . get ( g . $ . frameElement ) , b ) , c . x += g. x , c . y += g . y ) ; return c } function m ( a , b ) { return parseInt ( a . getComputedStyle ( "margin-" + b ) || 0 , 10 ) || 0 } ! a && ( a = this . getWindow ( ) ) ; d = a . getDocument ( ) ; var M = "BackCompat" == d . $ . compatMode ; a instanceof CKEDITOR . dom . window && ( a = M ? d . getBody ( ) : d . getDocumentElement ( ) ) ;
CKEDITOR . env . webkit && ( d = this . getEditor ( ! 1 ) ) && ( d . _ . previousScrollTop = null ) ; d = a . getWindow ( ) ; e = v( this , d ) ; var w = v ( a , d ) , J = this . $ . offsetHeight ; g= this . $ . offsetWidth ; var F = a . $ . clientHeight , q = a . $ . clientWidth ; d = e . x - m ( this , "left" ) - w. x || 0 ; f = e . y - m ( this , "top" ) - w. y || 0 ; g = e . x + g + m ( this , "right" ) - ( w. x + q ) || 0 ; e = e . y + J + m ( this , "bottom" ) - ( w. y + F ) || 0 ; ( 0 > f || 0 < e ) && k ( 0 , ! 0 === b ? f : ! 1 === b ? e : 0 > f? f : e ) ; c && ( 0 > d || 0 < g) && k ( 0 > d ? d : g , 0 ) } , setState : function ( a , b , c ) { b = b || "cke" ; switch ( a ) { case CKEDITOR . TRISTATE _ON : this . addClass ( b + "_on" ) ; this . removeClass ( b +
"_off" ) ; this . removeClass ( b + "_disabled" ) ; c && this . setAttribute ( "aria-pressed" , ! 0 ) ; c && this . removeAttribute ( "aria-disabled" ) ; break ; case CKEDITOR . TRISTATE _DISABLED : this . addClass ( b + "_disabled" ) ; this . removeClass ( b + "_off" ) ; this . removeClass ( b + "_on" ) ; c && this . setAttribute ( "aria-disabled" , ! 0 ) ; c && this . removeAttribute ( "aria-pressed" ) ; break ; default : this . addClass ( b + "_off" ) , this . removeClass ( b + "_on" ) , this . removeClass ( b + "_disabled" ) , c && this . removeAttribute ( "aria-pressed" ) , c && this . removeAttribute ( "aria-disabled" ) } } ,
getFrameDocument : function ( ) { var a = this . $ ; try { a . contentWindow . document } catch ( b ) { a . src = a . src } return a && new CKEDITOR . dom . document ( a . contentWindow . document ) } , copyAttributes : function ( a , b ) { var c = this . $ . attributes ; b = b || { } ; for ( var f= 0 ; f < c . length ; f ++ ) { var e = c [ f ] , d = e . nodeName . toLowerCase ( ) , g ; if ( ! ( d in b ) ) if ( "checked" == d && ( g = this . getAttribute ( d ) ) ) a . setAttribute ( d , g ) ; else if ( ! CKEDITOR . env . ie || this . hasAttribute ( d ) ) g = this . getAttribute ( d ) , null === g&& ( g = e . nodeValue ) , a . setAttribute ( d , g ) } "" !== this . $ . style . cssText &&
( a . $ . style . cssText = this . $ . style . cssText ) } , renameNode : function ( a ) { if ( this . getName ( ) != a ) { var b = this . getDocument ( ) ; a = new CKEDITOR . dom . element ( a , b ) ; this . copyAttributes ( a ) ; this . moveChildren ( a ) ; this . getParent ( ! 0 ) && this . $ . parentNode . replaceChild ( a . $ , this . $ ) ; a . $ [ "data-cke-expando" ] = this . $ [ "data-cke-expando" ] ; this . $ = a . $ ; delete this . getName } } , getChild : function ( ) { function a ( b , c ) { var f = b . childNodes ; if ( 0 <= c && c < f. length ) return f [ c ] } return function ( b ) { var c = this . $ ; if ( b . slice ) for ( b = b . slice ( ) ; 0 < b . length && c ; ) c = a ( c ,
getFrameDocument : function ( ) { var a = this . $ ; try { a . contentWindow . document } catch ( b ) { a . src = a . src } return a && new CKEDITOR . dom . document ( a . contentWindow . document ) } , copyAttributes : function ( a , b ) { var c = this . $ . attributes ; b = b || { } ; for ( var g= 0 ; g < c . length ; g ++ ) { var e = c [ g ] , d = e . nodeName . toLowerCase ( ) , f ; if ( ! ( d in b ) ) if ( "checked" == d && ( f = this . getAttribute ( d ) ) ) a . setAttribute ( d , f ) ; else if ( ! CKEDITOR . env . ie || this . hasAttribute ( d ) ) f = this . getAttribute ( d ) , null === f&& ( f = e . nodeValue ) , a . setAttribute ( d , f ) } "" !== this . $ . style . cssText &&
( a . $ . style . cssText = this . $ . style . cssText ) } , renameNode : function ( a ) { if ( this . getName ( ) != a ) { var b = this . getDocument ( ) ; a = new CKEDITOR . dom . element ( a , b ) ; this . copyAttributes ( a ) ; this . moveChildren ( a ) ; this . getParent ( ! 0 ) && this . $ . parentNode . replaceChild ( a . $ , this . $ ) ; a . $ [ "data-cke-expando" ] = this . $ [ "data-cke-expando" ] ; this . $ = a . $ ; delete this . getName } } , getChild : function ( ) { function a ( b , c ) { var g = b . childNodes ; if ( 0 <= c && c < g. length ) return g [ c ] } return function ( b ) { var c = this . $ ; if ( b . slice ) for ( b = b . slice ( ) ; 0 < b . length && c ; ) c = a ( c ,
b . shift ( ) ) ; else c = a ( c , b ) ; return c ? new CKEDITOR . dom . node ( c ) : null } } ( ) , getChildCount : function ( ) { return this . $ . childNodes . length } , disableContextMenu : function ( ) { function a ( b ) { return b . type == CKEDITOR . NODE _ELEMENT && b . hasClass ( "cke_enable_context_menu" ) } this . on ( "contextmenu" , function ( b ) { b . data . getTarget ( ) . getAscendant ( a , ! 0 ) || b . data . preventDefault ( ) } ) } , getDirection : function ( a ) { return a ? this . getComputedStyle ( "direction" ) || this . getDirection ( ) || this . getParent ( ) && this . getParent ( ) . getDirection ( 1 ) || this . getDocument ( ) . $ . dir ||
"ltr" : this . getStyle ( "direction" ) || this . getAttribute ( "dir" ) } , data : function ( a , b ) { a = "data-" + a ; if ( void 0 === b ) return this . getAttribute ( a ) ; ! 1 === b ? this . removeAttribute ( a ) : this . setAttribute ( a , b ) ; return null } , getEditor : function ( a ) { var b = CKEDITOR . instances , c , f , e ; a = a || void 0 === a ; for ( c in b ) if ( f= b [ c ] , f . element . equals ( this ) && f . elementMode != CKEDITOR . ELEMENT _MODE _APPENDTO || ! a && ( e = f . editable ( ) ) && ( e . equals ( this ) || e . contains ( this ) ) ) return f ; return null } , find : function ( a ) { var c = d ( this ) ; a = new CKEDITOR . dom . nodeList ( this . $ . querySelectorAll ( b ( this ,
a ) ) ) ; c ( ) ; return a } , findOne : function ( a ) { var c = d ( this ) ; a = this . $ . querySelector ( b ( this , a ) ) ; c ( ) ; return a ? new CKEDITOR . dom . element ( a ) : null } , forEach : function ( a , b , c ) { if ( ! ( c || b && this . type != b ) ) var f = a ( this ) ; if ( ! 1 !== f ) { c = this . getChildren ( ) ; for ( var e = 0 ; e < c . count ( ) ; e ++ ) f= c . getItem ( e ) , f . type == CKEDITOR . NODE _ELEMENT ? f . forEach ( a , b ) : b && f. type != b || a ( f ) } } , fireEventHandler : function ( a , b ) { var c = "on" + a , f = this . $ ; if ( CKEDITOR . env . ie && 9 > CKEDITOR . env . version ) { var e = f . ownerDocument . createEventObject ( ) , d ; for ( d in b ) e [ d ] = b [ d ] ; f . fireEvent ( c ,
e ) } else f[ f [ a ] ? a : c ] ( b ) } , isDetached : function ( ) { var a = this . getDocument ( ) , b = a . getDocumentElement ( ) ; return b . equals ( this ) || b . contains ( this ) ? ! CKEDITOR . env . ie || 8 < CKEDITOR . env . version && ! CKEDITOR . env . quirks ? ! a . $ . defaultView : ! 1 : ! 0 } } ) ; var h = { width : [ "border-left-width" , "border-right-width" , "padding-left" , "padding-right" ] , height : [ "border-top-width" , "border-bottom-width" , "padding-top" , "padding-bottom" ] } ; CKEDITOR . dom . element . prototype . setSize = function ( a , b , e ) { "number" == typeof b && ( ! e || CKEDITOR . env . ie && CKEDITOR . env . quirks ||
"ltr" : this . getStyle ( "direction" ) || this . getAttribute ( "dir" ) } , data : function ( a , b ) { a = "data-" + a ; if ( void 0 === b ) return this . getAttribute ( a ) ; ! 1 === b ? this . removeAttribute ( a ) : this . setAttribute ( a , b ) ; return null } , getEditor : function ( a ) { var b = CKEDITOR . instances , c , g , e ; a = a || void 0 === a ; for ( c in b ) if ( g= b [ c ] , g . element . equals ( this ) && g . elementMode != CKEDITOR . ELEMENT _MODE _APPENDTO || ! a && ( e = g . editable ( ) ) && ( e . equals ( this ) || e . contains ( this ) ) ) return g ; return null } , find : function ( a ) { var c = d ( this ) ; a = new CKEDITOR . dom . nodeList ( this . $ . querySelectorAll ( b ( this ,
a ) ) ) ; c ( ) ; return a } , findOne : function ( a ) { var c = d ( this ) ; a = this . $ . querySelector ( b ( this , a ) ) ; c ( ) ; return a ? new CKEDITOR . dom . element ( a ) : null } , forEach : function ( a , b , c ) { if ( ! ( c || b && this . type != b ) ) var g = a ( this ) ; if ( ! 1 !== g ) { c = this . getChildren ( ) ; for ( var e = 0 ; e < c . count ( ) ; e ++ ) g= c . getItem ( e ) , g . type == CKEDITOR . NODE _ELEMENT ? g . forEach ( a , b ) : b && g. type != b || a ( g ) } } , fireEventHandler : function ( a , b ) { var c = "on" + a , g = this . $ ; if ( CKEDITOR . env . ie && 9 > CKEDITOR . env . version ) { var e = g . ownerDocument . createEventObject ( ) , d ; for ( d in b ) e [ d ] = b [ d ] ; g . fireEvent ( c ,
e ) } else g[ g [ a ] ? a : c ] ( b ) } , isDetached : function ( ) { var a = this . getDocument ( ) , b = a . getDocumentElement ( ) ; return b . equals ( this ) || b . contains ( this ) ? ! CKEDITOR . env . ie || 8 < CKEDITOR . env . version && ! CKEDITOR . env . quirks ? ! a . $ . defaultView : ! 1 : ! 0 } } ) ; var k = { width : [ "border-left-width" , "border-right-width" , "padding-left" , "padding-right" ] , height : [ "border-top-width" , "border-bottom-width" , "padding-top" , "padding-bottom" ] } ; CKEDITOR . dom . element . prototype . setSize = function ( a , b , e ) { "number" == typeof b && ( ! e || CKEDITOR . env . ie && CKEDITOR . env . quirks ||
( b -= c . call ( this , a ) ) , this . setStyle ( a , b + "px" ) ) } ; CKEDITOR . dom . element . prototype . getSize = function ( a , b ) { var e = Math . max ( this . $ [ "offset" + CKEDITOR . tools . capitalize ( a ) ] , this . $ [ "client" + CKEDITOR . tools . capitalize ( a ) ] ) || 0 ; b && ( e -= c . call ( this , a ) ) ; return e } } ) ( ) ; CKEDITOR . dom . documentFragment = function ( a ) { a = a || CKEDITOR . document ; this . $ = a . type == CKEDITOR . NODE _DOCUMENT ? a . $ . createDocumentFragment ( ) : a } ;
CKEDITOR . tools . extend ( CKEDITOR . dom . documentFragment . prototype , CKEDITOR . dom . element . prototype , { type : CKEDITOR . NODE _DOCUMENT _FRAGMENT , insertAfterNode : function ( a ) { a = a . $ ; a . parentNode . insertBefore ( this . $ , a . nextSibling ) } , getHtml : function ( ) { var a = new CKEDITOR . dom . element ( "div" ) ; this . clone ( 1 , 1 ) . appendTo ( a ) ; return a . getHtml ( ) . replace ( /\s*data-cke-expando=".*?"/g , "" ) } } , ! 0 , { append : 1 , appendBogus : 1 , clone : 1 , getFirst : 1 , getHtml : 1 , getLast : 1 , getParent : 1 , getNext : 1 , getPrevious : 1 , appendTo : 1 , moveChildren : 1 , insertBefore : 1 ,
insertAfterNode : 1 , replace : 1 , trim : 1 , type : 1 , ltrim : 1 , rtrim : 1 , getDocument : 1 , getChildCount : 1 , getChild : 1 , getChildren : 1 } ) ; CKEDITOR . tools . extend ( CKEDITOR . dom . documentFragment . prototype , CKEDITOR . dom . document . prototype , ! 0 , { find : 1 , findOne : 1 } ) ;
( function ( ) { function a ( a , b ) { var c = this . range ; if ( this . _ . end ) return null ; if ( ! this . _ . start ) { this . _ . start = 1 ; if ( c . collapsed ) return this . end ( ) , null ; c . optimize ( ) } var f, e = c . startContainer ; f = c . endContainer ; var d = c . startOffset , g= c . endOffset , w , k = this . guard , h = this . type , l = a ? "getPreviousSourceNode" : "getNextSourceNode" ; if ( ! a && ! this . _ . guardLTR ) { var q= f . type == CKEDITOR . NODE _ELEMENT ? f: f . getParent ( ) , E = f . type == CKEDITOR . NODE _ELEMENT ? f. getChild ( g ) : f . getNext ( ) ; this . _ . guardLTR = function ( a , b ) { return ( ! b || ! q . equals ( a ) ) && ( ! E ||
! a . equals ( E ) ) && ( a . type != CKEDITOR . NODE _ELEMENT || ! b || ! a . equals ( c . root ) ) } } if ( a && ! this . _ . guardRTL ) { var z = e . type == CKEDITOR . NODE _ELEMENT ? e : e . getParent ( ) , t = e . type == CKEDITOR . NODE _ELEMENT ? d ? e . getChild ( d - 1 ) : null : e . getPrevious ( ) ; this . _ . guardRTL = function ( a , b ) { return ( ! b || ! z . equals ( a ) ) && ( ! t || ! a . equals ( t ) ) && ( a . type != CKEDITOR . NODE _ELEMENT || ! b || ! a . equals ( c . root ) ) } } var D = a ? this . _ . guardRTL : this . _ . guardLTR ; w= k ? function ( a , b ) { return ! 1 === D( a , b ) ? ! 1 : k ( a , b ) } : D ; this . current ? f = this . current [ l ] ( ! 1 , h, w ) : ( a ? f . type == CKEDITOR . NODE _ELEMENT &&
( f= 0 < g ? f . getChild ( g - 1 ) : ! 1 === w ( f , ! 0 ) ? null : f . getPreviousSourceNode ( ! 0 , h , w ) ) : ( f = e , f . type == CKEDITOR . NODE _ELEMENT && ( ( f= f . getChild ( d ) ) || ( f = ! 1 === w ( e , ! 0 ) ? null : e . getNextSourceNode ( ! 0 , h, w ) ) ) ) , f && ! 1 === w ( f ) && ( f = null ) ) ; for ( ; f && ! this . _ . end ; ) { this . current = f ; if ( ! this . evaluator || ! 1 !== this . evaluator ( f) ) { if ( ! b ) return f } else if ( b && this . evaluator ) return ! 1 ; f= f [ l ] ( ! 1 , h , w ) } this . end ( ) ; return this . current = null } function d ( b ) { for ( var c , f = null ; c = a . call ( this , b ) ; ) f= c ; return f } CKEDITOR . dom . walker = CKEDITOR . tools . createClass ( { $ : function ( a ) { this . range =
( function ( ) { function a ( a , b ) { var c = this . range ; if ( this . _ . end ) return null ; if ( ! this . _ . start ) { this . _ . start = 1 ; if ( c . collapsed ) return this . end ( ) , null ; c . optimize ( ) } var g, e = c . startContainer ; g = c . endContainer ; var d = c . startOffset , f= c . endOffset , h , x = this . guard , k = this . type , l = a ? "getPreviousSourceNode" : "getNextSourceNode" ; if ( ! a && ! this . _ . guardLTR ) { var n= g . type == CKEDITOR . NODE _ELEMENT ? g: g . getParent ( ) , D = g . type == CKEDITOR . NODE _ELEMENT ? g. getChild ( f ) : g . getNext ( ) ; this . _ . guardLTR = function ( a , b ) { return ( ! b || ! n . equals ( a ) ) && ( ! D ||
! a . equals ( D ) ) && ( a . type != CKEDITOR . NODE _ELEMENT || ! b || ! a . equals ( c . root ) ) } } if ( a && ! this . _ . guardRTL ) { var B = e . type == CKEDITOR . NODE _ELEMENT ? e : e . getParent ( ) , t = e . type == CKEDITOR . NODE _ELEMENT ? d ? e . getChild ( d - 1 ) : null : e . getPrevious ( ) ; this . _ . guardRTL = function ( a , b ) { return ( ! b || ! B . equals ( a ) ) && ( ! t || ! a . equals ( t ) ) && ( a . type != CKEDITOR . NODE _ELEMENT || ! b || ! a . equals ( c . root ) ) } } var H = a ? this . _ . guardRTL : this . _ . guardLTR ; h= x ? function ( a , b ) { return ! 1 === H( a , b ) ? ! 1 : x ( a , b ) } : H ; this . current ? g = this . current [ l ] ( ! 1 , k, h ) : ( a ? g . type == CKEDITOR . NODE _ELEMENT &&
( g= 0 < f ? g . getChild ( f - 1 ) : ! 1 === h ( g , ! 0 ) ? null : g . getPreviousSourceNode ( ! 0 , k , h ) ) : ( g = e , g . type == CKEDITOR . NODE _ELEMENT && ( ( g= g . getChild ( d ) ) || ( g = ! 1 === h ( e , ! 0 ) ? null : e . getNextSourceNode ( ! 0 , k, h ) ) ) ) , g && ! 1 === h ( g ) && ( g = null ) ) ; for ( ; g && ! this . _ . end ; ) { this . current = g ; if ( ! this . evaluator || ! 1 !== this . evaluator ( g) ) { if ( ! b ) return g } else if ( b && this . evaluator ) return ! 1 ; g= g [ l ] ( ! 1 , k , h ) } this . end ( ) ; return this . current = null } function d ( b ) { for ( var c , g = null ; c = a . call ( this , b ) ; ) g= c ; return g } CKEDITOR . dom . walker = CKEDITOR . tools . createClass ( { $ : function ( a ) { this . range =
a ; this . _ = { } } , proto : { end : function ( ) { this . _ . end = 1 } , next : function ( ) { return a . call ( this ) } , previous : function ( ) { return a . call ( this , 1 ) } , checkForward : function ( ) { return ! 1 !== a . call ( this , 0 , 1 ) } , checkBackward : function ( ) { return ! 1 !== a . call ( this , 1 , 1 ) } , lastForward : function ( ) { return d . call ( this ) } , lastBackward : function ( ) { return d . call ( this , 1 ) } , reset : function ( ) { delete this . current ; this . _ = { } } } } ) ; var b = { 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 } , c = { absolute : 1 , fixed : 1 } ; CKEDITOR . dom . element . prototype . isBlockBoundary = function ( a ) { return "none" != this . getComputedStyle ( "float" ) || this . getComputedStyle ( "position" ) in c || ! b [ this . getComputedStyle ( "display" ) ] ? ! ! ( this . is ( CKEDITOR . dtd . $block ) || a && this . is ( a ) ) : ! 0 } ; CKEDITOR . dom . walker . blockBoundary = function ( a ) { return function ( b ) { return ! ( b . type == CKEDITOR . NODE _ELEMENT && b . isBlockBoundary ( a ) ) } } ; CKEDITOR . dom . walker . listItemBoundary = function ( ) { return this . blockBoundary ( { br : 1 } ) } ;
CKEDITOR . dom . walker . bookmark = function ( a , b ) { function c ( a ) { return a && a . getName && "span" == a . getName ( ) && a . data ( "cke-bookmark" ) } return function ( f) { var e , d ; e = f && f . type != CKEDITOR . NODE _ELEMENT && ( d = f . getParent ( ) ) && c ( d ) ; e = a ? e : e || c ( f ) ; return ! ! ( b ^ e ) } } ; CKEDITOR . dom . walker . whitespaces = function ( a ) { return function ( b ) { var c ; b && b . type == CKEDITOR . NODE _TEXT && ( c = ! CKEDITOR . tools . trim ( b . getText ( ) ) || CKEDITOR . env . webkit && b . getText ( ) == CKEDITOR . dom . selection . FILLING _CHAR _SEQUENCE ) ; return ! ! ( a ^ c ) } } ; CKEDITOR . dom . walker . invisible =
function ( a ) { var b = CKEDITOR . dom . walker . whitespaces ( ) , c = CKEDITOR . env . webkit ? 1 : 0 ; return function ( f) { b ( f ) ? f = 1 : ( f . type == CKEDITOR . NODE _TEXT && ( f= f . getParent ( ) ) , f = f . $ . offsetWidth <= c ) ; return ! ! ( a ^ f ) } } ; CKEDITOR . dom . walker . nodeType = function ( a , b ) { return function ( c ) { return ! ! ( b ^ c . type == a ) } } ; CKEDITOR . dom . walker . bogus = function ( a ) { function b ( a ) { return ! e ( a ) && ! h ( a ) } return function ( c ) { var f = CKEDITOR . env . needsBrFiller ? c . is && c . is ( "br" ) : c . getText && g . test ( c . getText ( ) ) ; f&& ( f = c . getParent ( ) , c = c . getNext ( b ) , f= f . isBlockBoundary ( ) &&
( ! c || c . type == CKEDITOR . NODE _ELEMENT && c . isBlockBoundary ( ) ) ) ; return ! ! ( a ^ f ) } } ; CKEDITOR . dom . walker . temp = function ( a ) { return function ( b ) { b . type != CKEDITOR . NODE _ELEMENT && ( b = b . getParent ( ) ) ; b = b && b . hasAttribute ( "data-cke-temp" ) ; return ! ! ( a ^ b ) } } ; var g = /^[\t\r\n ]*(?: |\xa0)$/ , e = CKEDITOR . dom . walker . whitespaces ( ) , h = CKEDITOR . dom . walker . bookmark ( ) , k = CKEDITOR . dom . walker . temp ( ) , l= function ( a ) { return h ( a ) || e ( a ) || a . type == CKEDITOR . NODE _ELEMENT && a . is ( CKEDITOR . dtd . $inline ) && ! a . is ( CKEDITOR . dtd . $empty ) } ; CKEDITOR . dom . walker . ignored =
function ( a ) { return function ( b ) { b = e ( b ) || h( b ) || k ( b ) ; return ! ! ( a ^ b ) } } ; var q = CKEDITOR . dom . walker . ignored ( ) ; CKEDITOR . dom . walker . empty = function ( a ) { return function ( b ) { for ( var c = 0 , f = b . getChildCount ( ) ; c < f; ++ c ) if ( ! q ( b . getChild ( c ) ) ) return ! ! a ; return ! a } } ; var f = CKEDITOR . dom . walker . empty ( ) , w = CKEDITOR . dom . walker . validEmptyBlockContainers = CKEDITOR . tools . extend ( function ( a ) { var b = { } , c ; for ( c in a ) CKEDITOR . dtd [ c ] [ "#" ] && ( b [ c ] = 1 ) ; return b } ( CKEDITOR . dtd . $block ) , { caption : 1 , td : 1 , th : 1 } ) ; CKEDITOR . dom . walker . editable = function ( a ) { return function ( b ) { b =
q ( b ) ? ! 1 : b . type == CKEDITOR . NODE _TEXT || b . type == CKEDITOR . NODE _ELEMENT && ( b . is ( CKEDITOR . dtd . $inline ) || b . is ( "hr" ) || "false" == b . getAttribute ( "contenteditable" ) || ! CKEDITOR . env . needsBrFiller && b . is ( w) && f ( b ) ) ? ! 0 : ! 1 ; return ! ! ( a ^ b ) } } ; CKEDITOR . dom . element . prototype . getBogus = function ( ) { var a = this ; do a = a . getPreviousSourceNode ( ) ; while ( l ( a ) ) ; return a && ( CKEDITOR . env . needsBrFiller ? a . is && a . is ( "br" ) : a . getText && g . test ( a . getText ( ) ) ) ? a : ! 1 } } ) ( ) ; "use strict" ;
CKEDITOR . dom . walker . bookmark = function ( a , b ) { function c ( a ) { return a && a . getName && "span" == a . getName ( ) && a . data ( "cke-bookmark" ) } return function ( g) { var e , d ; e = g && g . type != CKEDITOR . NODE _ELEMENT && ( d = g . getParent ( ) ) && c ( d ) ; e = a ? e : e || c ( g ) ; return ! ! ( b ^ e ) } } ; CKEDITOR . dom . walker . whitespaces = function ( a ) { return function ( b ) { var c ; b && b . type == CKEDITOR . NODE _TEXT && ( c = ! CKEDITOR . tools . trim ( b . getText ( ) ) || CKEDITOR . env . webkit && b . getText ( ) == CKEDITOR . dom . selection . FILLING _CHAR _SEQUENCE ) ; return ! ! ( a ^ c ) } } ; CKEDITOR . dom . walker . invisible =
function ( a ) { var b = CKEDITOR . dom . walker . whitespaces ( ) , c = CKEDITOR . env . webkit ? 1 : 0 ; return function ( g) { b ( g ) ? g = 1 : ( g . type == CKEDITOR . NODE _TEXT && ( g= g . getParent ( ) ) , g = g . $ . offsetWidth <= c ) ; return ! ! ( a ^ g ) } } ; CKEDITOR . dom . walker . nodeType = function ( a , b ) { return function ( c ) { return ! ! ( b ^ c . type == a ) } } ; CKEDITOR . dom . walker . bogus = function ( a ) { function b ( a ) { return ! e ( a ) && ! k ( a ) } return function ( c ) { var g = CKEDITOR . env . needsBrFiller ? c . is && c . is ( "br" ) : c . getText && f . test ( c . getText ( ) ) ; g&& ( g = c . getParent ( ) , c = c . getNext ( b ) , g= g . isBlockBoundary ( ) &&
( ! c || c . type == CKEDITOR . NODE _ELEMENT && c . isBlockBoundary ( ) ) ) ; return ! ! ( a ^ g ) } } ; CKEDITOR . dom . walker . temp = function ( a ) { return function ( b ) { b . type != CKEDITOR . NODE _ELEMENT && ( b = b . getParent ( ) ) ; b = b && b . hasAttribute ( "data-cke-temp" ) ; return ! ! ( a ^ b ) } } ; var f = /^[\t\r\n ]*(?: |\xa0)$/ , e = CKEDITOR . dom . walker . whitespaces ( ) , k = CKEDITOR . dom . walker . bookmark ( ) , h = CKEDITOR . dom . walker . temp ( ) , n= function ( a ) { return k ( a ) || e ( a ) || a . type == CKEDITOR . NODE _ELEMENT && a . is ( CKEDITOR . dtd . $inline ) && ! a . is ( CKEDITOR . dtd . $empty ) } ; CKEDITOR . dom . walker . ignored =
function ( a ) { return function ( b ) { b = e ( b ) || k( b ) || h ( b ) ; return ! ! ( a ^ b ) } } ; var l = CKEDITOR . dom . walker . ignored ( ) ; CKEDITOR . dom . walker . empty = function ( a ) { return function ( b ) { for ( var c = 0 , g = b . getChildCount ( ) ; c < g; ++ c ) if ( ! l ( b . getChild ( c ) ) ) return ! ! a ; return ! a } } ; var g = CKEDITOR . dom . walker . empty ( ) , x = CKEDITOR . dom . walker . validEmptyBlockContainers = CKEDITOR . tools . extend ( function ( a ) { var b = { } , c ; for ( c in a ) CKEDITOR . dtd [ c ] [ "#" ] && ( b [ c ] = 1 ) ; return b } ( CKEDITOR . dtd . $block ) , { caption : 1 , td : 1 , th : 1 } ) ; CKEDITOR . dom . walker . editable = function ( a ) { return function ( b ) { b =
l ( b ) ? ! 1 : b . type == CKEDITOR . NODE _TEXT || b . type == CKEDITOR . NODE _ELEMENT && ( b . is ( CKEDITOR . dtd . $inline ) || b . is ( "hr" ) || "false" == b . getAttribute ( "contenteditable" ) || ! CKEDITOR . env . needsBrFiller && b . is ( x) && g ( b ) ) ? ! 0 : ! 1 ; return ! ! ( a ^ b ) } } ; CKEDITOR . dom . element . prototype . getBogus = function ( ) { var a = this ; do a = a . getPreviousSourceNode ( ) ; while ( n ( a ) ) ; return a && ( CKEDITOR . env . needsBrFiller ? a . is && a . is ( "br" ) : a . getText && f . test ( a . getText ( ) ) ) ? a : ! 1 } } ) ( ) ; "use strict" ;
CKEDITOR . dom . range = function ( a ) { this . endOffset = this . endContainer = this . startOffset = this . startContainer = null ; this . collapsed = ! 0 ; var d = a instanceof CKEDITOR . dom . document ; this . document = d ? a : a . getDocument ( ) ; this . root = d ? a . getBody ( ) : a } ;
( function ( ) { function a ( a ) { a . collapsed = a . startContainer && a . endContainer && a . startContainer . equals ( a . endContainer ) && a . startOffset == a . endOffset } function d ( a , b , c , e , d ) { function g( a , b , c , f ) { var Q = c ? a . getPrevious ( ) : a . getNext ( ) ; if ( f&& h ) return Q ; q || f ? b . append ( a . clone ( ! 0 , d ) , c ) : ( a . remove ( ) , l && b . append ( a , c ) ) ; return Q } function m ( ) { var a , b , c , f= Math . min ( N . length , x . length ) ; for ( a = 0 ; a < f; a ++ ) if ( b = N [ a ] , c = x [ a ] , ! b . equals ( c ) ) return a ; return a - 1 } function k( ) { var b = H - 1 , c = D && C && ! p . equals ( u ) ; b < M - 1 || b < n - 1 || c ? ( c ? a . moveToPosition ( u ,
CKEDITOR . POSITION _BEFORE _START ) : n == b + 1 && t ? a . moveToPosition ( x [ b ] , CKEDITOR . POSITION _BEFORE _END ) : a . moveToPosition ( x [ b + 1 ] , CKEDITOR . POSITION _BEFORE _START ) , e && ( b = N [ b + 1 ] ) && b . type == CKEDITOR . NODE _ELEMENT && ( c = CKEDITOR . dom . element . createFromHtml ( '\x3cspan data-cke-bookmark\x3d"1" style\x3d"display:none"\x3e\x26nbsp;\x3c/span\x3e' , a . document ) , c . insertAfter ( b ) , b . mergeSiblings ( ! 1 ) , a . moveToBookmark ( { startNode : c } ) ) ) : a . collapse ( ! 0 ) } a . optimizeBookmark ( ) ; var h = 0 === b , l = 1 == b , q= 2 == b ; b = q || l ; var p = a . startContainer , u = a . endContainer ,
K = a . startOffset , E= a . endOffset , z , t , D , C , I , T ; if ( q && u . type == CKEDITOR . NODE _TEXT && ( p. equals ( u ) || p . type === CKEDITOR . NODE _ELEMENT && p . getFirst ( ) . equals ( u ) ) ) c . append ( a . document . createText ( u . substring ( K , E ) ) ) ; else { u . type == CKEDITOR . NODE _TEXT ? q? T = ! 0 : u = u . split ( E ) : 0 < u . getChildCount ( ) ? E >= u . getChildCount ( ) ? ( u = u . getChild ( E - 1 ) , t = ! 0 ) : u = u . getChild ( E) : C = t = ! 0 ; p . type == CKEDITOR . NODE _TEXT ? q ? I = ! 0 : p . split ( K ) : 0 < p . getChildCount ( ) ? 0 === K ? ( p= p . getChild ( K ) , z = ! 0 ) : p = p . getChild ( K - 1 ) : D = z = ! 0 ; for ( var N = p . getParents ( ) , x = u . getParents ( ) , H = m ( ) ,
M= N . length - 1 , n = x . length - 1 , A = c , Q , aa , X , ea = - 1 , V = H ; V <= M ; V ++ ) { aa = N [ V ] ; X = aa . getNext ( ) ; for ( V != M || aa . equals ( x [ V ] ) && M < n ? b && ( Q = A . append ( aa . clone ( 0 , d ) ) ) : z? g ( aa , A , ! 1 , D ) : I && A . append ( a . document . createText ( aa . substring ( K ) ) ) ; X; ) { if ( X . equals ( x [ V ] ) ) { ea = V ; break } X = g ( X , A ) } A = Q } A = c ; for ( V = H ; V <= n ; V ++ ) if ( c = x [ V ] , X = c . getPrevious ( ) , c . equals ( N[ V ] ) ) b && ( A = A . getChild ( 0 ) ) ; else { V != n || c . equals ( N [ V ] ) && n < M ? b && ( Q = A . append ( c . clone ( 0 , d ) ) ) : t ? g( c , A , ! 1 , C ) : T && A . append ( a . document . createText ( c . substring ( 0 , E) ) ) ; if ( V > ea ) for ( ; X ; ) X = g ( X , A , ! 0 ) ; A = Q } q ||
k ( ) } } function b ( ) { var a = ! 1 , b = CKEDITOR . dom . walker . whitespaces ( ) , c = CKEDITOR . dom . walker . bookmark ( ! 0 ) , d = CKEDITOR . dom . walker . bogus ( ) ; return function ( g) { return c ( g ) || b ( g ) ? ! 0 : d ( g ) && ! a ? a = ! 0 : g . type == CKEDITOR . NODE _TEXT && ( g . hasAscendant ( "pre" ) || CKEDITOR . tools . trim ( g . getText ( ) ) . length ) || g . type == CKEDITOR . NODE _ELEMENT && ! g . is ( e ) ? ! 1 : ! 0 } } function c ( a ) { var b = CKEDITOR . dom . walker . whitespaces ( ) , c = CKEDITOR . dom . walker . bookmark ( 1 ) ; return function ( e ) { return c ( e ) || b ( e ) ? ! 0 : ! a && h ( e ) || e . type == CKEDITOR . NODE _ELEMENT && e . is ( CKEDITOR . dtd . $removeEmpty ) } }
function g ( a ) { return function ( ) { var b ; return this [ a ? "getPreviousNode" : "getNextNode" ] ( function ( a ) { ! b && q ( a ) && ( b = a ) ; return l( a ) && ! ( h ( a ) && a . equals ( b ) ) } ) } } var e = { 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 } , h = CKEDITOR . dom . walker . bogus ( ) , k= /^[\t\r\n ]*(?: |\xa0)$/ , l = CKEDITOR . dom . walker . editable ( ) , q = CKEDITOR . dom . walker . ignored ( ! 0 ) ; CKEDITOR . dom . range . prototype = { clone : function ( ) { var a =
( function ( ) { function a ( a ) { a . collapsed = a . startContainer && a . endContainer && a . startContainer . equals ( a . endContainer ) && a . startOffset == a . endOffset } function d ( a , b , c , e , d ) { function f( a , b , c , g ) { var Y = c ? a . getPrevious ( ) : a . getNext ( ) ; if ( g&& k ) return Y ; n || g ? b . append ( a . clone ( ! 0 , d ) , c ) : ( a . remove ( ) , l && b . append ( a , c ) ) ; return Y } function m ( ) { var a , b , c , g= Math . min ( L . length , r . length ) ; for ( a = 0 ; a < g; a ++ ) if ( b = L [ a ] , c = r [ a ] , ! b . equals ( c ) ) return a ; return a - 1 } function h( ) { var b = E - 1 , c = H && A && ! q . equals ( u ) ; b < S - 1 || b < p - 1 || c ? ( c ? a . moveToPosition ( u ,
CKEDITOR . POSITION _BEFORE _START ) : p == b + 1 && t ? a . moveToPosition ( r [ b ] , CKEDITOR . POSITION _BEFORE _END ) : a . moveToPosition ( r [ b + 1 ] , CKEDITOR . POSITION _BEFORE _START ) , e && ( b = L [ b + 1 ] ) && b . type == CKEDITOR . NODE _ELEMENT && ( c = CKEDITOR . dom . element . createFromHtml ( '\x3cspan data-cke-bookmark\x3d"1" style\x3d"display:none"\x3e\x26nbsp;\x3c/span\x3e' , a . document ) , c . insertAfter ( b ) , b . mergeSiblings ( ! 1 ) , a . moveToBookmark ( { startNode : c } ) ) ) : a . collapse ( ! 0 ) } a . optimizeBookmark ( ) ; var k = 0 === b , l = 1 == b , n= 2 == b ; b = n || l ; var q = a . startContainer , u = a . endContainer ,
K = a . startOffset , D= a . endOffset , B , t , H , A , I , N ; if ( n && u . type == CKEDITOR . NODE _TEXT && ( q. equals ( u ) || q . type === CKEDITOR . NODE _ELEMENT && q . getFirst ( ) . equals ( u ) ) ) c . append ( a . document . createText ( u . substring ( K , D ) ) ) ; else { u . type == CKEDITOR . NODE _TEXT ? n? N = ! 0 : u = u . split ( D ) : 0 < u . getChildCount ( ) ? D >= u . getChildCount ( ) ? ( u = u . getChild ( D - 1 ) , t = ! 0 ) : u = u . getChild ( D) : A = t = ! 0 ; q . type == CKEDITOR . NODE _TEXT ? n ? I = ! 0 : q . split ( K ) : 0 < q . getChildCount ( ) ? 0 === K ? ( q= q . getChild ( K ) , B = ! 0 ) : q = q . getChild ( K - 1 ) : H = B = ! 0 ; for ( var L = q . getParents ( ) , r = u . getParents ( ) , E = m ( ) ,
S= L . length - 1 , p = r . length - 1 , C = c , Y , aa , W , ea = - 1 , U = E ; U <= S ; U ++ ) { aa = L [ U ] ; W = aa . getNext ( ) ; for ( U != S || aa . equals ( r [ U ] ) && S < p ? b && ( Y = C . append ( aa . clone ( 0 , d ) ) ) : B? f ( aa , C , ! 1 , H ) : I && C . append ( a . document . createText ( aa . substring ( K ) ) ) ; W; ) { if ( W . equals ( r [ U ] ) ) { ea = U ; break } W = f ( W , C ) } C = Y } C = c ; for ( U = E ; U <= p ; U ++ ) if ( c = r [ U ] , W = c . getPrevious ( ) , c . equals ( L[ U ] ) ) b && ( C = C . getChild ( 0 ) ) ; else { U != p || c . equals ( L [ U ] ) && p < S ? b && ( Y = C . append ( c . clone ( 0 , d ) ) ) : t ? f( c , C , ! 1 , A ) : N && C . append ( a . document . createText ( c . substring ( 0 , D) ) ) ; if ( U > ea ) for ( ; W ; ) W = f ( W , C , ! 0 ) ; C = Y } n ||
h ( ) } } function b ( ) { var a = ! 1 , b = CKEDITOR . dom . walker . whitespaces ( ) , c = CKEDITOR . dom . walker . bookmark ( ! 0 ) , d = CKEDITOR . dom . walker . bogus ( ) ; return function ( f) { return c ( f ) || b ( f ) ? ! 0 : d ( f ) && ! a ? a = ! 0 : f . type == CKEDITOR . NODE _TEXT && ( f . hasAscendant ( "pre" ) || CKEDITOR . tools . trim ( f . getText ( ) ) . length ) || f . type == CKEDITOR . NODE _ELEMENT && ! f . is ( e ) ? ! 1 : ! 0 } } function c ( a ) { var b = CKEDITOR . dom . walker . whitespaces ( ) , c = CKEDITOR . dom . walker . bookmark ( 1 ) ; return function ( e ) { return c ( e ) || b ( e ) ? ! 0 : ! a && k ( e ) || e . type == CKEDITOR . NODE _ELEMENT && e . is ( CKEDITOR . dtd . $removeEmpty ) } }
function f ( a ) { return function ( ) { var b ; return this [ a ? "getPreviousNode" : "getNextNode" ] ( function ( a ) { ! b && l ( a ) && ( b = a ) ; return n( a ) && ! ( k ( a ) && a . equals ( b ) ) } ) } } var e = { 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 } , k = CKEDITOR . dom . walker . bogus ( ) , h= /^[\t\r\n ]*(?: |\xa0)$/ , n = CKEDITOR . dom . walker . editable ( ) , l = CKEDITOR . dom . walker . ignored ( ! 0 ) ; CKEDITOR . dom . range . prototype = { clone : function ( ) { var a =
new CKEDITOR . dom . range ( this . root ) ; a . _setStartContainer ( this . startContainer ) ; a . startOffset = this . startOffset ; a . _setEndContainer ( this . endContainer ) ; a . endOffset = this . endOffset ; a . collapsed = this . collapsed ; return a } , collapse : function ( a ) { a ? ( this . _setEndContainer ( this . startContainer ) , this . endOffset = this . startOffset ) : ( this . _setStartContainer ( this . endContainer ) , this . startOffset = this . endOffset ) ; this . collapsed = ! 0 } , cloneContents : function ( a ) { var b = new CKEDITOR . dom . documentFragment ( this . document ) ; this . collapsed ||
d ( this , 2 , b , ! 1 , "undefined" == typeof a ? ! 0 : a ) ; return b } , deleteContents : function ( a ) { this . collapsed || d ( this , 0 , null , a ) } , extractContents : function ( a , b ) { var c = new CKEDITOR . dom . documentFragment ( this . document ) ; this . collapsed || d ( this , 1 , c , a , "undefined" == typeof b ? ! 0 : b ) ; return c } , equals : function ( a ) { return this . startOffset === a . startOffset && this . endOffset === a . endOffset && this . startContainer . equals ( a . startContainer ) && this . endContainer . equals ( a . endContainer ) } , createBookmark : function ( a ) { function b ( a ) { return a . getAscendant ( function ( a ) { var b ;
if ( b = a . data && a . data ( "cke-temp" ) ) b = - 1 === CKEDITOR . tools . array . indexOf ( [ "cke_copybin" , "cke_pastebin" ] , a . getAttribute ( "id" ) ) ; return b } , ! 0 ) } var c = this . startContainer , e = this . endContainer , d = this . collapsed , g, m , k , h ; g = this . document . createElement ( "span" ) ; g . data ( "cke-bookmark" , 1 ) ; g . setStyle ( "display" , "none" ) ; g . setHtml ( "\x26nbsp;" ) ; a && ( k = "cke_bm_" + CKEDITOR . tools . getNextNumber ( ) , g. setAttribute ( "id" , k + ( d ? "C" : "S" ) ) ) ; d || ( m = g . clone ( ) , m . setHtml ( "\x26nbsp;" ) , a && m . setAttribute ( "id" , k+ "E" ) , h = this . clone ( ) , b ( e ) && ( e = b ( e ) ,
h . moveToPosition ( e , CKEDITOR . POSITION _AFTER _END ) ) , h. collapse ( ) , h . insertNode ( m ) ) ; h = this . clone ( ) ; b ( c ) && ( e = b ( c ) , h . moveToPosition ( e , CKEDITOR . POSITION _BEFORE _START ) ) ; h. collapse ( ! 0 ) ; h . insertNode ( g ) ; m ? ( this . setStartAfter ( g ) , this . setEndBefore ( m ) ) : this . moveToPosition ( g , CKEDITOR . POSITION _AFTER _END ) ; return { startNode : a ? k + ( d ? "C" : "S" ) : g, endNode : a ? k + "E" : m , serializable : a , collapsed : d } } , createBookmark2 : function ( ) { function a ( b ) { var f = b . container , e = b . offset , d ; d = f; var g = e ; d = d . type != CKEDITOR . NODE _ELEMENT || 0 === g|| g == d . getChildCount ( ) ?
0 : d . getChild ( g - 1 ) . type == CKEDITOR . NODE _TEXT && d . getChild ( g ) . type == CKEDITOR . NODE _TEXT ; d && ( f= f . getChild ( e - 1 ) , e = f. getLength ( ) ) ; if ( f . type == CKEDITOR . NODE _ELEMENT && 0 < e ) { a : { for ( d = f; e -- ; ) if ( g = d . getChild ( e ) . getIndex ( ! 0 ) , 0 <= g) { e = g ; break a } e = - 1 } e += 1 } if ( f . type == CKEDITOR . NODE _TEXT ) { d = f; for ( g = 0 ; ( d = d . getPrevious ( ) ) && d . type == CKEDITOR . NODE _TEXT ; ) g += d . getText ( ) . replace ( CKEDITOR . dom . selection . FILLING _CHAR _SEQUENCE , "" ) . length ; d = g; f . isEmpty ( ) ? ( g = f . getPrevious ( c ) , d ? ( e = d , f= g ? g . getNext ( ) : f . getParent ( ) . getFirst ( ) ) : ( f= f . getParent ( ) ,
e = g? g . getIndex ( ! 0 ) + 1 : 0 ) ) : e += d } b . container = f ; b . offset = e } function b ( a , c ) { var f = c . getCustomData ( "cke-fillingChar" ) ; if ( f ) { var e = a . container ; f . equals ( e ) && ( a . offset -= CKEDITOR . dom . selection . FILLING _CHAR _SEQUENCE . length , 0 >= a . offset && ( a . offset = e . getIndex ( ) , a . container = e . getParent ( ) ) ) } } var c = CKEDITOR . dom . walker . nodeType ( CKEDITOR . NODE _TEXT , ! 0 ) ; return function ( c ) { var e = this . collapsed , d = { container : this . startContainer , offset : this . startOffset } , m = { container : this . endContainer , offset : this . endOffset } ; c && ( a ( d ) , b ( d , this . root ) ,
if ( b = a . data && a . data ( "cke-temp" ) ) b = - 1 === CKEDITOR . tools . array . indexOf ( [ "cke_copybin" , "cke_pastebin" ] , a . getAttribute ( "id" ) ) ; return b } , ! 0 ) } var c = this . startContainer , e = this . endContainer , d = this . collapsed , f, m , h , k ; f = this . document . createElement ( "span" ) ; f . data ( "cke-bookmark" , 1 ) ; f . setStyle ( "display" , "none" ) ; f . setHtml ( "\x26nbsp;" ) ; a && ( h = "cke_bm_" + CKEDITOR . tools . getNextNumber ( ) , f. setAttribute ( "id" , h + ( d ? "C" : "S" ) ) ) ; d || ( m = f . clone ( ) , m . setHtml ( "\x26nbsp;" ) , a && m . setAttribute ( "id" , h+ "E" ) , k = this . clone ( ) , b ( e ) && ( e = b ( e ) ,
k . moveToPosition ( e , CKEDITOR . POSITION _AFTER _END ) ) , k. collapse ( ) , k . insertNode ( m ) ) ; k = this . clone ( ) ; b ( c ) && ( e = b ( c ) , k . moveToPosition ( e , CKEDITOR . POSITION _BEFORE _START ) ) ; k. collapse ( ! 0 ) ; k . insertNode ( f ) ; m ? ( this . setStartAfter ( f ) , this . setEndBefore ( m ) ) : this . moveToPosition ( f , CKEDITOR . POSITION _AFTER _END ) ; return { startNode : a ? h + ( d ? "C" : "S" ) : f, endNode : a ? h + "E" : m , serializable : a , collapsed : d } } , createBookmark2 : function ( ) { function a ( b ) { var g = b . container , e = b . offset , d ; d = g; var f = e ; d = d . type != CKEDITOR . NODE _ELEMENT || 0 === f|| f == d . getChildCount ( ) ?
0 : d . getChild ( f - 1 ) . type == CKEDITOR . NODE _TEXT && d . getChild ( f ) . type == CKEDITOR . NODE _TEXT ; d && ( g= g . getChild ( e - 1 ) , e = g. getLength ( ) ) ; if ( g . type == CKEDITOR . NODE _ELEMENT && 0 < e ) { a : { for ( d = g; e -- ; ) if ( f = d . getChild ( e ) . getIndex ( ! 0 ) , 0 <= f) { e = f ; break a } e = - 1 } e += 1 } if ( g . type == CKEDITOR . NODE _TEXT ) { d = g; for ( f = 0 ; ( d = d . getPrevious ( ) ) && d . type == CKEDITOR . NODE _TEXT ; ) f += d . getText ( ) . replace ( CKEDITOR . dom . selection . FILLING _CHAR _SEQUENCE , "" ) . length ; d = f; g . isEmpty ( ) ? ( f = g . getPrevious ( c ) , d ? ( e = d , g= f ? f . getNext ( ) : g . getParent ( ) . getFirst ( ) ) : ( g= g . getParent ( ) ,
e = f? f . getIndex ( ! 0 ) + 1 : 0 ) ) : e += d } b . container = g ; b . offset = e } function b ( a , c ) { var g = c . getCustomData ( "cke-fillingChar" ) ; if ( g ) { var e = a . container ; g . equals ( e ) && ( a . offset -= CKEDITOR . dom . selection . FILLING _CHAR _SEQUENCE . length , 0 >= a . offset && ( a . offset = e . getIndex ( ) , a . container = e . getParent ( ) ) ) } } var c = CKEDITOR . dom . walker . nodeType ( CKEDITOR . NODE _TEXT , ! 0 ) ; return function ( c ) { var e = this . collapsed , d = { container : this . startContainer , offset : this . startOffset } , m = { container : this . endContainer , offset : this . endOffset } ; c && ( a ( d ) , b ( d , this . root ) ,
e || ( a ( m ) , b ( m , this . root ) ) ) ; return { start : d . container . getAddress ( c ) , end : e ? null : m . container . getAddress ( c ) , startOffset : d . offset , endOffset : m . offset , normalized : c , collapsed : e , is2 : ! 0 } } } ( ) , moveToBookmark : function ( a ) { if ( a . is2 ) { var b = this . document . getByAddress ( a . start , a . normalized ) , c = a . startOffset , e = a . end && this . document . getByAddress ( a . end , a . normalized ) ; a = a . endOffset ; this . setStart ( b , c ) ; e ? this . setEnd ( e , a ) : this . collapse ( ! 0 ) } else b = ( c = a . serializable ) ? this . document . getById ( a . startNode ) : a . startNode , a = c ? this . document . getById ( a . endNode ) :
a . endNode , this . setStartBefore ( b ) , b . remove ( ) , a ? ( this . setEndBefore ( a ) , a . remove ( ) ) : this . collapse ( ! 0 ) } , getBoundaryNodes : function ( ) { var a = this . startContainer , b = this . endContainer , c = this . startOffset , e = this . endOffset , d ; if ( a . type == CKEDITOR . NODE _ELEMENT ) if ( d = a . getChildCount ( ) , d > c ) a = a . getChild ( c ) ; else if ( 1 > d ) a = a . getPreviousSourceNode ( ) ; else { for ( a = a . $ ; a . lastChild ; ) a = a . lastChild ; a = new CKEDITOR . dom . node ( a ) ; a = a . getNextSourceNode ( ) || a } if ( b . type == CKEDITOR . NODE _ELEMENT ) if ( d = b . getChildCount ( ) , d > e ) b = b . getChild ( e ) . getPreviousSourceNode ( ! 0 ) ;
else if ( 1 > d ) b = b . getPreviousSourceNode ( ) ; else { for ( b = b . $ ; b . lastChild ; ) b = b . lastChild ; b = new CKEDITOR . dom . node ( b ) } a . getPosition ( b ) & CKEDITOR . POSITION _FOLLOWING && ( a = b ) ; return { startNode : a , endNode : b } } , getCommonAncestor : function ( a , b ) { var c = this . startContainer , e = this . endContainer , c = c . equals ( e ) ? a && c . type == CKEDITOR . NODE _ELEMENT && this . startOffset == this . endOffset - 1 ? c . getChild ( this . startOffset ) : c : c . getCommonAncestor ( e ) ; return b && ! c . is ? c . getParent ( ) : c } , optimize : function ( ) { var a = this . startContainer , b = this . startOffset ;
a . type != CKEDITOR . NODE _ELEMENT && ( b ? b >= a . getLength ( ) && this . setStartAfter ( a ) : this . setStartBefore ( a ) ) ; a = this . endContainer ; b = this . endOffset ; a . type != CKEDITOR . NODE _ELEMENT && ( b ? b >= a . getLength ( ) && this . setEndAfter ( a ) : this . setEndBefore ( a ) ) } , optimizeBookmark : function ( ) { var a = this . startContainer , b = this . endContainer ; a . is && a . is ( "span" ) && a . data ( "cke-bookmark" ) && this . setStartAt ( a , CKEDITOR . POSITION _BEFORE _START ) ; b && b . is && b . is ( "span" ) && b . data ( "cke-bookmark" ) && this . setEndAt ( b , CKEDITOR . POSITION _AFTER _END ) } , trim : function ( a ,
b ) { var c = this . startContainer , e = this . startOffset , d = this . collapsed ; if ( ( ! a || d ) && c && c . type == CKEDITOR . NODE _TEXT ) { if ( e ) if ( e >= c . getLength ( ) ) e = c . getIndex ( ) + 1 , c = c . getParent ( ) ; else { var g = c . split ( e ) , e = c . getIndex ( ) + 1 , c = c . getParent ( ) ; this . startContainer . equals ( this . endContainer ) ? this . setEnd ( g , this . endOffset - this . startOffset ) : c . equals ( this . endContainer ) && ( this . endOffset += 1 ) } else e = c . getIndex ( ) , c = c . getParent ( ) ; this . setStart ( c , e ) ; if ( d ) { this . collapse ( ! 0 ) ; return } } c = this . endContainer ; e = this . endOffset ; b || d || ! c || c . type !=
CKEDITOR . NODE _TEXT || ( e ? ( e >= c . getLength ( ) || c . split ( e ) , e = c . getIndex ( ) + 1 ) : e = c . getIndex ( ) , c = c . getParent ( ) , this . setEnd ( c , e ) ) } , enlarge : function ( a , b ) { function c ( a ) { return a && a . type == CKEDITOR . NODE _ELEMENT && a . hasAttribute ( "contenteditable" ) ? null : a } function e ( a , b , c ) { var f = new CKEDITOR . dom . range ( c ) ; f. setStart ( a , b ) ; f . setEndAt ( c , CKEDITOR . POSITION _BEFORE _END ) ; c = new CKEDITOR . dom . walker ( f ) ; for ( c . guard = function ( a ) { return ! ( a . type == CKEDITOR . NODE _ELEMENT && a . isBlockBoundary ( ) ) } ; f = c . next ( ) ; ) { if ( f . type != CKEDITOR . NODE _TEXT ) return ! 1 ;
g= f != a ? f . getText ( ) : f . substring ( b ) ; if ( d . test ( g ) ) return ! 1 } return ! 0 } var d = new RegExp ( /[^\s\ufeff]/ ) , g , m ; switch ( a ) { case CKEDITOR . ENLARGE _INLINE : var k = 1 ; case CKEDITOR . ENLARGE _ELEMENT : if ( this . collapsed ) break ; var h = this . getCommonAncestor ( ) ; m = this . root ; var q, l , p , u , K , E = ! 1 , z ; z = this . startContainer ; var t = this . startOffset ; z . type == CKEDITOR . NODE _TEXT ? ( t && ( z= ! CKEDITOR . tools . trim ( z . substring ( 0 , t ) ) . length && z, E = ! ! z ) , z && ( ( u = z . getPrevious ( ) ) || ( p = z . getParent ( ) ) ) ) : ( t && ( u = z. getChild ( t - 1 ) || z . getLast ( ) ) , u || ( p = z ) ) ; for ( p = c ( p ) ; p ||
u ; ) { if ( p&& ! u ) { ! K && p . equals ( h ) && ( K = ! 0 ) ; if ( k? p . isBlockBoundary ( ) : ! m . contains ( p) ) break ; E && "inline" == p . getComputedStyle ( "display" ) || ( E= ! 1 , K ? q = p : this . setStartBefore ( p ) ) ; u = p . getPrevious ( ) } for ( ; u ; ) if ( z = ! 1 , u . type == CKEDITOR . NODE _COMMENT ) u = u . getPrevious ( ) ; else { if ( u . type == CKEDITOR . NODE _TEXT ) g = u . getText ( ) , d . test ( g) && ( u = null ) , z = /[\s\ufeff]$/ . test ( g ) ; else if ( ( u . $ . offsetWidth > ( CKEDITOR . env . webkit ? 1 : 0 ) || b && u . is ( "br" ) ) && ! u . data ( "cke-bookmark" ) ) if ( E && CKEDITOR . dtd . $removeEmpty [ u . getName ( ) ] ) { g = u . getText ( ) ; if ( d . test ( g ) ) u =
null ; else for ( var t = u . $ . getElementsByTagName ( "*" ) , D= 0 , C ; C = t [ D ++ ] ; ) if ( ! CKEDITOR . dtd . $removeEmpty [ C . nodeName . toLowerCase ( ) ] ) { u = null ; break } u && ( z= ! ! g . length ) } else u = null ; z&& ( E ? K ? q = p : p && this . setStartBefore ( p ) : E = ! 0 ) ; if ( u ) { z = u . getPrevious ( ) ; if ( ! p&& ! z ) { p = u ; u = null ; break } u = z} else p = null } p && ( p = c ( p . getParent ( ) ) ) } z = this . endContainer ; t = this . endOffset ; p= u = null ; K = E = ! 1 ; z . type == CKEDITOR . NODE _TEXT ? CKEDITOR . tools . trim ( z . substring ( t ) ) . length ? E= ! 0 : ( E = ! z . getLength ( ) , t == z . getLength ( ) ? ( u = z . getNext ( ) ) || ( p = z . getParent ( ) ) : e ( z ,
t , m ) && ( p= z . getParent ( ) ) ) : ( u = z. getChild ( t ) ) || ( p = z ) ; for ( ; p || u ; ) { if ( p && ! u ) { ! K && p . equals ( h ) && ( K = ! 0 ) ; if ( k? p . isBlockBoundary ( ) : ! m . contains ( p) ) break ; E && "inline" == p . getComputedStyle ( "display" ) || ( E= ! 1 , K ? l = p : p && this . setEndAfter ( p ) ) ; u = p . getNext ( ) } for ( ; u ; ) { z = ! 1 ; if ( u . type == CKEDITOR . NODE _TEXT ) g = u . getText ( ) , e ( u , 0 , m ) || ( u = null ) , z= /^[\s\ufeff]/ . test ( g ) ; else if ( u . type == CKEDITOR . NODE _ELEMENT ) { if ( ( 0 < u . $ . offsetWidth || b && u . is ( "br" ) ) && ! u . data ( "cke-bookmark" ) ) if ( E && CKEDITOR . dtd . $removeEmpty [ u . getName ( ) ] ) { g = u . getText ( ) ; if ( d . test ( g ) ) u =
null ; else for ( t = u . $ . getElementsByTagName ( "*" ) , D= 0 ; C = t [ D ++ ] ; ) if ( ! CKEDITOR . dtd . $removeEmpty [ C . nodeName . toLowerCase ( ) ] ) { u = null ; break } u && ( z= ! ! g . length ) } else u = null } else z= 1 ; z && E && ( K ? l = p : this . setEndAfter ( p ) ) ; if ( u ) { z = u . getNext ( ) ; if ( ! p&& ! z ) { p = u ; u = null ; break } u = z} else p = null } p && ( p = c ( p . getParent ( ) ) ) } q && l && ( h = q . contains ( l ) ? l : q , this . setStartBefore ( h ) , this . setEndAfter ( h ) ) ; break ; case CKEDITOR . ENLARGE _BLOCK _CONTENTS : case CKEDITOR . ENLARGE _LIST _ITEM _CONTENTS : p = new CKEDITOR . dom . range ( this . root ) ; m = this . root ; p . setStartAt ( m ,
CKEDITOR . POSITION _AFTER _START ) ; p . setEnd ( this . startContainer , this . startOffset ) ; p= new CKEDITOR . dom . walker ( p ) ; var I , T , N = CKEDITOR . dom . walker . blockBoundary ( a == CKEDITOR . ENLARGE _LIST _ITEM _CONTENTS ? { br : 1 } : null ) , x= null , H = function ( a ) { if ( a . type == CKEDITOR . NODE _ELEMENT && "false" == a . getAttribute ( "contenteditable" ) ) if ( x) { if ( x . equals ( a ) ) { x = null ; return } } else x = a ; else if ( x ) return ; var b = N ( a ) ; b || ( I = a ) ; return b } , k= function ( a ) { var b = H ( a ) ; ! b && a . is && a . is ( "br" ) && ( T= a ) ; return b } ; p . guard = H ; p = p . lastBackward ( ) ; I = I || m ; this . setStartAt ( I ,
! I . is ( "br" ) && ( ! p&& this . checkStartOfBlock ( ) || p && I . contains ( p ) ) ? CKEDITOR . POSITION _AFTER _START : CKEDITOR . POSITION _AFTER _END ) ; if ( a == CKEDITOR . ENLARGE _LIST _ITEM _CONTENTS ) { p= this . clone ( ) ; p = new CKEDITOR . dom . walker ( p ) ; var M = CKEDITOR . dom . walker . whitespaces ( ) , n = CKEDITOR . dom . walker . bookmark ( ) ; p . evaluator = function ( a ) { return ! M( a ) && ! n ( a ) } ; if ( ( p = p . previous ( ) ) && p . type == CKEDITOR . NODE _ELEMENT && p. is ( "br" ) ) break } p = this . clone ( ) ; p . collapse ( ) ; p . setEndAt ( m , CKEDITOR . POSITION _BEFORE _END ) ; p= new CKEDITOR . dom . walker ( p ) ; p . guard =
a == CKEDITOR . ENLARGE _LIST _ITEM _CONTENTS ? k: H ; I = x = T = null ; p = p . lastForward ( ) ; I = I || m ; this . setEndAt ( I , ! p&& this . checkEndOfBlock ( ) || p && I . contains ( p ) ? CKEDITOR . POSITION _BEFORE _END : CKEDITOR . POSITION _BEFORE _START ) ; T&& this . setEndAfter ( T ) } } , shrink : function ( a , b , c ) { var e = "boolean" === typeof c ? c : c && "boolean" === typeof c . shrinkOnBlockBoundary ? c . shrinkOnBlockBoundary : ! 0 , d = c && c . skipBogus ; if ( ! this . collapsed ) { a = a || CKEDITOR . SHRINK _TEXT ; var g = this . clone ( ) , m = this . startContainer , h = this . endContainer , k = this . startOffset , q = this . endOffset ,
l = c = 1 ; m && m . type == CKEDITOR . NODE _TEXT && ( k ? k >= m . getLength ( ) ? g. setStartAfter ( m ) : ( g . setStartBefore ( m ) , c = 0 ) : g . setStartBefore ( m ) ) ; h && h . type == CKEDITOR . NODE _TEXT && ( q? q >= h . getLength ( ) ? g . setEndAfter ( h ) : ( g . setEndAfter ( h ) , l = 0 ) : g . setEndBefore ( h ) ) ; var g = new CKEDITOR . dom . walker ( g ) , p = CKEDITOR . dom . walker . bookmark ( ) , u = CKEDITOR . dom . walker . bogus ( ) ; g . evaluator = function ( b ) { return b . type == ( a == CKEDITOR . SHRINK _ELEMENT ? CKEDITOR . NODE _ELEMENT : CKEDITOR . NODE _TEXT ) } ; var K ; g . guard = function ( b , c ) { if ( d && u ( b ) || p ( b ) ) return ! 0 ; if ( a == CKEDITOR . SHRINK _ELEMENT &&
b . type == CKEDITOR . NODE _TEXT || c && b . equals ( K ) || ! 1 === e && b . type == CKEDITOR . NODE _ELEMENT && b . isBlockBoundary ( ) || b . type == CKEDITOR . NODE _ELEMENT && b . hasAttribute ( "contenteditable" ) ) return ! 1 ; c || b . type != CKEDITOR . NODE _ELEMENT || ( K = b ) ; return ! 0 } ; c && ( m = g [ a == CKEDITOR . SHRINK _ELEMENT ? "lastForward" : "next" ] ( ) ) && this . setStartAt ( m , b ? CKEDITOR . POSITION _AFTER _START : CKEDITOR . POSITION _BEFORE _START ) ; l&& ( g . reset ( ) , ( g = g [ a == CKEDITOR . SHRINK _ELEMENT ? "lastBackward" : "previous" ] ( ) ) && this . setEndAt ( g , b ? CKEDITOR . POSITION _BEFORE _END : CKEDITOR . POSITION _AFTER _END ) ) ;
return ! ( ! c && ! l ) } } , insertNode : function ( a ) { this . optimizeBookmark ( ) ; this . trim ( ! 1 , ! 0 ) ; var b = this . startContainer , c = b . getChild ( this . startOffset ) ; c ? a . insertBefore ( c ) : b . append ( a ) ; a . getParent ( ) && a . getParent ( ) . equals ( this . endContainer ) && this . endOffset ++ ; this . setStartBefore ( a ) } , moveToPosition : function ( a , b ) { this . setStartAt ( a , b ) ; this . collapse ( ! 0 ) } , moveToRange : function ( a ) { this . setStart ( a . startContainer , a . startOffset ) ; this . setEnd ( a . endContainer , a . endOffset ) } , selectNodeContents : function ( a ) { this . setStart ( a , 0 ) ; this . setEnd ( a ,
b ) { var c = this . startContainer , e = this . startOffset , d = this . collapsed ; if ( ( ! a || d ) && c && c . type == CKEDITOR . NODE _TEXT ) { if ( e ) if ( e >= c . getLength ( ) ) e = c . getIndex ( ) + 1 , c = c . getParent ( ) ; else { var f = c . split ( e ) , e = c . getIndex ( ) + 1 , c = c . getParent ( ) ; this . startContainer . equals ( this . endContainer ) ? this . setEnd ( f , this . endOffset - this . startOffset ) : c . equals ( this . endContainer ) && ( this . endOffset += 1 ) } else e = c . getIndex ( ) , c = c . getParent ( ) ; this . setStart ( c , e ) ; if ( d ) { this . collapse ( ! 0 ) ; return } } c = this . endContainer ; e = this . endOffset ; b || d || ! c || c . type !=
CKEDITOR . NODE _TEXT || ( e ? ( e >= c . getLength ( ) || c . split ( e ) , e = c . getIndex ( ) + 1 ) : e = c . getIndex ( ) , c = c . getParent ( ) , this . setEnd ( c , e ) ) } , enlarge : function ( a , b ) { function c ( a ) { return a && a . type == CKEDITOR . NODE _ELEMENT && a . hasAttribute ( "contenteditable" ) ? null : a } function e ( a , b , c ) { var g = new CKEDITOR . dom . range ( c ) ; g. setStart ( a , b ) ; g . setEndAt ( c , CKEDITOR . POSITION _BEFORE _END ) ; c = new CKEDITOR . dom . walker ( g ) ; for ( c . guard = function ( a ) { return ! ( a . type == CKEDITOR . NODE _ELEMENT && a . isBlockBoundary ( ) ) } ; g = c . next ( ) ; ) { if ( g . type != CKEDITOR . NODE _TEXT ) return ! 1 ;
f= g != a ? g . getText ( ) : g . substring ( b ) ; if ( d . test ( f ) ) return ! 1 } return ! 0 } var d = new RegExp ( /[^\s\ufeff]/ ) , f , m ; switch ( a ) { case CKEDITOR . ENLARGE _INLINE : var h = 1 ; case CKEDITOR . ENLARGE _ELEMENT : if ( this . collapsed ) break ; var k = this . getCommonAncestor ( ) ; m = this . root ; var l, n , q , u , K , D = ! 1 , B ; B = this . startContainer ; var t = this . startOffset ; B . type == CKEDITOR . NODE _TEXT ? ( t && ( B= ! CKEDITOR . tools . trim ( B . substring ( 0 , t ) ) . length && B, D = ! ! B ) , B && ( ( u = B . getPrevious ( ) ) || ( q = B . getParent ( ) ) ) ) : ( t && ( u = B. getChild ( t - 1 ) || B . getLast ( ) ) , u || ( q = B ) ) ; for ( q = c ( q ) ; q ||
u ; ) { if ( q&& ! u ) { ! K && q . equals ( k ) && ( K = ! 0 ) ; if ( h? q . isBlockBoundary ( ) : ! m . contains ( q) ) break ; D && "inline" == q . getComputedStyle ( "display" ) || ( D= ! 1 , K ? l = q : this . setStartBefore ( q ) ) ; u = q . getPrevious ( ) } for ( ; u ; ) if ( B = ! 1 , u . type == CKEDITOR . NODE _COMMENT ) u = u . getPrevious ( ) ; else { if ( u . type == CKEDITOR . NODE _TEXT ) f = u . getText ( ) , d . test ( f) && ( u = null ) , B = /[\s\ufeff]$/ . test ( f ) ; else if ( ( u . $ . offsetWidth > ( CKEDITOR . env . webkit ? 1 : 0 ) || b && u . is ( "br" ) ) && ! u . data ( "cke-bookmark" ) ) if ( D && CKEDITOR . dtd . $removeEmpty [ u . getName ( ) ] ) { f = u . getText ( ) ; if ( d . test ( f ) ) u =
null ; else for ( var t = u . $ . getElementsByTagName ( "*" ) , H= 0 , A ; A = t [ H ++ ] ; ) if ( ! CKEDITOR . dtd . $removeEmpty [ A . nodeName . toLowerCase ( ) ] ) { u = null ; break } u && ( B= ! ! f . length ) } else u = null ; B&& ( D ? K ? l = q : q && this . setStartBefore ( q ) : D = ! 0 ) ; if ( u ) { B = u . getPrevious ( ) ; if ( ! q&& ! B ) { q = u ; u = null ; break } u = B} else q = null } q && ( q = c ( q . getParent ( ) ) ) } B = this . endContainer ; t = this . endOffset ; q= u = null ; K = D = ! 1 ; B . type == CKEDITOR . NODE _TEXT ? CKEDITOR . tools . trim ( B . substring ( t ) ) . length ? D= ! 0 : ( D = ! B . getLength ( ) , t == B . getLength ( ) ? ( u = B . getNext ( ) ) || ( q = B . getParent ( ) ) : e ( B ,
t , m ) && ( q= B . getParent ( ) ) ) : ( u = B. getChild ( t ) ) || ( q = B ) ; for ( ; q || u ; ) { if ( q && ! u ) { ! K && q . equals ( k ) && ( K = ! 0 ) ; if ( h? q . isBlockBoundary ( ) : ! m . contains ( q) ) break ; D && "inline" == q . getComputedStyle ( "display" ) || ( D= ! 1 , K ? n = q : q && this . setEndAfter ( q ) ) ; u = q . getNext ( ) } for ( ; u ; ) { B = ! 1 ; if ( u . type == CKEDITOR . NODE _TEXT ) f = u . getText ( ) , e ( u , 0 , m ) || ( u = null ) , B= /^[\s\ufeff]/ . test ( f ) ; else if ( u . type == CKEDITOR . NODE _ELEMENT ) { if ( ( 0 < u . $ . offsetWidth || b && u . is ( "br" ) ) && ! u . data ( "cke-bookmark" ) ) if ( D && CKEDITOR . dtd . $removeEmpty [ u . getName ( ) ] ) { f = u . getText ( ) ; if ( d . test ( f ) ) u =
null ; else for ( t = u . $ . getElementsByTagName ( "*" ) , H= 0 ; A = t [ H ++ ] ; ) if ( ! CKEDITOR . dtd . $removeEmpty [ A . nodeName . toLowerCase ( ) ] ) { u = null ; break } u && ( B= ! ! f . length ) } else u = null } else B= 1 ; B && D && ( K ? n = q : this . setEndAfter ( q ) ) ; if ( u ) { B = u . getNext ( ) ; if ( ! q&& ! B ) { q = u ; u = null ; break } u = B} else q = null } q && ( q = c ( q . getParent ( ) ) ) } l && n && ( k = l . contains ( n ) ? n : l , this . setStartBefore ( k ) , this . setEndAfter ( k ) ) ; break ; case CKEDITOR . ENLARGE _BLOCK _CONTENTS : case CKEDITOR . ENLARGE _LIST _ITEM _CONTENTS : q = new CKEDITOR . dom . range ( this . root ) ; m = this . root ; q . setStartAt ( m ,
CKEDITOR . POSITION _AFTER _START ) ; q . setEnd ( this . startContainer , this . startOffset ) ; q= new CKEDITOR . dom . walker ( q ) ; var I , N , L = CKEDITOR . dom . walker . blockBoundary ( a == CKEDITOR . ENLARGE _LIST _ITEM _CONTENTS ? { br : 1 } : null ) , r= null , E = function ( a ) { if ( a . type == CKEDITOR . NODE _ELEMENT && "false" == a . getAttribute ( "contenteditable" ) ) if ( r) { if ( r . equals ( a ) ) { r = null ; return } } else r = a ; else if ( r ) return ; var b = L ( a ) ; b || ( I = a ) ; return b } , h= function ( a ) { var b = E ( a ) ; ! b && a . is && a . is ( "br" ) && ( N= a ) ; return b } ; q . guard = E ; q = q . lastBackward ( ) ; I = I || m ; this . setStartAt ( I ,
! I . is ( "br" ) && ( ! q&& this . checkStartOfBlock ( ) || q && I . contains ( q ) ) ? CKEDITOR . POSITION _AFTER _START : CKEDITOR . POSITION _AFTER _END ) ; if ( a == CKEDITOR . ENLARGE _LIST _ITEM _CONTENTS ) { q= this . clone ( ) ; q = new CKEDITOR . dom . walker ( q ) ; var S = CKEDITOR . dom . walker . whitespaces ( ) , p = CKEDITOR . dom . walker . bookmark ( ) ; q . evaluator = function ( a ) { return ! S( a ) && ! p ( a ) } ; if ( ( q = q . previous ( ) ) && q . type == CKEDITOR . NODE _ELEMENT && q. is ( "br" ) ) break } q = this . clone ( ) ; q . collapse ( ) ; q . setEndAt ( m , CKEDITOR . POSITION _BEFORE _END ) ; q= new CKEDITOR . dom . walker ( q ) ; q . guard =
a == CKEDITOR . ENLARGE _LIST _ITEM _CONTENTS ? h: E ; I = r = N = null ; q = q . lastForward ( ) ; I = I || m ; this . setEndAt ( I , ! q&& this . checkEndOfBlock ( ) || q && I . contains ( q ) ? CKEDITOR . POSITION _BEFORE _END : CKEDITOR . POSITION _BEFORE _START ) ; N&& this . setEndAfter ( N ) } } , shrink : function ( a , b , c ) { var e = "boolean" === typeof c ? c : c && "boolean" === typeof c . shrinkOnBlockBoundary ? c . shrinkOnBlockBoundary : ! 0 , d = c && c . skipBogus ; if ( ! this . collapsed ) { a = a || CKEDITOR . SHRINK _TEXT ; var f = this . clone ( ) , m = this . startContainer , h = this . endContainer , k = this . startOffset , l = this . endOffset ,
n = c = 1 ; m && m . type == CKEDITOR . NODE _TEXT && ( k ? k >= m . getLength ( ) ? f. setStartAfter ( m ) : ( f . setStartBefore ( m ) , c = 0 ) : f . setStartBefore ( m ) ) ; h && h . type == CKEDITOR . NODE _TEXT && ( l? l >= h . getLength ( ) ? f . setEndAfter ( h ) : ( f . setEndAfter ( h ) , n = 0 ) : f . setEndBefore ( h ) ) ; var f = new CKEDITOR . dom . walker ( f ) , q = CKEDITOR . dom . walker . bookmark ( ) , u = CKEDITOR . dom . walker . bogus ( ) ; f . evaluator = function ( b ) { return b . type == ( a == CKEDITOR . SHRINK _ELEMENT ? CKEDITOR . NODE _ELEMENT : CKEDITOR . NODE _TEXT ) } ; var K ; f . guard = function ( b , c ) { if ( d && u ( b ) || q ( b ) ) return ! 0 ; if ( a == CKEDITOR . SHRINK _ELEMENT &&
b . type == CKEDITOR . NODE _TEXT || c && b . equals ( K ) || ! 1 === e && b . type == CKEDITOR . NODE _ELEMENT && b . isBlockBoundary ( ) || b . type == CKEDITOR . NODE _ELEMENT && b . hasAttribute ( "contenteditable" ) ) return ! 1 ; c || b . type != CKEDITOR . NODE _ELEMENT || ( K = b ) ; return ! 0 } ; c && ( m = f [ a == CKEDITOR . SHRINK _ELEMENT ? "lastForward" : "next" ] ( ) ) && this . setStartAt ( m , b ? CKEDITOR . POSITION _AFTER _START : CKEDITOR . POSITION _BEFORE _START ) ; n&& ( f . reset ( ) , ( f = f [ a == CKEDITOR . SHRINK _ELEMENT ? "lastBackward" : "previous" ] ( ) ) && this . setEndAt ( f , b ? CKEDITOR . POSITION _BEFORE _END : CKEDITOR . POSITION _AFTER _END ) ) ;
return ! ( ! c && ! n ) } } , insertNode : function ( a ) { this . optimizeBookmark ( ) ; this . trim ( ! 1 , ! 0 ) ; var b = this . startContainer , c = b . getChild ( this . startOffset ) ; c ? a . insertBefore ( c ) : b . append ( a ) ; a . getParent ( ) && a . getParent ( ) . equals ( this . endContainer ) && this . endOffset ++ ; this . setStartBefore ( a ) } , moveToPosition : function ( a , b ) { this . setStartAt ( a , b ) ; this . collapse ( ! 0 ) } , moveToRange : function ( a ) { this . setStart ( a . startContainer , a . startOffset ) ; this . setEnd ( a . endContainer , a . endOffset ) } , selectNodeContents : function ( a ) { this . setStart ( a , 0 ) ; this . setEnd ( a ,
a . type == CKEDITOR . NODE _TEXT ? a . getLength ( ) : a . getChildCount ( ) ) } , setStart : function ( b , c ) { b . type == CKEDITOR . NODE _ELEMENT && CKEDITOR . dtd . $empty [ b . getName ( ) ] && ( c = b . getIndex ( ) , b = b . getParent ( ) ) ; this . _setStartContainer ( b ) ; this . startOffset = c ; this . endContainer || ( this . _setEndContainer ( b ) , this . endOffset = c ) ; a ( this ) } , setEnd : function ( b , c ) { b . type == CKEDITOR . NODE _ELEMENT && CKEDITOR . dtd . $empty [ b . getName ( ) ] && ( c = b . getIndex ( ) + 1 , b = b . getParent ( ) ) ; this . _setEndContainer ( b ) ; this . endOffset = c ; this . startContainer || ( this . _setStartContainer ( b ) ,
this . startOffset = c ) ; a ( this ) } , setStartAfter : function ( a ) { this . setStart ( a . getParent ( ) , a . getIndex ( ) + 1 ) } , setStartBefore : function ( a ) { this . setStart ( a . getParent ( ) , a . getIndex ( ) ) } , setEndAfter : function ( a ) { this . setEnd ( a . getParent ( ) , a . getIndex ( ) + 1 ) } , setEndBefore : function ( a ) { this . setEnd ( a . getParent ( ) , a . getIndex ( ) ) } , setStartAt : function ( b , c ) { switch ( c ) { case CKEDITOR . POSITION _AFTER _START : this . setStart ( b , 0 ) ; break ; case CKEDITOR . POSITION _BEFORE _END : b . type == CKEDITOR . NODE _TEXT ? this . setStart ( b , b . getLength ( ) ) : this . setStart ( b ,
b . getChildCount ( ) ) ; break ; case CKEDITOR . POSITION _BEFORE _START : this . setStartBefore ( b ) ; break ; case CKEDITOR . POSITION _AFTER _END : this . setStartAfter ( b ) } a ( this ) } , setEndAt : function ( b , c ) { switch ( c ) { case CKEDITOR . POSITION _AFTER _START : this . setEnd ( b , 0 ) ; break ; case CKEDITOR . POSITION _BEFORE _END : b . type == CKEDITOR . NODE _TEXT ? this . setEnd ( b , b . getLength ( ) ) : this . setEnd ( b , b . getChildCount ( ) ) ; break ; case CKEDITOR . POSITION _BEFORE _START : this . setEndBefore ( b ) ; break ; case CKEDITOR . POSITION _AFTER _END : this . setEndAfter ( b ) } a ( this ) } , fixBlock : function ( a ,
b ) { var c = this . createBookmark ( ) , e = this . document . createElement ( b ) ; this . collapse ( a ) ; this . enlarge ( CKEDITOR . ENLARGE _BLOCK _CONTENTS ) ; this . extractContents ( ) . appendTo ( e ) ; e . trim ( ) ; this . insertNode ( e ) ; var d = e . getBogus ( ) ; d && d . remove ( ) ; e . appendBogus ( ) ; this . moveToBookmark ( c ) ; return e } , splitBlock : function ( a , b ) { var c = new CKEDITOR . dom . elementPath ( this . startContainer , this . root ) , e = new CKEDITOR . dom . elementPath ( this . endContainer , this . root ) , d = c . block , g = e . block , m = null ; if ( ! c . blockLimit . equals ( e . blockLimit ) ) return null ; "br" !=
a && ( d || ( d = this . fixBlock ( ! 0 , a ) , g = ( new CKEDITOR . dom . elementPath ( this . endContainer , this . root ) ) . block ) , g|| ( g = this . fixBlock ( ! 1 , a ) ) ) ; c = d && this . checkStartOfBlock ( ) ; e = g && this . checkEndOfBlock ( ) ; this . deleteContents ( ) ; d && d . equals ( g ) && ( e ? ( m = new CKEDITOR . dom . elementPath ( this . startContainer , this . root ) , this . moveToPosition ( g , CKEDITOR . POSITION _AFTER _END ) , g = null ) : c ? ( m = new CKEDITOR . dom . elementPath ( this . startContainer , this . root ) , this . moveToPosition ( d , CKEDITOR . POSITION _BEFORE _START ) , d = null ) : ( g = this . splitElement ( d , b ||
! 1 ) , d . is ( "ul" , "ol" ) || d . appendBogus ( ) ) ) ; return { previousBlock : d , nextBlock : g , wasStartOfBlock : c , wasEndOfBlock : e , elementPath : m } } , splitElement : function ( a , b ) { if ( ! this . collapsed ) return null ; this . setEndAt ( a , CKEDITOR . POSITION _BEFORE _END ) ; var c = this . extractContents ( ! 1 , b || ! 1 ) , e = a . clone ( ! 1 , b || ! 1 ) ; c . appendTo ( e ) ; e . insertAfter ( a ) ; this . moveToPosition ( a , CKEDITOR . POSITION _AFTER _END ) ; return e } , removeEmptyBlocksAtEnd : function ( ) { function a ( f ) { return function ( a ) { return b ( a ) || c ( a ) || a . type == CKEDITOR . NODE _ELEMENT && a . isEmptyInlineRemoveable ( ) ||
f . is ( "table" ) && a . is ( "caption" ) ? ! 1 : ! 0 } } var b = CKEDITOR . dom . walker . whitespaces ( ) , c = CKEDITOR . dom . walker . bookmark ( ! 1 ) ; return function ( b ) { for ( var c = this . createBookmark ( ) , e = this [ b ? "endPath" : "startPath" ] ( ) , d = e . block || e . blockLimit , g ; d && ! d . equals ( e . root ) && ! d . getFirst ( a ( d ) ) ; ) g = d . getParent ( ) , this [ b ? "setEndAt" : "setStartAt" ] ( d , CKEDITOR . POSITION _AFTER _END ) , d . remove ( 1 ) , d = g ; this . moveToBookmark ( c ) } } ( ) , startPath : function ( ) { return new CKEDITOR . dom . elementPath ( this . startContainer , this . root ) } , endPath : function ( ) { return new CKEDITOR . dom . elementPath ( this . endContainer ,
this . root ) } , checkBoundaryOfElement : function ( a , b ) { var e = b == CKEDITOR . START , d = this . clone ( ) ; d . collapse ( e ) ; d [ e ? "setStartAt" : "setEndAt" ] ( a , e ? CKEDITOR . POSITION _AFTER _START : CKEDITOR . POSITION _BEFORE _END ) ; d = new CKEDITOR . dom . walker ( d ) ; d . evaluator = c ( e ) ; return d [ e ? "checkBackward" : "checkForward" ] ( ) } , checkStartOfBlock : function ( a ) { var c = this . startContainer , e = this . startOffset ; CKEDITOR . env . ie && e && c . type == CKEDITOR . NODE _TEXT && ( c = CKEDITOR . tools . ltrim ( c . substring ( 0 , e ) ) , k . test ( c ) && this . trim ( 0 , 1 ) ) ; a || this . trim ( ) ; a = new CKEDITOR . dom . elementPath ( this . startContainer ,
this . root ) ; c = this . clone ( ) ; c . collapse ( ! 0 ) ; c . setStartAt ( a . block || a . blockLimit , CKEDITOR . POSITION _AFTER _START ) ; a = new CKEDITOR . dom . walker ( c ) ; a . evaluator = b ( ) ; return a . checkBackward ( ) } , checkEndOfBlock : function ( a ) { var c = this . endContainer , e = this . endOffset ; CKEDITOR . env . ie && c . type == CKEDITOR . NODE _TEXT && ( c = CKEDITOR . tools . rtrim ( c . substring ( e ) ) , k . test ( c ) && this . trim ( 1 , 0 ) ) ; a || this . trim ( ) ; a = new CKEDITOR . dom . elementPath ( this . endContainer , this . root ) ; c = this . clone ( ) ; c . collapse ( ! 1 ) ; c . setEndAt ( a . block || a . blockLimit , CKEDITOR . POSITION _BEFORE _END ) ;
b ) { var c = this . createBookmark ( ) , e = this . document . createElement ( b ) ; this . collapse ( a ) ; this . enlarge ( CKEDITOR . ENLARGE _BLOCK _CONTENTS ) ; this . extractContents ( ) . appendTo ( e ) ; e . trim ( ) ; this . insertNode ( e ) ; var d = e . getBogus ( ) ; d && d . remove ( ) ; e . appendBogus ( ) ; this . moveToBookmark ( c ) ; return e } , splitBlock : function ( a , b ) { var c = new CKEDITOR . dom . elementPath ( this . startContainer , this . root ) , e = new CKEDITOR . dom . elementPath ( this . endContainer , this . root ) , d = c . block , f = e . block , m = null ; if ( ! c . blockLimit . equals ( e . blockLimit ) ) return null ; "br" !=
a && ( d || ( d = this . fixBlock ( ! 0 , a ) , f = ( new CKEDITOR . dom . elementPath ( this . endContainer , this . root ) ) . block ) , f|| ( f = this . fixBlock ( ! 1 , a ) ) ) ; c = d && this . checkStartOfBlock ( ) ; e = f && this . checkEndOfBlock ( ) ; this . deleteContents ( ) ; d && d . equals ( f ) && ( e ? ( m = new CKEDITOR . dom . elementPath ( this . startContainer , this . root ) , this . moveToPosition ( f , CKEDITOR . POSITION _AFTER _END ) , f = null ) : c ? ( m = new CKEDITOR . dom . elementPath ( this . startContainer , this . root ) , this . moveToPosition ( d , CKEDITOR . POSITION _BEFORE _START ) , d = null ) : ( f = this . splitElement ( d , b ||
! 1 ) , d . is ( "ul" , "ol" ) || d . appendBogus ( ) ) ) ; return { previousBlock : d , nextBlock : f , wasStartOfBlock : c , wasEndOfBlock : e , elementPath : m } } , splitElement : function ( a , b ) { if ( ! this . collapsed ) return null ; this . setEndAt ( a , CKEDITOR . POSITION _BEFORE _END ) ; var c = this . extractContents ( ! 1 , b || ! 1 ) , e = a . clone ( ! 1 , b || ! 1 ) ; c . appendTo ( e ) ; e . insertAfter ( a ) ; this . moveToPosition ( a , CKEDITOR . POSITION _AFTER _END ) ; return e } , removeEmptyBlocksAtEnd : function ( ) { function a ( e ) { return function ( a ) { return b ( a ) || c ( a ) || a . type == CKEDITOR . NODE _ELEMENT && a . isEmptyInlineRemoveable ( ) ||
e . is ( "table" ) && a . is ( "caption" ) ? ! 1 : ! 0 } } var b = CKEDITOR . dom . walker . whitespaces ( ) , c = CKEDITOR . dom . walker . bookmark ( ! 1 ) ; return function ( b ) { for ( var c = this . createBookmark ( ) , e = this [ b ? "endPath" : "startPath" ] ( ) , d = e . block || e . blockLimit , f ; d && ! d . equals ( e . root ) && ! d . getFirst ( a ( d ) ) ; ) f = d . getParent ( ) , this [ b ? "setEndAt" : "setStartAt" ] ( d , CKEDITOR . POSITION _AFTER _END ) , d . remove ( 1 ) , d = f ; this . moveToBookmark ( c ) } } ( ) , startPath : function ( ) { return new CKEDITOR . dom . elementPath ( this . startContainer , this . root ) } , endPath : function ( ) { return new CKEDITOR . dom . elementPath ( this . endContainer ,
this . root ) } , checkBoundaryOfElement : function ( a , b ) { var e = b == CKEDITOR . START , d = this . clone ( ) ; d . collapse ( e ) ; d [ e ? "setStartAt" : "setEndAt" ] ( a , e ? CKEDITOR . POSITION _AFTER _START : CKEDITOR . POSITION _BEFORE _END ) ; d = new CKEDITOR . dom . walker ( d ) ; d . evaluator = c ( e ) ; return d [ e ? "checkBackward" : "checkForward" ] ( ) } , checkStartOfBlock : function ( a ) { var c = this . startContainer , e = this . startOffset ; CKEDITOR . env . ie && e && c . type == CKEDITOR . NODE _TEXT && ( c = CKEDITOR . tools . ltrim ( c . substring ( 0 , e ) ) , h . test ( c ) && this . trim ( 0 , 1 ) ) ; a || this . trim ( ) ; a = new CKEDITOR . dom . elementPath ( this . startContainer ,
this . root ) ; c = this . clone ( ) ; c . collapse ( ! 0 ) ; c . setStartAt ( a . block || a . blockLimit , CKEDITOR . POSITION _AFTER _START ) ; a = new CKEDITOR . dom . walker ( c ) ; a . evaluator = b ( ) ; return a . checkBackward ( ) } , checkEndOfBlock : function ( a ) { var c = this . endContainer , e = this . endOffset ; CKEDITOR . env . ie && c . type == CKEDITOR . NODE _TEXT && ( c = CKEDITOR . tools . rtrim ( c . substring ( e ) ) , h . test ( c ) && this . trim ( 1 , 0 ) ) ; a || this . trim ( ) ; a = new CKEDITOR . dom . elementPath ( this . endContainer , this . root ) ; c = this . clone ( ) ; c . collapse ( ! 1 ) ; c . setEndAt ( a . block || a . blockLimit , CKEDITOR . POSITION _BEFORE _END ) ;
a = new CKEDITOR . dom . walker ( c ) ; a . evaluator = b ( ) ; return a . checkForward ( ) } , getPreviousNode : function ( a , b , c ) { var e = this . clone ( ) ; e . collapse ( 1 ) ; e . setStartAt ( c || this . root , CKEDITOR . POSITION _AFTER _START ) ; c = new CKEDITOR . dom . walker ( e ) ; c . evaluator = a ; c . guard = b ; return c . previous ( ) } , getNextNode : function ( a , b , c ) { var e = this . clone ( ) ; e . collapse ( ) ; e . setEndAt ( c || this . root , CKEDITOR . POSITION _BEFORE _END ) ; c = new CKEDITOR . dom . walker ( e ) ; c . evaluator = a ; c . guard = b ; return c . next ( ) } , checkReadOnly : function ( ) { function a ( b , c ) { for ( ; b ; ) { if ( b . type ==
CKEDITOR . NODE _ELEMENT ) { if ( "false" == b . getAttribute ( "contentEditable" ) && ! b . data ( "cke-editable" ) ) return 0 ; if ( b . is ( "html" ) || "true" == b . getAttribute ( "contentEditable" ) && ( b . contains ( c ) || b . equals ( c ) ) ) break } b = b . getParent ( ) } return 1 } return function ( ) { var b = this . startContainer , c = this . endContainer ; return ! ( a ( b , c ) && a ( c , b ) ) } } ( ) , moveToElementEditablePosition : function ( a , b ) { if ( a . type == CKEDITOR . NODE _ELEMENT && ! a . isEditable ( ! 1 ) ) return this . moveToPosition ( a , b ? CKEDITOR . POSITION _AFTER _END : CKEDITOR . POSITION _BEFORE _START ) ,
! 0 ; for ( var c = 0 ; a ; ) { if ( a . type == CKEDITOR . NODE _TEXT ) { b && this . endContainer && this . checkEndOfBlock ( ) && k . test ( a . getText ( ) ) ? this . moveToPosition ( a , CKEDITOR . POSITION _BEFORE _START ) : this . moveToPosition ( a , b ? CKEDITOR . POSITION _AFTER _END : CKEDITOR . POSITION _BEFORE _START ) ; c = 1 ; break } if ( a . type == CKEDITOR . NODE _ELEMENT ) if ( a . isEditable ( ) ) this . moveToPosition ( a , b ? CKEDITOR . POSITION _BEFORE _END : CKEDITOR . POSITION _AFTER _START ) , c = 1 ; else if ( b && a . is ( "br" ) && this . endContainer && this . checkEndOfBlock ( ) ) this . moveToPosition ( a , CKEDITOR . POSITION _BEFORE _START ) ;
else if ( "false" == a . getAttribute ( "contenteditable" ) && a . is ( CKEDITOR . dtd . $block ) ) return this . setStartBefore ( a ) , this . setEndAfter ( a ) , ! 0 ; var e = a , d = c , g = void 0 ; e . type == CKEDITOR . NODE _ELEMENT && e . isEditable ( ! 1 ) && ( g = e [ b ? "getLast" : "getFirst" ] ( q) ) ; d || g || ( g = e [ b ? "getPrevious" : "getNext" ] ( q) ) ; a = g } return ! ! c } , moveToClosestEditablePosition : function ( a , b ) { var c , e = 0 , d , g , m = [ CKEDITOR . POSITION _AFTER _END , CKEDITOR . POSITION _BEFORE _START ] ; a ? ( c = new CKEDITOR . dom . range ( this . root ) , c . moveToPosition ( a , m [ b ? 0 : 1 ] ) ) : c = this . clone ( ) ; if ( a &&
! a . is ( CKEDITOR . dtd . $block ) ) e = 1 ; else if ( d = c [ b ? "getNextEditableNode" : "getPreviousEditableNode" ] ( ) ) e = 1 , ( g = d . type == CKEDITOR . NODE _ELEMENT ) && d . is ( CKEDITOR . dtd . $block ) && "false" == d . getAttribute ( "contenteditable" ) ? ( c . setStartAt ( d , CKEDITOR . POSITION _BEFORE _START ) , c . setEndAt ( d , CKEDITOR . POSITION _AFTER _END ) ) : ! CKEDITOR . env . needsBrFiller && g && d . is ( CKEDITOR . dom . walker . validEmptyBlockContainers ) ? ( c . setEnd ( d , 0 ) , c . collapse ( ) ) : c . moveToPosition ( d , m [ b ? 1 : 0 ] ) ; e && this . moveToRange ( c ) ; return ! ! e } , moveToElementEditStart : function ( a ) { return this . moveToElementEditablePosition ( a ) } ,
! 0 ; for ( var c = 0 ; a ; ) { if ( a . type == CKEDITOR . NODE _TEXT ) { b && this . endContainer && this . checkEndOfBlock ( ) && h . test ( a . getText ( ) ) ? this . moveToPosition ( a , CKEDITOR . POSITION _BEFORE _START ) : this . moveToPosition ( a , b ? CKEDITOR . POSITION _AFTER _END : CKEDITOR . POSITION _BEFORE _START ) ; c = 1 ; break } if ( a . type == CKEDITOR . NODE _ELEMENT ) if ( a . isEditable ( ) ) this . moveToPosition ( a , b ? CKEDITOR . POSITION _BEFORE _END : CKEDITOR . POSITION _AFTER _START ) , c = 1 ; else if ( b && a . is ( "br" ) && this . endContainer && this . checkEndOfBlock ( ) ) this . moveToPosition ( a , CKEDITOR . POSITION _BEFORE _START ) ;
else if ( "false" == a . getAttribute ( "contenteditable" ) && a . is ( CKEDITOR . dtd . $block ) ) return this . setStartBefore ( a ) , this . setEndAfter ( a ) , ! 0 ; var e = a , d = c , f = void 0 ; e . type == CKEDITOR . NODE _ELEMENT && e . isEditable ( ! 1 ) && ( f = e [ b ? "getLast" : "getFirst" ] ( l) ) ; d || f || ( f = e [ b ? "getPrevious" : "getNext" ] ( l) ) ; a = f } return ! ! c } , moveToClosestEditablePosition : function ( a , b ) { var c , e = 0 , d , f , m = [ CKEDITOR . POSITION _AFTER _END , CKEDITOR . POSITION _BEFORE _START ] ; a ? ( c = new CKEDITOR . dom . range ( this . root ) , c . moveToPosition ( a , m [ b ? 0 : 1 ] ) ) : c = this . clone ( ) ; if ( a &&
! a . is ( CKEDITOR . dtd . $block ) ) e = 1 ; else if ( d = c [ b ? "getNextEditableNode" : "getPreviousEditableNode" ] ( ) ) e = 1 , ( f = d . type == CKEDITOR . NODE _ELEMENT ) && d . is ( CKEDITOR . dtd . $block ) && "false" == d . getAttribute ( "contenteditable" ) ? ( c . setStartAt ( d , CKEDITOR . POSITION _BEFORE _START ) , c . setEndAt ( d , CKEDITOR . POSITION _AFTER _END ) ) : ! CKEDITOR . env . needsBrFiller && f && d . is ( CKEDITOR . dom . walker . validEmptyBlockContainers ) ? ( c . setEnd ( d , 0 ) , c . collapse ( ) ) : c . moveToPosition ( d , m [ b ? 1 : 0 ] ) ; e && this . moveToRange ( c ) ; return ! ! e } , moveToElementEditStart : function ( a ) { return this . moveToElementEditablePosition ( a ) } ,
moveToElementEditEnd : function ( a ) { return this . moveToElementEditablePosition ( a , ! 0 ) } , getEnclosedNode : function ( ) { var a = this . clone ( ) ; a . optimize ( ) ; if ( a . startContainer . type != CKEDITOR . NODE _ELEMENT || a . endContainer . type != CKEDITOR . NODE _ELEMENT ) return null ; var a = new CKEDITOR . dom . walker ( a ) , b = CKEDITOR . dom . walker . bookmark ( ! 1 , ! 0 ) , c = CKEDITOR . dom . walker . whitespaces ( ! 0 ) ; a . evaluator = function ( a ) { return c ( a ) && b ( a ) } ; var e = a . next ( ) ; a . reset ( ) ; return e && e . equals ( a . previous ( ) ) ? e : null } , getTouchedStartNode : function ( ) { var a = this . startContainer ;
return this . collapsed || a . type != CKEDITOR . NODE _ELEMENT ? a : a . getChild ( this . startOffset ) || a } , getTouchedEndNode : function ( ) { var a = this . endContainer ; return this . collapsed || a . type != CKEDITOR . NODE _ELEMENT ? a : a . getChild ( this . endOffset - 1 ) || a } , getNextEditableNode : g( ) , getPreviousEditableNode : g ( 1 ) , _getTableElement : function ( a ) { a = a || { td : 1 , th : 1 , tr : 1 , tbody : 1 , thead : 1 , tfoot : 1 , table : 1 } ; var b = this . getTouchedStartNode ( ) , c = this . getTouchedEndNode ( ) , e = b . getAscendant ( "table" , ! 0 ) , c = c . getAscendant ( "table" , ! 0 ) ; return e && ! this . root . contains ( e ) ?
return this . collapsed || a . type != CKEDITOR . NODE _ELEMENT ? a : a . getChild ( this . startOffset ) || a } , getTouchedEndNode : function ( ) { var a = this . endContainer ; return this . collapsed || a . type != CKEDITOR . NODE _ELEMENT ? a : a . getChild ( this . endOffset - 1 ) || a } , getNextEditableNode : f( ) , getPreviousEditableNode : f ( 1 ) , _getTableElement : function ( a ) { a = a || { td : 1 , th : 1 , tr : 1 , tbody : 1 , thead : 1 , tfoot : 1 , table : 1 } ; var b = this . getTouchedStartNode ( ) , c = this . getTouchedEndNode ( ) , e = b . getAscendant ( "table" , ! 0 ) , c = c . getAscendant ( "table" , ! 0 ) ; return e && ! this . root . contains ( e ) ?
null : this . getEnclosedNode ( ) ? this . getEnclosedNode ( ) . getAscendant ( a , ! 0 ) : e && c && ( e . equals ( c ) || e . contains ( c ) || c . contains ( e ) ) ? b . getAscendant ( a , ! 0 ) : null } , scrollIntoView : function ( ) { var a = new CKEDITOR . dom . element . createFromHtml ( "\x3cspan\x3e\x26nbsp;\x3c/span\x3e" , this . document ) , b , c , e , d = this . clone ( ) ; d . optimize ( ) ; ( e = d . startContainer . type == CKEDITOR . NODE _TEXT ) ? ( c = d . startContainer . getText ( ) , b = d . startContainer . split ( d . startOffset ) , a . insertAfter ( d . startContainer ) ) : d . insertNode ( a ) ; a . scrollIntoView ( ) ; e && ( d . startContainer . setText ( c ) ,
b . remove ( ) ) ; a . remove ( ) } , getClientRects : function ( ) { function a ( b , c ) { var e = CKEDITOR . tools . array . map ( b , function ( a ) { return a } ) , d = new CKEDITOR . dom . range ( c . root ) , f, g , h ; c . startContainer instanceof CKEDITOR . dom . element && ( g = 0 === c . startOffset && c . startContainer . hasAttribute ( "data-widget" ) ) ; c . endContainer instanceof CKEDITOR . dom . element && ( h = ( h = c . endOffset === ( c . endContainer . getChildCount ? c . endContainer . getChildCount ( ) : c . endContainer . length ) ) && c . endContainer . hasAttribute ( "data-widget" ) ) ; g && d . setStart ( c . startContainer . getParent ( ) ,
c . startContainer . getIndex ( ) ) ; h && d . setEnd ( c . endContainer . getParent ( ) , c . endContainer . getIndex ( ) + 1 ) ; if ( g || h ) c = d ; d = c . cloneContents ( ) . find ( "[data-cke-widget-id]" ) . toArray ( ) ; if ( d = CKEDITOR . tools . array . map ( d , function ( a ) { var b = c . root . editor ; a = a . getAttribute ( "data-cke-widget-id" ) ; return b . widgets . instances [ a ] . element } ) ) return d = CKEDITOR . tools . array . map ( d , function ( a ) { var b ; b = a . getParent ( ) . hasClass ( "cke_widget_wrapper" ) ? a . getParent ( ) : a ; f = this . root . getDocument ( ) . $ . createRange ( ) ; f . setStart ( b . getParent ( ) . $ , b . getIndex ( ) ) ;
f . setEnd ( b . getParent ( ) . $ , b . getIndex ( ) + 1 ) ; b = f . getClientRects ( ) ; b . widgetRect = a . getClientRect ( ) ; return b } , c ) , CKEDITOR . tools . array . forEach ( d , function ( a ) { function b ( d ) { CKEDITOR . tools . array . forEach ( e , function ( b , f) { var g = CKEDITOR . tools . objectCompare ( a [ d ] , b ) ; g|| ( g = CKEDITOR . tools . objectCompare ( a . widgetRect , b ) ) ; g && ( Array . prototype . splice . call ( e , f , a . length - d , a . widgetRect ) , c = ! 0 ) } ) ; c || ( d < e . length - 1 ? b ( d + 1 ) : e . push ( a . widgetRect ) ) } var c ; b ( 0 ) } ) , e } function b ( a , c , d ) { var f ; c . collapsed ? d . startContainer instanceof CKEDITOR . dom . element ?
( a = d . checkStartOfBlock ( ) , f = new CKEDITOR . dom . text ( " " ) , a ? d . startContainer . append ( f , ! 0 ) : 0 === d . startOffset ? f . insertBefore ( d . startContainer . getFirst ( ) ) : ( d = d . startContainer . getChildren ( ) . getItem ( d . startOffset - 1 ) , f . insertAfter ( d ) ) , c . setStart ( f . $ , 0 ) , c . setEnd ( f . $ , 0 ) , a = c . getClientRects ( ) , f . remove ( ) ) : d . startContainer instanceof CKEDITOR . dom . text && ( "" === d . startContainer . getText ( ) ? ( d . startContainer . setText ( " " ) , a = c . getClientRects ( ) , d . startContainer . setText ( "" ) ) : a = [ e ( d . createBookmark ( ) ) ] ) : a = [ e ( d . createBookmark ( ) ) ] ;
b . remove ( ) ) ; a . remove ( ) } , getClientRects : function ( ) { function a ( b , c ) { var e = CKEDITOR . tools . array . map ( b , function ( a ) { return a } ) , d = new CKEDITOR . dom . range ( c . root ) , g, f , h ; c . startContainer instanceof CKEDITOR . dom . element && ( f = 0 === c . startOffset && c . startContainer . hasAttribute ( "data-widget" ) ) ; c . endContainer instanceof CKEDITOR . dom . element && ( h = ( h = c . endOffset === ( c . endContainer . getChildCount ? c . endContainer . getChildCount ( ) : c . endContainer . length ) ) && c . endContainer . hasAttribute ( "data-widget" ) ) ; f && d . setStart ( c . startContainer . getParent ( ) ,
c . startContainer . getIndex ( ) ) ; h && d . setEnd ( c . endContainer . getParent ( ) , c . endContainer . getIndex ( ) + 1 ) ; if ( f || h ) c = d ; d = c . cloneContents ( ) . find ( "[data-cke-widget-id]" ) . toArray ( ) ; if ( d = CKEDITOR . tools . array . map ( d , function ( a ) { var b = c . root . editor ; a = a . getAttribute ( "data-cke-widget-id" ) ; return b . widgets . instances [ a ] . element } ) ) return d = CKEDITOR . tools . array . map ( d , function ( a ) { var b ; b = a . getParent ( ) . hasClass ( "cke_widget_wrapper" ) ? a . getParent ( ) : a ; g = this . root . getDocument ( ) . $ . createRange ( ) ; g . setStart ( b . getParent ( ) . $ , b . getIndex ( ) ) ;
g . setEnd ( b . getParent ( ) . $ , b . getIndex ( ) + 1 ) ; b = g . getClientRects ( ) ; b . widgetRect = a . getClientRect ( ) ; return b } , c ) , CKEDITOR . tools . array . forEach ( d , function ( a ) { function b ( d ) { CKEDITOR . tools . array . forEach ( e , function ( b , g) { var f = CKEDITOR . tools . objectCompare ( a [ d ] , b ) ; f|| ( f = CKEDITOR . tools . objectCompare ( a . widgetRect , b ) ) ; f && ( Array . prototype . splice . call ( e , g , a . length - d , a . widgetRect ) , c = ! 0 ) } ) ; c || ( d < e . length - 1 ? b ( d + 1 ) : e . push ( a . widgetRect ) ) } var c ; b ( 0 ) } ) , e } function b ( a , c , d ) { var g ; c . collapsed ? d . startContainer instanceof CKEDITOR . dom . element ?
( a = d . checkStartOfBlock ( ) , g = new CKEDITOR . dom . text ( " " ) , a ? d . startContainer . append ( g , ! 0 ) : 0 === d . startOffset ? g . insertBefore ( d . startContainer . getFirst ( ) ) : ( d = d . startContainer . getChildren ( ) . getItem ( d . startOffset - 1 ) , g . insertAfter ( d ) ) , c . setStart ( g . $ , 0 ) , c . setEnd ( g . $ , 0 ) , a = c . getClientRects ( ) , g . remove ( ) ) : d . startContainer instanceof CKEDITOR . dom . text && ( "" === d . startContainer . getText ( ) ? ( d . startContainer . setText ( " " ) , a = c . getClientRects ( ) , d . startContainer . setText ( "" ) ) : a = [ e ( d . createBookmark ( ) ) ] ) : a = [ e ( d . createBookmark ( ) ) ] ;
return a } function c ( a , b , e ) { a = CKEDITOR . tools . extend ( { } , a ) ; b && ( a = CKEDITOR . tools . getAbsoluteRectPosition ( e . document . getWindow ( ) , a ) ) ; ! a . width && ( a . width = a . right - a . left ) ; ! a . height && ( a . height = a . bottom - a . top ) ; return a } function e ( a ) { var b = a . startNode ; a = a . endNode ; var c ; b . setText ( " " ) ; b . removeStyle ( "display" ) ; a ? ( a . setText ( " " ) , a . removeStyle ( "display" ) , c = [ b . getClientRect ( ) , a . getClientRect ( ) ] , a . remove ( ) ) : c = [ b . getClientRect ( ) , b . getClientRect ( ) ] ; b . remove ( ) ; return { right : Math . max ( c [ 0 ] . right , c [ 1 ] . right ) , bottom : Math . max ( c [ 0 ] . bottom ,
c [ 1 ] . bottom ) , left : Math . min ( c [ 0 ] . left , c [ 1 ] . left ) , top : Math . min ( c [ 0 ] . top , c [ 1 ] . top ) , width : Math . abs ( c [ 0 ] . left - c [ 1 ] . left ) , height : Math . max ( c [ 0 ] . bottom , c [ 1 ] . bottom ) - Math . min ( c [ 0 ] . top , c [ 1 ] . top ) } } return void 0 !== document . getSelection ? function ( e ) { var d = this . root . getDocument ( ) . $ . createRange ( ) , g ; d . setStart ( this . startContainer . $ , this . startOffset ) ; d . setEnd ( this . endContainer . $ , this . endOffset ) ; g= d . getClientRects ( ) ; g = a ( g , this ) ; g . length || ( g = b ( g , d , this ) ) ; return CKEDITOR . tools . array . map ( g , function ( a ) { return c ( a , e , this ) } ,
this ) } : function ( a ) { return [ c ( e ( this . createBookmark ( ) ) , a , this ) ] } } ( ) , _setStartContainer : function ( a ) { this . startContainer = a } , _setEndContainer : function ( a ) { this . endContainer = a } , _find : function ( a , b ) { var c = this . getCommonAncestor ( ) , e = this . getBoundaryNodes ( ) , d = [ ] , g , m , h , k ; if ( c && c . find ) for ( m = c . find ( a ) , g= 0 ; g < m . count ( ) ; g ++ ) if ( c = m . getItem ( g ) , b || ! c . isReadOnly ( ) ) h = c . getPosition ( e . startNode ) & CKEDITOR . POSITION _FOLLOWING || e . startNode . equals ( c ) , k = c . getPosition ( e . endNode ) & CKEDITOR . POSITION _PRECEDING + CKEDITOR . POSITION _IS _CONTAINED ||
e . endNode . equals ( c ) , h && k && d . push ( c ) ; return d } } ; CKEDITOR . dom . range . mergeRanges = function ( a ) { return CKEDITOR . tools . array . reduce ( a , function ( a , b ) { var c = a [ a . length - 1 ] , e = ! 1 ; b = b . clone ( ) ; b . enlarge ( CKEDITOR . ENLARGE _ELEMENT ) ; if ( c ) { var d = new CKEDITOR . dom . range ( b . root ) , e = new CKEDITOR . dom . walker ( d ) , f = CKEDITOR . dom . walker . whitespaces ( ) ; d . setStart ( c . endContainer , c . endOffset ) ; d . setEnd ( b . startContainer , b . startOffset ) ; for ( d = e . next ( ) ; f ( d ) || b . endContainer . equals ( d ) ; ) d = e . next ( ) ; e = ! d } e ? c . setEnd ( b . endContainer , b . endOffset ) :
c [ 1 ] . bottom ) , left : Math . min ( c [ 0 ] . left , c [ 1 ] . left ) , top : Math . min ( c [ 0 ] . top , c [ 1 ] . top ) , width : Math . abs ( c [ 0 ] . left - c [ 1 ] . left ) , height : Math . max ( c [ 0 ] . bottom , c [ 1 ] . bottom ) - Math . min ( c [ 0 ] . top , c [ 1 ] . top ) } } return void 0 !== document . getSelection ? function ( e ) { var d = this . root . getDocument ( ) . $ . createRange ( ) , f ; d . setStart ( this . startContainer . $ , this . startOffset ) ; d . setEnd ( this . endContainer . $ , this . endOffset ) ; f= d . getClientRects ( ) ; f = a ( f , this ) ; f . length || ( f = b ( f , d , this ) ) ; return CKEDITOR . tools . array . map ( f , function ( a ) { return c ( a , e , this ) } ,
this ) } : function ( a ) { return [ c ( e ( this . createBookmark ( ) ) , a , this ) ] } } ( ) , _setStartContainer : function ( a ) { this . startContainer = a } , _setEndContainer : function ( a ) { this . endContainer = a } , _find : function ( a , b ) { var c = this . getCommonAncestor ( ) , e = this . getBoundaryNodes ( ) , d = [ ] , f , m , h , k ; if ( c && c . find ) for ( m = c . find ( a ) , f= 0 ; f < m . count ( ) ; f ++ ) if ( c = m . getItem ( f ) , b || ! c . isReadOnly ( ) ) h = c . getPosition ( e . startNode ) & CKEDITOR . POSITION _FOLLOWING || e . startNode . equals ( c ) , k = c . getPosition ( e . endNode ) & CKEDITOR . POSITION _PRECEDING + CKEDITOR . POSITION _IS _CONTAINED ||
e . endNode . equals ( c ) , h && k && d . push ( c ) ; return d } } ; CKEDITOR . dom . range . mergeRanges = function ( a ) { return CKEDITOR . tools . array . reduce ( a , function ( a , b ) { var c = a [ a . length - 1 ] , e = ! 1 ; b = b . clone ( ) ; b . enlarge ( CKEDITOR . ENLARGE _ELEMENT ) ; if ( c ) { var d = new CKEDITOR . dom . range ( b . root ) , e = new CKEDITOR . dom . walker ( d ) , g = CKEDITOR . dom . walker . whitespaces ( ) ; d . setStart ( c . endContainer , c . endOffset ) ; d . setEnd ( b . startContainer , b . startOffset ) ; for ( d = e . next ( ) ; g ( d ) || b . endContainer . equals ( d ) ; ) d = e . next ( ) ; e = ! d } e ? c . setEnd ( b . endContainer , b . endOffset ) :
a . push ( b ) ; return a } , [ ] ) } } ) ( ) ; CKEDITOR . POSITION _AFTER _START = 1 ; CKEDITOR . POSITION _BEFORE _END = 2 ; CKEDITOR . POSITION _BEFORE _START = 3 ; CKEDITOR . POSITION _AFTER _END = 4 ; CKEDITOR . ENLARGE _ELEMENT = 1 ; CKEDITOR . ENLARGE _BLOCK _CONTENTS = 2 ; CKEDITOR . ENLARGE _LIST _ITEM _CONTENTS = 3 ; CKEDITOR . ENLARGE _INLINE = 4 ; CKEDITOR . START = 1 ; CKEDITOR . END = 2 ; CKEDITOR . SHRINK _ELEMENT = 1 ; CKEDITOR . SHRINK _TEXT = 2 ; "use strict" ;
( function ( ) { function a ( a ) { 1 > arguments . length || ( this . range = a , this . forceBrBreak = 0 , this . enlargeBr = 1 , this . enforceRealBlocks = 0 , this . _ || ( this . _ = { } ) ) } function d ( a ) { var b = [ ] ; a . forEach ( function ( a ) { if ( "true" == a . getAttribute ( "contenteditable" ) ) return b . push ( a ) , ! 1 } , CKEDITOR . NODE _ELEMENT , ! 0 ) ; return b } function b ( a , c , e , g) { a : { null == g && ( g = d ( e ) ) ; for ( var h ; h = g . shift ( ) ; ) if ( h . getDtd ( ) . p ) { g= { element : h , remaining : g } ; break a } g = null } if ( ! g ) return 0 ; if ( ( h = CKEDITOR . filter . instances [ g . element . data ( "cke-filter" ) ] ) && ! h . check ( c ) ) return b ( a ,
c , e , g . remaining ) ; c = new CKEDITOR . dom . range ( g . element ) ; c . selectNodeContents ( g . element ) ; c = c . createIterator ( ) ; c . enlargeBr = a . enlargeBr ; c . enforceRealBlocks = a . enforceRealBlocks ; c . activeFilter = c . filter = h ; a . _ . nestedEditable = { element : g . element , container : e , remaining : g . remaining , iterator : c } ; return 1 } function c ( a , b , c ) { if ( ! b ) return ! 1 ; a = a . clone ( ) ; a . collapse ( ! c ) ; return a . checkBoundaryOfElement ( b , c ? CKEDITOR . START : CKEDITOR . END ) } var g = /^[\r\n\t ]+$/ , e = CKEDITOR . dom . walker . bookmark ( ! 1 , ! 0 ) , h = CKEDITOR . dom . walker . whitespaces ( ! 0 ) ,
k = function ( a ) { return e ( a ) && h( a ) } , l = { dd : 1 , dt : 1 , li : 1 } ; a . prototype = { getNextParagraph : function ( a ) { var d , h, B , y , F ; a = a || "p" ; if ( this . _ . nestedEditable ) { if ( d = this . _ . nestedEditable . iterator . getNextParagraph ( a ) ) return this . activeFilter = this . _ . nestedEditable . iterator . activeFilter , d ; this . activeFilter = this . filter ; if ( b ( this , a , this . _ . nestedEditable . container , this . _ . nestedEditable . remaining ) ) return this . activeFilter = this . _ . nestedEditable . iterator . activeFilter , this . _ . nestedEditable . iterator . getNextParagraph ( a ) ; this . _ . nestedEditable =
null } if ( ! this . range . root . getDtd ( ) [ a ] ) return null ; if ( ! this . _ . started ) { var r = this . range . clone ( ) ; h= r . startPath ( ) ; var m = r . endPath ( ) , L = ! r . collapsed && c ( r , h . block ) , v = ! r . collapsed && c ( r , m . block , 1 ) ; r . shrink ( CKEDITOR . SHRINK _ELEMENT , ! 0 ) ; L&& r . setStartAt ( h . block , CKEDITOR . POSITION _BEFORE _END ) ; v&& r . setEndAt ( m . block , CKEDITOR . POSITION _AFTER _START ) ; h= r . endContainer . hasAscendant ( "pre" , ! 0 ) || r . startContainer . hasAscendant ( "pre" , ! 0 ) ; r . enlarge ( this . forceBrBreak && ! h || ! this . enlargeBr ? CKEDITOR . ENLARGE _LIST _ITEM _CONTENTS : CKEDITOR . ENLARGE _BLOCK _CONTENTS ) ;
r. collapsed || ( h = new CKEDITOR . dom . walker ( r . clone ( ) ) , m = CKEDITOR . dom . walker . bookmark ( ! 0 , ! 0 ) , h . evaluator = m , this . _ . nextNode = h. next ( ) , h = new CKEDITOR . dom . walker ( r . clone ( ) ) , h . evaluator = m , h = h . previous ( ) , this . _ . lastNode = h. getNextSourceNode ( ! 0 , null , r . root ) , this . _ . lastNode && this . _ . lastNode . type == CKEDITOR . NODE _TEXT && ! CKEDITOR . tools . trim ( this . _ . lastNode . getText ( ) ) && this . _ . lastNode . getParent ( ) . isBlockBoundary ( ) && ( m = this . range . clone ( ) , m . moveToPosition ( this . _ . lastNode , CKEDITOR . POSITION _AFTER _END ) , m . checkEndOfBlock ( ) &&
( m = new CKEDITOR . dom . elementPath ( m . endContainer , m . root ) , this . _ . lastNode = ( m . block || m . blockLimit ) . getNextSourceNode ( ! 0 ) ) ) , this . _ . lastNode && r . root . contains ( this . _ . lastNode ) || ( this . _ . lastNode = this . _ . docEndMarker = r . document . createText ( "" ) , this . _ . lastNode . insertAfter ( h) ) , r = null ) ; this . _ . started = 1 ; h= r } m = this . _ . nextNode ; r = this . _ . lastNode ; for ( this . _ . nextNode = null ; m ; ) { var L= 0 , v = m . hasAscendant ( "pre" ) , J = m . type != CKEDITOR . NODE _ELEMENT , G = 0 ; if ( J ) m . type == CKEDITOR . NODE _TEXT && g . test ( m . getText ( ) ) && ( J = 0 ) ; else { var p = m . getName ( ) ;
if ( CKEDITOR . dtd . $block [ p ] && "false" == m . getAttribute ( "contenteditable" ) ) { d = m ; b ( this , a , d ) ; break } else if ( m . isBlockBoundary ( this . forceBrBreak && ! v && { br : 1 } ) ) { if ( "br" == p) J = 1 ; else if ( ! h && ! m . getChildCount ( ) && "hr" != p) { d = m ; B = m . equals ( r ) ; break } h && ( h . setEndAt ( m , CKEDITOR . POSITION _BEFORE _START ) , "br" != p && ( this . _ . nextNode = m ) ) ; L = 1 } else { if ( m . getFirst ( ) ) { h|| ( h = this . range . clone ( ) , h . setStartAt ( m , CKEDITOR . POSITION _BEFORE _START ) ) ; m = m . getFirst ( ) ; continue } J = 1 } } J && ! h&& ( h = this . range . clone ( ) , h . setStartAt ( m , CKEDITOR . POSITION _BEFORE _START ) ) ;
B= ( ! L || J ) && m . equals ( r ) ; if ( h && ! L ) for ( ; ! m . getNext ( k ) && ! B ; ) { p = m . getParent ( ) ; if ( p . isBlockBoundary ( this . forceBrBreak && ! v&& { br : 1 } ) ) { L = 1 ; J = 0 ; B || p . equals ( r ) ; h . setEndAt ( p , CKEDITOR . POSITION _BEFORE _END ) ; break } m = p; J = 1 ; B = m . equals ( r ) ; G = 1 } J && h . setEndAt ( m , CKEDITOR . POSITION _AFTER _END ) ; m = this . _getNextSourceNode ( m , G, r ) ; if ( ( B = ! m ) || L && h ) break } if ( ! d ) { if ( ! h ) return this . _ . docEndMarker && this . _ . docEndMarker . remove ( ) , this . _ . nextNode = null ; d = new CKEDITOR . dom . elementPath ( h. startContainer , h . root ) ; m = d . blockLimit ; L = { div : 1 , th : 1 , td : 1 } ;
d = d . block ; ! d && m && ! this . enforceRealBlocks && L[ m . getName ( ) ] && h . checkStartOfBlock ( ) && h . checkEndOfBlock ( ) && ! m . equals ( h . root ) ? d = m : ! d || this . enforceRealBlocks && d . is ( l ) ? ( d = this . range . document . createElement ( a ) , h . extractContents ( ) . appendTo ( d ) , d . trim ( ) , h. insertNode ( d ) , y = F = ! 0 ) : "li" != d . getName ( ) ? h. checkStartOfBlock ( ) && h . checkEndOfBlock ( ) || ( d = d . clone ( ! 1 ) , h . extractContents ( ) . appendTo ( d ) , d . trim ( ) , F= h . splitBlock ( ) , y = ! F . wasStartOfBlock , F = ! F . wasEndOfBlock , h . insertNode ( d ) ) : B || ( this . _ . nextNode = d . equals ( r ) ? null : this . _getNextSourceNode ( h . getBoundaryNodes ( ) . endNode ,
1 , r) ) } y && ( y = d . getPrevious ( ) ) && y . type == CKEDITOR . NODE _ELEMENT && ( "br" == y. getName ( ) ? y . remove ( ) : y . getLast ( ) && "br" == y . getLast ( ) . $ . nodeName . toLowerCase ( ) && y . getLast ( ) . remove ( ) ) ; F&& ( y = d . getLast ( ) ) && y . type == CKEDITOR . NODE _ELEMENT && "br" == y . getName ( ) && ( ! CKEDITOR . env . needsBrFiller || y. getPrevious ( e ) || y . getNext ( e ) ) && y . remove ( ) ; this . _ . nextNode || ( this . _ . nextNode = B|| d . equals ( r ) || ! r ? null : this . _getNextSourceNode ( d , 1 , r ) ) ; return d } , _getNextSourceNode : function ( a , b , c ) { function d ( a ) { return ! ( a . equals ( c ) || a . equals ( g) ) } var g =
( function ( ) { function a ( a ) { 1 > arguments . length || ( this . range = a , this . forceBrBreak = 0 , this . enlargeBr = 1 , this . enforceRealBlocks = 0 , this . _ || ( this . _ = { } ) ) } function d ( a ) { var b = [ ] ; a . forEach ( function ( a ) { if ( "true" == a . getAttribute ( "contenteditable" ) ) return b . push ( a ) , ! 1 } , CKEDITOR . NODE _ELEMENT , ! 0 ) ; return b } function b ( a , c , e , f) { a : { null == f && ( f = d ( e ) ) ; for ( var h ; h = f . shift ( ) ; ) if ( h . getDtd ( ) . p ) { f= { element : h , remaining : f } ; break a } f = null } if ( ! f ) return 0 ; if ( ( h = CKEDITOR . filter . instances [ f . element . data ( "cke-filter" ) ] ) && ! h . check ( c ) ) return b ( a ,
c , e , f . remaining ) ; c = new CKEDITOR . dom . range ( f . element ) ; c . selectNodeContents ( f . element ) ; c = c . createIterator ( ) ; c . enlargeBr = a . enlargeBr ; c . enforceRealBlocks = a . enforceRealBlocks ; c . activeFilter = c . filter = h ; a . _ . nestedEditable = { element : f . element , container : e , remaining : f . remaining , iterator : c } ; return 1 } function c ( a , b , c ) { if ( ! b ) return ! 1 ; a = a . clone ( ) ; a . collapse ( ! c ) ; return a . checkBoundaryOfElement ( b , c ? CKEDITOR . START : CKEDITOR . END ) } var f = /^[\r\n\t ]+$/ , e = CKEDITOR . dom . walker . bookmark ( ! 1 , ! 0 ) , k = CKEDITOR . dom . walker . whitespaces ( ! 0 ) ,
h = function ( a ) { return e ( a ) && k( a ) } , n = { dd : 1 , dt : 1 , li : 1 } ; a . prototype = { getNextParagraph : function ( a ) { var d , k, y , z , G ; a = a || "p" ; if ( this . _ . nestedEditable ) { if ( d = this . _ . nestedEditable . iterator . getNextParagraph ( a ) ) return this . activeFilter = this . _ . nestedEditable . iterator . activeFilter , d ; this . activeFilter = this . filter ; if ( b ( this , a , this . _ . nestedEditable . container , this . _ . nestedEditable . remaining ) ) return this . activeFilter = this . _ . nestedEditable . iterator . activeFilter , this . _ . nestedEditable . iterator . getNextParagraph ( a ) ; this . _ . nestedEditable =
null } if ( ! this . range . root . getDtd ( ) [ a ] ) return null ; if ( ! this . _ . started ) { var v = this . range . clone ( ) ; k= v . startPath ( ) ; var m = v . endPath ( ) , M = ! v . collapsed && c ( v , k . block ) , w = ! v . collapsed && c ( v , m . block , 1 ) ; v . shrink ( CKEDITOR . SHRINK _ELEMENT , ! 0 ) ; M&& v . setStartAt ( k . block , CKEDITOR . POSITION _BEFORE _END ) ; w&& v . setEndAt ( m . block , CKEDITOR . POSITION _AFTER _START ) ; k= v . endContainer . hasAscendant ( "pre" , ! 0 ) || v . startContainer . hasAscendant ( "pre" , ! 0 ) ; v . enlarge ( this . forceBrBreak && ! k || ! this . enlargeBr ? CKEDITOR . ENLARGE _LIST _ITEM _CONTENTS : CKEDITOR . ENLARGE _BLOCK _CONTENTS ) ;
v. collapsed || ( k = new CKEDITOR . dom . walker ( v . clone ( ) ) , m = CKEDITOR . dom . walker . bookmark ( ! 0 , ! 0 ) , k . evaluator = m , this . _ . nextNode = k. next ( ) , k = new CKEDITOR . dom . walker ( v . clone ( ) ) , k . evaluator = m , k = k . previous ( ) , this . _ . lastNode = k. getNextSourceNode ( ! 0 , null , v . root ) , this . _ . lastNode && this . _ . lastNode . type == CKEDITOR . NODE _TEXT && ! CKEDITOR . tools . trim ( this . _ . lastNode . getText ( ) ) && this . _ . lastNode . getParent ( ) . isBlockBoundary ( ) && ( m = this . range . clone ( ) , m . moveToPosition ( this . _ . lastNode , CKEDITOR . POSITION _AFTER _END ) , m . checkEndOfBlock ( ) &&
( m = new CKEDITOR . dom . elementPath ( m . endContainer , m . root ) , this . _ . lastNode = ( m . block || m . blockLimit ) . getNextSourceNode ( ! 0 ) ) ) , this . _ . lastNode && v . root . contains ( this . _ . lastNode ) || ( this . _ . lastNode = this . _ . docEndMarker = v . document . createText ( "" ) , this . _ . lastNode . insertAfter ( k) ) , v = null ) ; this . _ . started = 1 ; k= v } m = this . _ . nextNode ; v = this . _ . lastNode ; for ( this . _ . nextNode = null ; m ; ) { var M= 0 , w = m . hasAscendant ( "pre" ) , J = m . type != CKEDITOR . NODE _ELEMENT , F = 0 ; if ( J ) m . type == CKEDITOR . NODE _TEXT && f . test ( m . getText ( ) ) && ( J = 0 ) ; else { var q = m . getName ( ) ;
if ( CKEDITOR . dtd . $block [ q ] && "false" == m . getAttribute ( "contenteditable" ) ) { d = m ; b ( this , a , d ) ; break } else if ( m . isBlockBoundary ( this . forceBrBreak && ! w && { br : 1 } ) ) { if ( "br" == q) J = 1 ; else if ( ! k && ! m . getChildCount ( ) && "hr" != q) { d = m ; y = m . equals ( v ) ; break } k && ( k . setEndAt ( m , CKEDITOR . POSITION _BEFORE _START ) , "br" != q && ( this . _ . nextNode = m ) ) ; M = 1 } else { if ( m . getFirst ( ) ) { k|| ( k = this . range . clone ( ) , k . setStartAt ( m , CKEDITOR . POSITION _BEFORE _START ) ) ; m = m . getFirst ( ) ; continue } J = 1 } } J && ! k&& ( k = this . range . clone ( ) , k . setStartAt ( m , CKEDITOR . POSITION _BEFORE _START ) ) ;
y= ( ! M || J ) && m . equals ( v ) ; if ( k && ! M ) for ( ; ! m . getNext ( h ) && ! y ; ) { q = m . getParent ( ) ; if ( q . isBlockBoundary ( this . forceBrBreak && ! w&& { br : 1 } ) ) { M = 1 ; J = 0 ; y || q . equals ( v ) ; k . setEndAt ( q , CKEDITOR . POSITION _BEFORE _END ) ; break } m = q; J = 1 ; y = m . equals ( v ) ; F = 1 } J && k . setEndAt ( m , CKEDITOR . POSITION _AFTER _END ) ; m = this . _getNextSourceNode ( m , F, v ) ; if ( ( y = ! m ) || M && k ) break } if ( ! d ) { if ( ! k ) return this . _ . docEndMarker && this . _ . docEndMarker . remove ( ) , this . _ . nextNode = null ; d = new CKEDITOR . dom . elementPath ( k. startContainer , k . root ) ; m = d . blockLimit ; M = { div : 1 , th : 1 , td : 1 } ;
d = d . block ; ! d && m && ! this . enforceRealBlocks && M[ m . getName ( ) ] && k . checkStartOfBlock ( ) && k . checkEndOfBlock ( ) && ! m . equals ( k . root ) ? d = m : ! d || this . enforceRealBlocks && d . is ( n ) ? ( d = this . range . document . createElement ( a ) , k . extractContents ( ) . appendTo ( d ) , d . trim ( ) , k. insertNode ( d ) , z = G = ! 0 ) : "li" != d . getName ( ) ? k. checkStartOfBlock ( ) && k . checkEndOfBlock ( ) || ( d = d . clone ( ! 1 ) , k . extractContents ( ) . appendTo ( d ) , d . trim ( ) , G= k . splitBlock ( ) , z = ! G . wasStartOfBlock , G = ! G . wasEndOfBlock , k . insertNode ( d ) ) : y || ( this . _ . nextNode = d . equals ( v ) ? null : this . _getNextSourceNode ( k . getBoundaryNodes ( ) . endNode ,
1 , v) ) } z && ( z = d . getPrevious ( ) ) && z . type == CKEDITOR . NODE _ELEMENT && ( "br" == z. getName ( ) ? z . remove ( ) : z . getLast ( ) && "br" == z . getLast ( ) . $ . nodeName . toLowerCase ( ) && z . getLast ( ) . remove ( ) ) ; G&& ( z = d . getLast ( ) ) && z . type == CKEDITOR . NODE _ELEMENT && "br" == z . getName ( ) && ( ! CKEDITOR . env . needsBrFiller || z. getPrevious ( e ) || z . getNext ( e ) ) && z . remove ( ) ; this . _ . nextNode || ( this . _ . nextNode = y|| d . equals ( v ) || ! v ? null : this . _getNextSourceNode ( d , 1 , v ) ) ; return d } , _getNextSourceNode : function ( a , b , c ) { function d ( a ) { return ! ( a . equals ( c ) || a . equals ( f) ) } var f =
this . range . root ; for ( a = a . getNextSourceNode ( b , null , d ) ; ! e ( a ) ; ) a = a . getNextSourceNode ( b , null , d ) ; return a } } ; CKEDITOR . dom . range . prototype . createIterator = function ( ) { return new a ( this ) } } ) ( ) ;
CKEDITOR . command = function ( a , d ) { this . uiItems = [ ] ; this . exec = function ( b ) { if ( this . state == CKEDITOR . TRISTATE _DISABLED || ! this . checkAllowed ( ) ) return ! 1 ; this . editorFocus && a . focus ( ) ; return ! 1 === this . fire ( "exec" ) ? ! 0 : ! 1 !== d . exec . call ( this , a , b ) } ; this . refresh = function ( a , b ) { if ( ! this . readOnly && a . readOnly ) return ! 0 ; if ( this . context && ! b . isContextFor ( this . context ) || ! this . checkAllowed ( ! 0 ) ) return this . disable ( ) , ! 0 ; this . startDisabled || this . enable ( ) ; this . modes && ! this . modes [ a . mode ] && this . disable ( ) ; return ! 1 === this . fire ( "refresh" ,
{ editor : a , path : b } ) ? ! 0 : d . refresh && ! 1 !== d . refresh . apply ( this , arguments ) } ; var b ; this . checkAllowed = function ( c ) { return c || "boolean" != typeof b ? b = a . activeFilter . checkFeature ( this ) : b } ; CKEDITOR . tools . extend ( this , d , { modes : { wysiwyg : 1 } , editorFocus : 1 , contextSensitive : ! ! d . context , state : CKEDITOR . TRISTATE _DISABLED } ) ; CKEDITOR . event . call ( this ) } ;
CKEDITOR . command . prototype = { enable : function ( ) { this . state == CKEDITOR . TRISTATE _DISABLED && this . checkAllowed ( ) && this . setState ( this . preserveState && "undefined" != typeof this . previousState ? this . previousState : CKEDITOR . TRISTATE _OFF ) } , disable : function ( ) { this . setState ( CKEDITOR . TRISTATE _DISABLED ) } , setState : function ( a ) { if ( this . state == a || a != CKEDITOR . TRISTATE _DISABLED && ! this . checkAllowed ( ) ) return ! 1 ; this . previousState = this . state ; this . state = a ; this . fire ( "state" ) ; return ! 0 } , toggleState : function ( ) { this . state == CKEDITOR . TRISTATE _OFF ?
this . setState ( CKEDITOR . TRISTATE _ON ) : this . state == CKEDITOR . TRISTATE _ON && this . setState ( CKEDITOR . TRISTATE _OFF ) } } ; CKEDITOR . event . implementOn ( CKEDITOR . command . prototype ) ; CKEDITOR . ENTER _P = 1 ; CKEDITOR . ENTER _BR = 2 ; CKEDITOR . ENTER _DIV = 3 ;
CKEDITOR . config = { customConfig : "config.js" , autoUpdateElement : ! 0 , language : "" , licenseKey : "" , defaultLanguage : "en" , contentsLangDirection : "" , enterMode : CKEDITOR . ENTER _P , forceEnterMode : ! 1 , shiftEnterMode : CKEDITOR . ENTER _BR , docType : "\x3c!DOCTYPE html\x3e" , bodyId : "" , bodyClass : "" , fullPage : ! 1 , height : 200 , contentsCss : CKEDITOR . getUrl ( "contents.css" ) , extraPlugins : "" , removePlugins : "" , protectedSource : [ ] , tabIndex : 0 , useComputedState : ! 0 , width : "" , baseFloatZIndex : 1E4 , blockedKeystrokes : [ CKEDITOR . CTRL + 66 , CKEDITOR . CTRL + 73 , CKEDITOR . CTRL +
85 ] } ;
( function ( ) { function a ( a , b , c , e , d ) { var g , f ; a = [ ] ; for ( g in b ) { f = b [ g ] ; f = "boolean" == typeof f ? { } : "function" == typeof f ? { match : f } : D ( f ) ; "$" != g . charAt ( 0 ) && ( f . elements = g ) ; c && ( f . featureName = c . toLowerCase ( ) ) ; var n = f ; n . elements = h ( n . elements , /\s+/ ) || null ; n . propertiesOnly = n . propertiesOnly || ! 0 === n . elements ; var t = /\s*,\s*/ , x = void 0 ; for ( x in T ) { n [ x ] = h ( n [ x ] , t ) || null ; var m = n , C = N [ x ] , k = h ( n [ N [ x ] ] , t ) , E = n [ x ] , A = [ ] , I = ! 0 , H = void 0 ; k ? I = ! 1 : k = { } ; for ( H in E ) "!" == H . charAt ( 0 ) && ( H = H . slice ( 1 ) , A . push ( H ) , k [ H ] = ! 0 , I = ! 1 ) ; for ( ; H = A . pop ( ) ; ) E [ H ] = E [ "!" +
H ] , delete E [ "!" + H ] ; m [ C ] = ( I ? ! 1 : k ) || null } n . match = n . match || null ; e . push ( f ) ; a . push ( f ) } b = d . elements ; d = d . generic ; var z ; c = 0 ; for ( e = a . length ; c < e ; ++ c ) { g = D ( a [ c ] ) ; f = ! 0 === g . classes || ! 0 === g . styles || ! 0 === g . attributes ; n = g ; x = C = t = void 0 ; for ( t in T ) n [ t ] = L ( n [ t ] ) ; m = ! 0 ; for ( x in N ) { t = N [ x ] ; C = n [ t ] ; k = [ ] ; E = void 0 ; for ( E in C ) - 1 < E . indexOf ( "*" ) ? k . push ( new RegExp ( "^" + E . replace ( /\*/g , ".*" ) + "$" ) ) : k . push ( E ) ; C = k ; C . length && ( n [ t ] = C , m = ! 1 ) } n . nothingRequired = m ; n . noProperties = ! ( n . attributes || n . classes || n . styles ) ; if ( ! 0 === g . elements || null ===
g . elements ) d [ f ? "unshift" : "push" ] ( g ) ; else for ( z in n = g . elements , delete g . elements , n ) if ( b [ z ] ) b [ z ] [ f ? "unshift" : "push" ] ( g ) ; else b [ z ] = [ g ] } } function d ( a , c , e , d ) { if ( ! a . match || a . match ( c ) ) if ( d || k ( a , c ) ) if ( a . propertiesOnly || ( e . valid = ! 0 ) , e . allAttributes || ( e . allAttributes = b ( a . attributes , c . attributes , e . validAttributes ) ) , e . allStyles || ( e . allStyles = b ( a . styles , c . styles , e . validStyles ) ) , ! e . allClasses ) { a = a . classes ; c = c . classes ; d = e . validClasses ; if ( a ) if ( ! 0 === a ) a = ! 0 ; else { for ( var g = 0 , f = c . length , n ; g < f ; ++ g ) n = c [ g ] , d [ n ] || ( d [ n ] =
a ( n ) ) ; a = ! 1 } else a = ! 1 ; e . allClasses = a } } function b ( a , b , c ) { if ( ! a ) return ! 1 ; if ( ! 0 === a ) return ! 0 ; for ( var e in b ) c [ e ] || ( c [ e ] = a ( e ) ) ; return ! 1 } function c ( a , b , c ) { if ( ! a . match || a . match ( b ) ) { if ( a . noProperties ) return ! 1 ; c . hadInvalidAttribute = g ( a . attributes , b . attributes ) || c . hadInvalidAttribute ; c . hadInvalidStyle = g ( a . styles , b . styles ) || c . hadInvalidStyle ; a = a . classes ; b = b . classes ; if ( a ) { for ( var e = ! 1 , d = ! 0 === a , f = b . length ; f -- ; ) if ( d || a ( b [ f ] ) ) b . splice ( f , 1 ) , e = ! 0 ; a = e } else a = ! 1 ; c . hadInvalidClass = a || c . hadInvalidClass } } function g ( a ,
b ) { if ( ! a ) return ! 1 ; var c = ! 1 , e = ! 0 === a , d ; for ( d in b ) if ( e || a ( d ) ) delete b [ d ] , c = ! 0 ; return c } function e ( a , b , c ) { if ( a . disabled || a . customConfig && ! c || ! b ) return ! 1 ; a . _ . cachedChecks = { } ; return ! 0 } function h ( a , b ) { if ( ! a ) return ! 1 ; if ( ! 0 === a ) return a ; if ( "string" == typeof a ) return a = C ( a ) , "*" == a ? ! 0 : CKEDITOR . tools . convertArrayToObject ( a . split ( b ) ) ; if ( CKEDITOR . tools . isArray ( a ) ) return a . length ? CKEDITOR . tools . convertArrayToObject ( a ) : ! 1 ; var c = { } , e = 0 , d ; for ( d in a ) c [ d ] = a [ d ] , e ++ ; return e ? c : ! 1 } function k ( a , b ) { if ( a . nothingRequired ) return ! 0 ;
var c , e , d , g ; if ( d = a . requiredClasses ) for ( g = b . classes , c = 0 ; c < d . length ; ++ c ) if ( e = d [ c ] , "string" == typeof e ) { if ( - 1 == CKEDITOR . tools . indexOf ( g , e ) ) return ! 1 } else if ( ! CKEDITOR . tools . checkIfAnyArrayItemMatches ( g , e ) ) return ! 1 ; return l ( b . styles , a . requiredStyles ) && l ( b . attributes , a . requiredAttributes ) } function l ( a , b ) { if ( ! b ) return ! 0 ; for ( var c = 0 , e ; c < b . length ; ++ c ) if ( e = b [ c ] , "string" == typeof e ) { if ( ! ( e in a ) ) return ! 1 } else if ( ! CKEDITOR . tools . checkIfAnyObjectPropertyMatches ( a , e ) ) return ! 1 ; return ! 0 } function q ( a ) { if ( ! a ) return { } ;
a = a . split ( /\s*,\s*/ ) . sort ( ) ; for ( var b = { } ; a . length ; ) b [ a . shift ( ) ] = "cke-test" ; return b } function f ( a ) { var b , c , e , d , g = { } , f = 1 ; for ( a = C ( a ) ; b = a . match ( x ) ; ) ( c = b [ 2 ] ) ? ( e = w ( c , "styles" ) , d = w ( c , "attrs" ) , c = w ( c , "classes" ) ) : e = d = c = null , g [ "$" + f ++ ] = { elements : b [ 1 ] , classes : c , styles : e , attributes : d } , a = a . slice ( b [ 0 ] . length ) ; return g } function w ( a , b ) { var c = a . match ( H [ b ] ) ; return c ? C ( c [ 1 ] ) : null } function B ( a ) { var b = a . styleBackup = a . attributes . style , c = a . classBackup = a . attributes [ "class" ] ; a . styles || ( a . styles = CKEDITOR . tools . parseCssText ( b ||
"" , 1 ) ) ; a . classes || ( a . classes = c ? c . split ( /\s+/ ) : [ ] ) } function y ( a , b , e , g ) { var f = 0 , t ; g . toHtml && ( b . name = b . name . replace ( M , "$1" ) ) ; if ( g . doCallbacks && a . elementCallbacks ) { a : { t = a . elementCallbacks ; for ( var h = 0 , x = t . length , C ; h < x ; ++ h ) if ( C = t [ h ] ( b ) ) { t = C ; break a } t = void 0 } if ( t ) return t } if ( g . doTransform && ( t = a . _ . transformations [ b . name ] ) ) { B ( b ) ; for ( h = 0 ; h < t . length ; ++ h ) p ( a , b , t [ h ] ) ; r ( b ) } if ( g . doFilter ) { a : { h = b . name ; x = a . _ ; a = x . allowedRules . elements [ h ] ; t = x . allowedRules . generic ; h = x . disallowedRules . elements [ h ] ; x = x . disallowedRules . generic ;
C = g . skipRequired ; var D = { valid : ! 1 , validAttributes : { } , validClasses : { } , validStyles : { } , allAttributes : ! 1 , allClasses : ! 1 , allStyles : ! 1 , hadInvalidAttribute : ! 1 , hadInvalidClass : ! 1 , hadInvalidStyle : ! 1 } , k , E ; if ( a || t ) { B ( b ) ; if ( h ) for ( k = 0 , E = h . length ; k < E ; ++ k ) if ( ! 1 === c ( h [ k ] , b , D ) ) { a = null ; break a } if ( x ) for ( k = 0 , E = x . length ; k < E ; ++ k ) c ( x [ k ] , b , D ) ; if ( a ) for ( k = 0 , E = a . length ; k < E ; ++ k ) d ( a [ k ] , b , D , C ) ; if ( t ) for ( k = 0 , E = t . length ; k < E ; ++ k ) d ( t [ k ] , b , D , C ) ; a = D } else a = null } if ( ! a || ! a . valid ) return e . push ( b ) , 1 ; E = a . validAttributes ; var A = a . validStyles ;
t = a . validClasses ; var h = b . attributes , I = b . styles , x = b . classes ; C = b . classBackup ; var N = b . styleBackup , H , z , l = [ ] , D = [ ] , T = /^data-cke-/ ; k = ! 1 ; delete h . style ; delete h [ "class" ] ; delete b . classBackup ; delete b . styleBackup ; if ( ! a . allAttributes ) for ( H in h ) E [ H ] || ( T . test ( H ) ? H == ( z = H . replace ( /^data-cke-saved-/ , "" ) ) || E [ z ] || ( delete h [ H ] , k = ! 0 ) : ( delete h [ H ] , k = ! 0 ) ) ; if ( ! a . allStyles || a . hadInvalidStyle ) { for ( H in I ) a . allStyles || A [ H ] ? l . push ( H + ":" + I [ H ] ) : k = ! 0 ; l . length && ( h . style = l . sort ( ) . join ( "; " ) ) } else N && ( h . style = N ) ; if ( ! a . allClasses ||
a . hadInvalidClass ) { for ( H = 0 ; H < x . length ; ++ H ) ( a . allClasses || t [ x [ H ] ] ) && D . push ( x [ H ] ) ; D . length && ( h [ "class" ] = D . sort ( ) . join ( " " ) ) ; C && D . length < C . split ( /\s+/ ) . length && ( k = ! 0 ) } else C && ( h [ "class" ] = C ) ; k && ( f = 1 ) ; if ( ! g . skipFinalValidation && ! m ( b ) ) return e . push ( b ) , 1 } g . toHtml && ( b . name = b . name . replace ( n , "cke:$1" ) ) ; return f } function F ( a ) { var b = [ ] , c ; for ( c in a ) - 1 < c . indexOf ( "*" ) && b . push ( c . replace ( /\*/g , ".*" ) ) ; return b . length ? new RegExp ( "^(?:" + b . join ( "|" ) + ")$" ) : null } function r ( a ) { var b = a . attributes , c ; delete b . style ; delete b [ "class" ] ;
if ( c = CKEDITOR . tools . writeCssText ( a . styles , ! 0 ) ) b . style = c ; a . classes . length && ( b [ "class" ] = a . classes . sort ( ) . join ( " " ) ) } function m ( a ) { switch ( a . name ) { case "a" : if ( ! ( a . children . length || a . attributes . name || a . attributes . id ) ) return ! 1 ; break ; case "img" : if ( ! a . attributes . src ) return ! 1 } return ! 0 } function L ( a ) { if ( ! a ) return ! 1 ; if ( ! 0 === a ) return ! 0 ; var b = F ( a ) ; return function ( c ) { return c in a || b && c . match ( b ) } } function v ( ) { return new CKEDITOR . htmlParser . element ( "br" ) } function J ( a ) { return a . type == CKEDITOR . NODE _ELEMENT && ( "br" ==
a . name || t . $block [ a . name ] ) } function G ( a , b , c ) { var e = a . name ; if ( t . $empty [ e ] || ! a . children . length ) "hr" == e && "br" == b ? a . replaceWith ( v ( ) ) : ( a . parent && c . push ( { check : "it" , el : a . parent } ) , a . remove ( ) ) ; else if ( t . $block [ e ] || "tr" == e ) if ( "br" == b ) a . previous && ! J ( a . previous ) && ( b = v ( ) , b . insertBefore ( a ) ) , a . next && ! J ( a . next ) && ( b = v ( ) , b . insertAfter ( a ) ) , a . replaceWithChildren ( ) ; else { var e = a . children , d ; b : { d = t [ b ] ; for ( var g = 0 , f = e . length , n ; g < f ; ++ g ) if ( n = e [ g ] , n . type == CKEDITOR . NODE _ELEMENT && ! d [ n . name ] ) { d = ! 1 ; break b } d = ! 0 } if ( d ) a . name = b , a . attributes =
{ } , c . push ( { check : "parent-down" , el : a } ) ; else { d = a . parent ; for ( var g = d . type == CKEDITOR . NODE _DOCUMENT _FRAGMENT || "body" == d . name , h , x , f = e . length ; 0 < f ; ) n = e [ -- f ] , g && ( n . type == CKEDITOR . NODE _TEXT || n . type == CKEDITOR . NODE _ELEMENT && t . $inline [ n . name ] ) ? ( h || ( h = new CKEDITOR . htmlParser . element ( b ) , h . insertAfter ( a ) , c . push ( { check : "parent-down" , el : h } ) ) , h . add ( n , 0 ) ) : ( h = null , x = t [ d . name ] || t . span , n . insertAfter ( a ) , d . type == CKEDITOR . NODE _DOCUMENT _FRAGMENT || n . type != CKEDITOR . NODE _ELEMENT || x [ n . name ] || c . push ( { check : "el-up" , el : n } ) ) ; a . remove ( ) } } else e in
{ style : 1 , script : 1 } ? a . remove ( ) : ( a . parent && c . push ( { check : "it" , el : a . parent } ) , a . replaceWithChildren ( ) ) } function p ( a , b , c ) { var e , d ; for ( e = 0 ; e < c . length ; ++ e ) if ( d = c [ e ] , ! ( d . check && ! a . check ( d . check , ! 1 ) || d . left && ! d . left ( b ) ) ) { d . right ( b , A ) ; break } } function u ( a , b ) { var c = b . getDefinition ( ) , e = c . attributes , d = c . styles , g , f , n , t ; if ( a . name != c . element ) return ! 1 ; for ( g in e ) if ( "class" == g ) for ( c = e [ g ] . split ( /\s+/ ) , n = a . classes . join ( "|" ) ; t = c . pop ( ) ; ) { if ( - 1 == n . indexOf ( t ) ) return ! 1 } else if ( a . attributes [ g ] != e [ g ] ) return ! 1 ; for ( f in d ) if ( a . styles [ f ] !=
d [ f ] ) return ! 1 ; return ! 0 } function K ( a , b ) { var c , e ; "string" == typeof a ? c = a : a instanceof CKEDITOR . style ? e = a : ( c = a [ 0 ] , e = a [ 1 ] ) ; return [ { element : c , left : e , right : function ( a , c ) { c . transform ( a , b ) } } ] } function E ( a ) { return function ( b ) { return u ( b , a ) } } function z ( a ) { return function ( b , c ) { c [ a ] ( b ) } } var t = CKEDITOR . dtd , D = CKEDITOR . tools . copy , C = CKEDITOR . tools . trim , I = [ "" , "p" , "br" , "div" ] ; CKEDITOR . FILTER _SKIP _TREE = 2 ; CKEDITOR . filter = function ( a , b ) { this . allowedContent = [ ] ; this . disallowedContent = [ ] ; this . elementCallbacks = null ; this . disabled =
CKEDITOR . config = { customConfig : "config.js" , autoUpdateElement : ! 0 , language : "" , defaultLanguage : "en" , contentsLangDirection : "" , enterMode : CKEDITOR . ENTER _P , forceEnterMode : ! 1 , shiftEnterMode : CKEDITOR . ENTER _BR , docType : "\x3c!DOCTYPE html\x3e" , bodyId : "" , bodyClass : "" , fullPage : ! 1 , height : 200 , contentsCss : CKEDITOR . getUrl ( "contents.css" ) , extraPlugins : "" , removePlugins : "" , protectedSource : [ ] , tabIndex : 0 , useComputedState : ! 0 , width : "" , baseFloatZIndex : 1E4 , blockedKeystrokes : [ CKEDITOR . CTRL + 66 , CKEDITOR . CTRL + 73 , CKEDITOR . CTRL + 85 ] } ;
( function ( ) { function a ( a , b , c , e , d ) { var f , g ; a = [ ] ; for ( f in b ) { g = b [ f ] ; g = "boolean" == typeof g ? { } : "function" == typeof g ? { match : g } : H ( g ) ; "$" != f . charAt ( 0 ) && ( g . elements = f ) ; c && ( g . featureName = c . toLowerCase ( ) ) ; var p = g ; p . elements = k ( p . elements , /\s+/ ) || null ; p . propertiesOnly = p . propertiesOnly || ! 0 === p . elements ; var t = /\s*,\s*/ , r = void 0 ; for ( r in N ) { p [ r ] = k ( p [ r ] , t ) || null ; var m = p , A = L [ r ] , h = k ( p [ L [ r ] ] , t ) , D = p [ r ] , C = [ ] , I = ! 0 , E = void 0 ; h ? I = ! 1 : h = { } ; for ( E in D ) "!" == E . charAt ( 0 ) && ( E = E . slice ( 1 ) , C . push ( E ) , h [ E ] = ! 0 , I = ! 1 ) ; for ( ; E = C . pop ( ) ; ) D [ E ] =
D [ "!" + E ] , delete D [ "!" + E ] ; m [ A ] = ( I ? ! 1 : h ) || null } p . match = p . match || null ; e . push ( g ) ; a . push ( g ) } b = d . elements ; d = d . generic ; var B ; c = 0 ; for ( e = a . length ; c < e ; ++ c ) { f = H ( a [ c ] ) ; g = ! 0 === f . classes || ! 0 === f . styles || ! 0 === f . attributes ; p = f ; r = A = t = void 0 ; for ( t in N ) p [ t ] = M ( p [ t ] ) ; m = ! 0 ; for ( r in L ) { t = L [ r ] ; A = p [ t ] ; h = [ ] ; D = void 0 ; for ( D in A ) - 1 < D . indexOf ( "*" ) ? h . push ( new RegExp ( "^" + D . replace ( /\*/g , ".*" ) + "$" ) ) : h . push ( D ) ; A = h ; A . length && ( p [ t ] = A , m = ! 1 ) } p . nothingRequired = m ; p . noProperties = ! ( p . attributes || p . classes || p . styles ) ; if ( ! 0 === f . elements ||
null === f . elements ) d [ g ? "unshift" : "push" ] ( f ) ; else for ( B in p = f . elements , delete f . elements , p ) if ( b [ B ] ) b [ B ] [ g ? "unshift" : "push" ] ( f ) ; else b [ B ] = [ f ] } } function d ( a , c , e , d ) { if ( ! a . match || a . match ( c ) ) if ( d || h ( a , c ) ) if ( a . propertiesOnly || ( e . valid = ! 0 ) , e . allAttributes || ( e . allAttributes = b ( a . attributes , c . attributes , e . validAttributes ) ) , e . allStyles || ( e . allStyles = b ( a . styles , c . styles , e . validStyles ) ) , ! e . allClasses ) { a = a . classes ; c = c . classes ; d = e . validClasses ; if ( a ) if ( ! 0 === a ) a = ! 0 ; else { for ( var f = 0 , g = c . length , p ; f < g ; ++ f ) p = c [ f ] , d [ p ] ||
( d [ p ] = a ( p ) ) ; a = ! 1 } else a = ! 1 ; e . allClasses = a } } function b ( a , b , c ) { if ( ! a ) return ! 1 ; if ( ! 0 === a ) return ! 0 ; for ( var e in b ) c [ e ] || ( c [ e ] = a ( e ) ) ; return ! 1 } function c ( a , b , c ) { if ( ! a . match || a . match ( b ) ) { if ( a . noProperties ) return ! 1 ; c . hadInvalidAttribute = f ( a . attributes , b . attributes ) || c . hadInvalidAttribute ; c . hadInvalidStyle = f ( a . styles , b . styles ) || c . hadInvalidStyle ; a = a . classes ; b = b . classes ; if ( a ) { for ( var e = ! 1 , d = ! 0 === a , g = b . length ; g -- ; ) if ( d || a ( b [ g ] ) ) b . splice ( g , 1 ) , e = ! 0 ; a = e } else a = ! 1 ; c . hadInvalidClass = a || c . hadInvalidClass } } function f ( a ,
b ) { if ( ! a ) return ! 1 ; var c = ! 1 , e = ! 0 === a , d ; for ( d in b ) if ( e || a ( d ) ) delete b [ d ] , c = ! 0 ; return c } function e ( a , b , c ) { if ( a . disabled || a . customConfig && ! c || ! b ) return ! 1 ; a . _ . cachedChecks = { } ; return ! 0 } function k ( a , b ) { if ( ! a ) return ! 1 ; if ( ! 0 === a ) return a ; if ( "string" == typeof a ) return a = A ( a ) , "*" == a ? ! 0 : CKEDITOR . tools . convertArrayToObject ( a . split ( b ) ) ; if ( CKEDITOR . tools . isArray ( a ) ) return a . length ? CKEDITOR . tools . convertArrayToObject ( a ) : ! 1 ; var c = { } , e = 0 , d ; for ( d in a ) c [ d ] = a [ d ] , e ++ ; return e ? c : ! 1 } function h ( a , b ) { if ( a . nothingRequired ) return ! 0 ;
var c , e , d , f ; if ( d = a . requiredClasses ) for ( f = b . classes , c = 0 ; c < d . length ; ++ c ) if ( e = d [ c ] , "string" == typeof e ) { if ( - 1 == CKEDITOR . tools . indexOf ( f , e ) ) return ! 1 } else if ( ! CKEDITOR . tools . checkIfAnyArrayItemMatches ( f , e ) ) return ! 1 ; return n ( b . styles , a . requiredStyles ) && n ( b . attributes , a . requiredAttributes ) } function n ( a , b ) { if ( ! b ) return ! 0 ; for ( var c = 0 , e ; c < b . length ; ++ c ) if ( e = b [ c ] , "string" == typeof e ) { if ( ! ( e in a ) ) return ! 1 } else if ( ! CKEDITOR . tools . checkIfAnyObjectPropertyMatches ( a , e ) ) return ! 1 ; return ! 0 } function l ( a ) { if ( ! a ) return { } ;
a = a . split ( /\s*,\s*/ ) . sort ( ) ; for ( var b = { } ; a . length ; ) b [ a . shift ( ) ] = "cke-test" ; return b } function g ( a ) { var b , c , e , d , f = { } , g = 1 ; for ( a = A ( a ) ; b = a . match ( r ) ; ) ( c = b [ 2 ] ) ? ( e = x ( c , "styles" ) , d = x ( c , "attrs" ) , c = x ( c , "classes" ) ) : e = d = c = null , f [ "$" + g ++ ] = { elements : b [ 1 ] , classes : c , styles : e , attributes : d } , a = a . slice ( b [ 0 ] . length ) ; return f } function x ( a , b ) { var c = a . match ( E [ b ] ) ; return c ? A ( c [ 1 ] ) : null } function y ( a ) { var b = a . styleBackup = a . attributes . style , c = a . classBackup = a . attributes [ "class" ] ; a . styles || ( a . styles = CKEDITOR . tools . parseCssText ( b ||
"" , 1 ) ) ; a . classes || ( a . classes = c ? c . split ( /\s+/ ) : [ ] ) } function z ( a , b , e , f ) { var g = 0 , t ; f . toHtml && ( b . name = b . name . replace ( S , "$1" ) ) ; if ( f . doCallbacks && a . elementCallbacks ) { a : { t = a . elementCallbacks ; for ( var r = 0 , A = t . length , h ; r < A ; ++ r ) if ( h = t [ r ] ( b ) ) { t = h ; break a } t = void 0 } if ( t ) return t } if ( f . doTransform && ( t = a . _ . transformations [ b . name ] ) ) { y ( b ) ; for ( r = 0 ; r < t . length ; ++ r ) q ( a , b , t [ r ] ) ; v ( b ) } if ( f . doFilter ) { a : { r = b . name ; A = a . _ ; a = A . allowedRules . elements [ r ] ; t = A . allowedRules . generic ; r = A . disallowedRules . elements [ r ] ; A = A . disallowedRules . generic ;
h = f . skipRequired ; var H = { valid : ! 1 , validAttributes : { } , validClasses : { } , validStyles : { } , allAttributes : ! 1 , allClasses : ! 1 , allStyles : ! 1 , hadInvalidAttribute : ! 1 , hadInvalidClass : ! 1 , hadInvalidStyle : ! 1 } , k , D ; if ( a || t ) { y ( b ) ; if ( r ) for ( k = 0 , D = r . length ; k < D ; ++ k ) if ( ! 1 === c ( r [ k ] , b , H ) ) { a = null ; break a } if ( A ) for ( k = 0 , D = A . length ; k < D ; ++ k ) c ( A [ k ] , b , H ) ; if ( a ) for ( k = 0 , D = a . length ; k < D ; ++ k ) d ( a [ k ] , b , H , h ) ; if ( t ) for ( k = 0 , D = t . length ; k < D ; ++ k ) d ( t [ k ] , b , H , h ) ; a = H } else a = null } if ( ! a || ! a . valid ) return e . push ( b ) , 1 ; D = a . validAttributes ; var C = a . validStyles ;
t = a . validClasses ; var r = b . attributes , I = b . styles , A = b . classes ; h = b . classBackup ; var L = b . styleBackup , E , B , N = [ ] , H = [ ] , l = /^data-cke-/ ; k = ! 1 ; delete r . style ; delete r [ "class" ] ; delete b . classBackup ; delete b . styleBackup ; if ( ! a . allAttributes ) for ( E in r ) D [ E ] || ( l . test ( E ) ? E == ( B = E . replace ( /^data-cke-saved-/ , "" ) ) || D [ B ] || ( delete r [ E ] , k = ! 0 ) : ( delete r [ E ] , k = ! 0 ) ) ; if ( ! a . allStyles || a . hadInvalidStyle ) { for ( E in I ) a . allStyles || C [ E ] ? N . push ( E + ":" + I [ E ] ) : k = ! 0 ; N . length && ( r . style = N . sort ( ) . join ( "; " ) ) } else L && ( r . style = L ) ; if ( ! a . allClasses ||
a . hadInvalidClass ) { for ( E = 0 ; E < A . length ; ++ E ) ( a . allClasses || t [ A [ E ] ] ) && H . push ( A [ E ] ) ; H . length && ( r [ "class" ] = H . sort ( ) . join ( " " ) ) ; h && H . length < h . split ( /\s+/ ) . length && ( k = ! 0 ) } else h && ( r [ "class" ] = h ) ; k && ( g = 1 ) ; if ( ! f . skipFinalValidation && ! m ( b ) ) return e . push ( b ) , 1 } f . toHtml && ( b . name = b . name . replace ( p , "cke:$1" ) ) ; return g } function G ( a ) { var b = [ ] , c ; for ( c in a ) - 1 < c . indexOf ( "*" ) && b . push ( c . replace ( /\*/g , ".*" ) ) ; return b . length ? new RegExp ( "^(?:" + b . join ( "|" ) + ")$" ) : null } function v ( a ) { var b = a . attributes , c ; delete b . style ; delete b [ "class" ] ;
if ( c = CKEDITOR . tools . writeCssText ( a . styles , ! 0 ) ) b . style = c ; a . classes . length && ( b [ "class" ] = a . classes . sort ( ) . join ( " " ) ) } function m ( a ) { switch ( a . name ) { case "a" : if ( ! ( a . children . length || a . attributes . name || a . attributes . id ) ) return ! 1 ; break ; case "img" : if ( ! a . attributes . src ) return ! 1 } return ! 0 } function M ( a ) { if ( ! a ) return ! 1 ; if ( ! 0 === a ) return ! 0 ; var b = G ( a ) ; return function ( c ) { return c in a || b && c . match ( b ) } } function w ( ) { return new CKEDITOR . htmlParser . element ( "br" ) } function J ( a ) { return a . type == CKEDITOR . NODE _ELEMENT && ( "br" ==
a . name || t . $block [ a . name ] ) } function F ( a , b , c ) { var e = a . name ; if ( t . $empty [ e ] || ! a . children . length ) "hr" == e && "br" == b ? a . replaceWith ( w ( ) ) : ( a . parent && c . push ( { check : "it" , el : a . parent } ) , a . remove ( ) ) ; else if ( t . $block [ e ] || "tr" == e ) if ( "br" == b ) a . previous && ! J ( a . previous ) && ( b = w ( ) , b . insertBefore ( a ) ) , a . next && ! J ( a . next ) && ( b = w ( ) , b . insertAfter ( a ) ) , a . replaceWithChildren ( ) ; else { var e = a . children , d ; b : { d = t [ b ] ; for ( var f = 0 , g = e . length , p ; f < g ; ++ f ) if ( p = e [ f ] , p . type == CKEDITOR . NODE _ELEMENT && ! d [ p . name ] ) { d = ! 1 ; break b } d = ! 0 } if ( d ) a . name = b , a . attributes =
{ } , c . push ( { check : "parent-down" , el : a } ) ; else { d = a . parent ; for ( var f = d . type == CKEDITOR . NODE _DOCUMENT _FRAGMENT || "body" == d . name , r , A , g = e . length ; 0 < g ; ) p = e [ -- g ] , f && ( p . type == CKEDITOR . NODE _TEXT || p . type == CKEDITOR . NODE _ELEMENT && t . $inline [ p . name ] ) ? ( r || ( r = new CKEDITOR . htmlParser . element ( b ) , r . insertAfter ( a ) , c . push ( { check : "parent-down" , el : r } ) ) , r . add ( p , 0 ) ) : ( r = null , A = t [ d . name ] || t . span , p . insertAfter ( a ) , d . type == CKEDITOR . NODE _DOCUMENT _FRAGMENT || p . type != CKEDITOR . NODE _ELEMENT || A [ p . name ] || c . push ( { check : "el-up" , el : p } ) ) ; a . remove ( ) } } else e in
{ style : 1 , script : 1 } ? a . remove ( ) : ( a . parent && c . push ( { check : "it" , el : a . parent } ) , a . replaceWithChildren ( ) ) } function q ( a , b , c ) { var e , d ; for ( e = 0 ; e < c . length ; ++ e ) if ( d = c [ e ] , ! ( d . check && ! a . check ( d . check , ! 1 ) || d . left && ! d . left ( b ) ) ) { d . right ( b , C ) ; break } } function u ( a , b ) { var c = b . getDefinition ( ) , e = c . attributes , d = c . styles , f , g , p , t ; if ( a . name != c . element ) return ! 1 ; for ( f in e ) if ( "class" == f ) for ( c = e [ f ] . split ( /\s+/ ) , p = a . classes . join ( "|" ) ; t = c . pop ( ) ; ) { if ( - 1 == p . indexOf ( t ) ) return ! 1 } else if ( a . attributes [ f ] != e [ f ] ) return ! 1 ; for ( g in d ) if ( a . styles [ g ] !=
d [ g ] ) return ! 1 ; return ! 0 } function K ( a , b ) { var c , e ; "string" == typeof a ? c = a : a instanceof CKEDITOR . style ? e = a : ( c = a [ 0 ] , e = a [ 1 ] ) ; return [ { element : c , left : e , right : function ( a , c ) { c . transform ( a , b ) } } ] } function D ( a ) { return function ( b ) { return u ( b , a ) } } function B ( a ) { return function ( b , c ) { c [ a ] ( b ) } } var t = CKEDITOR . dtd , H = CKEDITOR . tools . copy , A = CKEDITOR . tools . trim , I = [ "" , "p" , "br" , "div" ] ; CKEDITOR . FILTER _SKIP _TREE = 2 ; CKEDITOR . filter = function ( a , b ) { this . allowedContent = [ ] ; this . disallowedContent = [ ] ; this . elementCallbacks = null ; this . disabled =
! 1 ; this . editor = null ; this . id = CKEDITOR . tools . getNextNumber ( ) ; this . _ = { allowedRules : { elements : { } , generic : [ ] } , disallowedRules : { elements : { } , generic : [ ] } , transformations : { } , cachedTests : { } , cachedChecks : { } } ; CKEDITOR . filter . instances [ this . id ] = this ; var c = this . editor = a instanceof CKEDITOR . editor ? a : null ; if ( c && ! b ) { this . customConfig = ! 0 ; var e = c . config . allowedContent ; ! 0 === e ? this . disabled = ! 0 : ( e || ( this . customConfig = ! 1 ) , this . allow ( e , "config" , 1 ) , this . allow ( c . config . extraAllowedContent , "extra" , 1 ) , this . allow ( I [ c . enterMode ] +
" " + I [ c . shiftEnterMode ] , "default" , 1 ) , this . disallow ( c . config . disallowedContent ) ) } else this . customConfig = ! 1 , this . allow ( b || a , "default" , 1 ) } ; CKEDITOR . filter . instances = { } ; CKEDITOR . filter . prototype = { allow : function ( b , c , d ) { if ( ! e ( this , b , d ) ) return ! 1 ; var g, n ; if ( "string" == typeof b ) b = f ( b ) ; else if ( b instanceof CKEDITOR . style ) { if ( b . toAllowedContentRules ) return this . allow ( b . toAllowedContentRules ( this . editor ) , c , d ) ; g = b . getDefinition ( ) ; b = { } ; d = g. attributes ; b [ g . element ] = g = { styles : g . styles , requiredStyles : g . styles && CKEDITOR . tools . object . keys ( g . styles ) } ;
d && ( d = D( d ) , g . classes = d [ "class" ] ? d [ "class" ] . split ( /\s+/ ) : null , g. requiredClasses = g . classes , delete d [ "class" ] , g. attributes = d , g . requiredAttributes = d && CKEDITOR . tools . object . keys ( d ) ) } else if ( CKEDITOR . tools . isArray ( b ) ) { for ( g= 0 ; g < b . length ; ++ g ) n = this . allow ( b [ g ] , c , d ) ; return n } a ( this , b , c , this . allowedContent , this . _ . allowedRules ) ; return ! 0 } , applyTo : function ( a , b , c , e ) { if ( this . disabled ) return ! 1 ; var d = this , g= [ ] , f = this . editor && this . editor . config . protectedSource , n, h = ! 1 , x = { doFilter : ! c , doTransform : ! 0 , doCallbacks : ! 0 , toHtml : b } ;
a . forEach ( function ( a ) { if ( a . type == CKEDITOR . NODE _ELEMENT ) { if ( "off" == a . attributes [ "data-cke-filter" ] ) return ! 1 ; if ( ! b || "span" != a . name || ! ~ CKEDITOR . tools . object . keys ( a . attributes ) . join ( "|" ) . indexOf ( "data-cke-" ) ) if ( n= y ( d , a , g , x ) , n & 1 ) h = ! 0 ; else if ( n & 2 ) return ! 1 } else if ( a . type == CKEDITOR . NODE _COMMENT && a . value . match ( /^\{cke_protected\}(?!\{C\})/ ) ) { var c ; a : { var e = decodeURIComponent ( a . value . replace ( /^\{cke_protected\}/ , "" ) ) ; c = [ ] ; var t , C, m ; if ( f ) for ( C = 0 ; C < f . length ; ++ C ) if ( ( m = e . match ( f [ C ] ) ) && m [ 0 ] . length == e . length ) { c =
! 0 ; break a } e = CKEDITOR . htmlParser . fragment . fromHtml ( e ) ; 1 == e . children . length && ( t = e . children [ 0 ] ) . type == CKEDITOR . NODE _ELEMENT && y( d , t , c , x ) ; c = ! c . length } c || g . push ( a ) } } , null , ! 0 ) ; g. length && ( h = ! 0 ) ; var C ; a = [ ] ; e = I [ e || ( this . editor ? this . editor . enterMode : CKEDITOR . ENTER _P ) ] ; for ( var D; c = g . pop ( ) ; ) c . type == CKEDITOR . NODE _ELEMENT ? G ( c , e , a ) : c . remove ( ) ; for ( ; C = a . pop ( ) ; ) if ( c = C . el , c . parent ) switch ( D = t [ c . parent . name ] || t . span , C . check ) { case "it" : t . $removeEmpty [ c . name ] && ! c . children . length ? G ( c , e , a ) : m ( c ) || G ( c , e , a ) ; break ; case "el-up" : c . parent . type ==
CKEDITOR . NODE _DOCUMENT _FRAGMENT || D[ c . name ] || G ( c , e , a ) ; break ; case "parent-down" : c . parent . type == CKEDITOR . NODE _DOCUMENT _FRAGMENT || D[ c . name ] || G ( c . parent , e , a ) } return h } , checkFeature : function ( a ) { if ( this . disabled || ! a ) return ! 0 ; a . toFeature && ( a = a . toFeature ( this . editor ) ) ; return ! a . requiredContent || this . check ( a . requiredContent ) } , disable : function ( ) { this . disabled = ! 0 } , disallow : function ( b ) { if ( ! e ( this , b , ! 0 ) ) return ! 1 ; "string" == typeof b && ( b = f ( b ) ) ; a ( this , b , null , this . disallowedContent , this . _ . disallowedRules ) ; return ! 0 } ,
" " + I [ c . shiftEnterMode ] , "default" , 1 ) , this . disallow ( c . config . disallowedContent ) ) } else this . customConfig = ! 1 , this . allow ( b || a , "default" , 1 ) } ; CKEDITOR . filter . instances = { } ; CKEDITOR . filter . prototype = { allow : function ( b , c , d ) { if ( ! e ( this , b , d ) ) return ! 1 ; var f, p ; if ( "string" == typeof b ) b = g ( b ) ; else if ( b instanceof CKEDITOR . style ) { if ( b . toAllowedContentRules ) return this . allow ( b . toAllowedContentRules ( this . editor ) , c , d ) ; f = b . getDefinition ( ) ; b = { } ; d = f. attributes ; b [ f . element ] = f = { styles : f . styles , requiredStyles : f . styles && CKEDITOR . tools . object . keys ( f . styles ) } ;
d && ( d = H( d ) , f . classes = d [ "class" ] ? d [ "class" ] . split ( /\s+/ ) : null , f. requiredClasses = f . classes , delete d [ "class" ] , f. attributes = d , f . requiredAttributes = d && CKEDITOR . tools . object . keys ( d ) ) } else if ( CKEDITOR . tools . isArray ( b ) ) { for ( f= 0 ; f < b . length ; ++ f ) p = this . allow ( b [ f ] , c , d ) ; return p } a ( this , b , c , this . allowedContent , this . _ . allowedRules ) ; return ! 0 } , applyTo : function ( a , b , c , e ) { if ( this . disabled ) return ! 1 ; var d = this , f= [ ] , g = this . editor && this . editor . config . protectedSource , p, r = ! 1 , A = { doFilter : ! c , doTransform : ! 0 , doCallbacks : ! 0 , toHtml : b } ;
a . forEach ( function ( a ) { if ( a . type == CKEDITOR . NODE _ELEMENT ) { if ( "off" == a . attributes [ "data-cke-filter" ] ) return ! 1 ; if ( ! b || "span" != a . name || ! ~ CKEDITOR . tools . object . keys ( a . attributes ) . join ( "|" ) . indexOf ( "data-cke-" ) ) if ( p= z ( d , a , f , A ) , p & 1 ) r = ! 0 ; else if ( p & 2 ) return ! 1 } else if ( a . type == CKEDITOR . NODE _COMMENT && a . value . match ( /^\{cke_protected\}(?!\{C\})/ ) ) { var c ; a : { var e = decodeURIComponent ( a . value . replace ( /^\{cke_protected\}/ , "" ) ) ; c = [ ] ; var t , h, k ; if ( g ) for ( h = 0 ; h < g . length ; ++ h ) if ( ( k = e . match ( g [ h ] ) ) && k [ 0 ] . length == e . length ) { c =
! 0 ; break a } e = CKEDITOR . htmlParser . fragment . fromHtml ( e ) ; 1 == e . children . length && ( t = e . children [ 0 ] ) . type == CKEDITOR . NODE _ELEMENT && z( d , t , c , A ) ; c = ! c . length } c || f . push ( a ) } } , null , ! 0 ) ; f. length && ( r = ! 0 ) ; var h ; a = [ ] ; e = I [ e || ( this . editor ? this . editor . enterMode : CKEDITOR . ENTER _P ) ] ; for ( var k; c = f . pop ( ) ; ) c . type == CKEDITOR . NODE _ELEMENT ? F ( c , e , a ) : c . remove ( ) ; for ( ; h = a . pop ( ) ; ) if ( c = h . el , c . parent ) switch ( k = t [ c . parent . name ] || t . span , h . check ) { case "it" : t . $removeEmpty [ c . name ] && ! c . children . length ? F ( c , e , a ) : m ( c ) || F ( c , e , a ) ; break ; case "el-up" : c . parent . type ==
CKEDITOR . NODE _DOCUMENT _FRAGMENT || k[ c . name ] || F ( c , e , a ) ; break ; case "parent-down" : c . parent . type == CKEDITOR . NODE _DOCUMENT _FRAGMENT || k[ c . name ] || F ( c . parent , e , a ) } return r } , checkFeature : function ( a ) { if ( this . disabled || ! a ) return ! 0 ; a . toFeature && ( a = a . toFeature ( this . editor ) ) ; return ! a . requiredContent || this . check ( a . requiredContent ) } , disable : function ( ) { this . disabled = ! 0 } , disallow : function ( b ) { if ( ! e ( this , b , ! 0 ) ) return ! 1 ; "string" == typeof b && ( b = g ( b ) ) ; a ( this , b , null , this . disallowedContent , this . _ . disallowedRules ) ; return ! 0 } ,
addContentForms : function ( a ) { if ( ! this . disabled && a ) { var b , c , e = [ ] , d ; for ( b = 0 ; b < a . length && ! d ; ++ b ) c = a [ b ] , ( "string" == typeof c || c instanceof CKEDITOR . style ) && this . check ( c ) && ( d = c ) ; if ( d ) { for ( b = 0 ; b < a . length ; ++ b ) e . push ( K ( a [ b ] , d ) ) ; this . addTransformations ( e ) } } } , addElementCallback : function ( a ) { this . elementCallbacks || ( this . elementCallbacks = [ ] ) ; this . elementCallbacks . push ( a ) } , addFeature : function ( a ) { if ( this . disabled || ! a ) return ! 0 ; a . toFeature && ( a = a . toFeature ( this . editor ) ) ; this . allow ( a . allowedContent , a . name ) ; this . addTransformations ( a . contentTransformations ) ;
this . addContentForms ( a . contentForms ) ; return a . requiredContent && ( this . customConfig || this . disallowedContent . length ) ? this . check ( a . requiredContent ) : ! 0 } , addTransformations : function ( a ) { var b , c ; if ( ! this . disabled && a ) { var e = this . _ . transformations , d ; for ( d = 0 ; d < a . length ; ++ d ) { b = a [ d ] ; var g= void 0 , f = void 0 , n = void 0 , t = void 0 , h = void 0 , x = void 0 ; c = [ ] ; for ( f= 0 ; f < b . length ; ++ f ) n = b [ f ] , "string" == typeof n ? ( n = n . split ( /\s*:\s*/ ) , t = n [ 0 ] , h = null , x = n [ 1 ] ) : ( t = n . check , h = n . left , x = n . right ) , g || ( g = n , g = g . element ? g . element : t ? t . match ( /^([a-z0-9]+)/i ) [ 0 ] :
g . left . getDefinition ( ) . element ) , h instanceof CKEDITOR . style && ( h = E ( h ) ) , c . push ( { check : t == g? null : t , left : h , right : "string" == typeof x ? z ( x ) : x } ) ; b = g ; e [ b ] || ( e [ b ] = [ ] ) ; e [ b ] . push ( c ) } } } , check : function ( a , b , c ) { if ( this . disabled ) return ! 0 ; if ( CKEDITOR . tools . isArray ( a ) ) { for ( var e = a . length ; e -- ; ) if ( this . check ( a [ e ] , b , c ) ) return ! 0 ; return ! 1 } var d , g ; if ( "string" == typeof a ) { g = a + "\x3c" + ( ! 1 === b ? "0" : "1" ) + ( c ? "1" : "0" ) + "\x3e" ; if ( g in this . _ . cachedChecks ) return this . _ . cachedChecks [ g] ; d = f ( a ) . $1 ; var n = d . styles , e = d . classes ; d . name = d . elements ;
d . classes = e = e ? e . split ( /\s*,\s*/ ) : [ ] ; d . styles = q( n ) ; d . attributes = q ( d . attributes ) ; d . children = [ ] ; e . length && ( d . attributes [ "class" ] = e . join ( " " ) ) ; n && ( d . attributes . style = CKEDITOR . tools . writeCssText ( d . styles ) ) } else d = a . getDefinition ( ) , n = d . styles , e = d . attributes || { } , n && ! CKEDITOR . tools . isEmpty ( n) ? ( n = D ( n ) , e . style = CKEDITOR . tools . writeCssText ( n, ! 0 ) ) : n = { } , d = { name : d . element , attributes : e , classes : e [ "class" ] ? e [ "class" ] . split ( /\s+/ ) : [ ] , styles : n, children : [ ] } ; var n = CKEDITOR . tools . clone ( d ) , t = [ ] , h; if ( ! 1 !== b && ( h = this . _ . transformations [ d . name ] ) ) { for ( e =
0 ; e < h. length ; ++ e ) p ( this , d , h [ e ] ) ; r ( d ) } y ( this , n , t , { doFilter : ! 0 , doTransform : ! 1 !== b , skipRequired : ! c , skipFinalValidation : ! c } ) ; 0 < t . length ? c = ! 1 : ( ( b = d . attributes [ "class" ] ) && ( d . attributes [ "class" ] = d . attributes [ "class" ] . split ( " " ) . sort ( ) . join ( " " ) ) , c = CKEDITOR . tools . objectCompare ( d . attributes , n . attributes , ! 0 ) , b && ( d . attributes [ "class" ] = b ) ) ; "string" == typeof a && ( this . _ . cachedChecks [ g ] = c ) ; return c } , getAllowedEnterMode : function ( ) { var a = [ "p" , "div" , "br" ] , b = { p : CKEDITOR . ENTER _P , div : CKEDITOR . ENTER _DIV , br : CKEDITOR . ENTER _BR } ;
return function ( c , e ) { var d = a . slice ( ) , g ; if ( this . check ( I [ c ] ) ) return c ; for ( e || ( d = d . reverse ( ) ) ; g = d . pop ( ) ; ) if ( this . check ( g) ) return b [ g ] ; return CKEDITOR . ENTER _BR } } ( ) , clone : function ( ) { var a = new CKEDITOR . filter , b = CKEDITOR . tools . clone ; a . allowedContent = b ( this . allowedContent ) ; a . _ . allowedRules = b ( this . _ . allowedRules ) ; a . disallowedContent = b ( this . disallowedContent ) ; a . _ . disallowedRules = b ( this . _ . disallowedRules ) ; a . _ . transformations = b ( this . _ . transformations ) ; a . disabled = this . disabled ; a . editor = this . editor ; return a } , destroy : function ( ) { delete CKEDITOR . filter . instances [ this . id ] ;
delete this . _ ; delete this . allowedContent ; delete this . disallowedContent } } ; var T = { styles : 1 , attributes : 1 , classes : 1 } , N = { styles : "requiredStyles" , attributes : "requiredAttributes" , classes : "requiredClasses" } , x = /^([a-z0-9\-*\s]+)((?:\s*\{[!\w\-,\s\*]+\}\s*|\s*\[[!\w\-,\s\*]+\]\s*|\s*\([!\w\-,\s\*]+\)\s*){0,3})(?:;\s*|$)/i , H = { styles : /{([^}]+)}/ , attrs : /\[([^\]]+)\]/ , classes : /\(([^\)]+)\)/ } , M= /^cke:(object|embed|param)$/ , n = /^(object|embed|param)$/ , A ; A = CKEDITOR . filter . transformationsTools = { sizeToStyle : function ( a ) { this . lengthToStyle ( a ,
this . addContentForms ( a . contentForms ) ; return a . requiredContent && ( this . customConfig || this . disallowedContent . length ) ? this . check ( a . requiredContent ) : ! 0 } , addTransformations : function ( a ) { var b , c ; if ( ! this . disabled && a ) { var e = this . _ . transformations , d ; for ( d = 0 ; d < a . length ; ++ d ) { b = a [ d ] ; var f= void 0 , g = void 0 , p = void 0 , t = void 0 , r = void 0 , A = void 0 ; c = [ ] ; for ( g= 0 ; g < b . length ; ++ g ) p = b [ g ] , "string" == typeof p ? ( p = p . split ( /\s*:\s*/ ) , t = p [ 0 ] , r = null , A = p [ 1 ] ) : ( t = p . check , r = p . left , A = p . right ) , f || ( f = p , f = f . element ? f . element : t ? t . match ( /^([a-z0-9]+)/i ) [ 0 ] :
f . left . getDefinition ( ) . element ) , r instanceof CKEDITOR . style && ( r = D ( r ) ) , c . push ( { check : t == f? null : t , left : r , right : "string" == typeof A ? B ( A ) : A } ) ; b = f ; e [ b ] || ( e [ b ] = [ ] ) ; e [ b ] . push ( c ) } } } , check : function ( a , b , c ) { if ( this . disabled ) return ! 0 ; if ( CKEDITOR . tools . isArray ( a ) ) { for ( var e = a . length ; e -- ; ) if ( this . check ( a [ e ] , b , c ) ) return ! 0 ; return ! 1 } var d , f ; if ( "string" == typeof a ) { f = a + "\x3c" + ( ! 1 === b ? "0" : "1" ) + ( c ? "1" : "0" ) + "\x3e" ; if ( f in this . _ . cachedChecks ) return this . _ . cachedChecks [ f] ; d = g ( a ) . $1 ; var p = d . styles , e = d . classes ; d . name = d . elements ;
d . classes = e = e ? e . split ( /\s*,\s*/ ) : [ ] ; d . styles = l( p ) ; d . attributes = l ( d . attributes ) ; d . children = [ ] ; e . length && ( d . attributes [ "class" ] = e . join ( " " ) ) ; p && ( d . attributes . style = CKEDITOR . tools . writeCssText ( d . styles ) ) } else d = a . getDefinition ( ) , p = d . styles , e = d . attributes || { } , p && ! CKEDITOR . tools . isEmpty ( p) ? ( p = H ( p ) , e . style = CKEDITOR . tools . writeCssText ( p, ! 0 ) ) : p = { } , d = { name : d . element , attributes : e , classes : e [ "class" ] ? e [ "class" ] . split ( /\s+/ ) : [ ] , styles : p, children : [ ] } ; var p = CKEDITOR . tools . clone ( d ) , t = [ ] , r; if ( ! 1 !== b && ( r = this . _ . transformations [ d . name ] ) ) { for ( e =
0 ; e < r. length ; ++ e ) q ( this , d , r [ e ] ) ; v ( d ) } z ( this , p , t , { doFilter : ! 0 , doTransform : ! 1 !== b , skipRequired : ! c , skipFinalValidation : ! c } ) ; 0 < t . length ? c = ! 1 : ( ( b = d . attributes [ "class" ] ) && ( d . attributes [ "class" ] = d . attributes [ "class" ] . split ( " " ) . sort ( ) . join ( " " ) ) , c = CKEDITOR . tools . objectCompare ( d . attributes , p . attributes , ! 0 ) , b && ( d . attributes [ "class" ] = b ) ) ; "string" == typeof a && ( this . _ . cachedChecks [ f ] = c ) ; return c } , getAllowedEnterMode : function ( ) { var a = [ "p" , "div" , "br" ] , b = { p : CKEDITOR . ENTER _P , div : CKEDITOR . ENTER _DIV , br : CKEDITOR . ENTER _BR } ;
return function ( c , e ) { var d = a . slice ( ) , f ; if ( this . check ( I [ c ] ) ) return c ; for ( e || ( d = d . reverse ( ) ) ; f = d . pop ( ) ; ) if ( this . check ( f) ) return b [ f ] ; return CKEDITOR . ENTER _BR } } ( ) , clone : function ( ) { var a = new CKEDITOR . filter , b = CKEDITOR . tools . clone ; a . allowedContent = b ( this . allowedContent ) ; a . _ . allowedRules = b ( this . _ . allowedRules ) ; a . disallowedContent = b ( this . disallowedContent ) ; a . _ . disallowedRules = b ( this . _ . disallowedRules ) ; a . _ . transformations = b ( this . _ . transformations ) ; a . disabled = this . disabled ; a . editor = this . editor ; return a } , destroy : function ( ) { delete CKEDITOR . filter . instances [ this . id ] ;
delete this . _ ; delete this . allowedContent ; delete this . disallowedContent } } ; var N = { styles : 1 , attributes : 1 , classes : 1 } , L = { styles : "requiredStyles" , attributes : "requiredAttributes" , classes : "requiredClasses" } , r = /^([a-z0-9\-*\s]+)((?:\s*\{[!\w\-,\s\*]+\}\s*|\s*\[[!\w\-,\s\*]+\]\s*|\s*\([!\w\-,\s\*]+\)\s*){0,3})(?:;\s*|$)/i , E = { styles : /{([^}]+)}/ , attrs : /\[([^\]]+)\]/ , classes : /\(([^\)]+)\)/ } , S= /^cke:(object|embed|param)$/ , p = /^(object|embed|param)$/ , C ; C = CKEDITOR . filter . transformationsTools = { sizeToStyle : function ( a ) { this . lengthToStyle ( a ,
"width" ) ; this . lengthToStyle ( a , "height" ) } , sizeToAttribute : function ( a ) { this . lengthToAttribute ( a , "width" ) ; this . lengthToAttribute ( a , "height" ) } , lengthToStyle : function ( a , b , c ) { c = c || b ; if ( ! ( c in a . styles ) ) { var e = a . attributes [ b ] ; e && ( /^\d+$/ . test ( e ) && ( e += "px" ) , a . styles [ c ] = e ) } delete a . attributes [ b ] } , lengthToAttribute : function ( a , b , c ) { c = c || b ; if ( ! ( c in a . attributes ) ) { var e = a . styles [ b ] , d = e && e . match ( /^(\d+)(?:\.\d*)?px$/ ) ; d ? a . attributes [ c ] = d [ 1 ] : "cke-test" == e && ( a . attributes [ c ] = "cke-test" ) } delete a . styles [ b ] } , alignmentToStyle : function ( a ) { if ( ! ( "float" in
a . styles ) ) { var b = a . attributes . align ; if ( "left" == b || "right" == b ) a . styles [ "float" ] = b } delete a . attributes . align } , alignmentToAttribute : function ( a ) { if ( ! ( "align" in a . attributes ) ) { var b = a . styles [ "float" ] ; if ( "left" == b || "right" == b ) a . attributes . align = b } delete a . styles [ "float" ] } , splitBorderShorthand : function ( a ) { if ( a . styles . border ) { var b = CKEDITOR . tools . style . parse . border ( a . styles . border ) ; b . color && ( a . styles [ "border-color" ] = b . color ) ; b . style && ( a . styles [ "border-style" ] = b . style ) ; b . width && ( a . styles [ "border-width" ] = b . width ) ;
delete a . styles . border } } , listTypeToStyle : function ( a ) { if ( a . attributes . type ) switch ( a . attributes . type ) { case "a" : a . styles [ "list-style-type" ] = "lower-alpha" ; break ; case "A" : a . styles [ "list-style-type" ] = "upper-alpha" ; break ; case "i" : a . styles [ "list-style-type" ] = "lower-roman" ; break ; case "I" : a . styles [ "list-style-type" ] = "upper-roman" ; break ; case "1" : a . styles [ "list-style-type" ] = "decimal" ; break ; default : a . styles [ "list-style-type" ] = a . attributes . type } } , splitMarginShorthand : function ( a ) { function b ( e ) { a . styles [ "margin-top" ] =
c [ e [ 0 ] ] ; a . styles [ "margin-right" ] = c [ e [ 1 ] ] ; a . styles [ "margin-bottom" ] = c [ e [ 2 ] ] ; a . styles [ "margin-left" ] = c [ e [ 3 ] ] } if ( a . styles . margin ) { var c = a . styles . margin . match ( /(auto|0|(?:\-?[\.\d]+(?:\w+|%)))/g ) || [ "0px" ] ; switch ( c . length ) { case 1 : b ( [ 0 , 0 , 0 , 0 ] ) ; break ; case 2 : b ( [ 0 , 1 , 0 , 1 ] ) ; break ; case 3 : b ( [ 0 , 1 , 2 , 1 ] ) ; break ; case 4 : b ( [ 0 , 1 , 2 , 3 ] ) } delete a . styles . margin } } , matchesStyle : u , transform : function ( a , b ) { if ( "string" == typeof b ) a . name = b ; else { var c = b . getDefinition ( ) , e = c . styles , d = c . attributes , g, f , n , t ; a . name = c . element ; for ( g in d ) if ( "class" ==
g ) for ( c = a . classes . join ( "|" ) , n= d [ g ] . split ( /\s+/ ) ; t = n . pop ( ) ; ) - 1 == c . indexOf ( t ) && a . classes . push ( t ) ; else a . attributes [ g] = d [ g ] ; for ( f in e ) a . styles [ f ] = e [ f ] } } } } ) ( ) ;
c [ e [ 0 ] ] ; a . styles [ "margin-right" ] = c [ e [ 1 ] ] ; a . styles [ "margin-bottom" ] = c [ e [ 2 ] ] ; a . styles [ "margin-left" ] = c [ e [ 3 ] ] } if ( a . styles . margin ) { var c = a . styles . margin . match ( /(auto|0|(?:\-?[\.\d]+(?:\w+|%)))/g ) || [ "0px" ] ; switch ( c . length ) { case 1 : b ( [ 0 , 0 , 0 , 0 ] ) ; break ; case 2 : b ( [ 0 , 1 , 0 , 1 ] ) ; break ; case 3 : b ( [ 0 , 1 , 2 , 1 ] ) ; break ; case 4 : b ( [ 0 , 1 , 2 , 3 ] ) } delete a . styles . margin } } , matchesStyle : u , transform : function ( a , b ) { if ( "string" == typeof b ) a . name = b ; else { var c = b . getDefinition ( ) , e = c . styles , d = c . attributes , f, g , p , t ; a . name = c . element ; for ( f in d ) if ( "class" ==
f ) for ( c = a . classes . join ( "|" ) , p= d [ f ] . split ( /\s+/ ) ; t = p . pop ( ) ; ) - 1 == c . indexOf ( t ) && a . classes . push ( t ) ; else a . attributes [ f] = d [ f ] ; for ( g in e ) a . styles [ g ] = e [ g ] } } } } ) ( ) ;
( function ( ) { CKEDITOR . focusManager = function ( a ) { if ( a . focusManager ) return a . focusManager ; this . hasFocus = ! 1 ; this . currentActive = null ; this . _ = { editor : a } ; return this } ; CKEDITOR . focusManager . _ = { blurDelay : 200 } ; CKEDITOR . focusManager . prototype = { focus : function ( a ) { this . _ . timer && clearTimeout ( this . _ . timer ) ; a && ( this . currentActive = a ) ; this . hasFocus || this . _ . locked || ( ( a = CKEDITOR . currentInstance ) && a . focusManager . blur ( 1 ) , this . hasFocus = ! 0 , ( a = this . _ . editor . container ) && a . addClass ( "cke_focus" ) , this . _ . editor . fire ( "focus" ) ) } , lock : function ( ) { this . _ . locked =
1 } , unlock : function ( ) { delete this . _ . locked } , blur : function ( a ) { function d ( ) { if ( this . hasFocus ) { this . hasFocus = ! 1 ; var a = this . _ . editor . container ; a && a . removeClass ( "cke_focus" ) ; this . _ . editor . fire ( "blur" ) } } if ( ! this . _ . locked ) { this . _ . timer && clearTimeout ( this . _ . timer ) ; var b = CKEDITOR . focusManager . _ . blurDelay ; a || ! b ? d . call ( this ) : this . _ . timer = CKEDITOR . tools . setTimeout ( function ( ) { delete this . _ . timer ; d . call ( this ) } , b , this ) } } , add : function ( a , d ) { var b = a . getCustomData ( "focusmanager" ) ; if ( ! b || b != this ) { b && b . remove ( a ) ; var b =
"focus" , c = "blur" ; d && ( CKEDITOR . env . ie ? ( b = "focusin" , c = "focusout" ) : CKEDITOR . event . useCapture = 1 ) ; var g = { blur : function ( ) { a . equals ( this . currentActive ) && this . blur ( ) } , focus : function ( ) { this . focus ( a ) } } ; a . on ( b , g . focus , this ) ; a . on ( c , g . blur , this ) ; d && ( CKEDITOR . event . useCapture = 0 ) ; a . setCustomData ( "focusmanager" , this ) ; a . setCustomData ( "focusmanager_handlers" , g ) } } , remove : function ( a ) { a . removeCustomData ( "focusmanager" ) ; var d = a . removeCustomData ( "focusmanager_handlers" ) ; a . removeListener ( "blur" , d . blur ) ; a . removeListener ( "focus" ,
"focus" , c = "blur" ; d && ( CKEDITOR . env . ie ? ( b = "focusin" , c = "focusout" ) : CKEDITOR . event . useCapture = 1 ) ; var f = { blur : function ( ) { a . equals ( this . currentActive ) && this . blur ( ) } , focus : function ( ) { this . focus ( a ) } } ; a . on ( b , f . focus , this ) ; a . on ( c , f . blur , this ) ; d && ( CKEDITOR . event . useCapture = 0 ) ; a . setCustomData ( "focusmanager" , this ) ; a . setCustomData ( "focusmanager_handlers" , f ) } } , remove : function ( a ) { a . removeCustomData ( "focusmanager" ) ; var d = a . removeCustomData ( "focusmanager_handlers" ) ; a . removeListener ( "blur" , d . blur ) ; a . removeListener ( "focus" ,
d . focus ) } } } ) ( ) ; CKEDITOR . keystrokeHandler = function ( a ) { if ( a . keystrokeHandler ) return a . keystrokeHandler ; this . keystrokes = { } ; this . blockedKeystrokes = { } ; this . _ = { editor : a } ; return this } ;
( function ( ) { var a , d = function ( b ) { b = b . data ; var d = b . getKeystroke ( ) , e = this . keystrokes [ d ] , h = this . _ . editor ; a = ! 1 === h . fire ( "key" , { keyCode : d , domEvent : b } ) ; a || ( e && ( a = ! 1 !== h . execCommand ( e , { from : "keystrokeHandler" } ) ) , a || ( a = ! ! this . blockedKeystrokes [ d ] ) ) ; a && b . preventDefault ( ! 0 ) ; return ! a } , b = function ( b ) { a && ( a = ! 1 , b . data . preventDefault ( ! 0 ) ) } ; CKEDITOR . keystrokeHandler . prototype = { attach : function ( a ) { a . on ( "keydown" , d , this ) ; if ( CKEDITOR . env . gecko && CKEDITOR . env . mac ) a . on ( "keypress" , b , this ) } } } ) ( ) ;
( function ( ) { var a , d = function ( b ) { b = b . data ; var d = b . getKeystroke ( ) , e = this . keystrokes [ d ] , k = this . _ . editor ; a = ! 1 === k . fire ( "key" , { keyCode : d , domEvent : b } ) ; a || ( e && ( a = ! 1 !== k . execCommand ( e , { from : "keystrokeHandler" } ) ) , a || ( a = ! ! this . blockedKeystrokes [ d ] ) ) ; a && b . preventDefault ( ! 0 ) ; return ! a } , b = function ( b ) { a && ( a = ! 1 , b . data . preventDefault ( ! 0 ) ) } ; CKEDITOR . keystrokeHandler . prototype = { attach : function ( a ) { a . on ( "keydown" , d , this ) ; if ( CKEDITOR . env . gecko && CKEDITOR . env . mac ) a . on ( "keypress" , b , this ) } } } ) ( ) ;
( function ( ) { CKEDITOR . lang = { languages : { af : 1 , ar : 1 , az : 1 , bg : 1 , bn : 1 , bs : 1 , ca : 1 , cs : 1 , cy : 1 , da : 1 , de : 1 , "de-ch" : 1 , el : 1 , "en-au" : 1 , "en-ca" : 1 , "en-gb" : 1 , en : 1 , eo : 1 , es : 1 , "es-mx" : 1 , et : 1 , eu : 1 , fa : 1 , fi : 1 , fo : 1 , "fr-ca" : 1 , fr : 1 , gl : 1 , gu : 1 , he : 1 , hi : 1 , hr : 1 , hu : 1 , id : 1 , is : 1 , it : 1 , ja : 1 , ka : 1 , km : 1 , ko : 1 , ku : 1 , lt : 1 , lv : 1 , mk : 1 , mn : 1 , ms : 1 , nb : 1 , nl : 1 , no : 1 , oc : 1 , pl : 1 , "pt-br" : 1 , pt : 1 , ro : 1 , ru : 1 , si : 1 , sk : 1 , sl : 1 , sq : 1 , "sr-latn" : 1 , sr : 1 , sv : 1 , th : 1 , tr : 1 , tt : 1 , ug : 1 , uk : 1 , vi : 1 , "zh-cn" : 1 , zh : 1 } , rtl : { ar : 1 , fa : 1 , he : 1 , ku : 1 , ug : 1 } , load : function ( a , d , b ) { a && CKEDITOR . lang . languages [ a ] ||
( a = this . detect ( d , a ) ) ; var c = this ; d = function ( ) { c [ a ] . dir = c . rtl [ a ] ? "rtl" : "ltr" ; b ( a , c [ a ] ) } ; this [ a ] ? d ( ) : CKEDITOR . scriptLoader . load ( CKEDITOR . getUrl ( "lang/" + a + ".js" ) , d , this ) } , detect : function ( a , d ) { var b = this . languages ; d = d || navigator . userLanguage || navigator . language || a ; var c = d . toLowerCase ( ) . match ( /([a-z]+)(?:-([a-z]+))?/ ) , g = c [ 1 ] , c = c [ 2 ] ; b [ g+ "-" + c ] ? g = g + "-" + c : b [ g ] || ( g = null ) ; CKEDITOR . lang . detect = g? function ( ) { return g } : function ( a ) { return a } ; return g || a } } } ) ( ) ;
CKEDITOR . scriptLoader = function ( ) { var a = { } , d = { } ; return { load : function ( b , c , g, e ) { var h = "string" == typeof b ; h && ( b = [ b ] ) ; g || ( g = CKEDITOR ) ; var k = b . length , l = k , q = [ ] , f = [ ] , w = function ( a ) { c && ( h? c . call ( g , a ) : c . call ( g , q , f ) ) } ; if ( 0 === l ) w ( ! 0 ) ; else { var B = function ( a , b ) { ( b ? q: f ) . push ( a ) ; 0 >= -- l && ( e && CKEDITOR . document . getDocumentElement ( ) . removeStyle ( "cursor" ) , w( b ) ) } , y = function ( b , c ) { a [ b ] = 1 ; var e = d [ b ] ; delete d [ b ] ; for ( var g= 0 ; g < e . length ; g ++ ) e [ g ] ( b , c ) } , F = function ( b ) { if ( a [ b ] ) B ( b , ! 0 ) ; else { var e = d [ b ] || ( d [ b ] = [ ] ) ; e . push ( B ) ; if ( ! ( 1 < e . length ) ) { var g =
new CKEDITOR . dom . element ( "script" ) ; g . setAttributes ( { type : "text/javascript" , src : b } ) ; c && ( CKEDITOR . env . ie && ( 8 >= CKEDITOR . env . version || CKEDITOR . env . ie9Compat ) ? g . $ . onreadystatechange = function ( ) { if ( "loaded" == g. $ . readyState || "complete" == g . $ . readyState ) g . $ . onreadystatechange = null , y ( b , ! 0 ) } : ( g . $ . onload = function ( ) { setTimeout ( function ( ) { g. $ . onload = null ; g . $ . onerror = null ; y ( b , ! 0 ) } , 0 ) } , g . $ . onerror = function ( ) { g. $ . onload = null ; g . $ . onerror = null ; y ( b , ! 1 ) } ) ) ; g . appendTo ( CKEDITOR . document . getHead ( ) ) } } } ; e && CKEDITOR . document . getDocumentElement ( ) . setStyle ( "cursor" ,
"wait" ) ; for ( var r= 0 ; r < k ; r ++ ) F ( b [ r ] ) } } , queue : function ( ) { function a ( ) { var b ; ( b = c [ 0 ] ) && this . load ( b . scriptUrl , b . callback , CKEDITOR , 0 ) } var c = [ ] ; return function ( d , e ) { var h = this ; c . push ( { scriptUrl : d , callback : function ( ) { e && e . apply ( this , arguments ) ; c . shift ( ) ; a . call ( h ) } } ) ; 1 == c . length && a . call ( this ) } } ( ) } } ( ) ; CKEDITOR . resourceManager = function ( a , d ) { this . basePath = a ; this . fileName = d ; this . registered = { } ; this . loaded = { } ; this . externals = { } ; this . _ = { waitingList : { } } } ;
( a = this . detect ( d , a ) ) ; var c = this ; d = function ( ) { c [ a ] . dir = c . rtl [ a ] ? "rtl" : "ltr" ; b ( a , c [ a ] ) } ; this [ a ] ? d ( ) : CKEDITOR . scriptLoader . load ( CKEDITOR . getUrl ( "lang/" + a + ".js" ) , d , this ) } , detect : function ( a , d ) { var b = this . languages ; d = d || navigator . userLanguage || navigator . language || a ; var c = d . toLowerCase ( ) . match ( /([a-z]+)(?:-([a-z]+))?/ ) , f = c [ 1 ] , c = c [ 2 ] ; b [ f+ "-" + c ] ? f = f + "-" + c : b [ f ] || ( f = null ) ; CKEDITOR . lang . detect = f? function ( ) { return f } : function ( a ) { return a } ; return f || a } } } ) ( ) ;
CKEDITOR . scriptLoader = function ( ) { var a = { } , d = { } ; return { load : function ( b , c , f, e ) { var k = "string" == typeof b ; k && ( b = [ b ] ) ; f || ( f = CKEDITOR ) ; var h = b . length , n = h , l = [ ] , g = [ ] , x = function ( a ) { c && ( k? c . call ( f , a ) : c . call ( f , l , g ) ) } ; if ( 0 === n ) x ( ! 0 ) ; else { var y = function ( a , b ) { ( b ? l: g ) . push ( a ) ; 0 >= -- n && ( e && CKEDITOR . document . getDocumentElement ( ) . removeStyle ( "cursor" ) , x( b ) ) } , z = function ( b , c ) { a [ b ] = 1 ; var e = d [ b ] ; delete d [ b ] ; for ( var f= 0 ; f < e . length ; f ++ ) e [ f ] ( b , c ) } , G = function ( b ) { if ( a [ b ] ) y ( b , ! 0 ) ; else { var e = d [ b ] || ( d [ b ] = [ ] ) ; e . push ( y ) ; if ( ! ( 1 < e . length ) ) { var f =
new CKEDITOR . dom . element ( "script" ) ; f . setAttributes ( { type : "text/javascript" , src : b } ) ; c && ( CKEDITOR . env . ie && ( 8 >= CKEDITOR . env . version || CKEDITOR . env . ie9Compat ) ? f . $ . onreadystatechange = function ( ) { if ( "loaded" == f. $ . readyState || "complete" == f . $ . readyState ) f . $ . onreadystatechange = null , z ( b , ! 0 ) } : ( f . $ . onload = function ( ) { setTimeout ( function ( ) { f. $ . onload = null ; f . $ . onerror = null ; z ( b , ! 0 ) } , 0 ) } , f . $ . onerror = function ( ) { f. $ . onload = null ; f . $ . onerror = null ; z ( b , ! 1 ) } ) ) ; f . appendTo ( CKEDITOR . document . getHead ( ) ) } } } ; e && CKEDITOR . document . getDocumentElement ( ) . setStyle ( "cursor" ,
"wait" ) ; for ( var v= 0 ; v < h ; v ++ ) G ( b [ v ] ) } } , queue : function ( ) { function a ( ) { var b ; ( b = c [ 0 ] ) && this . load ( b . scriptUrl , b . callback , CKEDITOR , 0 ) } var c = [ ] ; return function ( d , e ) { var k = this ; c . push ( { scriptUrl : d , callback : function ( ) { e && e . apply ( this , arguments ) ; c . shift ( ) ; a . call ( k ) } } ) ; 1 == c . length && a . call ( this ) } } ( ) } } ( ) ; CKEDITOR . resourceManager = function ( a , d ) { this . basePath = a ; this . fileName = d ; this . registered = { } ; this . loaded = { } ; this . externals = { } ; this . _ = { waitingList : { } } } ;
CKEDITOR . resourceManager . prototype = { add : function ( a , d ) { if ( this . registered [ a ] ) throw Error ( '[CKEDITOR.resourceManager.add] The resource name "' + a + '" is already registered.' ) ; var b = this . registered [ a ] = d || { } ; b . name = a ; b . path = this . getPath ( a ) ; CKEDITOR . fire ( a + CKEDITOR . tools . capitalize ( this . fileName ) + "Ready" , b ) ; return this . get ( a ) } , get : function ( a ) { return this . registered [ a ] || null } , getPath : function ( a ) { var d = this . externals [ a ] ; return CKEDITOR . getUrl ( d && d . dir || this . basePath + a + "/" ) } , getFilePath : function ( a ) { var d = this . externals [ a ] ;
return CKEDITOR . getUrl ( this . getPath ( a ) + ( d ? d . file : this . fileName + ".js" ) ) } , addExternal : function ( a , d , b ) { b || ( d = d . replace ( /[^\/]+$/ , function ( a ) { b = a ; return "" } ) ) ; b = b || this . fileName + ".js" ; a = a . split ( "," ) ; for ( var c = 0 ; c < a . length ; c ++ ) this . externals [ a [ c ] ] = { dir : d , file : b } } , load : function ( a , d , b ) { CKEDITOR . tools . isArray ( a ) || ( a = a ? [ a ] : [ ] ) ; for ( var c = this . loaded , g = this . registered , e = [ ] , h= { } , k = { } , l = 0 ; l < a . length ; l ++ ) { var q = a [ l ] ; if ( q ) if ( c [ q ] || g [ q ] ) k [ q ] = this . get ( q ) ; else { var f = this . getFilePath ( q ) ; e . push ( f ) ; f in h || ( h [ f ] = [ ] ) ; h [ f ] . push ( q ) } } CKEDITOR . scriptLoader . load ( e ,
function ( a , e ) { if ( e . length ) throw Error ( '[CKEDITOR.resourceManager.load] Resource name "' + h [ e [ 0 ] ] . join ( "," ) + '" was not found at "' + e [ 0 ] + '".' ) ; for ( var g= 0 ; g < a . length ; g ++ ) for ( var f = h [ a [ g ] ] , l = 0 ; l < f . length ; l ++ ) { var m = f[ l ] ; k [ m ] = this . get ( m ) ; c [ m ] = 1 } d . call ( b , k ) } , this ) } } ; CKEDITOR . plugins = new CKEDITOR . resourceManager ( "plugins/" , "plugin" ) ;
CKEDITOR . plugins . load = CKEDITOR . tools . override ( CKEDITOR . plugins . load , function ( a ) { var d = { } ; return function ( b , c , g) { var e = { } , h = function ( b ) { a . call ( this , b , function ( a ) { CKEDITOR . tools . extend ( e , a ) ; var b = [ ] , f; for ( f in a ) { var k = a [ f ] , B = k && k . requires ; if ( ! d [ f ] ) { if ( k . icons ) for ( var y = k . icons . split ( "," ) , F = y . length ; F -- ; ) CKEDITOR . skin . addIcon ( y[ F ] , k . path + "icons/" + ( CKEDITOR . env . hidpi && k . hidpi ? "hidpi/" : "" ) + y[ F ] + ".png" ) ; k . isSupportedEnvironment = k . isSupportedEnvironment || function ( ) { return ! 0 } ; d [ f] = 1 } if ( B ) for ( B . split && ( B =
B. split ( "," ) ) , k = 0 ; k < B . length ; k ++ ) e [ B [ k ] ] || b . push ( B [ k ] ) } if ( b . length ) h . call ( this , b ) ; else { for ( f in e ) k = e [ f ] , k . onLoad && ! k . onLoad . _called && ( ! 1 === k. onLoad ( ) && delete e [ f ] , k . onLoad . _called = 1 ) ; c && c . call ( g || window , e ) } } , this ) } ; h . call ( this , b ) } } ) ; CKEDITOR . plugins . setLang = function ( a , d , b ) { var c = this . get ( a ) ; a = c . langEntries || ( c . langEntries = { } ) ; c = c . lang || ( c . lang = [ ] ) ; c . split && ( c = c . split ( "," ) ) ; - 1 == CKEDITOR . tools . indexOf ( c , d ) && c . push ( d ) ; a [ d ] = b } ;
return CKEDITOR . getUrl ( this . getPath ( a ) + ( d ? d . file : this . fileName + ".js" ) ) } , addExternal : function ( a , d , b ) { b || ( d = d . replace ( /[^\/]+$/ , function ( a ) { b = a ; return "" } ) ) ; b = b || this . fileName + ".js" ; a = a . split ( "," ) ; for ( var c = 0 ; c < a . length ; c ++ ) this . externals [ a [ c ] ] = { dir : d , file : b } } , load : function ( a , d , b ) { CKEDITOR . tools . isArray ( a ) || ( a = a ? [ a ] : [ ] ) ; for ( var c = this . loaded , f = this . registered , e = [ ] , k= { } , h = { } , n = 0 ; n < a . length ; n ++ ) { var l = a [ n ] ; if ( l ) if ( c [ l ] || f [ l ] ) h [ l ] = this . get ( l ) ; else { var g = this . getFilePath ( l ) ; e . push ( g ) ; g in k || ( k [ g ] = [ ] ) ; k [ g ] . push ( l ) } } CKEDITOR . scriptLoader . load ( e ,
function ( a , e ) { if ( e . length ) throw Error ( '[CKEDITOR.resourceManager.load] Resource name "' + k [ e [ 0 ] ] . join ( "," ) + '" was not found at "' + e [ 0 ] + '".' ) ; for ( var f= 0 ; f < a . length ; f ++ ) for ( var g = k [ a [ f ] ] , l = 0 ; l < g . length ; l ++ ) { var m = g[ l ] ; h [ m ] = this . get ( m ) ; c [ m ] = 1 } d . call ( b , h ) } , this ) } } ; CKEDITOR . plugins = new CKEDITOR . resourceManager ( "plugins/" , "plugin" ) ;
CKEDITOR . plugins . load = CKEDITOR . tools . override ( CKEDITOR . plugins . load , function ( a ) { var d = { } ; return function ( b , c , f) { var e = { } , k = function ( b ) { a . call ( this , b , function ( a ) { CKEDITOR . tools . extend ( e , a ) ; var b = [ ] , g; for ( g in a ) { var h = a [ g ] , y = h && h . requires ; if ( ! d [ g ] ) { if ( h . icons ) for ( var z = h . icons . split ( "," ) , G = z . length ; G -- ; ) CKEDITOR . skin . addIcon ( z[ G ] , h . path + "icons/" + ( CKEDITOR . env . hidpi && h . hidpi ? "hidpi/" : "" ) + z[ G ] + ".png" ) ; h . isSupportedEnvironment = h . isSupportedEnvironment || function ( ) { return ! 0 } ; d [ g] = 1 } if ( y ) for ( y . split && ( y =
y. split ( "," ) ) , h = 0 ; h < y . length ; h ++ ) e [ y [ h ] ] || b . push ( y [ h ] ) } if ( b . length ) k . call ( this , b ) ; else { for ( g in e ) h = e [ g ] , h . onLoad && ! h . onLoad . _called && ( ! 1 === h. onLoad ( ) && delete e [ g ] , h . onLoad . _called = 1 ) ; c && c . call ( f || window , e ) } } , this ) } ; k . call ( this , b ) } } ) ; CKEDITOR . plugins . setLang = function ( a , d , b ) { var c = this . get ( a ) ; a = c . langEntries || ( c . langEntries = { } ) ; c = c . lang || ( c . lang = [ ] ) ; c . split && ( c = c . split ( "," ) ) ; - 1 == CKEDITOR . tools . indexOf ( c , d ) && c . push ( d ) ; a [ d ] = b } ;
CKEDITOR . ui = function ( a ) { if ( a . ui ) return a . ui ; this . items = { } ; this . instances = { } ; this . editor = a ; this . _ = { handlers : { } } ; return this } ;
CKEDITOR . ui . prototype = { add : function ( a , d , b ) { b . name = a . toLowerCase ( ) ; var c = this . items [ a ] = { type : d , command : b . command || null , args : Array . prototype . slice . call ( arguments , 2 ) } ; CKEDITOR . tools . extend ( c , b ) } , get : function ( a ) { return this . instances [ a ] } , create : function ( a ) { var d = this . items [ a ] , b = d && this . _ . handlers [ d . type ] , c = d && d . command && this . editor . getCommand ( d . command ) , b = b && b . create . apply ( this , d . args ) ; this . instances [ a ] = b ; c && c . uiItems . push ( b ) ; b && ! b . type && ( b . type = d . type ) ; return b } , addHandler : function ( a , d ) { this . _ . handlers [ a ] =
d } , space : function ( a ) { return CKEDITOR . document . getById ( this . spaceId ( a ) ) } , spaceId : function ( a ) { return this . editor . id + "_" + a } } ; CKEDITOR . event . implementOn ( CKEDITOR . ui ) ;
( function ( ) { function a ( a , g, f ) { CKEDITOR . event . call ( this ) ; a = a && CKEDITOR . tools . clone ( a ) ; if ( void 0 !== g) { if ( ! ( g instanceof CKEDITOR . dom . element ) ) throw Error ( "Expect element of type CKEDITOR.dom.element." ) ; if ( ! f ) throw Error ( "One of the element modes must be specified." ) ; if ( CKEDITOR . env . ie && CKEDITOR . env . quirks && f == CKEDITOR . ELEMENT _MODE _INLINE ) throw Error ( "Inline element mode is not supported on IE quirks." ) ; if ( ! b ( g, f ) ) throw Error ( 'The specified element mode is not supported on element: "' + g . getName ( ) + '".' ) ;
this . element = g; this . elementMode = f ; this . name = this . elementMode != CKEDITOR . ELEMENT _MODE _APPENDTO && ( g. getId ( ) || g . getNameAtt ( ) ) } else this . elementMode = CKEDITOR . ELEMENT _MODE _NONE ; this . _ = { } ; this . commands = { } ; this . templates = { } ; this . name = this . name || d ( ) ; this . id = CKEDITOR . tools . getNextId ( ) ; this . status = "unloaded" ; this . config = CKEDITOR . tools . prototypedCopy ( CKEDITOR . config ) ; this . ui = new CKEDITOR . ui ( this ) ; this . focusManager = new CKEDITOR . focusManager ( this ) ; this . keystrokeHandler = new CKEDITOR . keystrokeHandler ( this ) ; this . on ( "readOnly" ,
( function ( ) { function a ( a , f, g ) { CKEDITOR . event . call ( this ) ; a = a && CKEDITOR . tools . clone ( a ) ; if ( void 0 !== f) { if ( ! ( f instanceof CKEDITOR . dom . element ) ) throw Error ( "Expect element of type CKEDITOR.dom.element." ) ; if ( ! g ) throw Error ( "One of the element modes must be specified." ) ; if ( CKEDITOR . env . ie && CKEDITOR . env . quirks && g == CKEDITOR . ELEMENT _MODE _INLINE ) throw Error ( "Inline element mode is not supported on IE quirks." ) ; if ( ! b ( f, g ) ) throw Error ( 'The specified element mode is not supported on element: "' + f . getName ( ) + '".' ) ;
this . element = f; this . elementMode = g ; this . name = this . elementMode != CKEDITOR . ELEMENT _MODE _APPENDTO && ( f. getId ( ) || f . getNameAtt ( ) ) } else this . elementMode = CKEDITOR . ELEMENT _MODE _NONE ; this . _ = { } ; this . commands = { } ; this . templates = { } ; this . name = this . name || d ( ) ; this . id = CKEDITOR . tools . getNextId ( ) ; this . status = "unloaded" ; this . config = CKEDITOR . tools . prototypedCopy ( CKEDITOR . config ) ; this . ui = new CKEDITOR . ui ( this ) ; this . focusManager = new CKEDITOR . focusManager ( this ) ; this . keystrokeHandler = new CKEDITOR . keystrokeHandler ( this ) ; this . on ( "readOnly" ,
c ) ; this . on ( "selectionChange" , function ( a ) { e ( this , a . data . path ) } ) ; this . on ( "activeFilterChange" , function ( ) { e ( this , this . elementPath ( ) , ! 0 ) } ) ; this . on ( "mode" , c ) ; CKEDITOR . dom . selection . setupEditorOptimization ( this ) ; this . on ( "instanceReady" , function ( ) { if ( this . config . startupFocus ) { if ( "end" === this . config . startupFocus ) { var a = this . createRange ( ) ; a . selectNodeContents ( this . editable ( ) ) ; a . shrink ( CKEDITOR . SHRINK _ELEMENT , ! 0 ) ; a . collapse ( ) ; this . getSelection ( ) . selectRanges ( [ a ] ) } this . focus ( ) } } ) ; CKEDITOR . fire ( "instanceCreated" ,
null , this ) ; CKEDITOR . add ( this ) ; CKEDITOR . tools . setTimeout ( function ( ) { this . isDestroyed ( ) || this . isDetached ( ) || k ( this , a ) } , 0 , this ) } function d ( ) { do var a = "editor" + ++ F ; while ( CKEDITOR . instances [ a ] ) ; return a } function b ( a , b ) { return b == CKEDITOR . ELEMENT _MODE _INLINE ? a . is ( CKEDITOR . dtd . $editable ) || a . is ( "textarea" ) : b == CKEDITOR . ELEMENT _MODE _REPLACE ? ! a . is ( CKEDITOR . dtd . $nonBodyContent ) : 1 } function c ( ) { var a = this . commands , b ; for ( b in a ) g ( this , a [ b ] ) } function g ( a , b ) { b [ b . startDisabled ? "disable" : a . readOnly && ! b . readOnly ? "disable" :
b . modes [ a . mode ] ? "enable" : "disable" ] ( ) } function e ( a , b , c ) { if ( b ) { var e , d , g = a . commands ; for ( d in g) e = g [ d ] , ( c || e . contextSensitive ) && e . refresh ( a , b ) } } function h ( a ) { var b = a . config . customConfig ; if ( ! b ) return ! 1 ; var b = CKEDITOR . getUrl ( b ) , c = r[ b ] || ( r [ b ] = { } ) ; c . fn ? ( c . fn . call ( a , a . config ) , CKEDITOR . getUrl ( a . config . customConfig ) != b && h ( a ) || a . fireOnce ( "customConfigLoaded" ) ) : CKEDITOR . scriptLoader . queue ( b , function ( ) { c . fn = c . fn || CKEDITOR . editorConfig || function ( ) { } ; h ( a ) } ) ; return ! 0 } function k ( a , b ) { a . on ( "customConfigLoaded" , function ( ) { if ( b ) { if ( b . on ) for ( var c in b . on ) a . on ( c ,
null , this ) ; CKEDITOR . add ( this ) ; CKEDITOR . tools . setTimeout ( function ( ) { this . isDestroyed ( ) || this . isDetached ( ) || h ( this , a ) } , 0 , this ) } function d ( ) { do var a = "editor" + ++ G ; while ( CKEDITOR . instances [ a ] ) ; return a } function b ( a , b ) { return b == CKEDITOR . ELEMENT _MODE _INLINE ? a . is ( CKEDITOR . dtd . $editable ) || a . is ( "textarea" ) : b == CKEDITOR . ELEMENT _MODE _REPLACE ? ! a . is ( CKEDITOR . dtd . $nonBodyContent ) : 1 } function c ( ) { var a = this . commands , b ; for ( b in a ) f ( this , a [ b ] ) } function f ( a , b ) { b [ b . startDisabled ? "disable" : a . readOnly && ! b . readOnly ? "disable" :
b . modes [ a . mode ] ? "enable" : "disable" ] ( ) } function e ( a , b , c ) { if ( b ) { var e , d , f = a . commands ; for ( d in f) e = f [ d ] , ( c || e . contextSensitive ) && e . refresh ( a , b ) } } function k ( a ) { var b = a . config . customConfig ; if ( ! b ) return ! 1 ; var b = CKEDITOR . getUrl ( b ) , c = v[ b ] || ( v [ b ] = { } ) ; c . fn ? ( c . fn . call ( a , a . config ) , CKEDITOR . getUrl ( a . config . customConfig ) != b && k ( a ) || a . fireOnce ( "customConfigLoaded" ) ) : CKEDITOR . scriptLoader . queue ( b , function ( ) { c . fn = c . fn || CKEDITOR . editorConfig || function ( ) { } ; k ( a ) } ) ; return ! 0 } function h ( a , b ) { a . on ( "customConfigLoaded" , function ( ) { if ( b ) { if ( b . on ) for ( var c in b . on ) a . on ( c ,
b . on [ c ] ) ; CKEDITOR . tools . extend ( a . config , b , ! 0 ) ; delete a . config . on } c = a . config ; a . readOnly = c . readOnly ? ! 0 : a . elementMode == CKEDITOR . ELEMENT _MODE _INLINE ? a . element . is ( "textarea" ) ? a . element . hasAttribute ( "disabled" ) || a . element . hasAttribute ( "readonly" ) : a . element . isReadOnly ( ) : a . elementMode == CKEDITOR . ELEMENT _MODE _REPLACE ? a . element . hasAttribute ( "disabled" ) || a . element . hasAttribute ( "readonly" ) : ! 1 ; a . blockless = a . elementMode == CKEDITOR . ELEMENT _MODE _INLINE ? ! ( a . element . is ( "textarea" ) || CKEDITOR . dtd [ a . element . getName ( ) ] . p ) :
! 1 ; a . tabIndex = c . tabIndex || a . element && a . element . getAttribute ( "tabindex" ) || 0 ; a . activeEnterMode = a . enterMode = a . blockless ? CKEDITOR . ENTER _BR : c . enterMode ; a . activeShiftEnterMode = a . shiftEnterMode = a . blockless ? CKEDITOR . ENTER _BR : c . shiftEnterMode ; c . skin && ( CKEDITOR . skinName = c . skin ) ; a . fireOnce ( "configLoaded" ) ; a . dataProcessor = new CKEDITOR . htmlDataProcessor ( a ) ; a . filter = a . activeFilter = new CKEDITOR . filter ( a ) ; l ( a ) } ) ; b && null != b . customConfig && ( a . config . customConfig = b . customConfig ) ; h ( a ) || a . fireOnce ( "customConfigLoaded" ) }
function l ( a ) { CKEDITOR . skin . loadPart ( "editor" , function ( ) { q( a ) } ) } function q ( a ) { CKEDITOR . lang . load ( a . config . language , a . config . defaultLanguage , function ( b , c ) { var e = a . config . title , d = a . config . applicationTitle ; a . langCode = b ; a . lang = CKEDITOR . tools . prototypedCopy ( c ) ; a . title = "string" == typeof e || ! 1 === e ? e : [ a . lang . editor , a . name ] . join ( ", " ) ; a . applicationTitle = "string" == typeof d || ! 1 === d ? d : [ a . lang . application , a . name ] . join ( ", " ) ; a . config . contentsLangDirection || ( a . config . contentsLangDirection = a . elementMode == CKEDITOR . ELEMENT _MODE _INLINE ?
a . element . getDirection ( 1 ) : a . lang . dir ) ; a . fire ( "langLoaded" ) ; f( a ) } ) } function f ( a ) { a . getStylesSet ( function ( b ) { a . once ( "loaded" , function ( ) { a . fire ( "stylesSet" , { styles : b } ) } , null , null , 1 ) ; w( a ) } ) } function w ( a ) { function b ( a ) { if ( ! a ) return "" ; CKEDITOR . tools . isArray ( a ) && ( a = a . join ( "," ) ) ; return a . replace ( /\s/g , "" ) } var c = a . config , e = b ( c . plugins ) , d = b ( c . extraPlugins ) , g = b ( c . removePlugins ) ; if ( d ) var f = new RegExp ( "(?:^|,)(?:" + d . replace ( /,/g , "|" ) + ")(?\x3d,|$)" , "g" ) , e = e . replace ( f , "" ) , e = e + ( "," + d ) ; if ( g ) var h = new RegExp ( "(?:^|,)(?:" +
g . replace ( /,/g , "|" ) + ")(?\x3d,|$)" , "g" ) , e = e . replace ( h , "" ) ; CKEDITOR . env . air && ( e += ",adobeair" ) ; CKEDITOR . plugins . load ( e . split ( "," ) , function ( b ) { var e = [ ] , d = [ ] , g = [ ] ; a . plugins = CKEDITOR . tools . extend ( { } , a . plugins , b ) ; for ( var f in b ) { var k = b [ f ] , l = k . lang , N = null , x = k . requires , H ; CKEDITOR . tools . isArray ( x ) && ( x = x . join ( "," ) ) ; if ( x&& ( H = x . match ( h ) ) ) for ( ; x= H . pop ( ) ; ) CKEDITOR . error ( "editor-plugin-required" , { plugin : x . replace ( "," , "" ) , requiredBy : f} ) ; l && ! a . lang [ f ] && ( l . split && ( l = l . split ( "," ) ) , 0 <= CKEDITOR . tools . indexOf ( l , a . langCode ) ?
N= a . langCode : ( N = a . langCode . replace ( /-.*/ , "" ) , N= N != a . langCode && 0 <= CKEDITOR . tools . indexOf ( l, N ) ? N : 0 <= CKEDITOR . tools . indexOf ( l, "en" ) ? "en" : l [ 0 ] ) , k . langEntries && k . langEntries [ N] ? ( a . lang [ f ] = k . langEntries [ N ] , N = null ) : g . push ( CKEDITOR . getUrl ( k . path + "lang/" + N + ".js" ) ) ) ; d . push ( N ) ; e . push ( k ) } CKEDITOR . scriptLoader . load ( g , function ( ) { if ( ! a . isDestroyed ( ) && ! a . isDetached ( ) ) { for ( var b = [ "beforeInit" , "init" , "afterInit" ] , g= 0 ; g < b . length ; g ++ ) for ( var f = 0 ; f < e . length ; f ++ ) { var h = e [ f ] ; 0 === g && d [ f ] && h . lang && h . langEntries && ( a . lang [ h . name ] =
h. langEntries [ d [ f ] ] ) ; if ( h [ b [ g ] ] ) h [ b [ g ] ] ( a ) } a . fireOnce ( "pluginsLoaded" ) ; c . keystrokes && a . setKeystroke ( a . config . keystrokes ) ; for ( f= 0 ; f < a . config . blockedKeystrokes . length ; f ++ ) a . keystrokeHandler . blockedKeystrokes [ a . config . blockedKeystrokes [ f ] ] = 1 ; a . status = "loaded" ; a . fireOnce ( "loaded" ) ; CKEDITOR . fire ( "instanceLoaded" , null , a ) } } ) } ) } function B ( ) { var a = this . element ; if ( a && this . elementMode != CKEDITOR . ELEMENT _MODE _APPENDTO ) { var b = this . getData ( ) ; this . config . htmlEncodeOutput && ( b = CKEDITOR . tools . htmlEncode ( b ) ) ; a . is ( "textarea" ) ?
a . setValue ( b ) : a . setHtml ( b ) ; return ! 0 } return ! 1 } function y ( a , b ) { function c ( a ) { var b = a . startContainer , e = a . endContainer , d = b . is && b . is ( "tr" ) , g = b . is && b . is ( "td" ) ; a = g && b . equals ( e ) && a . endOffset === b . getChildCount ( ) ; b = g && 1 === b . getChildCount ( ) && "img" === b . getChildren ( ) . getItem ( 0 ) . getName ( ) ; return d || a && ! b ? ! 0 : ! 1 } function e ( a ) { var b = a . startContainer ; return b . is ( "tr" ) ? a . cloneContents ( ) : b . clone ( ! 0 ) } for ( var d = new CKEDITOR . dom . documentFragment , g, f , h , k = 0 ; k < a . length ; k ++ ) { var z= a [ k ] , t = z . startContainer . getAscendant ( "tr" ,
! 0 ) ; c ( z) ? ( g || ( g = t . getAscendant ( "table" ) . clone ( ) , g . append ( t . getAscendant ( { thead : 1 , tbody : 1 , tfoot : 1 } ) . clone ( ) ) , d . append ( g) , g = g . findOne ( "thead, tbody, tfoot" ) ) , f&& f . equals ( t ) || ( f = t , h = t . clone ( ) , g . append ( h ) ) , h . append ( e ( z) ) ) : d . append ( z . cloneContents ( ) ) } return g ? d : b . getHtmlFromRange ( a [ 0 ] ) } a . prototype = CKEDITOR . editor . prototype ; CKEDITOR . editor = a ; var F= 0 , r = { } ; CKEDITOR . tools . extend ( CKEDITOR . editor . prototype , { plugins : { detectConflict : function ( a , b ) { for ( var c = 0 ; c < b . length ; c ++ ) { var e = b [ c ] ; if ( this [ e ] ) return CKEDITOR . warn ( "editor-plugin-conflict" ,
{ plugin : a , replacedWith : e } ) , ! 0 } return ! 1 } } , addCommand : function ( a , b ) { b . name = a . toLowerCase ( ) ; var c = b instanceof CKEDITOR . command ? b : new CKEDITOR . command ( this , b ) ; this . mode && g ( this , c ) ; return this . commands [ a ] = c } , _attachToForm : function ( ) { function a ( b ) { c . updateElement ( ) ; c . _ . required && ! e . getValue ( ) && ! 1 === c . fire ( "required" ) && b . data . preventDefault ( ) } function b ( a ) { return ! ! ( a && a . call && a . apply ) } var c = this , e = c . element , d = new CKEDITOR . dom . element ( e . $ . form ) ; e . is ( "textarea" ) && d && ( d . on ( "submit" , a ) , b ( d . $ . submit ) && ( d . $ . submit =
CKEDITOR . tools . override ( d . $ . submit , function ( b ) { return function ( ) { a ( ) ; b . apply ? b . apply ( this ) : b ( ) } } ) ) , c . on ( "destroy" , function ( ) { d . removeListener ( "submit" , a ) } ) ) } , destroy : function ( a ) { var b = CKEDITOR . filter . instances , c = this ; this . fire ( "beforeDestroy" ) ; ! a && B . call ( this ) ; this . editable ( null ) ; this . filter && delete this . filter ; CKEDITOR . tools . array . forEach ( CKEDITOR . tools . object . keys ( b ) , function ( a ) { a = b [ a ] ; c === a . editor && a . destroy ( ) } ) ; delete this . activeFilter ; this . status = "destroyed" ; this . fire ( "destroy" ) ; this . removeAllListeners ( ) ;
! 1 ; a . tabIndex = c . tabIndex || a . element && a . element . getAttribute ( "tabindex" ) || 0 ; a . activeEnterMode = a . enterMode = a . blockless ? CKEDITOR . ENTER _BR : c . enterMode ; a . activeShiftEnterMode = a . shiftEnterMode = a . blockless ? CKEDITOR . ENTER _BR : c . shiftEnterMode ; c . skin && ( CKEDITOR . skinName = c . skin ) ; a . fireOnce ( "configLoaded" ) ; a . dataProcessor = new CKEDITOR . htmlDataProcessor ( a ) ; a . filter = a . activeFilter = new CKEDITOR . filter ( a ) ; n ( a ) } ) ; b && null != b . customConfig && ( a . config . customConfig = b . customConfig ) ; k ( a ) || a . fireOnce ( "customConfigLoaded" ) }
function n ( a ) { CKEDITOR . skin . loadPart ( "editor" , function ( ) { l( a ) } ) } function l ( a ) { CKEDITOR . lang . load ( a . config . language , a . config . defaultLanguage , function ( b , c ) { var e = a . config . title , d = a . config . applicationTitle ; a . langCode = b ; a . lang = CKEDITOR . tools . prototypedCopy ( c ) ; a . title = "string" == typeof e || ! 1 === e ? e : [ a . lang . editor , a . name ] . join ( ", " ) ; a . applicationTitle = "string" == typeof d || ! 1 === d ? d : [ a . lang . application , a . name ] . join ( ", " ) ; a . config . contentsLangDirection || ( a . config . contentsLangDirection = a . elementMode == CKEDITOR . ELEMENT _MODE _INLINE ?
a . element . getDirection ( 1 ) : a . lang . dir ) ; a . fire ( "langLoaded" ) ; g( a ) } ) } function g ( a ) { a . getStylesSet ( function ( b ) { a . once ( "loaded" , function ( ) { a . fire ( "stylesSet" , { styles : b } ) } , null , null , 1 ) ; x( a ) } ) } function x ( a ) { function b ( a ) { if ( ! a ) return "" ; CKEDITOR . tools . isArray ( a ) && ( a = a . join ( "," ) ) ; return a . replace ( /\s/g , "" ) } var c = a . config , e = b ( c . plugins ) , d = b ( c . extraPlugins ) , f = b ( c . removePlugins ) ; if ( d ) var g = new RegExp ( "(?:^|,)(?:" + d . replace ( /,/g , "|" ) + ")(?\x3d,|$)" , "g" ) , e = e . replace ( g , "" ) , e = e + ( "," + d ) ; if ( f ) var h = new RegExp ( "(?:^|,)(?:" +
f . replace ( /,/g , "|" ) + ")(?\x3d,|$)" , "g" ) , e = e . replace ( h , "" ) ; CKEDITOR . env . air && ( e += ",adobeair" ) ; CKEDITOR . plugins . load ( e . split ( "," ) , function ( b ) { var e = [ ] , d = [ ] , f = [ ] ; a . plugins = CKEDITOR . tools . extend ( { } , a . plugins , b ) ; for ( var g in b ) { var k = b [ g ] , N = k . lang , L = null , r = k . requires , E ; CKEDITOR . tools . isArray ( r ) && ( r = r . join ( "," ) ) ; if ( r&& ( E = r . match ( h ) ) ) for ( ; r= E . pop ( ) ; ) CKEDITOR . error ( "editor-plugin-required" , { plugin : r . replace ( "," , "" ) , requiredBy : g} ) ; N && ! a . lang [ g ] && ( N . split && ( N = N . split ( "," ) ) , 0 <= CKEDITOR . tools . indexOf ( N , a . langCode ) ?
L= a . langCode : ( L = a . langCode . replace ( /-.*/ , "" ) , L= L != a . langCode && 0 <= CKEDITOR . tools . indexOf ( N, L ) ? L : 0 <= CKEDITOR . tools . indexOf ( N, "en" ) ? "en" : N [ 0 ] ) , k . langEntries && k . langEntries [ L] ? ( a . lang [ g ] = k . langEntries [ L ] , L = null ) : f . push ( CKEDITOR . getUrl ( k . path + "lang/" + L + ".js" ) ) ) ; d . push ( L ) ; e . push ( k ) } CKEDITOR . scriptLoader . load ( f , function ( ) { if ( ! a . isDestroyed ( ) && ! a . isDetached ( ) ) { for ( var b = [ "beforeInit" , "init" , "afterInit" ] , f= 0 ; f < b . length ; f ++ ) for ( var g = 0 ; g < e . length ; g ++ ) { var r = e [ g ] ; 0 === f && d [ g ] && r . lang && r . langEntries && ( a . lang [ r . name ] =
r. langEntries [ d [ g ] ] ) ; if ( r [ b [ f ] ] ) r [ b [ f ] ] ( a ) } a . fireOnce ( "pluginsLoaded" ) ; c . keystrokes && a . setKeystroke ( a . config . keystrokes ) ; for ( g= 0 ; g < a . config . blockedKeystrokes . length ; g ++ ) a . keystrokeHandler . blockedKeystrokes [ a . config . blockedKeystrokes [ g ] ] = 1 ; a . status = "loaded" ; a . fireOnce ( "loaded" ) ; CKEDITOR . fire ( "instanceLoaded" , null , a ) } } ) } ) } function y ( ) { var a = this . element ; if ( a && this . elementMode != CKEDITOR . ELEMENT _MODE _APPENDTO ) { var b = this . getData ( ) ; this . config . htmlEncodeOutput && ( b = CKEDITOR . tools . htmlEncode ( b ) ) ; a . is ( "textarea" ) ?
a . setValue ( b ) : a . setHtml ( b ) ; return ! 0 } return ! 1 } function z ( a , b ) { function c ( a ) { var b = a . startContainer , e = a . endContainer , d = b . is && b . is ( "tr" ) , f = b . is && b . is ( "td" ) ; a = f && b . equals ( e ) && a . endOffset === b . getChildCount ( ) ; b = f && 1 === b . getChildCount ( ) && "img" === b . getChildren ( ) . getItem ( 0 ) . getName ( ) ; return d || a && ! b ? ! 0 : ! 1 } function e ( a ) { var b = a . startContainer ; return b . is ( "tr" ) ? a . cloneContents ( ) : b . clone ( ! 0 ) } for ( var d = new CKEDITOR . dom . documentFragment , f, g , h , k = 0 ; k < a . length ; k ++ ) { var B= a [ k ] , t = B . startContainer . getAscendant ( "tr" ,
! 0 ) ; c ( B) ? ( f || ( f = t . getAscendant ( "table" ) . clone ( ) , f . append ( t . getAscendant ( { thead : 1 , tbody : 1 , tfoot : 1 } ) . clone ( ) ) , d . append ( f) , f = f . findOne ( "thead, tbody, tfoot" ) ) , g&& g . equals ( t ) || ( g = t , h = t . clone ( ) , f . append ( h ) ) , h . append ( e ( B) ) ) : d . append ( B . cloneContents ( ) ) } return f ? d : b . getHtmlFromRange ( a [ 0 ] ) } a . prototype = CKEDITOR . editor . prototype ; CKEDITOR . editor = a ; var G= 0 , v = { } ; CKEDITOR . tools . extend ( CKEDITOR . editor . prototype , { plugins : { detectConflict : function ( a , b ) { for ( var c = 0 ; c < b . length ; c ++ ) { var e = b [ c ] ; if ( this [ e ] ) return CKEDITOR . warn ( "editor-plugin-conflict" ,
{ plugin : a , replacedWith : e } ) , ! 0 } return ! 1 } } , addCommand : function ( a , b ) { b . name = a . toLowerCase ( ) ; var c = b instanceof CKEDITOR . command ? b : new CKEDITOR . command ( this , b ) ; this . mode && f ( this , c ) ; return this . commands [ a ] = c } , _attachToForm : function ( ) { function a ( b ) { c . updateElement ( ) ; c . _ . required && ! e . getValue ( ) && ! 1 === c . fire ( "required" ) && b . data . preventDefault ( ) } function b ( a ) { return ! ! ( a && a . call && a . apply ) } var c = this , e = c . element , d = new CKEDITOR . dom . element ( e . $ . form ) ; e . is ( "textarea" ) && d && ( d . on ( "submit" , a ) , b ( d . $ . submit ) && ( d . $ . submit =
CKEDITOR . tools . override ( d . $ . submit , function ( b ) { return function ( ) { a ( ) ; b . apply ? b . apply ( this ) : b ( ) } } ) ) , c . on ( "destroy" , function ( ) { d . removeListener ( "submit" , a ) } ) ) } , destroy : function ( a ) { var b = CKEDITOR . filter . instances , c = this ; this . fire ( "beforeDestroy" ) ; ! a && y . call ( this ) ; this . editable ( null ) ; this . filter && delete this . filter ; CKEDITOR . tools . array . forEach ( CKEDITOR . tools . object . keys ( b ) , function ( a ) { a = b [ a ] ; c === a . editor && a . destroy ( ) } ) ; delete this . activeFilter ; this . status = "destroyed" ; this . fire ( "destroy" ) ; this . removeAllListeners ( ) ;
CKEDITOR . remove ( this ) ; CKEDITOR . fire ( "instanceDestroyed" , null , this ) } , elementPath : function ( a ) { if ( ! a ) { a = this . getSelection ( ) ; if ( ! a ) return null ; a = a . getStartElement ( ) } return a ? new CKEDITOR . dom . elementPath ( a , this . editable ( ) ) : null } , createRange : function ( ) { var a = this . editable ( ) ; return a ? new CKEDITOR . dom . range ( a ) : null } , execCommand : function ( a , b ) { var c = this . getCommand ( a ) , e = { name : a , commandData : b || { } , command : c } ; return c && c . state != CKEDITOR . TRISTATE _DISABLED && ! 1 !== this . fire ( "beforeCommandExec" , e ) && ( e . returnValue =
c . exec ( e . commandData ) , ! c . async && ! 1 !== this . fire ( "afterCommandExec" , e ) ) ? e . returnValue : ! 1 } , getCommand : function ( a ) { return this . commands [ a ] } , getData : function ( a ) { ! a && this . fire ( "beforeGetData" ) ; var b = this . _ . data ; "string" != typeof b && ( b = ( b = this . element ) && this . elementMode == CKEDITOR . ELEMENT _MODE _REPLACE ? b . is ( "textarea" ) ? b . getValue ( ) : b . getHtml ( ) : "" ) ; b = { dataValue : b } ; ! a && this . fire ( "getData" , b ) ; return b . dataValue } , getSnapshot : function ( ) { var a = this . fire ( "getSnapshot" ) ; "string" != typeof a && ( a = ( a = this . element ) && this . elementMode ==
CKEDITOR . ELEMENT _MODE _REPLACE ? a . is ( "textarea" ) ? a . getValue ( ) : a . getHtml ( ) : "" ) ; return a } , loadSnapshot : function ( a ) { this . fire ( "loadSnapshot" , a ) } , setData : function ( a , b , c ) { var e = ! 0 , d = b ; b && "object" == typeof b && ( c = b . internal , d = b . callback , e = ! b . noSnapshot ) ; ! c && e && this . fire ( "saveSnapshot" ) ; if ( d || ! c ) this . once ( "dataReady" , function ( a ) { ! c && e && this . fire ( "saveSnapshot" ) ; d && d . call ( a . editor ) } ) ; a = { dataValue : a } ; ! c && this . fire ( "setData" , a ) ; this . _ . data = a . dataValue ; ! c && this . fire ( "afterSetData" , a ) } , setReadOnly : function ( a ) { a =
null == a || a ; this . readOnly != a && ( this . readOnly = a , this . keystrokeHandler . blockedKeystrokes [ 8 ] = + a , this . editable ( ) . setReadOnly ( a ) , this . fire ( "readOnly" ) ) } , insertHtml : function ( a , b , c ) { this . fire ( "insertHtml" , { dataValue : a , mode : b , range : c } ) } , insertText : function ( a ) { this . fire ( "insertText" , a ) } , insertElement : function ( a ) { this . fire ( "insertElement" , a ) } , getSelectedHtml : function ( a ) { var b = this . editable ( ) , c = this . getSelection ( ) , c = c && c . getRanges ( ) ; if ( ! b || ! c || 0 === c . length ) return null ; b = y ( c , b ) ; return a ? b . getHtml ( ) : b } , extractSelectedHtml : function ( a ,
b ) { var c = this . editable ( ) , e = this . getSelection ( ) . getRanges ( ) , d = new CKEDITOR . dom . documentFragment , g ; if ( ! c || 0 === e . length ) return null ; for ( g= 0 ; g < e . length ; g ++ ) d . append ( c . extractHtmlFromRange ( e [ g ] , b ) ) ; b || this . getSelection ( ) . selectRanges ( [ e [ 0 ] ] ) ; return a ? d . getHtml ( ) : d } , focus : function ( ) { this . fire ( "beforeFocus" ) } , checkDirty : function ( ) { return "ready" == this . status && this . _ . previousValue !== this . getSnapshot ( ) } , resetDirty : function ( ) { this . _ . previousValue = this . getSnapshot ( ) } , updateElement : function ( ) { return B . call ( this ) } ,
setKeystroke : function ( ) { for ( var a = this . keystrokeHandler . keystrokes , b = CKEDITOR . tools . isArray ( arguments [ 0 ] ) ? arguments [ 0 ] : [ [ ] . slice . call ( arguments , 0 ) ] , c , e , d = b . length ; d -- ; ) c = b [ d ] , e = 0 , CKEDITOR . tools . isArray ( c ) && ( e = c [ 1 ] , c = c [ 0 ] ) , e ? a [ c ] = e : delete a [ c ] } , getCommandKeystroke : function ( a , b ) { var c = "string" === typeof a ? this . getCommand ( a ) : a , e = [ ] ; if ( c ) { var d = CKEDITOR . tools . object . findKey ( this . commands , c ) , g = this . keystrokeHandler . keystrokes ; if ( c . fakeKeystroke ) e . push ( c . fakeKeystroke ) ; else for ( var f in g ) g [ f ] === d && e . push ( f ) } return b ?
null == a || a ; this . readOnly != a && ( this . readOnly = a , this . keystrokeHandler . blockedKeystrokes [ 8 ] = + a , this . editable ( ) . setReadOnly ( a ) , this . fire ( "readOnly" ) ) } , insertHtml : function ( a , b , c ) { this . fire ( "insertHtml" , { dataValue : a , mode : b , range : c } ) } , insertText : function ( a ) { this . fire ( "insertText" , a ) } , insertElement : function ( a ) { this . fire ( "insertElement" , a ) } , getSelectedHtml : function ( a ) { var b = this . editable ( ) , c = this . getSelection ( ) , c = c && c . getRanges ( ) ; if ( ! b || ! c || 0 === c . length ) return null ; b = z ( c , b ) ; return a ? b . getHtml ( ) : b } , extractSelectedHtml : function ( a ,
b ) { var c = this . editable ( ) , e = this . getSelection ( ) . getRanges ( ) , d = new CKEDITOR . dom . documentFragment , f ; if ( ! c || 0 === e . length ) return null ; for ( f= 0 ; f < e . length ; f ++ ) d . append ( c . extractHtmlFromRange ( e [ f ] , b ) ) ; b || this . getSelection ( ) . selectRanges ( [ e [ 0 ] ] ) ; return a ? d . getHtml ( ) : d } , focus : function ( ) { this . fire ( "beforeFocus" ) } , checkDirty : function ( ) { return "ready" == this . status && this . _ . previousValue !== this . getSnapshot ( ) } , resetDirty : function ( ) { this . _ . previousValue = this . getSnapshot ( ) } , updateElement : function ( ) { return y . call ( this ) } ,
setKeystroke : function ( ) { for ( var a = this . keystrokeHandler . keystrokes , b = CKEDITOR . tools . isArray ( arguments [ 0 ] ) ? arguments [ 0 ] : [ [ ] . slice . call ( arguments , 0 ) ] , c , e , d = b . length ; d -- ; ) c = b [ d ] , e = 0 , CKEDITOR . tools . isArray ( c ) && ( e = c [ 1 ] , c = c [ 0 ] ) , e ? a [ c ] = e : delete a [ c ] } , getCommandKeystroke : function ( a , b ) { var c = "string" === typeof a ? this . getCommand ( a ) : a , e = [ ] ; if ( c ) { var d = CKEDITOR . tools . object . findKey ( this . commands , c ) , f = this . keystrokeHandler . keystrokes ; if ( c . fakeKeystroke ) e . push ( c . fakeKeystroke ) ; else for ( var g in f ) f [ g ] === d && e . push ( g ) } return b ?
e : e [ 0 ] || null } , addFeature : function ( a ) { return this . filter . addFeature ( a ) } , setActiveFilter : function ( a ) { a || ( a = this . filter ) ; this . activeFilter !== a && ( this . activeFilter = a , this . fire ( "activeFilterChange" ) , a === this . filter ? this . setActiveEnterMode ( null , null ) : this . setActiveEnterMode ( a . getAllowedEnterMode ( this . enterMode ) , a . getAllowedEnterMode ( this . shiftEnterMode , ! 0 ) ) ) } , setActiveEnterMode : function ( a , b ) { a = a ? this . blockless ? CKEDITOR . ENTER _BR : a : this . enterMode ; b = b ? this . blockless ? CKEDITOR . ENTER _BR : b : this . shiftEnterMode ;
if ( this . activeEnterMode != a || this . activeShiftEnterMode != b ) this . activeEnterMode = a , this . activeShiftEnterMode = b , this . fire ( "activeEnterModeChange" ) } , showNotification : function ( a ) { alert ( a ) } , isDetached : function ( ) { return ! ! this . container && this . container . isDetached ( ) } , isDestroyed : function ( ) { return "destroyed" === this . status } } ) ; CKEDITOR . editor . _getEditorElement = function ( a ) { if ( ! CKEDITOR . env . isCompatible ) return null ; var b = CKEDITOR . dom . element . get ( a ) ; return b ? b . getEditor ( ) ? ( CKEDITOR . error ( "editor-element-conflict" ,
{ editorName : b . getEditor ( ) . name } ) , null ) : b : ( CKEDITOR . error ( "editor-incorrect-element" , { element : a } ) , null ) } ; CKEDITOR . editor . initializeDelayedEditorCreation = function ( a , b , c ) { if ( b . delayIfDetached _callback ) return CKEDITOR . warn ( "editor-delayed-creation" , { method : "callback" } ) , b . delayIfDetached _callback ( function ( ) { CKEDITOR [ c ] ( a , b ) ; CKEDITOR . warn ( "editor-delayed-creation-success" , { method : "callback" } ) } ) , null ; var e = void 0 === b . delayIfDetached _interval ? CKEDITOR . config . delayIfDetached _interval : b . delayIfDetached _interval ;
CKEDITOR . warn ( "editor-delayed-creation" , { method : "interval - " + e + " ms" } ) ; var d = setInterval ( function ( ) { a . isDetached ( ) || ( clearInterval ( d ) , CKEDITOR [ c ] ( a , b ) , CKEDITOR . warn ( "editor-delayed-creation-success" , { method : "interval - " + e + " ms" } ) ) } , e ) ; return function ( ) { clearInterval ( d ) } } ; CKEDITOR . editor . shouldDelayEditorCreation = function ( a , b ) { CKEDITOR . editor . mergeDelayedCreationConfigs ( b ) ; return b && b . delayIfDetached && a . isDetached ( ) } ; CKEDITOR . editor . mergeDelayedCreationConfigs = function ( a ) { a && ( a . delayIfDetached = "boolean" ===
typeof a . delayIfDetached ? a . delayIfDetached : CKEDITOR . config . delayIfDetached , a . delayIfDetached _interval = isNaN ( a . delayIfDetached _interval ) ? CKEDITOR . config . delayIfDetached _interval : a . delayIfDetached _interval , a . delayIfDetached _callback = a . delayIfDetached _callback || CKEDITOR . config . delayIfDetached _callback ) } } ) ( ) ; CKEDITOR . ELEMENT _MODE _NONE = 0 ; CKEDITOR . ELEMENT _MODE _REPLACE = 1 ; CKEDITOR . ELEMENT _MODE _APPENDTO = 2 ; CKEDITOR . ELEMENT _MODE _INLINE = 3 ; CKEDITOR . config . delayIfDetached = ! 1 ;
CKEDITOR . config . delayIfDetached _callback = void 0 ; CKEDITOR . config . delayIfDetached _interval = 50 ; CKEDITOR . htmlParser = function ( ) { this . _ = { htmlPartsRegex : /<(?:(?:\/([^>]+)>)|(?:!--([\S|\s]*?)--!?>)|(?:([^\/\s>]+)((?:\s+[\w\-:.]+(?:\s*=\s*?(?:(?:"[^"]*")|(?:'[^']*')|[^\s"'\/>]+))?)*)[\S\s]*?(\/?)>))/g } } ;
( function ( ) { var a = /([\w\-:.]+)(?:(?:\s*=\s*(?:(?:"([^"]*)")|(?:'([^']*)')|([^\s>]+)))|(?=\s|$))/g , d = { 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 = { onTagOpen : function ( ) { } , onTagClose : function ( ) { } , onText : function ( ) { } , onCDATA : function ( ) { } , onComment : function ( ) { } , parse : function ( b ) { for ( var c , g, e = 0 , h ; c = this . _ . htmlPartsRegex . exec ( b ) ; ) { g= c . index ; if ( g > e ) if ( e = b . substring ( e , g) , h ) h . push ( e ) ; else this . onText ( e ) ;
e = this . _ . htmlPartsRegex . lastIndex ; if ( g= c [ 1 ] ) if ( g = g . toLowerCase ( ) , h && CKEDITOR . dtd . $cdata [ g ] && ( this . onCDATA ( h . join ( "" ) ) , h = null ) , ! h ) { this . onTagClose ( g ) ; continue } if ( h ) h . push ( c [ 0 ] ) ; else if ( g= c [ 3 ] ) { if ( g = g . toLowerCase ( ) , ! /="/ . test ( g) ) { var k = { } , l , q = c [ 4 ] ; c = ! ! c [ 5 ] ; if ( q) for ( ; l = a . exec ( q ) ; ) { var f = l [ 1 ] . toLowerCase ( ) ; l = l [ 2 ] || l [ 3 ] || l [ 4 ] || "" ; k [ f ] = ! l && d [ f ] ? f : CKEDITOR . tools . htmlDecodeAttr ( l ) } this . onTagOpen ( g , k , c ) ; ! h && CKEDITOR . dtd . $cdata [ g ] && ( h = [ ] ) } } else if ( g = c [ 2 ] ) this . onComment ( g ) } if ( b . length > e ) this . onText ( b . substring ( e ,
( function ( ) { var a = /([\w\-:.]+)(?:(?:\s*=\s*(?:(?:"([^"]*)")|(?:'([^']*)')|([^\s>]+)))|(?=\s|$))/g , d = { 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 = { onTagOpen : function ( ) { } , onTagClose : function ( ) { } , onText : function ( ) { } , onCDATA : function ( ) { } , onComment : function ( ) { } , parse : function ( b ) { for ( var c , f, e = 0 , k ; c = this . _ . htmlPartsRegex . exec ( b ) ; ) { f= c . index ; if ( f > e ) if ( e = b . substring ( e , f) , k ) k . push ( e ) ; else this . onText ( e ) ;
e = this . _ . htmlPartsRegex . lastIndex ; if ( f= c [ 1 ] ) if ( f = f . toLowerCase ( ) , k && CKEDITOR . dtd . $cdata [ f ] && ( this . onCDATA ( k . join ( "" ) ) , k = null ) , ! k ) { this . onTagClose ( f ) ; continue } if ( k ) k . push ( c [ 0 ] ) ; else if ( f= c [ 3 ] ) { if ( f = f . toLowerCase ( ) , ! /="/ . test ( f) ) { var h = { } , n , l = c [ 4 ] ; c = ! ! c [ 5 ] ; if ( l) for ( ; n = a . exec ( l ) ; ) { var g = n [ 1 ] . toLowerCase ( ) ; n = n [ 2 ] || n [ 3 ] || n [ 4 ] || "" ; h [ g ] = ! n && d [ g ] ? g : CKEDITOR . tools . htmlDecodeAttr ( n ) } this . onTagOpen ( f , h , c ) ; ! k && CKEDITOR . dtd . $cdata [ f ] && ( k = [ ] ) } } else if ( f = c [ 2 ] ) this . onComment ( f ) } if ( b . length > e ) this . onText ( b . substring ( e ,
b . length ) ) } } } ) ( ) ;
CKEDITOR . htmlParser . basicWriter = CKEDITOR . tools . createClass ( { $ : function ( ) { this . _ = { output : [ ] } } , proto : { openTag : function ( a ) { this . _ . output . push ( "\x3c" , a ) } , openTagClose : function ( a , d ) { d ? this . _ . output . push ( " /\x3e" ) : this . _ . output . push ( "\x3e" ) } , attribute : function ( a , d ) { "string" == typeof d && ( d = CKEDITOR . tools . htmlEncodeAttr ( d ) ) ; this . _ . output . push ( " " , a , '\x3d"' , d , '"' ) } , closeTag : function ( a ) { this . _ . output . push ( "\x3c/" , a , "\x3e" ) } , text : function ( a ) { this . _ . output . push ( a ) } , comment : function ( a ) { this . _ . output . push ( "\x3c!--" , a ,
"--\x3e" ) } , write : function ( a ) { this . _ . output . push ( a ) } , reset : function ( ) { this . _ . output = [ ] ; this . _ . indent = ! 1 } , getHtml : function ( a ) { var d = this . _ . output . join ( "" ) ; a && this . reset ( ) ; return d } } } ) ; "use strict" ;
( function ( ) { CKEDITOR . htmlParser . node = function ( ) { } ; CKEDITOR . htmlParser . node . prototype = { remove : function ( ) { var a = this . parent . children , d = CKEDITOR . tools . indexOf ( a , this ) , b = this . previous , c = this . next ; b && ( b . next = c ) ; c && ( c . previous = b ) ; a . splice ( d , 1 ) ; this . parent = null } , replaceWith : function ( a ) { var d = this . parent . children , b = CKEDITOR . tools . indexOf ( d , this ) , c = a . previous = this . previous , g = a . next = this . next ; c && ( c . next = a ) ; g&& ( g . previous = a ) ; d [ b ] = a ; a . parent = this . parent ; this . parent = null } , insertAfter : function ( a ) { var d = a . parent . children ,
( function ( ) { CKEDITOR . htmlParser . node = function ( ) { } ; CKEDITOR . htmlParser . node . prototype = { remove : function ( ) { var a = this . parent . children , d = CKEDITOR . tools . indexOf ( a , this ) , b = this . previous , c = this . next ; b && ( b . next = c ) ; c && ( c . previous = b ) ; a . splice ( d , 1 ) ; this . parent = null } , replaceWith : function ( a ) { var d = this . parent . children , b = CKEDITOR . tools . indexOf ( d , this ) , c = a . previous = this . previous , f = a . next = this . next ; c && ( c . next = a ) ; f&& ( f . previous = a ) ; d [ b ] = a ; a . parent = this . parent ; this . parent = null } , insertAfter : function ( a ) { var d = a . parent . children ,
b = CKEDITOR . tools . indexOf ( d , a ) , c = a . next ; d . splice ( b + 1 , 0 , this ) ; this . next = a . next ; this . previous = a ; a . next = this ; c && ( c . previous = this ) ; this . parent = a . parent } , insertBefore : function ( a ) { var d = a . parent . children , b = CKEDITOR . tools . indexOf ( d , a ) ; d . splice ( b , 0 , this ) ; this . next = a ; ( this . previous = a . previous ) && ( a . previous . next = this ) ; a . previous = this ; this . parent = a . parent } , getAscendant : function ( a ) { var d = "function" == typeof a ? a : "string" == typeof a ? function ( b ) { return b . name == a } : function ( b ) { return b . name in a } , b = this . parent ; for ( ; b &&
b . type == CKEDITOR . NODE _ELEMENT ; ) { if ( d ( b ) ) return b ; b = b . parent } return null } , wrapWith : function ( a ) { this . replaceWith ( a ) ; a . add ( this ) ; return a } , getIndex : function ( ) { return CKEDITOR . tools . indexOf ( this . parent . children , this ) } , getFilterContext : function ( a ) { return a || { } } } } ) ( ) ; "use strict" ; CKEDITOR . htmlParser . comment = function ( a ) { this . value = a ; this . _ = { isBlockLike : ! 1 } } ;
CKEDITOR . htmlParser . comment . prototype = CKEDITOR . tools . extend ( new CKEDITOR . htmlParser . node , { type : CKEDITOR . NODE _COMMENT , filter : function ( a , d ) { var b = this . value ; if ( ! ( b = a . onComment ( d , b , this ) ) ) return this . remove ( ) , ! 1 ; if ( "string" != typeof b ) return this . replaceWith ( b ) , ! 1 ; this . value = b ; return ! 0 } , writeHtml : function ( a , d ) { d && this . filter ( d ) ; a . comment ( this . value ) } } ) ; "use strict" ;
( function ( ) { CKEDITOR . htmlParser . text = function ( a ) { this . value = a ; this . _ = { isBlockLike : ! 1 } } ; CKEDITOR . htmlParser . text . prototype = CKEDITOR . tools . extend ( new CKEDITOR . htmlParser . node , { type : CKEDITOR . NODE _TEXT , filter : function ( a , d ) { if ( ! ( this . value = a . onText ( d , this . value , this ) ) ) return this . remove ( ) , ! 1 } , writeHtml : function ( a , d ) { d && this . filter ( d ) ; a . text ( this . value ) } } ) } ) ( ) ; "use strict" ;
( function ( ) { CKEDITOR . htmlParser . cdata = function ( a ) { this . value = a } ; CKEDITOR . htmlParser . cdata . prototype = CKEDITOR . tools . extend ( new CKEDITOR . htmlParser . node , { type : CKEDITOR . NODE _TEXT , filter : function ( a ) { var d = this . getAscendant ( "style" ) ; if ( d && d . getAscendant ( { math : 1 , svg : 1 } ) ) { var d = CKEDITOR . htmlParser . fragment . fromHtml ( this . value ) , b = new CKEDITOR . htmlParser . basicWriter ; a . applyTo ( d ) ; d . writeHtml ( b ) ; this . value = b . getHtml ( ) } } , writeHtml : function ( a ) { a . write ( this . value ) } } ) } ) ( ) ; "use strict" ;
CKEDITOR . htmlParser . fragment = function ( ) { this . children = [ ] ; this . parent = null ; this . _ = { isBlockLike : ! 0 , hasInlineStarted : ! 1 } } ;
( function ( ) { function a ( a ) { return a . attributes [ "data-cke-survive" ] ? ! 1 : "a" == a . name && a . attributes . href || CKEDITOR . dtd . $removeEmpty [ a . name ] } var d = CKEDITOR . tools . extend ( { table : 1 , ul : 1 , ol : 1 , dl : 1 } , CKEDITOR . dtd . table , CKEDITOR . dtd . ul , CKEDITOR . dtd . ol , CKEDITOR . dtd . dl ) , b = { ol : 1 , ul : 1 } , c = CKEDITOR . tools . extend ( { } , { html : 1 } , CKEDITOR . dtd . html , CKEDITOR . dtd . body , CKEDITOR . dtd . head , { style : 1 , script : 1 } ) , g = { ul : "li" , ol : "li" , dl : "dd" , table : "tbody" , tbody : "tr" , thead : "tr" , tfoot : "tr" , tr : "td" } ; CKEDITOR . htmlParser . fragment . fromHtml =
function ( e , h, k ) { function l ( a ) { var b ; if ( 0 < m . length ) for ( var c = 0 ; c < m . length ; c ++ ) { var e = m [ c ] , d = e . name , g= CKEDITOR . dtd [ d ] , f = v . name && CKEDITOR . dtd [ v . name ] ; f && ! f [ d ] || a && g && ! g [ a ] && CKEDITOR . dtd [ a ] ? d == v. name && ( w ( v , v . parent , 1 ) , c -- ) : ( b || ( q ( ) , b = 1 ) , e = e . clone ( ) , e . parent = v, v = e , m . splice ( c , 1 ) , c -- ) } } function q( ) { for ( ; L . length ; ) w ( L . shift ( ) , v ) } function f ( a ) { if ( a . _ . isBlockLike && "pre" != a . name && "textarea" != a . name ) { var b = a . children . length , c = a . children [ b - 1 ] , e ; c && c . type == CKEDITOR . NODE _TEXT && ( ( e = CKEDITOR . tools . rtrim ( c . value ) ) ?
c . value = e : a . children . length = b - 1 ) } } function w ( b , c , e ) { c = c || v|| r ; var d = v ; void 0 === b . previous && ( B( c , b ) && ( v = c , F . onTagOpen ( k , { } ) , b . returnPoint = c = v) , f ( b ) , a ( b ) && ! b . children . length || c . add ( b ) , "pre" == b . name && ( G = ! 1 ) , "textarea" == b . name && ( J = ! 1 ) ) ; b . returnPoint ? ( v = b . returnPoint , delete b . returnPoint ) : v= e ? c : d } function B ( a , b ) { if ( ( a == r || "body" == a . name ) && k && ( ! a . name || CKEDITOR . dtd [ a . name ] [ k ] ) ) { var c , e ; return ( c = b . attributes && ( e = b . attributes [ "data-cke-real-element-type" ] ) ? e : b . name ) && c in CKEDITOR . dtd . $inline && ! ( c in CKEDITOR . dtd . head ) &&
! b . isOrphan || b . type == CKEDITOR . NODE _TEXT } } function y ( a , b ) { return a in CKEDITOR . dtd . $listItem || a in CKEDITOR . dtd . $tableContent ? a == b || "dt" == a && "dd" == b || "dd" == a && "dt" == b : ! 1 } var F= new CKEDITOR . htmlParser , r = h instanceof CKEDITOR . htmlParser . element ? h: "string" == typeof h ? new CKEDITOR . htmlParser . element ( h ) : new CKEDITOR . htmlParser . fragment , m = [ ] , L= [ ] , v = r , J = "textarea" == r . name , G = "pre" == r . name ; F . onTagOpen = function ( e , g , f , h ) { g = new CKEDITOR . htmlParser . element ( e , g) ; g . isUnknown && f && ( g . isEmpty = ! 0 ) ; g . isOptionalClose = h ;
if ( a ( g) ) m . push ( g ) ; else { if ( "pre" == e ) G = ! 0 ; else { if ( "br" == e && G) { v . add ( new CKEDITOR . htmlParser . text ( "\n" ) ) ; return } "textarea" == e && ( J = ! 0 ) } if ( "br" == e ) L. push ( g ) ; else { for ( ; ! ( h = ( f= v . name ) ? CKEDITOR . dtd [ f ] || ( v . _ . isBlockLike ? CKEDITOR . dtd . div : CKEDITOR . dtd . span ) : c , g. isUnknown || v . isUnknown || h [ e ] ) ; ) if ( v. isOptionalClose ) F . onTagClose ( f ) ; else if ( e in b && f in b ) f = v . children , ( f = f [ f . length - 1 ] ) && "li" == f. name || w ( f = new CKEDITOR . htmlParser . element ( "li" ) , v) , ! g . returnPoint && ( g . returnPoint = v ) , v = f ; else if ( e in CKEDITOR . dtd . $listItem &&
! y( e , f ) ) F . onTagOpen ( "li" == e ? "ul" : "dl" , { } , 0 , 1 ) ; else if ( f in d && ! y ( e , f ) ) ! g . returnPoint && ( g . returnPoint = v ) , v = v . parent ; else if ( f in CKEDITOR . dtd . $inline && m . unshift ( v) , v . parent ) w ( v , v . parent , 1 ) ; else { g . isOrphan = 1 ; break } l ( e ) ; q ( ) ; g . parent = v ; g . isEmpty ? w ( g ) : v = g } } } ; F . onTagClose = function ( a ) { for ( var b = m . length - 1 ; 0 <= b ; b -- ) if ( a == m [ b ] . name ) { m . splice ( b , 1 ) ; return } for ( var c = [ ] , e = [ ] , d = v; d != r && d . name != a ; ) d . _ . isBlockLike || e . unshift ( d ) , c . push ( d ) , d = d . returnPoint || d . parent ; if ( d != r ) { for ( b = 0 ; b < c . length ; b ++ ) { var g= c [ b ] ; w ( g , g . parent ) } v =
d ; d . _ . isBlockLike ? q ( ) : ( b = CKEDITOR . config . shiftLineBreaks , ! 0 !== b && L . length && ( "function" !== typeof b ? q( ) : ( b = b ( L [ L . length - 1 ] ) , ! 0 !== b && ( q ( ) , b instanceof CKEDITOR . htmlParser . text && v . add ( b ) , b instanceof CKEDITOR . htmlParser . element && w( b , v ) ) ) ) ) ; w ( d , d . parent ) ; d == v&& ( v = v . parent ) ; m = m . concat ( e ) } "body" == a && ( k= ! 1 ) } ; F . onText = function ( a ) { if ( ! ( v. _ . hasInlineStarted && ! L . length || G || J ) && ( a = CKEDITOR . tools . ltrim ( a ) , 0 === a . length ) ) return ; var b = v . name , e = b ? CKEDITOR . dtd [ b ] || ( v . _ . isBlockLike ? CKEDITOR . dtd . div : CKEDITOR . dtd . span ) :
c ; if ( ! J && ! e [ "#" ] && b in d ) F. onTagOpen ( g [ b ] || "" ) , F . onText ( a ) ; else { q ( ) ; l ( ) ; G || J || ( a = a . replace ( /[\t\r\n ]{2,}|[\t\r\n]/g , " " ) ) ; a = new CKEDITOR . htmlParser . text ( a ) ; if ( B( v , a ) ) this . onTagOpen ( k , { } , 0 , 1 ) ; v . add ( a ) } } ; F . onCDATA = function ( a ) { v . add ( new CKEDITOR . htmlParser . cdata ( a ) ) } ; F. onComment = function ( a ) { q ( ) ; l ( ) ; v . add ( new CKEDITOR . htmlParser . comment ( a ) ) } ; F. parse ( e ) ; for ( q ( ) ; v != r ; ) w ( v , v . parent , 1 ) ; f ( r ) ; return r } ; CKEDITOR . htmlParser . fragment . prototype = { type : CKEDITOR . NODE _DOCUMENT _FRAGMENT , add : function ( a , b ) { isNaN ( b ) &&
( function ( ) { function a ( a ) { return a . attributes [ "data-cke-survive" ] ? ! 1 : "a" == a . name && a . attributes . href || CKEDITOR . dtd . $removeEmpty [ a . name ] } var d = CKEDITOR . tools . extend ( { table : 1 , ul : 1 , ol : 1 , dl : 1 } , CKEDITOR . dtd . table , CKEDITOR . dtd . ul , CKEDITOR . dtd . ol , CKEDITOR . dtd . dl ) , b = { ol : 1 , ul : 1 } , c = CKEDITOR . tools . extend ( { } , { html : 1 } , CKEDITOR . dtd . html , CKEDITOR . dtd . body , CKEDITOR . dtd . head , { style : 1 , script : 1 } ) , f = { ul : "li" , ol : "li" , dl : "dd" , table : "tbody" , tbody : "tr" , thead : "tr" , tfoot : "tr" , tr : "td" } ; CKEDITOR . htmlParser . fragment . fromHtml =
function ( e , k, h ) { function n ( a ) { var b ; if ( 0 < m . length ) for ( var c = 0 ; c < m . length ; c ++ ) { var e = m [ c ] , d = e . name , f= CKEDITOR . dtd [ d ] , g = w . name && CKEDITOR . dtd [ w . name ] ; g && ! g [ d ] || a && f && ! f [ a ] && CKEDITOR . dtd [ a ] ? d == w. name && ( x ( w , w . parent , 1 ) , c -- ) : ( b || ( l ( ) , b = 1 ) , e = e . clone ( ) , e . parent = w, w = e , m . splice ( c , 1 ) , c -- ) } } function l( ) { for ( ; M . length ; ) x ( M . shift ( ) , w ) } function g ( a ) { if ( a . _ . isBlockLike && "pre" != a . name && "textarea" != a . name ) { var b = a . children . length , c = a . children [ b - 1 ] , e ; c && c . type == CKEDITOR . NODE _TEXT && ( ( e = CKEDITOR . tools . rtrim ( c . value ) ) ?
c . value = e : a . children . length = b - 1 ) } } function x ( b , c , e ) { c = c || w|| v ; var d = w ; void 0 === b . previous && ( y( c , b ) && ( w = c , G . onTagOpen ( h , { } ) , b . returnPoint = c = w) , g ( b ) , a ( b ) && ! b . children . length || c . add ( b ) , "pre" == b . name && ( F = ! 1 ) , "textarea" == b . name && ( J = ! 1 ) ) ; b . returnPoint ? ( w = b . returnPoint , delete b . returnPoint ) : w= e ? c : d } function y ( a , b ) { if ( ( a == v || "body" == a . name ) && h && ( ! a . name || CKEDITOR . dtd [ a . name ] [ h ] ) ) { var c , e ; return ( c = b . attributes && ( e = b . attributes [ "data-cke-real-element-type" ] ) ? e : b . name ) && c in CKEDITOR . dtd . $inline && ! ( c in CKEDITOR . dtd . head ) &&
! b . isOrphan || b . type == CKEDITOR . NODE _TEXT } } function z ( a , b ) { return a in CKEDITOR . dtd . $listItem || a in CKEDITOR . dtd . $tableContent ? a == b || "dt" == a && "dd" == b || "dd" == a && "dt" == b : ! 1 } var G= new CKEDITOR . htmlParser , v = k instanceof CKEDITOR . htmlParser . element ? k: "string" == typeof k ? new CKEDITOR . htmlParser . element ( k ) : new CKEDITOR . htmlParser . fragment , m = [ ] , M= [ ] , w = v , J = "textarea" == v . name , F = "pre" == v . name ; G . onTagOpen = function ( e , f , g , h ) { f = new CKEDITOR . htmlParser . element ( e , f) ; f . isUnknown && g && ( f . isEmpty = ! 0 ) ; f . isOptionalClose = h ;
if ( a ( f) ) m . push ( f ) ; else { if ( "pre" == e ) F = ! 0 ; else { if ( "br" == e && F) { w . add ( new CKEDITOR . htmlParser . text ( "\n" ) ) ; return } "textarea" == e && ( J = ! 0 ) } if ( "br" == e ) M. push ( f ) ; else { for ( ; ! ( h = ( g= w . name ) ? CKEDITOR . dtd [ g ] || ( w . _ . isBlockLike ? CKEDITOR . dtd . div : CKEDITOR . dtd . span ) : c , f. isUnknown || w . isUnknown || h [ e ] ) ; ) if ( w. isOptionalClose ) G . onTagClose ( g ) ; else if ( e in b && g in b ) g = w . children , ( g = g [ g . length - 1 ] ) && "li" == g. name || x ( g = new CKEDITOR . htmlParser . element ( "li" ) , w) , ! f . returnPoint && ( f . returnPoint = w ) , w = g ; else if ( e in CKEDITOR . dtd . $listItem &&
! z( e , g ) ) G . onTagOpen ( "li" == e ? "ul" : "dl" , { } , 0 , 1 ) ; else if ( g in d && ! z ( e , g ) ) ! f . returnPoint && ( f . returnPoint = w ) , w = w . parent ; else if ( g in CKEDITOR . dtd . $inline && m . unshift ( w) , w . parent ) x ( w , w . parent , 1 ) ; else { f . isOrphan = 1 ; break } n ( e ) ; l ( ) ; f . parent = w ; f . isEmpty ? x ( f ) : w = f } } } ; G . onTagClose = function ( a ) { for ( var b = m . length - 1 ; 0 <= b ; b -- ) if ( a == m [ b ] . name ) { m . splice ( b , 1 ) ; return } for ( var c = [ ] , e = [ ] , d = w; d != v && d . name != a ; ) d . _ . isBlockLike || e . unshift ( d ) , c . push ( d ) , d = d . returnPoint || d . parent ; if ( d != v ) { for ( b = 0 ; b < c . length ; b ++ ) { var f= c [ b ] ; x ( f , f . parent ) } w =
d ; d . _ . isBlockLike ? l ( ) : ( b = CKEDITOR . config . shiftLineBreaks , ! 0 !== b && M . length && ( "function" !== typeof b ? l( ) : ( b = b ( M [ M . length - 1 ] ) , ! 0 !== b && ( l ( ) , b instanceof CKEDITOR . htmlParser . text && w . add ( b ) , b instanceof CKEDITOR . htmlParser . element && x( b , w ) ) ) ) ) ; x ( d , d . parent ) ; d == w&& ( w = w . parent ) ; m = m . concat ( e ) } "body" == a && ( h= ! 1 ) } ; G . onText = function ( a ) { if ( ! ( w. _ . hasInlineStarted && ! M . length || F || J ) && ( a = CKEDITOR . tools . ltrim ( a ) , 0 === a . length ) ) return ; var b = w . name , e = b ? CKEDITOR . dtd [ b ] || ( w . _ . isBlockLike ? CKEDITOR . dtd . div : CKEDITOR . dtd . span ) :
c ; if ( ! J && ! e [ "#" ] && b in d ) G. onTagOpen ( f [ b ] || "" ) , G . onText ( a ) ; else { l ( ) ; n ( ) ; F || J || ( a = a . replace ( /[\t\r\n ]{2,}|[\t\r\n]/g , " " ) ) ; a = new CKEDITOR . htmlParser . text ( a ) ; if ( y( w , a ) ) this . onTagOpen ( h , { } , 0 , 1 ) ; w . add ( a ) } } ; G . onCDATA = function ( a ) { w . add ( new CKEDITOR . htmlParser . cdata ( a ) ) } ; G. onComment = function ( a ) { l ( ) ; n ( ) ; w . add ( new CKEDITOR . htmlParser . comment ( a ) ) } ; G. parse ( e ) ; for ( l ( ) ; w != v ; ) x ( w , w . parent , 1 ) ; g ( v ) ; return v } ; CKEDITOR . htmlParser . fragment . prototype = { type : CKEDITOR . NODE _DOCUMENT _FRAGMENT , add : function ( a , b ) { isNaN ( b ) &&
( b = this . children . length ) ; var c = 0 < b ? this . children [ b - 1 ] : null ; if ( c ) { if ( a . _ . isBlockLike && c . type == CKEDITOR . NODE _TEXT && ( c . value = CKEDITOR . tools . rtrim ( c . value ) , 0 === c . value . length ) ) { this . children . pop ( ) ; this . add ( a ) ; return } c . next = a } a . previous = c ; a . parent = this ; this . children . splice ( b , 0 , a ) ; this . _ . hasInlineStarted || ( this . _ . hasInlineStarted = a . type == CKEDITOR . NODE _TEXT || a . type == CKEDITOR . NODE _ELEMENT && ! a . _ . isBlockLike ) } , filter : function ( a , b ) { b = this . getFilterContext ( b ) ; a . onRoot ( b , this ) ; this . filterChildren ( a , ! 1 , b ) } , filterChildren : function ( a ,
b , c ) { if ( this . childrenFilteredBy != a . id ) { c = this . getFilterContext ( c ) ; if ( b && ! this . parent ) a . onRoot ( c , this ) ; this . childrenFilteredBy = a . id ; for ( b = 0 ; b < this . children . length ; b ++ ) ! 1 === this . children [ b ] . filter ( a , c ) && b -- } } , writeHtml : function ( a , b ) { b && this . filter ( b ) ; this . writeChildrenHtml ( a ) } , writeChildrenHtml : function ( a , b , c ) { var d = this . getFilterContext ( ) ; if ( c && ! this . parent && b ) b . onRoot ( d , this ) ; b && this . filterChildren ( b , ! 1 , d ) ; b = 0 ; c = this . children ; for ( d = c . length ; b < d ; b ++ ) c [ b ] . writeHtml ( a ) } , forEach : function ( a , b , c ) { if ( ! ( c ||
b && this . type != b ) ) var d = a ( this ) ; if ( ! 1 !== d ) { c = this . children ; for ( var g= 0 ; g < c . length ; g ++ ) d = c [ g ] , d . type == CKEDITOR . NODE _ELEMENT ? d . forEach ( a , b ) : b && d . type != b || a ( d ) } } , getFilterContext : function ( a ) { return a || { } } } ; CKEDITOR . config . shiftLineBreaks = ! 0 } ) ( ) ; "use strict" ;
( function ( ) { function a ( ) { this . rules = [ ] } function d ( b , c , d , e ) { var h, k ; for ( h in c ) ( k = b [ h ] ) || ( k = b [ h ] = new a ) , k . add ( c [ h ] , d , e ) } CKEDITOR . htmlParser . filter = CKEDITOR . tools . createClass ( { $ : function ( b ) { this . id = CKEDITOR . tools . getNextNumber ( ) ; this . elementNameRules = new a ; this . attributeNameRules = new a ; this . elementsRules = { } ; this . attributesRules = { } ; this . textRules = new a ; this . commentRules = new a ; this . rootRules = new a ; b && this . addRules ( b , 10 ) } , proto : { addRules : function ( a , c ) { var g; "number" == typeof c ? g = c : c && "priority" in c && ( g =
c . priority ) ; "number" != typeof g&& ( g = 10 ) ; "object" != typeof c && ( c = { } ) ; a . elementNames && this . elementNameRules . addMany ( a . elementNames , g , c ) ; a . attributeNames && this . attributeNameRules . addMany ( a . attributeNames , g , c ) ; a . elements && d ( this . elementsRules , a . elements , g , c ) ; a . attributes && d ( this . attributesRules , a . attributes , g , c ) ; a . text && this . textRules . add ( a . text , g , c ) ; a . comment && this . commentRules . add ( a . comment , g , c ) ; a . root && this . rootRules . add ( a . root , g , c ) } , applyTo : function ( a ) { a . filter ( this ) } , onElementName : function ( a , c ) { return this . elementNameRules . execOnName ( a ,
c ) } , onAttributeName : function ( a , c ) { return this . attributeNameRules . execOnName ( a , c ) } , onText : function ( a , c , d ) { return this . textRules . exec ( a , c , d ) } , onComment : function ( a , c , d ) { return this . commentRules . exec ( a , c , d ) } , onRoot : function ( a , c ) { return this . rootRules . exec ( a , c ) } , onElement : function ( a , c ) { for ( var d = [ this . elementsRules [ "^" ] , this . elementsRules [ c . name ] , this . elementsRules . $ ] , e , h= 0 ; 3 > h ; h ++ ) if ( e = d [ h ] ) { e = e . exec ( a , c , this ) ; if ( ! 1 === e ) return null ; if ( e && e != c ) return this . onNode ( a , e ) ; if ( c . parent && ! c . name ) break } return c } ,
b && this . type != b ) ) var d = a ( this ) ; if ( ! 1 !== d ) { c = this . children ; for ( var f= 0 ; f < c . length ; f ++ ) d = c [ f ] , d . type == CKEDITOR . NODE _ELEMENT ? d . forEach ( a , b ) : b && d . type != b || a ( d ) } } , getFilterContext : function ( a ) { return a || { } } } ; CKEDITOR . config . shiftLineBreaks = ! 0 } ) ( ) ; "use strict" ;
( function ( ) { function a ( ) { this . rules = [ ] } function d ( b , c , d , e ) { var k, h ; for ( k in c ) ( h = b [ k ] ) || ( h = b [ k ] = new a ) , h . add ( c [ k ] , d , e ) } CKEDITOR . htmlParser . filter = CKEDITOR . tools . createClass ( { $ : function ( b ) { this . id = CKEDITOR . tools . getNextNumber ( ) ; this . elementNameRules = new a ; this . attributeNameRules = new a ; this . elementsRules = { } ; this . attributesRules = { } ; this . textRules = new a ; this . commentRules = new a ; this . rootRules = new a ; b && this . addRules ( b , 10 ) } , proto : { addRules : function ( a , c ) { var f; "number" == typeof c ? f = c : c && "priority" in c && ( f =
c . priority ) ; "number" != typeof f&& ( f = 10 ) ; "object" != typeof c && ( c = { } ) ; a . elementNames && this . elementNameRules . addMany ( a . elementNames , f , c ) ; a . attributeNames && this . attributeNameRules . addMany ( a . attributeNames , f , c ) ; a . elements && d ( this . elementsRules , a . elements , f , c ) ; a . attributes && d ( this . attributesRules , a . attributes , f , c ) ; a . text && this . textRules . add ( a . text , f , c ) ; a . comment && this . commentRules . add ( a . comment , f , c ) ; a . root && this . rootRules . add ( a . root , f , c ) } , applyTo : function ( a ) { a . filter ( this ) } , onElementName : function ( a , c ) { return this . elementNameRules . execOnName ( a ,
c ) } , onAttributeName : function ( a , c ) { return this . attributeNameRules . execOnName ( a , c ) } , onText : function ( a , c , d ) { return this . textRules . exec ( a , c , d ) } , onComment : function ( a , c , d ) { return this . commentRules . exec ( a , c , d ) } , onRoot : function ( a , c ) { return this . rootRules . exec ( a , c ) } , onElement : function ( a , c ) { for ( var d = [ this . elementsRules [ "^" ] , this . elementsRules [ c . name ] , this . elementsRules . $ ] , e , k= 0 ; 3 > k ; k ++ ) if ( e = d [ k ] ) { e = e . exec ( a , c , this ) ; if ( ! 1 === e ) return null ; if ( e && e != c ) return this . onNode ( a , e ) ; if ( c . parent && ! c . name ) break } return c } ,
onNode : function ( a , c ) { var d = c . type ; return d == CKEDITOR . NODE _ELEMENT ? this . onElement ( a , c ) : d == CKEDITOR . NODE _TEXT ? new CKEDITOR . htmlParser . text ( this . onText ( a , c . value , c ) ) : d == CKEDITOR . NODE _COMMENT ? new CKEDITOR . htmlParser . comment ( this . onComment ( a , c . value , c ) ) : null } , onAttribute : function ( a , c , d , e ) { return ( d = this . attributesRules [ d ] ) ? d . exec ( a , e , c , this ) : e } } } ) ; CKEDITOR . htmlParser . filterRulesGroup = a ; a . prototype = { add : function ( a , c , d ) { this . rules . splice ( this . findIndex ( c ) , 0 , { value : a , priority : c , options : d } ) } , addMany : function ( a ,
c , d ) { for ( var e = [ this . findIndex ( c ) , 0 ] , h= 0 , k = a . length ; h < k ; h ++ ) e . push ( { value : a [ h ] , priority : c , options : d } ) ; this . rules . splice . apply ( this . rules , e ) } , findIndex : function ( a ) { for ( var c = this . rules , d = c . length - 1 ; 0 <= d && a < c [ d ] . priority ; ) d -- ; return d + 1 } , exec : function ( a , c ) { var d = c instanceof CKEDITOR . htmlParser . node || c instanceof CKEDITOR . htmlParser . fragment , e = Array . prototype . slice . call ( arguments , 1 ) , h= this . rules , k = h . length , l , q , f , w ; for ( w = 0 ; w < k ; w ++ ) if ( d && ( l = c . type , q = c . name ) , f = h [ w ] , ! ( a . nonEditable && ! f . options . applyToAll ||
a . nestedEditable && f. options . excludeNestedEditable ) ) { f = f . value . apply ( null , e ) ; if ( ! 1 === f|| d && f && ( f . name != q || f . type != l ) ) return f ; null != f && ( e [ 0 ] = c = f ) } return c } , execOnName : function ( a , c ) { for ( var d = 0 , e = this . rules , h= e . length , k ; c && d < h ; d ++ ) k = e [ d ] , a . nonEditable && ! k . options . applyToAll || a . nestedEditable && k . options . excludeNestedEditable || ( c = c . replace ( k. value [ 0 ] , k . value [ 1 ] ) ) ; return c } } } ) ( ) ;
( function ( ) { function a ( a , d ) { function f ( a ) { return a || CKEDITOR . env . needsNbspFiller ? new CKEDITOR . htmlParser . text ( " " ) : new CKEDITOR . htmlParser . element ( "br" , { "data-cke-bogus" : 1 } ) } function t ( a , d ) { return function ( g) { if ( g . type != CKEDITOR . NODE _DOCUMENT _FRAGMENT ) { var n= [ ] , t = b ( g ) , h , C ; if ( t ) for ( x ( t , 1 ) && n . push ( t ) ; t ; ) e ( t ) && ( h = c ( t ) ) && x( h ) && ( ( C = c ( h ) ) && ! e ( C) ? n . push ( h ) : ( f ( k ) . insertAfter ( h ) , h . remove ( ) ) ) , t = t . previous ; for ( t = 0 ; t < n. length ; t ++ ) n [ t ] . remove ( ) ; if ( n = ! a || ! 1 !== ( "function" == typeof d ? d ( g) : d ) ) k || CKEDITOR . env . needsBrFiller ||
g . type != CKEDITOR . NODE _DOCUMENT _FRAGMENT ? k || CKEDITOR . env . needsBrFiller || ! ( 7 < document . documentMode || g . name in CKEDITOR . dtd . tr || g . name in CKEDITOR . dtd . $listItem ) ? ( n= b ( g ) , n = ! n || "form" == g . name && "input" == n . name ) : n = ! 1 : n = ! 1 ; n && g . add ( f ( a ) ) } } } function x ( a , b ) { if ( ( ! k || CKEDITOR . env . needsBrFiller ) && a . type == CKEDITOR . NODE _ELEMENT && "br" == a . name && ! a . attributes [ "data-cke-eol" ] ) return ! 0 ; var c ; return a . type == CKEDITOR . NODE _TEXT && ( c = a . value . match ( L ) ) && ( c . index && ( ( new CKEDITOR . htmlParser . text ( a . value . substring ( 0 , c . index ) ) ) . insertBefore ( a ) ,
a . value = c [ 0 ] ) , ! CKEDITOR . env . needsBrFiller && k && ( ! b || a . parent . name in D) || ! k && ( ( c = a . previous ) && "br" == c . name || ! c || e ( c ) ) ) ? ! 0 : ! 1 } var C= { elements : { } } , k = "html" == d , D = CKEDITOR . tools . extend ( { } , p) , E ; for ( E in D ) "#" in J [ E ] || delete D [ E ] ; for ( E in D ) C . elements [ E ] = t ( k , a . config . fillEmptyBlocks ) ; C . root = t ( k , ! 1 ) ; C . elements . br = function ( a ) { return function ( b ) { if ( b . parent . type != CKEDITOR . NODE _DOCUMENT _FRAGMENT ) { var d = b . attributes ; if ( "data-cke-bogus" in d || "data-cke-eol" in d ) delete d [ "data-cke-bogus" ] ; else { for ( d = b . next ; d && g ( d ) ; ) d =
d . next ; var n = c ( b ) ; ! d && e ( b . parent ) ? h( b . parent , f ( a ) ) : e ( d ) && n&& ! e ( n ) && f ( a ) . insertBefore ( d ) } } } } ( k) ; return C } function d ( a , b ) { return a != CKEDITOR . ENTER _BR && ! 1 !== b ? a == CKEDITOR . ENTER _DIV ? "div" : "p" : ! 1 } function b ( a ) { for ( a = a . children [ a . children . length - 1 ] ; a && g ( a ) ; ) a = a . previous ; return a } function c ( a ) { for ( a = a . previous ; a && g ( a ) ; ) a = a . previous ; return a } function g ( a ) { return a . type == CKEDITOR . NODE _TEXT && ! CKEDITOR . tools . trim ( a . value ) || a . type == CKEDITOR . NODE _ELEMENT && a . attributes [ "data-cke-bookmark" ] } function e ( a ) { return a &&
( a . type == CKEDITOR . NODE _ELEMENT && a . name in p || a . type == CKEDITOR . NODE _DOCUMENT _FRAGMENT ) } function h ( a , b ) { var c = a . children [ a . children . length - 1 ] ; a . children . push ( b ) ; b . parent = a ; c && ( c . next = b , b . previous = c ) } function k ( a ) { a = a . attributes ; "false" != a . contenteditable && ( a [ "data-cke-editable" ] = a . contenteditable ? "true" : 1 ) ; a . contenteditable = "false" } function l ( a ) { a = a . attributes ; switch ( a [ "data-cke-editable" ] ) { case "true" : a . contenteditable = "true" ; break ; case "1" : delete a . contenteditable } } function q ( a , b ) { return a . replace ( t ,
function ( a , c , d ) { return "\x3c" + c + d . replace ( D , function ( a , c ) { return C . test ( c ) && - 1 == d . indexOf ( "data-cke-saved-" + c ) ? " data-cke-saved-" + a + " data-cke-" + b + "-" + a : a } ) + "\x3e" } ) } function f ( a , b ) { return a . replace ( b , function ( a , b , c ) { 0 === a . indexOf ( "\x3ctextarea" ) && ( a = b + y ( c ) . replace ( /</g , "\x26lt;" ) . replace ( />/g , "\x26gt;" ) + "\x3c/textarea\x3e" ) ; return "\x3ccke:encoded\x3e" + encodeURIComponent ( a ) + "\x3c/cke:encoded\x3e" } ) } function w ( a ) { return a . replace ( N , function ( a , b ) { return decodeURIComponent ( b ) } ) } function B ( a ) { return a . replace ( /\x3c!--(?!{cke_protected})[\s\S]+?--\x3e/g ,
function ( a ) { return "\x3c!--" + v + "{C}" + encodeURIComponent ( a ) . replace ( /--/g , "%2D%2D" ) + "--\x3e" } ) } function y ( a ) { return a . replace ( /\x3c!--\{cke_protected\}\{C\}([\s\S]+?)--\x3e/g , function ( a , b ) { return decodeURIComponent ( b ) } ) } function F ( a , b ) { var c = b . _ . dataStore ; return a . replace ( /\x3c!--\{cke_protected\}([\s\S]+?)--\x3e/g , function ( a , b ) { return decodeURIComponent ( b ) } ) . replace ( /\{cke_protected_(\d+)\}/g , function ( a , b ) { return c && c [ b ] || "" } ) } function r ( a , b , c ) { var d = [ ] , e = b . config . protectedSource , g = b . _ . dataStore ||
( b . _ . dataStore = { id : 1 } ) , f = new RegExp ( "\x3c\\!--\\{cke_temp_" + c + "(comment)?\\}(\\d*?)--\x3e" , "g" ) , e = [ /<script[\s\S]*?(<\/script>|$)/gi , /<noscript[\s\S]*?<\/noscript>/gi , /<meta[\s\S]*?\/?>/gi ] . concat ( e ) ; a = a . replace ( /\x3c!--[\s\S]*?--\x3e/g , function ( a ) { return "\x3c!--{cke_temp_" + c + "comment}" + ( d . push ( a ) - 1 ) + "--\x3e" } ) ; for ( var t = 0 ; t < e . length ; t ++ ) a = a . replace ( e [ t ] , function ( a ) { a = a . replace ( f , function ( a , b , c ) { return d [ c ] } ) ; return f . test ( a ) ? a : "\x3c!--{cke_temp_" + c + "}" + ( d . push ( a ) - 1 ) + "--\x3e" } ) ; a = a . replace ( f , function ( a ,
b , c ) { return "\x3c!--" + v + ( b ? "{C}" : "" ) + encodeURIComponent ( d [ c ] ) . replace ( /--/g , "%2D%2D" ) + "--\x3e" } ) ; a = a . replace ( /<\w+(?:\s+(?:(?:[^\s=>]+\s*=\s*(?:[^'"\s>]+|'[^']*'|"[^"]*"))|[^\s=\/>]+))+\s*\/?>/g , function ( a ) { return a . replace ( /\x3c!--\{cke_protected\}([^>]*)--\x3e/g , function ( a , b ) { g[ g . id ] = decodeURIComponent ( b ) ; return "{cke_protected_" + g . id ++ + "}" } ) } ) ; return a = a . replace ( /<(title|iframe|textarea)([^>]*)>([\s\S]*?)<\/\1>/g , function ( a , c , d , e ) { return "\x3c" + c + d + "\x3e" + F( y ( e ) , b ) + "\x3c/" + c + "\x3e" } ) } var m ; CKEDITOR . htmlDataProcessor =
function ( b ) { var c , e , g = this ; this . editor = b ; this . dataFilter = c = new CKEDITOR . htmlParser . filter ; this . htmlFilter = e = new CKEDITOR . htmlParser . filter ; this . writer = new CKEDITOR . htmlParser . basicWriter ; c . addRules ( u ) ; c . addRules ( K , { applyToAll : ! 0 } ) ; c . addRules ( a ( b , "data" ) , { applyToAll : ! 0 } ) ; e . addRules ( E) ; e . addRules ( z , { applyToAll : ! 0 } ) ; e . addRules ( a ( b , "html" ) , { applyToAll : ! 0 } ) ; b . on ( "toHtml" , function ( a ) { var c ; var e = window . crypto || window . msCrypto ; c = e ? e . getRandomValues ( new Uint32Array ( 1 ) ) [ 0 ] : Math . floor ( 9E9 * Math . random ( ) + 1E9 ) ;
a = a . data ; var e = a . dataValue , e = m ( e ) , e = r( e , b , c ) , e = f ( e , T ) , e = q ( e , c ) , e = f ( e , I ) , e = e . replace ( x , "$1cke:$2" ) , e = e . replace ( M , "\x3ccke:$1$2\x3e\x3c/cke:$1\x3e" ) , e = e . replace ( /(<pre\b[^>]*>)(\r\n|\n)/g , "$1$2$2" ) , e = e . replace ( /([^a-z0-9<\-])(on\w{3,})(?!>)/gi , "$1data-cke-" + c + "-$2" ) , g = a . context || b . editable ( ) . getName ( ) , t ; CKEDITOR . env . ie && 9 > CKEDITOR . env . version && "pre" == g&& ( g = "div" , e = "\x3cpre\x3e" + e + "\x3c/pre\x3e" , t = 1 ) ; g= b . document . createElement ( g ) ; g . setHtml ( "a" + e ) ; e = g . getHtml ( ) . substr ( 1 ) ; e = e . replace ( new RegExp ( "data-cke-" +
c + "-" , "ig" ) , "" ) ; t && ( e = e . replace ( /^<pre>|<\/pre>$/gi , "" ) ) ; e = e . replace ( H, "$1$2" ) ; e = w ( e ) ; e = y ( e ) ; c = ! 1 === a . fixForBody ? ! 1 : d ( a . enterMode , b . config . autoParagraph ) ; e = CKEDITOR . htmlParser . fragment . fromHtml ( e , a . context , c ) ; c && ( t = e , ! t . children . length && CKEDITOR . dtd [ t . name ] [ c ] && ( c = new CKEDITOR . htmlParser . element ( c ) , t . add ( c ) ) ) ; a . dataValue = e } , null , null , 5 ) ; b . on ( "toHtml" , function ( a ) { a . data . filter . applyTo ( a . data . dataValue , ! 0 , a . data . dontFilter , a . data . enterMode ) && b . fire ( "dataFiltered" ) } , null , null , 6 ) ; b . on ( "toHtml" , function ( a ) { a . data . dataValue . filterChildren ( g . dataFilter ,
! 0 ) } , null , null , 10 ) ; b . on ( "toHtml" , function ( a ) { a = a . data ; var b = a . dataValue , c = new CKEDITOR . htmlParser . basicWriter ; b . writeChildrenHtml ( c ) ; b = c . getHtml ( ! 0 ) ; a . dataValue = B ( b ) } , null , null , 15 ) ; b . on ( "toDataFormat" , function ( a ) { var c = a . data . dataValue ; a . data . enterMode != CKEDITOR . ENTER _BR && ( c = c . replace ( /^<br *\/?>/i , "" ) ) ; a . data . dataValue = CKEDITOR . htmlParser . fragment . fromHtml ( c , a . data . context , d ( a . data . enterMode , b . config . autoParagraph ) ) } , null , null , 5 ) ; b . on ( "toDataFormat" , function ( a ) { a . data . dataValue . filterChildren ( g . htmlFilter ,
! 0 ) } , null , null , 10 ) ; b . on ( "toDataFormat" , function ( a ) { a . data . filter . applyTo ( a . data . dataValue , ! 1 , ! 0 ) } , null , null , 11 ) ; b . on ( "toDataFormat" , function ( a ) { var c = a . data . dataValue , e = g . writer ; e . reset ( ) ; c . writeChildrenHtml ( e ) ; c = e . getHtml ( ! 0 ) ; c = y( c ) ; c = F ( c , b ) ; a . data . dataValue = c } , null , null , 15 ) } ; CKEDITOR . htmlDataProcessor . prototype = { toHtml : function ( a , b , c , e ) { var d = this . editor , g, f , t , h ; b && "object" == typeof b ? ( g = b . context , c = b . fixForBody , e = b . dontFilter , f = b . filter , t = b . enterMode , h= b . protectedWhitespaces ) : g = b ; g || null === g || ( g =
d . editable ( ) . getName ( ) ) ; return d . fire ( "toHtml" , { dataValue : a , context : g , fixForBody : c , dontFilter : e , filter : f || d . filter , enterMode : t || d . enterMode , protectedWhitespaces : h } ) . dataValue } , toDataFormat : function ( a , b ) { var c , e , d ; b && ( c = b . context , e = b . filter , d = b . enterMode ) ; c || null === c || ( c = this . editor . editable ( ) . getName ( ) ) ; return this . editor . fire ( "toDataFormat" , { dataValue : a , filter : e || this . editor . filter , context : c , enterMode : d || this . editor . enterMode } ) . dataValue } , protectSource : function ( a ) { return r ( a , this . editor ) } , unprotectSource : function ( a ) { return F ( a ,
this . editor ) } , unprotectRealComments : function ( a ) { return y( a ) } } ; var L = /(?: |\xa0)$/ , v = "{cke_protected}" , J = CKEDITOR . dtd , G = "caption colgroup col thead tfoot tbody" . split ( " " ) , p = CKEDITOR . tools . extend ( { } , J . $blockLimit , J . $block ) , u = { elements : { input : k, textarea : k } } , K = { attributeNames : [ [ /^on/ , "data-cke-pa-on" ] , [ /^srcdoc/ , "data-cke-pa-srcdoc" ] , [ /^data-cke-expando$/ , "" ] ] , elements : { iframe : function ( a ) { if ( a . attributes && a . attributes . src ) { var b = a . attributes . src . toLowerCase ( ) . replace ( /[^a-z]/gi , "" ) ; if ( 0 === b . indexOf ( "javascript" ) ||
0 === b . indexOf ( "data" ) ) a . attributes [ "data-cke-pa-src" ] = a . attributes . src , delete a . attributes . src } } } } , E = { elements : { embed : function ( a ) { var b = a . parent ; if ( b && "object" == b . name ) { var c = b . attributes . width , b = b . attributes . height ; c && ( a . attributes . width = c ) ; b && ( a . attributes . height = b ) } } , a : function ( a ) { var b = a . attributes ; if ( ! ( a . children . length || b . name || b . id || a . attributes [ "data-cke-saved-name" ] ) ) return ! 1 } } } , z = { elementNames : [ [ /^cke:/ , "" ] , [ /^\?xml:namespace$/ , "" ] ] , attributeNames : [ [ /^data-cke-(saved|pa)-/ , "" ] , [ /^data-cke-.*/ ,
"" ] , [ "hidefocus" , "" ] ] , elements : { $ : function ( a ) { var b = a . attributes ; if ( b ) { if ( b [ "data-cke-temp" ] ) return ! 1 ; for ( var c = [ "name" , "href" , "src" ] , e , d = 0 ; d < c . length ; d ++ ) e = "data-cke-saved-" + c [ d ] , e in b && delete b [ c [ d ] ] } return a } , table : function ( a ) { a . children . slice ( 0 ) . sort ( function ( a , b ) { var c , e ; a . type == CKEDITOR . NODE _ELEMENT && b . type == a . type && ( c = CKEDITOR . tools . indexOf ( G , a . name ) , e = CKEDITOR . tools . indexOf ( G , b . name ) ) ; - 1 < c && - 1 < e && c != e || ( c = a . parent ? a . getIndex ( ) : - 1 , e = b . parent ? b . getIndex ( ) : - 1 ) ; return c > e ? 1 : - 1 } ) } , param : function ( a ) { a . children =
[ ] ; a . isEmpty = ! 0 ; return a } , span : function ( a ) { "Apple-style-span" == a . attributes [ "class" ] && delete a . name } , html : function ( a ) { delete a . attributes . contenteditable ; delete a . attributes [ "class" ] } , body : function ( a ) { delete a . attributes . spellcheck ; delete a . attributes . contenteditable } , style : function ( a ) { var b = a . children [ 0 ] ; b && b . value && ( b . value = CKEDITOR . tools . trim ( b . value ) ) ; a . attributes . type || ( a . attributes . type = "text/css" ) } , title : function ( a ) { var b = a . children [ 0 ] ; ! b && h ( a , b = new CKEDITOR . htmlParser . text ) ; b . value = a . attributes [ "data-cke-title" ] ||
"" } , input : l, textarea : l } , attributes : { "class" : function ( a ) { return CKEDITOR . tools . ltrim ( a . replace ( /(?:^|\s+)cke_[^\s]*/g , "" ) ) || ! 1 } } } ; CKEDITOR . env . ie && ( z . attributes . style = function ( a ) { return a . replace ( /(^|;)([^\:]+)/g , function ( a ) { return a . toLowerCase ( ) } ) } ) ; var t = /<(a|area|img|input|source)\b([^>]*)>/gi , D = /([\w-:]+)\s*=\s*(?:(?:"[^"]*")|(?:'[^']*')|(?:[^ "'>]+))/gi , C = /^(href|src|name)$/i , I = /(?:<style(?=[ >])[^>]*>[\s\S]*?<\/style>)|(?:<(:?link|meta|base)[^>]*>)/gi , T = /(<textarea(?=[ >])[^>]*>)([\s\S]*?)(?:<\/textarea>)/gi ,
N= /<cke:encoded>([^<]*)<\/cke:encoded>/gi , x = /(<\/?)((?:object|embed|param|html|body|head|title)([\s][^>]*)?>)/gi , H= /(<\/?)cke:((?:html|body|head|title)[^>]*>)/gi , M = /<cke:(param|embed)([^>]*?)\/?>(?!\s*<\/cke:\1)/gi ; m = function ( ) { function a ( b , c ) { for ( var e = 0 ; e < b . length ; e ++ ) { var d = b [ e ] ; d . lastIndex = 0 ; if ( d . test ( c ) ) return ! 0 } return ! 1 } function b ( a ) { return CKEDITOR . tools . array . reduce ( a . split ( "" ) , function ( a , b ) { var e = b . toLowerCase ( ) , d = b . toUpperCase ( ) , g = c ( e ) ; e !== d && ( g += "|" + c ( d ) ) ; return a + ( "(" + g + ")" ) } , "" ) } function c ( a ) { var b ;
c , d ) { for ( var e = [ this . findIndex ( c ) , 0 ] , k= 0 , h = a . length ; k < h ; k ++ ) e . push ( { value : a [ k ] , priority : c , options : d } ) ; this . rules . splice . apply ( this . rules , e ) } , findIndex : function ( a ) { for ( var c = this . rules , d = c . length - 1 ; 0 <= d && a < c [ d ] . priority ; ) d -- ; return d + 1 } , exec : function ( a , c ) { var d = c instanceof CKEDITOR . htmlParser . node || c instanceof CKEDITOR . htmlParser . fragment , e = Array . prototype . slice . call ( arguments , 1 ) , k= this . rules , h = k . length , n , l , g , x ; for ( x = 0 ; x < h ; x ++ ) if ( d && ( n = c . type , l = c . name ) , g = k [ x ] , ! ( a . nonEditable && ! g . options . applyToAll ||
a . nestedEditable && g. options . excludeNestedEditable ) ) { g = g . value . apply ( null , e ) ; if ( ! 1 === g|| d && g && ( g . name != l || g . type != n ) ) return g ; null != g && ( e [ 0 ] = c = g ) } return c } , execOnName : function ( a , c ) { for ( var d = 0 , e = this . rules , k= e . length , h ; c && d < k ; d ++ ) h = e [ d ] , a . nonEditable && ! h . options . applyToAll || a . nestedEditable && h . options . excludeNestedEditable || ( c = c . replace ( h. value [ 0 ] , h . value [ 1 ] ) ) ; return c } } } ) ( ) ;
( function ( ) { function a ( a , d ) { function g ( a ) { return a || CKEDITOR . env . needsNbspFiller ? new CKEDITOR . htmlParser . text ( " " ) : new CKEDITOR . htmlParser . element ( "br" , { "data-cke-bogus" : 1 } ) } function t ( a , d ) { return function ( f) { if ( f . type != CKEDITOR . NODE _DOCUMENT _FRAGMENT ) { var p= [ ] , t = b ( f ) , h , k ; if ( t ) for ( r ( t , 1 ) && p . push ( t ) ; t ; ) e ( t ) && ( h = c ( t ) ) && r( h ) && ( ( k = c ( h ) ) && ! e ( k) ? p . push ( h ) : ( g ( A ) . insertAfter ( h ) , h . remove ( ) ) ) , t = t . previous ; for ( t = 0 ; t < p. length ; t ++ ) p [ t ] . remove ( ) ; if ( p = ! a || ! 1 !== ( "function" == typeof d ? d ( f) : d ) ) A || CKEDITOR . env . needsBrFiller ||
f . type != CKEDITOR . NODE _DOCUMENT _FRAGMENT ? A || CKEDITOR . env . needsBrFiller || ! ( 7 < document . documentMode || f . name in CKEDITOR . dtd . tr || f . name in CKEDITOR . dtd . $listItem ) ? ( p= b ( f ) , p = ! p || "form" == f . name && "input" == p . name ) : p = ! 1 : p = ! 1 ; p && f . add ( g ( a ) ) } } } function r ( a , b ) { if ( ( ! A || CKEDITOR . env . needsBrFiller ) && a . type == CKEDITOR . NODE _ELEMENT && "br" == a . name && ! a . attributes [ "data-cke-eol" ] ) return ! 0 ; var c ; return a . type == CKEDITOR . NODE _TEXT && ( c = a . value . match ( M ) ) && ( c . index && ( ( new CKEDITOR . htmlParser . text ( a . value . substring ( 0 , c . index ) ) ) . insertBefore ( a ) ,
a . value = c [ 0 ] ) , ! CKEDITOR . env . needsBrFiller && A && ( ! b || a . parent . name in H) || ! A && ( ( c = a . previous ) && "br" == c . name || ! c || e ( c ) ) ) ? ! 0 : ! 1 } var h= { elements : { } } , A = "html" == d , H = CKEDITOR . tools . extend ( { } , q) , D ; for ( D in H ) "#" in J [ D ] || delete H [ D ] ; for ( D in H ) h . elements [ D ] = t ( A , a . config . fillEmptyBlocks ) ; h . root = t ( A , ! 1 ) ; h . elements . br = function ( a ) { return function ( b ) { if ( b . parent . type != CKEDITOR . NODE _DOCUMENT _FRAGMENT ) { var d = b . attributes ; if ( "data-cke-bogus" in d || "data-cke-eol" in d ) delete d [ "data-cke-bogus" ] ; else { for ( d = b . next ; d && f ( d ) ; ) d =
d . next ; var p = c ( b ) ; ! d && e ( b . parent ) ? k( b . parent , g ( a ) ) : e ( d ) && p&& ! e ( p ) && g ( a ) . insertBefore ( d ) } } } } ( A) ; return h } function d ( a , b ) { return a != CKEDITOR . ENTER _BR && ! 1 !== b ? a == CKEDITOR . ENTER _DIV ? "div" : "p" : ! 1 } function b ( a ) { for ( a = a . children [ a . children . length - 1 ] ; a && f ( a ) ; ) a = a . previous ; return a } function c ( a ) { for ( a = a . previous ; a && f ( a ) ; ) a = a . previous ; return a } function f ( a ) { return a . type == CKEDITOR . NODE _TEXT && ! CKEDITOR . tools . trim ( a . value ) || a . type == CKEDITOR . NODE _ELEMENT && a . attributes [ "data-cke-bookmark" ] } function e ( a ) { return a &&
( a . type == CKEDITOR . NODE _ELEMENT && a . name in q || a . type == CKEDITOR . NODE _DOCUMENT _FRAGMENT ) } function k ( a , b ) { var c = a . children [ a . children . length - 1 ] ; a . children . push ( b ) ; b . parent = a ; c && ( c . next = b , b . previous = c ) } function h ( a ) { a = a . attributes ; "false" != a . contenteditable && ( a [ "data-cke-editable" ] = a . contenteditable ? "true" : 1 ) ; a . contenteditable = "false" } function n ( a ) { a = a . attributes ; switch ( a [ "data-cke-editable" ] ) { case "true" : a . contenteditable = "true" ; break ; case "1" : delete a . contenteditable } } function l ( a , b ) { return a . replace ( t ,
function ( a , c , d ) { return "\x3c" + c + d . replace ( H , function ( a , c ) { return A . test ( c ) && - 1 == d . indexOf ( "data-cke-saved-" + c ) ? " data-cke-saved-" + a + " data-cke-" + b + "-" + a : a } ) + "\x3e" } ) } function g ( a , b ) { return a . replace ( b , function ( a , b , c ) { 0 === a . indexOf ( "\x3ctextarea" ) && ( a = b + z ( c ) . replace ( /</g , "\x26lt;" ) . replace ( />/g , "\x26gt;" ) + "\x3c/textarea\x3e" ) ; return "\x3ccke:encoded\x3e" + encodeURIComponent ( a ) + "\x3c/cke:encoded\x3e" } ) } function x ( a ) { return a . replace ( L , function ( a , b ) { return decodeURIComponent ( b ) } ) } function y ( a ) { return a . replace ( /\x3c!--(?!{cke_protected})[\s\S]+?--\x3e/g ,
function ( a ) { return "\x3c!--" + w + "{C}" + encodeURIComponent ( a ) . replace ( /--/g , "%2D%2D" ) + "--\x3e" } ) } function z ( a ) { return a . replace ( /\x3c!--\{cke_protected\}\{C\}([\s\S]+?)--\x3e/g , function ( a , b ) { return decodeURIComponent ( b ) } ) } function G ( a , b ) { var c = b . _ . dataStore ; return a . replace ( /\x3c!--\{cke_protected\}([\s\S]+?)--\x3e/g , function ( a , b ) { return decodeURIComponent ( b ) } ) . replace ( /\{cke_protected_(\d+)\}/g , function ( a , b ) { return c && c [ b ] || "" } ) } function v ( a , b , c ) { var d = [ ] , e = b . config . protectedSource , f = b . _ . dataStore ||
( b . _ . dataStore = { id : 1 } ) , g = new RegExp ( "\x3c\\!--\\{cke_temp_" + c + "(comment)?\\}(\\d*?)--\x3e" , "g" ) , e = [ /<script[\s\S]*?(<\/script>|$)/gi , /<noscript[\s\S]*?<\/noscript>/gi , /<meta[\s\S]*?\/?>/gi ] . concat ( e ) ; a = a . replace ( /\x3c!--[\s\S]*?--\x3e/g , function ( a ) { return "\x3c!--{cke_temp_" + c + "comment}" + ( d . push ( a ) - 1 ) + "--\x3e" } ) ; for ( var t = 0 ; t < e . length ; t ++ ) a = a . replace ( e [ t ] , function ( a ) { a = a . replace ( g , function ( a , b , c ) { return d [ c ] } ) ; return g . test ( a ) ? a : "\x3c!--{cke_temp_" + c + "}" + ( d . push ( a ) - 1 ) + "--\x3e" } ) ; a = a . replace ( g , function ( a ,
b , c ) { return "\x3c!--" + w + ( b ? "{C}" : "" ) + encodeURIComponent ( d [ c ] ) . replace ( /--/g , "%2D%2D" ) + "--\x3e" } ) ; a = a . replace ( /<\w+(?:\s+(?:(?:[^\s=>]+\s*=\s*(?:[^'"\s>]+|'[^']*'|"[^"]*"))|[^\s=\/>]+))+\s*\/?>/g , function ( a ) { return a . replace ( /\x3c!--\{cke_protected\}([^>]*)--\x3e/g , function ( a , b ) { f[ f . id ] = decodeURIComponent ( b ) ; return "{cke_protected_" + f . id ++ + "}" } ) } ) ; return a = a . replace ( /<(title|iframe|textarea)([^>]*)>([\s\S]*?)<\/\1>/g , function ( a , c , d , e ) { return "\x3c" + c + d + "\x3e" + G( z ( e ) , b ) + "\x3c/" + c + "\x3e" } ) } var m ; CKEDITOR . htmlDataProcessor =
function ( b ) { var c , e , f = this ; this . editor = b ; this . dataFilter = c = new CKEDITOR . htmlParser . filter ; this . htmlFilter = e = new CKEDITOR . htmlParser . filter ; this . writer = new CKEDITOR . htmlParser . basicWriter ; c . addRules ( u ) ; c . addRules ( K , { applyToAll : ! 0 } ) ; c . addRules ( a ( b , "data" ) , { applyToAll : ! 0 } ) ; e . addRules ( D) ; e . addRules ( B , { applyToAll : ! 0 } ) ; e . addRules ( a ( b , "html" ) , { applyToAll : ! 0 } ) ; b . on ( "toHtml" , function ( a ) { var c ; var e = window . crypto || window . msCrypto ; c = e ? e . getRandomValues ( new Uint32Array ( 1 ) ) [ 0 ] : Math . floor ( 9E9 * Math . random ( ) + 1E9 ) ;
a = a . data ; var e = a . dataValue , e = m ( e ) , e = v( e , b , c ) , e = g ( e , N ) , e = l ( e , c ) , e = g ( e , I ) , e = e . replace ( r , "$1cke:$2" ) , e = e . replace ( S , "\x3ccke:$1$2\x3e\x3c/cke:$1\x3e" ) , e = e . replace ( /(<pre\b[^>]*>)(\r\n|\n)/g , "$1$2$2" ) , e = e . replace ( /([^a-z0-9<\-])(on\w{3,})(?!>)/gi , "$1data-cke-" + c + "-$2" ) , f = a . context || b . editable ( ) . getName ( ) , t ; CKEDITOR . env . ie && 9 > CKEDITOR . env . version && "pre" == f&& ( f = "div" , e = "\x3cpre\x3e" + e + "\x3c/pre\x3e" , t = 1 ) ; f= b . document . createElement ( f ) ; f . setHtml ( "a" + e ) ; e = f . getHtml ( ) . substr ( 1 ) ; e = e . replace ( new RegExp ( "data-cke-" +
c + "-" , "ig" ) , "" ) ; t && ( e = e . replace ( /^<pre>|<\/pre>$/gi , "" ) ) ; e = e . replace ( E, "$1$2" ) ; e = x ( e ) ; e = z ( e ) ; c = ! 1 === a . fixForBody ? ! 1 : d ( a . enterMode , b . config . autoParagraph ) ; e = CKEDITOR . htmlParser . fragment . fromHtml ( e , a . context , c ) ; c && ( t = e , ! t . children . length && CKEDITOR . dtd [ t . name ] [ c ] && ( c = new CKEDITOR . htmlParser . element ( c ) , t . add ( c ) ) ) ; a . dataValue = e } , null , null , 5 ) ; b . on ( "toHtml" , function ( a ) { a . data . filter . applyTo ( a . data . dataValue , ! 0 , a . data . dontFilter , a . data . enterMode ) && b . fire ( "dataFiltered" ) } , null , null , 6 ) ; b . on ( "toHtml" , function ( a ) { a . data . dataValue . filterChildren ( f . dataFilter ,
! 0 ) } , null , null , 10 ) ; b . on ( "toHtml" , function ( a ) { a = a . data ; var b = a . dataValue , c = new CKEDITOR . htmlParser . basicWriter ; b . writeChildrenHtml ( c ) ; b = c . getHtml ( ! 0 ) ; a . dataValue = y ( b ) } , null , null , 15 ) ; b . on ( "toDataFormat" , function ( a ) { var c = a . data . dataValue ; a . data . enterMode != CKEDITOR . ENTER _BR && ( c = c . replace ( /^<br *\/?>/i , "" ) ) ; a . data . dataValue = CKEDITOR . htmlParser . fragment . fromHtml ( c , a . data . context , d ( a . data . enterMode , b . config . autoParagraph ) ) } , null , null , 5 ) ; b . on ( "toDataFormat" , function ( a ) { a . data . dataValue . filterChildren ( f . htmlFilter ,
! 0 ) } , null , null , 10 ) ; b . on ( "toDataFormat" , function ( a ) { a . data . filter . applyTo ( a . data . dataValue , ! 1 , ! 0 ) } , null , null , 11 ) ; b . on ( "toDataFormat" , function ( a ) { var c = a . data . dataValue , e = f . writer ; e . reset ( ) ; c . writeChildrenHtml ( e ) ; c = e . getHtml ( ! 0 ) ; c = z( c ) ; c = G ( c , b ) ; a . data . dataValue = c } , null , null , 15 ) } ; CKEDITOR . htmlDataProcessor . prototype = { toHtml : function ( a , b , c , e ) { var d = this . editor , f, g , t , r ; b && "object" == typeof b ? ( f = b . context , c = b . fixForBody , e = b . dontFilter , g = b . filter , t = b . enterMode , r= b . protectedWhitespaces ) : f = b ; f || null === f || ( f =
d . editable ( ) . getName ( ) ) ; return d . fire ( "toHtml" , { dataValue : a , context : f , fixForBody : c , dontFilter : e , filter : g || d . filter , enterMode : t || d . enterMode , protectedWhitespaces : r } ) . dataValue } , toDataFormat : function ( a , b ) { var c , e , d ; b && ( c = b . context , e = b . filter , d = b . enterMode ) ; c || null === c || ( c = this . editor . editable ( ) . getName ( ) ) ; return this . editor . fire ( "toDataFormat" , { dataValue : a , filter : e || this . editor . filter , context : c , enterMode : d || this . editor . enterMode } ) . dataValue } , protectSource : function ( a ) { return v ( a , this . editor ) } , unprotectSource : function ( a ) { return G ( a ,
this . editor ) } , unprotectRealComments : function ( a ) { return z( a ) } } ; var M = /(?: |\xa0)$/ , w = "{cke_protected}" , J = CKEDITOR . dtd , F = "caption colgroup col thead tfoot tbody" . split ( " " ) , q = CKEDITOR . tools . extend ( { } , J . $blockLimit , J . $block ) , u = { elements : { input : h, textarea : h } } , K = { attributeNames : [ [ /^on/ , "data-cke-pa-on" ] , [ /^srcdoc/ , "data-cke-pa-srcdoc" ] , [ /^data-cke-expando$/ , "" ] ] , elements : { iframe : function ( a ) { if ( a . attributes && a . attributes . src ) { var b = a . attributes . src . toLowerCase ( ) . replace ( /[^a-z]/gi , "" ) ; if ( 0 === b . indexOf ( "javascript" ) ||
0 === b . indexOf ( "data" ) ) a . attributes [ "data-cke-pa-src" ] = a . attributes . src , delete a . attributes . src } } } } , D = { elements : { embed : function ( a ) { var b = a . parent ; if ( b && "object" == b . name ) { var c = b . attributes . width , b = b . attributes . height ; c && ( a . attributes . width = c ) ; b && ( a . attributes . height = b ) } } , a : function ( a ) { var b = a . attributes ; if ( ! ( a . children . length || b . name || b . id || a . attributes [ "data-cke-saved-name" ] ) ) return ! 1 } } } , B = { elementNames : [ [ /^cke:/ , "" ] , [ /^\?xml:namespace$/ , "" ] ] , attributeNames : [ [ /^data-cke-(saved|pa)-/ , "" ] , [ /^data-cke-.*/ ,
"" ] , [ "hidefocus" , "" ] ] , elements : { $ : function ( a ) { var b = a . attributes ; if ( b ) { if ( b [ "data-cke-temp" ] ) return ! 1 ; for ( var c = [ "name" , "href" , "src" ] , e , d = 0 ; d < c . length ; d ++ ) e = "data-cke-saved-" + c [ d ] , e in b && delete b [ c [ d ] ] } return a } , table : function ( a ) { a . children . slice ( 0 ) . sort ( function ( a , b ) { var c , e ; a . type == CKEDITOR . NODE _ELEMENT && b . type == a . type && ( c = CKEDITOR . tools . indexOf ( F , a . name ) , e = CKEDITOR . tools . indexOf ( F , b . name ) ) ; - 1 < c && - 1 < e && c != e || ( c = a . parent ? a . getIndex ( ) : - 1 , e = b . parent ? b . getIndex ( ) : - 1 ) ; return c > e ? 1 : - 1 } ) } , param : function ( a ) { a . children =
[ ] ; a . isEmpty = ! 0 ; return a } , span : function ( a ) { "Apple-style-span" == a . attributes [ "class" ] && delete a . name } , html : function ( a ) { delete a . attributes . contenteditable ; delete a . attributes [ "class" ] } , body : function ( a ) { delete a . attributes . spellcheck ; delete a . attributes . contenteditable } , style : function ( a ) { var b = a . children [ 0 ] ; b && b . value && ( b . value = CKEDITOR . tools . trim ( b . value ) ) ; a . attributes . type || ( a . attributes . type = "text/css" ) } , title : function ( a ) { var b = a . children [ 0 ] ; ! b && k ( a , b = new CKEDITOR . htmlParser . text ) ; b . value = a . attributes [ "data-cke-title" ] ||
"" } , input : n, textarea : n } , attributes : { "class" : function ( a ) { return CKEDITOR . tools . ltrim ( a . replace ( /(?:^|\s+)cke_[^\s]*/g , "" ) ) || ! 1 } } } ; CKEDITOR . env . ie && ( B . attributes . style = function ( a ) { return a . replace ( /(^|;)([^\:]+)/g , function ( a ) { return a . toLowerCase ( ) } ) } ) ; var t = /<(a|area|img|input|source)\b([^>]*)>/gi , H = /([\w-:]+)\s*=\s*(?:(?:"[^"]*")|(?:'[^']*')|(?:[^ "'>]+))/gi , A = /^(href|src|name)$/i , I = /(?:<style(?=[ >])[^>]*>[\s\S]*?<\/style>)|(?:<(:?link|meta|base)[^>]*>)/gi , N = /(<textarea(?=[ >])[^>]*>)([\s\S]*?)(?:<\/textarea>)/gi ,
L= /<cke:encoded>([^<]*)<\/cke:encoded>/gi , r = /(<\/?)((?:object|embed|param|html|body|head|title)([\s][^>]*)?>)/gi , E= /(<\/?)cke:((?:html|body|head|title)[^>]*>)/gi , S = /<cke:(param|embed)([^>]*?)\/?>(?!\s*<\/cke:\1)/gi ; m = function ( ) { function a ( b , c ) { for ( var e = 0 ; e < b . length ; e ++ ) { var d = b [ e ] ; d . lastIndex = 0 ; if ( d . test ( c ) ) return ! 0 } return ! 1 } function b ( a ) { return CKEDITOR . tools . array . reduce ( a . split ( "" ) , function ( a , b ) { var e = b . toLowerCase ( ) , d = b . toUpperCase ( ) , f = c ( e ) ; e !== d && ( f += "|" + c ( d ) ) ; return a + ( "(" + f + ")" ) } , "" ) } function c ( a ) { var b ;
b = a . charCodeAt ( 0 ) ; var e = b . toString ( 16 ) ; b = { htmlCode : "\x26#" + b + ";?" , hex : "\x26#x0*" + e + ";?" , entity : { "\x3c" : "\x26lt;" , "\x3e" : "\x26gt;" , ":" : "\x26colon;" } [ a ] } ; for ( var d in b ) b [ d ] && ( a += "|" + b [ d ] ) ; return a } var e = [ new RegExp ( "(" + b ( "\x3ccke:encoded\x3e" ) + "(.*?)" + b ( "\x3c/cke:encoded\x3e" ) + ")|(" + b ( "\x3c" ) + b ( "/" ) + "?" + b ( "cke:encoded\x3e" ) + ")" , "gi" ) , new RegExp ( "((" + b ( "{cke_protected" ) + ")(_[0-9]*)?" + b ( "}" ) + ")" , "gi" ) , /<!(?:\s*-\s*){2,3}!?\s*>/g ] ; return function ( b ) { for ( ; a ( e , b ) ; ) for ( var c = e , d = 0 ; d < c . length ; d ++ ) b = b . replace ( c [ d ] ,
"" ) ; return b } } ( ) } ) ( ) ; "use strict" ; CKEDITOR . htmlParser . element = function ( a , d ) { this . name = a ; this . attributes = d || { } ; this . children = [ ] ; var b = a || "" , c = b . match ( /^cke:(.*)/ ) ; c && ( b = c [ 1 ] ) ; b = ! ! ( CKEDITOR . dtd . $nonBodyContent [ b ] || CKEDITOR . dtd . $block [ b ] || CKEDITOR . dtd . $listItem [ b ] || CKEDITOR . dtd . $tableContent [ b ] || CKEDITOR . dtd . $nonEditable [ b ] || "br" == b ) ; this . isEmpty = ! ! CKEDITOR . dtd . $empty [ a ] ; this . isUnknown = ! CKEDITOR . dtd [ a ] ; this . _ = { isBlockLike : b , hasInlineStarted : this . isEmpty || ! b } } ;
CKEDITOR . htmlParser . cssStyle = function ( a ) { var d = { } ; ( ( a instanceof CKEDITOR . htmlParser . element ? a . attributes . style : a ) || "" ) . replace ( /"/g , '"' ) . replace ( /\s*([^ :;]+)\s*:\s*([^;]+)\s*(?=;|$)/g , function ( a , c , g) { "font-family" == c && ( g = g . replace ( /["']/g , "" ) ) ; d [ c . toLowerCase ( ) ] = g } ) ; return { rules : d , populate : function ( a ) { var c = this . toString ( ) ; c && ( a instanceof CKEDITOR . dom . element ? a . setAttribute ( "style" , c ) : a instanceof CKEDITOR . htmlParser . element ? a . attributes . style = c : a . style = c ) } , toString : function ( ) { var a = [ ] , c ;
CKEDITOR . htmlParser . cssStyle = function ( a ) { var d = { } ; ( ( a instanceof CKEDITOR . htmlParser . element ? a . attributes . style : a ) || "" ) . replace ( /"/g , '"' ) . replace ( /\s*([^ :;]+)\s*:\s*([^;]+)\s*(?=;|$)/g , function ( a , c , f) { "font-family" == c && ( f = f . replace ( /["']/g , "" ) ) ; d [ c . toLowerCase ( ) ] = f } ) ; return { rules : d , populate : function ( a ) { var c = this . toString ( ) ; c && ( a instanceof CKEDITOR . dom . element ? a . setAttribute ( "style" , c ) : a instanceof CKEDITOR . htmlParser . element ? a . attributes . style = c : a . style = c ) } , toString : function ( ) { var a = [ ] , c ;
for ( c in d ) d [ c ] && a . push ( c , ":" , d [ c ] , ";" ) ; return a . join ( "" ) } } } ;
( function ( ) { function a ( a ) { return function ( b ) { return b . type == CKEDITOR . NODE _ELEMENT && ( "string" == typeof a ? b . name == a : b . name in a ) } } var d = function ( a , b ) { a = a [ 0 ] ; b = b [ 0 ] ; return a < b ? - 1 : a > b ? 1 : 0 } , b = CKEDITOR . htmlParser . fragment . prototype ; CKEDITOR . htmlParser . element . prototype = CKEDITOR . tools . extend ( new CKEDITOR . htmlParser . node , { type : CKEDITOR . NODE _ELEMENT , add : b . add , clone : function ( ) { return new CKEDITOR . htmlParser . element ( this . name , this . attributes ) } , filter : function ( a , b ) { var e = this , d , k ; b = e . getFilterContext ( b ) ; if ( ! e . parent ) a . onRoot ( b ,
e ) ; for ( ; ; ) { d = e . name ; if ( ! ( k = a . onElementName ( b , d ) ) ) return this . remove ( ) , ! 1 ; e . name = k ; if ( ! ( e = a . onElement ( b , e ) ) ) return this . remove ( ) , ! 1 ; if ( e !== this ) return this . replaceWith ( e ) , ! 1 ; if ( e . name == d ) break ; if ( e . type != CKEDITOR . NODE _ELEMENT ) return this . replaceWith ( e ) , ! 1 ; if ( ! e . name ) return this . replaceWithChildren ( ) , ! 1 } d = e . attributes ; var l, q ; for ( l in d ) { for ( k = d [ l ] ; ; ) if ( q = a . onAttributeName ( b , l ) ) if ( q != l ) delete d [ l ] , l = q ; else break ; else { delete d [ l] ; break } q && ( ! 1 === ( k = a . onAttribute ( b , e , q , k ) ) ? delete d [ q ] : d [ q ] = k ) } e . isEmpty ||
this . filterChildren ( a , ! 1 , b ) ; return ! 0 } , filterChildren : b . filterChildren , writeHtml : function ( a , b ) { b && this . filter ( b ) ; var e = this . name , h= [ ] , k = this . attributes , l , q ; a . openTag ( e , k ) ; for ( l in k ) h . push ( [ l , k [ l ] ] ) ; a . sortAttributes && h. sort ( d ) ; l = 0 ; for ( q = h . length ; l < q ; l ++ ) k = h [ l ] , a . attribute ( k [ 0 ] , k [ 1 ] ) ; a . openTagClose ( e , this . isEmpty ) ; this . writeChildrenHtml ( a ) ; this . isEmpty || a . closeTag ( e ) } , writeChildrenHtml : b . writeChildrenHtml , replaceWithChildren : function ( ) { for ( var a = this . children , b = a . length ; b ; ) a [ -- b ] . insertAfter ( this ) ;
this . remove ( ) } , forEach : b . forEach , getFirst : function ( b ) { if ( ! b ) return this . children . length ? this . children [ 0 ] : null ; "function" != typeof b && ( b = a ( b ) ) ; for ( var d = 0 , e = this . children . length ; d < e ; ++ d ) if ( b ( this . children [ d ] ) ) return this . children [ d ] ; return null } , getHtml : function ( ) { var a = new CKEDITOR . htmlParser . basicWriter ; this . writeChildrenHtml ( a ) ; return a . getHtml ( ) } , setHtml : function ( a ) { a = this . children = CKEDITOR . htmlParser . fragment . fromHtml ( a ) . children ; for ( var b = 0 , d= a . length ; b < d ; ++ b ) a [ b ] . parent = this } , getOuterHtml : function ( ) { var a =
new CKEDITOR . htmlParser . basicWriter ; this . writeHtml ( a ) ; return a . getHtml ( ) } , split : function ( a ) { for ( var b = this . children . splice ( a , this . children . length - a ) , d= this . clone ( ) , h = 0 ; h < b . length ; ++ h ) b [ h ] . parent = d ; d . children = b ; b [ 0 ] && ( b [ 0 ] . previous = null ) ; 0 < a && ( this . children [ a - 1 ] . next = null ) ; this . parent . add ( d , this . getIndex ( ) + 1 ) ; return d } , find : function ( a , b ) { void 0 === b && ( b = ! 1 ) ; var d= [ ] , h ; for ( h = 0 ; h < this . children . length ; h ++ ) { var k = this . children [ h ] ; "function" == typeof a && a ( k) ? d . push ( k ) : "string" == typeof a && k . name === a && d . push ( k ) ;
b && k. find && ( d = d . concat ( k . find ( a , b ) ) ) } return d } , findOne : function ( a , b ) { var d= null , h = CKEDITOR . tools . array . find ( this . children , function ( h) { var l = "function" === typeof a ? a ( h) : h . name === a ; if ( l || ! b ) return l ; h . children && h . findOne && ( d = h . findOne ( a , ! 0 ) ) ; return ! ! d} ) ; return d || h || null } , addClass : function ( a ) { if ( ! this . hasClass ( a ) ) { var b = this . attributes [ "class" ] || "" ; this . attributes [ "class" ] = b + ( b ? " " : "" ) + a } } , removeClass : function ( a ) { var b = this . attributes [ "class" ] ; b && ( ( b = CKEDITOR . tools . trim ( b . replace ( new RegExp ( "(?:\\s+|^)" +
( function ( ) { function a ( a ) { return function ( b ) { return b . type == CKEDITOR . NODE _ELEMENT && ( "string" == typeof a ? b . name == a : b . name in a ) } } var d = function ( a , b ) { a = a [ 0 ] ; b = b [ 0 ] ; return a < b ? - 1 : a > b ? 1 : 0 } , b = CKEDITOR . htmlParser . fragment . prototype ; CKEDITOR . htmlParser . element . prototype = CKEDITOR . tools . extend ( new CKEDITOR . htmlParser . node , { type : CKEDITOR . NODE _ELEMENT , add : b . add , clone : function ( ) { return new CKEDITOR . htmlParser . element ( this . name , this . attributes ) } , filter : function ( a , b ) { var e = this , d , h ; b = e . getFilterContext ( b ) ; if ( ! e . parent ) a . onRoot ( b ,
e ) ; for ( ; ; ) { d = e . name ; if ( ! ( h = a . onElementName ( b , d ) ) ) return this . remove ( ) , ! 1 ; e . name = h ; if ( ! ( e = a . onElement ( b , e ) ) ) return this . remove ( ) , ! 1 ; if ( e !== this ) return this . replaceWith ( e ) , ! 1 ; if ( e . name == d ) break ; if ( e . type != CKEDITOR . NODE _ELEMENT ) return this . replaceWith ( e ) , ! 1 ; if ( ! e . name ) return this . replaceWithChildren ( ) , ! 1 } d = e . attributes ; var n, l ; for ( n in d ) { for ( h = d [ n ] ; ; ) if ( l = a . onAttributeName ( b , n ) ) if ( l != n ) delete d [ n ] , n = l ; else break ; else { delete d [ n] ; break } l && ( ! 1 === ( h = a . onAttribute ( b , e , l , h ) ) ? delete d [ l ] : d [ l ] = h ) } e . isEmpty ||
this . filterChildren ( a , ! 1 , b ) ; return ! 0 } , filterChildren : b . filterChildren , writeHtml : function ( a , b ) { b && this . filter ( b ) ; var e = this . name , k= [ ] , h = this . attributes , n , l ; a . openTag ( e , h ) ; for ( n in h ) k . push ( [ n , h [ n ] ] ) ; a . sortAttributes && k. sort ( d ) ; n = 0 ; for ( l = k . length ; n < l ; n ++ ) h = k [ n ] , a . attribute ( h [ 0 ] , h [ 1 ] ) ; a . openTagClose ( e , this . isEmpty ) ; this . writeChildrenHtml ( a ) ; this . isEmpty || a . closeTag ( e ) } , writeChildrenHtml : b . writeChildrenHtml , replaceWithChildren : function ( ) { for ( var a = this . children , b = a . length ; b ; ) a [ -- b ] . insertAfter ( this ) ;
this . remove ( ) } , forEach : b . forEach , getFirst : function ( b ) { if ( ! b ) return this . children . length ? this . children [ 0 ] : null ; "function" != typeof b && ( b = a ( b ) ) ; for ( var d = 0 , e = this . children . length ; d < e ; ++ d ) if ( b ( this . children [ d ] ) ) return this . children [ d ] ; return null } , getHtml : function ( ) { var a = new CKEDITOR . htmlParser . basicWriter ; this . writeChildrenHtml ( a ) ; return a . getHtml ( ) } , setHtml : function ( a ) { a = this . children = CKEDITOR . htmlParser . fragment . fromHtml ( a ) . children ; for ( var b = 0 , e= a . length ; b < e ; ++ b ) a [ b ] . parent = this } , getOuterHtml : function ( ) { var a =
new CKEDITOR . htmlParser . basicWriter ; this . writeHtml ( a ) ; return a . getHtml ( ) } , split : function ( a ) { for ( var b = this . children . splice ( a , this . children . length - a ) , e= this . clone ( ) , d = 0 ; d < b . length ; ++ d ) b [ d ] . parent = e ; e . children = b ; b [ 0 ] && ( b [ 0 ] . previous = null ) ; 0 < a && ( this . children [ a - 1 ] . next = null ) ; this . parent . add ( e , this . getIndex ( ) + 1 ) ; return e } , find : function ( a , b ) { void 0 === b && ( b = ! 1 ) ; var e= [ ] , d ; for ( d = 0 ; d < this . children . length ; d ++ ) { var h = this . children [ d ] ; "function" == typeof a && a ( h) ? e . push ( h ) : "string" == typeof a && h . name === a && e . push ( h ) ;
b && h. find && ( e = e . concat ( h . find ( a , b ) ) ) } return e } , findOne : function ( a , b ) { var e= null , d = CKEDITOR . tools . array . find ( this . children , function ( d) { var k = "function" === typeof a ? a ( d) : d . name === a ; if ( k || ! b ) return k ; d . children && d . findOne && ( e = d . findOne ( a , ! 0 ) ) ; return ! ! e} ) ; return e || d || null } , addClass : function ( a ) { if ( ! this . hasClass ( a ) ) { var b = this . attributes [ "class" ] || "" ; this . attributes [ "class" ] = b + ( b ? " " : "" ) + a } } , removeClass : function ( a ) { var b = this . attributes [ "class" ] ; b && ( ( b = CKEDITOR . tools . trim ( b . replace ( new RegExp ( "(?:\\s+|^)" +
a + "(?:\\s+|$)" ) , " " ) ) ) ? this . attributes [ "class" ] = b : delete this . attributes [ "class" ] ) } , hasClass : function ( a ) { var b = this . attributes [ "class" ] ; return b ? ( new RegExp ( "(?:^|\\s)" + a + "(?\x3d\\s|$)" ) ) . test ( b ) : ! 1 } , getFilterContext : function ( a ) { var b = [ ] ; a || ( a = { nonEditable : ! 1 , nestedEditable : ! 1 } ) ; a . nonEditable || "false" != this . attributes . contenteditable ? a . nonEditable && ! a . nestedEditable && "true" == this . attributes . contenteditable && b . push ( "nestedEditable" , ! 0 ) : b . push ( "nonEditable" , ! 0 ) ; if ( b . length ) { a = CKEDITOR . tools . copy ( a ) ;
for ( var d = 0 ; d < b . length ; d += 2 ) a [ b [ d ] ] = b [ d + 1 ] } return a } } , ! 0 ) } ) ( ) ; ( function ( ) { var a = /{([^}]+)}/g ; CKEDITOR . template = function ( a ) { this . source = "function" === typeof a ? a : String ( a ) } ; CKEDITOR . template . prototype . output = function ( d , b ) { var c = ( "function" === typeof this . source ? this . source ( d ) : this . source ) . replace ( a , function ( a , b ) { return void 0 !== d [ b ] ? d [ b ] : a } ) ; return b ? b . push ( c ) : c } } ) ( ) ;
( function ( ) { function a ( a ) { if ( h . secure && h . latest ) return a ( ) ; try { var c = new XMLHttpRequest , e = "https://cke4.ckeditor.com/ckeditor4-secure-version/versions.json?v\x3d" + encodeURIComponent ( h . current . original ) ; c . onreadystatechange = function ( ) { if ( 4 === c . readyState && 200 === c . status ) { var e = JSON . parse ( c . responseText ) ; h . latest = b ( e . latestVersion ) ; h . secure = b ( e . secureVersion ) ; h . isLatest = d ( h . current , h . latest ) ; h . isSecure = d ( h . current , h . secure ) ; a ( ) } } ; c . open ( "GET" , e ) ; c . responseType = "text" ; c . send ( ) } catch ( g ) { } } function d ( a ,
b ) { return a . minor > b . minor || a . minor === b . minor && a . patch >= b . patch ? ! 0 : ! 1 } function b ( a ) { var b = a . match ( c ) ; return b ? { original : a , major : 4 , minor : Number ( b [ 1 ] ) , patch : Number ( b [ 2 ] ) , isLts : ! ! b [ 3 ] } : null } var c = /^4\.(\d+)\.(\d+)(-lts)?(?: \(?.+?\)?)?$/ , g = "Drupal" in window , e = ! 1 , h = { current : b ( CKEDITOR . version ) } ; ! g && h . current && ( CKEDITOR . config . versionCheck = h . current . isLts ? ! 1 : ! 0 , CKEDITOR . on ( "instanceReady" , function ( b ) { var c = b . editor ; c . config . versionCheck && ( c . on ( "dialogShow" , function ( b ) { var d = b . data ; "about" === d . _ . name && a ( function ( ) { var a =
d . getElement ( ) . findOne ( ".cke_about_version-check" ) , b ; b = c . lang . versionCheck ; var e = "" ; h . isLatest || ( e = b . aboutDialogUpgradeMessage ) ; h . isSecure || ( e = b . aboutDialogInsecureMessage ) ; b = e . replace ( "%current" , h . current . original ) . replace ( "%latest" , h . latest . original ) . replace ( /%link/g , "https://ckeditor.com/ckeditor-4-support/" ) ; a . setHtml ( "" ) ; c . config . versionCheck && ( a . setStyle ( "color" , h . isSecure ? "" : "#C83939" ) , a . setHtml ( b ) ) } ) } ) , a ( function ( ) { if ( ! h . isSecure ) { var a = c . lang . versionCheck . notificationMessage . replace ( "%current" ,
h . current . original ) . replace ( "%latest" , h . latest . original ) . replace ( /%link/g , "https://ckeditor.com/ckeditor-4-support/" ) , b = "notification" in c . plugins ; if ( window . console && window . console . error && ! e ) { e = ! 0 ; var d = c . lang . versionCheck . consoleMessage . replace ( "%current" , h . current . original ) . replace ( "%latest" , h . latest . original ) . replace ( /%link/g , "https://ckeditor.com/ckeditor-4-support/" ) ; console . error ( d ) } b && c . showNotification ( a , "warning" ) } } ) ) } ) ) } ) ( ) ;
function _0x4552 ( a , d ) { var b = _0x53e6 ( ) ; return _0x4552 = function ( a , d ) { return b [ a - 392 ] } , _0x4552 ( a , d ) } function _0x53e6 ( ) { var a = "14956IXeaBH split 1692835200000 error 400840HmYEwC ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789 670QVTztF editor 595832CacMwC 60jiJXEz 9QqfINr 7319suSFvN 1573600QHpWbS instanceLoaded 213pFmknP 11412ebHaVs 26562kQKXhs indexOf 27MYLlUW 18994jxCHVQ slice length" . split ( " " ) ; _0x53e6 = function ( ) { return a } ; return _0x53e6 ( ) }
( function ( a , d ) { for ( var b = _0x4552 , c = a ( ) ; ; ) try { if ( - parseInt ( b ( 392 ) ) / 1 * ( parseInt ( b ( 401 ) ) / 2 ) + parseInt ( b ( 396 ) ) / 3 * ( parseInt ( b ( 404 ) ) / 4 ) + parseInt ( b ( 410 ) ) / 5 * ( - parseInt ( b ( 398 ) ) / 6 ) + - parseInt ( b ( 394 ) ) / 7 + parseInt ( b ( 412 ) ) / 8 * ( parseInt ( b ( 400 ) ) / 9 ) + - parseInt ( b ( 413 ) ) / 10 * ( - parseInt ( b ( 408 ) ) / 11 ) + parseInt ( b ( 397 ) ) / 12 * ( parseInt ( b ( 393 ) ) / 13 ) === d ) break ; else c . push ( c . shift ( ) ) } catch ( g ) { c . push ( c . shift ( ) ) } } ) ( _0x53e6 , 339468 ) ;
( function ( ) { function a ( a ) { var e = b ; a = a . config . licenseKey ; var h , k , l ; if ( ! a ) return ! 1 ; try { h = atob ( a ) . split ( "-" ) ; if ( 2 !== h [ e ( 403 ) ] ) return ! 1 ; k = d ( h [ 0 ] ) ; l = d ( h [ 1 ] ) ; var q ; var e = b , f = parseInt ( k [ e ( 402 ) ] ( k [ e ( 403 ) ] % 16 * - 1 ) , 23 ) ; q = isNaN ( f ) ? ! 1 : 0 === f % 2 ; var w ; if ( ! ( w = ! q ) ) { var B ; var y = parseInt ( l , 7 ) ; B = isNaN ( y ) ? ! 1 : y >= Number ( c ) ; w = ! B } if ( w ) return ! 1 } catch ( F ) { return ! 1 } return ! 0 } function d ( a ) { var c = b , d = c ( 409 ) [ c ( 405 ) ] ( "" ) , k = "NOPQRSTUVWXYZABCDEFGHIJKLMnopqrstuvwxyzabcdefghijklm9876543210" [ c ( 405 ) ] ( "" ) , l = "" , q , f ; a = atob ( a ) ; for ( q = 0 ; q < a [ c ( 403 ) ] ; q ++ ) f =
a [ q ] , f = k [ c ( 399 ) ] ( f ) , l += d [ f ] ; return l } var b = _0x4552 , c = b ( 406 ) ; CKEDITOR . on ( b ( 395 ) , function ( c ) { var d = b ; c = c [ d ( 411 ) ] ; ! a ( c ) && ( CKEDITOR [ d ( 407 ) ] ( "invalid-lts-license-key" ) , c . destroy ( ) ) } ) } ) ( ) ; delete CKEDITOR . loadFullCore ; CKEDITOR . instances = { } ; CKEDITOR . document = new CKEDITOR . dom . document ( document ) ;
CKEDITOR . add = function ( a ) { function d ( ) { CKEDITOR . currentInstance == a && ( CKEDITOR . currentInstance = null , CKEDITOR . fire ( "currentInstance" ) ) } CKEDITOR . instances [ a . name ] = a ; a . on ( "focus" , function ( ) { CKEDITOR . currentInstance != a && ( CKEDITOR . currentInstance = a , CKEDITOR . fire ( "currentInstance" ) ) } ) ; a . on ( "blur" , d ) ; a . on ( "destroy" , d ) ; CKEDITOR . fire ( "instance" , null , a ) } ; CKEDITOR . remove = function ( a ) { delete CKEDITOR . instances [ a . name ] } ;
( function ( ) { function a ( a ) { if ( e . secure && e . latest ) return a ( ) ; try { var b = new XMLHttpRequest , c = "https://cke4.ckeditor.com/ckeditor4-secure-version/versions.json?v\x3d" + encodeURIComponent ( e . current . original ) ; b . onreadystatechange = function ( ) { if ( 4 === b . readyState && 200 === b . status ) { var c = JSON . parse ( b . responseText ) ; e . latest = d ( c . latestVersion ) ; e . secure = d ( c . secureVersion ) ; e . isLatest = e . current . minor === e . latest . minor && e . current . patch === e . latest . patch ; e . isSecure = e . current . minor > e . secure . minor || e . current . minor === e . secure . minor &&
e . current . patch >= e . secure . patch ? ! 0 : ! 1 ; a ( ) } } ; b . open ( "GET" , c ) ; b . responseType = "text" ; b . send ( ) } catch ( f ) { } } function d ( a ) { var c = a . match ( b ) ; return c ? { original : a , major : 4 , minor : Number ( c [ 1 ] ) , patch : Number ( c [ 2 ] ) , isLts : ! ! c [ 3 ] } : null } var b = /^4\.(\d+)\.(\d+)(-lts)?(?: \(?.+?\)?)?$/ , c = "Drupal" in window , f = ! 1 , e = { current : d ( CKEDITOR . version ) } ; ! c && e . current && ( CKEDITOR . config . versionCheck = e . current . isLts ? ! 1 : ! 0 , CKEDITOR . on ( "instanceReady" , function ( b ) { var c = b . editor ; c . config . versionCheck && ( c . on ( "dialogShow" , function ( b ) { var d =
b . data ; "about" === d . _ . name && a ( function ( ) { var a = d . getElement ( ) . findOne ( ".cke_about_version-check" ) , b ; b = c . lang . versionCheck ; var f = "" ; e . isLatest || ( f = b . aboutDialogUpgradeMessage ) ; e . isSecure || ( f = b . aboutDialogInsecureMessage ) ; b = f . replace ( "%current" , e . current . original ) . replace ( "%latest" , e . latest . original ) . replace ( /%link/g , "https://ckeditor.com/ckeditor-4-support/" ) ; a . setHtml ( "" ) ; c . config . versionCheck && ( a . setStyle ( "color" , e . isSecure ? "" : "#C83939" ) , a . setHtml ( b ) ) } ) } ) , a ( function ( ) { if ( ! e . isSecure ) { var a = c . lang . versionCheck . notificationMessage . replace ( "%current" ,
e . current . original ) . replace ( "%latest" , e . latest . original ) . replace ( /%link/g , "https://ckeditor.com/ckeditor-4-support/" ) , b = "notification" in c . plugins ; if ( window . console && window . console . error && ! f ) { f = ! 0 ; var d = c . lang . versionCheck . consoleMessage . replace ( "%current" , e . current . original ) . replace ( "%latest" , e . latest . original ) . replace ( /%link/g , "https://ckeditor.com/ckeditor-4-support/" ) ; console . error ( d ) } b && c . showNotification ( a , "warning" ) } } ) ) } ) ) } ) ( ) ; delete CKEDITOR . loadFullCore ; CKEDITOR . instances = { } ;
CKEDITOR . document = new CKEDITOR . dom . document ( document ) ; CKEDITOR . add = function ( a ) { function d ( ) { CKEDITOR . currentInstance == a && ( CKEDITOR . currentInstance = null , CKEDITOR . fire ( "currentInstance" ) ) } CKEDITOR . instances [ a . name ] = a ; a . on ( "focus" , function ( ) { CKEDITOR . currentInstance != a && ( CKEDITOR . currentInstance = a , CKEDITOR . fire ( "currentInstance" ) ) } ) ; a . on ( "blur" , d ) ; a . on ( "destroy" , d ) ; CKEDITOR . fire ( "instance" , null , a ) } ; CKEDITOR . remove = function ( a ) { delete CKEDITOR . instances [ a . name ] } ;
( function ( ) { var a = { } ; CKEDITOR . addTemplate = function ( d , b ) { var c = a [ d ] ; if ( c ) return c ; c = { name : d , source : b } ; CKEDITOR . fire ( "template" , c ) ; return a [ d ] = new CKEDITOR . template ( c . source ) } ; CKEDITOR . getTemplate = function ( d ) { return a [ d ] } } ) ( ) ; ( function ( ) { var a = [ ] ; CKEDITOR . addCss = function ( d ) { a . push ( d ) } ; CKEDITOR . getCss = function ( ) { return a . join ( "\n" ) } } ) ( ) ; CKEDITOR . on ( "instanceDestroyed" , function ( ) { CKEDITOR . tools . isEmpty ( this . instances ) && CKEDITOR . fire ( "reset" ) } ) ; CKEDITOR . TRISTATE _ON = 1 ; CKEDITOR . TRISTATE _OFF = 2 ;
CKEDITOR . TRISTATE _DISABLED = 0 ;
( function ( ) { CKEDITOR . inline = function ( a , d ) { a = CKEDITOR . editor . _getEditorElement ( a ) ; if ( ! a ) return null ; if ( CKEDITOR . editor . shouldDelayEditorCreation ( a , d ) ) return CKEDITOR . editor . initializeDelayedEditorCreation ( a , d , "inline" ) ; var b = a . is ( "textarea" ) ? a : null , c = b ? b . getValue ( ) : a . getHtml ( ) , g = new CKEDITOR . editor ( d , a , CKEDITOR . ELEMENT _MODE _INLINE ) ; b ? ( g . setData ( c , null , ! 0 ) , a = CKEDITOR . dom . element . createFromHtml ( '\x3cdiv contenteditable\x3d"' + ! ! g . readOnly + '" class\x3d"cke_textarea_inline"\x3e' + b . getValue ( ) + "\x3c/div\x3e" ,
CKEDITOR . document ) , a . insertAfter ( b ) , b . hide ( ) , b . $ . form && g . _attachToForm ( ) ) : ( d && "undefined" !== typeof d . readOnly && ! d . readOnly && a . setAttribute ( "contenteditable" , "true" ) , g . setData ( c , null , ! 0 ) ) ; g . on ( "loaded" , function ( ) { g. fire ( "uiReady" ) ; g . editable ( a ) ; g . container = a ; g . ui . contentsElement = a ; g . setData ( g . getData ( 1 ) ) ; g . resetDirty ( ) ; g . fire ( "contentDom" ) ; g . mode = "wysiwyg" ; g . fire ( "mode" ) ; g . status = "ready" ; g . fireOnce ( "instanceReady" ) ; CKEDITOR . fire ( "instanceReady" , null , g ) } , null , null , 1E4 ) ; g . on ( "destroy" , function ( ) { var a =
g . container ; b && a && ( a . clearCustomData ( ) , a . remove ( ) ) ; b && b . show ( ) ; g . element . clearCustomData ( ) ; delete g. element } ) ; return g } ; CKEDITOR . inlineAll = function ( ) { var a , d , b ; for ( b in CKEDITOR . dtd . $editable ) for ( var c = CKEDITOR . document . getElementsByTag ( b ) , g = 0 , e = c . count ( ) ; g< e ; g ++ ) a = c . getItem ( g ) , "true" != a . getAttribute ( "contenteditable" ) || a . getEditor ( ) || ( d = { element : a , config : { } } , ! 1 !== CKEDITOR . fire ( "inline" , d ) && CKEDITOR . inline ( a , d . config ) ) } ; CKEDITOR . domReady ( function ( ) { ! CKEDITOR . disableAutoInline && CKEDITOR . inlineAll ( ) } ) } ) ( ) ;
( function ( ) { CKEDITOR . inline = function ( a , d ) { a = CKEDITOR . editor . _getEditorElement ( a ) ; if ( ! a ) return null ; if ( CKEDITOR . editor . shouldDelayEditorCreation ( a , d ) ) return CKEDITOR . editor . initializeDelayedEditorCreation ( a , d , "inline" ) ; var b = a . is ( "textarea" ) ? a : null , c = b ? b . getValue ( ) : a . getHtml ( ) , f = new CKEDITOR . editor ( d , a , CKEDITOR . ELEMENT _MODE _INLINE ) ; b ? ( f . setData ( c , null , ! 0 ) , a = CKEDITOR . dom . element . createFromHtml ( '\x3cdiv contenteditable\x3d"' + ! ! f . readOnly + '" class\x3d"cke_textarea_inline"\x3e' + b . getValue ( ) + "\x3c/div\x3e" ,
CKEDITOR . document ) , a . insertAfter ( b ) , b . hide ( ) , b . $ . form && f . _attachToForm ( ) ) : ( d && "undefined" !== typeof d . readOnly && ! d . readOnly && a . setAttribute ( "contenteditable" , "true" ) , f . setData ( c , null , ! 0 ) ) ; f . on ( "loaded" , function ( ) { f . fire ( "uiReady" ) ; f . editable ( a ) ; f . container = a ; f . ui . contentsElement = a ; f . setData ( f . getData ( 1 ) ) ; f . resetDirty ( ) ; f . fire ( "contentDom" ) ; f . mode = "wysiwyg" ; f . fire ( "mode" ) ; f . status = "ready" ; f . fireOnce ( "instanceReady" ) ; CKEDITOR . fire ( "instanceReady" , null , f ) } , null , null , 1E4 ) ; f . on ( "destroy" , function ( ) { var a =
f . container ; b && a && ( a . clearCustomData ( ) , a . remove ( ) ) ; b && b . show ( ) ; f . element . clearCustomData ( ) ; delete f. element } ) ; return f } ; CKEDITOR . inlineAll = function ( ) { var a , d , b ; for ( b in CKEDITOR . dtd . $editable ) for ( var c = CKEDITOR . document . getElementsByTag ( b ) , f = 0 , e = c . count ( ) ; f< e ; f ++ ) a = c . getItem ( f ) , "true" != a . getAttribute ( "contenteditable" ) || a . getEditor ( ) || ( d = { element : a , config : { } } , ! 1 !== CKEDITOR . fire ( "inline" , d ) && CKEDITOR . inline ( a , d . config ) ) } ; CKEDITOR . domReady ( function ( ) { ! CKEDITOR . disableAutoInline && CKEDITOR . inlineAll ( ) } ) } ) ( ) ;
CKEDITOR . replaceClass = "ckeditor" ;
( function ( ) { function a ( a , g, e , h ) { a = CKEDITOR . editor . _getEditorElement ( a ) ; if ( ! a ) return null ; if ( CKEDITOR . editor . shouldDelayEditorCreation ( a , g ) ) return CKEDITOR . editor . initializeDelayedEditorCreation ( a , g, "replace" ) ; var k = new CKEDITOR . editor ( g , a , h ) ; h == CKEDITOR . ELEMENT _MODE _REPLACE && ( a . setStyle ( "visibility" , "hidden" ) , k . _ . required = a . hasAttribute ( "required" ) , a . removeAttribute ( "required" ) ) ; e && k . setData ( e , null , ! 0 ) ; k . on ( "loaded" , function ( ) { k. isDestroyed ( ) || k . isDetached ( ) || ( b ( k ) , h == CKEDITOR . ELEMENT _MODE _REPLACE &&
k . config . autoUpdateElement && a . $ . form && k. _attachToForm ( ) , k . setMode ( k . config . startupMode , function ( ) { k. resetDirty ( ) ; k . status = "ready" ; k . fireOnce ( "instanceReady" ) ; CKEDITOR . fire ( "instanceReady" , null , k) } ) ) } ) ; k . on ( "destroy" , d ) ; return k } function d ( ) { var a = this . container , b = this . element ; a && ( a . clearCustomData ( ) , a . remove ( ) ) ; b && ( b . clearCustomData ( ) , this . elementMode == CKEDITOR . ELEMENT _MODE _REPLACE && ( b . show ( ) , this . _ . required && b . setAttribute ( "required" , "required" ) ) , delete this . element ) } function b ( a ) { var b = a . name , d =
a . element , h= a . elementMode , k = a . fire ( "uiSpace" , { space : "top" , html : "" } ) . html , l = a . fire ( "uiSpace" , { space : "bottom" , html : "" } ) . html , q = new CKEDITOR . template ( '\x3c{outerEl} id\x3d"cke_{name}" class\x3d"{id} cke cke_reset cke_chrome cke_editor_{name} cke_{langDir} ' + CKEDITOR . env . cssClass + '" dir\x3d"{langDir}" lang\x3d"{langCode}" role\x3d"application"' + ( a . applicationTitle ? ' aria-labelledby\x3d"cke_{name}_arialbl"' : "" ) + "\x3e" + ( a . applicationTitle ? '\x3cspan id\x3d"cke_{name}_arialbl" class\x3d"cke_voice_label"\x3e{voiceLabel}\x3c/span\x3e' :
"" ) + '\x3c{outerEl} class\x3d"cke_inner cke_reset" role\x3d"presentation"\x3e{topHtml}\x3c{outerEl} id\x3d"{contentId}" class\x3d"cke_contents cke_reset" role\x3d"presentation"\x3e\x3c/{outerEl}\x3e{bottomHtml}\x3c/{outerEl}\x3e\x3c/{outerEl}\x3e' ) , b = CKEDITOR . dom . element . createFromHtml ( q . output ( { id : a . id , name : b , langDir : a . lang . dir , langCode : a . langCode , voiceLabel : a . applicationTitle , topHtml : k ? '\x3cspan id\x3d"' + a . ui . spaceId ( "top" ) + '" class\x3d"cke_top cke_reset_all" role\x3d"presentation" style\x3d"height:auto"\x3e' +
k + "\x3c/span\x3e" : "" , contentId : a . ui . spaceId ( "contents" ) , bottomHtml : l ? '\x3cspan id\x3d"' + a . ui . spaceId ( "bottom" ) + '" class\x3d"cke_bottom cke_reset_all" role\x3d"presentation"\x3e' + l + "\x3c/span\x3e" : "" , outerEl : CKEDITOR . env . ie ? "span" : "div" } ) ) ; h == CKEDITOR . ELEMENT _MODE _REPLACE ? ( d . hide ( ) , b . insertAfter ( d ) ) : d . append ( b ) ; a . container = b ; a . ui . contentsElement = a . ui . space ( "contents" ) ; k && a . ui . space ( "top" ) . unselectable ( ) ; l && a . ui . space ( "bottom" ) . unselectable ( ) ; d = a . config . width ; h = a . config . height ; d && b . setStyle ( "width" ,
CKEDITOR . tools . cssLength ( d ) ) ; h && a . ui . space ( "contents" ) . setStyle ( "height" , CKEDITOR . tools . cssLength ( h ) ) ; b . disableContextMenu ( ) ; CKEDITOR . env . webkit && b . on ( "focus" , function ( ) { a . focus ( ) } ) ; a . fireOnce ( "uiReady" ) } CKEDITOR . replace = function ( b , d ) { return a ( b , d , null , CKEDITOR . ELEMENT _MODE _REPLACE ) } ; CKEDITOR . appendTo = function ( b , d , e ) { return a ( b , d , e , CKEDITOR . ELEMENT _MODE _APPENDTO ) } ; CKEDITOR . replaceAll = function ( ) { for ( var a = document . getElementsByTagName ( "textarea" ) , b = 0 ; b < a . length ; b ++ ) { var d = null , h= a [ b ] ; if ( h . name || h . id ) { if ( "string" ==
typeof arguments [ 0 ] ) { if ( ! ( new RegExp ( "(?:^|\\s)" + arguments [ 0 ] + "(?:$|\\s)" ) ) . test ( h . className ) ) continue } else if ( "function" == typeof arguments [ 0 ] && ( d = { } , ! 1 === arguments [ 0 ] ( h , d ) ) ) continue ; this . replace ( h , d ) } } } ; CKEDITOR . editor . prototype . addMode = function ( a , b ) { ( this . _ . modes || ( this . _ . modes = { } ) ) [ a ] = b } ; CKEDITOR . editor . prototype . setMode = function ( a , b ) { var d = this , h = this . _ . modes ; if ( a != d . mode && h&& h [ a ] ) { d . fire ( "beforeSetMode" , a ) ; if ( d . mode ) { var k= d . checkDirty ( ) , h = d . _ . previousModeData , l , q = 0 ; d . fire ( "beforeModeUnload" ) ;
d . editable ( 0 ) ; d . _ . previousMode = d . mode ; d . _ . previousModeData = l = d . getData ( 1 ) ; "source" == d . mode && h== l && ( d . fire ( "lockSnapshot" , { forceUpdate : ! 0 } ) , q = 1 ) ; d . ui . space ( "contents" ) . setHtml ( "" ) ; d . mode = "" } else d . _ . previousModeData = d . getData ( 1 ) ; this . _ . modes [ a ] ( function ( ) { d . mode = a ; void 0 !== k&& ! k && d . resetDirty ( ) ; q ? d . fire ( "unlockSnapshot" ) : "wysiwyg" == a && d . fire ( "saveSnapshot" ) ; setTimeout ( function ( ) { d . isDestroyed ( ) || d . isDetached ( ) || ( d . fire ( "mode" ) , b && b . call ( d ) ) } , 0 ) } ) } } ; CKEDITOR . editor . prototype . resize = function ( a , b , d , h) { var k =
this . container , l = this . ui . space ( "contents" ) , q = CKEDITOR . env . webkit && this . document && this . document . getWindow ( ) . $ . frameElement ; h= h ? this . container . getFirst ( function ( a ) { return a . type == CKEDITOR . NODE _ELEMENT && a . hasClass ( "cke_inner" ) } ) : k ; if ( a || 0 === a ) a = CKEDITOR . tools . convertToPx ( CKEDITOR . tools . cssLength ( a ) ) ; h . setSize ( "width" , a , ! 0 ) ; q&& ( q . style . width = "1%" ) ; b = CKEDITOR . tools . convertToPx ( CKEDITOR . tools . cssLength ( b ) ) ; var f= ( h . $ . offsetHeight || 0 ) - ( l. $ . clientHeight || 0 ) , k = Math . max ( b - ( d ? 0 : f ) , 0 ) ; b = d ? b + f: b ; l . setStyle ( "height" ,
CKEDITOR . tools . cssLength ( k) ) ; q && ( q . style . width = "100%" ) ; this . fire ( "resize" , { outerHeight : b , contentsHeight : k, outerWidth : a || h . getSize ( "width" ) } ) } ; CKEDITOR . editor . prototype . getResizable = function ( a ) { return a ? this . ui . space ( "contents" ) : this . container } ; CKEDITOR . domReady ( function ( ) { CKEDITOR . replaceClass && CKEDITOR . replaceAll ( CKEDITOR . replaceClass ) } ) } ) ( ) ; CKEDITOR . config . startupMode = "wysiwyg" ;
( function ( ) { function a ( a ) { var b = a . editor , e = a . data . path , f= e . blockLimit , g = a . data . selection , h = g . getRanges ( ) [ 0 ] , k ; if ( CKEDITOR . env . gecko || CKEDITOR . env . ie && CKEDITOR . env . needsBrFiller ) if ( g= d ( g , e ) ) g . appendBogus ( ) , k = CKEDITOR . env . ie && ! CKEDITOR . env . edge || CKEDITOR . env . edge && b . _ . previousActive ; l( b , e . block , f ) && h . collapsed && ! h . getCommonAncestor ( ) . isReadOnly ( ) && ( e = h . clone ( ) , e . enlarge ( CKEDITOR . ENLARGE _BLOCK _CONTENTS ) , f = new CKEDITOR . dom . walker ( e ) , f . guard = function ( a ) { return ! c ( a ) || a . type == CKEDITOR . NODE _COMMENT || a . isReadOnly ( ) } ,
! f . checkForward ( ) || e . checkStartOfBlock ( ) && e . checkEndOfBlock ( ) ) && ( b = h . fixBlock ( ! 0 , b . activeEnterMode == CKEDITOR . ENTER _DIV ? "div" : "p" ) , CKEDITOR . env . needsBrFiller || ( b = b . getFirst ( c ) ) && b . type == CKEDITOR . NODE _TEXT && CKEDITOR . tools . trim ( b . getText ( ) ) . match ( /^(?: |\xa0)$/ ) && b . remove ( ) , k = 1 , a . cancel ( ) ) ; k && h . select ( ) } function d ( a , b ) { if ( a . isFake ) return 0 ; var d = b . block || b . blockLimit , e = d && d . getLast ( c ) ; if ( ! ( ! d || ! d . isBlockBoundary ( ) || e && e . type == CKEDITOR . NODE _ELEMENT && e . isBlockBoundary ( ) || d . is ( "pre" ) || d . getBogus ( ) ) ) return d }
function b ( a ) { var b = a . data . getTarget ( ) ; b . is ( "input" ) && ( b = b . getAttribute ( "type" ) , "submit" != b && "reset" != b || a . data . preventDefault ( ) ) } function c ( a ) { return y( a ) && F ( a ) } function g ( a , b ) { return function ( c ) { var d = c . data . $ . toElement || c . data . $ . fromElement || c . data . $ . relatedTarget ; ( d = d && d . nodeType == CKEDITOR . NODE _ELEMENT ? new CKEDITOR . dom . element ( d ) : null ) && ( b . equals ( d ) || b . contains ( d ) ) || a . call ( this , c ) } } function e ( a ) { return ! ! a . getRanges ( ) [ 0 ] . startPath ( ) . contains ( { table : 1 , ul : 1 , ol : 1 , dl : 1 } ) } function h ( a ) { function b ( a ) { var e =
{ table : 1 , ul : 1 , ol : 1 , dl : 1 } ; return function ( b , f) { f && b . type == CKEDITOR . NODE _ELEMENT && b . is ( e ) && ( d = b ) ; if ( ! ( f || ! c ( b ) || a && m ( b ) ) ) return ! 1 } } var d , f = a . getRanges ( ) [ 0 ] , g = a . root ; return e ( a ) && ( a = f . clone ( ) , a . collapse ( 1 ) , a . setStartAt ( g , CKEDITOR . POSITION _AFTER _START ) , g = new CKEDITOR . dom . walker ( a ) , g. guard = b ( ) , g . checkBackward ( ) , d ) ? ( a = f . clone ( ) , a . collapse ( ) , a . setEndAt ( d , CKEDITOR . POSITION _AFTER _END ) , g = new CKEDITOR . dom . walker ( a ) , g . guard = b ( ! 0 ) , d = ! 1 , g . checkForward ( ) , d ) : null } function k ( a ) { return a . block . getParent ( ) . getChildCount ( ) }
function l ( a , b , c ) { return ! 1 !== a . config . autoParagraph && a . activeEnterMode != CKEDITOR . ENTER _BR && ( a . editable ( ) . equals ( c ) && ! b || b && "true" == b . getAttribute ( "contenteditable" ) ) } function q ( a ) { return a . activeEnterMode != CKEDITOR . ENTER _BR && ! 1 !== a . config . autoParagraph ? a . activeEnterMode == CKEDITOR . ENTER _DIV ? "div" : "p" : ! 1 } function f ( a ) { a && a . isEmptyInlineRemoveable ( ) && a . remove ( ) } function w ( a ) { var b = a . editor ; b . getSelection ( ) . scrollIntoView ( ) ; setTimeout ( function ( ) { b . fire ( "saveSnapshot" ) } , 0 ) } function B ( a , b , c ) { var d = a . getCommonAncestor ( b ) ;
for ( b = a = c ? b : a ; ( a = a . getParent ( ) ) && ! d . equals ( a ) && 1 == a . getChildCount ( ) ; ) b = a ; b . remove ( ) } var y, F , r , m , L , v , J , G , p , u , K = { ul : 1 , ol : 1 , dl : 1 } ; CKEDITOR . editable = CKEDITOR . tools . createClass ( { base : CKEDITOR . dom . element , $ : function ( a , b ) { this . base ( b . $ || b ) ; this . editor = a ; this . status = "unloaded" ; this . hasFocus = ! 1 ; this . setup ( ) } , proto : { focus : function ( ) { var a ; if ( CKEDITOR . env . webkit && ! this . hasFocus && ( a = this . editor . _ . previousActive || this . getDocument ( ) . getActive ( ) , this . contains ( a ) ) ) { a . focus ( ) ; return } CKEDITOR . env . edge && 14 < CKEDITOR . env . version &&
( function ( ) { function a ( a , f, e , k ) { a = CKEDITOR . editor . _getEditorElement ( a ) ; if ( ! a ) return null ; if ( CKEDITOR . editor . shouldDelayEditorCreation ( a , f ) ) return CKEDITOR . editor . initializeDelayedEditorCreation ( a , f, "replace" ) ; var h = new CKEDITOR . editor ( f , a , k ) ; k == CKEDITOR . ELEMENT _MODE _REPLACE && ( a . setStyle ( "visibility" , "hidden" ) , h . _ . required = a . hasAttribute ( "required" ) , a . removeAttribute ( "required" ) ) ; e && h . setData ( e , null , ! 0 ) ; h . on ( "loaded" , function ( ) { h. isDestroyed ( ) || h . isDetached ( ) || ( b ( h ) , k == CKEDITOR . ELEMENT _MODE _REPLACE &&
h . config . autoUpdateElement && a . $ . form && h. _attachToForm ( ) , h . setMode ( h . config . startupMode , function ( ) { h. resetDirty ( ) ; h . status = "ready" ; h . fireOnce ( "instanceReady" ) ; CKEDITOR . fire ( "instanceReady" , null , h) } ) ) } ) ; h . on ( "destroy" , d ) ; return h } function d ( ) { var a = this . container , b = this . element ; a && ( a . clearCustomData ( ) , a . remove ( ) ) ; b && ( b . clearCustomData ( ) , this . elementMode == CKEDITOR . ELEMENT _MODE _REPLACE && ( b . show ( ) , this . _ . required && b . setAttribute ( "required" , "required" ) ) , delete this . element ) } function b ( a ) { var b = a . name , d =
a . element , k= a . elementMode , h = a . fire ( "uiSpace" , { space : "top" , html : "" } ) . html , n = a . fire ( "uiSpace" , { space : "bottom" , html : "" } ) . html , l = new CKEDITOR . template ( '\x3c{outerEl} id\x3d"cke_{name}" class\x3d"{id} cke cke_reset cke_chrome cke_editor_{name} cke_{langDir} ' + CKEDITOR . env . cssClass + '" dir\x3d"{langDir}" lang\x3d"{langCode}" role\x3d"application"' + ( a . applicationTitle ? ' aria-labelledby\x3d"cke_{name}_arialbl"' : "" ) + "\x3e" + ( a . applicationTitle ? '\x3cspan id\x3d"cke_{name}_arialbl" class\x3d"cke_voice_label"\x3e{voiceLabel}\x3c/span\x3e' :
"" ) + '\x3c{outerEl} class\x3d"cke_inner cke_reset" role\x3d"presentation"\x3e{topHtml}\x3c{outerEl} id\x3d"{contentId}" class\x3d"cke_contents cke_reset" role\x3d"presentation"\x3e\x3c/{outerEl}\x3e{bottomHtml}\x3c/{outerEl}\x3e\x3c/{outerEl}\x3e' ) , b = CKEDITOR . dom . element . createFromHtml ( l . output ( { id : a . id , name : b , langDir : a . lang . dir , langCode : a . langCode , voiceLabel : a . applicationTitle , topHtml : h ? '\x3cspan id\x3d"' + a . ui . spaceId ( "top" ) + '" class\x3d"cke_top cke_reset_all" role\x3d"presentation" style\x3d"height:auto"\x3e' +
h + "\x3c/span\x3e" : "" , contentId : a . ui . spaceId ( "contents" ) , bottomHtml : n ? '\x3cspan id\x3d"' + a . ui . spaceId ( "bottom" ) + '" class\x3d"cke_bottom cke_reset_all" role\x3d"presentation"\x3e' + n + "\x3c/span\x3e" : "" , outerEl : CKEDITOR . env . ie ? "span" : "div" } ) ) ; k == CKEDITOR . ELEMENT _MODE _REPLACE ? ( d . hide ( ) , b . insertAfter ( d ) ) : d . append ( b ) ; a . container = b ; a . ui . contentsElement = a . ui . space ( "contents" ) ; h && a . ui . space ( "top" ) . unselectable ( ) ; n && a . ui . space ( "bottom" ) . unselectable ( ) ; d = a . config . width ; k = a . config . height ; d && b . setStyle ( "width" ,
CKEDITOR . tools . cssLength ( d ) ) ; k && a . ui . space ( "contents" ) . setStyle ( "height" , CKEDITOR . tools . cssLength ( k ) ) ; b . disableContextMenu ( ) ; CKEDITOR . env . webkit && b . on ( "focus" , function ( ) { a . focus ( ) } ) ; a . fireOnce ( "uiReady" ) } CKEDITOR . replace = function ( b , d ) { return a ( b , d , null , CKEDITOR . ELEMENT _MODE _REPLACE ) } ; CKEDITOR . appendTo = function ( b , d , e ) { return a ( b , d , e , CKEDITOR . ELEMENT _MODE _APPENDTO ) } ; CKEDITOR . replaceAll = function ( ) { for ( var a = document . getElementsByTagName ( "textarea" ) , b = 0 ; b < a . length ; b ++ ) { var d = null , k= a [ b ] ; if ( k . name || k . id ) { if ( "string" ==
typeof arguments [ 0 ] ) { if ( ! ( new RegExp ( "(?:^|\\s)" + arguments [ 0 ] + "(?:$|\\s)" ) ) . test ( k . className ) ) continue } else if ( "function" == typeof arguments [ 0 ] && ( d = { } , ! 1 === arguments [ 0 ] ( k , d ) ) ) continue ; this . replace ( k , d ) } } } ; CKEDITOR . editor . prototype . addMode = function ( a , b ) { ( this . _ . modes || ( this . _ . modes = { } ) ) [ a ] = b } ; CKEDITOR . editor . prototype . setMode = function ( a , b ) { var d = this , k = this . _ . modes ; if ( a != d . mode && k&& k [ a ] ) { d . fire ( "beforeSetMode" , a ) ; if ( d . mode ) { var h= d . checkDirty ( ) , k = d . _ . previousModeData , n , l = 0 ; d . fire ( "beforeModeUnload" ) ;
d . editable ( 0 ) ; d . _ . previousMode = d . mode ; d . _ . previousModeData = n = d . getData ( 1 ) ; "source" == d . mode && k== n && ( d . fire ( "lockSnapshot" , { forceUpdate : ! 0 } ) , l = 1 ) ; d . ui . space ( "contents" ) . setHtml ( "" ) ; d . mode = "" } else d . _ . previousModeData = d . getData ( 1 ) ; this . _ . modes [ a ] ( function ( ) { d . mode = a ; void 0 !== h&& ! h && d . resetDirty ( ) ; l ? d . fire ( "unlockSnapshot" ) : "wysiwyg" == a && d . fire ( "saveSnapshot" ) ; setTimeout ( function ( ) { d . isDestroyed ( ) || d . isDetached ( ) || ( d . fire ( "mode" ) , b && b . call ( d ) ) } , 0 ) } ) } } ; CKEDITOR . editor . prototype . resize = function ( a , b , d , k) { var h =
this . container , n = this . ui . space ( "contents" ) , l = CKEDITOR . env . webkit && this . document && this . document . getWindow ( ) . $ . frameElement ; k= k ? this . container . getFirst ( function ( a ) { return a . type == CKEDITOR . NODE _ELEMENT && a . hasClass ( "cke_inner" ) } ) : h ; if ( a || 0 === a ) a = CKEDITOR . tools . convertToPx ( CKEDITOR . tools . cssLength ( a ) ) ; k . setSize ( "width" , a , ! 0 ) ; l&& ( l . style . width = "1%" ) ; b = CKEDITOR . tools . convertToPx ( CKEDITOR . tools . cssLength ( b ) ) ; var g= ( k . $ . offsetHeight || 0 ) - ( n. $ . clientHeight || 0 ) , h = Math . max ( b - ( d ? 0 : g ) , 0 ) ; b = d ? b + g: b ; n . setStyle ( "height" ,
CKEDITOR . tools . cssLength ( h) ) ; l && ( l . style . width = "100%" ) ; this . fire ( "resize" , { outerHeight : b , contentsHeight : h, outerWidth : a || k . getSize ( "width" ) } ) } ; CKEDITOR . editor . prototype . getResizable = function ( a ) { return a ? this . ui . space ( "contents" ) : this . container } ; CKEDITOR . domReady ( function ( ) { CKEDITOR . replaceClass && CKEDITOR . replaceAll ( CKEDITOR . replaceClass ) } ) } ) ( ) ; CKEDITOR . config . startupMode = "wysiwyg" ;
( function ( ) { function a ( a ) { var b = a . editor , e = a . data . path , g= e . blockLimit , f = a . data . selection , h = f . getRanges ( ) [ 0 ] , k ; if ( CKEDITOR . env . gecko || CKEDITOR . env . ie && CKEDITOR . env . needsBrFiller ) if ( f= d ( f , e ) ) f . appendBogus ( ) , k = CKEDITOR . env . ie && ! CKEDITOR . env . edge || CKEDITOR . env . edge && b . _ . previousActive ; n( b , e . block , g ) && h . collapsed && ! h . getCommonAncestor ( ) . isReadOnly ( ) && ( e = h . clone ( ) , e . enlarge ( CKEDITOR . ENLARGE _BLOCK _CONTENTS ) , g = new CKEDITOR . dom . walker ( e ) , g . guard = function ( a ) { return ! c ( a ) || a . type == CKEDITOR . NODE _COMMENT || a . isReadOnly ( ) } ,
! g . checkForward ( ) || e . checkStartOfBlock ( ) && e . checkEndOfBlock ( ) ) && ( b = h . fixBlock ( ! 0 , b . activeEnterMode == CKEDITOR . ENTER _DIV ? "div" : "p" ) , CKEDITOR . env . needsBrFiller || ( b = b . getFirst ( c ) ) && b . type == CKEDITOR . NODE _TEXT && CKEDITOR . tools . trim ( b . getText ( ) ) . match ( /^(?: |\xa0)$/ ) && b . remove ( ) , k = 1 , a . cancel ( ) ) ; k && h . select ( ) } function d ( a , b ) { if ( a . isFake ) return 0 ; var d = b . block || b . blockLimit , e = d && d . getLast ( c ) ; if ( ! ( ! d || ! d . isBlockBoundary ( ) || e && e . type == CKEDITOR . NODE _ELEMENT && e . isBlockBoundary ( ) || d . is ( "pre" ) || d . getBogus ( ) ) ) return d }
function b ( a ) { var b = a . data . getTarget ( ) ; b . is ( "input" ) && ( b = b . getAttribute ( "type" ) , "submit" != b && "reset" != b || a . data . preventDefault ( ) ) } function c ( a ) { return z( a ) && G ( a ) } function f ( a , b ) { return function ( c ) { var d = c . data . $ . toElement || c . data . $ . fromElement || c . data . $ . relatedTarget ; ( d = d && d . nodeType == CKEDITOR . NODE _ELEMENT ? new CKEDITOR . dom . element ( d ) : null ) && ( b . equals ( d ) || b . contains ( d ) ) || a . call ( this , c ) } } function e ( a ) { return ! ! a . getRanges ( ) [ 0 ] . startPath ( ) . contains ( { table : 1 , ul : 1 , ol : 1 , dl : 1 } ) } function k ( a ) { function b ( a ) { var e =
{ table : 1 , ul : 1 , ol : 1 , dl : 1 } ; return function ( b , g) { g && b . type == CKEDITOR . NODE _ELEMENT && b . is ( e ) && ( d = b ) ; if ( ! ( g || ! c ( b ) || a && m ( b ) ) ) return ! 1 } } var d , g = a . getRanges ( ) [ 0 ] , f = a . root ; return e ( a ) && ( a = g . clone ( ) , a . collapse ( 1 ) , a . setStartAt ( f , CKEDITOR . POSITION _AFTER _START ) , f = new CKEDITOR . dom . walker ( a ) , f. guard = b ( ) , f . checkBackward ( ) , d ) ? ( a = g . clone ( ) , a . collapse ( ) , a . setEndAt ( d , CKEDITOR . POSITION _AFTER _END ) , f = new CKEDITOR . dom . walker ( a ) , f . guard = b ( ! 0 ) , d = ! 1 , f . checkForward ( ) , d ) : null } function h ( a ) { return a . block . getParent ( ) . getChildCount ( ) }
function n ( a , b , c ) { return ! 1 !== a . config . autoParagraph && a . activeEnterMode != CKEDITOR . ENTER _BR && ( a . editable ( ) . equals ( c ) && ! b || b && "true" == b . getAttribute ( "contenteditable" ) ) } function l ( a ) { return a . activeEnterMode != CKEDITOR . ENTER _BR && ! 1 !== a . config . autoParagraph ? a . activeEnterMode == CKEDITOR . ENTER _DIV ? "div" : "p" : ! 1 } function g ( a ) { a && a . isEmptyInlineRemoveable ( ) && a . remove ( ) } function x ( a ) { var b = a . editor ; b . getSelection ( ) . scrollIntoView ( ) ; setTimeout ( function ( ) { b . fire ( "saveSnapshot" ) } , 0 ) } function y ( a , b , c ) { var d = a . getCommonAncestor ( b ) ;
for ( b = a = c ? b : a ; ( a = a . getParent ( ) ) && ! d . equals ( a ) && 1 == a . getChildCount ( ) ; ) b = a ; b . remove ( ) } var z, G , v , m , M , w , J , F , q , u , K = { ul : 1 , ol : 1 , dl : 1 } ; CKEDITOR . editable = CKEDITOR . tools . createClass ( { base : CKEDITOR . dom . element , $ : function ( a , b ) { this . base ( b . $ || b ) ; this . editor = a ; this . status = "unloaded" ; this . hasFocus = ! 1 ; this . setup ( ) } , proto : { focus : function ( ) { var a ; if ( CKEDITOR . env . webkit && ! this . hasFocus && ( a = this . editor . _ . previousActive || this . getDocument ( ) . getActive ( ) , this . contains ( a ) ) ) { a . focus ( ) ; return } CKEDITOR . env . edge && 14 < CKEDITOR . env . version &&
! this . hasFocus && this . getDocument ( ) . equals ( CKEDITOR . document ) && ( this . editor . _ . previousScrollTop = this . $ . scrollTop ) ; try { if ( ! CKEDITOR . env . ie || CKEDITOR . env . edge && 14 < CKEDITOR . env . version || ! this . getDocument ( ) . equals ( CKEDITOR . document ) ) if ( CKEDITOR . env . chrome ) { var b = this . $ . scrollTop ; this . $ . focus ( ) ; this . $ . scrollTop = b } else this . $ . focus ( ) ; else this . $ . setActive ( ) } catch ( c ) { if ( ! CKEDITOR . env . ie ) throw c ; } CKEDITOR . env . safari && ! this . isInline ( ) && ( a = CKEDITOR . document . getActive ( ) , a . equals ( this . getWindow ( ) . getFrame ( ) ) ||
this . getWindow ( ) . focus ( ) ) } , on : function ( a , b ) { var c = Array . prototype . slice . call ( arguments , 0 ) ; CKEDITOR . env . ie && /^focus|blur$/ . exec ( a ) && ( a = "focus" == a ? "focusin" : "focusout" , b = g ( b , this ) , c [ 0 ] = a , c [ 1 ] = b ) ; return CKEDITOR . dom . element . prototype . on . apply ( this , c ) } , attachListener : function ( a ) { ! this . _ . listeners && ( this . _ . listeners = [ ] ) ; var b = Array . prototype . slice . call ( arguments , 1 ) , b = a . on . apply ( a , b ) ; this . _ . listeners . push ( b ) ; return b } , clearListeners : function ( ) { var a = this . _ . listeners ; try { for ( ; a . length ; ) a . pop ( ) . removeListener ( ) } catch ( b ) { } } ,
this . getWindow ( ) . focus ( ) ) } , on : function ( a , b ) { var c = Array . prototype . slice . call ( arguments , 0 ) ; CKEDITOR . env . ie && /^focus|blur$/ . exec ( a ) && ( a = "focus" == a ? "focusin" : "focusout" , b = f ( b , this ) , c [ 0 ] = a , c [ 1 ] = b ) ; return CKEDITOR . dom . element . prototype . on . apply ( this , c ) } , attachListener : function ( a ) { ! this . _ . listeners && ( this . _ . listeners = [ ] ) ; var b = Array . prototype . slice . call ( arguments , 1 ) , b = a . on . apply ( a , b ) ; this . _ . listeners . push ( b ) ; return b } , clearListeners : function ( ) { var a = this . _ . listeners ; try { for ( ; a . length ; ) a . pop ( ) . removeListener ( ) } catch ( b ) { } } ,
restoreAttrs : function ( ) { var a = this . _ . attrChanges , b , c ; for ( c in a ) a . hasOwnProperty ( c ) && ( b = a [ c ] , null !== b ? this . setAttribute ( c , b ) : this . removeAttribute ( c ) ) } , attachClass : function ( a ) { var b = this . getCustomData ( "classes" ) ; this . hasClass ( a ) || ( ! b && ( b = [ ] ) , b . push ( a ) , this . setCustomData ( "classes" , b ) , this . addClass ( a ) ) } , changeAttr : function ( a , b ) { var c = this . getAttribute ( a ) ; b !== c && ( ! this . _ . attrChanges && ( this . _ . attrChanges = { } ) , a in this . _ . attrChanges || ( this . _ . attrChanges [ a ] = c ) , this . setAttribute ( a , b ) ) } , insertText : function ( a ) { this . editor . focus ( ) ;
this . insertHtml ( this . transformPlainTextToHtml ( a ) , "text" ) } , transformPlainTextToHtml : function ( a ) { var b = this . editor . getSelection ( ) . getStartElement ( ) . hasAscendant ( "pre" , ! 0 ) ? CKEDITOR . ENTER _BR : this . editor . activeEnterMode ; return CKEDITOR . tools . transformPlainTextToHtml ( a , b ) } , insertHtml : function ( a , b , c ) { var d = this . editor ; d . focus ( ) ; d . fire ( "saveSnapshot" ) ; c || ( c = d . getSelection ( ) . getRanges ( ) [ 0 ] ) ; v ( this , b || "html" , a , c ) ; c . select ( ) ; w ( this ) ; this . editor . fire ( "afterInsertHtml" , { } ) } , insertHtmlIntoRange : function ( a , b , c ) { v ( this ,
c || "html" , a , b ) ; this . editor . fire ( "afterInsertHtml" , { intoRange : b } ) } , insertElement : function ( a , b ) { var d = this . editor ; d . focus ( ) ; d . fire ( "saveSnapshot" ) ; var e = d . activeEnterMode , d = d . getSelection ( ) , f= a . getName ( ) , f = CKEDITOR . dtd . $block [ f ] ; b || ( b = d . getRanges ( ) [ 0 ] ) ; this . insertElementIntoRange ( a , b ) && ( b . moveToPosition ( a , CKEDITOR . POSITION _AFTER _END ) , f&& ( ( f = a . getNext ( function ( a ) { return c ( a ) && ! m ( a ) } ) ) && f . type == CKEDITOR . NODE _ELEMENT && f . is ( CKEDITOR . dtd . $block ) ? f . getDtd ( ) [ "#" ] ? b . moveToElementEditStart ( f ) : b . moveToElementEditEnd ( a ) :
f || e == CKEDITOR . ENTER _BR || ( f = b . fixBlock ( ! 0 , e == CKEDITOR . ENTER _DIV ? "div" : "p" ) , b . moveToElementEditStart ( f ) ) ) ) ; d . selectRanges ( [ b ] ) ; w ( this ) } , insertElementIntoSelection : function ( a ) { this . insertElement ( a ) } , insertElementIntoRange : function ( a , b ) { var c = this . editor , d = c . config . enterMode , e = a . getName ( ) , g = CKEDITOR . dtd . $block [ e ] ; if ( b . checkReadOnly ( ) ) return ! 1 ; b . deleteContents ( 1 ) ; b . startContainer . type == CKEDITOR . NODE _ELEMENT && ( b . startContainer . is ( { tr : 1 , table : 1 , tbody : 1 , thead : 1 , tfoot : 1 } ) ? J ( b ) : b . startContainer . is ( CKEDITOR . dtd . $list ) &&
G ( b ) ) ; var h , k ; if ( g ) for ( ; ( h = b . getCommonAncestor ( 0 , 1 ) ) && ( k = CKEDITOR . dtd [ h . getName ( ) ] ) && ( ! k || ! k [ e ] ) ; ) if ( h . getName ( ) in CKEDITOR . dtd . span ) { var g= b . splitElement ( h ) , x = b . createBookmark ( ) ; f ( h ) ; f ( g ) ; b . moveToBookmark ( x ) } else b . checkStartOfBlock ( ) && b . checkEndOfBlock ( ) ? ( b . setStartBefore ( h ) , b . collapse ( ! 0 ) , h . remove ( ) ) : b . splitBlock ( d == CKEDITOR . ENTER _DIV ? "div" : "p" , c . editable ( ) ) ; b . insertNode ( a ) ; return ! 0 } , setData : function ( a , b ) { b || ( a = this . editor . dataProcessor . toHtml ( a ) ) ; this . setHtml ( a ) ; this . fixInitialSelection ( ) ; "unloaded" ==
this . insertHtml ( this . transformPlainTextToHtml ( a ) , "text" ) } , transformPlainTextToHtml : function ( a ) { var b = this . editor . getSelection ( ) . getStartElement ( ) . hasAscendant ( "pre" , ! 0 ) ? CKEDITOR . ENTER _BR : this . editor . activeEnterMode ; return CKEDITOR . tools . transformPlainTextToHtml ( a , b ) } , insertHtml : function ( a , b , c ) { var d = this . editor ; d . focus ( ) ; d . fire ( "saveSnapshot" ) ; c || ( c = d . getSelection ( ) . getRanges ( ) [ 0 ] ) ; w ( this , b || "html" , a , c ) ; c . select ( ) ; x ( this ) ; this . editor . fire ( "afterInsertHtml" , { } ) } , insertHtmlIntoRange : function ( a , b , c ) { w ( this ,
c || "html" , a , b ) ; this . editor . fire ( "afterInsertHtml" , { intoRange : b } ) } , insertElement : function ( a , b ) { var d = this . editor ; d . focus ( ) ; d . fire ( "saveSnapshot" ) ; var e = d . activeEnterMode , d = d . getSelection ( ) , g= a . getName ( ) , g = CKEDITOR . dtd . $block [ g ] ; b || ( b = d . getRanges ( ) [ 0 ] ) ; this . insertElementIntoRange ( a , b ) && ( b . moveToPosition ( a , CKEDITOR . POSITION _AFTER _END ) , g&& ( ( g = a . getNext ( function ( a ) { return c ( a ) && ! m ( a ) } ) ) && g . type == CKEDITOR . NODE _ELEMENT && g . is ( CKEDITOR . dtd . $block ) ? g . getDtd ( ) [ "#" ] ? b . moveToElementEditStart ( g ) : b . moveToElementEditEnd ( a ) :
g || e == CKEDITOR . ENTER _BR || ( g = b . fixBlock ( ! 0 , e == CKEDITOR . ENTER _DIV ? "div" : "p" ) , b . moveToElementEditStart ( g ) ) ) ) ; d . selectRanges ( [ b ] ) ; x ( this ) } , insertElementIntoSelection : function ( a ) { this . insertElement ( a ) } , insertElementIntoRange : function ( a , b ) { var c = this . editor , d = c . config . enterMode , e = a . getName ( ) , f = CKEDITOR . dtd . $block [ e ] ; if ( b . checkReadOnly ( ) ) return ! 1 ; b . deleteContents ( 1 ) ; b . startContainer . type == CKEDITOR . NODE _ELEMENT && ( b . startContainer . is ( { tr : 1 , table : 1 , tbody : 1 , thead : 1 , tfoot : 1 } ) ? J ( b ) : b . startContainer . is ( CKEDITOR . dtd . $list ) &&
F ( b ) ) ; var h , k ; if ( f ) for ( ; ( h = b . getCommonAncestor ( 0 , 1 ) ) && ( k = CKEDITOR . dtd [ h . getName ( ) ] ) && ( ! k || ! k [ e ] ) ; ) if ( h . getName ( ) in CKEDITOR . dtd . span ) { var f= b . splitElement ( h ) , r = b . createBookmark ( ) ; g ( h ) ; g ( f ) ; b . moveToBookmark ( r ) } else b . checkStartOfBlock ( ) && b . checkEndOfBlock ( ) ? ( b . setStartBefore ( h ) , b . collapse ( ! 0 ) , h . remove ( ) ) : b . splitBlock ( d == CKEDITOR . ENTER _DIV ? "div" : "p" , c . editable ( ) ) ; b . insertNode ( a ) ; return ! 0 } , setData : function ( a , b ) { b || ( a = this . editor . dataProcessor . toHtml ( a ) ) ; this . setHtml ( a ) ; this . fixInitialSelection ( ) ; "unloaded" ==
this . status && ( this . status = "ready" ) ; this . editor . fire ( "dataReady" ) } , getData : function ( a ) { var b = this . getHtml ( ) ; a || ( b = this . editor . dataProcessor . toDataFormat ( b ) ) ; return b } , setReadOnly : function ( a ) { this . setAttribute ( "contenteditable" , String ( ! a ) ) ; this . setAttribute ( "aria-readonly" , String ( a ) ) } , detach : function ( ) { this . status = "detached" ; this . editor . setData ( this . editor . getData ( ) , { internal : ! 0 } ) ; this . clearListeners ( ) ; try { this . _ . cleanCustomData ( ) } catch ( a ) { if ( ! CKEDITOR . env . ie || - 2146828218 !== a . number ) throw a ; } this . editor . fire ( "contentDomUnload" ) ;
delete this . editor . document ; delete this . editor . window ; delete this . editor } , isInline : function ( ) { return this . getDocument ( ) . equals ( CKEDITOR . document ) } , fixInitialSelection : function ( ) { function a ( ) { var b = c . getDocument ( ) . $ , d = b . getSelection ( ) , e ; a : if ( d . anchorNode && d . anchorNode == c . $ ) e = ! 0 ; else { if ( CKEDITOR . env . webkit && ( e = c . getDocument ( ) . getActive ( ) ) && e . equals ( c ) && ! d . anchorNode ) { e = ! 0 ; break a } e = void 0 } e && ( e = new CKEDITOR . dom . range ( c ) , e . moveToElementEditStart ( c ) , b = b . createRange ( ) , b . setStart ( e . startContainer . $ , e . startOffset ) ,
b . collapse ( ! 0 ) , d . removeAllRanges ( ) , d . addRange ( b ) ) } function b ( ) { var a = c . getDocument ( ) . $ , d = a . selection , e = c . getDocument ( ) . getActive ( ) ; "None" == d . type && e . equals ( c ) && ( d = new CKEDITOR . dom . range ( c ) , a = a . body . createTextRange ( ) , d . moveToElementEditStart ( c ) , d = d . startContainer , d . type != CKEDITOR . NODE _ELEMENT && ( d = d . getParent ( ) ) , a . moveToElementText ( d . $ ) , a . collapse ( ! 0 ) , a . select ( ) ) } var c = this ; if ( CKEDITOR . env . ie && ( 9 > CKEDITOR . env . version || CKEDITOR . env . quirks ) ) this . hasFocus && ( this . focus ( ) , b ( ) ) ; else if ( this . hasFocus ) this . focus ( ) ,
a ( ) ; else this . once ( "focus" , function ( ) { a ( ) } , null , null , - 999 ) } , getHtmlFromRange : function ( a ) { if ( a . collapsed ) return new CKEDITOR . dom . documentFragment ( a . document ) ; a = { doc : this . getDocument ( ) , range : a . clone ( ) } ; p . eol . detect ( a , this ) ; p. bogus . exclude ( a ) ; p . cell . shrink ( a ) ; a . fragment = a . range . cloneContents ( ) ; p . tree . rebuild ( a , this ) ; p . eol . fix ( a , this ) ; return new CKEDITOR . dom . documentFragment ( a . fragment . $ ) } , extractHtmlFromRange : function ( a , b ) { var c = u , d = { range : a , doc : a . document } , e = this . getHtmlFromRange ( a ) ; if ( a . collapsed ) return a . optimize ( ) ,
e ; a . enlarge ( CKEDITOR . ENLARGE _INLINE , 1 ) ; c . table . detectPurge ( d ) ; d . bookmark = a . createBookmark ( ) ; delete d . range ; var f = this . editor . createRange ( ) ; f . moveToPosition ( d . bookmark . startNode , CKEDITOR . POSITION _BEFORE _START ) ; d . targetBookmark = f . createBookmark ( ) ; c . list . detectMerge ( d , this ) ; c . table . detectRanges ( d , this ) ; c . block . detectMerge ( d , this ) ; d . tableContentsRanges ? ( c . table . deleteRanges ( d ) , a . moveToBookmark ( d . bookmark ) , d . range = a ) : ( a . moveToBookmark ( d . bookmark ) , d . range = a , a . extractContents ( c . detectExtractMerge ( d ) ) ) ; a . moveToBookmark ( d . targetBookmark ) ;
a . optimize ( ) ; c . fixUneditableRangePosition ( a ) ; c . list . merge ( d , this ) ; c . table . purge ( d , this ) ; c . block . merge ( d , this ) ; if ( b ) { c = a . startPath ( ) ; if ( d = a . checkStartOfBlock ( ) && a . checkEndOfBlock ( ) && c . block && ! a . root . equals ( c . block ) ) { a : { var d = c . block . getElementsByTag ( "span" ) , f= 0 , g ; if ( d ) for ( ; g = d . getItem ( f ++ ) ; ) if ( ! F ( g ) ) { d = ! 0 ; break a } d = ! 1 } d = ! d } d && ( a . moveToPosition ( c . block , CKEDITOR . POSITION _BEFORE _START ) , c . block . remove ( ) ) } else c . autoParagraph ( this . editor , a ) , r ( a . startContainer ) && a . startContainer . appendBogus ( ) ; a . startContainer . mergeSiblings ( ) ;
return e } , setup : function ( ) { var a = this . editor ; this . attachListener ( a , "beforeGetData" , function ( ) { var b = this . getData ( ) ; this . is ( "textarea" ) || ! 1 !== a . config . ignoreEmptyParagraph && ( b = b . replace ( L , function ( a , b ) { return b } ) ) ; a . setData ( b , null , 1 ) } , this ) ; this . attachListener ( a , "getSnapshot" , function ( a ) { a . data = this . getData ( 1 ) } , this ) ; this . attachListener ( a , "afterSetData" , function ( ) { this . setData ( a . getData ( 1 ) ) } , this ) ; this . attachListener ( a , "loadSnapshot" , function ( a ) { this . setData ( a . data , 1 ) } , this ) ; this . attachListener ( a ,
a ( ) ; else this . once ( "focus" , function ( ) { a ( ) } , null , null , - 999 ) } , getHtmlFromRange : function ( a ) { if ( a . collapsed ) return new CKEDITOR . dom . documentFragment ( a . document ) ; a = { doc : this . getDocument ( ) , range : a . clone ( ) } ; q . eol . detect ( a , this ) ; q. bogus . exclude ( a ) ; q . cell . shrink ( a ) ; a . fragment = a . range . cloneContents ( ) ; q . tree . rebuild ( a , this ) ; q . eol . fix ( a , this ) ; return new CKEDITOR . dom . documentFragment ( a . fragment . $ ) } , extractHtmlFromRange : function ( a , b ) { var c = u , d = { range : a , doc : a . document } , e = this . getHtmlFromRange ( a ) ; if ( a . collapsed ) return a . optimize ( ) ,
e ; a . enlarge ( CKEDITOR . ENLARGE _INLINE , 1 ) ; c . table . detectPurge ( d ) ; d . bookmark = a . createBookmark ( ) ; delete d . range ; var g = this . editor . createRange ( ) ; g . moveToPosition ( d . bookmark . startNode , CKEDITOR . POSITION _BEFORE _START ) ; d . targetBookmark = g . createBookmark ( ) ; c . list . detectMerge ( d , this ) ; c . table . detectRanges ( d , this ) ; c . block . detectMerge ( d , this ) ; d . tableContentsRanges ? ( c . table . deleteRanges ( d ) , a . moveToBookmark ( d . bookmark ) , d . range = a ) : ( a . moveToBookmark ( d . bookmark ) , d . range = a , a . extractContents ( c . detectExtractMerge ( d ) ) ) ; a . moveToBookmark ( d . targetBookmark ) ;
a . optimize ( ) ; c . fixUneditableRangePosition ( a ) ; c . list . merge ( d , this ) ; c . table . purge ( d , this ) ; c . block . merge ( d , this ) ; if ( b ) { c = a . startPath ( ) ; if ( d = a . checkStartOfBlock ( ) && a . checkEndOfBlock ( ) && c . block && ! a . root . equals ( c . block ) ) { a : { var d = c . block . getElementsByTag ( "span" ) , g= 0 , f ; if ( d ) for ( ; f = d . getItem ( g ++ ) ; ) if ( ! G ( f ) ) { d = ! 0 ; break a } d = ! 1 } d = ! d } d && ( a . moveToPosition ( c . block , CKEDITOR . POSITION _BEFORE _START ) , c . block . remove ( ) ) } else c . autoParagraph ( this . editor , a ) , v ( a . startContainer ) && a . startContainer . appendBogus ( ) ; a . startContainer . mergeSiblings ( ) ;
return e } , setup : function ( ) { var a = this . editor ; this . attachListener ( a , "beforeGetData" , function ( ) { var b = this . getData ( ) ; this . is ( "textarea" ) || ! 1 !== a . config . ignoreEmptyParagraph && ( b = b . replace ( M , function ( a , b ) { return b } ) ) ; a . setData ( b , null , 1 ) } , this ) ; this . attachListener ( a , "getSnapshot" , function ( a ) { a . data = this . getData ( 1 ) } , this ) ; this . attachListener ( a , "afterSetData" , function ( ) { this . setData ( a . getData ( 1 ) ) } , this ) ; this . attachListener ( a , "loadSnapshot" , function ( a ) { this . setData ( a . data , 1 ) } , this ) ; this . attachListener ( a ,
"beforeFocus" , function ( ) { var b = a . getSelection ( ) ; ( b = b && b . getNative ( ) ) && "Control" == b . type || this . focus ( ) } , this ) ; this . attachListener ( a , "insertHtml" , function ( a ) { this . insertHtml ( a . data . dataValue , a . data . mode , a . data . range ) } , this ) ; this . attachListener ( a , "insertElement" , function ( a ) { this . insertElement ( a . data ) } , this ) ; this . attachListener ( a , "insertText" , function ( a ) { this . insertText ( a . data ) } , this ) ; this . setReadOnly ( a . readOnly ) ; this . attachClass ( "cke_editable" ) ; a . elementMode == CKEDITOR . ELEMENT _MODE _INLINE ? this . attachClass ( "cke_editable_inline" ) :
a . elementMode != CKEDITOR . ELEMENT _MODE _REPLACE && a . elementMode != CKEDITOR . ELEMENT _MODE _APPENDTO || this . attachClass ( "cke_editable_themed" ) ; this . attachClass ( "cke_contents_" + a . config . contentsLangDirection ) ; a . keystrokeHandler . blockedKeystrokes [ 8 ] = + a . readOnly ; a . keystrokeHandler . attach ( this ) ; this . on ( "blur" , function ( ) { this . hasFocus = ! 1 } , null , null , - 1 ) ; this . on ( "focus" , function ( ) { this . hasFocus = ! 0 } , null , null , - 1 ) ; if ( CKEDITOR . env . webkit ) this . on ( "scroll" , function ( ) { a . _ . previousScrollTop = a . editable ( ) . $ . scrollTop } , null ,
null , - 1 ) ; if ( CKEDITOR . env . edge && 14 < CKEDITOR . env . version ) { var d = function ( ) { var b = a . editable ( ) ; null != a . _ . previousScrollTop && b . getDocument ( ) . equals ( CKEDITOR . document ) && ( b . $ . scrollTop = a . _ . previousScrollTop , a . _ . previousScrollTop = null , this . removeListener ( "scroll" , d ) ) } ; this . on ( "scroll" , d ) } a . focusManager . add ( this ) ; this . equals ( CKEDITOR . document . getActive ( ) ) && ( this . hasFocus = ! 0 , a . once ( "contentDom" , function ( ) { a . focusManager . focus ( this ) } , this ) ) ; this . isInline ( ) && this . changeAttr ( "tabindex" , a . tabIndex ) ; if ( ! this . is ( "textarea" ) ) { a . document =
this . getDocument ( ) ; a . window = this . getWindow ( ) ; var f = a . document ; this . changeAttr ( "spellcheck" , ! a . config . disableNativeSpellChecker ) ; var g = a . config . contentsLangDirection ; this . getDirection ( 1 ) != g && this . changeAttr ( "dir" , g) ; var C = CKEDITOR . getCss ( ) ; if ( C) { var g = f . getHead ( ) , I = g . getCustomData ( "stylesheet" ) ; I ? C != I . getText ( ) && ( CKEDITOR . env . ie && 9 > CKEDITOR . env . version ? I . $ . styleSheet . cssText = C: I . setText ( C ) ) : ( C = f . appendStyleText ( C ) , C = new CKEDITOR . dom . element ( C . ownerNode || C . owningElement ) , g . setCustomData ( "stylesheet" ,
C) , C . data ( "cke-temp" , 1 ) ) } g= f . getCustomData ( "stylesheet_ref" ) || 0 ; f. setCustomData ( "stylesheet_ref" , g + 1 ) ; this . setCustomData ( "cke_includeReadonly" , ! a . config . disableReadonlyStyling ) ; this . attachListener ( this , "click" , function ( a ) { a = a . data ; var b = ( new CKEDITOR . dom . elementPath ( a . getTarget ( ) , this ) ) . contains ( "a" ) ; b && 2 != a . $ . button && b . isReadOnly ( ) && a . preventDefault ( ) } ) ; var l = { 8 : 1 , 46 : 1 } ; this . attachListener ( a , "key" , function ( b ) { if ( a . readOnly ) return ! 0 ; var c = b . data . domEvent . getKey ( ) , d , f = a . getSelection ( ) ; if ( 0 !== f . getRanges ( ) . length ) { if ( c in
l) { var g ; b = f . getRanges ( ) [ 0 ] ; var t = b . startPath ( ) , C, D , I , c = 8 == c , q = ! 1 ; if ( CKEDITOR . env . ie && 11 > CKEDITOR . env . version && f. getSelectedElement ( ) ) g = f . getSelectedElement ( ) ; else if ( e ( f) ) { var m = new CKEDITOR . dom . walker ( b ) , z = b . collapsed ? b . startContainer : m. next ( ) , q = ! 1 , w ; if ( b . checkStartOfBlock ( ) ) { w = b . startPath ( ) . block || b . startPath ( ) . blockLimit ; var p= w . getName ( ) ; w = - 1 !== CKEDITOR . tools . array . indexOf ( [ "dd" , "dt" , "li" ] , p) && null === w . getPrevious ( ) } else w = ! 1 ; if ( w ) { for ( ; z && ! q ; ) q = z . $ . nodeName . toLowerCase ( ) , q= ! ! K [ q ] , z = m . next ( ) ;
m= k ( b . startPath ( ) ) ; z = k ( b . endPath ( ) ) ; q = q || m !== z } else q = void 0 ; q || ( g = h ( f ) ) } g || q ? ( a . fire ( "saveSnapshot" ) , q ? ( ( d = b . startContainer . getAscendant ( K , ! 0 ) ) ? ( b . setStart ( d , 0 ) , b . enlarge ( CKEDITOR . ENLARGE _ELEMENT ) , g= b ) : g = null , g . deleteContents ( ) ) : ( b . moveToPosition ( g , CKEDITOR . POSITION _BEFORE _START ) , g . remove ( ) ) , b . select ( ) , a . fire ( "saveSnapshot" ) , d = 1 ) : b . collapsed && ( ( C = t . block ) && ( I = C [ c ? "getPrevious" : "getNext" ] ( y ) ) && I . type == CKEDITOR . NODE _ELEMENT && I . is ( "table" ) && b [ c ? "checkStartOfBlock" : "checkEndOfBlock" ] ( ) ? ( a . fire ( "saveSnapshot" ) ,
b [ c ? "checkEndOfBlock" : "checkStartOfBlock" ] ( ) && C . remove ( ) , b [ "moveToElementEdit" + ( c ? "End" : "Start" ) ] ( I ) , b . select ( ) , a . fire ( "saveSnapshot" ) , d = 1 ) : t . blockLimit && t . blockLimit . is ( "td" ) && ( D = t . blockLimit . getAscendant ( "table" ) ) && b . checkBoundaryOfElement ( D , c ? CKEDITOR . START : CKEDITOR . END ) && ( I = D [ c ? "getPrevious" : "getNext" ] ( y ) ) ? ( a . fire ( "saveSnapshot" ) , b [ "moveToElementEdit" + ( c ? "End" : "Start" ) ] ( I ) , b . checkStartOfBlock ( ) && b . checkEndOfBlock ( ) ? I . remove ( ) : b . select ( ) , a . fire ( "saveSnapshot" ) , d = 1 ) : ( D = t . contains ( [ "td" , "th" , "caption" ] ) ) &&
b . checkBoundaryOfElement ( D , c ? CKEDITOR . START : CKEDITOR . END ) && ( d = 1 ) ) } return ! d } } ) ; a . blockless && CKEDITOR . env . ie && CKEDITOR . env . needsBrFiller && this . attachListener ( this , "keyup" , function ( b ) { b . data . getKeystroke ( ) in l && ! this . getFirst ( c ) && ( this . appendBogus ( ) , b = a . createRange ( ) , b . moveToPosition ( this , CKEDITOR . POSITION _AFTER _START ) , b . select ( ) ) } ) ; this . attachListener ( this , "dblclick" , function ( b ) { if ( a . readOnly ) return ! 1 ; b = { element : b . data . getTarget ( ) } ; a . fire ( "doubleclick" , b ) } ) ; CKEDITOR . env . ie && this . attachListener ( this ,
this . getDocument ( ) ; a . window = this . getWindow ( ) ; var g = a . document ; this . changeAttr ( "spellcheck" , ! a . config . disableNativeSpellChecker ) ; var f = a . config . contentsLangDirection ; this . getDirection ( 1 ) != f && this . changeAttr ( "dir" , f) ; var A = CKEDITOR . getCss ( ) ; if ( A) { var f = g . getHead ( ) , I = f . getCustomData ( "stylesheet" ) ; I ? A != I . getText ( ) && ( CKEDITOR . env . ie && 9 > CKEDITOR . env . version ? I . $ . styleSheet . cssText = A: I . setText ( A ) ) : ( A = g . appendStyleText ( A ) , A = new CKEDITOR . dom . element ( A . ownerNode || A . owningElement ) , f . setCustomData ( "stylesheet" ,
A) , A . data ( "cke-temp" , 1 ) ) } f= g . getCustomData ( "stylesheet_ref" ) || 0 ; g. setCustomData ( "stylesheet_ref" , f + 1 ) ; this . setCustomData ( "cke_includeReadonly" , ! a . config . disableReadonlyStyling ) ; this . attachListener ( this , "click" , function ( a ) { a = a . data ; var b = ( new CKEDITOR . dom . elementPath ( a . getTarget ( ) , this ) ) . contains ( "a" ) ; b && 2 != a . $ . button && b . isReadOnly ( ) && a . preventDefault ( ) } ) ; var N = { 8 : 1 , 46 : 1 } ; this . attachListener ( a , "key" , function ( b ) { if ( a . readOnly ) return ! 0 ; var c = b . data . domEvent . getKey ( ) , d , g = a . getSelection ( ) ; if ( 0 !== g . getRanges ( ) . length ) { if ( c in
N) { var f ; b = g . getRanges ( ) [ 0 ] ; var t = b . startPath ( ) , A, H , I , c = 8 == c , l = ! 1 ; if ( CKEDITOR . env . ie && 11 > CKEDITOR . env . version && g. getSelectedElement ( ) ) f = g . getSelectedElement ( ) ; else if ( e ( g) ) { var n = new CKEDITOR . dom . walker ( b ) , m = b . collapsed ? b . startContainer : n. next ( ) , l = ! 1 , B ; if ( b . checkStartOfBlock ( ) ) { B = b . startPath ( ) . block || b . startPath ( ) . blockLimit ; var q= B . getName ( ) ; B = - 1 !== CKEDITOR . tools . array . indexOf ( [ "dd" , "dt" , "li" ] , q) && null === B . getPrevious ( ) } else B = ! 1 ; if ( B ) { for ( ; m && ! l ; ) l = m . $ . nodeName . toLowerCase ( ) , l= ! ! K [ l ] , m = n . next ( ) ;
n= h ( b . startPath ( ) ) ; m = h ( b . endPath ( ) ) ; l = l || n !== m } else l = void 0 ; l || ( f = k ( g ) ) } f || l ? ( a . fire ( "saveSnapshot" ) , l ? ( ( d = b . startContainer . getAscendant ( K , ! 0 ) ) ? ( b . setStart ( d , 0 ) , b . enlarge ( CKEDITOR . ENLARGE _ELEMENT ) , f= b ) : f = null , f . deleteContents ( ) ) : ( b . moveToPosition ( f , CKEDITOR . POSITION _BEFORE _START ) , f . remove ( ) ) , b . select ( ) , a . fire ( "saveSnapshot" ) , d = 1 ) : b . collapsed && ( ( A = t . block ) && ( I = A [ c ? "getPrevious" : "getNext" ] ( z ) ) && I . type == CKEDITOR . NODE _ELEMENT && I . is ( "table" ) && b [ c ? "checkStartOfBlock" : "checkEndOfBlock" ] ( ) ? ( a . fire ( "saveSnapshot" ) ,
b [ c ? "checkEndOfBlock" : "checkStartOfBlock" ] ( ) && A . remove ( ) , b [ "moveToElementEdit" + ( c ? "End" : "Start" ) ] ( I ) , b . select ( ) , a . fire ( "saveSnapshot" ) , d = 1 ) : t . blockLimit && t . blockLimit . is ( "td" ) && ( H = t . blockLimit . getAscendant ( "table" ) ) && b . checkBoundaryOfElement ( H , c ? CKEDITOR . START : CKEDITOR . END ) && ( I = H [ c ? "getPrevious" : "getNext" ] ( z ) ) ? ( a . fire ( "saveSnapshot" ) , b [ "moveToElementEdit" + ( c ? "End" : "Start" ) ] ( I ) , b . checkStartOfBlock ( ) && b . checkEndOfBlock ( ) ? I . remove ( ) : b . select ( ) , a . fire ( "saveSnapshot" ) , d = 1 ) : ( H = t . contains ( [ "td" , "th" , "caption" ] ) ) &&
b . checkBoundaryOfElement ( H , c ? CKEDITOR . START : CKEDITOR . END ) && ( d = 1 ) ) } return ! d } } ) ; a . blockless && CKEDITOR . env . ie && CKEDITOR . env . needsBrFiller && this . attachListener ( this , "keyup" , function ( b ) { b . data . getKeystroke ( ) in N && ! this . getFirst ( c ) && ( this . appendBogus ( ) , b = a . createRange ( ) , b . moveToPosition ( this , CKEDITOR . POSITION _AFTER _START ) , b . select ( ) ) } ) ; this . attachListener ( this , "dblclick" , function ( b ) { if ( a . readOnly ) return ! 1 ; b = { element : b . data . getTarget ( ) } ; a . fire ( "doubleclick" , b ) } ) ; CKEDITOR . env . ie && this . attachListener ( this ,
"click" , b ) ; CKEDITOR . env . ie && ! CKEDITOR . env . edge || this . attachListener ( this , "mousedown" , function ( b ) { var c = b . data . getTarget ( ) ; c . is ( "img" , "hr" , "input" , "textarea" , "select" ) && ! c . isReadOnly ( ) && ( a . getSelection ( ) . selectElement ( c ) , c . is ( "input" , "textarea" , "select" ) && b . data . preventDefault ( ) ) } ) ; CKEDITOR . env . edge && this . attachListener ( this , "mouseup" , function ( b ) { ( b = b . data . getTarget ( ) ) && b . is ( "img" ) && ! b . isReadOnly ( ) && a . getSelection ( ) . selectElement ( b ) } ) ; CKEDITOR . env . gecko && this . attachListener ( this , "mouseup" , function ( b ) { if ( 2 ==
b . data . $ . button && ( b = b . data . getTarget ( ) , ! b . getAscendant ( "table" ) && ! b . getOuterHtml ( ) . replace ( L , "" ) ) ) { var c = a . createRange ( ) ; c . moveToElementEditStart ( b ) ; c . select ( ! 0 ) } } ) ; CKEDITOR . env . webkit && ( this . attachListener ( this , "click" , function ( a ) { a . data . getTarget ( ) . is ( "input" , "select" ) && a . data . preventDefault ( ) } ) , this . attachListener ( this , "mouseup" , function ( a ) { a . data . getTarget ( ) . is ( "input" , "textarea" ) && a . data . preventDefault ( ) } ) ) ; CKEDITOR . env . webkit && this . attachListener ( a , "key" , function ( b ) { if ( a . readOnly ) return ! 0 ; var c =
b . data . domEvent . getKey ( ) ; if ( c in l && ( b = a . getSelection ( ) , 0 !== b . getRanges ( ) . length ) ) { var c = 8 == c , d = b . getRanges ( ) [ 0 ] ; b = d . startPath ( ) ; if ( d . collapsed ) a : { var e = b . block ; if ( e && d [ c ? "checkStartOfBlock" : "checkEndOfBlock" ] ( ! 0 ) && d . moveToClosestEditablePosition ( e , ! c ) && d . collapsed ) { if ( d . startContainer . type == CKEDITOR . NODE _ELEMENT ) { var f = d . startContainer . getChild ( d . startOffset - ( c ? 1 : 0 ) ) ; if ( f&& f . type == CKEDITOR . NODE _ELEMENT && f . is ( "hr" ) ) { a . fire ( "saveSnapshot" ) ; f . remove ( ) ; b = ! 0 ; break a } } d = d . startPath ( ) . block ; if ( ! d || d && d . contains ( e ) ) b =
void 0 ; else { a . fire ( "saveSnapshot" ) ; var g; ( g = ( c ? d : e ) . getBogus ( ) ) && g. remove ( ) ; g = a . getSelection ( ) ; f = g . createBookmarks ( ) ; ( c ? e : d ) . moveChildren ( c ? d : e , ! 1 ) ; b . lastElement . mergeSiblings ( ) ; B( e , d , ! c ) ; g . selectBookmarks ( f ) ; b = ! 0 } } else b = ! 1 } else c = d , g = b . block , d = c . endPath ( ) . block , g&& d && ! g . equals ( d ) ? ( a . fire ( "saveSnapshot" ) , ( e = g . getBogus ( ) ) && e . remove ( ) , c . enlarge ( CKEDITOR . ENLARGE _INLINE ) , c . deleteContents ( ) , d . getParent ( ) && ( d . moveChildren ( g , ! 1 ) , b . lastElement . mergeSiblings ( ) , B( g , d , ! 0 ) ) , c = a . getSelection ( ) . getRanges ( ) [ 0 ] ,
b . data . $ . button && ( b = b . data . getTarget ( ) , ! b . getAscendant ( "table" ) && ! b . getOuterHtml ( ) . replace ( M , "" ) ) ) { var c = a . createRange ( ) ; c . moveToElementEditStart ( b ) ; c . select ( ! 0 ) } } ) ; CKEDITOR . env . webkit && ( this . attachListener ( this , "click" , function ( a ) { a . data . getTarget ( ) . is ( "input" , "select" ) && a . data . preventDefault ( ) } ) , this . attachListener ( this , "mouseup" , function ( a ) { a . data . getTarget ( ) . is ( "input" , "textarea" ) && a . data . preventDefault ( ) } ) ) ; CKEDITOR . env . webkit && this . attachListener ( a , "key" , function ( b ) { if ( a . readOnly ) return ! 0 ; var c =
b . data . domEvent . getKey ( ) ; if ( c in N && ( b = a . getSelection ( ) , 0 !== b . getRanges ( ) . length ) ) { var c = 8 == c , d = b . getRanges ( ) [ 0 ] ; b = d . startPath ( ) ; if ( d . collapsed ) a : { var e = b . block ; if ( e && d [ c ? "checkStartOfBlock" : "checkEndOfBlock" ] ( ! 0 ) && d . moveToClosestEditablePosition ( e , ! c ) && d . collapsed ) { if ( d . startContainer . type == CKEDITOR . NODE _ELEMENT ) { var g = d . startContainer . getChild ( d . startOffset - ( c ? 1 : 0 ) ) ; if ( g&& g . type == CKEDITOR . NODE _ELEMENT && g . is ( "hr" ) ) { a . fire ( "saveSnapshot" ) ; g . remove ( ) ; b = ! 0 ; break a } } d = d . startPath ( ) . block ; if ( ! d || d && d . contains ( e ) ) b =
void 0 ; else { a . fire ( "saveSnapshot" ) ; var f; ( f = ( c ? d : e ) . getBogus ( ) ) && f. remove ( ) ; f = a . getSelection ( ) ; g = f . createBookmarks ( ) ; ( c ? e : d ) . moveChildren ( c ? d : e , ! 1 ) ; b . lastElement . mergeSiblings ( ) ; y( e , d , ! c ) ; f . selectBookmarks ( g ) ; b = ! 0 } } else b = ! 1 } else c = d , f = b . block , d = c . endPath ( ) . block , f&& d && ! f . equals ( d ) ? ( a . fire ( "saveSnapshot" ) , ( e = f . getBogus ( ) ) && e . remove ( ) , c . enlarge ( CKEDITOR . ENLARGE _INLINE ) , c . deleteContents ( ) , d . getParent ( ) && ( d . moveChildren ( f , ! 1 ) , b . lastElement . mergeSiblings ( ) , y( f , d , ! 0 ) ) , c = a . getSelection ( ) . getRanges ( ) [ 0 ] ,
c . collapse ( 1 ) , c . optimize ( ) , "" === c . startContainer . getHtml ( ) && c . startContainer . appendBogus ( ) , c . select ( ) , b = ! 0 ) : b = ! 1 ; if ( ! b ) return ; a . getSelection ( ) . scrollIntoView ( ) ; a . fire ( "saveSnapshot" ) ; return ! 1 } } , this , null , 100 ) } } , getUniqueId : function ( ) { var a ; try { this . _ . expandoNumber = a = CKEDITOR . dom . domObject . prototype . getUniqueId . call ( this ) } catch ( b ) { a = this . _ && this . _ . expandoNumber } return a } } , _ : { cleanCustomData : function ( ) { this . removeClass ( "cke_editable" ) ; this . restoreAttrs ( ) ; for ( var a = this . removeCustomData ( "classes" ) ; a &&
a . length ; ) this . removeClass ( a . pop ( ) ) ; if ( ! this . is ( "textarea" ) ) { var a = this . getDocument ( ) , b = a . getHead ( ) ; if ( b . getCustomData ( "stylesheet" ) ) { var c = a . getCustomData ( "stylesheet_ref" ) ; -- c ? a . setCustomData ( "stylesheet_ref" , c ) : ( a . removeCustomData ( "stylesheet_ref" ) , b . removeCustomData ( "stylesheet" ) . remove ( ) ) } } } } } ) ; CKEDITOR . editor . prototype . editable = function ( a ) { var b = this . _ . editable ; if ( b && a ) return 0 ; if ( ! arguments . length ) return b ; a ? b = a instanceof CKEDITOR . editable ? a : new CKEDITOR . editable ( this , a ) : ( b && b . detach ( ) , b =
null ) ; return this . _ . editable = b } ; CKEDITOR . on ( "instanceLoaded" , function ( b ) { var c = b . editor ; c . on ( "insertElement" , function ( a ) { a = a . data ; a . type == CKEDITOR . NODE _ELEMENT && ( a . is ( "input" ) || a . is ( "textarea" ) ) && ( "false" != a . getAttribute ( "contentEditable" ) && a . data ( "cke-editable" , a . hasAttribute ( "contenteditable" ) ? "true" : "1" ) , a . setAttribute ( "contentEditable" , ! 1 ) ) } ) ; c . on ( "selectionChange" , function ( b ) { if ( ! c . readOnly ) { var d = c . getSelection ( ) ; d && ! d . isLocked && ( d = c . checkDirty ( ) , c . fire ( "lockSnapshot" ) , a ( b ) , c . fire ( "unlockSnapshot" ) ,
! d && c . resetDirty ( ) ) } } ) } ) ; CKEDITOR . on ( "instanceCreated" , function ( a ) { var b = a . editor ; b . on ( "mode" , function ( ) { var a = b . editable ( ) ; if ( a && a . isInline ( ) ) { var c = b . title ; a . changeAttr ( "role" , "textbox" ) ; a . changeAttr ( "aria-multiline" , "true" ) ; c && a . changeAttr ( "aria-label" , c ) ; c && a . changeAttr ( "title" , c ) ; var d = b . fire ( "ariaEditorHelpLabel" , { } ) . label ; if ( d && ( c = this . ui . space ( this . elementMode == CKEDITOR . ELEMENT _MODE _INLINE ? "top" : "contents" ) ) ) { var e = CKEDITOR . tools . getNextId ( ) , d = CKEDITOR . dom . element . createFromHtml ( '\x3cspan id\x3d"' +
e + '" class\x3d"cke_voice_label"\x3e' + d + "\x3c/span\x3e" ) ; c . append ( d ) ; a . changeAttr ( "aria-describedby" , e ) } } } ) } ) ; CKEDITOR . addCss ( ".cke_editable{cursor:text}.cke_editable img,.cke_editable input,.cke_editable textarea{cursor:default}" ) ; y = CKEDITOR . dom . walker . whitespaces ( ! 0 ) ; F = CKEDITOR . dom . walker . bookmark ( ! 1 , ! 0 ) ; r = CKEDITOR . dom . walker . empty ( ) ; m = CKEDITOR . dom . walker . bogus ( ) ; L = /(^|<body\b[^>]*>)\s*<(p|div|address|h\d|center|pre)[^>]*>\s*(?:<br[^>]*>| |\u00A0| )?\s*(:?<\/\2>)?\s*(?=$|<\/body>)/gi ; v =
function ( ) { function a ( b ) { return b . type == CKEDITOR . NODE _ELEMENT } function b ( c , d ) { var e , f, g , h , k = [ ] , x = d . range . startContainer ; e = d . range . startPath ( ) ; for ( var x= m [ x . getName ( ) ] , t = 0 , C = c . getChildren ( ) , D = C . count ( ) , I = - 1 , H= - 1 , M = 0 , l = e . contains ( m . $list ) ; t < D ; ++ t ) e = C . getItem ( t ) , a ( e ) ? ( g = e . getName ( ) , l && g in CKEDITOR . dtd . $list ? k = k . concat ( b ( e , d ) ) : ( h= ! ! x [ g ] , "br" != g || ! e . data ( "cke-eol" ) || t&& t != D - 1 || ( M = ( f = t ? k [ t - 1 ] . node : C . getItem ( t + 1 ) ) && ( ! a ( f ) || ! f . is ( "br" ) ) , f = f && a ( f ) && m . $block [ f . getName ( ) ] ) , - 1 != I || h|| ( I = t ) , h || ( H = t ) , k . push ( { isElement : 1 ,
isLineBreak : M , isBlock : e . isBlockBoundary ( ) , hasBlockSibling : f, node : e , name : g , allowed : h } ) , f = M = 0 ) ) : k . push ( { isElement : 0 , node : e , allowed : 1 } ) ; - 1 < I && ( k [ I ] . firstNotAllowed = 1 ) ; - 1 < H&& ( k [ H ] . lastNotAllowed = 1 ) ; return k } function d ( b , c ) { var e = [ ] , f= b . getChildren ( ) , g = f . count ( ) , h , k = 0 , x = m [ c ] , C = ! b . is ( m . $inline ) || b . is ( "br" ) ; for ( C&& e . push ( " " ) ; k < g ; k ++ ) h = f . getItem ( k ) , a ( h ) && ! h . is ( x ) ? e = e . concat ( d ( h , c ) ) : e . push ( h ) ; C && e . push ( " " ) ; return e } function e ( b ) { return a ( b . startContainer ) && b . startContainer . getChild ( b . startOffset - 1 ) } function g ( b ) { return b &&
a ( b ) && ( b . is ( m . $removeEmpty ) || b . is ( "a" ) && ! b . isBlockBoundary ( ) ) } function h ( b , c , d , e ) { var f= b . clone ( ) , g , k ; f . setEndAt ( c , CKEDITOR . POSITION _BEFORE _END ) ; ( g = ( new CKEDITOR . dom . walker ( f ) ) . next ( ) ) && a ( g) && x [ g . getName ( ) ] && ( k = g . getPrevious ( ) ) && a ( k ) && ! k . getParent ( ) . equals ( b . startContainer ) && d . contains ( k) && e . contains ( g ) && g . isIdentical ( k ) && ( g . moveChildren ( k ) , g . remove ( ) , h ( b , c , d , e ) ) } function k ( b , c ) { function d ( b , c ) { if ( c . isBlock && c . isElement && ! c . node . is ( "br" ) && a ( b ) && b . is ( "br" ) ) return b . remove ( ) , 1 } var e = c . endContainer . getChild ( c . endOffset ) ,
f = c . endContainer . getChild ( c . endOffset - 1 ) ; e && d ( e , b [ b . length - 1 ] ) ; f&& d ( f , b [ 0 ] ) && ( c . setEnd ( c . endContainer , c . endOffset - 1 ) , c . collapse ( ) ) } var m= CKEDITOR . dtd , x = { p : 1 , div : 1 , h1 : 1 , h2 : 1 , h3 : 1 , h4 : 1 , h5 : 1 , h6 : 1 , ul : 1 , ol : 1 , li : 1 , pre : 1 , dl : 1 , blockquote : 1 } , H = { p : 1 , div : 1 , h1 : 1 , h2 : 1 , h3 : 1 , h4 : 1 , h5 : 1 , h6 : 1 } , M = CKEDITOR . tools . extend ( { } , m. $inline ) ; delete M . br ; return function ( x , A , Q , w ) { var p = x . editor , r = ! 1 , y ; "unfiltered_html" == A&& ( A = "html" , r = ! 0 ) ; if ( ! w . checkReadOnly ( ) ) { var B = ( new CKEDITOR . dom . elementPath ( w. startContainer , w . root ) ) . blockLimit ||
w. root ; A = { type : A , dontFilter : r , editable : x , editor : p , range : w , blockLimit : B , mergeCandidates : [ ] , zombies : [ ] } ; var r= A . range , B = A . mergeCandidates , u = "html" === A . type , v , S , F , W , K ; "text" == A . type && r . shrink ( CKEDITOR . SHRINK _ELEMENT , ! 0 , ! 1 ) && ( S = CKEDITOR . dom . element . createFromHtml ( "\x3cspan\x3e\x26nbsp;\x3c/span\x3e" , r. document ) , r . insertNode ( S ) , r . setStartAfter ( S ) ) ; F = new CKEDITOR . dom . elementPath ( r. startContainer ) ; A . endPath = W = new CKEDITOR . dom . elementPath ( r. endContainer ) ; if ( ! r . collapsed ) { v = W . block || W . blockLimit ; var Z = r . getCommonAncestor ( ) ;
v&& ! v . equals ( Z ) && ! v . contains ( Z ) && r . checkEndOfBlock ( ) && A . zombies . push ( v ) ; r . deleteContents ( ) } for ( ; ( K = e ( r ) ) && a ( K ) && K . isBlockBoundary ( ) && F. contains ( K ) ; ) r . moveToPosition ( K , CKEDITOR . POSITION _BEFORE _END ) ; h ( r, A . blockLimit , F , W ) ; S && ( r . setEndBefore ( S ) , r . collapse ( ) , S . remove ( ) ) ; S = r . startPath ( ) ; if ( v = S . contains ( g , ! 1 , 1 ) ) y = r . splitElement ( v ) , A . inlineStylesRoot = v , A . inlineStylesPeak = S . lastElement ; S = r . createBookmark ( ) ; u && ( f( v ) , f ( y ) ) ; ( v = S . startNode . getPrevious ( c ) ) && a ( v) && g ( v ) && B . push ( v ) ; ( v = S . startNode . getNext ( c ) ) && a ( v ) &&
g( v ) && B . push ( v ) ; for ( v = S . startNode ; ( v = v . getParent ( ) ) && g ( v ) ; ) B . push ( v ) ; r . moveToBookmark ( S ) ; y = x . getHtml ( ) ; y = "" === y || y . match ( L) ; p . enterMode === CKEDITOR . ENTER _DIV && y && ( ( p= x . getFirst ( ) ) && p . remove ( ) , w . setStartAt ( x , CKEDITOR . POSITION _AFTER _START ) , w . collapse ( ! 0 ) ) ; if ( x= Q ) { x = A . range ; if ( "text" == A . type && A . inlineStylesRoot ) { w = A . inlineStylesPeak ; p = w . getDocument ( ) . createText ( "{cke-peak}" ) ; for ( y = A . inlineStylesRoot . getParent ( ) ; ! w. equals ( y ) ; ) p = p . appendTo ( w . clone ( ) ) , w = w . getParent ( ) ; Q = p . getOuterHtml ( ) . split ( "{cke-peak}" ) . join ( Q) } w =
A . blockLimit . getName ( ) ; if ( /^\s+|\s+$/ . test ( Q ) && "span" in CKEDITOR . dtd [ w ] ) { var J = '\x3cspan data-cke-marker\x3d"1"\x3e\x26nbsp;\x3c/span\x3e' ; Q= J + Q + J } Q = A . editor . dataProcessor . toHtml ( Q , { context : null , fixForBody : ! 1 , protectedWhitespaces : ! ! J , dontFilter : A. dontFilter , filter : A . editor . activeFilter , enterMode : A . editor . activeEnterMode } ) ; w = x . document . createElement ( "body" ) ; w. setHtml ( Q ) ; J && ( w . getFirst ( ) . remove ( ) , w . getLast ( ) . remove ( ) ) ; if ( ( J = x . startPath ( ) . block ) && ( 1 != J . getChildCount ( ) || ! J . getBogus ( ) ) ) a : { var P ; if ( 1 ==
w . getChildCount ( ) && a ( P = w . getFirst ( ) ) && P . is ( H ) && ! P . hasAttribute ( "contenteditable" ) ) { J = P . getElementsByTag ( "*" ) ; x = 0 ; for ( y = J . count ( ) ; x< y ; x ++ ) if ( p = J . getItem ( x ) , ! p . is ( M ) ) break a ; P . moveChildren ( P . getParent ( 1 ) ) ; P . remove ( ) } } A. dataWrapper = w ; x = Q } if ( x ) { P = A . range ; x = P . document ; w = A . blockLimit ; y = 0 ; var G , J = [ ] , ca , O ; Q = S = 0 ; var U , p = P . startContainer ; K = A . endPath . elements [ 0 ] ; var R, r = K . getPosition ( p ) , B = ! ! K . getCommonAncestor ( p ) && r != CKEDITOR . POSITION _IDENTICAL && ! ( r & CKEDITOR . POSITION _CONTAINS + CKEDITOR . POSITION _IS _CONTAINED ) ,
p= b ( A . dataWrapper , A ) ; for ( A . editor . enterMode !== CKEDITOR . ENTER _BR && k ( p, P ) ; y < p . length ; y ++ ) { r = p [ y ] ; if ( u = r . isLineBreak ) u = P , v = w , W = F = void 0 , r . hasBlockSibling ? u = 1 : ( F = u . startContainer . getAscendant ( m . $block , 1 ) ) && F . is ( { div : 1 , p : 1 } ) ? ( W= F . getPosition ( v ) , W == CKEDITOR . POSITION _IDENTICAL || W == CKEDITOR . POSITION _CONTAINS ? u = 0 : ( v= u . splitElement ( F ) , u . moveToPosition ( v , CKEDITOR . POSITION _AFTER _START ) , u = 1 ) ) : u = 0 ; if ( u ) Q = 0 < y ; else { u = P . startPath ( ) ; ! r. isBlock && l ( A . editor , u . block , u . blockLimit ) && ( O = q( A . editor ) ) && ( O = x . createElement ( O ) ,
O . appendBogus ( ) , P . insertNode ( O ) , CKEDITOR . env . needsBrFiller && ( G= O . getBogus ( ) ) && G . remove ( ) , P . moveToPosition ( O , CKEDITOR . POSITION _BEFORE _END ) ) ; if ( ( u = P . startPath ( ) . block ) && ! u . equals ( ca ) ) { if ( G= u . getBogus ( ) ) G . remove ( ) , J . push ( u ) ; ca = u } r. firstNotAllowed && ( S = 1 ) ; if ( S && r . isElement ) { u = P . startContainer ; for ( v= null ; u && ! m [ u . getName ( ) ] [ r . name ] ; ) { if ( u . equals ( w) ) { u = null ; break } v = u ; u = u . getParent ( ) } if ( u ) v&& ( U = P . splitElement ( v ) , A . zombies . push ( U ) , A . zombies . push ( v ) ) ; else { v = w . getName ( ) ; R = ! y ; u = y == p . length - 1 ; v = d ( r . node , v ) ; F = [ ] ;
W= v . length ; for ( var Z = 0 , Y = void 0 , da = 0 , fa = - 1 ; Z < W; Z ++ ) Y = v [ Z ] , " " == Y ? ( da || R && ! Z || ( F . push ( new CKEDITOR . dom . text ( " " ) ) , fa = F . length ) , da = 1 ) : ( F. push ( Y ) , da = 0 ) ; u && fa == F. length && F . pop ( ) ; R = F } } if ( R ) { for ( ; u = R . pop ( ) ; ) P . insertNode ( u ) ; R= 0 } else P . insertNode ( r . node ) ; r . lastNotAllowed && y < p . length - 1 && ( ( U = B ? K : U ) && P . setEndAt ( U , CKEDITOR . POSITION _AFTER _START ) , S = 0 ) ; P . collapse ( ) } } 1 != p. length ? G = ! 1 : ( G = p [ 0 ] , G = G . isElement && "false" == G . node . getAttribute ( "contenteditable" ) ) ; G&& ( Q = ! 0 , u = p [ 0 ] . node , P . setStartAt ( u , CKEDITOR . POSITION _BEFORE _START ) ,
P . setEndAt ( u , CKEDITOR . POSITION _AFTER _END ) ) ; A. dontMoveCaret = Q ; A . bogusNeededBlocks = J } G = A . range ; var ba ; R = A . bogusNeededBlocks ; for ( ca = G . createBookmark ( ) ; O = A . zombies . pop ( ) ; ) O . getParent ( ) && ( U= G . clone ( ) , U . moveToElementEditStart ( O ) , U . removeEmptyBlocksAtEnd ( ) ) ; if ( R) for ( ; O = R . pop ( ) ; ) CKEDITOR . env . needsBrFiller ? O . appendBogus ( ) : O . append ( G . document . createText ( " " ) ) ; for ( ; O = A . mergeCandidates . pop ( ) ; ) O . mergeSiblings ( ) ; CKEDITOR . env . webkit && G. startPath ( ) && ( O = G . startPath ( ) , O . block ? O . block . $ . normalize ( ) : O . blockLimit && O . blockLimit . $ . normalize ( ) ) ;
G . moveToBookmark ( ca ) ; if ( ! A . dontMoveCaret ) { for ( O = e ( G ) ; O && a ( O ) && ! O . is ( m . $empty ) ; ) { if ( O . isBlockBoundary ( ) ) G . moveToPosition ( O , CKEDITOR . POSITION _BEFORE _END ) ; else { if ( g ( O ) && O . getHtml ( ) . match ( /(\s| )$/g ) ) { ba = null ; break } ba = G . clone ( ) ; ba . moveToPosition ( O , CKEDITOR . POSITION _BEFORE _END ) } O = O . getLast ( c ) } ba && G . moveToRange ( ba ) } } } } ( ) ; J = function ( ) { function a ( b ) { b = new CKEDITOR . dom . walker ( b ) ; b . guard = function ( a , b ) { if ( b ) return ! 1 ; if ( a . type == CKEDITOR . NODE _ELEMENT ) return a . is ( CKEDITOR . dtd . $tableContent ) } ; b . evaluator = function ( a ) { return a . type ==
CKEDITOR . NODE _ELEMENT } ; return b } function b ( a , c , d ) { c = a . getDocument ( ) . createElement ( c ) ; a . append ( c , d ) ; return c } function c ( a ) { var b = a . count ( ) , d ; for ( b ; 0 < b -- ; ) d = a . getItem ( b ) , CKEDITOR . tools . trim ( d . getHtml ( ) ) || ( d . appendBogus ( ) , CKEDITOR . env . ie && 9 > CKEDITOR . env . version && d . getChildCount ( ) && d . getFirst ( ) . remove ( ) ) } return function ( d ) { var e = d . startContainer , f = e . getAscendant ( "table" , 1 ) , g= ! 1 ; c ( f . getElementsByTag ( "td" ) ) ; c ( f. getElementsByTag ( "th" ) ) ; f = d . clone ( ) ; f . setStart ( e , 0 ) ; f = a ( f ) . lastBackward ( ) ; f || ( f = d . clone ( ) , f . setEndAt ( e ,
CKEDITOR . POSITION _BEFORE _END ) , f= a ( f ) . lastForward ( ) , g = ! 0 ) ; f || ( f = e ) ; f . is ( "table" ) ? ( d . setStartAt ( f , CKEDITOR . POSITION _BEFORE _START ) , d . collapse ( ! 0 ) , f. remove ( ) ) : ( f . is ( { tbody : 1 , thead : 1 , tfoot : 1 } ) && ( f= b ( f , "tr" , g ) ) , f . is ( "tr" ) && ( f = b ( f , f . getParent ( ) . is ( "thead" ) ? "th" : "td" , g) ) , ( e = f . getBogus ( ) ) && e . remove ( ) , d . moveToPosition ( f, g ? CKEDITOR . POSITION _AFTER _START : CKEDITOR . POSITION _BEFORE _END ) ) } } ( ) ; G = function ( ) { function a ( b ) { b = new CKEDITOR . dom . walker ( b ) ; b . guard = function ( a , b ) { if ( b ) return ! 1 ; if ( a . type == CKEDITOR . NODE _ELEMENT ) return a . is ( CKEDITOR . dtd . $list ) ||
e + '" class\x3d"cke_voice_label"\x3e' + d + "\x3c/span\x3e" ) ; c . append ( d ) ; a . changeAttr ( "aria-describedby" , e ) } } } ) } ) ; CKEDITOR . addCss ( ".cke_editable{cursor:text}.cke_editable img,.cke_editable input,.cke_editable textarea{cursor:default}" ) ; z = CKEDITOR . dom . walker . whitespaces ( ! 0 ) ; G = CKEDITOR . dom . walker . bookmark ( ! 1 , ! 0 ) ; v = CKEDITOR . dom . walker . empty ( ) ; m = CKEDITOR . dom . walker . bogus ( ) ; M = /(^|<body\b[^>]*>)\s*<(p|div|address|h\d|center|pre)[^>]*>\s*(?:<br[^>]*>| |\u00A0| )?\s*(:?<\/\2>)?\s*(?=$|<\/body>)/gi ; w =
function ( ) { function a ( b ) { return b . type == CKEDITOR . NODE _ELEMENT } function b ( c , d ) { var e , g, f , r , h = [ ] , t = d . range . startContainer ; e = d . range . startPath ( ) ; for ( var t= L [ t . getName ( ) ] , k = 0 , A = c . getChildren ( ) , H = A . count ( ) , I = - 1 , E= - 1 , S = 0 , N = e . contains ( L . $list ) ; k < H ; ++ k ) e = A . getItem ( k ) , a ( e ) ? ( f = e . getName ( ) , N && f in CKEDITOR . dtd . $list ? h = h . concat ( b ( e , d ) ) : ( r= ! ! t [ f ] , "br" != f || ! e . data ( "cke-eol" ) || k&& k != H - 1 || ( S = ( g = k ? h [ k - 1 ] . node : A . getItem ( k + 1 ) ) && ( ! a ( g ) || ! g . is ( "br" ) ) , g = g && a ( g ) && L . $block [ g . getName ( ) ] ) , - 1 != I || r|| ( I = k ) , r || ( E = k ) , h . push ( { isElement : 1 ,
isLineBreak : S , isBlock : e . isBlockBoundary ( ) , hasBlockSibling : g, node : e , name : f , allowed : r } ) , g = S = 0 ) ) : h . push ( { isElement : 0 , node : e , allowed : 1 } ) ; - 1 < I && ( h [ I ] . firstNotAllowed = 1 ) ; - 1 < E&& ( h [ E ] . lastNotAllowed = 1 ) ; return h } function d ( b , c ) { var e = [ ] , g= b . getChildren ( ) , f = g . count ( ) , h , r = 0 , k = L [ c ] , A = ! b . is ( L . $inline ) || b . is ( "br" ) ; for ( A&& e . push ( " " ) ; r < f ; r ++ ) h = g . getItem ( r ) , a ( h ) && ! h . is ( k ) ? e = e . concat ( d ( h , c ) ) : e . push ( h ) ; A && e . push ( " " ) ; return e } function e ( b ) { return a ( b . startContainer ) && b . startContainer . getChild ( b . startOffset - 1 ) } function f ( b ) { return b &&
a ( b ) && ( b . is ( L . $removeEmpty ) || b . is ( "a" ) && ! b . isBlockBoundary ( ) ) } function h ( b , c , d , e ) { var g= b . clone ( ) , f , t ; g . setEndAt ( c , CKEDITOR . POSITION _BEFORE _END ) ; ( f = ( new CKEDITOR . dom . walker ( g ) ) . next ( ) ) && a ( f) && r [ f . getName ( ) ] && ( t = f . getPrevious ( ) ) && a ( t ) && ! t . getParent ( ) . equals ( b . startContainer ) && d . contains ( t) && e . contains ( f ) && f . isIdentical ( t ) && ( f . moveChildren ( t ) , f . remove ( ) , h ( b , c , d , e ) ) } function k ( b , c ) { function d ( b , c ) { if ( c . isBlock && c . isElement && ! c . node . is ( "br" ) && a ( b ) && b . is ( "br" ) ) return b . remove ( ) , 1 } var e = c . endContainer . getChild ( c . endOffset ) ,
g = c . endContainer . getChild ( c . endOffset - 1 ) ; e && d ( e , b [ b . length - 1 ] ) ; g&& d ( g , b [ 0 ] ) && ( c . setEnd ( c . endContainer , c . endOffset - 1 ) , c . collapse ( ) ) } var L= CKEDITOR . dtd , r = { p : 1 , div : 1 , h1 : 1 , h2 : 1 , h3 : 1 , h4 : 1 , h5 : 1 , h6 : 1 , ul : 1 , ol : 1 , li : 1 , pre : 1 , dl : 1 , blockquote : 1 } , E = { p : 1 , div : 1 , h1 : 1 , h2 : 1 , h3 : 1 , h4 : 1 , h5 : 1 , h6 : 1 } , S = CKEDITOR . tools . extend ( { } , L. $inline ) ; delete S . br ; return function ( r , C , m , q ) { var x = r . editor , v = ! 1 , y ; "unfiltered_html" == C&& ( C = "html" , v = ! 0 ) ; if ( ! q . checkReadOnly ( ) ) { var z = ( new CKEDITOR . dom . elementPath ( q. startContainer , q . root ) ) . blockLimit ||
q. root ; C = { type : C , dontFilter : v , editable : r , editor : x , range : q , blockLimit : z , mergeCandidates : [ ] , zombies : [ ] } ; var v= C . range , z = C . mergeCandidates , u = "html" === C . type , w , R , G , V , K ; "text" == C . type && v . shrink ( CKEDITOR . SHRINK _ELEMENT , ! 0 , ! 1 ) && ( R = CKEDITOR . dom . element . createFromHtml ( "\x3cspan\x3e\x26nbsp;\x3c/span\x3e" , v. document ) , v . insertNode ( R ) , v . setStartAfter ( R ) ) ; G = new CKEDITOR . dom . elementPath ( v. startContainer ) ; C . endPath = V = new CKEDITOR . dom . elementPath ( v. endContainer ) ; if ( ! v . collapsed ) { w = V . block || V . blockLimit ; var Z = v . getCommonAncestor ( ) ;
w&& ! w . equals ( Z ) && ! w . contains ( Z ) && v . checkEndOfBlock ( ) && C . zombies . push ( w ) ; v . deleteContents ( ) } for ( ; ( K = e ( v ) ) && a ( K ) && K . isBlockBoundary ( ) && G. contains ( K ) ; ) v . moveToPosition ( K , CKEDITOR . POSITION _BEFORE _END ) ; h ( v, C . blockLimit , G , V ) ; R && ( v . setEndBefore ( R ) , v . collapse ( ) , R . remove ( ) ) ; R = v . startPath ( ) ; if ( w = R . contains ( f , ! 1 , 1 ) ) y = v . splitElement ( w ) , C . inlineStylesRoot = w , C . inlineStylesPeak = R . lastElement ; R = v . createBookmark ( ) ; u && ( g( w ) , g ( y ) ) ; ( w = R . startNode . getPrevious ( c ) ) && a ( w) && f ( w ) && z . push ( w ) ; ( w = R . startNode . getNext ( c ) ) && a ( w ) &&
f( w ) && z . push ( w ) ; for ( w = R . startNode ; ( w = w . getParent ( ) ) && f ( w ) ; ) z . push ( w ) ; v . moveToBookmark ( R ) ; y = r . getHtml ( ) ; y = "" === y || y . match ( M) ; x . enterMode === CKEDITOR . ENTER _DIV && y && ( ( x= r . getFirst ( ) ) && x . remove ( ) , q . setStartAt ( r , CKEDITOR . POSITION _AFTER _START ) , q . collapse ( ! 0 ) ) ; if ( r= m ) { r = C . range ; if ( "text" == C . type && C . inlineStylesRoot ) { q = C . inlineStylesPeak ; x = q . getDocument ( ) . createText ( "{cke-peak}" ) ; for ( y = C . inlineStylesRoot . getParent ( ) ; ! q. equals ( y ) ; ) x = x . appendTo ( q . clone ( ) ) , q = q . getParent ( ) ; m = x . getOuterHtml ( ) . split ( "{cke-peak}" ) . join ( m) } q =
C . blockLimit . getName ( ) ; if ( /^\s+|\s+$/ . test ( m ) && "span" in CKEDITOR . dtd [ q ] ) { var J = '\x3cspan data-cke-marker\x3d"1"\x3e\x26nbsp;\x3c/span\x3e' ; m= J + m + J } m = C . editor . dataProcessor . toHtml ( m , { context : null , fixForBody : ! 1 , protectedWhitespaces : ! ! J , dontFilter : C. dontFilter , filter : C . editor . activeFilter , enterMode : C . editor . activeEnterMode } ) ; q = r . document . createElement ( "body" ) ; q. setHtml ( m ) ; J && ( q . getFirst ( ) . remove ( ) , q . getLast ( ) . remove ( ) ) ; if ( ( J = r . startPath ( ) . block ) && ( 1 != J . getChildCount ( ) || ! J . getBogus ( ) ) ) a : { var P ; if ( 1 ==
q . getChildCount ( ) && a ( P = q . getFirst ( ) ) && P . is ( E ) && ! P . hasAttribute ( "contenteditable" ) ) { J = P . getElementsByTag ( "*" ) ; r = 0 ; for ( y = J . count ( ) ; r< y ; r ++ ) if ( x = J . getItem ( r ) , ! x . is ( S ) ) break a ; P . moveChildren ( P . getParent ( 1 ) ) ; P . remove ( ) } } C. dataWrapper = q ; r = m } if ( r ) { P = C . range ; r = P . document ; q = C . blockLimit ; y = 0 ; var F , J = [ ] , ca , O ; m = R = 0 ; var T , x = P . startContainer ; K = C . endPath . elements [ 0 ] ; var Q, v = K . getPosition ( x ) , z = ! ! K . getCommonAncestor ( x ) && v != CKEDITOR . POSITION _IDENTICAL && ! ( v & CKEDITOR . POSITION _CONTAINS + CKEDITOR . POSITION _IS _CONTAINED ) ,
x= b ( C . dataWrapper , C ) ; for ( C . editor . enterMode !== CKEDITOR . ENTER _BR && k ( x, P ) ; y < x . length ; y ++ ) { v = x [ y ] ; if ( u = v . isLineBreak ) u = P , w = q , V = G = void 0 , v . hasBlockSibling ? u = 1 : ( G = u . startContainer . getAscendant ( L . $block , 1 ) ) && G . is ( { div : 1 , p : 1 } ) ? ( V= G . getPosition ( w ) , V == CKEDITOR . POSITION _IDENTICAL || V == CKEDITOR . POSITION _CONTAINS ? u = 0 : ( w= u . splitElement ( G ) , u . moveToPosition ( w , CKEDITOR . POSITION _AFTER _START ) , u = 1 ) ) : u = 0 ; if ( u ) m = 0 < y ; else { u = P . startPath ( ) ; ! v. isBlock && n ( C . editor , u . block , u . blockLimit ) && ( O = l( C . editor ) ) && ( O = r . createElement ( O ) ,
O . appendBogus ( ) , P . insertNode ( O ) , CKEDITOR . env . needsBrFiller && ( F= O . getBogus ( ) ) && F . remove ( ) , P . moveToPosition ( O , CKEDITOR . POSITION _BEFORE _END ) ) ; if ( ( u = P . startPath ( ) . block ) && ! u . equals ( ca ) ) { if ( F= u . getBogus ( ) ) F . remove ( ) , J . push ( u ) ; ca = u } v. firstNotAllowed && ( R = 1 ) ; if ( R && v . isElement ) { u = P . startContainer ; for ( w= null ; u && ! L [ u . getName ( ) ] [ v . name ] ; ) { if ( u . equals ( q) ) { u = null ; break } w = u ; u = u . getParent ( ) } if ( u ) w&& ( T = P . splitElement ( w ) , C . zombies . push ( T ) , C . zombies . push ( w ) ) ; else { w = q . getName ( ) ; Q = ! y ; u = y == x . length - 1 ; w = d ( v . node , w ) ; G = [ ] ;
V= w . length ; for ( var Z = 0 , X = void 0 , da = 0 , fa = - 1 ; Z < V; Z ++ ) X = w [ Z ] , " " == X ? ( da || Q && ! Z || ( G . push ( new CKEDITOR . dom . text ( " " ) ) , fa = G . length ) , da = 1 ) : ( G. push ( X ) , da = 0 ) ; u && fa == G. length && G . pop ( ) ; Q = G } } if ( Q ) { for ( ; u = Q . pop ( ) ; ) P . insertNode ( u ) ; Q= 0 } else P . insertNode ( v . node ) ; v . lastNotAllowed && y < x . length - 1 && ( ( T = z ? K : T ) && P . setEndAt ( T , CKEDITOR . POSITION _AFTER _START ) , R = 0 ) ; P . collapse ( ) } } 1 != x. length ? F = ! 1 : ( F = x [ 0 ] , F = F . isElement && "false" == F . node . getAttribute ( "contenteditable" ) ) ; F&& ( m = ! 0 , u = x [ 0 ] . node , P . setStartAt ( u , CKEDITOR . POSITION _BEFORE _START ) ,
P . setEndAt ( u , CKEDITOR . POSITION _AFTER _END ) ) ; C. dontMoveCaret = m ; C . bogusNeededBlocks = J } F = C . range ; var ba ; Q = C . bogusNeededBlocks ; for ( ca = F . createBookmark ( ) ; O = C . zombies . pop ( ) ; ) O . getParent ( ) && ( T= F . clone ( ) , T . moveToElementEditStart ( O ) , T . removeEmptyBlocksAtEnd ( ) ) ; if ( Q) for ( ; O = Q . pop ( ) ; ) CKEDITOR . env . needsBrFiller ? O . appendBogus ( ) : O . append ( F . document . createText ( " " ) ) ; for ( ; O = C . mergeCandidates . pop ( ) ; ) O . mergeSiblings ( ) ; CKEDITOR . env . webkit && F. startPath ( ) && ( O = F . startPath ( ) , O . block ? O . block . $ . normalize ( ) : O . blockLimit && O . blockLimit . $ . normalize ( ) ) ;
F . moveToBookmark ( ca ) ; if ( ! C . dontMoveCaret ) { for ( O = e ( F ) ; O && a ( O ) && ! O . is ( L . $empty ) ; ) { if ( O . isBlockBoundary ( ) ) F . moveToPosition ( O , CKEDITOR . POSITION _BEFORE _END ) ; else { if ( f ( O ) && O . getHtml ( ) . match ( /(\s| )$/g ) ) { ba = null ; break } ba = F . clone ( ) ; ba . moveToPosition ( O , CKEDITOR . POSITION _BEFORE _END ) } O = O . getLast ( c ) } ba && F . moveToRange ( ba ) } } } } ( ) ; J = function ( ) { function a ( b ) { b = new CKEDITOR . dom . walker ( b ) ; b . guard = function ( a , b ) { if ( b ) return ! 1 ; if ( a . type == CKEDITOR . NODE _ELEMENT ) return a . is ( CKEDITOR . dtd . $tableContent ) } ; b . evaluator = function ( a ) { return a . type ==
CKEDITOR . NODE _ELEMENT } ; return b } function b ( a , c , d ) { c = a . getDocument ( ) . createElement ( c ) ; a . append ( c , d ) ; return c } function c ( a ) { var b = a . count ( ) , d ; for ( b ; 0 < b -- ; ) d = a . getItem ( b ) , CKEDITOR . tools . trim ( d . getHtml ( ) ) || ( d . appendBogus ( ) , CKEDITOR . env . ie && 9 > CKEDITOR . env . version && d . getChildCount ( ) && d . getFirst ( ) . remove ( ) ) } return function ( d ) { var e = d . startContainer , g = e . getAscendant ( "table" , 1 ) , f= ! 1 ; c ( g . getElementsByTag ( "td" ) ) ; c ( g. getElementsByTag ( "th" ) ) ; g = d . clone ( ) ; g . setStart ( e , 0 ) ; g = a ( g ) . lastBackward ( ) ; g || ( g = d . clone ( ) , g . setEndAt ( e ,
CKEDITOR . POSITION _BEFORE _END ) , g= a ( g ) . lastForward ( ) , f = ! 0 ) ; g || ( g = e ) ; g . is ( "table" ) ? ( d . setStartAt ( g , CKEDITOR . POSITION _BEFORE _START ) , d . collapse ( ! 0 ) , g. remove ( ) ) : ( g . is ( { tbody : 1 , thead : 1 , tfoot : 1 } ) && ( g= b ( g , "tr" , f ) ) , g . is ( "tr" ) && ( g = b ( g , g . getParent ( ) . is ( "thead" ) ? "th" : "td" , f) ) , ( e = g . getBogus ( ) ) && e . remove ( ) , d . moveToPosition ( g, f ? CKEDITOR . POSITION _AFTER _START : CKEDITOR . POSITION _BEFORE _END ) ) } } ( ) ; F = function ( ) { function a ( b ) { b = new CKEDITOR . dom . walker ( b ) ; b . guard = function ( a , b ) { if ( b ) return ! 1 ; if ( a . type == CKEDITOR . NODE _ELEMENT ) return a . is ( CKEDITOR . dtd . $list ) ||
a . is ( CKEDITOR . dtd . $listItem ) } ; b . evaluator = function ( a ) { return a . type == CKEDITOR . NODE _ELEMENT && a . is ( CKEDITOR . dtd . $listItem ) } ; return b } return function ( b ) { var c = b . startContainer , d = ! 1 , e ; e = b . clone ( ) ; e . setStart ( c , 0 ) ; e = a ( e ) . lastBackward ( ) ; e || ( e = b . clone ( ) , e . setEndAt ( c , CKEDITOR . POSITION _BEFORE _END ) , e = a ( e ) . lastForward ( ) , d = ! 0 ) ; e || ( e = c ) ; e . is ( CKEDITOR . dtd . $list ) ? ( b . setStartAt ( e , CKEDITOR . POSITION _BEFORE _START ) , b . collapse ( ! 0 ) , e . remove ( ) ) : ( ( c = e . getBogus ( ) ) && c . remove ( ) , b . moveToPosition ( e , d ? CKEDITOR . POSITION _AFTER _START :
CKEDITOR . POSITION _BEFORE _END ) , b . select ( ) ) } } ( ) ; p = { eol : { detect : function ( a , b ) { var c = a . range , d = c . clone ( ) , e = c . clone ( ) , f = new CKEDITOR . dom . elementPath ( c . startContainer , b ) , g = new CKEDITOR . dom . elementPath ( c . endContainer , b ) ; d . collapse ( 1 ) ; e . collapse ( ) ; f . block && d . checkBoundaryOfElement ( f . block , CKEDITOR . END ) && ( c . setStartAfter ( f . block ) , a . prependEolBr = 1 ) ; g . block && e . checkBoundaryOfElement ( g . block , CKEDITOR . START ) && ( c . setEndBefore ( g . block ) , a . appendEolBr = 1 ) } , fix : function ( a , b ) { var c = b . getDocument ( ) , d ; a . appendEolBr && ( d =
this . createEolBr ( c ) , a . fragment . append ( d ) ) ; ! a . prependEolBr || d && ! d . getPrevious ( ) || a . fragment . append ( this . createEolBr ( c ) , 1 ) } , createEolBr : function ( a ) { return a . createElement ( "br" , { attributes : { "data-cke-eol" : 1 } } ) } } , bogus : { exclude : function ( a ) { var b = a . range . getBoundaryNodes ( ) , c = b . startNode , b = b . endNode ; ! b || ! m ( b ) || c && c . equals ( b ) || a . range . setEndBefore ( b ) } } , tree : { rebuild : function ( a , b ) { var c = a . range , d = c . getCommonAncestor ( ) , e = new CKEDITOR . dom . elementPath ( d , b ) , f = new CKEDITOR . dom . elementPath ( c . startContainer , b ) ,
c = new CKEDITOR . dom . elementPath ( c . endContainer , b ) , g ; d . type == CKEDITOR . NODE _TEXT && ( d = d . getParent ( ) ) ; if ( e . blockLimit . is ( { tr : 1 , table : 1 } ) ) { var h = e . contains ( "table" ) . getParent ( ) ; g = function ( a ) { return ! a . equals ( h ) } } else if ( e . block && e . block . is ( CKEDITOR . dtd . $listItem ) && ( f= f . contains ( CKEDITOR . dtd . $list ) , c = c . contains ( CKEDITOR . dtd . $list ) , ! f. equals ( c ) ) ) { var k = e . contains ( CKEDITOR . dtd . $list ) . getParent ( ) ; g = function ( a ) { return ! a . equals ( k) } } g || ( g = function ( a ) { return ! a . equals ( e . block ) && ! a . equals ( e . blockLimit ) } ) ; this . rebuildFragment ( a ,
b , d , g ) } , rebuildFragment : function ( a , b , c , d ) { for ( var e ; c && ! c . equals ( b ) && d ( c ) ; ) e = c . clone ( 0 , 1 ) , a . fragment . appendTo ( e ) , a . fragment = e , c = c . getParent ( ) } } , cell : { shrink : function ( a ) { a = a . range ; var b = a . startContainer , c = a . endContainer , d = a . startOffset , e = a . endOffset ; b . type == CKEDITOR . NODE _ELEMENT && b . equals ( c ) && b . is ( "tr" ) && ++ d == e && a . shrink ( CKEDITOR . SHRINK _TEXT ) } } } ; u = function ( ) { function a ( b , c ) { var d = b . getParent ( ) ; if ( d . is ( CKEDITOR . dtd . $inline ) ) b [ c ? "insertBefore" : "insertAfter" ] ( d ) } function b ( c , d , e ) { a ( d ) ; a ( e , 1 ) ; for ( var f; f =
e . getNext ( ) ; ) f. insertAfter ( d ) , d = f ; r ( c ) && c . remove ( ) } function c ( a , b ) { var d = new CKEDITOR . dom . range ( a ) ; d . setStartAfter ( b . startNode ) ; d . setEndBefore ( b . endNode ) ; return d } return { list : { detectMerge : function ( a , b ) { var d = c ( b , a . bookmark ) , e = d . startPath ( ) , f= d . endPath ( ) , g = e . contains ( CKEDITOR . dtd . $list ) , h = f . contains ( CKEDITOR . dtd . $list ) ; a . mergeList = g&& h && g . getParent ( ) . equals ( h . getParent ( ) ) && ! g . equals ( h ) ; a . mergeListItems = e . block && f . block && e . block . is ( CKEDITOR . dtd . $listItem ) && f . block . is ( CKEDITOR . dtd . $listItem ) ; if ( a . mergeList ||
a . mergeListItems ) d = d . clone ( ) , d . setStartBefore ( a . bookmark . startNode ) , d . setEndAfter ( a . bookmark . endNode ) , a . mergeListBookmark = d . createBookmark ( ) } , merge : function ( a , c ) { if ( a . mergeListBookmark ) { var d = a . mergeListBookmark . startNode , e = a . mergeListBookmark . endNode , f = new CKEDITOR . dom . elementPath ( d , c ) , g = new CKEDITOR . dom . elementPath ( e , c ) ; if ( a . mergeList ) { var h = f . contains ( CKEDITOR . dtd . $list ) , k = g . contains ( CKEDITOR . dtd . $list ) ; h . equals ( k ) || ( k . moveChildren ( h ) , k . remove ( ) ) } a . mergeListItems && ( f= f . contains ( CKEDITOR . dtd . $listItem ) ,
g= g . contains ( CKEDITOR . dtd . $listItem ) , f. equals ( g ) || b ( g , d , e ) ) ; d . remove ( ) ; e . remove ( ) } } } , block : { detectMerge : function ( a , b ) { if ( ! a . tableContentsRanges && ! a . mergeListBookmark ) { var c = new CKEDITOR . dom . range ( b ) ; c . setStartBefore ( a . bookmark . startNode ) ; c . setEndAfter ( a . bookmark . endNode ) ; a . mergeBlockBookmark = c . createBookmark ( ) } } , merge : function ( a , c ) { if ( a . mergeBlockBookmark && ! a . purgeTableBookmark ) { var d = a . mergeBlockBookmark . startNode , e = a . mergeBlockBookmark . endNode , f = new CKEDITOR . dom . elementPath ( d , c ) , g = new CKEDITOR . dom . elementPath ( e ,
c ) , f= f . block , g = g . block ; f && g && ! f . equals ( g ) && b ( g , d , e ) ; d . remove ( ) ; e . remove ( ) } } } , table : function ( ) { function a ( c ) { var e = [ ] , f, g = new CKEDITOR . dom . walker ( c ) , h = c . startPath ( ) . contains ( d ) , k = c . endPath ( ) . contains ( d ) , t = { } ; g. guard = function ( a , g ) { if ( a . type == CKEDITOR . NODE _ELEMENT ) { var H= "visited_" + ( g ? "out" : "in" ) ; if ( a . getCustomData ( H ) ) return ; CKEDITOR . dom . element . setMarker ( t , a , H, 1 ) } if ( g && h && a . equals ( h ) ) f= c . clone ( ) , f . setEndAt ( h , CKEDITOR . POSITION _BEFORE _END ) , e . push ( f) ; else if ( ! g && k && a . equals ( k ) ) f= c . clone ( ) , f . setStartAt ( k ,
CKEDITOR . POSITION _AFTER _START ) , e . push ( f) ; else { if ( H = ! g ) H = a . type == CKEDITOR . NODE _ELEMENT && a . is ( d ) && ( ! h || b ( a , h ) ) && ( ! k || b ( a , k ) ) ; if ( ! H&& ( H = g ) ) if ( a . is ( d ) ) var H = h && h . getAscendant ( "table" , ! 0 ) , D = k && k . getAscendant ( "table" , ! 0 ) , l = a . getAscendant ( "table" , ! 0 ) , H= H && H . contains ( l ) || D && D . contains ( l ) ; else H = void 0 ; H && ( f = c . clone ( ) , f . selectNodeContents ( a ) , e . push ( f) ) } } ; g . lastForward ( ) ; CKEDITOR . dom . element . clearAllMarkers ( t ) ; return e } function b ( a , c ) { var d = CKEDITOR . POSITION _CONTAINS + CKEDITOR . POSITION _IS _CONTAINED , e = a . getPosition ( c ) ;
return e === CKEDITOR . POSITION _IDENTICAL ? ! 1 : 0 === ( e & d ) } var d = { td : 1 , th : 1 , caption : 1 } ; return { detectPurge : function ( a ) { var b = a . range , c = b . clone ( ) ; c . enlarge ( CKEDITOR . ENLARGE _ELEMENT ) ; var c = new CKEDITOR . dom . walker ( c ) , e = 0 ; c . evaluator = function ( a ) { a . type == CKEDITOR . NODE _ELEMENT && a . is ( d ) && ++ e } ; c . checkForward ( ) ; if ( 1 < e ) { var c = b . startPath ( ) . contains ( "table" ) , f = b . endPath ( ) . contains ( "table" ) ; c && f && b . checkBoundaryOfElement ( c , CKEDITOR . START ) && b . checkBoundaryOfElement ( f , CKEDITOR . END ) && ( b = a . range . clone ( ) , b . setStartBefore ( c ) ,
b . setEndAfter ( f ) , a . purgeTableBookmark = b . createBookmark ( ) ) } } , detectRanges : function ( e , f) { var g = c ( f , e . bookmark ) , h = g . clone ( ) , k , n , l = g . getCommonAncestor ( ) ; l . is ( CKEDITOR . dtd . $tableContent ) && ! l . is ( d ) && ( l = l . getAscendant ( "table" , ! 0 ) ) ; n = l ; l = new CKEDITOR . dom . elementPath ( g. startContainer , n ) ; n = new CKEDITOR . dom . elementPath ( g. endContainer , n ) ; l = l . contains ( "table" ) ; n= n . contains ( "table" ) ; if ( l || n) l && n && b ( l , n ) ? ( e . tableSurroundingRange = h , h . setStartAt ( l , CKEDITOR . POSITION _AFTER _END ) , h . setEndAt ( n , CKEDITOR . POSITION _BEFORE _START ) ,
h = g . clone ( ) , h . setEndAt ( l , CKEDITOR . POSITION _AFTER _END ) , k = g . clone ( ) , k . setStartAt ( n , CKEDITOR . POSITION _BEFORE _START ) , k = a ( h ) . concat ( a ( k ) ) ) : l ? n || ( e . tableSurroundingRange = h , h . setStartAt ( l , CKEDITOR . POSITION _AFTER _END ) , g . setEndAt ( l , CKEDITOR . POSITION _AFTER _END ) ) : ( e . tableSurroundingRange = h , h . setEndAt ( n , CKEDITOR . POSITION _BEFORE _START ) , g. setStartAt ( n , CKEDITOR . POSITION _AFTER _START ) ) , e . tableContentsRanges = k ? k : a ( g ) } , deleteRanges : function ( a ) { for ( var b ; b = a . tableContentsRanges . pop ( ) ; ) b . extractContents ( ) , r ( b . startContainer ) &&
CKEDITOR . POSITION _BEFORE _END ) , b . select ( ) ) } } ( ) ; q = { eol : { detect : function ( a , b ) { var c = a . range , d = c . clone ( ) , e = c . clone ( ) , g = new CKEDITOR . dom . elementPath ( c . startContainer , b ) , f = new CKEDITOR . dom . elementPath ( c . endContainer , b ) ; d . collapse ( 1 ) ; e . collapse ( ) ; g . block && d . checkBoundaryOfElement ( g . block , CKEDITOR . END ) && ( c . setStartAfter ( g . block ) , a . prependEolBr = 1 ) ; f . block && e . checkBoundaryOfElement ( f . block , CKEDITOR . START ) && ( c . setEndBefore ( f . block ) , a . appendEolBr = 1 ) } , fix : function ( a , b ) { var c = b . getDocument ( ) , d ; a . appendEolBr && ( d =
this . createEolBr ( c ) , a . fragment . append ( d ) ) ; ! a . prependEolBr || d && ! d . getPrevious ( ) || a . fragment . append ( this . createEolBr ( c ) , 1 ) } , createEolBr : function ( a ) { return a . createElement ( "br" , { attributes : { "data-cke-eol" : 1 } } ) } } , bogus : { exclude : function ( a ) { var b = a . range . getBoundaryNodes ( ) , c = b . startNode , b = b . endNode ; ! b || ! m ( b ) || c && c . equals ( b ) || a . range . setEndBefore ( b ) } } , tree : { rebuild : function ( a , b ) { var c = a . range , d = c . getCommonAncestor ( ) , e = new CKEDITOR . dom . elementPath ( d , b ) , g = new CKEDITOR . dom . elementPath ( c . startContainer , b ) ,
c = new CKEDITOR . dom . elementPath ( c . endContainer , b ) , f ; d . type == CKEDITOR . NODE _TEXT && ( d = d . getParent ( ) ) ; if ( e . blockLimit . is ( { tr : 1 , table : 1 } ) ) { var h = e . contains ( "table" ) . getParent ( ) ; f = function ( a ) { return ! a . equals ( h ) } } else if ( e . block && e . block . is ( CKEDITOR . dtd . $listItem ) && ( g= g . contains ( CKEDITOR . dtd . $list ) , c = c . contains ( CKEDITOR . dtd . $list ) , ! g. equals ( c ) ) ) { var r = e . contains ( CKEDITOR . dtd . $list ) . getParent ( ) ; f = function ( a ) { return ! a . equals ( r) } } f || ( f = function ( a ) { return ! a . equals ( e . block ) && ! a . equals ( e . blockLimit ) } ) ; this . rebuildFragment ( a ,
b , d , f ) } , rebuildFragment : function ( a , b , c , d ) { for ( var e ; c && ! c . equals ( b ) && d ( c ) ; ) e = c . clone ( 0 , 1 ) , a . fragment . appendTo ( e ) , a . fragment = e , c = c . getParent ( ) } } , cell : { shrink : function ( a ) { a = a . range ; var b = a . startContainer , c = a . endContainer , d = a . startOffset , e = a . endOffset ; b . type == CKEDITOR . NODE _ELEMENT && b . equals ( c ) && b . is ( "tr" ) && ++ d == e && a . shrink ( CKEDITOR . SHRINK _TEXT ) } } } ; u = function ( ) { function a ( b , c ) { var d = b . getParent ( ) ; if ( d . is ( CKEDITOR . dtd . $inline ) ) b [ c ? "insertBefore" : "insertAfter" ] ( d ) } function b ( c , d , e ) { a ( d ) ; a ( e , 1 ) ; for ( var g; g =
e . getNext ( ) ; ) g. insertAfter ( d ) , d = g ; v ( c ) && c . remove ( ) } function c ( a , b ) { var d = new CKEDITOR . dom . range ( a ) ; d . setStartAfter ( b . startNode ) ; d . setEndBefore ( b . endNode ) ; return d } return { list : { detectMerge : function ( a , b ) { var d = c ( b , a . bookmark ) , e = d . startPath ( ) , g= d . endPath ( ) , f = e . contains ( CKEDITOR . dtd . $list ) , h = g . contains ( CKEDITOR . dtd . $list ) ; a . mergeList = f&& h && f . getParent ( ) . equals ( h . getParent ( ) ) && ! f . equals ( h ) ; a . mergeListItems = e . block && g . block && e . block . is ( CKEDITOR . dtd . $listItem ) && g . block . is ( CKEDITOR . dtd . $listItem ) ; if ( a . mergeList ||
a . mergeListItems ) d = d . clone ( ) , d . setStartBefore ( a . bookmark . startNode ) , d . setEndAfter ( a . bookmark . endNode ) , a . mergeListBookmark = d . createBookmark ( ) } , merge : function ( a , c ) { if ( a . mergeListBookmark ) { var d = a . mergeListBookmark . startNode , e = a . mergeListBookmark . endNode , g = new CKEDITOR . dom . elementPath ( d , c ) , f = new CKEDITOR . dom . elementPath ( e , c ) ; if ( a . mergeList ) { var h = g . contains ( CKEDITOR . dtd . $list ) , k = f . contains ( CKEDITOR . dtd . $list ) ; h . equals ( k ) || ( k . moveChildren ( h ) , k . remove ( ) ) } a . mergeListItems && ( g= g . contains ( CKEDITOR . dtd . $listItem ) ,
f= f . contains ( CKEDITOR . dtd . $listItem ) , g. equals ( f ) || b ( f , d , e ) ) ; d . remove ( ) ; e . remove ( ) } } } , block : { detectMerge : function ( a , b ) { if ( ! a . tableContentsRanges && ! a . mergeListBookmark ) { var c = new CKEDITOR . dom . range ( b ) ; c . setStartBefore ( a . bookmark . startNode ) ; c . setEndAfter ( a . bookmark . endNode ) ; a . mergeBlockBookmark = c . createBookmark ( ) } } , merge : function ( a , c ) { if ( a . mergeBlockBookmark && ! a . purgeTableBookmark ) { var d = a . mergeBlockBookmark . startNode , e = a . mergeBlockBookmark . endNode , g = new CKEDITOR . dom . elementPath ( d , c ) , f = new CKEDITOR . dom . elementPath ( e ,
c ) , g= g . block , f = f . block ; g && f && ! g . equals ( f ) && b ( f , d , e ) ; d . remove ( ) ; e . remove ( ) } } } , table : function ( ) { function a ( c ) { var e = [ ] , g, f = new CKEDITOR . dom . walker ( c ) , h = c . startPath ( ) . contains ( d ) , k = c . endPath ( ) . contains ( d ) , t = { } ; f. guard = function ( a , f ) { if ( a . type == CKEDITOR . NODE _ELEMENT ) { var E= "visited_" + ( f ? "out" : "in" ) ; if ( a . getCustomData ( E ) ) return ; CKEDITOR . dom . element . setMarker ( t , a , E, 1 ) } if ( f && h && a . equals ( h ) ) g= c . clone ( ) , g . setEndAt ( h , CKEDITOR . POSITION _BEFORE _END ) , e . push ( g) ; else if ( ! f && k && a . equals ( k ) ) g= c . clone ( ) , g . setStartAt ( k ,
CKEDITOR . POSITION _AFTER _START ) , e . push ( g) ; else { if ( E = ! f ) E = a . type == CKEDITOR . NODE _ELEMENT && a . is ( d ) && ( ! h || b ( a , h ) ) && ( ! k || b ( a , k ) ) ; if ( ! E&& ( E = f ) ) if ( a . is ( d ) ) var E = h && h . getAscendant ( "table" , ! 0 ) , H = k && k . getAscendant ( "table" , ! 0 ) , l = a . getAscendant ( "table" , ! 0 ) , E= E && E . contains ( l ) || H && H . contains ( l ) ; else E = void 0 ; E && ( g = c . clone ( ) , g . selectNodeContents ( a ) , e . push ( g) ) } } ; f . lastForward ( ) ; CKEDITOR . dom . element . clearAllMarkers ( t ) ; return e } function b ( a , c ) { var d = CKEDITOR . POSITION _CONTAINS + CKEDITOR . POSITION _IS _CONTAINED , e = a . getPosition ( c ) ;
return e === CKEDITOR . POSITION _IDENTICAL ? ! 1 : 0 === ( e & d ) } var d = { td : 1 , th : 1 , caption : 1 } ; return { detectPurge : function ( a ) { var b = a . range , c = b . clone ( ) ; c . enlarge ( CKEDITOR . ENLARGE _ELEMENT ) ; var c = new CKEDITOR . dom . walker ( c ) , e = 0 ; c . evaluator = function ( a ) { a . type == CKEDITOR . NODE _ELEMENT && a . is ( d ) && ++ e } ; c . checkForward ( ) ; if ( 1 < e ) { var c = b . startPath ( ) . contains ( "table" ) , g = b . endPath ( ) . contains ( "table" ) ; c && g && b . checkBoundaryOfElement ( c , CKEDITOR . START ) && b . checkBoundaryOfElement ( g , CKEDITOR . END ) && ( b = a . range . clone ( ) , b . setStartBefore ( c ) ,
b . setEndAfter ( g ) , a . purgeTableBookmark = b . createBookmark ( ) ) } } , detectRanges : function ( e , g) { var f = c ( g , e . bookmark ) , h = f . clone ( ) , k , p , l = f . getCommonAncestor ( ) ; l . is ( CKEDITOR . dtd . $tableContent ) && ! l . is ( d ) && ( l = l . getAscendant ( "table" , ! 0 ) ) ; p = l ; l = new CKEDITOR . dom . elementPath ( f. startContainer , p ) ; p = new CKEDITOR . dom . elementPath ( f. endContainer , p ) ; l = l . contains ( "table" ) ; p= p . contains ( "table" ) ; if ( l || p) l && p && b ( l , p ) ? ( e . tableSurroundingRange = h , h . setStartAt ( l , CKEDITOR . POSITION _AFTER _END ) , h . setEndAt ( p , CKEDITOR . POSITION _BEFORE _START ) ,
h = f . clone ( ) , h . setEndAt ( l , CKEDITOR . POSITION _AFTER _END ) , k = f . clone ( ) , k . setStartAt ( p , CKEDITOR . POSITION _BEFORE _START ) , k = a ( h ) . concat ( a ( k ) ) ) : l ? p || ( e . tableSurroundingRange = h , h . setStartAt ( l , CKEDITOR . POSITION _AFTER _END ) , f . setEndAt ( l , CKEDITOR . POSITION _AFTER _END ) ) : ( e . tableSurroundingRange = h , h . setEndAt ( p , CKEDITOR . POSITION _BEFORE _START ) , f. setStartAt ( p , CKEDITOR . POSITION _AFTER _START ) ) , e . tableContentsRanges = k ? k : a ( f ) } , deleteRanges : function ( a ) { for ( var b ; b = a . tableContentsRanges . pop ( ) ; ) b . extractContents ( ) , v ( b . startContainer ) &&
b . startContainer . appendBogus ( ) ; a . tableSurroundingRange && a . tableSurroundingRange . extractContents ( ) } , purge : function ( a ) { if ( a . purgeTableBookmark ) { var b = a . doc , c = a . range . clone ( ) , b = b . createElement ( "p" ) ; b . insertBefore ( a . purgeTableBookmark . startNode ) ; c . moveToBookmark ( a . purgeTableBookmark ) ; c . deleteContents ( ) ; a . range . moveToPosition ( b , CKEDITOR . POSITION _AFTER _START ) } } } } ( ) , detectExtractMerge : function ( a ) { return ! ( a . range . startPath ( ) . contains ( CKEDITOR . dtd . $listItem ) && a . range . endPath ( ) . contains ( CKEDITOR . dtd . $listItem ) ) } ,
fixUneditableRangePosition : function ( a ) { a . startContainer . getDtd ( ) [ "#" ] || a . moveToClosestEditablePosition ( null , ! 0 ) } , autoParagraph : function ( a , b ) { var c = b . startPath ( ) , d ; l ( a , c . block , c . blockLimit ) && ( d = q ( a ) ) && ( d = b . document . createElement ( d ) , d . appendBogus ( ) , b . insertNode ( d ) , b . moveToPosition ( d , CKEDITOR . POSITION _AFTER _START ) ) } } } ( ) } ) ( ) ;
( function ( ) { function a ( a ) { return CKEDITOR . plugins . widget && CKEDITOR . plugins . widget . isDomWidget ( a ) } function d ( b , c ) { if ( 0 === b . length || a ( b [ 0 ] . getEnclosedNode ( ) ) ) return ! 1 ; var d , e ; if ( ( d = ! c && 1 === b . length ) && ! ( d = b [ 0 ] . collapsed ) ) { var f= b [ 0 ] ; d = f . startContainer . getAscendant ( { td : 1 , th : 1 } , ! 0 ) ; var g= f . endContainer . getAscendant ( { td : 1 , th : 1 } , ! 0 ) ; e = CKEDITOR . tools . trim ; d && d . equals ( g ) && ! d . findOne ( "td, th, tr, tbody, table" ) ? ( f= f . cloneContents ( ) , d = f . getFirst ( ) ? e ( f . getFirst ( ) . getText ( ) ) !== e ( d . getText ( ) ) : ! 0 ) : d = ! 1 } if ( d ) return ! 1 ;
for ( e = 0 ; e < b . length ; e ++ ) if ( d = b [ e ] . _getTableElement ( ) , ! d ) return ! 1 ; return ! 0 } function b ( a ) { function b ( a ) { a = a . find ( "td, th" ) ; var c = [ ] , d ; for ( d = 0 ; d < a . count ( ) ; d ++ ) c . push ( a . getItem ( d ) ) ; return c } var c = [ ] , d , e ; for ( e = 0 ; e < a . length ; e ++ ) d = a [ e ] . _getTableElement ( ) , d . is && d . is ( { td : 1 , th : 1 } ) ? c . push ( d ) : c = c . concat ( b ( d ) ) ; return c } function c ( a ) { a = b ( a ) ; var c = "" , d = [ ] , e , f; for ( f = 0 ; f < a . length ; f ++ ) e && ! e . equals ( a [ f ] . getAscendant ( "tr" ) ) ? ( c += d . join ( "\t" ) + "\n" , e = a [ f ] . getAscendant ( "tr" ) , d = [ ] ) : 0 === f&& ( e = a [ f ] . getAscendant ( "tr" ) ) , d . push ( a [ f ] . getText ( ) ) ;
return c += d . join ( "\t" ) } function g ( a ) { var b = this . root . editor , d = b . getSelection ( 1 ) ; this . reset ( ) ; G = ! 0 ; d . root . once ( "selectionchange" , function ( a ) { a . cancel ( ) } , null , null , 0 ) ; d . selectRanges ( [ a [ 0 ] ] ) ; d = this . _ . cache ; d . ranges = new CKEDITOR . dom . rangeList ( a ) ; d . type = CKEDITOR . SELECTION _TEXT ; d . selectedElement = a [ 0 ] . _getTableElement ( ) ; d . selectedText = c ( a ) ; d . nativeSel = null ; this . isFake = 1 ; this . rev = L ++ ; b . _ . fakeSelection = this ; G = ! 1 ; this . root . fire ( "selectionchange" ) } function e ( ) { var b = this . _ . fakeSelection , c ; if ( b ) { c = this . getSelection ( 1 ) ;
var e ; if ( ! ( e = ! c ) && ( e = ! c . isHidden ( ) ) ) { e = b ; var f= c . getRanges ( ) , g = e . getRanges ( ) , h = f . length && f [ 0 ] . _getTableElement ( ) && f [ 0 ] . _getTableElement ( ) . getAscendant ( "table" , ! 0 ) , k = g. length && g [ 0 ] . _getTableElement ( ) && g [ 0 ] . _getTableElement ( ) . getAscendant ( "table" , ! 0 ) , l= 1 === f . length && f [ 0 ] . _getTableElement ( ) && f [ 0 ] . _getTableElement ( ) . is ( "table" ) , M= 1 === g . length && g [ 0 ] . _getTableElement ( ) && g [ 0 ] . _getTableElement ( ) . is ( "table" ) ; if ( a ( e . getSelectedElement ( ) ) ) e = ! 1 ; else { var n= 1 === f . length && f [ 0 ] . collapsed , g = d ( f , ! ! CKEDITOR . env . webkit ) &&
d ( g ) ; h = h && k ? h . equals ( k ) || k . contains ( h ) : ! 1 ; h && ( n|| g ) ? ( l && ! M && e . selectRanges ( f ) , e = ! 0 ) : e = ! 1 } e = ! e } e && ( b . reset ( ) , b = 0 ) } if ( ! b && ( b = c || this . getSelection ( 1 ) , ! b || b . getType ( ) == CKEDITOR . SELECTION _NONE ) ) return ; this . fire ( "selectionCheck" , b ) ; c = this . elementPath ( ) ; c . compare ( this . _ . selectionPreviousPath ) || ( e = this . _ . selectionPreviousPath && this . _ . selectionPreviousPath . blockLimit . equals ( c . blockLimit ) , ! CKEDITOR . env . webkit && ! CKEDITOR . env . gecko || e || ( this . _ . previousActive = this . document . getActive ( ) ) , this . _ . selectionPreviousPath =
c , this . fire ( "selectionChange" , { selection : b , path : c } ) ) } function h( ) { u = ! 0 ; p || ( k . call ( this ) , p = CKEDITOR . tools . setTimeout ( k , 200 , this ) ) } function k ( ) { p = null ; u && ( CKEDITOR . tools . setTimeout ( e , 0 , this ) , u = ! 1 ) } function l ( a ) { return K ( a ) || a . type == CKEDITOR . NODE _ELEMENT && ! a . is ( CKEDITOR . dtd . $empty ) ? ! 0 : ! 1 } function q ( a ) { function b ( c , d ) { return c && c . type != CKEDITOR . NODE _TEXT ? a . clone ( ) [ "moveToElementEdit" + ( d ? "End" : "Start" ) ] ( c ) : ! 1 } if ( ! ( a . root instanceof CKEDITOR . editable ) ) return ! 1 ; var c = a . startContainer , d = a . getPreviousNode ( l ,
null , c ) , e = a . getNextNode ( l , null , c ) ; return b ( d ) || b ( e , 1 ) || ! ( d || e || c . type == CKEDITOR . NODE _ELEMENT && c . isBlockBoundary ( ) && c . getBogus ( ) ) ? ! 0 : ! 1 } function f( a ) { w ( a , ! 1 ) ; var b = a . getDocument ( ) . createText ( v ) ; a . setCustomData ( "cke-fillingChar" , b ) ; return b } function w ( a , b ) { var c = a && a . removeCustomData ( "cke-fillingChar" ) ; if ( c ) { if ( ! 1 !== b ) { var d = a . getDocument ( ) . getSelection ( ) . getNative ( ) , e = d && "None" != d . type && d . getRangeAt ( 0 ) , f= v . length ; if ( c . getLength ( ) > f && e && e . intersectsNode ( c . $ ) ) { var g = [ { node : d . anchorNode , offset : d . anchorOffset } ,
{ node : d . focusNode , offset : d . focusOffset } ] ; d . anchorNode == c . $ && d . anchorOffset > f&& ( g [ 0 ] . offset -= f ) ; d . focusNode == c . $ && d . focusOffset > f&& ( g [ 1 ] . offset -= f ) } } c . setText ( B ( c . getText ( ) , 1 ) ) ; g && ( c = a . getDocument ( ) . $ , d = c . getSelection ( ) , c = c . createRange ( ) , c . setStart ( g[ 0 ] . node , g [ 0 ] . offset ) , c . collapse ( ! 0 ) , d . removeAllRanges ( ) , d . addRange ( c ) , d . extend ( g[ 1 ] . node , g [ 1 ] . offset ) ) } } function B ( a , b ) { return b ? a . replace ( J , function ( a , b ) { return b ? " " : "" } ) : a . replace ( v, "" ) } function y ( a , b ) { var c = b && CKEDITOR . tools . htmlEncode ( b ) || "\x26nbsp;" ,
c = CKEDITOR . dom . element . createFromHtml ( '\x3cdiv data-cke-hidden-sel\x3d"1" data-cke-temp\x3d"1" style\x3d"' + ( CKEDITOR . env . ie && 14 > CKEDITOR . env . version ? "display:none" : "position:fixed;top:0;left:-1000px;width:0;height:0;overflow:hidden;" ) + '"\x3e' + c + "\x3c/div\x3e" , a . document ) ; a . fire ( "lockSnapshot" ) ; a . editable ( ) . append ( c ) ; var d = a . getSelection ( 1 ) , e = a . createRange ( ) , f = d . root . on ( "selectionchange" , function ( a ) { a . cancel ( ) } , null , null , 0 ) ; e . setStartAt ( c , CKEDITOR . POSITION _AFTER _START ) ; e . setEndAt ( c , CKEDITOR . POSITION _BEFORE _END ) ;
d . selectRanges ( [ e ] ) ; f . removeListener ( ) ; a . fire ( "unlockSnapshot" ) ; a . _ . hiddenSelectionContainer = c } function F ( b ) { var c = { 37 : 1 , 39 : 1 , 8 : 1 , 46 : 1 } ; return function ( d ) { var e = d . data . getKeystroke ( ) ; if ( c [ e ] ) { var f= b . getSelection ( ) , g = f . getRanges ( ) [ 0 ] ; f . isCollapsed ( ) && ( g = g [ 38 > e ? "getPreviousEditableNode" : "getNextEditableNode" ] ( ) ) && g . type == CKEDITOR . NODE _ELEMENT && "false" == g . getAttribute ( "contenteditable" ) && ( f= f . getStartElement ( ) , ! f . isBlockBoundary ( ) || "" !== ( void 0 === f. $ . textContent ? f . $ . innerText : f . $ . textContent ) || a ( f . getFirst ( ) ) ||
8 !== e && 46 !== e || ( f . remove ( ) , b . fire ( "saveSnapshot" ) ) , b . getSelection ( ) . fake ( g ) , d . data . preventDefault ( ) , d . cancel ( ) ) } } } function r ( a ) { for ( var b = 0 ; b < a . length ; b ++ ) { var c = a [ b ] ; c . getCommonAncestor ( ) . isReadOnly ( ) && a . splice ( b , 1 ) ; if ( ! c . collapsed ) { if ( c . startContainer . isReadOnly ( ) ) for ( var d = c . startContainer , e ; d && ! ( ( e = d . type == CKEDITOR . NODE _ELEMENT ) && d . is ( "body" ) || ! d . isReadOnly ( ) ) ; ) e && "false" == d . getAttribute ( "contentEditable" ) && c . setStartAfter ( d ) , d = d . getParent ( ) ; d = c . startContainer ; e = c . endContainer ; var f = c . startOffset ,
g = c . endOffset , h = c . clone ( ) ; d && d . type == CKEDITOR . NODE _TEXT && ( f >= d . getLength ( ) ? h . setStartAfter ( d ) : h . setStartBefore ( d ) ) ; e && e . type == CKEDITOR . NODE _TEXT && ( g ? h . setEndAfter ( e ) : h . setEndBefore ( e ) ) ; d = new CKEDITOR . dom . walker ( h ) ; d . evaluator = function ( d ) { if ( d . type == CKEDITOR . NODE _ELEMENT && d . isReadOnly ( ) ) { var e = c . clone ( ) ; c . setEndBefore ( d ) ; c . collapsed && a . splice ( b -- , 1 ) ; d . getPosition ( h . endContainer ) & CKEDITOR . POSITION _CONTAINS || ( e . setStartAfter ( d ) , e . collapsed || a . splice ( b + 1 , 0 , e ) ) ; return ! 0 } return ! 1 } ; d . next ( ) } } return a } var m =
"function" != typeof window . getSelection , L= 1 , v = CKEDITOR . tools . repeat ( " " , 7 ) , J = new RegExp ( v+ "( )?" , "g" ) , G , p , u , K = CKEDITOR . dom . walker . invisible ( 1 ) , E = function ( ) { function a ( b ) { return function ( a ) { var c = a . editor . createRange ( ) ; c . moveToClosestEditablePosition ( a . selected , b ) && a . editor . getSelection ( ) . selectRanges ( [ c ] ) ; return ! 1 } } function b ( a ) { return function ( b ) { var c = b . editor , d = c . createRange ( ) , e ; if ( ! c . readOnly ) return ( e = d . moveToClosestEditablePosition ( b . selected , a ) ) || ( e = d . moveToClosestEditablePosition ( b . selected ,
! a ) ) , e && c . getSelection ( ) . selectRanges ( [ d ] ) , c . fire ( "saveSnapshot" ) , b . selected . remove ( ) , e || ( d . moveToElementEditablePosition ( c . editable ( ) ) , c . getSelection ( ) . selectRanges ( [ d ] ) ) , c . fire ( "saveSnapshot" ) , ! 1 } } var c = a ( ) , d = a ( 1 ) ; return { 37 : c , 38 : c , 39 : d , 40 : d , 8 : b ( ) , 46 : b ( 1 ) } } ( ) ; CKEDITOR . on ( "instanceCreated" , function ( a ) { function b ( ) { var a = c . getSelection ( ) ; a && a . removeAllRanges ( ) } var c = a . editor ; c . on ( "contentDom" , function ( ) { function a ( ) { p = new CKEDITOR . dom . selection ( c . getSelection ( ) ) ; p . lock ( ) } function b ( ) { k . removeListener ( "mouseup" ,
b ) ; l . removeListener ( "mouseup" , b ) ; var a = CKEDITOR . document . $ . selection , c = a . createRange ( ) ; "None" != a . type && c . parentElement ( ) && c . parentElement ( ) . ownerDocument == g . $ && c . select ( ) } function d ( a ) { var b , c ; b = ( b = this . document . getActive ( ) ) ? "input" === b . getName ( ) || "textarea" === b . getName ( ) : ! 1 ; b || ( b = this . getSelection ( 1 ) , ( c = f ( b ) ) && ! c . equals ( n ) && ( b . selectElement ( c ) , a . data . preventDefault ( ) ) ) } function f ( a ) { a = a . getRanges ( ) [ 0 ] ; return a ? ( a = a . startContainer . getAscendant ( function ( a ) { return a . type == CKEDITOR . NODE _ELEMENT && a . hasAttribute ( "contenteditable" ) } ,
! 0 ) ) && "false" === a . getAttribute ( "contenteditable" ) ? a : null : null } var g= c . document , k = CKEDITOR . document , n = c . editable ( ) , t = g . getBody ( ) , l = g . getDocumentElement ( ) , q = n . isInline ( ) , D , p ; CKEDITOR . env . gecko && n . attachListener ( n , "focus" , function ( a ) { a . removeListener ( ) ; 0 !== D && ( a = c . getSelection ( ) . getNative ( ) ) && a . isCollapsed && a . anchorNode == n . $ && ( a = c . createRange ( ) , a . moveToElementEditStart ( n ) , a . select ( ) ) } , null , null , - 2 ) ; n. attachListener ( n , CKEDITOR . env . webkit || CKEDITOR . env . gecko ? "focusin" : "focus" , function ( ) { if ( D && ( CKEDITOR . env . webkit ||
CKEDITOR . env . gecko ) ) { D = c . _ . previousActive && c . _ . previousActive . equals ( g . getActive ( ) ) ; var a = null != c . _ . previousScrollTop && c . _ . previousScrollTop != n . $ . scrollTop ; CKEDITOR . env . webkit && D&& a && ( n . $ . scrollTop = c . _ . previousScrollTop ) } c . unlockSelection ( D) ; D = 0 } , null , null , - 1 ) ; n. attachListener ( n , "mousedown" , function ( ) { D = 0 } ) ; if ( CKEDITOR . env . ie || CKEDITOR . env . gecko || q) m ? n . attachListener ( n , "beforedeactivate" , a , null , null , - 1 ) : n . attachListener ( c , "selectionCheck" , a , null , null , - 1 ) , n. attachListener ( n , CKEDITOR . env . webkit || CKEDITOR . env . gecko ?
"focusout" : "blur" , function ( ) { var a = p&& ( p . isFake || 2 > p . getRanges ( ) . length ) ; CKEDITOR . env . gecko && ! q && a || ( c . lockSelection ( p) , D = 1 ) } , null , null , - 1 ) , n. attachListener ( n , "mousedown" , function ( ) { D = 0 } ) ; if ( CKEDITOR . env . ie && ! q) { var r ; n . attachListener ( n , "mousedown" , function ( a ) { 2 == a . data . $ . button && ( ( a = c . document . getSelection ( ) ) && a . getType ( ) != CKEDITOR . SELECTION _NONE || ( r = c . window . getScrollPosition ( ) ) ) } ) ; n. attachListener ( n , "mouseup" , function ( a ) { 2 == a . data . $ . button && r && ( c . document . $ . documentElement . scrollLeft = r . x , c . document . $ . documentElement . scrollTop =
r. y ) ; r = null } ) ; if ( "BackCompat" != g . $ . compatMode ) { if ( CKEDITOR . env . ie7Compat || CKEDITOR . env . ie6Compat ) { var u , v ; l . on ( "mousedown" , function ( a ) { function b ( a ) { a = a . data . $ ; if ( u ) { var c = t . $ . createTextRange ( ) ; try { c . moveToPoint ( a . clientX , a . clientY ) } catch ( d ) { } u . setEndPoint ( 0 > v . compareEndPoints ( "StartToStart" , c ) ? "EndToEnd" : "StartToStart" , c ) ; u . select ( ) } } function c ( ) { l . removeListener ( "mousemove" , b ) ; k . removeListener ( "mouseup" , c ) ; l . removeListener ( "mouseup" , c ) ; u . select ( ) } a = a . data ; if ( a . getTarget ( ) . is ( "html" ) && a . $ . y < l . $ . clientHeight &&
a . $ . x < l . $ . clientWidth ) { u = t . $ . createTextRange ( ) ; try { u . moveToPoint ( a . $ . clientX , a . $ . clientY ) } catch ( d ) { } v = u . duplicate ( ) ; l . on ( "mousemove" , b ) ; k . on ( "mouseup" , c ) ; l . on ( "mouseup" , c ) } } ) } if ( 7 < CKEDITOR . env . version && 11 > CKEDITOR . env . version ) l . on ( "mousedown" , function ( a ) { a . data . getTarget ( ) . is ( "html" ) && ( k . on ( "mouseup" , b ) , l . on ( "mouseup" , b ) ) } ) } } n. attachListener ( n , "selectionchange" , e , c ) ; n. attachListener ( n , "keyup" , h , c ) ; n . attachListener ( n , "touchstart" , h , c ) ; n . attachListener ( n , "touchend" , h , c ) ; CKEDITOR . env . ie && n. attachListener ( n ,
"keydown" , d , c ) ; n. attachListener ( n , CKEDITOR . env . webkit || CKEDITOR . env . gecko ? "focusin" : "focus" , function ( ) { c . forceNextSelectionCheck ( ) ; c . selectionChange ( 1 ) } ) ; if ( q && ( CKEDITOR . env . webkit || CKEDITOR . env . gecko ) ) { var y; n . attachListener ( n , "mousedown" , function ( ) { y = 1 } ) ; n . attachListener ( g . getDocumentElement ( ) , "mouseup" , function ( ) { y&& h . call ( c ) ; y = 0 } ) } else n . attachListener ( CKEDITOR . env . ie ? n: g . getDocumentElement ( ) , "mouseup" , h , c ) ; CKEDITOR . env . webkit && n. attachListener ( g , "keydown" , function ( a ) { switch ( a . data . getKey ( ) ) { case 13 : case 33 : case 34 : case 35 : case 36 : case 37 : case 39 : case 8 : case 45 : case 46 : n . hasFocus &&
w( n ) } } , null , null , - 1 ) ; n. attachListener ( n , "keydown" , F ( c ) , null , null , - 1 ) } ) ; c . on ( "setData" , function ( ) { c . unlockSelection ( ) ; CKEDITOR . env . webkit && b ( ) } ) ; c . on ( "contentDomUnload" , function ( ) { c . unlockSelection ( ) } ) ; if ( CKEDITOR . env . ie9Compat ) c . on ( "beforeDestroy" , b , null , null , 9 ) ; c . on ( "dataReady" , function ( ) { delete c . _ . fakeSelection ; delete c . _ . hiddenSelectionContainer ; c . selectionChange ( 1 ) } ) ; c . on ( "loadSnapshot" , function ( ) { var a = CKEDITOR . dom . walker . nodeType ( CKEDITOR . NODE _ELEMENT ) , b = c . editable ( ) . getLast ( a ) ; b && b . hasAttribute ( "data-cke-hidden-sel" ) &&
( b . remove ( ) , CKEDITOR . env . gecko && ( a = c . editable ( ) . getFirst ( a ) ) && a . is ( "br" ) && a . getAttribute ( "_moz_editor_bogus_node" ) && a . remove ( ) ) } , null , null , 100 ) ; c . on ( "key" , function ( a ) { if ( "wysiwyg" == c . mode ) { var b = c . getSelection ( ) ; if ( b . isFake ) { var d = E [ a . data . keyCode ] ; if ( d ) return d ( { editor : c , selected : b . getSelectedElement ( ) , selection : b , keyEvent : a } ) } } } ) } ) ; if ( CKEDITOR . env . webkit ) CKEDITOR . on ( "instanceReady" , function ( a ) { var b = a . editor ; b . on ( "selectionChange" , function ( ) { var a = b . editable ( ) , c = a . getCustomData ( "cke-fillingChar" ) ;
c && ( c . getCustomData ( "ready" ) ? ( w ( a ) , a . editor . fire ( "selectionCheck" ) ) : c . setCustomData ( "ready" , 1 ) ) } , null , null , - 1 ) ; b . on ( "beforeSetMode" , function ( ) { w ( b . editable ( ) ) } , null , null , - 1 ) ; b . on ( "getSnapshot" , function ( a ) { a . data && ( a . data = B ( a . data ) ) } , b , null , 20 ) ; b . on ( "toDataFormat" , function ( a ) { a . data . dataValue = B ( a . data . dataValue ) } , null , null , 0 ) } ) ; CKEDITOR . editor . prototype . selectionChange = function ( a ) { ( a ? e : h ) . call ( this ) } ; CKEDITOR . editor . prototype . getSelection = function ( a ) { return ! this . _ . savedSelection && ! this . _ . fakeSelection ||
fixUneditableRangePosition : function ( a ) { a . startContainer . getDtd ( ) [ "#" ] || a . moveToClosestEditablePosition ( null , ! 0 ) } , autoParagraph : function ( a , b ) { var c = b . startPath ( ) , d ; n ( a , c . block , c . blockLimit ) && ( d = l ( a ) ) && ( d = b . document . createElement ( d ) , d . appendBogus ( ) , b . insertNode ( d ) , b . moveToPosition ( d , CKEDITOR . POSITION _AFTER _START ) ) } } } ( ) } ) ( ) ;
( function ( ) { function a ( a ) { return CKEDITOR . plugins . widget && CKEDITOR . plugins . widget . isDomWidget ( a ) } function d ( b , c ) { if ( 0 === b . length || a ( b [ 0 ] . getEnclosedNode ( ) ) ) return ! 1 ; var d , e ; if ( ( d = ! c && 1 === b . length ) && ! ( d = b [ 0 ] . collapsed ) ) { var g= b [ 0 ] ; d = g . startContainer . getAscendant ( { td : 1 , th : 1 } , ! 0 ) ; var f= g . endContainer . getAscendant ( { td : 1 , th : 1 } , ! 0 ) ; e = CKEDITOR . tools . trim ; d && d . equals ( f ) && ! d . findOne ( "td, th, tr, tbody, table" ) ? ( g= g . cloneContents ( ) , d = g . getFirst ( ) ? e ( g . getFirst ( ) . getText ( ) ) !== e ( d . getText ( ) ) : ! 0 ) : d = ! 1 } if ( d ) return ! 1 ;
for ( e = 0 ; e < b . length ; e ++ ) if ( d = b [ e ] . _getTableElement ( ) , ! d ) return ! 1 ; return ! 0 } function b ( a ) { function b ( a ) { a = a . find ( "td, th" ) ; var c = [ ] , d ; for ( d = 0 ; d < a . count ( ) ; d ++ ) c . push ( a . getItem ( d ) ) ; return c } var c = [ ] , d , e ; for ( e = 0 ; e < a . length ; e ++ ) d = a [ e ] . _getTableElement ( ) , d . is && d . is ( { td : 1 , th : 1 } ) ? c . push ( d ) : c = c . concat ( b ( d ) ) ; return c } function c ( a ) { a = b ( a ) ; var c = "" , d = [ ] , e , g; for ( g = 0 ; g < a . length ; g ++ ) e && ! e . equals ( a [ g ] . getAscendant ( "tr" ) ) ? ( c += d . join ( "\t" ) + "\n" , e = a [ g ] . getAscendant ( "tr" ) , d = [ ] ) : 0 === g&& ( e = a [ g ] . getAscendant ( "tr" ) ) , d . push ( a [ g ] . getText ( ) ) ;
return c += d . join ( "\t" ) } function f ( a ) { var b = this . root . editor , d = b . getSelection ( 1 ) ; this . reset ( ) ; F = ! 0 ; d . root . once ( "selectionchange" , function ( a ) { a . cancel ( ) } , null , null , 0 ) ; d . selectRanges ( [ a [ 0 ] ] ) ; d = this . _ . cache ; d . ranges = new CKEDITOR . dom . rangeList ( a ) ; d . type = CKEDITOR . SELECTION _TEXT ; d . selectedElement = a [ 0 ] . _getTableElement ( ) ; d . selectedText = c ( a ) ; d . nativeSel = null ; this . isFake = 1 ; this . rev = M ++ ; b . _ . fakeSelection = this ; F = ! 1 ; this . root . fire ( "selectionchange" ) } function e ( ) { var b = this . _ . fakeSelection , c ; if ( b ) { c = this . getSelection ( 1 ) ;
var e ; if ( ! ( e = ! c ) && ( e = ! c . isHidden ( ) ) ) { e = b ; var g= c . getRanges ( ) , f = e . getRanges ( ) , h = g . length && g [ 0 ] . _getTableElement ( ) && g [ 0 ] . _getTableElement ( ) . getAscendant ( "table" , ! 0 ) , k = f. length && f [ 0 ] . _getTableElement ( ) && f [ 0 ] . _getTableElement ( ) . getAscendant ( "table" , ! 0 ) , E= 1 === g . length && g [ 0 ] . _getTableElement ( ) && g [ 0 ] . _getTableElement ( ) . is ( "table" ) , l= 1 === f . length && f [ 0 ] . _getTableElement ( ) && f [ 0 ] . _getTableElement ( ) . is ( "table" ) ; if ( a ( e . getSelectedElement ( ) ) ) e = ! 1 ; else { var p= 1 === g . length && g [ 0 ] . collapsed , f = d ( g , ! ! CKEDITOR . env . webkit ) &&
d ( f ) ; h = h && k ? h . equals ( k ) || k . contains ( h ) : ! 1 ; h && ( p|| f ) ? ( E && ! l && e . selectRanges ( g ) , e = ! 0 ) : e = ! 1 } e = ! e } e && ( b . reset ( ) , b = 0 ) } if ( ! b && ( b = c || this . getSelection ( 1 ) , ! b || b . getType ( ) == CKEDITOR . SELECTION _NONE ) ) return ; this . fire ( "selectionCheck" , b ) ; c = this . elementPath ( ) ; c . compare ( this . _ . selectionPreviousPath ) || ( e = this . _ . selectionPreviousPath && this . _ . selectionPreviousPath . blockLimit . equals ( c . blockLimit ) , ! CKEDITOR . env . webkit && ! CKEDITOR . env . gecko || e || ( this . _ . previousActive = this . document . getActive ( ) ) , this . _ . selectionPreviousPath =
c , this . fire ( "selectionChange" , { selection : b , path : c } ) ) } function k( ) { u = ! 0 ; q || ( h . call ( this ) , q = CKEDITOR . tools . setTimeout ( h , 200 , this ) ) } function h ( ) { q = null ; u && ( CKEDITOR . tools . setTimeout ( e , 0 , this ) , u = ! 1 ) } function n ( a ) { return K ( a ) || a . type == CKEDITOR . NODE _ELEMENT && ! a . is ( CKEDITOR . dtd . $empty ) ? ! 0 : ! 1 } function l ( a ) { function b ( c , d ) { return c && c . type != CKEDITOR . NODE _TEXT ? a . clone ( ) [ "moveToElementEdit" + ( d ? "End" : "Start" ) ] ( c ) : ! 1 } if ( ! ( a . root instanceof CKEDITOR . editable ) ) return ! 1 ; var c = a . startContainer , d = a . getPreviousNode ( n ,
null , c ) , e = a . getNextNode ( n , null , c ) ; return b ( d ) || b ( e , 1 ) || ! ( d || e || c . type == CKEDITOR . NODE _ELEMENT && c . isBlockBoundary ( ) && c . getBogus ( ) ) ? ! 0 : ! 1 } function g( a ) { x ( a , ! 1 ) ; var b = a . getDocument ( ) . createText ( w ) ; a . setCustomData ( "cke-fillingChar" , b ) ; return b } function x ( a , b ) { var c = a && a . removeCustomData ( "cke-fillingChar" ) ; if ( c ) { if ( ! 1 !== b ) { var d = a . getDocument ( ) . getSelection ( ) . getNative ( ) , e = d && "None" != d . type && d . getRangeAt ( 0 ) , g= w . length ; if ( c . getLength ( ) > g && e && e . intersectsNode ( c . $ ) ) { var f = [ { node : d . anchorNode , offset : d . anchorOffset } ,
{ node : d . focusNode , offset : d . focusOffset } ] ; d . anchorNode == c . $ && d . anchorOffset > g&& ( f [ 0 ] . offset -= g ) ; d . focusNode == c . $ && d . focusOffset > g&& ( f [ 1 ] . offset -= g ) } } c . setText ( y ( c . getText ( ) , 1 ) ) ; f && ( c = a . getDocument ( ) . $ , d = c . getSelection ( ) , c = c . createRange ( ) , c . setStart ( f[ 0 ] . node , f [ 0 ] . offset ) , c . collapse ( ! 0 ) , d . removeAllRanges ( ) , d . addRange ( c ) , d . extend ( f[ 1 ] . node , f [ 1 ] . offset ) ) } } function y ( a , b ) { return b ? a . replace ( J , function ( a , b ) { return b ? " " : "" } ) : a . replace ( w, "" ) } function z ( a , b ) { var c = b && CKEDITOR . tools . htmlEncode ( b ) || "\x26nbsp;" ,
c = CKEDITOR . dom . element . createFromHtml ( '\x3cdiv data-cke-hidden-sel\x3d"1" data-cke-temp\x3d"1" style\x3d"' + ( CKEDITOR . env . ie && 14 > CKEDITOR . env . version ? "display:none" : "position:fixed;top:0;left:-1000px;width:0;height:0;overflow:hidden;" ) + '"\x3e' + c + "\x3c/div\x3e" , a . document ) ; a . fire ( "lockSnapshot" ) ; a . editable ( ) . append ( c ) ; var d = a . getSelection ( 1 ) , e = a . createRange ( ) , g = d . root . on ( "selectionchange" , function ( a ) { a . cancel ( ) } , null , null , 0 ) ; e . setStartAt ( c , CKEDITOR . POSITION _AFTER _START ) ; e . setEndAt ( c , CKEDITOR . POSITION _BEFORE _END ) ;
d . selectRanges ( [ e ] ) ; g . removeListener ( ) ; a . fire ( "unlockSnapshot" ) ; a . _ . hiddenSelectionContainer = c } function G ( b ) { var c = { 37 : 1 , 39 : 1 , 8 : 1 , 46 : 1 } ; return function ( d ) { var e = d . data . getKeystroke ( ) ; if ( c [ e ] ) { var g= b . getSelection ( ) , f = g . getRanges ( ) [ 0 ] ; g . isCollapsed ( ) && ( f = f [ 38 > e ? "getPreviousEditableNode" : "getNextEditableNode" ] ( ) ) && f . type == CKEDITOR . NODE _ELEMENT && "false" == f . getAttribute ( "contenteditable" ) && ( g= g . getStartElement ( ) , ! g . isBlockBoundary ( ) || "" !== ( void 0 === g. $ . textContent ? g . $ . innerText : g . $ . textContent ) || a ( g . getFirst ( ) ) ||
8 !== e && 46 !== e || ( g . remove ( ) , b . fire ( "saveSnapshot" ) ) , b . getSelection ( ) . fake ( f ) , d . data . preventDefault ( ) , d . cancel ( ) ) } } } function v ( a ) { for ( var b = 0 ; b < a . length ; b ++ ) { var c = a [ b ] ; c . getCommonAncestor ( ) . isReadOnly ( ) && a . splice ( b , 1 ) ; if ( ! c . collapsed ) { if ( c . startContainer . isReadOnly ( ) ) for ( var d = c . startContainer , e ; d && ! ( ( e = d . type == CKEDITOR . NODE _ELEMENT ) && d . is ( "body" ) || ! d . isReadOnly ( ) ) ; ) e && "false" == d . getAttribute ( "contentEditable" ) && c . setStartAfter ( d ) , d = d . getParent ( ) ; d = c . startContainer ; e = c . endContainer ; var g = c . startOffset ,
f = c . endOffset , h = c . clone ( ) ; d && d . type == CKEDITOR . NODE _TEXT && ( g >= d . getLength ( ) ? h . setStartAfter ( d ) : h . setStartBefore ( d ) ) ; e && e . type == CKEDITOR . NODE _TEXT && ( f ? h . setEndAfter ( e ) : h . setEndBefore ( e ) ) ; d = new CKEDITOR . dom . walker ( h ) ; d . evaluator = function ( d ) { if ( d . type == CKEDITOR . NODE _ELEMENT && d . isReadOnly ( ) ) { var e = c . clone ( ) ; c . setEndBefore ( d ) ; c . collapsed && a . splice ( b -- , 1 ) ; d . getPosition ( h . endContainer ) & CKEDITOR . POSITION _CONTAINS || ( e . setStartAfter ( d ) , e . collapsed || a . splice ( b + 1 , 0 , e ) ) ; return ! 0 } return ! 1 } ; d . next ( ) } } return a } var m =
"function" != typeof window . getSelection , M= 1 , w = CKEDITOR . tools . repeat ( " " , 7 ) , J = new RegExp ( w+ "( )?" , "g" ) , F , q , u , K = CKEDITOR . dom . walker . invisible ( 1 ) , D = function ( ) { function a ( b ) { return function ( a ) { var c = a . editor . createRange ( ) ; c . moveToClosestEditablePosition ( a . selected , b ) && a . editor . getSelection ( ) . selectRanges ( [ c ] ) ; return ! 1 } } function b ( a ) { return function ( b ) { var c = b . editor , d = c . createRange ( ) , e ; if ( ! c . readOnly ) return ( e = d . moveToClosestEditablePosition ( b . selected , a ) ) || ( e = d . moveToClosestEditablePosition ( b . selected ,
! a ) ) , e && c . getSelection ( ) . selectRanges ( [ d ] ) , c . fire ( "saveSnapshot" ) , b . selected . remove ( ) , e || ( d . moveToElementEditablePosition ( c . editable ( ) ) , c . getSelection ( ) . selectRanges ( [ d ] ) ) , c . fire ( "saveSnapshot" ) , ! 1 } } var c = a ( ) , d = a ( 1 ) ; return { 37 : c , 38 : c , 39 : d , 40 : d , 8 : b ( ) , 46 : b ( 1 ) } } ( ) ; CKEDITOR . on ( "instanceCreated" , function ( a ) { function b ( ) { var a = c . getSelection ( ) ; a && a . removeAllRanges ( ) } var c = a . editor ; c . on ( "contentDom" , function ( ) { function a ( ) { q = new CKEDITOR . dom . selection ( c . getSelection ( ) ) ; q . lock ( ) } function b ( ) { h . removeListener ( "mouseup" ,
b ) ; l . removeListener ( "mouseup" , b ) ; var a = CKEDITOR . document . $ . selection , c = a . createRange ( ) ; "None" != a . type && c . parentElement ( ) && c . parentElement ( ) . ownerDocument == f . $ && c . select ( ) } function d ( a ) { var b , c ; b = ( b = this . document . getActive ( ) ) ? "input" === b . getName ( ) || "textarea" === b . getName ( ) : ! 1 ; b || ( b = this . getSelection ( 1 ) , ( c = g ( b ) ) && ! c . equals ( p ) && ( b . selectElement ( c ) , a . data . preventDefault ( ) ) ) } function g ( a ) { a = a . getRanges ( ) [ 0 ] ; return a ? ( a = a . startContainer . getAscendant ( function ( a ) { return a . type == CKEDITOR . NODE _ELEMENT && a . hasAttribute ( "contenteditable" ) } ,
! 0 ) ) && "false" === a . getAttribute ( "contenteditable" ) ? a : null : null } var f= c . document , h = CKEDITOR . document , p = c . editable ( ) , t = f . getBody ( ) , l = f . getDocumentElement ( ) , H = p . isInline ( ) , n , q ; CKEDITOR . env . gecko && p . attachListener ( p , "focus" , function ( a ) { a . removeListener ( ) ; 0 !== n && ( a = c . getSelection ( ) . getNative ( ) ) && a . isCollapsed && a . anchorNode == p . $ && ( a = c . createRange ( ) , a . moveToElementEditStart ( p ) , a . select ( ) ) } , null , null , - 2 ) ; p. attachListener ( p , CKEDITOR . env . webkit || CKEDITOR . env . gecko ? "focusin" : "focus" , function ( ) { if ( n && ( CKEDITOR . env . webkit ||
CKEDITOR . env . gecko ) ) { n = c . _ . previousActive && c . _ . previousActive . equals ( f . getActive ( ) ) ; var a = null != c . _ . previousScrollTop && c . _ . previousScrollTop != p . $ . scrollTop ; CKEDITOR . env . webkit && n&& a && ( p . $ . scrollTop = c . _ . previousScrollTop ) } c . unlockSelection ( n) ; n = 0 } , null , null , - 1 ) ; p. attachListener ( p , "mousedown" , function ( ) { n = 0 } ) ; if ( CKEDITOR . env . ie || CKEDITOR . env . gecko || H) m ? p . attachListener ( p , "beforedeactivate" , a , null , null , - 1 ) : p . attachListener ( c , "selectionCheck" , a , null , null , - 1 ) , p. attachListener ( p , CKEDITOR . env . webkit || CKEDITOR . env . gecko ?
"focusout" : "blur" , function ( ) { var a = q&& ( q . isFake || 2 > q . getRanges ( ) . length ) ; CKEDITOR . env . gecko && ! H && a || ( c . lockSelection ( q) , n = 1 ) } , null , null , - 1 ) , p. attachListener ( p , "mousedown" , function ( ) { n = 0 } ) ; if ( CKEDITOR . env . ie && ! H) { var v ; p . attachListener ( p , "mousedown" , function ( a ) { 2 == a . data . $ . button && ( ( a = c . document . getSelection ( ) ) && a . getType ( ) != CKEDITOR . SELECTION _NONE || ( v = c . window . getScrollPosition ( ) ) ) } ) ; p. attachListener ( p , "mouseup" , function ( a ) { 2 == a . data . $ . button && v && ( c . document . $ . documentElement . scrollLeft = v . x , c . document . $ . documentElement . scrollTop =
v. y ) ; v = null } ) ; if ( "BackCompat" != f . $ . compatMode ) { if ( CKEDITOR . env . ie7Compat || CKEDITOR . env . ie6Compat ) { var u , y ; l . on ( "mousedown" , function ( a ) { function b ( a ) { a = a . data . $ ; if ( u ) { var c = t . $ . createTextRange ( ) ; try { c . moveToPoint ( a . clientX , a . clientY ) } catch ( d ) { } u . setEndPoint ( 0 > y . compareEndPoints ( "StartToStart" , c ) ? "EndToEnd" : "StartToStart" , c ) ; u . select ( ) } } function c ( ) { l . removeListener ( "mousemove" , b ) ; h . removeListener ( "mouseup" , c ) ; l . removeListener ( "mouseup" , c ) ; u . select ( ) } a = a . data ; if ( a . getTarget ( ) . is ( "html" ) && a . $ . y < l . $ . clientHeight &&
a . $ . x < l . $ . clientWidth ) { u = t . $ . createTextRange ( ) ; try { u . moveToPoint ( a . $ . clientX , a . $ . clientY ) } catch ( d ) { } y = u . duplicate ( ) ; l . on ( "mousemove" , b ) ; h . on ( "mouseup" , c ) ; l . on ( "mouseup" , c ) } } ) } if ( 7 < CKEDITOR . env . version && 11 > CKEDITOR . env . version ) l . on ( "mousedown" , function ( a ) { a . data . getTarget ( ) . is ( "html" ) && ( h . on ( "mouseup" , b ) , l . on ( "mouseup" , b ) ) } ) } } p. attachListener ( p , "selectionchange" , e , c ) ; p. attachListener ( p , "keyup" , k , c ) ; p . attachListener ( p , "touchstart" , k , c ) ; p . attachListener ( p , "touchend" , k , c ) ; CKEDITOR . env . ie && p. attachListener ( p ,
"keydown" , d , c ) ; p. attachListener ( p , CKEDITOR . env . webkit || CKEDITOR . env . gecko ? "focusin" : "focus" , function ( ) { c . forceNextSelectionCheck ( ) ; c . selectionChange ( 1 ) } ) ; if ( H && ( CKEDITOR . env . webkit || CKEDITOR . env . gecko ) ) { var w; p . attachListener ( p , "mousedown" , function ( ) { w = 1 } ) ; p . attachListener ( f . getDocumentElement ( ) , "mouseup" , function ( ) { w&& k . call ( c ) ; w = 0 } ) } else p . attachListener ( CKEDITOR . env . ie ? p: f . getDocumentElement ( ) , "mouseup" , k , c ) ; CKEDITOR . env . webkit && p. attachListener ( f , "keydown" , function ( a ) { switch ( a . data . getKey ( ) ) { case 13 : case 33 : case 34 : case 35 : case 36 : case 37 : case 39 : case 8 : case 45 : case 46 : p . hasFocus &&
x( p ) } } , null , null , - 1 ) ; p. attachListener ( p , "keydown" , G ( c ) , null , null , - 1 ) } ) ; c . on ( "setData" , function ( ) { c . unlockSelection ( ) ; CKEDITOR . env . webkit && b ( ) } ) ; c . on ( "contentDomUnload" , function ( ) { c . unlockSelection ( ) } ) ; if ( CKEDITOR . env . ie9Compat ) c . on ( "beforeDestroy" , b , null , null , 9 ) ; c . on ( "dataReady" , function ( ) { delete c . _ . fakeSelection ; delete c . _ . hiddenSelectionContainer ; c . selectionChange ( 1 ) } ) ; c . on ( "loadSnapshot" , function ( ) { var a = CKEDITOR . dom . walker . nodeType ( CKEDITOR . NODE _ELEMENT ) , b = c . editable ( ) . getLast ( a ) ; b && b . hasAttribute ( "data-cke-hidden-sel" ) &&
( b . remove ( ) , CKEDITOR . env . gecko && ( a = c . editable ( ) . getFirst ( a ) ) && a . is ( "br" ) && a . getAttribute ( "_moz_editor_bogus_node" ) && a . remove ( ) ) } , null , null , 100 ) ; c . on ( "key" , function ( a ) { if ( "wysiwyg" == c . mode ) { var b = c . getSelection ( ) ; if ( b . isFake ) { var d = D [ a . data . keyCode ] ; if ( d ) return d ( { editor : c , selected : b . getSelectedElement ( ) , selection : b , keyEvent : a } ) } } } ) } ) ; if ( CKEDITOR . env . webkit ) CKEDITOR . on ( "instanceReady" , function ( a ) { var b = a . editor ; b . on ( "selectionChange" , function ( ) { var a = b . editable ( ) , c = a . getCustomData ( "cke-fillingChar" ) ;
c && ( c . getCustomData ( "ready" ) ? ( x ( a ) , a . editor . fire ( "selectionCheck" ) ) : c . setCustomData ( "ready" , 1 ) ) } , null , null , - 1 ) ; b . on ( "beforeSetMode" , function ( ) { x ( b . editable ( ) ) } , null , null , - 1 ) ; b . on ( "getSnapshot" , function ( a ) { a . data && ( a . data = y ( a . data ) ) } , b , null , 20 ) ; b . on ( "toDataFormat" , function ( a ) { a . data . dataValue = y ( a . data . dataValue ) } , null , null , 0 ) } ) ; CKEDITOR . editor . prototype . selectionChange = function ( a ) { ( a ? e : k ) . call ( this ) } ; CKEDITOR . editor . prototype . getSelection = function ( a ) { return ! this . _ . savedSelection && ! this . _ . fakeSelection ||
a ? ( a = this . editable ( ) ) && "wysiwyg" == this . mode && "recreating" !== this . status ? new CKEDITOR . dom . selection ( a ) : null : this . _ . savedSelection || this . _ . fakeSelection } ; CKEDITOR . editor . prototype . getSelectedRanges = function ( a ) { var b = this . getSelection ( ) ; return b && b . getRanges ( a ) || [ ] } ; CKEDITOR . editor . prototype . lockSelection = function ( a ) { a = a || this . getSelection ( 1 ) ; return a . getType ( ) != CKEDITOR . SELECTION _NONE ? ( ! a . isLocked && a . lock ( ) , this . _ . savedSelection = a , ! 0 ) : ! 1 } ; CKEDITOR . editor . prototype . unlockSelection = function ( a ) { var b =
this . _ . savedSelection ; return b ? ( b . unlock ( a ) , delete this . _ . savedSelection , ! 0 ) : ! 1 } ; CKEDITOR . editor . prototype . forceNextSelectionCheck = function ( ) { delete this . _ . selectionPreviousPath } ; CKEDITOR . dom . document . prototype . getSelection = function ( ) { return new CKEDITOR . dom . selection ( this ) } ; CKEDITOR . dom . range . prototype . select = function ( ) { var a = this . root instanceof CKEDITOR . editable ? this . root . editor . getSelection ( ) : new CKEDITOR . dom . selection ( this . root ) ; a . selectRanges ( [ this ] ) ; return a } ; CKEDITOR . SELECTION _NONE = 1 ; CKEDITOR . SELECTION _TEXT =
2 ; CKEDITOR . SELECTION _ELEMENT = 3 ; CKEDITOR . dom . selection = function ( a ) { if ( a instanceof CKEDITOR . dom . selection ) { var b = a ; a = a . root } var c = a instanceof CKEDITOR . dom . element ; this . rev = b ? b . rev : L ++ ; this . document = a instanceof CKEDITOR . dom . document ? a : a . getDocument ( ) ; this . root = c ? a : this . document . getBody ( ) ; this . isLocked = 0 ; this . _ = { cache : { } } ; if ( b ) return CKEDITOR . tools . extend ( this . _ . cache , b . _ . cache ) , this . isFake = b . isFake , this . isLocked = b . isLocked , this ; a = this . getNative ( ) ; var d , e ; if ( a ) if ( a . getRangeAt ) d = ( e = a . rangeCount && a . getRangeAt ( 0 ) ) &&
new CKEDITOR . dom . node ( e . commonAncestorContainer ) ; else { try { e = a . createRange ( ) } catch ( f ) { } d = e && CKEDITOR . dom . element . get ( e . item && e . item ( 0 ) || e . parentElement ( ) ) } if ( ! d || d . type != CKEDITOR . NODE _ELEMENT && d . type != CKEDITOR . NODE _TEXT || ! this . root . equals ( d ) && ! this . root . contains ( d ) ) this . _ . cache . type = CKEDITOR . SELECTION _NONE , this . _ . cache . startElement = null , this . _ . cache . selectedElement = null , this . _ . cache . selectedText = "" , this . _ . cache . ranges = new CKEDITOR . dom . rangeList ; return this } ; var z = { img : 1 , hr : 1 , li : 1 , table : 1 , tr : 1 , td : 1 ,
th : 1 , embed : 1 , object : 1 , ol : 1 , ul : 1 , a : 1 , input : 1 , form : 1 , select : 1 , textarea : 1 , button : 1 , fieldset : 1 , thead : 1 , tfoot : 1 } ; CKEDITOR . tools . extend ( CKEDITOR . dom . selection , { _removeFillingCharSequenceString : B, _createFillingCharSequenceNode : f , FILLING _CHAR _SEQUENCE : v } ) ; CKEDITOR . dom . selection . prototype = { getNative : function ( ) { return void 0 !== this . _ . cache . nativeSel ? this . _ . cache . nativeSel : this . _ . cache . nativeSel = m ? this . document . $ . selection : this . document . getWindow ( ) . $ . getSelection ( ) } , getType : m ? function ( ) { var a = this . _ . cache ; if ( a . type ) return a . type ;
2 ; CKEDITOR . SELECTION _ELEMENT = 3 ; CKEDITOR . dom . selection = function ( a ) { if ( a instanceof CKEDITOR . dom . selection ) { var b = a ; a = a . root } var c = a instanceof CKEDITOR . dom . element ; this . rev = b ? b . rev : M ++ ; this . document = a instanceof CKEDITOR . dom . document ? a : a . getDocument ( ) ; this . root = c ? a : this . document . getBody ( ) ; this . isLocked = 0 ; this . _ = { cache : { } } ; if ( b ) return CKEDITOR . tools . extend ( this . _ . cache , b . _ . cache ) , this . isFake = b . isFake , this . isLocked = b . isLocked , this ; a = this . getNative ( ) ; var d , e ; if ( a ) if ( a . getRangeAt ) d = ( e = a . rangeCount && a . getRangeAt ( 0 ) ) &&
new CKEDITOR . dom . node ( e . commonAncestorContainer ) ; else { try { e = a . createRange ( ) } catch ( g ) { } d = e && CKEDITOR . dom . element . get ( e . item && e . item ( 0 ) || e . parentElement ( ) ) } if ( ! d || d . type != CKEDITOR . NODE _ELEMENT && d . type != CKEDITOR . NODE _TEXT || ! this . root . equals ( d ) && ! this . root . contains ( d ) ) this . _ . cache . type = CKEDITOR . SELECTION _NONE , this . _ . cache . startElement = null , this . _ . cache . selectedElement = null , this . _ . cache . selectedText = "" , this . _ . cache . ranges = new CKEDITOR . dom . rangeList ; return this } ; var B = { img : 1 , hr : 1 , li : 1 , table : 1 , tr : 1 , td : 1 ,
th : 1 , embed : 1 , object : 1 , ol : 1 , ul : 1 , a : 1 , input : 1 , form : 1 , select : 1 , textarea : 1 , button : 1 , fieldset : 1 , thead : 1 , tfoot : 1 } ; CKEDITOR . tools . extend ( CKEDITOR . dom . selection , { _removeFillingCharSequenceString : y, _createFillingCharSequenceNode : g , FILLING _CHAR _SEQUENCE : w } ) ; CKEDITOR . dom . selection . prototype = { getNative : function ( ) { return void 0 !== this . _ . cache . nativeSel ? this . _ . cache . nativeSel : this . _ . cache . nativeSel = m ? this . document . $ . selection : this . document . getWindow ( ) . $ . getSelection ( ) } , getType : m ? function ( ) { var a = this . _ . cache ; if ( a . type ) return a . type ;
var b = CKEDITOR . SELECTION _NONE ; try { var c = this . getNative ( ) , d = c . type ; "Text" == d && ( b = CKEDITOR . SELECTION _TEXT ) ; "Control" == d && ( b = CKEDITOR . SELECTION _ELEMENT ) ; c . createRange ( ) . parentElement ( ) && ( b = CKEDITOR . SELECTION _TEXT ) } catch ( e ) { } return a . type = b } : function ( ) { var a = this . _ . cache ; if ( a . type ) return a . type ; var b = CKEDITOR . SELECTION _TEXT , c = this . getNative ( ) ; if ( ! c || ! c . rangeCount ) b = CKEDITOR . SELECTION _NONE ; else if ( 1 == c . rangeCount ) { var c = c . getRangeAt ( 0 ) , d = c . startContainer ; d == c . endContainer && 1 == d . nodeType && 1 == c . endOffset -
c . startOffset && z [ d . childNodes [ c . startOffset ] . nodeName . toLowerCase ( ) ] && ( b = CKEDITOR . SELECTION _ELEMENT ) } return a . type = b } , getRanges : function ( ) { var a = m ? function ( ) { function a ( b ) { return ( new CKEDITOR . dom . node ( b ) ) . getIndex ( ) } var b = function ( b , c ) { b = b . duplicate ( ) ; b . collapse ( c ) ; var d = b . parentElement ( ) ; if ( ! d . hasChildNodes ( ) ) return { container : d , offset : 0 } ; for ( var e = d . children , f, g , h = b . duplicate ( ) , k = 0 , l = e . length - 1 , t = - 1 , q, m ; k <= l ; ) if ( t = Math . floor ( ( k + l ) / 2 ) , f = e [ t ] , h . moveToElementText ( f) , q = h . compareEndPoints ( "StartToStart" ,
b ) , 0 < q ) l = t - 1 ; else if ( 0 > q ) k = t + 1 ; else return { container : d , offset : a ( f ) } ; if ( - 1 == t || t == e . length - 1 && 0 > q ) { h . moveToElementText ( d ) ; h . setEndPoint ( "StartToStart" , b ) ; h = h . text . replace ( /(\r\n|\r)/g , "\n" ) . length ; e = d . childNodes ; if ( ! h ) return f = e [ e . length - 1 ] , f . nodeType != CKEDITOR . NODE _TEXT ? { container : d , offset : e . length } : { container : f, offset : f . nodeValue . length } ; for ( d = e . length ; 0 < h && 0 < d ; ) g= e [ -- d ] , g . nodeType == CKEDITOR . NODE _TEXT && ( m= g , h -= g . nodeValue . length ) ; return { container : m , offset : - h } } h . collapse ( 0 < q ? ! 0 : ! 1 ) ; h . setEndPoint ( 0 <
q ? "StartToStart" : "EndToStart" , b ) ; h = h . text . replace ( /(\r\n|\r)/g , "\n" ) . length ; if ( ! h ) return { container : d , offset : a ( f) + ( 0 < q ? 0 : 1 ) } ; for ( ; 0 < h ; ) try { g= f [ 0 < q ? "previousSibling" : "nextSibling" ] , g . nodeType == CKEDITOR . NODE _TEXT && ( h -= g. nodeValue . length , m = g ) , f = g } catch ( w ) { return { container : d , offset : a ( f) } } return { container : m , offset : 0 < q ? - h : m . nodeValue . length + h } } ; return function ( ) { var a = this . getNative ( ) , c = a && a . createRange ( ) , d = this . getType ( ) ; if ( ! a ) return [ ] ; if ( d == CKEDITOR . SELECTION _TEXT ) return a = new CKEDITOR . dom . range ( this . root ) ,
d = b ( c , ! 0 ) , a . setStart ( new CKEDITOR . dom . node ( d . container ) , d . offset ) , d = b ( c ) , a . setEnd ( new CKEDITOR . dom . node ( d . container ) , d . offset ) , a . endContainer . getPosition ( a . startContainer ) & CKEDITOR . POSITION _PRECEDING && a . endOffset <= a . startContainer . getIndex ( ) && a . collapse ( ) , [ a ] ; if ( d == CKEDITOR . SELECTION _ELEMENT ) { for ( var d = [ ] , e = 0 ; e < c . length ; e ++ ) { for ( var f= c . item ( e ) , g = f . parentNode , h = 0 , a = new CKEDITOR . dom . range ( this . root ) ; h < g. childNodes . length && g . childNodes [ h ] != f ; h ++ ) ; a . setStart ( new CKEDITOR . dom . node ( g ) , h ) ; a . setEnd ( new CKEDITOR . dom . node ( g ) ,
h + 1 ) ; d . push ( a ) } return d } return [ ] } } ( ) : function ( ) { var a = [ ] , b , c = this . getNative ( ) ; if ( ! c ) return a ; for ( var d = 0 ; d < c . rangeCount ; d ++ ) { var e = c . getRangeAt ( d ) ; b = new CKEDITOR . dom . range ( this . root ) ; b . setStart ( new CKEDITOR . dom . node ( e . startContainer ) , e . startOffset ) ; b . setEnd ( new CKEDITOR . dom . node ( e . endContainer ) , e . endOffset ) ; a . push ( b ) } return a } ; return function ( b ) { var c = this . _ . cache , d = c . ranges ; d || ( c . ranges = d = new CKEDITOR . dom . rangeList ( a . call ( this ) ) ) ; return b ? r ( new CKEDITOR . dom . rangeList ( d . slice ( ) ) ) : d } } ( ) , getStartElement : function ( ) { var a =
c . startOffset && B [ d . childNodes [ c . startOffset ] . nodeName . toLowerCase ( ) ] && ( b = CKEDITOR . SELECTION _ELEMENT ) } return a . type = b } , getRanges : function ( ) { var a = m ? function ( ) { function a ( b ) { return ( new CKEDITOR . dom . node ( b ) ) . getIndex ( ) } var b = function ( b , c ) { b = b . duplicate ( ) ; b . collapse ( c ) ; var d = b . parentElement ( ) ; if ( ! d . hasChildNodes ( ) ) return { container : d , offset : 0 } ; for ( var e = d . children , g, f , h = b . duplicate ( ) , k = 0 , l = e . length - 1 , t = - 1 , m, n ; k <= l ; ) if ( t = Math . floor ( ( k + l ) / 2 ) , g = e [ t ] , h . moveToElementText ( g) , m = h . compareEndPoints ( "StartToStart" ,
b ) , 0 < m ) l = t - 1 ; else if ( 0 > m ) k = t + 1 ; else return { container : d , offset : a ( g ) } ; if ( - 1 == t || t == e . length - 1 && 0 > m ) { h . moveToElementText ( d ) ; h . setEndPoint ( "StartToStart" , b ) ; h = h . text . replace ( /(\r\n|\r)/g , "\n" ) . length ; e = d . childNodes ; if ( ! h ) return g = e [ e . length - 1 ] , g . nodeType != CKEDITOR . NODE _TEXT ? { container : d , offset : e . length } : { container : g, offset : g . nodeValue . length } ; for ( d = e . length ; 0 < h && 0 < d ; ) f= e [ -- d ] , f . nodeType == CKEDITOR . NODE _TEXT && ( n= f , h -= f . nodeValue . length ) ; return { container : n , offset : - h } } h . collapse ( 0 < m ? ! 0 : ! 1 ) ; h . setEndPoint ( 0 <
m ? "StartToStart" : "EndToStart" , b ) ; h = h . text . replace ( /(\r\n|\r)/g , "\n" ) . length ; if ( ! h ) return { container : d , offset : a ( g) + ( 0 < m ? 0 : 1 ) } ; for ( ; 0 < h ; ) try { f= g [ 0 < m ? "previousSibling" : "nextSibling" ] , f . nodeType == CKEDITOR . NODE _TEXT && ( h -= f. nodeValue . length , n = f ) , g = f } catch ( q ) { return { container : d , offset : a ( g) } } return { container : n , offset : 0 < m ? - h : n . nodeValue . length + h } } ; return function ( ) { var a = this . getNative ( ) , c = a && a . createRange ( ) , d = this . getType ( ) ; if ( ! a ) return [ ] ; if ( d == CKEDITOR . SELECTION _TEXT ) return a = new CKEDITOR . dom . range ( this . root ) ,
d = b ( c , ! 0 ) , a . setStart ( new CKEDITOR . dom . node ( d . container ) , d . offset ) , d = b ( c ) , a . setEnd ( new CKEDITOR . dom . node ( d . container ) , d . offset ) , a . endContainer . getPosition ( a . startContainer ) & CKEDITOR . POSITION _PRECEDING && a . endOffset <= a . startContainer . getIndex ( ) && a . collapse ( ) , [ a ] ; if ( d == CKEDITOR . SELECTION _ELEMENT ) { for ( var d = [ ] , e = 0 ; e < c . length ; e ++ ) { for ( var g= c . item ( e ) , f = g . parentNode , h = 0 , a = new CKEDITOR . dom . range ( this . root ) ; h < f. childNodes . length && f . childNodes [ h ] != g ; h ++ ) ; a . setStart ( new CKEDITOR . dom . node ( f ) , h ) ; a . setEnd ( new CKEDITOR . dom . node ( f ) ,
h + 1 ) ; d . push ( a ) } return d } return [ ] } } ( ) : function ( ) { var a = [ ] , b , c = this . getNative ( ) ; if ( ! c ) return a ; for ( var d = 0 ; d < c . rangeCount ; d ++ ) { var e = c . getRangeAt ( d ) ; b = new CKEDITOR . dom . range ( this . root ) ; b . setStart ( new CKEDITOR . dom . node ( e . startContainer ) , e . startOffset ) ; b . setEnd ( new CKEDITOR . dom . node ( e . endContainer ) , e . endOffset ) ; a . push ( b ) } return a } ; return function ( b ) { var c = this . _ . cache , d = c . ranges ; d || ( c . ranges = d = new CKEDITOR . dom . rangeList ( a . call ( this ) ) ) ; return b ? v ( new CKEDITOR . dom . rangeList ( d . slice ( ) ) ) : d } } ( ) , getStartElement : function ( ) { var a =
this . _ . cache ; if ( void 0 !== a . startElement ) return a . startElement ; var b ; switch ( this . getType ( ) ) { case CKEDITOR . SELECTION _ELEMENT : return this . getSelectedElement ( ) ; case CKEDITOR . SELECTION _TEXT : var c = this . getRanges ( ) [ 0 ] ; if ( c ) { if ( c . collapsed ) b = c . startContainer , b . type != CKEDITOR . NODE _ELEMENT && ( b = b . getParent ( ) ) ; else { for ( c . optimize ( ) ; b = c . startContainer , c . startOffset == ( b . getChildCount ? b . getChildCount ( ) : b . getLength ( ) ) && ! b . isBlockBoundary ( ) ; ) c . setStartAfter ( b ) ; b = c . startContainer ; if ( b . type != CKEDITOR . NODE _ELEMENT ) return b . getParent ( ) ;
if ( ( b = b . getChild ( c . startOffset ) ) && b . type == CKEDITOR . NODE _ELEMENT ) for ( c = b . getFirst ( ) ; c && c . type == CKEDITOR . NODE _ELEMENT ; ) b = c , c = c . getFirst ( ) ; else b = c . startContainer } b = b . $ } } return a . startElement = b ? new CKEDITOR . dom . element ( b ) : null } , getSelectedElement : function ( ) { var a = this . _ . cache ; if ( void 0 !== a . selectedElement ) return a . selectedElement ; var b = this , c = CKEDITOR . tools . tryThese ( function ( ) { return b . getNative ( ) . createRange ( ) . item ( 0 ) } , function ( ) { for ( var a = b . getRanges ( ) [ 0 ] . clone ( ) , c , d , e = 2 ; e && ! ( ( c = a . getEnclosedNode ( ) ) &&
c . type == CKEDITOR . NODE _ELEMENT && z [ c . getName ( ) ] && ( d = c ) ) ; e -- ) a . shrink ( CKEDITOR . SHRINK _ELEMENT ) ; return d && d . $ } ) ; return a . selectedElement = c ? new CKEDITOR . dom . element ( c ) : null } , getSelectedText : function ( ) { var a = this . _ . cache ; if ( void 0 !== a . selectedText ) return a . selectedText ; var b = this . getNative ( ) , b = m ? "Control" == b . type ? "" : b . createRange ( ) . text : b . toString ( ) ; return a . selectedText = b } , lock : function ( ) { this . getRanges ( ) ; this . getStartElement ( ) ; this . getSelectedElement ( ) ; this . getSelectedText ( ) ; this . _ . cache . nativeSel = null ;
this . isLocked = 1 } , unlock : function ( a ) { if ( this . isLocked ) { if ( a ) var b = this . getSelectedElement ( ) , c = this . getRanges ( ) , e = this . isFake ; this . isLocked = 0 ; this . reset ( ) ; a && ( a = b || c [ 0 ] && c [ 0 ] . getCommonAncestor ( ) ) && a . getAscendant ( "body" , 1 ) && ( ( a = this . root . editor ) && a . plugins . tableselection && a . plugins . tableselection . isSupportedEnvironment ( a ) && d ( c ) ? g . call ( this , c ) : e ? this . fake ( b ) : b && 2 > c . length ? this . selectElement ( b ) : this . selectRanges ( c ) ) } } , reset : function ( ) { this . _ . cache = { } ; this . isFake = 0 ; var a = this . root . editor ; if ( a && a . _ . fakeSelection ) if ( this . rev ==
a . _ . fakeSelection . rev ) { delete a . _ . fakeSelection ; var b = a . _ . hiddenSelectionContainer ; if ( b ) { var c = a . checkDirty ( ) ; a . fire ( "lockSnapshot" ) ; b . remove ( ) ; a . fire ( "unlockSnapshot" ) ; ! c && a . resetDirty ( ) } delete a . _ . hiddenSelectionContainer } else CKEDITOR . warn ( "selection-fake-reset" ) ; this . rev = L ++ } , selectElement : function ( a ) { var b = new CKEDITOR . dom . range ( this . root ) ; b . setStartBefore ( a ) ; b . setEndAfter ( a ) ; this . selectRanges ( [ b ] ) } , selectRanges : function ( a ) { var b = this . root . editor , c = b && b . _ . hiddenSelectionContainer ; this . reset ( ) ;
if ( c ) for ( var c = this . root , e , h = 0 ; h < a . length ; ++ h ) e = a [ h ] , e . endContainer . equals ( c ) && ( e . endOffset = Math . min ( e . endOffset , c . getChildCount ( ) ) ) ; if ( a . length ) if ( this . isLocked ) { var k = CKEDITOR . document . getActive ( ) ; this . unlock ( ) ; this . selectRanges ( a ) ; this . lock ( ) ; k && ! k . equals ( this . root ) && k . focus ( ) } else { var x; a : { var l , M ; if ( 1 == a . length && ! ( M = a [ 0 ] ) . collapsed && ( x= M . getEnclosedNode ( ) ) && x . type == CKEDITOR . NODE _ELEMENT && ( M= M . clone ( ) , M . shrink ( CKEDITOR . SHRINK _ELEMENT , ! 0 ) , ( l= M . getEnclosedNode ( ) ) && l . type == CKEDITOR . NODE _ELEMENT &&
( x= l ) , "false" == x . getAttribute ( "contenteditable" ) ) ) break a ; x= void 0 } if ( x ) this . fake ( x ) ; else if ( b && b . plugins . tableselection && b . plugins . tableselection . isSupportedEnvironment ( b ) && d ( a ) && ! G && ! a [ 0 ] . _getTableElement ( { table : 1 } ) . hasAttribute ( "data-cke-tableselection-ignored" ) ) g . call ( this , a ) ; else { if ( m ) { l = CKEDITOR . dom . walker . whitespaces ( ! 0 ) ; x= /\ufeff|\u00a0/ ; M = { table : 1 , tbody : 1 , tr : 1 } ; 1 < a . length && ( b = a [ a . length - 1 ] , a [ 0 ] . setEnd ( b . endContainer , b . endOffset ) ) ; b = a [ 0 ] ; a = b . collapsed ; var n, A , p ; if ( ( c = b . getEnclosedNode ( ) ) &&
c . type == CKEDITOR . NODE _ELEMENT && c . getName ( ) in z && ( ! c . is ( "a" ) || ! c . getText ( ) ) ) try { p = c . $ . createControlRange ( ) ; p. addElement ( c . $ ) ; p . select ( ) ; return } catch ( r ) { } if ( b . startContainer . type == CKEDITOR . NODE _ELEMENT && b . startContainer . getName ( ) in M || b . endContainer . type == CKEDITOR . NODE _ELEMENT && b . endContainer . getName ( ) in M ) b . shrink ( CKEDITOR . NODE _ELEMENT , ! 0 ) , a = b . collapsed ; p= b . createBookmark ( ) ; M = p . startNode ; a || ( k = p . endNode ) ; p = b . document . $ . body . createTextRange ( ) ; p. moveToElementText ( M . $ ) ; p . moveStart ( "character" , 1 ) ; k ? ( x =
b . document . $ . body . createTextRange ( ) , x. moveToElementText ( k . $ ) , p . setEndPoint ( "EndToEnd" , x ) , p . moveEnd ( "character" , - 1 ) ) : ( n= M . getNext ( l ) , A = M . hasAscendant ( "pre" ) , n = ! ( n && n . getText && n . getText ( ) . match ( x ) ) && ( A || ! M . hasPrevious ( ) || M . getPrevious ( ) . is && M . getPrevious ( ) . is ( "br" ) ) , A = b . document . createElement ( "span" ) , A. setHtml ( "\x26#65279;" ) , A . insertBefore ( M ) , n && b . document . createText ( " " ) . insertBefore ( M) ) ; b . setStartBefore ( M ) ; M . remove ( ) ; a ? ( n ? ( p . moveStart ( "character" , - 1 ) , p . select ( ) , b . document . $ . selection . clear ( ) ) : p . select ( ) ,
b . moveToPosition ( A , CKEDITOR . POSITION _BEFORE _START ) , A . remove ( ) ) : ( b . setEndBefore ( k ) , k . remove ( ) , p . select ( ) ) } else { k = this . getNative ( ) ; if ( ! k ) return ; this . removeAllRanges ( ) ; for ( p= 0 ; p < a . length ; p ++ ) { if ( p < a . length - 1 && ( n = a [ p ] , A = a [ p + 1 ] , x = n . clone ( ) , x . setStart ( n . endContainer , n . endOffset ) , x . setEnd ( A . startContainer , A . startOffset ) , ! x . collapsed && ( x . shrink ( CKEDITOR . NODE _ELEMENT , ! 0 ) , b = x. getCommonAncestor ( ) , x = x . getEnclosedNode ( ) , b . isReadOnly ( ) || x&& x . isReadOnly ( ) ) ) ) { A . setStart ( n . startContainer , n . startOffset ) ; a . splice ( p -- ,
1 ) ; continue } b = a [ p] ; A = this . document . $ . createRange ( ) ; b . collapsed && CKEDITOR . env . webkit && q( b ) && ( x = f ( this . root ) , b . insertNode ( x) , ( n = x . getNext ( ) ) && ! x . getPrevious ( ) && n . type == CKEDITOR . NODE _ELEMENT && "br" == n. getName ( ) ? ( w ( this . root ) , b . moveToPosition ( n , CKEDITOR . POSITION _BEFORE _START ) ) : b . moveToPosition ( x , CKEDITOR . POSITION _AFTER _END ) ) ; A . setStart ( b . startContainer . $ , b . startOffset ) ; try { A . setEnd ( b . endContainer . $ , b . endOffset ) } catch ( u ) { if ( 0 <= u . toString ( ) . indexOf ( "NS_ERROR_ILLEGAL_VALUE" ) ) b . collapse ( 1 ) , A . setEnd ( b . endContainer . $ ,
b . endOffset ) ; else throw u ; } k . addRange ( A ) } } this . reset ( ) ; this . root . fire ( "selectionchange" ) } } } , fake : function ( a , b ) { var c = this . root . editor ; void 0 === b && a . hasAttribute ( "aria-label" ) && ( b = a . getAttribute ( "aria-label" ) ) ; this . reset ( ) ; y ( c , b ) ; var d = this . _ . cache , e = new CKEDITOR . dom . range ( this . root ) ; e . setStartBefore ( a ) ; e . setEndAfter ( a ) ; d . ranges = new CKEDITOR . dom . rangeList ( e ) ; d . selectedElement = d . startElement = a ; d . type = CKEDITOR . SELECTION _ELEMENT ; d . selectedText = d . nativeSel = null ; this . isFake = 1 ; this . rev = L ++ ; c . _ . fakeSelection =
c . type == CKEDITOR . NODE _ELEMENT && B [ c . getName ( ) ] && ( d = c ) ) ; e -- ) a . shrink ( CKEDITOR . SHRINK _ELEMENT ) ; return d && d . $ } ) ; return a . selectedElement = c ? new CKEDITOR . dom . element ( c ) : null } , getSelectedText : function ( ) { var a = this . _ . cache ; if ( void 0 !== a . selectedText ) return a . selectedText ; var b = this . getNative ( ) , b = m ? "Control" == b . type ? "" : b . createRange ( ) . text : b . toString ( ) ; return a . selectedText = b } , lock : function ( ) { this . getRanges ( ) ; this . getStartElement ( ) ; this . getSelectedElement ( ) ; this . getSelectedText ( ) ; this . _ . cache . nativeSel = null ;
this . isLocked = 1 } , unlock : function ( a ) { if ( this . isLocked ) { if ( a ) var b = this . getSelectedElement ( ) , c = this . getRanges ( ) , e = this . isFake ; this . isLocked = 0 ; this . reset ( ) ; a && ( a = b || c [ 0 ] && c [ 0 ] . getCommonAncestor ( ) ) && a . getAscendant ( "body" , 1 ) && ( ( a = this . root . editor ) && a . plugins . tableselection && a . plugins . tableselection . isSupportedEnvironment ( a ) && d ( c ) ? f . call ( this , c ) : e ? this . fake ( b ) : b && 2 > c . length ? this . selectElement ( b ) : this . selectRanges ( c ) ) } } , reset : function ( ) { this . _ . cache = { } ; this . isFake = 0 ; var a = this . root . editor ; if ( a && a . _ . fakeSelection ) if ( this . rev ==
a . _ . fakeSelection . rev ) { delete a . _ . fakeSelection ; var b = a . _ . hiddenSelectionContainer ; if ( b ) { var c = a . checkDirty ( ) ; a . fire ( "lockSnapshot" ) ; b . remove ( ) ; a . fire ( "unlockSnapshot" ) ; ! c && a . resetDirty ( ) } delete a . _ . hiddenSelectionContainer } else CKEDITOR . warn ( "selection-fake-reset" ) ; this . rev = M ++ } , selectElement : function ( a ) { var b = new CKEDITOR . dom . range ( this . root ) ; b . setStartBefore ( a ) ; b . setEndAfter ( a ) ; this . selectRanges ( [ b ] ) } , selectRanges : function ( a ) { var b = this . root . editor , c = b && b . _ . hiddenSelectionContainer ; this . reset ( ) ;
if ( c ) for ( var c = this . root , e , h = 0 ; h < a . length ; ++ h ) e = a [ h ] , e . endContainer . equals ( c ) && ( e . endOffset = Math . min ( e . endOffset , c . getChildCount ( ) ) ) ; if ( a . length ) if ( this . isLocked ) { var k = CKEDITOR . document . getActive ( ) ; this . unlock ( ) ; this . selectRanges ( a ) ; this . lock ( ) ; k && ! k . equals ( this . root ) && k . focus ( ) } else { var r; a : { var E , n ; if ( 1 == a . length && ! ( n = a [ 0 ] ) . collapsed && ( r= n . getEnclosedNode ( ) ) && r . type == CKEDITOR . NODE _ELEMENT && ( n= n . clone ( ) , n . shrink ( CKEDITOR . SHRINK _ELEMENT , ! 0 ) , ( E= n . getEnclosedNode ( ) ) && E . type == CKEDITOR . NODE _ELEMENT &&
( r= E ) , "false" == r . getAttribute ( "contenteditable" ) ) ) break a ; r= void 0 } if ( r ) this . fake ( r ) ; else if ( b && b . plugins . tableselection && b . plugins . tableselection . isSupportedEnvironment ( b ) && d ( a ) && ! F && ! a [ 0 ] . _getTableElement ( { table : 1 } ) . hasAttribute ( "data-cke-tableselection-ignored" ) ) f . call ( this , a ) ; else { if ( m ) { E = CKEDITOR . dom . walker . whitespaces ( ! 0 ) ; r= /\ufeff|\u00a0/ ; n = { table : 1 , tbody : 1 , tr : 1 } ; 1 < a . length && ( b = a [ a . length - 1 ] , a [ 0 ] . setEnd ( b . endContainer , b . endOffset ) ) ; b = a [ 0 ] ; a = b . collapsed ; var p, C , q ; if ( ( c = b . getEnclosedNode ( ) ) &&
c . type == CKEDITOR . NODE _ELEMENT && c . getName ( ) in B && ( ! c . is ( "a" ) || ! c . getText ( ) ) ) try { q = c . $ . createControlRange ( ) ; q. addElement ( c . $ ) ; q . select ( ) ; return } catch ( v ) { } if ( b . startContainer . type == CKEDITOR . NODE _ELEMENT && b . startContainer . getName ( ) in n || b . endContainer . type == CKEDITOR . NODE _ELEMENT && b . endContainer . getName ( ) in n ) b . shrink ( CKEDITOR . NODE _ELEMENT , ! 0 ) , a = b . collapsed ; q= b . createBookmark ( ) ; n = q . startNode ; a || ( k = q . endNode ) ; q = b . document . $ . body . createTextRange ( ) ; q. moveToElementText ( n . $ ) ; q . moveStart ( "character" , 1 ) ; k ? ( r =
b . document . $ . body . createTextRange ( ) , r. moveToElementText ( k . $ ) , q . setEndPoint ( "EndToEnd" , r ) , q . moveEnd ( "character" , - 1 ) ) : ( p= n . getNext ( E ) , C = n . hasAscendant ( "pre" ) , p = ! ( p && p . getText && p . getText ( ) . match ( r ) ) && ( C || ! n . hasPrevious ( ) || n . getPrevious ( ) . is && n . getPrevious ( ) . is ( "br" ) ) , C = b . document . createElement ( "span" ) , C. setHtml ( "\x26#65279;" ) , C . insertBefore ( n ) , p && b . document . createText ( " " ) . insertBefore ( n) ) ; b . setStartBefore ( n ) ; n . remove ( ) ; a ? ( p ? ( q . moveStart ( "character" , - 1 ) , q . select ( ) , b . document . $ . selection . clear ( ) ) : q . select ( ) ,
b . moveToPosition ( C , CKEDITOR . POSITION _BEFORE _START ) , C . remove ( ) ) : ( b . setEndBefore ( k ) , k . remove ( ) , q . select ( ) ) } else { k = this . getNative ( ) ; if ( ! k ) return ; this . removeAllRanges ( ) ; for ( q= 0 ; q < a . length ; q ++ ) { if ( q < a . length - 1 && ( p = a [ q ] , C = a [ q + 1 ] , r = p . clone ( ) , r . setStart ( p . endContainer , p . endOffset ) , r . setEnd ( C . startContainer , C . startOffset ) , ! r . collapsed && ( r . shrink ( CKEDITOR . NODE _ELEMENT , ! 0 ) , b = r. getCommonAncestor ( ) , r = r . getEnclosedNode ( ) , b . isReadOnly ( ) || r&& r . isReadOnly ( ) ) ) ) { C . setStart ( p . startContainer , p . startOffset ) ; a . splice ( q -- ,
1 ) ; continue } b = a [ q] ; C = this . document . $ . createRange ( ) ; b . collapsed && CKEDITOR . env . webkit && l( b ) && ( r = g ( this . root ) , b . insertNode ( r) , ( p = r . getNext ( ) ) && ! r . getPrevious ( ) && p . type == CKEDITOR . NODE _ELEMENT && "br" == p. getName ( ) ? ( x ( this . root ) , b . moveToPosition ( p , CKEDITOR . POSITION _BEFORE _START ) ) : b . moveToPosition ( r , CKEDITOR . POSITION _AFTER _END ) ) ; C . setStart ( b . startContainer . $ , b . startOffset ) ; try { C . setEnd ( b . endContainer . $ , b . endOffset ) } catch ( u ) { if ( 0 <= u . toString ( ) . indexOf ( "NS_ERROR_ILLEGAL_VALUE" ) ) b . collapse ( 1 ) , C . setEnd ( b . endContainer . $ ,
b . endOffset ) ; else throw u ; } k . addRange ( C ) } } this . reset ( ) ; this . root . fire ( "selectionchange" ) } } } , fake : function ( a , b ) { var c = this . root . editor ; void 0 === b && a . hasAttribute ( "aria-label" ) && ( b = a . getAttribute ( "aria-label" ) ) ; this . reset ( ) ; z ( c , b ) ; var d = this . _ . cache , e = new CKEDITOR . dom . range ( this . root ) ; e . setStartBefore ( a ) ; e . setEndAfter ( a ) ; d . ranges = new CKEDITOR . dom . rangeList ( e ) ; d . selectedElement = d . startElement = a ; d . type = CKEDITOR . SELECTION _ELEMENT ; d . selectedText = d . nativeSel = null ; this . isFake = 1 ; this . rev = M ++ ; c . _ . fakeSelection =
this ; this . root . fire ( "selectionchange" ) } , isHidden : function ( ) { var a = this . getCommonAncestor ( ) ; a && a . type == CKEDITOR . NODE _TEXT && ( a = a . getParent ( ) ) ; return ! ( ! a || ! a . data ( "cke-hidden-sel" ) ) } , isInTable : function ( a ) { return d ( this . getRanges ( ) , a ) } , isCollapsed : function ( ) { var a = this . getRanges ( ) ; return 1 === a . length && a [ 0 ] . collapsed } , createBookmarks : function ( a ) { a = this . getRanges ( ) . createBookmarks ( a ) ; this . isFake && ( a . isFake = 1 ) ; return a } , createBookmarks2 : function ( a ) { a = this . getRanges ( ) . createBookmarks2 ( a ) ; this . isFake && ( a . isFake =
1 ) ; return a } , selectBookmarks : function ( a ) { for ( var b = [ ] , c , e = 0 ; e < a . length ; e ++ ) { var f = new CKEDITOR . dom . range ( this . root ) ; f . moveToBookmark ( a [ e ] ) ; b . push ( f ) } a . isFake && ( c = d ( b ) ? b [ 0 ] . _getTableElement ( ) : b [ 0 ] . getEnclosedNode ( ) , c && c . type == CKEDITOR . NODE _ELEMENT || ( CKEDITOR . warn ( "selection-not-fake" ) , a . isFake = 0 ) ) ; a . isFake && ! d ( b ) ? this . fake ( c ) : this . selectRanges ( b ) ; return this } , getCommonAncestor : function ( ) { var a = this . getRanges ( ) ; return a . length ? a [ 0 ] . startContainer . getCommonAncestor ( a [ a . length - 1 ] . endContainer ) : null } ,
1 ) ; return a } , selectBookmarks : function ( a ) { for ( var b = [ ] , c , e = 0 ; e < a . length ; e ++ ) { var g = new CKEDITOR . dom . range ( this . root ) ; g . moveToBookmark ( a [ e ] ) ; b . push ( g ) } a . isFake && ( c = d ( b ) ? b [ 0 ] . _getTableElement ( ) : b [ 0 ] . getEnclosedNode ( ) , c && c . type == CKEDITOR . NODE _ELEMENT || ( CKEDITOR . warn ( "selection-not-fake" ) , a . isFake = 0 ) ) ; a . isFake && ! d ( b ) ? this . fake ( c ) : this . selectRanges ( b ) ; return this } , getCommonAncestor : function ( ) { var a = this . getRanges ( ) ; return a . length ? a [ 0 ] . startContainer . getCommonAncestor ( a [ a . length - 1 ] . endContainer ) : null } ,
scrollIntoView : function ( ) { this . getType ( ) != CKEDITOR . SELECTION _NONE && this . getRanges ( ) [ 0 ] . scrollIntoView ( ) } , removeAllRanges : function ( ) { if ( this . getType ( ) != CKEDITOR . SELECTION _NONE ) { var a = this . getNative ( ) ; try { a && a [ m ? "empty" : "removeAllRanges" ] ( ) } catch ( b ) { } this . reset ( ) } } } } ) ( ) ; "use strict" ; CKEDITOR . STYLE _BLOCK = 1 ; CKEDITOR . STYLE _INLINE = 2 ; CKEDITOR . STYLE _OBJECT = 3 ;
( function ( ) { function a ( a , b ) { for ( var c , d ; ( a = a . getParent ( ) ) && ! a . equals ( b ) ; ) if ( a . getAttribute ( "data-nostyle" ) ) c = a ; else if ( ! d ) { var e = a . getAttribute ( "contentEditable" ) ; "false" == e ? c = a : "true" == e && ( d = 1 ) } return c } function d ( a , b , c , d ) { return ( a . getPosition ( b ) | d ) == d && ( ! c . childRule || c . childRule ( a ) ) } function b ( c ) { var e = c . document ; if ( c . collapsed ) e = L ( this , e ) , c . insertNode ( e ) , c . moveToPosition ( e , CKEDITOR . POSITION _BEFORE _END ) ; else { var f = this . element , h = this . _ . definition , k , l = h . ignoreReadonly , q = l || h . includeReadonly ; null ==
q&& ( q = c . root . getCustomData ( "cke_includeReadonly" ) ) ; var m = CKEDITOR . dtd [ f ] ; m || ( k = ! 0 , m = CKEDITOR . dtd . span ) ; c . enlarge ( CKEDITOR . ENLARGE _INLINE , 1 ) ; c . trim ( ) ; var p= c . createBookmark ( ) , w = p . startNode , t = p . endNode , r = w , u ; if ( ! l ) { var v = c . getCommonAncestor ( ) , l = a ( w, v ) , v = a ( t , v ) ; l && ( r = l . getNextSourceNode ( ! 0 ) ) ; v&& ( t = v ) } for ( r . getPosition ( t ) == CKEDITOR . POSITION _FOLLOWING && ( r= 0 ) ; r ; ) { l = ! 1 ; if ( r . equals ( t ) ) r = null , l = ! 0 ; else { var y= r . type == CKEDITOR . NODE _ELEMENT ? r. getName ( ) : null , v = y && "false" == r . getAttribute ( "contentEditable" ) , B = y &&
- 1 !== CKEDITOR . tools . array . indexOf ( CKEDITOR . style . unstylableElements , y) , B = y && ( r . getAttribute ( "data-nostyle" ) || B ) ; if ( y && r . data ( "cke-bookmark" ) || r . type === CKEDITOR . NODE _COMMENT ) { r= r . getNextSourceNode ( ! 0 ) ; continue } if ( v&& q && CKEDITOR . dtd . $block [ y ] ) for ( var z = r , D = g ( z ) , E = void 0 , G = D . length , I = 0 , z = G && new CKEDITOR . dom . range ( z. getDocument ( ) ) ; I < G ; ++ I ) { var E = D [ I ] , J = CKEDITOR . filter . instances [ E . data ( "cke-filter" ) ] ; if ( J ? J . check ( this ) : 1 ) z. selectNodeContents ( E ) , b . call ( this , z ) } D = y ? ! m [ y ] || B ? 0 : v && ! q ? 0 : d ( r , t , h , T ) : 1 ; if ( D ) if ( E =
r. getParent ( ) , D = h , G = f , I = k , ! E || ! ( E . getDtd ( ) || CKEDITOR . dtd . span ) [ G ] && ! I || D . parentRule && ! D . parentRule ( E ) ) l = ! 0 ; else { if ( u || y&& CKEDITOR . dtd . $removeEmpty [ y ] && ( r . getPosition ( t ) | T ) != T || ( u = c . clone ( ) , u . setStartBefore ( r) ) , y = r . type , y == CKEDITOR . NODE _TEXT || v || y == CKEDITOR . NODE _ELEMENT && ! r . getChildCount ( ) ) { for ( var y= r , K ; ( l = ! y . getNext ( C ) ) && ( K = y . getParent ( ) , m [ K . getName ( ) ] ) && d ( K , w, h , N ) ; ) y = K ; u . setEndAfter ( y ) } } else l = ! 0 ; r = r . getNextSourceNode ( B || v ) } if ( l && u && ! u . collapsed ) { for ( var l = L( this , e ) , v = l . hasAttributes ( ) , B = u . getCommonAncestor ( ) ,
y= { } , D = { } , E = { } , G = { } , U , R , Y ; l && B ; ) { if ( B . getName ( ) == f ) { for ( U in h . attributes ) ! G [ U ] && ( Y = B . getAttribute ( R ) ) && ( l . getAttribute ( U ) == Y ? D [ U ] = 1 : G [ U ] = 1 ) ; for ( R in h . styles ) ! E [ R ] && ( Y = B . getStyle ( R ) ) && ( l . getStyle ( R ) == Y ? y [ R ] = 1 : E [ R ] = 1 ) } B = B . getParent ( ) } for ( U in D ) l . removeAttribute ( U ) ; for ( R in y ) l . removeStyle ( R ) ; v && ! l . hasAttributes ( ) && ( l = null ) ; l ? ( u . extractContents ( ) . appendTo ( l ) , u . insertNode ( l ) , F . call ( this , l ) , l . mergeSiblings ( ) , CKEDITOR . env . ie || l . $ . normalize ( ) ) : ( l = new CKEDITOR . dom . element ( "span" ) , u . extractContents ( ) . appendTo ( l ) ,
u . insertNode ( l ) , F . call ( this , l ) , l . remove ( ! 0 ) ) ; u = null } } c . moveToBookmark ( p ) ; c . shrink ( CKEDITOR . SHRINK _TEXT ) ; c . shrink ( CKEDITOR . NODE _ELEMENT , ! 0 ) } } function c ( a ) { function b ( ) { for ( var a = new CKEDITOR . dom . elementPath ( d . getParent ( ) ) , c = new CKEDITOR . dom . elementPath ( q . getParent ( ) ) , e = null , f= null , g = 0 ; g < a . elements . length ; g ++ ) { var h = a . elements [ g ] ; if ( h == a . block || h == a . blockLimit ) break ; m . checkElementRemovable ( h , ! 0 ) && ( e = h ) } for ( g= 0 ; g < c . elements . length ; g ++ ) { h = c . elements [ g ] ; if ( h == c . block || h == c . blockLimit ) break ; m . checkElementRemovable ( h ,
! 0 ) && ( f= h ) } f && q . breakParent ( f ) ; e && d . breakParent ( e ) } a . enlarge ( CKEDITOR . ENLARGE _INLINE , 1 ) ; var c = a . createBookmark ( ) , d = c . startNode , e = this . _ . definition . alwaysRemoveElement ; if ( a . collapsed ) { for ( var f = new CKEDITOR . dom . elementPath ( d . getParent ( ) , a . root ) , g, h = 0 , k ; h < f . elements . length && ( k = f . elements [ h ] ) && k != f. block && k != f . blockLimit ; h ++ ) if ( this . checkElementRemovable ( k ) ) { var l ; ! e && a . collapsed && ( a . checkBoundaryOfElement ( k , CKEDITOR . END ) || ( l = a . checkBoundaryOfElement ( k , CKEDITOR . START ) ) ) ? ( g= k , g . match = l ? "start" : "end" ) :
( k . mergeSiblings ( ) , k . is ( this . element ) ? y. call ( this , k ) : r ( k , G ( this ) [ k . getName ( ) ] ) ) } if ( g ) { e = d ; for ( h = 0 ; ; h ++ ) { k = f . elements [ h ] ; if ( k . equals ( g ) ) break ; else if ( k . match ) continue ; else k = k . clone ( ) ; k . append ( e ) ; e = k } e [ "start" == g . match ? "insertBefore" : "insertAfter" ] ( g) } } else { var q = c . endNode , m = this ; b ( ) ; for ( f= d ; ! f . equals ( q ) ; ) g = f . getNextSourceNode ( ) , f . type == CKEDITOR . NODE _ELEMENT && this . checkElementRemovable ( f) && ( f . getName ( ) == this . element ? y. call ( this , f ) : r ( f , G ( this ) [ f . getName ( ) ] ) , g . type == CKEDITOR . NODE _ELEMENT && g . contains ( d ) &&
( b ( ) , g= d . getNext ( ) ) ) , f = g } a . moveToBookmark ( c ) ; a . shrink ( CKEDITOR . NODE _ELEMENT , ! 0 ) } function g ( a ) { var b = [ ] ; a . forEach ( function ( a ) { if ( "true" == a . getAttribute ( "contenteditable" ) ) return b . push ( a ) , ! 1 } , CKEDITOR . NODE _ELEMENT , ! 0 ) ; return b } function e ( a ) { var b = a . getEnclosedNode ( ) || a . getCommonAncestor ( ! 1 , ! 0 ) ; ( a = ( new CKEDITOR . dom . elementPath ( b , a . root ) ) . contains ( this . element , 1 ) ) && ! a . isReadOnly ( ) && v( a , this ) } function h ( a ) { var b = a . getCommonAncestor ( ! 0 , ! 0 ) ; if ( a = ( new CKEDITOR . dom . elementPath ( b , a . root ) ) . contains ( this . element ,
1 ) ) { var b = this . _ . definition , c = b . attributes ; if ( c ) for ( var d in c ) a . removeAttribute ( d , c [ d ] ) ; if ( b . styles ) for ( var e in b . styles ) b . styles . hasOwnProperty ( e ) && a . removeStyle ( e ) } } function k ( a ) { var b = a . createBookmark ( ! 0 ) , c = a . createIterator ( ) ; c . enforceRealBlocks = ! 0 ; this . _ . enterMode && ( c . enlargeBr = this . _ . enterMode != CKEDITOR . ENTER _BR ) ; for ( var d , e = a . document , f ; d = c . getNextParagraph ( ) ; ) ! d . isReadOnly ( ) && ( c . activeFilter ? c . activeFilter . check ( this ) : 1 ) && ( f= L ( this , e , d ) , q ( d , f ) ) ; a . moveToBookmark ( b ) } function l ( a ) { var b = a . createBookmark ( 1 ) ,
c = a . createIterator ( ) ; c . enforceRealBlocks = ! 0 ; c . enlargeBr = this . _ . enterMode != CKEDITOR . ENTER _BR ; for ( var d , e ; d = c . getNextParagraph ( ) ; ) this . checkElementRemovable ( d ) && ( d . is ( "pre" ) ? ( ( e = this . _ . enterMode == CKEDITOR . ENTER _BR ? null : a . document . createElement ( this . _ . enterMode == CKEDITOR . ENTER _P ? "p" : "div" ) ) && d . copyAttributes ( e ) , q( d , e ) ) : y . call ( this , d ) ) ; a . moveToBookmark ( b ) } function q ( a , b ) { var c = ! b ; c && ( b = a . getDocument ( ) . createElement ( "div" ) , a . copyAttributes ( b ) ) ; var d = b && b . is ( "pre" ) , e = a . is ( "pre" ) , g = ! d && e ; if ( d && ! e ) { e = b ; ( g =
a . getBogus ( ) ) && g. remove ( ) ; g = a . getHtml ( ) ; g = w ( g , /(?:^[ \t\n\r]+)|(?:[ \t\n\r]+$)/g , "" ) ; g= g . replace ( /[ \t\r\n]*(<br[^>]*>)[ \t\r\n]*/gi , "$1" ) ; g= g . replace ( /([ \t\n\r]+| )/g , " " ) ; g= g . replace ( /<br\b[^>]*>/gi , "\n" ) ; if ( CKEDITOR . env . ie ) { var h = a . getDocument ( ) . createElement ( "div" ) ; h . append ( e ) ; e . $ . outerHTML = "\x3cpre\x3e" + g + "\x3c/pre\x3e" ; e . copyAttributes ( h . getFirst ( ) ) ; e = h . getFirst ( ) . remove ( ) } else e . setHtml ( g) ; b = e } else g ? b = B ( c ? [ a . getHtml ( ) ] : f ( a ) , b ) : a . moveChildren ( b ) ; b . replace ( a ) ; if ( d ) { var c = b , k ; ( k = c . getPrevious ( I ) ) &&
k . type == CKEDITOR . NODE _ELEMENT && k . is ( "pre" ) && ( d = w ( k . getHtml ( ) , /\n$/ , "" ) + "\n\n" + w ( c . getHtml ( ) , /^\n/ , "" ) , CKEDITOR . env . ie ? c . $ . outerHTML = "\x3cpre\x3e" + d + "\x3c/pre\x3e" : c . setHtml ( d ) , k . remove ( ) ) } else c && m ( b ) } function f ( a ) { var b = [ ] ; w ( a . getOuterHtml ( ) , /(\S\s*)\n(?:\s|(<span[^>]+data-cke-bookmark.*?\/span>))*\n(?!$)/gi , function ( a , b , c ) { return b + "\x3c/pre\x3e" + c + "\x3cpre\x3e" } ) . replace ( /<pre\b.*?>([\s\S]*?)<\/pre>/gi , function ( a , c ) { b . push ( c ) } ) ; return b } function w ( a , b , c ) { var d = "" , e = "" ; a = a . replace ( /(^<span[^>]+data-cke-bookmark.*?\/span>)|(<span[^>]+data-cke-bookmark.*?\/span>$)/gi ,
function ( a , b , c ) { b && ( d = b ) ; c && ( e = c ) ; return "" } ) ; return d + a . replace ( b , c ) + e } function B ( a , b ) { var c ; 1 < a . length && ( c = new CKEDITOR . dom . documentFragment ( b . getDocument ( ) ) ) ; for ( var d = 0 ; d < a . length ; d ++ ) { var e = a [ d ] , e = e . replace ( /(\r\n|\r)/g , "\n" ) , e = w ( e , /^[ \t]*\n/ , "" ) , e = w ( e , /\n$/ , "" ) , e = w ( e , /^[ \t]+|[ \t]+$/g , function ( a , b ) { return 1 == a . length ? "\x26nbsp;" : b ? " " + CKEDITOR . tools . repeat ( "\x26nbsp;" , a . length - 1 ) : CKEDITOR . tools . repeat ( "\x26nbsp;" , a . length - 1 ) + " " } ) , e = e . replace ( /\n/g , "\x3cbr\x3e" ) , e = e . replace ( /[ \t]{2,}/g , function ( a ) { return CKEDITOR . tools . repeat ( "\x26nbsp;" ,
a . length - 1 ) + " " } ) ; if ( c ) { var f= b . clone ( ) ; f . setHtml ( e ) ; c . append ( f ) } else b . setHtml ( e ) } return c || b } function y ( a , b ) { var c = this . _ . definition , d = c . attributes , c = c . styles , e = G ( this ) [ a . getName ( ) ] , f = CKEDITOR . tools . isEmpty ( d ) && CKEDITOR . tools . isEmpty ( c ) , g; for ( g in d ) if ( "class" != g && ! this . _ . definition . fullMatch || a . getAttribute ( g) == p ( g , d [ g ] ) ) b && "data-" == g . slice ( 0 , 5 ) || ( f = a . hasAttribute ( g ) , a . removeAttribute ( g ) ) ; for ( var h in c ) this . _ . definition . fullMatch && a . getStyle ( h ) != p ( h , c [ h ] , ! 0 ) || ( f= f || ! ! a . getStyle ( h ) , a . removeStyle ( h ) ) ;
r( a , e , E [ a . getName ( ) ] ) ; f && ( this . _ . definition . alwaysRemoveElement ? m ( a , 1 ) : ! CKEDITOR . dtd . $block [ a . getName ( ) ] || this . _ . enterMode == CKEDITOR . ENTER _BR && ! a . hasAttributes ( ) ? m ( a ) : a . renameNode ( this . _ . enterMode == CKEDITOR . ENTER _P ? "p" : "div" ) ) } function F( a ) { for ( var b = G ( this ) , c = a . getElementsByTag ( this . element ) , d , e = c . count ( ) ; 0 <= -- e ; ) d = c . getItem ( e ) , d . isReadOnly ( ) || y . call ( this , d , ! 0 ) ; for ( var f in b ) if ( f != this . element ) for ( c = a . getElementsByTag ( f ) , e = c . count ( ) - 1 ; 0 <= e ; e -- ) d = c . getItem ( e ) , d . isReadOnly ( ) || r( d , b [ f ] ) } function r ( a ,
b , c ) { if ( b = b && b . attributes ) for ( var d = 0 ; d < b . length ; d ++ ) { var e = b [ d ] [ 0 ] , f; if ( f = a . getAttribute ( e ) ) { var g = b [ d ] [ 1 ] ; ( null === g|| g . test && g . test ( f ) || "string" == typeof g && f == g ) && a . removeAttribute ( e ) } } c || m ( a ) } function m ( a , b ) { if ( ! a . hasAttributes ( ) || b ) if ( CKEDITOR . dtd . $block [ a . getName ( ) ] ) { var c = a . getPrevious ( I ) , d = a . getNext ( I ) ; ! c || c . type != CKEDITOR . NODE _TEXT && c . isBlockBoundary ( { br : 1 } ) || a . append ( "br" , 1 ) ; ! d || d . type != CKEDITOR . NODE _TEXT && d . isBlockBoundary ( { br : 1 } ) || a . append ( "br" ) ; a . remove ( ! 0 ) } else c = a . getFirst ( ) , d = a . getLast ( ) ,
a . remove ( ! 0 ) , c && ( c . type == CKEDITOR . NODE _ELEMENT && c . mergeSiblings ( ) , d && ! c . equals ( d ) && d . type == CKEDITOR . NODE _ELEMENT && d . mergeSiblings ( ) ) } function L ( a , b , c ) { var d ; d = a . element ; "*" == d && ( d = "span" ) ; d = new CKEDITOR . dom . element ( d , b ) ; c && c . copyAttributes ( d ) ; d = v ( d , a ) ; b . getCustomData ( "doc_processing_style" ) && d . hasAttribute ( "id" ) ? d . removeAttribute ( "id" ) : b . setCustomData ( "doc_processing_style" , 1 ) ; return d } function v ( a , b ) { var c = b . _ . definition , d = c . attributes , c = CKEDITOR . style . getStyleText ( c ) ; if ( d ) for ( var e in d ) a . setAttribute ( e ,
d [ e ] ) ; c && a . setAttribute ( "style" , c ) ; a . getDocument ( ) . removeCustomData ( "doc_processing_style" ) ; return a } function J ( a , b ) { for ( var c in a ) a [ c ] = a [ c ] . replace ( D , function ( a , c ) { return b [ c ] } ) } function G ( a ) { if ( a . _ . overrides ) return a . _ . overrides ; var b = a . _ . overrides = { } , c = a . _ . definition . overrides ; if ( c ) { CKEDITOR . tools . isArray ( c ) || ( c = [ c ] ) ; for ( var d = 0 ; d < c . length ; d ++ ) { var e = c [ d ] , f, g ; "string" == typeof e ? f = e . toLowerCase ( ) : ( f = e . element ? e . element . toLowerCase ( ) : a . element , g = e . attributes ) ; e = b [ f] || ( b [ f ] = { } ) ; if ( g ) { var e = e . attributes =
e . attributes || [ ] , h ; for ( h in g ) e . push ( [ h . toLowerCase ( ) , g [ h ] ] ) } } } return b } function p ( a , b , c ) { var d = new CKEDITOR . dom . element ( "span" ) ; d [ c ? "setStyle" : "setAttribute" ] ( a , b ) ; return d [ c ? "getStyle" : "getAttribute" ] ( a ) } function u ( a , b ) { function c ( a , b ) { return "font-family" == b . toLowerCase ( ) ? a . replace ( /["']/g , "" ) : a } "string" == typeof a && ( a = CKEDITOR . tools . parseCssText ( a ) ) ; "string" == typeof b && ( b = CKEDITOR . tools . parseCssText ( b , ! 0 ) ) ; for ( var d in a ) if ( ! ( d in b ) || c ( b [ d ] , d ) != c ( a [ d ] , d ) && "inherit" != a [ d ] && "inherit" != b [ d ] ) return ! 1 ;
return ! 0 } function K ( a , b , c ) { var d = a . getRanges ( ) ; b = b ? this . removeFromRange : this . applyToRange ; for ( var e , f = d . createIterator ( ) ; e = f . getNextRange ( ) ; ) b . call ( this , e , c ) ; a . selectRanges ( d ) } var E = { address : 1 , div : 1 , h1 : 1 , h2 : 1 , h3 : 1 , h4 : 1 , h5 : 1 , h6 : 1 , p : 1 , pre : 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 , details : 1 , datagrid : 1 , datalist : 1 } , z = { a : 1 , blockquote : 1 , embed : 1 , hr : 1 , img : 1 , li : 1 , object : 1 , ol : 1 , table : 1 , td : 1 , tr : 1 , th : 1 , ul : 1 , dl : 1 ,
dt : 1 , dd : 1 , form : 1 , audio : 1 , video : 1 } , t = /\s*(?:;\s*|$)/ , D= /#\((.+?)\)/g , C = CKEDITOR . dom . walker . bookmark ( 0 , 1 ) , I = CKEDITOR . dom . walker . whitespaces ( 1 ) ; CKEDITOR . style = function ( a , b ) { if ( "string" == typeof a . type ) return new CKEDITOR . style . customHandlers [ a . type ] ( a ) ; var c = a . attributes ; c && c . style && ( a . styles = CKEDITOR . tools . extend ( { } , a . styles , CKEDITOR . tools . parseCssText ( c . style ) ) , delete c . style ) ; b && ( a = CKEDITOR . tools . clone ( a ) , J ( a . attributes , b ) , J ( a . styles , b ) ) ; c = this . element = a . element ? "string" == typeof a . element ? a . element . toLowerCase ( ) :
a . element : "*" ; this . type = a . type || ( E [ c ] ? CKEDITOR . STYLE _BLOCK : z [ c ] ? CKEDITOR . STYLE _OBJECT : CKEDITOR . STYLE _INLINE ) ; "object" == typeof this . element && ( this . type = CKEDITOR . STYLE _OBJECT ) ; this . _ = { definition : a } } ; CKEDITOR . style . prototype = { apply : function ( a ) { if ( a instanceof CKEDITOR . dom . document ) return K . call ( this , a . getSelection ( ) ) ; if ( this . checkApplicable ( a . elementPath ( ) , a ) ) { var b = this . _ . enterMode ; b || ( this . _ . enterMode = a . activeEnterMode ) ; K . call ( this , a . getSelection ( ) , 0 , a ) ; this . _ . enterMode = b } } , remove : function ( a ) { if ( a instanceof
CKEDITOR . dom . document ) return K . call ( this , a . getSelection ( ) , 1 ) ; if ( this . checkApplicable ( a . elementPath ( ) , a ) ) { var b = this . _ . enterMode ; b || ( this . _ . enterMode = a . activeEnterMode ) ; K . call ( this , a . getSelection ( ) , 1 , a ) ; this . _ . enterMode = b } } , applyToRange : function ( a ) { this . applyToRange = this . type == CKEDITOR . STYLE _INLINE ? b : this . type == CKEDITOR . STYLE _BLOCK ? k : this . type == CKEDITOR . STYLE _OBJECT ? e : null ; return this . applyToRange ( a ) } , removeFromRange : function ( a ) { this . removeFromRange = this . type == CKEDITOR . STYLE _INLINE ? c : this . type == CKEDITOR . STYLE _BLOCK ?
l : this . type == CKEDITOR . STYLE _OBJECT ? h : null ; return this . removeFromRange ( a ) } , applyToObject : function ( a ) { v ( a , this ) } , checkActive : function ( a , b ) { switch ( this . type ) { case CKEDITOR . STYLE _BLOCK : return this . checkElementRemovable ( a . block || a . blockLimit , ! 0 , b ) ; case CKEDITOR . STYLE _OBJECT : case CKEDITOR . STYLE _INLINE : for ( var c = a . elements , d = 0 , e ; d < c . length ; d ++ ) if ( e = c [ d ] , this . type != CKEDITOR . STYLE _INLINE || e != a . block && e != a . blockLimit ) { if ( this . type == CKEDITOR . STYLE _OBJECT ) { var f = e . getName ( ) ; if ( ! ( "string" == typeof this . element ?
f== this . element : f in this . element ) ) continue } if ( this . checkElementRemovable ( e , ! 0 , b ) ) return ! 0 } } return ! 1 } , checkApplicable : function ( a , b , c ) { b && b instanceof CKEDITOR . filter && ( c = b ) ; if ( c && ! c . check ( this ) ) return ! 1 ; switch ( this . type ) { case CKEDITOR . STYLE _OBJECT : return ! ! a . contains ( this . element ) ; case CKEDITOR . STYLE _BLOCK : return ! ! a . blockLimit . getDtd ( ) [ this . element ] } return ! 0 } , checkElementMatch : function ( a , b ) { var c = this . _ . definition ; if ( ! a || ! c . ignoreReadonly && a . isReadOnly ( ) ) return ! 1 ; var d = a . getName ( ) ; if ( "string" == typeof this . element ?
d == this . element : d in this . element ) { if ( ! b && ! a . hasAttributes ( ) ) return ! 0 ; if ( d = c . _AC ) c = d ; else { var d = { } , e = 0 , f= c . attributes ; if ( f ) for ( var g in f ) e ++ , d [ g ] = f [ g ] ; if ( g = CKEDITOR . style . getStyleText ( c ) ) d . style || e ++ , d . style = g ; d . _length = e ; c = c . _AC = d } if ( c . _length ) { for ( var h in c ) if ( "_length" != h ) if ( d = a . getAttribute ( h ) || "" , "style" == h ? u ( c [ h ] , d ) : c [ h ] == d ) { if ( ! b ) return ! 0 } else if ( b ) return ! 1 ; if ( b ) return ! 0 } else return ! 0 } return ! 1 } , checkElementRemovable : function ( a , b , c ) { if ( this . checkElementMatch ( a , b , c ) ) return ! 0 ; if ( b = G ( this ) [ a . getName ( ) ] ) { var d ;
if ( ! ( b = b . attributes ) ) return ! 0 ; for ( c = 0 ; c < b . length ; c ++ ) if ( d = b [ c ] [ 0 ] , d = a . getAttribute ( d ) ) { var e = b [ c ] [ 1 ] ; if ( null === e ) return ! 0 ; if ( "string" == typeof e ) { if ( d == e ) return ! 0 } else if ( e . test ( d ) ) return ! 0 } } return ! 1 } , buildPreview : function ( a ) { var b = this . _ . definition , c = [ ] , d = b . element ; "bdo" == d && ( d = "span" ) ; var c = [ "\x3c" , d ] , e = b . attributes ; if ( e ) for ( var f in e ) c . push ( " " , f, '\x3d"' , e [ f ] , '"' ) ; ( e = CKEDITOR . style . getStyleText ( b ) ) && c . push ( ' style\x3d"' , e , '"' ) ; c . push ( "\x3e" , a || b . name , "\x3c/" , d , "\x3e" ) ; return c . join ( "" ) } , getDefinition : function ( ) { return this . _ . definition } } ;
CKEDITOR . style . getStyleText = function ( a ) { var b = a . _ST ; if ( b ) return b ; var b = a . styles , c = a . attributes && a . attributes . style || "" , d = "" ; c . length && ( c = c . replace ( t , ";" ) ) ; for ( var e in b ) { var f= b [ e ] , g = ( e + ":" + f ) . replace ( t , ";" ) ; "inherit" == f? d += g : c += g } c . length && ( c = CKEDITOR . tools . normalizeCssText ( c , ! 0 ) ) ; return a . _ST = c + d } ; CKEDITOR . style . customHandlers = { } ; CKEDITOR . style . unstylableElements = [ ] ; CKEDITOR . style . addCustomHandler = function ( a ) { var b = function ( a ) { this . _ = { definition : a } ; this . setup && this . setup ( a ) } ; b . prototype = CKEDITOR . tools . extend ( CKEDITOR . tools . prototypedCopy ( CKEDITOR . style . prototype ) ,
{ assignedTo : CKEDITOR . STYLE _OBJECT } , a , ! 0 ) ; return this . customHandlers [ a . type ] = b } ; var T = CKEDITOR . POSITION _PRECEDING | CKEDITOR . POSITION _IDENTICAL | CKEDITOR . POSITION _IS _CONTAINED , N = CKEDITOR . POSITION _FOLLOWING | CKEDITOR . POSITION _IDENTICAL | CKEDITOR . POSITION _IS _CONTAINED } ) ( ) ; CKEDITOR . styleCommand = function ( a , d ) { this . requiredContent = this . allowedContent = this . style = a ; CKEDITOR . tools . extend ( this , d , ! 0 ) } ;
( function ( ) { function a ( a , b ) { for ( var c , d ; ( a = a . getParent ( ) ) && ! a . equals ( b ) ; ) if ( a . getAttribute ( "data-nostyle" ) ) c = a ; else if ( ! d ) { var e = a . getAttribute ( "contentEditable" ) ; "false" == e ? c = a : "true" == e && ( d = 1 ) } return c } function d ( a , b , c , d ) { return ( a . getPosition ( b ) | d ) == d && ( ! c . childRule || c . childRule ( a ) ) } function b ( c ) { var e = c . document ; if ( c . collapsed ) e = M ( this , e ) , c . insertNode ( e ) , c . moveToPosition ( e , CKEDITOR . POSITION _BEFORE _END ) ; else { var g = this . element , h = this . _ . definition , k , l = h . ignoreReadonly , n = l || h . includeReadonly ; null ==
n&& ( n = c . root . getCustomData ( "cke_includeReadonly" ) ) ; var m = CKEDITOR . dtd [ g ] ; m || ( k = ! 0 , m = CKEDITOR . dtd . span ) ; c . enlarge ( CKEDITOR . ENLARGE _INLINE , 1 ) ; c . trim ( ) ; var q= c . createBookmark ( ) , t = q . startNode , v = q . endNode , x = t , u ; if ( ! l ) { var y = c . getCommonAncestor ( ) , l = a ( t, y ) , y = a ( v , y ) ; l && ( x = l . getNextSourceNode ( ! 0 ) ) ; y&& ( v = y ) } for ( x . getPosition ( v ) == CKEDITOR . POSITION _FOLLOWING && ( x= 0 ) ; x ; ) { l = ! 1 ; if ( x . equals ( v ) ) x = null , l = ! 0 ; else { var w= x . type == CKEDITOR . NODE _ELEMENT ? x. getName ( ) : null , y = w && "false" == x . getAttribute ( "contentEditable" ) , z = w &&
- 1 !== CKEDITOR . tools . array . indexOf ( CKEDITOR . style . unstylableElements , w) , z = w && ( x . getAttribute ( "data-nostyle" ) || z ) ; if ( w && x . data ( "cke-bookmark" ) || x . type === CKEDITOR . NODE _COMMENT ) { x= x . getNextSourceNode ( ! 0 ) ; continue } if ( y&& n && CKEDITOR . dtd . $block [ w ] ) for ( var B = x , D = f ( B ) , F = void 0 , H = D . length , I = 0 , B = H && new CKEDITOR . dom . range ( B. getDocument ( ) ) ; I < H ; ++ I ) { var F = D [ I ] , J = CKEDITOR . filter . instances [ F . data ( "cke-filter" ) ] ; if ( J ? J . check ( this ) : 1 ) B. selectNodeContents ( F ) , b . call ( this , B ) } D = w ? ! m [ w ] || z ? 0 : y && ! n ? 0 : d ( x , v , h , N ) : 1 ; if ( D ) if ( F =
x. getParent ( ) , D = h , H = g , I = k , ! F || ! ( F . getDtd ( ) || CKEDITOR . dtd . span ) [ H ] && ! I || D . parentRule && ! D . parentRule ( F ) ) l = ! 0 ; else { if ( u || w&& CKEDITOR . dtd . $removeEmpty [ w ] && ( x . getPosition ( v ) | N ) != N || ( u = c . clone ( ) , u . setStartBefore ( x) ) , w = x . type , w == CKEDITOR . NODE _TEXT || y || w == CKEDITOR . NODE _ELEMENT && ! x . getChildCount ( ) ) { for ( var w= x , K ; ( l = ! w . getNext ( A ) ) && ( K = w . getParent ( ) , m [ K . getName ( ) ] ) && d ( K , t, h , L ) ; ) w = K ; u . setEndAfter ( w ) } } else l = ! 0 ; x = x . getNextSourceNode ( z || y ) } if ( l && u && ! u . collapsed ) { for ( var l = M( this , e ) , y = l . hasAttributes ( ) , z = u . getCommonAncestor ( ) ,
w= { } , D = { } , F = { } , H = { } , T , Q , X ; l && z ; ) { if ( z . getName ( ) == g ) { for ( T in h . attributes ) ! H [ T ] && ( X = z . getAttribute ( Q ) ) && ( l . getAttribute ( T ) == X ? D [ T ] = 1 : H [ T ] = 1 ) ; for ( Q in h . styles ) ! F [ Q ] && ( X = z . getStyle ( Q ) ) && ( l . getStyle ( Q ) == X ? w [ Q ] = 1 : F [ Q ] = 1 ) } z = z . getParent ( ) } for ( T in D ) l . removeAttribute ( T ) ; for ( Q in w ) l . removeStyle ( Q ) ; y && ! l . hasAttributes ( ) && ( l = null ) ; l ? ( u . extractContents ( ) . appendTo ( l ) , u . insertNode ( l ) , G . call ( this , l ) , l . mergeSiblings ( ) , CKEDITOR . env . ie || l . $ . normalize ( ) ) : ( l = new CKEDITOR . dom . element ( "span" ) , u . extractContents ( ) . appendTo ( l ) ,
u . insertNode ( l ) , G . call ( this , l ) , l . remove ( ! 0 ) ) ; u = null } } c . moveToBookmark ( q ) ; c . shrink ( CKEDITOR . SHRINK _TEXT ) ; c . shrink ( CKEDITOR . NODE _ELEMENT , ! 0 ) } } function c ( a ) { function b ( ) { for ( var a = new CKEDITOR . dom . elementPath ( d . getParent ( ) ) , c = new CKEDITOR . dom . elementPath ( n . getParent ( ) ) , e = null , g= null , f = 0 ; f < a . elements . length ; f ++ ) { var h = a . elements [ f ] ; if ( h == a . block || h == a . blockLimit ) break ; m . checkElementRemovable ( h , ! 0 ) && ( e = h ) } for ( f= 0 ; f < c . elements . length ; f ++ ) { h = c . elements [ f ] ; if ( h == c . block || h == c . blockLimit ) break ; m . checkElementRemovable ( h ,
! 0 ) && ( g= h ) } g && n . breakParent ( g ) ; e && d . breakParent ( e ) } a . enlarge ( CKEDITOR . ENLARGE _INLINE , 1 ) ; var c = a . createBookmark ( ) , d = c . startNode , e = this . _ . definition . alwaysRemoveElement ; if ( a . collapsed ) { for ( var g = new CKEDITOR . dom . elementPath ( d . getParent ( ) , a . root ) , f, h = 0 , k ; h < g . elements . length && ( k = g . elements [ h ] ) && k != g. block && k != g . blockLimit ; h ++ ) if ( this . checkElementRemovable ( k ) ) { var l ; ! e && a . collapsed && ( a . checkBoundaryOfElement ( k , CKEDITOR . END ) || ( l = a . checkBoundaryOfElement ( k , CKEDITOR . START ) ) ) ? ( f= k , f . match = l ? "start" : "end" ) :
( k . mergeSiblings ( ) , k . is ( this . element ) ? z. call ( this , k ) : v ( k , F ( this ) [ k . getName ( ) ] ) ) } if ( f ) { e = d ; for ( h = 0 ; ; h ++ ) { k = g . elements [ h ] ; if ( k . equals ( f ) ) break ; else if ( k . match ) continue ; else k = k . clone ( ) ; k . append ( e ) ; e = k } e [ "start" == f . match ? "insertBefore" : "insertAfter" ] ( f) } } else { var n = c . endNode , m = this ; b ( ) ; for ( g= d ; ! g . equals ( n ) ; ) f = g . getNextSourceNode ( ) , g . type == CKEDITOR . NODE _ELEMENT && this . checkElementRemovable ( g) && ( g . getName ( ) == this . element ? z. call ( this , g ) : v ( g , F ( this ) [ g . getName ( ) ] ) , f . type == CKEDITOR . NODE _ELEMENT && f . contains ( d ) &&
( b ( ) , f= d . getNext ( ) ) ) , g = f } a . moveToBookmark ( c ) ; a . shrink ( CKEDITOR . NODE _ELEMENT , ! 0 ) } function f ( a ) { var b = [ ] ; a . forEach ( function ( a ) { if ( "true" == a . getAttribute ( "contenteditable" ) ) return b . push ( a ) , ! 1 } , CKEDITOR . NODE _ELEMENT , ! 0 ) ; return b } function e ( a ) { var b = a . getEnclosedNode ( ) || a . getCommonAncestor ( ! 1 , ! 0 ) ; ( a = ( new CKEDITOR . dom . elementPath ( b , a . root ) ) . contains ( this . element , 1 ) ) && ! a . isReadOnly ( ) && w( a , this ) } function k ( a ) { var b = a . getCommonAncestor ( ! 0 , ! 0 ) ; if ( a = ( new CKEDITOR . dom . elementPath ( b , a . root ) ) . contains ( this . element ,
1 ) ) { var b = this . _ . definition , c = b . attributes ; if ( c ) for ( var d in c ) a . removeAttribute ( d , c [ d ] ) ; if ( b . styles ) for ( var e in b . styles ) b . styles . hasOwnProperty ( e ) && a . removeStyle ( e ) } } function h ( a ) { var b = a . createBookmark ( ! 0 ) , c = a . createIterator ( ) ; c . enforceRealBlocks = ! 0 ; this . _ . enterMode && ( c . enlargeBr = this . _ . enterMode != CKEDITOR . ENTER _BR ) ; for ( var d , e = a . document , g ; d = c . getNextParagraph ( ) ; ) ! d . isReadOnly ( ) && ( c . activeFilter ? c . activeFilter . check ( this ) : 1 ) && ( g= M ( this , e , d ) , l ( d , g ) ) ; a . moveToBookmark ( b ) } function n ( a ) { var b = a . createBookmark ( 1 ) ,
c = a . createIterator ( ) ; c . enforceRealBlocks = ! 0 ; c . enlargeBr = this . _ . enterMode != CKEDITOR . ENTER _BR ; for ( var d , e ; d = c . getNextParagraph ( ) ; ) this . checkElementRemovable ( d ) && ( d . is ( "pre" ) ? ( ( e = this . _ . enterMode == CKEDITOR . ENTER _BR ? null : a . document . createElement ( this . _ . enterMode == CKEDITOR . ENTER _P ? "p" : "div" ) ) && d . copyAttributes ( e ) , l( d , e ) ) : z . call ( this , d ) ) ; a . moveToBookmark ( b ) } function l ( a , b ) { var c = ! b ; c && ( b = a . getDocument ( ) . createElement ( "div" ) , a . copyAttributes ( b ) ) ; var d = b && b . is ( "pre" ) , e = a . is ( "pre" ) , f = ! d && e ; if ( d && ! e ) { e = b ; ( f =
a . getBogus ( ) ) && f. remove ( ) ; f = a . getHtml ( ) ; f = x ( f , /(?:^[ \t\n\r]+)|(?:[ \t\n\r]+$)/g , "" ) ; f= f . replace ( /[ \t\r\n]*(<br[^>]*>)[ \t\r\n]*/gi , "$1" ) ; f= f . replace ( /([ \t\n\r]+| )/g , " " ) ; f= f . replace ( /<br\b[^>]*>/gi , "\n" ) ; if ( CKEDITOR . env . ie ) { var h = a . getDocument ( ) . createElement ( "div" ) ; h . append ( e ) ; e . $ . outerHTML = "\x3cpre\x3e" + f + "\x3c/pre\x3e" ; e . copyAttributes ( h . getFirst ( ) ) ; e = h . getFirst ( ) . remove ( ) } else e . setHtml ( f) ; b = e } else f ? b = y ( c ? [ a . getHtml ( ) ] : g ( a ) , b ) : a . moveChildren ( b ) ; b . replace ( a ) ; if ( d ) { var c = b , k ; ( k = c . getPrevious ( I ) ) &&
k . type == CKEDITOR . NODE _ELEMENT && k . is ( "pre" ) && ( d = x ( k . getHtml ( ) , /\n$/ , "" ) + "\n\n" + x ( c . getHtml ( ) , /^\n/ , "" ) , CKEDITOR . env . ie ? c . $ . outerHTML = "\x3cpre\x3e" + d + "\x3c/pre\x3e" : c . setHtml ( d ) , k . remove ( ) ) } else c && m ( b ) } function g ( a ) { var b = [ ] ; x ( a . getOuterHtml ( ) , /(\S\s*)\n(?:\s|(<span[^>]+data-cke-bookmark.*?\/span>))*\n(?!$)/gi , function ( a , b , c ) { return b + "\x3c/pre\x3e" + c + "\x3cpre\x3e" } ) . replace ( /<pre\b.*?>([\s\S]*?)<\/pre>/gi , function ( a , c ) { b . push ( c ) } ) ; return b } function x ( a , b , c ) { var d = "" , e = "" ; a = a . replace ( /(^<span[^>]+data-cke-bookmark.*?\/span>)|(<span[^>]+data-cke-bookmark.*?\/span>$)/gi ,
function ( a , b , c ) { b && ( d = b ) ; c && ( e = c ) ; return "" } ) ; return d + a . replace ( b , c ) + e } function y ( a , b ) { var c ; 1 < a . length && ( c = new CKEDITOR . dom . documentFragment ( b . getDocument ( ) ) ) ; for ( var d = 0 ; d < a . length ; d ++ ) { var e = a [ d ] , e = e . replace ( /(\r\n|\r)/g , "\n" ) , e = x ( e , /^[ \t]*\n/ , "" ) , e = x ( e , /\n$/ , "" ) , e = x ( e , /^[ \t]+|[ \t]+$/g , function ( a , b ) { return 1 == a . length ? "\x26nbsp;" : b ? " " + CKEDITOR . tools . repeat ( "\x26nbsp;" , a . length - 1 ) : CKEDITOR . tools . repeat ( "\x26nbsp;" , a . length - 1 ) + " " } ) , e = e . replace ( /\n/g , "\x3cbr\x3e" ) , e = e . replace ( /[ \t]{2,}/g , function ( a ) { return CKEDITOR . tools . repeat ( "\x26nbsp;" ,
a . length - 1 ) + " " } ) ; if ( c ) { var g= b . clone ( ) ; g . setHtml ( e ) ; c . append ( g ) } else b . setHtml ( e ) } return c || b } function z ( a , b ) { var c = this . _ . definition , d = c . attributes , c = c . styles , e = F ( this ) [ a . getName ( ) ] , g = CKEDITOR . tools . isEmpty ( d ) && CKEDITOR . tools . isEmpty ( c ) , f; for ( f in d ) if ( "class" != f && ! this . _ . definition . fullMatch || a . getAttribute ( f) == q ( f , d [ f ] ) ) b && "data-" == f . slice ( 0 , 5 ) || ( g = a . hasAttribute ( f ) , a . removeAttribute ( f ) ) ; for ( var h in c ) this . _ . definition . fullMatch && a . getStyle ( h ) != q ( h , c [ h ] , ! 0 ) || ( g= g || ! ! a . getStyle ( h ) , a . removeStyle ( h ) ) ;
v( a , e , D [ a . getName ( ) ] ) ; g && ( this . _ . definition . alwaysRemoveElement ? m ( a , 1 ) : ! CKEDITOR . dtd . $block [ a . getName ( ) ] || this . _ . enterMode == CKEDITOR . ENTER _BR && ! a . hasAttributes ( ) ? m ( a ) : a . renameNode ( this . _ . enterMode == CKEDITOR . ENTER _P ? "p" : "div" ) ) } function G( a ) { for ( var b = F ( this ) , c = a . getElementsByTag ( this . element ) , d , e = c . count ( ) ; 0 <= -- e ; ) d = c . getItem ( e ) , d . isReadOnly ( ) || z . call ( this , d , ! 0 ) ; for ( var g in b ) if ( g != this . element ) for ( c = a . getElementsByTag ( g ) , e = c . count ( ) - 1 ; 0 <= e ; e -- ) d = c . getItem ( e ) , d . isReadOnly ( ) || v( d , b [ g ] ) } function v ( a ,
b , c ) { if ( b = b && b . attributes ) for ( var d = 0 ; d < b . length ; d ++ ) { var e = b [ d ] [ 0 ] , g; if ( g = a . getAttribute ( e ) ) { var f = b [ d ] [ 1 ] ; ( null === f|| f . test && f . test ( g ) || "string" == typeof f && g == f ) && a . removeAttribute ( e ) } } c || m ( a ) } function m ( a , b ) { if ( ! a . hasAttributes ( ) || b ) if ( CKEDITOR . dtd . $block [ a . getName ( ) ] ) { var c = a . getPrevious ( I ) , d = a . getNext ( I ) ; ! c || c . type != CKEDITOR . NODE _TEXT && c . isBlockBoundary ( { br : 1 } ) || a . append ( "br" , 1 ) ; ! d || d . type != CKEDITOR . NODE _TEXT && d . isBlockBoundary ( { br : 1 } ) || a . append ( "br" ) ; a . remove ( ! 0 ) } else c = a . getFirst ( ) , d = a . getLast ( ) ,
a . remove ( ! 0 ) , c && ( c . type == CKEDITOR . NODE _ELEMENT && c . mergeSiblings ( ) , d && ! c . equals ( d ) && d . type == CKEDITOR . NODE _ELEMENT && d . mergeSiblings ( ) ) } function M ( a , b , c ) { var d ; d = a . element ; "*" == d && ( d = "span" ) ; d = new CKEDITOR . dom . element ( d , b ) ; c && c . copyAttributes ( d ) ; d = w ( d , a ) ; b . getCustomData ( "doc_processing_style" ) && d . hasAttribute ( "id" ) ? d . removeAttribute ( "id" ) : b . setCustomData ( "doc_processing_style" , 1 ) ; return d } function w ( a , b ) { var c = b . _ . definition , d = c . attributes , c = CKEDITOR . style . getStyleText ( c ) ; if ( d ) for ( var e in d ) a . setAttribute ( e ,
d [ e ] ) ; c && a . setAttribute ( "style" , c ) ; a . getDocument ( ) . removeCustomData ( "doc_processing_style" ) ; return a } function J ( a , b ) { for ( var c in a ) a [ c ] = a [ c ] . replace ( H , function ( a , c ) { return b [ c ] } ) } function F ( a ) { if ( a . _ . overrides ) return a . _ . overrides ; var b = a . _ . overrides = { } , c = a . _ . definition . overrides ; if ( c ) { CKEDITOR . tools . isArray ( c ) || ( c = [ c ] ) ; for ( var d = 0 ; d < c . length ; d ++ ) { var e = c [ d ] , g, f ; "string" == typeof e ? g = e . toLowerCase ( ) : ( g = e . element ? e . element . toLowerCase ( ) : a . element , f = e . attributes ) ; e = b [ g] || ( b [ g ] = { } ) ; if ( f ) { var e = e . attributes =
e . attributes || [ ] , h ; for ( h in f ) e . push ( [ h . toLowerCase ( ) , f [ h ] ] ) } } } return b } function q ( a , b , c ) { var d = new CKEDITOR . dom . element ( "span" ) ; d [ c ? "setStyle" : "setAttribute" ] ( a , b ) ; return d [ c ? "getStyle" : "getAttribute" ] ( a ) } function u ( a , b ) { function c ( a , b ) { return "font-family" == b . toLowerCase ( ) ? a . replace ( /["']/g , "" ) : a } "string" == typeof a && ( a = CKEDITOR . tools . parseCssText ( a ) ) ; "string" == typeof b && ( b = CKEDITOR . tools . parseCssText ( b , ! 0 ) ) ; for ( var d in a ) if ( ! ( d in b ) || c ( b [ d ] , d ) != c ( a [ d ] , d ) && "inherit" != a [ d ] && "inherit" != b [ d ] ) return ! 1 ;
return ! 0 } function K ( a , b , c ) { var d = a . getRanges ( ) ; b = b ? this . removeFromRange : this . applyToRange ; for ( var e , g = d . createIterator ( ) ; e = g . getNextRange ( ) ; ) b . call ( this , e , c ) ; a . selectRanges ( d ) } var D = { address : 1 , div : 1 , h1 : 1 , h2 : 1 , h3 : 1 , h4 : 1 , h5 : 1 , h6 : 1 , p : 1 , pre : 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 , details : 1 , datagrid : 1 , datalist : 1 } , B = { a : 1 , blockquote : 1 , embed : 1 , hr : 1 , img : 1 , li : 1 , object : 1 , ol : 1 , table : 1 , td : 1 , tr : 1 , th : 1 , ul : 1 , dl : 1 ,
dt : 1 , dd : 1 , form : 1 , audio : 1 , video : 1 } , t = /\s*(?:;\s*|$)/ , H= /#\((.+?)\)/g , A = CKEDITOR . dom . walker . bookmark ( 0 , 1 ) , I = CKEDITOR . dom . walker . whitespaces ( 1 ) ; CKEDITOR . style = function ( a , b ) { if ( "string" == typeof a . type ) return new CKEDITOR . style . customHandlers [ a . type ] ( a ) ; var c = a . attributes ; c && c . style && ( a . styles = CKEDITOR . tools . extend ( { } , a . styles , CKEDITOR . tools . parseCssText ( c . style ) ) , delete c . style ) ; b && ( a = CKEDITOR . tools . clone ( a ) , J ( a . attributes , b ) , J ( a . styles , b ) ) ; c = this . element = a . element ? "string" == typeof a . element ? a . element . toLowerCase ( ) :
a . element : "*" ; this . type = a . type || ( D [ c ] ? CKEDITOR . STYLE _BLOCK : B [ c ] ? CKEDITOR . STYLE _OBJECT : CKEDITOR . STYLE _INLINE ) ; "object" == typeof this . element && ( this . type = CKEDITOR . STYLE _OBJECT ) ; this . _ = { definition : a } } ; CKEDITOR . style . prototype = { apply : function ( a ) { if ( a instanceof CKEDITOR . dom . document ) return K . call ( this , a . getSelection ( ) ) ; if ( this . checkApplicable ( a . elementPath ( ) , a ) ) { var b = this . _ . enterMode ; b || ( this . _ . enterMode = a . activeEnterMode ) ; K . call ( this , a . getSelection ( ) , 0 , a ) ; this . _ . enterMode = b } } , remove : function ( a ) { if ( a instanceof
CKEDITOR . dom . document ) return K . call ( this , a . getSelection ( ) , 1 ) ; if ( this . checkApplicable ( a . elementPath ( ) , a ) ) { var b = this . _ . enterMode ; b || ( this . _ . enterMode = a . activeEnterMode ) ; K . call ( this , a . getSelection ( ) , 1 , a ) ; this . _ . enterMode = b } } , applyToRange : function ( a ) { this . applyToRange = this . type == CKEDITOR . STYLE _INLINE ? b : this . type == CKEDITOR . STYLE _BLOCK ? h : this . type == CKEDITOR . STYLE _OBJECT ? e : null ; return this . applyToRange ( a ) } , removeFromRange : function ( a ) { this . removeFromRange = this . type == CKEDITOR . STYLE _INLINE ? c : this . type == CKEDITOR . STYLE _BLOCK ?
n : this . type == CKEDITOR . STYLE _OBJECT ? k : null ; return this . removeFromRange ( a ) } , applyToObject : function ( a ) { w ( a , this ) } , checkActive : function ( a , b ) { switch ( this . type ) { case CKEDITOR . STYLE _BLOCK : return this . checkElementRemovable ( a . block || a . blockLimit , ! 0 , b ) ; case CKEDITOR . STYLE _OBJECT : case CKEDITOR . STYLE _INLINE : for ( var c = a . elements , d = 0 , e ; d < c . length ; d ++ ) if ( e = c [ d ] , this . type != CKEDITOR . STYLE _INLINE || e != a . block && e != a . blockLimit ) { if ( this . type == CKEDITOR . STYLE _OBJECT ) { var g = e . getName ( ) ; if ( ! ( "string" == typeof this . element ?
g== this . element : g in this . element ) ) continue } if ( this . checkElementRemovable ( e , ! 0 , b ) ) return ! 0 } } return ! 1 } , checkApplicable : function ( a , b , c ) { b && b instanceof CKEDITOR . filter && ( c = b ) ; if ( c && ! c . check ( this ) ) return ! 1 ; switch ( this . type ) { case CKEDITOR . STYLE _OBJECT : return ! ! a . contains ( this . element ) ; case CKEDITOR . STYLE _BLOCK : return ! ! a . blockLimit . getDtd ( ) [ this . element ] } return ! 0 } , checkElementMatch : function ( a , b ) { var c = this . _ . definition ; if ( ! a || ! c . ignoreReadonly && a . isReadOnly ( ) ) return ! 1 ; var d = a . getName ( ) ; if ( "string" == typeof this . element ?
d == this . element : d in this . element ) { if ( ! b && ! a . hasAttributes ( ) ) return ! 0 ; if ( d = c . _AC ) c = d ; else { var d = { } , e = 0 , g= c . attributes ; if ( g ) for ( var f in g ) e ++ , d [ f ] = g [ f ] ; if ( f = CKEDITOR . style . getStyleText ( c ) ) d . style || e ++ , d . style = f ; d . _length = e ; c = c . _AC = d } if ( c . _length ) { for ( var h in c ) if ( "_length" != h ) if ( d = a . getAttribute ( h ) || "" , "style" == h ? u ( c [ h ] , d ) : c [ h ] == d ) { if ( ! b ) return ! 0 } else if ( b ) return ! 1 ; if ( b ) return ! 0 } else return ! 0 } return ! 1 } , checkElementRemovable : function ( a , b , c ) { if ( this . checkElementMatch ( a , b , c ) ) return ! 0 ; if ( b = F ( this ) [ a . getName ( ) ] ) { var d ;
if ( ! ( b = b . attributes ) ) return ! 0 ; for ( c = 0 ; c < b . length ; c ++ ) if ( d = b [ c ] [ 0 ] , d = a . getAttribute ( d ) ) { var e = b [ c ] [ 1 ] ; if ( null === e ) return ! 0 ; if ( "string" == typeof e ) { if ( d == e ) return ! 0 } else if ( e . test ( d ) ) return ! 0 } } return ! 1 } , buildPreview : function ( a ) { var b = this . _ . definition , c = [ ] , d = b . element ; "bdo" == d && ( d = "span" ) ; var c = [ "\x3c" , d ] , e = b . attributes ; if ( e ) for ( var g in e ) c . push ( " " , g, '\x3d"' , e [ g ] , '"' ) ; ( e = CKEDITOR . style . getStyleText ( b ) ) && c . push ( ' style\x3d"' , e , '"' ) ; c . push ( "\x3e" , a || b . name , "\x3c/" , d , "\x3e" ) ; return c . join ( "" ) } , getDefinition : function ( ) { return this . _ . definition } } ;
CKEDITOR . style . getStyleText = function ( a ) { var b = a . _ST ; if ( b ) return b ; var b = a . styles , c = a . attributes && a . attributes . style || "" , d = "" ; c . length && ( c = c . replace ( t , ";" ) ) ; for ( var e in b ) { var g= b [ e ] , f = ( e + ":" + g ) . replace ( t , ";" ) ; "inherit" == g? d += f : c += f } c . length && ( c = CKEDITOR . tools . normalizeCssText ( c , ! 0 ) ) ; return a . _ST = c + d } ; CKEDITOR . style . customHandlers = { } ; CKEDITOR . style . unstylableElements = [ ] ; CKEDITOR . style . addCustomHandler = function ( a ) { var b = function ( a ) { this . _ = { definition : a } ; this . setup && this . setup ( a ) } ; b . prototype = CKEDITOR . tools . extend ( CKEDITOR . tools . prototypedCopy ( CKEDITOR . style . prototype ) ,
{ assignedTo : CKEDITOR . STYLE _OBJECT } , a , ! 0 ) ; return this . customHandlers [ a . type ] = b } ; var N = CKEDITOR . POSITION _PRECEDING | CKEDITOR . POSITION _IDENTICAL | CKEDITOR . POSITION _IS _CONTAINED , L = CKEDITOR . POSITION _FOLLOWING | CKEDITOR . POSITION _IDENTICAL | CKEDITOR . POSITION _IS _CONTAINED } ) ( ) ; CKEDITOR . styleCommand = function ( a , d ) { this . requiredContent = this . allowedContent = this . style = a ; CKEDITOR . tools . extend ( this , d , ! 0 ) } ;
CKEDITOR . styleCommand . prototype . exec = function ( a ) { a . focus ( ) ; this . state == CKEDITOR . TRISTATE _OFF ? a . applyStyle ( this . style ) : this . state == CKEDITOR . TRISTATE _ON && a . removeStyle ( this . style ) } ; CKEDITOR . stylesSet = new CKEDITOR . resourceManager ( "" , "stylesSet" ) ; CKEDITOR . addStylesSet = CKEDITOR . tools . bind ( CKEDITOR . stylesSet . add , CKEDITOR . stylesSet ) ; CKEDITOR . loadStylesSet = function ( a , d , b ) { CKEDITOR . stylesSet . addExternal ( a , d , "" ) ; CKEDITOR . stylesSet . load ( a , b ) } ;
CKEDITOR . tools . extend ( CKEDITOR . editor . prototype , { attachStyleStateChange : function ( a , d ) { var b = this . _ . styleStateChangeCallbacks ; b || ( b = this . _ . styleStateChangeCallbacks = [ ] , this . on ( "selectionChange" , function ( a ) { for ( var d = 0 ; d < b . length ; d ++ ) { var e = b [ d ] , h = e . style . checkActive ( a . data . path , this ) ? CKEDITOR . TRISTATE _ON : CKEDITOR . TRISTATE _OFF ; e . fn . call ( this , h ) } } ) ) ; b . push ( { style : a , fn : d } ) } , applyStyle : function ( a ) { a . apply ( this ) } , removeStyle : function ( a ) { a . remove ( this ) } , getStylesSet : function ( a ) { if ( this . _ . stylesDefinitions ) a ( this . _ . stylesDefinitions ) ;
CKEDITOR . tools . extend ( CKEDITOR . editor . prototype , { attachStyleStateChange : function ( a , d ) { var b = this . _ . styleStateChangeCallbacks ; b || ( b = this . _ . styleStateChangeCallbacks = [ ] , this . on ( "selectionChange" , function ( a ) { for ( var d = 0 ; d < b . length ; d ++ ) { var e = b [ d ] , k = e . style . checkActive ( a . data . path , this ) ? CKEDITOR . TRISTATE _ON : CKEDITOR . TRISTATE _OFF ; e . fn . call ( this , k ) } } ) ) ; b . push ( { style : a , fn : d } ) } , applyStyle : function ( a ) { a . apply ( this ) } , removeStyle : function ( a ) { a . remove ( this ) } , getStylesSet : function ( a ) { if ( this . _ . stylesDefinitions ) a ( this . _ . stylesDefinitions ) ;
else { var d = this , b = d . config . stylesCombo _stylesSet || d . config . stylesSet ; if ( ! 1 === b ) a ( null ) ; else if ( b instanceof Array ) d . _ . stylesDefinitions = b , a ( b ) ; else { b || ( b = "default" ) ; var b = b . split ( ":" ) , c = b [ 0 ] ; CKEDITOR . stylesSet . addExternal ( c , b [ 1 ] ? b . slice ( 1 ) . join ( ":" ) : CKEDITOR . getUrl ( "styles.js" ) , "" ) ; CKEDITOR . stylesSet . load ( c , function ( b ) { d . _ . stylesDefinitions = b [ c ] ; a ( d . _ . stylesDefinitions ) } ) } } } } ) ;
( function ( ) { if ( window . Promise ) CKEDITOR . tools . promise = Promise ; else { var a = CKEDITOR . getUrl ( "vendor/promise.js" ) ; if ( "function" === typeof window . define && window . define . amd && "function" === typeof window . require ) return window . require ( [ a ] , function ( a ) { CKEDITOR . tools . promise = a } ) ; CKEDITOR . scriptLoader . load ( a , function ( d ) { if ( ! d ) return CKEDITOR . error ( "no-vendor-lib" , { path : a } ) ; if ( "undefined" !== typeof window . ES6Promise ) return CKEDITOR . tools . promise = ES6Promise } ) } } ) ( ) ;
( function ( ) { function a ( a , g , e ) { a . once ( "selectionCheck" , function ( a ) { if ( ! d ) { var c = a . data . getRanges ( ) [ 0 ] ; e . equals ( c ) ? a . cancel ( ) : g . equals ( c ) && ( b = ! 0 ) } } , null , null , - 1 ) } var d = ! 0 , b = ! 1 ; CKEDITOR . dom . selection . setupEditorOptimization = function ( a ) { a . on ( "selectionCheck" , function ( a ) { a . data && ! b && a . data . optimizeInElementEnds ( ) ; b = ! 1 } ) ; a . on ( "contentDom" , function ( ) { var b = a . editable ( ) ; b && ( b . attachListener ( b , "keydown" , function ( a ) { this . _ . shiftPressed = a . data . $ . shiftKey } , this ) , b . attachListener ( b , "keyup" , function ( a ) { this . _ . shiftPressed =
a . data . $ . shiftKey } , this ) ) } ) } ; CKEDITOR . dom . selection . prototype . optimizeInElementEnds = function ( ) { var b = this . getRanges ( ) [ 0 ] , g = this . root . editor , e ; if ( this . root . editor . _ . shiftPressed || this . isFake || b . isCollapsed || b . startContainer . equals ( b . endContainer ) || ( b . endContainer . is ? b . endContainer . is ( "li" ) : b . endContainer . getParent ( ) . is && b . endContainer . getParent ( ) . is ( "li" ) ) ) e = ! 1 ; else if ( 0 === b . endOffset ) e = ! 0 ; else { e = b . startContainer . type === CKEDITOR . NODE _TEXT ; var h = b . endContainer . type === CKEDITOR . NODE _TEXT , k = e ? b . startContainer . getLength ( ) :
b . startContainer . getChildCount ( ) ; e = b . startOffset === k|| e ^ h } e && ( e = b . clone ( ) , b . shrink ( CKEDITOR . SHRINK _TEXT , ! 1 , { skipBogus : ! CKEDITOR . env . webkit } ) , d = ! 1 , a ( g , b , e ) , b . select ( ) , d = ! 0 ) } } ) ( ) ;
( function ( ) { function a ( a , c ) { if ( b ( a ) ) a = Math . round ( c * ( parseFloat ( a ) / 100 ) ) ; else if ( "string" === typeof a && a . match ( /^\d+$/gm ) || "string" === typeof a && a . match ( /^\d+(?:deg)?$/gm ) ) a = parseInt ( a , 10 ) ; return a } function d ( a , c ) { b ( a ) ? a = c * ( parseFloat ( a ) / 100 ) : "string" === typeof a && a . match ( /^\d?\.\d+/gm ) && ( a = parseFloat ( a ) ) ; return a } function b ( a ) { return "string" === typeof a && a . match ( /^((\d*\.\d+)|(\d+))%{1}$/gm ) } function c ( a , b , c ) { return ! isNaN ( a ) && a >= b && a <= c } function g ( a ) { a = a . toString ( 16 ) ; return 1 == a . length ? "0" + a : a } CKEDITOR . tools . color =
( function ( ) { function a ( a , f , e ) { a . once ( "selectionCheck" , function ( a ) { if ( ! d ) { var c = a . data . getRanges ( ) [ 0 ] ; e . equals ( c ) ? a . cancel ( ) : f . equals ( c ) && ( b = ! 0 ) } } , null , null , - 1 ) } var d = ! 0 , b = ! 1 ; CKEDITOR . dom . selection . setupEditorOptimization = function ( a ) { a . on ( "selectionCheck" , function ( a ) { a . data && ! b && a . data . optimizeInElementEnds ( ) ; b = ! 1 } ) ; a . on ( "contentDom" , function ( ) { var b = a . editable ( ) ; b && ( b . attachListener ( b , "keydown" , function ( a ) { this . _ . shiftPressed = a . data . $ . shiftKey } , this ) , b . attachListener ( b , "keyup" , function ( a ) { this . _ . shiftPressed =
a . data . $ . shiftKey } , this ) ) } ) } ; CKEDITOR . dom . selection . prototype . optimizeInElementEnds = function ( ) { var b = this . getRanges ( ) [ 0 ] , f = this . root . editor , e ; if ( this . root . editor . _ . shiftPressed || this . isFake || b . isCollapsed || b . startContainer . equals ( b . endContainer ) || ( b . endContainer . is ? b . endContainer . is ( "li" ) : b . endContainer . getParent ( ) . is && b . endContainer . getParent ( ) . is ( "li" ) ) ) e = ! 1 ; else if ( 0 === b . endOffset ) e = ! 0 ; else { e = b . startContainer . type === CKEDITOR . NODE _TEXT ; var k = b . endContainer . type === CKEDITOR . NODE _TEXT , h = e ? b . startContainer . getLength ( ) :
b . startContainer . getChildCount ( ) ; e = b . startOffset === h|| e ^ k } e && ( e = b . clone ( ) , b . shrink ( CKEDITOR . SHRINK _TEXT , ! 1 , { skipBogus : ! CKEDITOR . env . webkit } ) , d = ! 1 , a ( f , b , e ) , b . select ( ) , d = ! 0 ) } } ) ( ) ;
( function ( ) { function a ( a , c ) { if ( b ( a ) ) a = Math . round ( c * ( parseFloat ( a ) / 100 ) ) ; else if ( "string" === typeof a && a . match ( /^\d+$/gm ) || "string" === typeof a && a . match ( /^\d+(?:deg)?$/gm ) ) a = parseInt ( a , 10 ) ; return a } function d ( a , c ) { b ( a ) ? a = c * ( parseFloat ( a ) / 100 ) : "string" === typeof a && a . match ( /^\d?\.\d+/gm ) && ( a = parseFloat ( a ) ) ; return a } function b ( a ) { return "string" === typeof a && a . match ( /^((\d*\.\d+)|(\d+))%{1}$/gm ) } function c ( a , b , c ) { return ! isNaN ( a ) && a >= b && a <= c } function f ( a ) { a = a . toString ( 16 ) ; return 1 == a . length ? "0" + a : a } CKEDITOR . tools . color =
CKEDITOR . tools . createClass ( { $ : function ( a , b ) { this . _ . initialColorCode = a ; this . _ . defaultValue = b ; this . _ . parseInput ( a ) } , proto : { getHex : function ( ) { if ( ! this . _ . isValidColor ) return this . _ . defaultValue ; var a = this . _ . blendAlphaColor ( this . _ . red , this . _ . green , this . _ . blue , this . _ . alpha ) ; return this . _ . formatHexString ( a [ 0 ] , a [ 1 ] , a [ 2 ] ) } , getHexWithAlpha : function ( ) { if ( ! this . _ . isValidColor ) return this . _ . defaultValue ; var a = Math . round ( this . _ . alpha * CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE ) ; return this . _ . formatHexString ( this . _ . red ,
this . _ . green , this . _ . blue , a ) } , getRgb : function ( ) { if ( ! this . _ . isValidColor ) return this . _ . defaultValue ; var a = this . _ . blendAlphaColor ( this . _ . red , this . _ . green , this . _ . blue , this . _ . alpha ) ; return this . _ . formatRgbString ( "rgb" , a [ 0 ] , a [ 1 ] , a [ 2 ] ) } , getRgba : function ( ) { return this . _ . isValidColor ? this . _ . formatRgbString ( "rgba" , this . _ . red , this . _ . green , this . _ . blue , this . _ . alpha ) : this . _ . defaultValue } , getHsl : function ( ) { var a = 0 === this . _ . alpha || 1 === this . _ . alpha ; if ( ! this . _ . isValidColor ) return this . _ . defaultValue ; this . _ . type ===
CKEDITOR . tools . color . TYPE _HSL && a ? a = [ this . _ . hue , this . _ . saturation , this . _ . lightness ] : ( a = this . _ . blendAlphaColor ( this . _ . red , this . _ . green , this . _ . blue , this . _ . alpha ) , a = this . _ . rgbToHsl ( a [ 0 ] , a [ 1 ] , a [ 2 ] ) ) ; return this . _ . formatHslString ( "hsl" , a [ 0 ] , a [ 1 ] , a [ 2 ] ) } , getHsla : function ( ) { var a ; if ( ! this . _ . isValidColor ) return this . _ . defaultValue ; a = this . _ . type === CKEDITOR . tools . color . TYPE _HSL ? [ this . _ . hue , this . _ . saturation , this . _ . lightness ] : this . _ . rgbToHsl ( this . _ . red , this . _ . green , this . _ . blue ) ; return this . _ . formatHslString ( "hsla" ,
a [ 0 ] , a [ 1 ] , a [ 2 ] , this . _ . alpha ) } , getInitialValue : function ( ) { return this . _ . initialColorCode } } , _ : { initialColorCode : "" , isValidColor : ! 0 , type : 0 , hue : 0 , saturation : 0 , lightness : 0 , red : 0 , green : 0 , blue : 0 , alpha : 1 , blendAlphaColor : function ( a , b , c , d ) { return CKEDITOR . tools . array . map ( [ a , b , c ] , function ( a ) { return Math . round ( CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE - d * ( CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE - a ) ) } ) } , formatHexString : function ( a , b , c , d ) { a = "#" + g( a ) + g ( b ) + g ( c ) ; void 0 !== d && ( a += g ( d ) ) ; return a . toUpperCase ( ) } , formatRgbString : function ( a ,
b , c , d , g ) { b = [ b , c , d ] ; void 0 !== g&& b . push ( g ) ; return a + "(" + b . join ( "," ) + ")" } , formatHslString : function ( a , b , c , d , g ) { return a + "(" + b + "," + c + "%," + d + "%" + ( void 0 !== g? "," + g : "" ) + ")" } , parseInput : function ( a ) { if ( "string" !== typeof a ) this . _ . isValidColor = ! 1 ; else { a = CKEDITOR . tools . trim ( a ) ; var b = this . _ . matchStringToNamedColor ( a ) ; b && ( a = b ) ; var b = this . _ . extractColorChannelsFromHex ( a ) , c = this . _ . extractColorChannelsFromRgba ( a ) ; a = this . _ . extractColorChannelsFromHsla ( a ) ; ( a = b || c || a ) ? ( this . _ . type = a . type , this . _ . red = a . red , this . _ . green =
a [ 0 ] , a [ 1 ] , a [ 2 ] , this . _ . alpha ) } , getInitialValue : function ( ) { return this . _ . initialColorCode } } , _ : { initialColorCode : "" , isValidColor : ! 0 , type : 0 , hue : 0 , saturation : 0 , lightness : 0 , red : 0 , green : 0 , blue : 0 , alpha : 1 , blendAlphaColor : function ( a , b , c , d ) { return CKEDITOR . tools . array . map ( [ a , b , c ] , function ( a ) { return Math . round ( CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE - d * ( CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE - a ) ) } ) } , formatHexString : function ( a , b , c , d ) { a = "#" + f( a ) + f ( b ) + f ( c ) ; void 0 !== d && ( a += f ( d ) ) ; return a . toUpperCase ( ) } , formatRgbString : function ( a ,
b , c , d , f ) { b = [ b , c , d ] ; void 0 !== f&& b . push ( f ) ; return a + "(" + b . join ( "," ) + ")" } , formatHslString : function ( a , b , c , d , f ) { return a + "(" + b + "," + c + "%," + d + "%" + ( void 0 !== f? "," + f : "" ) + ")" } , parseInput : function ( a ) { if ( "string" !== typeof a ) this . _ . isValidColor = ! 1 ; else { a = CKEDITOR . tools . trim ( a ) ; var b = this . _ . matchStringToNamedColor ( a ) ; b && ( a = b ) ; var b = this . _ . extractColorChannelsFromHex ( a ) , c = this . _ . extractColorChannelsFromRgba ( a ) ; a = this . _ . extractColorChannelsFromHsla ( a ) ; ( a = b || c || a ) ? ( this . _ . type = a . type , this . _ . red = a . red , this . _ . green =
a . green , this . _ . blue = a . blue , this . _ . alpha = a . alpha , a . type === CKEDITOR . tools . color . TYPE _HSL && ( this . _ . hue = a . hue , this . _ . saturation = a . saturation , this . _ . lightness = a . lightness ) ) : this . _ . isValidColor = ! 1 } } , matchStringToNamedColor : function ( a ) { return CKEDITOR . tools . color . namedColors [ a . toLowerCase ( ) ] || null } , extractColorChannelsFromHex : function ( a ) { - 1 === a . indexOf ( "#" ) && ( a = "#" + a ) ; a . match ( CKEDITOR . tools . color . hex3CharsRegExp ) && ( a = this . _ . hex3ToHex6 ( a ) ) ; a . match ( CKEDITOR . tools . color . hex4CharsRegExp ) && ( a = this . _ . hex4ToHex8 ( a ) ) ;
if ( ! a . match ( CKEDITOR . tools . color . hex6CharsRegExp ) && ! a . match ( CKEDITOR . tools . color . hex8CharsRegExp ) ) return null ; a = a . split ( "" ) ; var b = 1 ; a [ 7 ] && a [ 8 ] && ( b = parseInt ( a [ 7 ] + a [ 8 ] , 16 ) , b /= CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE , b = Number ( b . toFixed ( 1 ) ) ) ; return { type : CKEDITOR . tools . color . TYPE _RGB , red : parseInt ( a [ 1 ] + a [ 2 ] , 16 ) , green : parseInt ( a [ 3 ] + a [ 4 ] , 16 ) , blue : parseInt ( a [ 5 ] + a [ 6 ] , 16 ) , alpha : b } } , extractColorChannelsFromRgba : function ( b ) { var c = this . _ . extractColorChannelsByPattern ( b , CKEDITOR . tools . color . rgbRegExp ) ; if ( ! c ||
3 > c . length || 4 < c . length ) return null ; var g = 4 === c . length ; b = a ( c [ 0 ] , CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE ) ; var l = a ( c [ 1 ] , CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE ) , q = a ( c [ 2 ] , CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE ) , f= 1 ; g && ( f = d ( c [ 3 ] , CKEDITOR . tools . color . MAX _ALPHA _CHANNEL _VALUE ) ) ; c = { type : CKEDITOR . tools . color . TYPE _RGB , red : b , green : l, blue : q , alpha : f } ; return this . _ . areColorChannelsValid ( b , l, q , f ) ? c : null } , extractColorChannelsFromHsla : function ( b ) { var c = this . _ . extractColorChannelsByPattern ( b , CKEDITOR . tools . color . hslRegExp ) ;
if ( ! c || 3 > c . length || 4 < c . length ) return null ; var g= 4 === c . length , l = a ( c [ 0 ] , CKEDITOR . tools . color . MAX _HUE _CHANNEL _VALUE ) , q = d ( c [ 1 ] , CKEDITOR . tools . color . MAX _SATURATION _LIGHTNESS _CHANNEL _VALUE ) , f = d ( c [ 2 ] , CKEDITOR . tools . color . MAX _SATURATION _LIGHTNESS _CHANNEL _VALUE ) , w = 1 ; b = this . _ . hslToRgb ( l, q , f ) ; g && ( w = d ( c [ 3 ] , CKEDITOR . tools . color . MAX _ALPHA _CHANNEL _VALUE ) ) ; b . push ( w ) ; c = { type : CKEDITOR . tools . color . TYPE _HSL , red : b [ 0 ] , green : b [ 1 ] , blue : b [ 2 ] , alpha : b [ 3 ] , hue : l , saturation : Math . round ( 100 * q ) , lightness : Math . round ( 100 * f ) } ; return this . _ . areColorChannelsValid ( b [ 0 ] ,
3 > c . length || 4 < c . length ) return null ; var f = 4 === c . length ; b = a ( c [ 0 ] , CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE ) ; var n = a ( c [ 1 ] , CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE ) , l = a ( c [ 2 ] , CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE ) , g= 1 ; f && ( g = d ( c [ 3 ] , CKEDITOR . tools . color . MAX _ALPHA _CHANNEL _VALUE ) ) ; c = { type : CKEDITOR . tools . color . TYPE _RGB , red : b , green : n, blue : l , alpha : g } ; return this . _ . areColorChannelsValid ( b , n, l , g ) ? c : null } , extractColorChannelsFromHsla : function ( b ) { var c = this . _ . extractColorChannelsByPattern ( b , CKEDITOR . tools . color . hslRegExp ) ;
if ( ! c || 3 > c . length || 4 < c . length ) return null ; var f= 4 === c . length , n = a ( c [ 0 ] , CKEDITOR . tools . color . MAX _HUE _CHANNEL _VALUE ) , l = d ( c [ 1 ] , CKEDITOR . tools . color . MAX _SATURATION _LIGHTNESS _CHANNEL _VALUE ) , g = d ( c [ 2 ] , CKEDITOR . tools . color . MAX _SATURATION _LIGHTNESS _CHANNEL _VALUE ) , x = 1 ; b = this . _ . hslToRgb ( n, l , g ) ; f && ( x = d ( c [ 3 ] , CKEDITOR . tools . color . MAX _ALPHA _CHANNEL _VALUE ) ) ; b . push ( x ) ; c = { type : CKEDITOR . tools . color . TYPE _HSL , red : b [ 0 ] , green : b [ 1 ] , blue : b [ 2 ] , alpha : b [ 3 ] , hue : n , saturation : Math . round ( 100 * l ) , lightness : Math . round ( 100 * g ) } ; return this . _ . areColorChannelsValid ( b [ 0 ] ,
b [ 1 ] , b [ 2 ] , b [ 3 ] ) ? c : null } , hex3ToHex6 : function ( a ) { a = a . split ( "" ) ; return "#" + a [ 1 ] + a [ 1 ] + a [ 2 ] + a [ 2 ] + a [ 3 ] + a [ 3 ] } , hex4ToHex8 : function ( a ) { return this . _ . hex3ToHex6 ( a . substr ( 0 , 4 ) ) + CKEDITOR . tools . repeat ( a [ 4 ] , 2 ) } , extractColorChannelsByPattern : function ( a , b ) { var c = a . match ( b ) ; if ( ! c ) return null ; var d = - 1 === c [ 1 ] . indexOf ( "," ) ? /\s/ : "," , d = c [ 1 ] . split ( d ) , d = CKEDITOR . tools . array . reduce ( d , function ( a , b ) { var c = CKEDITOR . tools . trim ( b ) ; return 0 === c . length ? a : a . concat ( [ c ] ) } , [ ] ) ; c [ 2 ] && ( c = CKEDITOR . tools . trim ( c [ 2 ] . replace ( /[\/,]/ , "" ) ) , d . push ( c ) ) ;
return d } , areColorChannelsValid : function ( a , b , d , g ) { return c ( a , 0 , CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE ) && c ( b , 0 , CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE ) && c ( d , 0 , CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE ) && c ( g , 0 , CKEDITOR . tools . color . MAX _ALPHA _CHANNEL _VALUE ) } , hslToRgb : function ( a , b , c ) { var d = function ( d ) { var f = ( d + a / 30 ) % 12 ; d = b * Math . min ( c , 1 - c ) ; f= Math . min ( f - 3 , 9 - f , 1 ) ; f = Math . max ( - 1 , f ) ; return Math . round ( ( c - d * f ) * CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE ) } ; return [ d ( 0 ) , d ( 8 ) , d ( 4 ) ] } , rgbToHsl : function ( a , b , c ) { a /=
CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE ; b /= CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE ; var d = c / CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE , g = Math . max ( a , b , d ) , f = Math . min ( a , b , d ) ; c = g- f ; var w = 0 ; switch ( g ) { case a : w = ( b - d ) / c % 6 ; break ; case b : w = ( d - a ) / c + 2 ; break ; case d : w = ( a - b ) / c + 4 } a = 0 === c ? 0 : 60 * w; b = ( g + f ) / 2 ; g = 0 ; 1 !== b && 0 !== b && ( g = c / ( 1 - Math . abs ( 2 * b - 1 ) ) ) ; a = Math . round ( a ) ; g= Math . round ( 100 * g ) ; b = Math . round ( 100 * b ) ; return [ a , g , b ] } } , statics : { TYPE _RGB : 1 , TYPE _HSL : 2 , MAX _RGB _CHANNEL _VALUE : 255 , MAX _ALPHA _CHANNEL _VALUE : 1 , MAX _HUE _CHANNEL _VALUE : 360 ,
return d } , areColorChannelsValid : function ( a , b , d , f ) { return c ( a , 0 , CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE ) && c ( b , 0 , CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE ) && c ( d , 0 , CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE ) && c ( f , 0 , CKEDITOR . tools . color . MAX _ALPHA _CHANNEL _VALUE ) } , hslToRgb : function ( a , b , c ) { var d = function ( d ) { var g = ( d + a / 30 ) % 12 ; d = b * Math . min ( c , 1 - c ) ; g= Math . min ( g - 3 , 9 - g , 1 ) ; g = Math . max ( - 1 , g ) ; return Math . round ( ( c - d * g ) * CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE ) } ; return [ d ( 0 ) , d ( 8 ) , d ( 4 ) ] } , rgbToHsl : function ( a , b , c ) { a /=
CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE ; b /= CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE ; var d = c / CKEDITOR . tools . color . MAX _RGB _CHANNEL _VALUE , f = Math . max ( a , b , d ) , g = Math . min ( a , b , d ) ; c = f- g ; var x = 0 ; switch ( f ) { case a : x = ( b - d ) / c % 6 ; break ; case b : x = ( d - a ) / c + 2 ; break ; case d : x = ( a - b ) / c + 4 } a = 0 === c ? 0 : 60 * x; b = ( f + g ) / 2 ; f = 0 ; 1 !== b && 0 !== b && ( f = c / ( 1 - Math . abs ( 2 * b - 1 ) ) ) ; a = Math . round ( a ) ; f= Math . round ( 100 * f ) ; b = Math . round ( 100 * b ) ; return [ a , f , b ] } } , statics : { TYPE _RGB : 1 , TYPE _HSL : 2 , MAX _RGB _CHANNEL _VALUE : 255 , MAX _ALPHA _CHANNEL _VALUE : 1 , MAX _HUE _CHANNEL _VALUE : 360 ,
MAX _SATURATION _LIGHTNESS _CHANNEL _VALUE : 1 , hex3CharsRegExp : /#([0-9a-f]{3}$)/gim , hex4CharsRegExp : /#([0-9a-f]{4}$)/gim , hex6CharsRegExp : /#([0-9a-f]{6}$)/gim , hex8CharsRegExp : /#([0-9a-f]{8}$)/gim , rgbRegExp : /rgba?\(([.,\d\s%]*)(\s*\/\s*[\d.%]+)?\s*\)/i , hslRegExp : /hsla?\((\s*(?:[.\d]+(?:deg)?)(?:\s*,?\s*[.\d]+%){2})((?:(?:\s*\/\s*)|(?:\s*,\s*))[\d.]+%?)?\s*\)/i , namedColors : { aliceblue : "#F0F8FF" , antiquewhite : "#FAEBD7" , aqua : "#00FFFF" , aquamarine : "#7FFFD4" , azure : "#F0FFFF" , beige : "#F5F5DC" , bisque : "#FFE4C4" , black : "#000000" ,
blanchedalmond : "#FFEBCD" , blue : "#0000FF" , blueviolet : "#8A2BE2" , brown : "#A52A2A" , burlywood : "#DEB887" , cadetblue : "#5F9EA0" , chartreuse : "#7FFF00" , chocolate : "#D2691E" , coral : "#FF7F50" , cornflowerblue : "#6495ED" , cornsilk : "#FFF8DC" , crimson : "#DC143C" , cyan : "#00FFFF" , darkblue : "#00008B" , darkcyan : "#008B8B" , darkgoldenrod : "#B8860B" , darkgray : "#A9A9A9" , darkgreen : "#006400" , darkgrey : "#A9A9A9" , darkkhaki : "#BDB76B" , darkmagenta : "#8B008B" , darkolivegreen : "#556B2F" , darkorange : "#FF8C00" , darkorchid : "#9932CC" , darkred : "#8B0000" , darksalmon : "#E9967A" ,
darkseagreen : "#8FBC8F" , darkslateblue : "#483D8B" , darkslategray : "#2F4F4F" , darkslategrey : "#2F4F4F" , darkturquoise : "#00CED1" , darkviolet : "#9400D3" , deeppink : "#FF1493" , deepskyblue : "#00BFFF" , dimgray : "#696969" , dimgrey : "#696969" , dodgerblue : "#1E90FF" , firebrick : "#B22222" , floralwhite : "#FFFAF0" , forestgreen : "#228B22" , fuchsia : "#FF00FF" , gainsboro : "#DCDCDC" , ghostwhite : "#F8F8FF" , gold : "#FFD700" , goldenrod : "#DAA520" , gray : "#808080" , green : "#008000" , greenyellow : "#ADFF2F" , grey : "#808080" , honeydew : "#F0FFF0" , hotpink : "#FF69B4" ,
@ -562,27 +557,27 @@ limegreen:"#32CD32",linen:"#FAF0E6",magenta:"#FF00FF",maroon:"#800000",mediumaqu
orchid : "#DA70D6" , palegoldenrod : "#EEE8AA" , palegreen : "#98FB98" , paleturquoise : "#AFEEEE" , palevioletred : "#DB7093" , papayawhip : "#FFEFD5" , peachpuff : "#FFDAB9" , peru : "#CD853F" , pink : "#FFC0CB" , plum : "#DDA0DD" , powderblue : "#B0E0E6" , purple : "#800080" , rebeccapurple : "#663399" , red : "#FF0000" , rosybrown : "#BC8F8F" , royalblue : "#4169E1" , saddlebrown : "#8B4513" , salmon : "#FA8072" , sandybrown : "#F4A460" , seagreen : "#2E8B57" , seashell : "#FFF5EE" , sienna : "#A0522D" , silver : "#C0C0C0" , skyblue : "#87CEEB" , slateblue : "#6A5ACD" , slategray : "#708090" ,
slategrey : "#708090" , snow : "#FFFAFA" , springgreen : "#00FF7F" , steelblue : "#4682B4" , tan : "#D2B48C" , teal : "#008080" , thistle : "#D8BFD8" , tomato : "#FF6347" , turquoise : "#40E0D0" , violet : "#EE82EE" , windowtext : "windowtext" , wheat : "#F5DEB3" , white : "#FFFFFF" , whitesmoke : "#F5F5F5" , yellow : "#FFFF00" , yellowgreen : "#9ACD32" } } } ) ; CKEDITOR . tools . style . parse . _colors = CKEDITOR . tools . color . namedColors } ) ( ) ; CKEDITOR . dom . comment = function ( a , d ) { "string" == typeof a && ( a = ( d ? d . $ : document ) . createComment ( a ) ) ; CKEDITOR . dom . domObject . call ( this , a ) } ;
CKEDITOR . dom . comment . prototype = new CKEDITOR . dom . node ; CKEDITOR . tools . extend ( CKEDITOR . dom . comment . prototype , { type : CKEDITOR . NODE _COMMENT , getOuterHtml : function ( ) { return "\x3c!--" + this . $ . nodeValue + "--\x3e" } } ) ; "use strict" ;
( function ( ) { var a = { } , d = { } , b ; for ( b in CKEDITOR . dtd . $blockLimit ) b in CKEDITOR . dtd . $list || ( a [ b ] = 1 ) ; for ( b in CKEDITOR . dtd . $block ) b in CKEDITOR . dtd . $blockLimit || b in CKEDITOR . dtd . $empty || ( d [ b ] = 1 ) ; CKEDITOR . dom . elementPath = function ( b , g) { var e = null , h = null , k = [ ] , l = b , q ; g = g || b . getDocument ( ) . getBody ( ) ; l|| ( l = g ) ; do if ( l . type == CKEDITOR . NODE _ELEMENT ) { k. push ( l ) ; if ( ! this . lastElement && ( this . lastElement = l, l . is ( CKEDITOR . dtd . $object ) || "false" == l . getAttribute ( "contenteditable" ) ) ) continue ; if ( l. equals ( g ) ) break ; if ( ! h && ( q = l . getName ( ) ,
"true" == l. getAttribute ( "contenteditable" ) ? h = l : ! e && d [ q ] && ( e = l ) , a [ q ] ) ) { if ( q = ! e && "div" == q ) { a : { q = l . getChildren ( ) ; for ( var f = 0 , w = q . count ( ) ; f < w ; f ++ ) { var B = q . getItem ( f ) ; if ( B . type == CKEDITOR . NODE _ELEMENT && CKEDITOR . dtd . $block [ B. getName ( ) ] ) { q = ! 0 ; break a } } q = ! 1 } q = ! q } q ? e = l : h = l } } while ( l = l . getParent ( ) ) ; h || ( h = g ) ; this . block = e ; this . blockLimit = h; this . root = g ; this . elements = k } } ) ( ) ;
CKEDITOR . dom . elementPath . prototype = { compare : function ( a ) { var d = this . elements ; a = a && a . elements ; if ( ! a || d . length != a . length ) return ! 1 ; for ( var b = 0 ; b < d . length ; b ++ ) if ( ! d [ b ] . equals ( a [ b ] ) ) return ! 1 ; return ! 0 } , contains : function ( a , d , b ) { var c = 0 , g; "string" == typeof a && ( g = function ( b ) { return b . getName ( ) == a } ) ; a instanceof CKEDITOR . dom . element ? g = function ( b ) { return b . equals ( a ) } : CKEDITOR . tools . isArray ( a ) ? g = function ( b ) { return - 1 < CKEDITOR . tools . indexOf ( a , b . getName ( ) ) } : "function" == typeof a ? g = a : "object" == typeof a && ( g = function ( b ) { return b . getName ( ) in
a } ) ; var e = this . elements , h = e . length ; d && ( b ? c += 1 : -- h ) ; b && ( e = Array . prototype . slice . call ( e , 0 ) , e . reverse ( ) ) ; for ( ; c < h; c ++ ) if ( g ( e [ c ] ) ) return e [ c ] ; return null } , isContextFor : function ( a ) { var d ; return a in CKEDITOR . dtd . $block ? ( d = this . contains ( CKEDITOR . dtd . $intermediate ) || this . root . equals ( this . block ) && this . block || this . blockLimit , ! ! d . getDtd ( ) [ a ] ) : ! 0 } , direction : function ( ) { return ( this . block || this . blockLimit || this . root ) . getDirection ( 1 ) } } ;
( function ( ) { var a = { } , d = { } , b ; for ( b in CKEDITOR . dtd . $blockLimit ) b in CKEDITOR . dtd . $list || ( a [ b ] = 1 ) ; for ( b in CKEDITOR . dtd . $block ) b in CKEDITOR . dtd . $blockLimit || b in CKEDITOR . dtd . $empty || ( d [ b ] = 1 ) ; CKEDITOR . dom . elementPath = function ( b , f) { var e = null , k = null , h = [ ] , n = b , l ; f = f || b . getDocument ( ) . getBody ( ) ; n|| ( n = f ) ; do if ( n . type == CKEDITOR . NODE _ELEMENT ) { h. push ( n ) ; if ( ! this . lastElement && ( this . lastElement = n, n . is ( CKEDITOR . dtd . $object ) || "false" == n . getAttribute ( "contenteditable" ) ) ) continue ; if ( n. equals ( f ) ) break ; if ( ! k && ( l = n . getName ( ) ,
"true" == n. getAttribute ( "contenteditable" ) ? k = n : ! e && d [ l ] && ( e = n ) , a [ l ] ) ) { if ( l = ! e && "div" == l ) { a : { l = n . getChildren ( ) ; for ( var g = 0 , x = l . count ( ) ; g < x ; g ++ ) { var y = l . getItem ( g ) ; if ( y . type == CKEDITOR . NODE _ELEMENT && CKEDITOR . dtd . $block [ y. getName ( ) ] ) { l = ! 0 ; break a } } l = ! 1 } l = ! l } l ? e = n : k = n } } while ( n = n . getParent ( ) ) ; k || ( k = f ) ; this . block = e ; this . blockLimit = k; this . root = f ; this . elements = h } } ) ( ) ;
CKEDITOR . dom . elementPath . prototype = { compare : function ( a ) { var d = this . elements ; a = a && a . elements ; if ( ! a || d . length != a . length ) return ! 1 ; for ( var b = 0 ; b < d . length ; b ++ ) if ( ! d [ b ] . equals ( a [ b ] ) ) return ! 1 ; return ! 0 } , contains : function ( a , d , b ) { var c = 0 , f; "string" == typeof a && ( f = function ( b ) { return b . getName ( ) == a } ) ; a instanceof CKEDITOR . dom . element ? f = function ( b ) { return b . equals ( a ) } : CKEDITOR . tools . isArray ( a ) ? f = function ( b ) { return - 1 < CKEDITOR . tools . indexOf ( a , b . getName ( ) ) } : "function" == typeof a ? f = a : "object" == typeof a && ( f = function ( b ) { return b . getName ( ) in
a } ) ; var e = this . elements , k = e . length ; d && ( b ? c += 1 : -- k ) ; b && ( e = Array . prototype . slice . call ( e , 0 ) , e . reverse ( ) ) ; for ( ; c < k; c ++ ) if ( f ( e [ c ] ) ) return e [ c ] ; return null } , isContextFor : function ( a ) { var d ; return a in CKEDITOR . dtd . $block ? ( d = this . contains ( CKEDITOR . dtd . $intermediate ) || this . root . equals ( this . block ) && this . block || this . blockLimit , ! ! d . getDtd ( ) [ a ] ) : ! 0 } , direction : function ( ) { return ( this . block || this . blockLimit || this . root ) . getDirection ( 1 ) } } ;
CKEDITOR . dom . text = function ( a , d ) { "string" == typeof a && ( a = ( d ? d . $ : document ) . createTextNode ( a ) ) ; this . $ = a } ; CKEDITOR . dom . text . prototype = new CKEDITOR . dom . node ;
CKEDITOR . tools . extend ( CKEDITOR . dom . text . prototype , { type : CKEDITOR . NODE _TEXT , getLength : function ( ) { return this . $ . nodeValue . length } , getText : function ( ) { return this . $ . nodeValue } , setText : function ( a ) { this . $ . nodeValue = a } , isEmpty : function ( a ) { var d = this . getText ( ) ; a && ( d = CKEDITOR . tools . trim ( d ) ) ; return ! d || d === CKEDITOR . dom . selection . FILLING _CHAR _SEQUENCE } , split : function ( a ) { var d = this . $ . parentNode , b = d . childNodes . length , c = this . getLength ( ) , g = this . getDocument ( ) , e = new CKEDITOR . dom . text ( this . $ . splitText ( a ) , g ) ; d . childNodes . length ==
b && ( a >= c ? ( e = g . createText ( "" ) , e . insertAfter ( this ) ) : ( a = g . createText ( "" ) , a . insertAfter ( e ) , a . remove ( ) ) ) ; return e } , substring : function ( a , d ) { return "number" != typeof d ? this . $ . nodeValue . substr ( a ) : this . $ . nodeValue . substring ( a , d ) } } ) ;
( function ( ) { function a ( a , c , d ) { var e = a . serializable , h = c [ d ? "endContainer" : "startContainer" ] , k = d ? "endOffset" : "startOffset" , l = e ? c . document . getById ( a . startNode ) : a . startNode ; a = e ? c . document . getById ( a . endNode ) : a . endNode ; h. equals ( l . getPrevious ( ) ) ? ( c . startOffset = c . startOffset - h . getLength ( ) - a . getPrevious ( ) . getLength ( ) , h= a . getNext ( ) ) : h . equals ( a . getPrevious ( ) ) && ( c . startOffset -= h. getLength ( ) , h = a . getNext ( ) ) ; h . equals ( l . getParent ( ) ) && c [ k ] ++ ; h . equals ( a . getParent ( ) ) && c [ k ] ++ ; c [ d ? "endContainer" : "startContainer" ] = h ; return c }
CKEDITOR . dom . rangeList = function ( a ) { if ( a instanceof CKEDITOR . dom . rangeList ) return a ; a ? a instanceof CKEDITOR . dom . range && ( a = [ a ] ) : a = [ ] ; return CKEDITOR . tools . extend ( a , d ) } ; var d = { createIterator : function ( ) { var a = this , c = CKEDITOR . dom . walker . bookmark ( ) , d = [ ] , e ; return { getNextRange : function ( h ) { e = void 0 === e ? 0 : e + 1 ; var k= a [ e ] ; if ( k && 1 < a . length ) { if ( ! e ) for ( var l= a . length - 1 ; 0 <= l ; l -- ) d . unshift ( a [ l ] . createBookmark ( ! 0 ) ) ; if ( h) for ( var q = 0 ; a [ e + q + 1 ] ; ) { var f = k . document ; h = 0 ; l = f . getById ( d [ q ] . endNode ) ; for ( f = f . getById ( d [ q + 1 ] . startNode ) ; ; ) { l =
l . getNextSourceNode ( ! 1 ) ; if ( f. equals ( l ) ) h = 1 ; else if ( c ( l ) || l . type == CKEDITOR . NODE _ELEMENT && l . isBlockBoundary ( ) ) continue ; break } if ( ! h) break ; q ++ } for ( k . moveToBookmark ( d . shift ( ) ) ; q-- ; ) l = a [ ++ e ] , l . moveToBookmark ( d . shift ( ) ) , k. setEnd ( l . endContainer , l . endOffset ) } return k } } } , createBookmarks : function ( b ) { for ( var c = [ ] , d , e = 0 ; e < this . length ; e ++ ) { c . push ( d = this [ e ] . createBookmark ( b , ! 0 ) ) ; for ( var h= e + 1 ; h < this . length ; h ++ ) this [ h ] = a ( d , this [ h ] ) , this [ h ] = a ( d , this [ h ] , ! 0 ) } return c } , createBookmarks2 : function ( a ) { for ( var c = [ ] , d = 0 ; d <
CKEDITOR . tools . extend ( CKEDITOR . dom . text . prototype , { type : CKEDITOR . NODE _TEXT , getLength : function ( ) { return this . $ . nodeValue . length } , getText : function ( ) { return this . $ . nodeValue } , setText : function ( a ) { this . $ . nodeValue = a } , isEmpty : function ( a ) { var d = this . getText ( ) ; a && ( d = CKEDITOR . tools . trim ( d ) ) ; return ! d || d === CKEDITOR . dom . selection . FILLING _CHAR _SEQUENCE } , split : function ( a ) { var d = this . $ . parentNode , b = d . childNodes . length , c = this . getLength ( ) , f = this . getDocument ( ) , e = new CKEDITOR . dom . text ( this . $ . splitText ( a ) , f ) ; d . childNodes . length ==
b && ( a >= c ? ( e = f . createText ( "" ) , e . insertAfter ( this ) ) : ( a = f . createText ( "" ) , a . insertAfter ( e ) , a . remove ( ) ) ) ; return e } , substring : function ( a , d ) { return "number" != typeof d ? this . $ . nodeValue . substr ( a ) : this . $ . nodeValue . substring ( a , d ) } } ) ;
( function ( ) { function a ( a , c , d ) { var e = a . serializable , k = c [ d ? "endContainer" : "startContainer" ] , h = d ? "endOffset" : "startOffset" , n = e ? c . document . getById ( a . startNode ) : a . startNode ; a = e ? c . document . getById ( a . endNode ) : a . endNode ; k. equals ( n . getPrevious ( ) ) ? ( c . startOffset = c . startOffset - k . getLength ( ) - a . getPrevious ( ) . getLength ( ) , k= a . getNext ( ) ) : k . equals ( a . getPrevious ( ) ) && ( c . startOffset -= k. getLength ( ) , k = a . getNext ( ) ) ; k . equals ( n . getParent ( ) ) && c [ h ] ++ ; k . equals ( a . getParent ( ) ) && c [ h ] ++ ; c [ d ? "endContainer" : "startContainer" ] = k ; return c }
CKEDITOR . dom . rangeList = function ( a ) { if ( a instanceof CKEDITOR . dom . rangeList ) return a ; a ? a instanceof CKEDITOR . dom . range && ( a = [ a ] ) : a = [ ] ; return CKEDITOR . tools . extend ( a , d ) } ; var d = { createIterator : function ( ) { var a = this , c = CKEDITOR . dom . walker . bookmark ( ) , d = [ ] , e ; return { getNextRange : function ( k ) { e = void 0 === e ? 0 : e + 1 ; var h= a [ e ] ; if ( h && 1 < a . length ) { if ( ! e ) for ( var n= a . length - 1 ; 0 <= n ; n -- ) d . unshift ( a [ n ] . createBookmark ( ! 0 ) ) ; if ( k) for ( var l = 0 ; a [ e + l + 1 ] ; ) { var g = h . document ; k = 0 ; n = g . getById ( d [ l ] . endNode ) ; for ( g = g . getById ( d [ l + 1 ] . startNode ) ; ; ) { n =
n . getNextSourceNode ( ! 1 ) ; if ( g. equals ( n ) ) k = 1 ; else if ( c ( n ) || n . type == CKEDITOR . NODE _ELEMENT && n . isBlockBoundary ( ) ) continue ; break } if ( ! k) break ; l ++ } for ( h . moveToBookmark ( d . shift ( ) ) ; l-- ; ) n = a [ ++ e ] , n . moveToBookmark ( d . shift ( ) ) , h. setEnd ( n . endContainer , n . endOffset ) } return h } } } , createBookmarks : function ( b ) { for ( var c = [ ] , d , e = 0 ; e < this . length ; e ++ ) { c . push ( d = this [ e ] . createBookmark ( b , ! 0 ) ) ; for ( var k= e + 1 ; k < this . length ; k ++ ) this [ k ] = a ( d , this [ k ] ) , this [ k ] = a ( d , this [ k ] , ! 0 ) } return c } , createBookmarks2 : function ( a ) { for ( var c = [ ] , d = 0 ; d <
this . length ; d ++ ) c . push ( this [ d ] . createBookmark2 ( a ) ) ; return c } , moveToBookmarks : function ( a ) { for ( var c = 0 ; c < this . length ; c ++ ) this [ c ] . moveToBookmark ( a [ c ] ) } } } ) ( ) ;
( function ( ) { function a ( ) { return CKEDITOR . getUrl ( CKEDITOR . skinName . split ( "," ) [ 1 ] || "skins/" + CKEDITOR . skinName . split ( "," ) [ 0 ] + "/" ) } function d ( b ) { var c = CKEDITOR . skin [ "ua_" + b ] , d = CKEDITOR . env ; if ( c ) for ( var c = c . split ( "," ) . sort ( function ( a , b ) { return a > b ? - 1 : 1 } ) , e = 0 , g ; e < c . length ; e ++ ) if ( g = c [ e ] , d . ie && ( g . replace ( /^ie/ , "" ) == d . version || d . quirks && "iequirks" == g) && ( g = "ie" ) , d [ g ] ) { b += "_" + c [ e ] ; break } return CKEDITOR . getUrl ( a ( ) + b + ".css" ) } function b ( a , b ) { e [ a ] || ( CKEDITOR . document . appendStyleSheet ( d ( a ) ) , e [ a ] = 1 ) ; b && b ( ) } function c ( a ) { var b =
a . getById ( h ) ; b || ( b = a . getHead ( ) . append ( "style" ) , b . setAttribute ( "id" , h ) , b . setAttribute ( "type" , "text/css" ) ) ; return b } function g ( a , b , c ) { var d , e , g ; if ( CKEDITOR . env . webkit ) for ( b = b . split ( "}" ) . slice ( 0 , - 1 ) , e = 0 ; e < b . length ; e ++ ) b [ e ] = b [ e ] . split ( "{" ) ; for ( var h = 0 ; h < a . length ; h ++ ) if ( CKEDITOR . env . webkit ) for ( e = 0 ; e < b . length ; e ++ ) { g = b [ e ] [ 1 ] ; for ( d = 0 ; d < c . length ; d ++ ) g= g . replace ( c [ d ] [ 0 ] , c [ d ] [ 1 ] ) ; a [ h ] . $ . sheet . addRule ( b [ e ] [ 0 ] , g) } else { g = b ; for ( d = 0 ; d < c . length ; d ++ ) g= g . replace ( c [ d ] [ 0 ] , c [ d ] [ 1 ] ) ; CKEDITOR . env . ie && 11 > CKEDITOR . env . version ?
a [ h ] . $ . styleSheet . cssText += g : a [ h ] . $ . innerHTML += g } } var e = { } ; CKEDITOR . skin = { path : a , loadPart : function ( c , d ) { CKEDITOR . skin . name != CKEDITOR . skinName . split ( "," ) [ 0 ] ? CKEDITOR . scriptLoader . load ( CKEDITOR . getUrl ( a ( ) + "skin.js" ) , function ( ) { b ( c , d ) } ) : b ( c , d ) } , getPath : function ( a ) { return CKEDITOR . getUrl ( d ( a ) ) } , icons : { } , addIcon : function ( a , b , c , d ) { a = a . toLowerCase ( ) ; this . icons [ a ] || ( this . icons [ a ] = { path : b , offset : c || 0 , bgsize : d || "16px" } ) } , getIconStyle : function ( a , b , c , d , e ) { var g ; a && ( a = a . toLowerCase ( ) , b && ( g = this . icons [ a + "-rtl" ] ) ,
g|| ( g = this . icons [ a ] ) ) ; a = c || g&& g . path || "" ; d = d || g&& g . offset ; e = e || g && g . bgsize || "16px" ; a && ( a = a . replace ( /'/g , "\\'" ) ) ; return a && "background-image:url('" + CKEDITOR . getUrl ( a ) + "');background-position:0 " + d + "px;background-size:" + e + ";" } } ; CKEDITOR . tools . extend ( CKEDITOR . editor . prototype , { getUiColor : function ( ) { return this . uiColor } , setUiColor : function ( a ) { var b = c ( CKEDITOR . document ) ; return ( this . setUiColor = function ( a ) { this . uiColor = a ; var c = CKEDITOR . skin . chameleon , d = "" , e = "" ; "function" == typeof c && ( d = c ( this , "editor" ) , e =
c ( this , "panel" ) ) ; a = [ [ l, a ] ] ; g ( [ b ] , d , a ) ; g ( k , e , a ) } ) . call ( this , a ) } } ) ; var h= "cke_ui_color" , k = [ ] , l = /\$color/g ; CKEDITOR . on ( "instanceLoaded" , function ( a ) { if ( ! CKEDITOR . env . ie || ! CKEDITOR . env . quirks ) { var b = a . editor ; a = function ( a ) { a = ( a . data [ 0 ] || a . data ) . element . getElementsByTag ( "iframe" ) . getItem ( 0 ) . getFrameDocument ( ) ; if ( ! a . getById ( "cke_ui_color" ) ) { var d = c ( a ) ; k . push ( d ) ; b . on ( "destroy" , function ( ) { k = CKEDITOR . tools . array . filter ( k , function ( a ) { return d !== a } ) } ) ; ( a = b . getUiColor ( ) ) && g ( [ d ] , CKEDITOR . skin . chameleon ( b , "panel" ) ,
[ [ l , a ] ] ) } } ; b . on ( "panelShow" , a ) ; b . on ( "menuShow" , a ) ; b . config . uiColor && b . setUiColor ( b . config . uiColor ) } } ) } ) ( ) ;
( function ( ) { function a ( ) { return CKEDITOR . getUrl ( CKEDITOR . skinName . split ( "," ) [ 1 ] || "skins/" + CKEDITOR . skinName . split ( "," ) [ 0 ] + "/" ) } function d ( b ) { var c = CKEDITOR . skin [ "ua_" + b ] , d = CKEDITOR . env ; if ( c ) for ( var c = c . split ( "," ) . sort ( function ( a , b ) { return a > b ? - 1 : 1 } ) , e = 0 , f ; e < c . length ; e ++ ) if ( f = c [ e ] , d . ie && ( f . replace ( /^ie/ , "" ) == d . version || d . quirks && "iequirks" == f) && ( f = "ie" ) , d [ f ] ) { b += "_" + c [ e ] ; break } return CKEDITOR . getUrl ( a ( ) + b + ".css" ) } function b ( a , b ) { e [ a ] || ( CKEDITOR . document . appendStyleSheet ( d ( a ) ) , e [ a ] = 1 ) ; b && b ( ) } function c ( a ) { var b =
a . getById ( k ) ; b || ( b = a . getHead ( ) . append ( "style" ) , b . setAttribute ( "id" , k ) , b . setAttribute ( "type" , "text/css" ) ) ; return b } function f ( a , b , c ) { var d , e , f ; if ( CKEDITOR . env . webkit ) for ( b = b . split ( "}" ) . slice ( 0 , - 1 ) , e = 0 ; e < b . length ; e ++ ) b [ e ] = b [ e ] . split ( "{" ) ; for ( var h = 0 ; h < a . length ; h ++ ) if ( CKEDITOR . env . webkit ) for ( e = 0 ; e < b . length ; e ++ ) { f = b [ e ] [ 1 ] ; for ( d = 0 ; d < c . length ; d ++ ) f= f . replace ( c [ d ] [ 0 ] , c [ d ] [ 1 ] ) ; a [ h ] . $ . sheet . addRule ( b [ e ] [ 0 ] , f) } else { f = b ; for ( d = 0 ; d < c . length ; d ++ ) f= f . replace ( c [ d ] [ 0 ] , c [ d ] [ 1 ] ) ; CKEDITOR . env . ie && 11 > CKEDITOR . env . version ?
a [ h ] . $ . styleSheet . cssText += f : a [ h ] . $ . innerHTML += f } } var e = { } ; CKEDITOR . skin = { path : a , loadPart : function ( c , d ) { CKEDITOR . skin . name != CKEDITOR . skinName . split ( "," ) [ 0 ] ? CKEDITOR . scriptLoader . load ( CKEDITOR . getUrl ( a ( ) + "skin.js" ) , function ( ) { b ( c , d ) } ) : b ( c , d ) } , getPath : function ( a ) { return CKEDITOR . getUrl ( d ( a ) ) } , icons : { } , addIcon : function ( a , b , c , d ) { a = a . toLowerCase ( ) ; this . icons [ a ] || ( this . icons [ a ] = { path : b , offset : c || 0 , bgsize : d || "16px" } ) } , getIconStyle : function ( a , b , c , d , e ) { var f ; a && ( a = a . toLowerCase ( ) , b && ( f = this . icons [ a + "-rtl" ] ) ,
f|| ( f = this . icons [ a ] ) ) ; a = c || f&& f . path || "" ; d = d || f&& f . offset ; e = e || f && f . bgsize || "16px" ; a && ( a = a . replace ( /'/g , "\\'" ) ) ; return a && "background-image:url('" + CKEDITOR . getUrl ( a ) + "');background-position:0 " + d + "px;background-size:" + e + ";" } } ; CKEDITOR . tools . extend ( CKEDITOR . editor . prototype , { getUiColor : function ( ) { return this . uiColor } , setUiColor : function ( a ) { var b = c ( CKEDITOR . document ) ; return ( this . setUiColor = function ( a ) { this . uiColor = a ; var c = CKEDITOR . skin . chameleon , d = "" , e = "" ; "function" == typeof c && ( d = c ( this , "editor" ) , e =
c ( this , "panel" ) ) ; a = [ [ n, a ] ] ; f ( [ b ] , d , a ) ; f ( h , e , a ) } ) . call ( this , a ) } } ) ; var k= "cke_ui_color" , h = [ ] , n = /\$color/g ; CKEDITOR . on ( "instanceLoaded" , function ( a ) { if ( ! CKEDITOR . env . ie || ! CKEDITOR . env . quirks ) { var b = a . editor ; a = function ( a ) { a = ( a . data [ 0 ] || a . data ) . element . getElementsByTag ( "iframe" ) . getItem ( 0 ) . getFrameDocument ( ) ; if ( ! a . getById ( "cke_ui_color" ) ) { var d = c ( a ) ; h . push ( d ) ; b . on ( "destroy" , function ( ) { h = CKEDITOR . tools . array . filter ( h , function ( a ) { return d !== a } ) } ) ; ( a = b . getUiColor ( ) ) && f ( [ d ] , CKEDITOR . skin . chameleon ( b , "panel" ) ,
[ [ n , a ] ] ) } } ; b . on ( "panelShow" , a ) ; b . on ( "menuShow" , a ) ; b . config . uiColor && b . setUiColor ( b . config . uiColor ) } } ) } ) ( ) ;
( function ( ) { var a = CKEDITOR . dom . element . createFromHtml ( '\x3cdiv style\x3d"width:0;height:0;position:absolute;left:-10000px;border:1px solid;border-color:red blue"\x3e\x3c/div\x3e' , CKEDITOR . document ) ; a . appendTo ( CKEDITOR . document . getHead ( ) ) ; try { var d = a . getComputedStyle ( "border-top-color" ) , b = a . getComputedStyle ( "border-right-color" ) ; CKEDITOR . env . hc = ! ( ! d || d != b ) } catch ( c ) { CKEDITOR . env . hc = ! 1 } a . remove ( ) ; CKEDITOR . env . hc && ( CKEDITOR . env . cssClass += " cke_hc" ) ; CKEDITOR . document . appendStyleText ( ".cke{visibility:hidden;}" ) ;
CKEDITOR . status = "loaded" ; CKEDITOR . fireOnce ( "loaded" ) ; if ( a = CKEDITOR . _ . pending ) for ( delete CKEDITOR . _ . pending , d = 0 ; d < a . length ; d ++ ) CKEDITOR . editor . prototype . constructor . apply ( a [ d ] [ 0 ] , a [ d ] [ 1 ] ) , CKEDITOR . add ( a [ d ] [ 0 ] ) } ) ( ) ; / *
Copyright ( c ) 2003 - 2023 , CKSource Holding sp . z o . o . All rights reserved .
CKEditor 4 LTS ( "Long Term Support" ) is available under the terms of the Extended Support Model .
For licensing , see LICENSE . md or https : //ckeditor.com/legal/ckeditor-oss-license
* /
CKEDITOR . skin . name = "moono-lisa" ; CKEDITOR . skin . ua _editor = "ie,iequirks,ie8,gecko" ; CKEDITOR . skin . ua _dialog = "ie,iequirks,ie8" ;
CKEDITOR . skin . chameleon = function ( ) { var b = function ( ) { return function ( b , d ) { for ( var a = b . match ( /[^#]./g ) , e = 0 ; 3 > e ; e ++ ) { var f = e , c ; c = parseInt ( a [ e ] , 16 ) ; c = ( "0" + ( 0 > d ? 0 | c * ( 1 + d ) : 0 | c + ( 255 - c ) * d ) . toString ( 16 ) ) . slice ( - 2 ) ; a [ f ] = c } return "#" + a . join ( "" ) } } ( ) , f = { editor : new CKEDITOR . template ( "{id}.cke_chrome [border-color:{defaultBorder};] {id} .cke_top [ background-color:{defaultBackground};border-bottom-color:{defaultBorder};] {id} .cke_bottom [background-color:{defaultBackground};border-top-color:{defaultBorder};] {id} .cke_resizer [border-right-color:{ckeResizer}] {id} .cke_dialog_title [background-color:{defaultBackground};border-bottom-color:{defaultBorder};] {id} .cke_dialog_footer [background-color:{defaultBackground};outline-color:{defaultBorder};] {id} .cke_dialog_tab [background-color:{dialogTab};border-color:{defaultBorder};] {id} .cke_dialog_tab:hover [background-color:{lightBackground};] {id} .cke_dialog_contents [border-top-color:{defaultBorder};] {id} .cke_dialog_tab_selected, {id} .cke_dialog_tab_selected:hover [background:{dialogTabSelected};border-bottom-color:{dialogTabSelectedBorder};] {id} .cke_dialog_body [background:{dialogBody};border-color:{defaultBorder};] {id} a.cke_button_off:hover,{id} a.cke_button_off:focus,{id} a.cke_button_off:active [background-color:{darkBackground};border-color:{toolbarElementsBorder};] {id} .cke_button_on [background-color:{ckeButtonOn};border-color:{toolbarElementsBorder};] {id} .cke_toolbar_separator,{id} .cke_toolgroup a.cke_button:last-child:after,{id} .cke_toolgroup a.cke_button.cke_button_disabled:hover:last-child:after [background-color: {toolbarElementsBorder};border-color: {toolbarElementsBorder};] {id} a.cke_combo_button:hover,{id} a.cke_combo_button:focus,{id} .cke_combo_on a.cke_combo_button [border-color:{toolbarElementsBorder};background-color:{darkBackground};] {id} .cke_combo:after [border-color:{toolbarElementsBorder};] {id} .cke_path_item [color:{elementsPathColor};] {id} a.cke_path_item:hover,{id} a.cke_path_item:focus,{id} a.cke_path_item:active [background-color:{darkBackground};] {id}.cke_panel [border-color:{defaultBorder};] " ) , panel : new CKEDITOR . template ( ".cke_panel_grouptitle [background-color:{lightBackground};border-color:{defaultBorder};] .cke_menubutton_icon [background-color:{menubuttonIcon};] .cke_menubutton:hover,.cke_menubutton:focus,.cke_menubutton:active [background-color:{menubuttonHover};] .cke_menubutton:hover .cke_menubutton_icon, .cke_menubutton:focus .cke_menubutton_icon, .cke_menubutton:active .cke_menubutton_icon [background-color:{menubuttonIconHover};] .cke_menubutton_disabled:hover .cke_menubutton_icon,.cke_menubutton_disabled:focus .cke_menubutton_icon,.cke_menubutton_disabled:active .cke_menubutton_icon [background-color:{menubuttonIcon};] .cke_menuseparator [background-color:{menubuttonIcon};] a:hover.cke_colorbox, a:active.cke_colorbox [border-color:{defaultBorder};] a:hover.cke_colorauto, a:hover.cke_colormore, a:active.cke_colorauto, a:active.cke_colormore [background-color:{ckeColorauto};border-color:{defaultBorder};] " ) } ;