| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787278827892790279127922793279427952796279727982799280028012802280328042805280628072808280928102811281228132814281528162817281828192820282128222823282428252826282728282829283028312832283328342835283628372838283928402841284228432844284528462847284828492850285128522853285428552856285728582859286028612862286328642865286628672868286928702871287228732874287528762877287828792880288128822883288428852886288728882889289028912892289328942895289628972898289929002901290229032904290529062907290829092910291129122913291429152916291729182919292029212922292329242925292629272928292929302931293229332934293529362937293829392940294129422943294429452946294729482949295029512952295329542955295629572958295929602961296229632964296529662967296829692970297129722973297429752976297729782979298029812982298329842985298629872988298929902991299229932994299529962997299829993000300130023003300430053006300730083009301030113012301330143015301630173018301930203021302230233024302530263027302830293030303130323033303430353036303730383039304030413042304330443045304630473048304930503051305230533054305530563057305830593060306130623063306430653066306730683069307030713072307330743075307630773078307930803081308230833084308530863087308830893090309130923093309430953096309730983099310031013102310331043105310631073108310931103111311231133114311531163117311831193120312131223123312431253126312731283129313031313132313331343135313631373138313931403141314231433144314531463147314831493150315131523153315431553156315731583159316031613162316331643165316631673168316931703171317231733174317531763177317831793180318131823183318431853186318731883189319031913192319331943195319631973198319932003201320232033204320532063207320832093210321132123213321432153216321732183219322032213222322332243225322632273228322932303231323232333234323532363237323832393240324132423243324432453246324732483249325032513252325332543255325632573258325932603261326232633264326532663267326832693270327132723273327432753276327732783279328032813282328332843285328632873288328932903291329232933294329532963297329832993300330133023303330433053306330733083309331033113312331333143315331633173318331933203321332233233324332533263327332833293330333133323333333433353336333733383339334033413342334333443345334633473348334933503351335233533354335533563357335833593360336133623363336433653366336733683369337033713372337333743375337633773378337933803381338233833384338533863387338833893390339133923393339433953396339733983399340034013402340334043405340634073408340934103411341234133414341534163417341834193420342134223423342434253426342734283429343034313432343334343435343634373438343934403441344234433444344534463447344834493450345134523453345434553456345734583459346034613462346334643465346634673468346934703471347234733474347534763477347834793480348134823483348434853486348734883489349034913492349334943495349634973498349935003501350235033504350535063507350835093510351135123513351435153516351735183519352035213522352335243525352635273528352935303531353235333534353535363537353835393540354135423543354435453546354735483549355035513552355335543555355635573558355935603561356235633564356535663567356835693570357135723573357435753576357735783579358035813582358335843585358635873588358935903591359235933594359535963597359835993600360136023603360436053606360736083609361036113612361336143615361636173618361936203621362236233624362536263627362836293630363136323633363436353636363736383639364036413642364336443645364636473648364936503651365236533654365536563657365836593660366136623663366436653666366736683669367036713672367336743675367636773678367936803681368236833684368536863687368836893690369136923693369436953696369736983699370037013702370337043705370637073708370937103711371237133714371537163717371837193720372137223723372437253726372737283729373037313732373337343735373637373738373937403741374237433744374537463747374837493750375137523753375437553756375737583759376037613762376337643765376637673768376937703771377237733774377537763777377837793780378137823783378437853786378737883789379037913792379337943795379637973798379938003801380238033804380538063807380838093810381138123813381438153816381738183819382038213822382338243825382638273828382938303831383238333834383538363837383838393840384138423843384438453846384738483849385038513852385338543855385638573858385938603861386238633864386538663867386838693870387138723873387438753876387738783879388038813882388338843885388638873888388938903891389238933894389538963897389838993900390139023903390439053906390739083909391039113912391339143915391639173918391939203921392239233924392539263927392839293930393139323933393439353936393739383939394039413942394339443945394639473948394939503951395239533954395539563957395839593960396139623963396439653966396739683969397039713972397339743975397639773978397939803981398239833984398539863987398839893990399139923993399439953996399739983999400040014002400340044005400640074008400940104011401240134014401540164017401840194020402140224023402440254026402740284029403040314032403340344035403640374038403940404041404240434044404540464047404840494050405140524053405440554056405740584059406040614062406340644065406640674068406940704071407240734074407540764077407840794080408140824083408440854086408740884089409040914092409340944095409640974098409941004101410241034104410541064107410841094110411141124113411441154116411741184119412041214122412341244125412641274128412941304131413241334134413541364137413841394140414141424143414441454146414741484149415041514152415341544155415641574158415941604161416241634164416541664167416841694170417141724173417441754176417741784179418041814182418341844185418641874188418941904191419241934194419541964197419841994200420142024203420442054206420742084209421042114212421342144215421642174218421942204221422242234224422542264227422842294230423142324233423442354236423742384239424042414242424342444245424642474248424942504251425242534254425542564257425842594260426142624263426442654266426742684269427042714272427342744275427642774278427942804281428242834284428542864287428842894290429142924293429442954296429742984299430043014302430343044305430643074308430943104311431243134314431543164317431843194320432143224323432443254326432743284329433043314332433343344335433643374338433943404341434243434344434543464347434843494350435143524353435443554356435743584359436043614362436343644365436643674368436943704371437243734374437543764377437843794380438143824383438443854386438743884389439043914392439343944395439643974398439944004401440244034404440544064407440844094410441144124413441444154416441744184419442044214422442344244425442644274428442944304431443244334434443544364437443844394440444144424443444444454446444744484449445044514452445344544455445644574458445944604461446244634464446544664467446844694470447144724473447444754476447744784479448044814482448344844485448644874488448944904491449244934494449544964497449844994500450145024503450445054506450745084509451045114512451345144515451645174518451945204521452245234524452545264527452845294530453145324533453445354536453745384539454045414542454345444545454645474548454945504551455245534554455545564557455845594560456145624563456445654566456745684569457045714572457345744575457645774578457945804581458245834584458545864587458845894590459145924593459445954596459745984599460046014602460346044605460646074608460946104611461246134614461546164617461846194620462146224623462446254626462746284629463046314632463346344635463646374638463946404641464246434644464546464647464846494650465146524653465446554656465746584659466046614662466346644665466646674668466946704671467246734674467546764677467846794680468146824683468446854686468746884689469046914692469346944695469646974698469947004701470247034704470547064707470847094710471147124713471447154716471747184719472047214722472347244725472647274728472947304731473247334734473547364737473847394740474147424743474447454746474747484749475047514752475347544755475647574758475947604761476247634764476547664767476847694770477147724773477447754776477747784779478047814782478347844785478647874788478947904791479247934794479547964797479847994800480148024803480448054806480748084809481048114812481348144815481648174818481948204821482248234824482548264827482848294830483148324833483448354836483748384839484048414842484348444845484648474848484948504851485248534854485548564857485848594860486148624863486448654866486748684869487048714872487348744875487648774878487948804881488248834884488548864887488848894890489148924893489448954896489748984899490049014902490349044905490649074908490949104911491249134914491549164917491849194920492149224923492449254926492749284929493049314932493349344935493649374938493949404941494249434944494549464947494849494950495149524953495449554956495749584959496049614962496349644965496649674968496949704971497249734974497549764977497849794980498149824983498449854986498749884989499049914992499349944995499649974998499950005001500250035004500550065007500850095010501150125013501450155016501750185019502050215022502350245025502650275028502950305031503250335034503550365037503850395040504150425043504450455046504750485049505050515052505350545055505650575058505950605061506250635064506550665067506850695070507150725073507450755076507750785079508050815082508350845085508650875088508950905091509250935094509550965097509850995100510151025103510451055106510751085109511051115112511351145115511651175118511951205121512251235124512551265127512851295130513151325133513451355136513751385139514051415142514351445145514651475148514951505151515251535154515551565157515851595160516151625163516451655166516751685169517051715172517351745175517651775178517951805181518251835184518551865187518851895190519151925193519451955196519751985199520052015202520352045205520652075208520952105211521252135214521552165217521852195220522152225223522452255226522752285229523052315232523352345235523652375238523952405241524252435244524552465247524852495250525152525253525452555256525752585259526052615262526352645265526652675268526952705271527252735274527552765277527852795280528152825283528452855286528752885289529052915292529352945295529652975298529953005301530253035304530553065307530853095310531153125313531453155316531753185319532053215322532353245325532653275328532953305331533253335334533553365337533853395340534153425343534453455346534753485349535053515352535353545355535653575358535953605361536253635364536553665367536853695370537153725373537453755376537753785379538053815382538353845385538653875388538953905391539253935394539553965397539853995400540154025403540454055406540754085409541054115412541354145415541654175418541954205421542254235424542554265427542854295430543154325433543454355436543754385439544054415442544354445445544654475448544954505451545254535454545554565457545854595460546154625463546454655466546754685469547054715472547354745475547654775478547954805481548254835484548554865487548854895490549154925493549454955496549754985499550055015502550355045505550655075508550955105511551255135514551555165517551855195520552155225523552455255526552755285529553055315532553355345535553655375538553955405541554255435544554555465547554855495550555155525553555455555556555755585559556055615562556355645565556655675568556955705571557255735574557555765577557855795580558155825583558455855586558755885589559055915592559355945595559655975598559956005601560256035604560556065607560856095610561156125613561456155616561756185619562056215622562356245625562656275628562956305631563256335634563556365637563856395640564156425643564456455646564756485649565056515652565356545655565656575658565956605661566256635664566556665667566856695670567156725673567456755676567756785679568056815682568356845685568656875688568956905691569256935694569556965697569856995700570157025703570457055706570757085709571057115712571357145715571657175718571957205721572257235724572557265727572857295730573157325733573457355736573757385739574057415742574357445745574657475748574957505751575257535754575557565757575857595760576157625763576457655766576757685769577057715772577357745775577657775778577957805781578257835784578557865787578857895790579157925793579457955796579757985799580058015802580358045805580658075808580958105811581258135814581558165817581858195820582158225823582458255826582758285829583058315832583358345835583658375838583958405841584258435844584558465847584858495850585158525853585458555856585758585859586058615862586358645865586658675868586958705871587258735874587558765877587858795880588158825883588458855886588758885889589058915892589358945895589658975898589959005901590259035904590559065907590859095910591159125913591459155916591759185919592059215922592359245925592659275928592959305931593259335934593559365937593859395940594159425943594459455946594759485949595059515952595359545955595659575958595959605961596259635964596559665967596859695970597159725973597459755976597759785979598059815982598359845985598659875988598959905991599259935994599559965997599859996000600160026003600460056006600760086009601060116012601360146015601660176018601960206021602260236024602560266027602860296030603160326033603460356036603760386039604060416042604360446045604660476048604960506051605260536054605560566057605860596060606160626063606460656066606760686069607060716072607360746075607660776078607960806081608260836084608560866087608860896090609160926093609460956096609760986099610061016102610361046105610661076108610961106111611261136114611561166117611861196120612161226123612461256126612761286129613061316132613361346135613661376138613961406141614261436144614561466147614861496150615161526153615461556156615761586159616061616162616361646165616661676168616961706171617261736174617561766177617861796180618161826183618461856186618761886189619061916192619361946195619661976198619962006201620262036204620562066207620862096210621162126213621462156216621762186219622062216222622362246225622662276228622962306231623262336234623562366237623862396240624162426243624462456246624762486249625062516252625362546255625662576258625962606261626262636264626562666267626862696270627162726273627462756276627762786279628062816282628362846285628662876288628962906291629262936294629562966297629862996300630163026303630463056306630763086309631063116312631363146315631663176318631963206321632263236324632563266327632863296330633163326333633463356336633763386339634063416342634363446345634663476348634963506351635263536354635563566357635863596360636163626363636463656366636763686369637063716372637363746375637663776378637963806381638263836384638563866387638863896390639163926393639463956396639763986399640064016402640364046405640664076408640964106411641264136414641564166417641864196420642164226423642464256426642764286429643064316432643364346435643664376438643964406441644264436444644564466447644864496450645164526453645464556456645764586459646064616462646364646465646664676468646964706471647264736474647564766477647864796480648164826483648464856486648764886489649064916492649364946495649664976498649965006501650265036504650565066507650865096510651165126513651465156516651765186519652065216522652365246525652665276528652965306531653265336534653565366537653865396540654165426543654465456546654765486549655065516552655365546555655665576558655965606561656265636564656565666567656865696570657165726573657465756576657765786579658065816582658365846585658665876588658965906591659265936594659565966597659865996600660166026603660466056606660766086609661066116612661366146615661666176618661966206621662266236624662566266627662866296630663166326633663466356636663766386639664066416642664366446645664666476648664966506651665266536654665566566657665866596660666166626663666466656666666766686669667066716672667366746675667666776678667966806681668266836684668566866687668866896690669166926693669466956696669766986699670067016702670367046705670667076708670967106711671267136714671567166717671867196720672167226723672467256726672767286729673067316732673367346735673667376738673967406741674267436744674567466747674867496750675167526753675467556756675767586759676067616762676367646765676667676768676967706771677267736774677567766777677867796780678167826783678467856786678767886789679067916792679367946795679667976798679968006801680268036804680568066807680868096810681168126813681468156816681768186819682068216822682368246825682668276828682968306831683268336834683568366837683868396840684168426843684468456846684768486849685068516852685368546855685668576858685968606861686268636864686568666867686868696870687168726873687468756876687768786879688068816882688368846885688668876888688968906891689268936894689568966897689868996900690169026903690469056906690769086909691069116912691369146915691669176918691969206921692269236924692569266927692869296930693169326933693469356936693769386939694069416942694369446945694669476948694969506951695269536954695569566957695869596960696169626963696469656966696769686969697069716972697369746975697669776978697969806981698269836984698569866987698869896990699169926993699469956996699769986999700070017002700370047005700670077008700970107011701270137014701570167017701870197020702170227023702470257026702770287029703070317032703370347035703670377038703970407041704270437044704570467047704870497050705170527053705470557056705770587059706070617062706370647065706670677068706970707071707270737074707570767077707870797080708170827083708470857086708770887089709070917092709370947095709670977098709971007101710271037104710571067107710871097110711171127113711471157116711771187119712071217122712371247125712671277128712971307131713271337134713571367137713871397140714171427143714471457146714771487149715071517152715371547155715671577158715971607161716271637164716571667167716871697170717171727173717471757176717771787179718071817182718371847185718671877188718971907191719271937194719571967197719871997200720172027203720472057206720772087209721072117212721372147215721672177218721972207221722272237224722572267227722872297230723172327233723472357236723772387239724072417242724372447245724672477248724972507251725272537254725572567257725872597260726172627263726472657266726772687269727072717272727372747275727672777278727972807281728272837284728572867287728872897290729172927293729472957296729772987299730073017302730373047305730673077308730973107311731273137314731573167317731873197320732173227323732473257326732773287329733073317332733373347335733673377338733973407341734273437344734573467347734873497350735173527353735473557356735773587359736073617362736373647365736673677368736973707371737273737374737573767377737873797380738173827383738473857386738773887389739073917392739373947395739673977398739974007401740274037404740574067407740874097410741174127413741474157416741774187419742074217422742374247425742674277428742974307431743274337434743574367437743874397440744174427443744474457446744774487449745074517452745374547455745674577458745974607461746274637464746574667467746874697470747174727473747474757476747774787479748074817482748374847485748674877488748974907491749274937494749574967497749874997500750175027503750475057506750775087509751075117512751375147515751675177518751975207521752275237524752575267527752875297530753175327533753475357536753775387539754075417542754375447545754675477548754975507551755275537554755575567557755875597560756175627563756475657566756775687569757075717572757375747575757675777578757975807581758275837584758575867587758875897590759175927593759475957596759775987599760076017602760376047605760676077608760976107611761276137614761576167617761876197620762176227623762476257626762776287629763076317632763376347635763676377638763976407641764276437644764576467647764876497650765176527653765476557656765776587659766076617662766376647665766676677668766976707671767276737674767576767677767876797680768176827683768476857686768776887689769076917692769376947695769676977698769977007701770277037704770577067707770877097710771177127713771477157716771777187719772077217722772377247725772677277728772977307731773277337734773577367737773877397740774177427743774477457746774777487749775077517752775377547755775677577758775977607761776277637764776577667767776877697770777177727773777477757776777777787779778077817782778377847785778677877788778977907791779277937794779577967797779877997800780178027803780478057806780778087809781078117812781378147815781678177818781978207821782278237824782578267827782878297830783178327833783478357836783778387839784078417842784378447845784678477848784978507851785278537854785578567857785878597860786178627863786478657866786778687869787078717872787378747875787678777878787978807881788278837884788578867887788878897890789178927893789478957896789778987899790079017902790379047905790679077908790979107911791279137914791579167917791879197920792179227923792479257926792779287929793079317932793379347935793679377938793979407941794279437944794579467947794879497950795179527953795479557956795779587959796079617962796379647965796679677968796979707971797279737974797579767977797879797980798179827983798479857986798779887989799079917992799379947995799679977998799980008001800280038004800580068007800880098010801180128013801480158016801780188019802080218022802380248025802680278028802980308031803280338034803580368037803880398040804180428043804480458046804780488049805080518052805380548055805680578058805980608061806280638064806580668067806880698070807180728073807480758076807780788079808080818082808380848085808680878088808980908091809280938094809580968097809880998100810181028103810481058106810781088109811081118112811381148115811681178118811981208121812281238124812581268127812881298130813181328133813481358136813781388139814081418142814381448145814681478148814981508151815281538154815581568157815881598160816181628163816481658166816781688169817081718172817381748175817681778178817981808181818281838184818581868187818881898190819181928193819481958196819781988199820082018202820382048205820682078208820982108211821282138214821582168217821882198220822182228223822482258226822782288229823082318232823382348235823682378238823982408241824282438244824582468247824882498250825182528253825482558256825782588259826082618262826382648265826682678268826982708271827282738274827582768277827882798280828182828283828482858286828782888289829082918292829382948295829682978298829983008301830283038304830583068307830883098310831183128313831483158316831783188319832083218322832383248325832683278328832983308331833283338334833583368337833883398340834183428343834483458346834783488349835083518352835383548355835683578358835983608361836283638364836583668367836883698370837183728373837483758376837783788379838083818382838383848385838683878388838983908391839283938394839583968397839883998400840184028403840484058406840784088409841084118412841384148415841684178418841984208421842284238424842584268427842884298430843184328433843484358436843784388439844084418442844384448445844684478448844984508451845284538454845584568457845884598460846184628463846484658466846784688469847084718472847384748475847684778478847984808481848284838484848584868487848884898490849184928493849484958496849784988499850085018502850385048505850685078508850985108511851285138514851585168517851885198520852185228523852485258526852785288529853085318532853385348535853685378538853985408541854285438544854585468547854885498550855185528553855485558556855785588559856085618562856385648565856685678568856985708571857285738574857585768577857885798580858185828583858485858586858785888589859085918592859385948595859685978598859986008601860286038604860586068607860886098610861186128613861486158616861786188619862086218622862386248625862686278628862986308631863286338634863586368637863886398640864186428643864486458646864786488649865086518652865386548655865686578658865986608661866286638664866586668667866886698670867186728673867486758676867786788679868086818682868386848685868686878688868986908691869286938694869586968697869886998700870187028703870487058706870787088709871087118712871387148715871687178718871987208721872287238724872587268727872887298730873187328733873487358736873787388739874087418742874387448745874687478748874987508751875287538754875587568757875887598760876187628763876487658766876787688769877087718772877387748775877687778778877987808781878287838784878587868787878887898790879187928793879487958796879787988799880088018802880388048805880688078808880988108811881288138814881588168817881888198820882188228823882488258826882788288829883088318832883388348835883688378838883988408841884288438844884588468847884888498850885188528853885488558856885788588859886088618862886388648865886688678868886988708871887288738874887588768877887888798880888188828883888488858886888788888889889088918892889388948895889688978898889989008901890289038904890589068907890889098910891189128913891489158916891789188919892089218922892389248925892689278928892989308931893289338934893589368937893889398940894189428943894489458946894789488949895089518952895389548955895689578958895989608961896289638964896589668967896889698970897189728973897489758976897789788979898089818982898389848985898689878988898989908991899289938994899589968997899889999000900190029003900490059006900790089009901090119012901390149015901690179018901990209021902290239024902590269027902890299030903190329033903490359036903790389039904090419042904390449045904690479048904990509051905290539054905590569057905890599060906190629063906490659066906790689069907090719072907390749075907690779078907990809081908290839084908590869087908890899090909190929093909490959096909790989099910091019102910391049105910691079108910991109111911291139114911591169117911891199120912191229123912491259126912791289129913091319132913391349135913691379138913991409141914291439144914591469147914891499150915191529153915491559156915791589159916091619162916391649165916691679168916991709171917291739174917591769177917891799180918191829183918491859186918791889189919091919192919391949195919691979198919992009201920292039204920592069207920892099210921192129213921492159216921792189219922092219222922392249225922692279228922992309231923292339234923592369237923892399240924192429243924492459246924792489249925092519252925392549255925692579258925992609261926292639264926592669267926892699270927192729273927492759276927792789279928092819282928392849285928692879288928992909291929292939294929592969297929892999300930193029303930493059306930793089309931093119312931393149315931693179318931993209321932293239324932593269327932893299330933193329333933493359336933793389339934093419342934393449345934693479348934993509351935293539354935593569357935893599360936193629363936493659366936793689369937093719372937393749375937693779378937993809381938293839384938593869387938893899390939193929393939493959396939793989399940094019402940394049405940694079408940994109411941294139414941594169417941894199420942194229423942494259426942794289429943094319432943394349435943694379438943994409441944294439444944594469447944894499450945194529453945494559456945794589459946094619462946394649465946694679468946994709471947294739474947594769477947894799480948194829483948494859486948794889489949094919492949394949495949694979498949995009501950295039504950595069507950895099510951195129513951495159516951795189519952095219522952395249525952695279528952995309531953295339534953595369537953895399540954195429543954495459546954795489549955095519552955395549555955695579558955995609561956295639564956595669567956895699570957195729573957495759576957795789579958095819582958395849585958695879588958995909591959295939594959595969597959895999600960196029603960496059606960796089609961096119612961396149615961696179618961996209621962296239624962596269627962896299630963196329633963496359636963796389639964096419642964396449645964696479648964996509651965296539654965596569657965896599660966196629663966496659666966796689669967096719672967396749675967696779678967996809681968296839684968596869687968896899690969196929693969496959696969796989699970097019702970397049705970697079708970997109711971297139714971597169717971897199720972197229723972497259726972797289729973097319732973397349735973697379738973997409741974297439744974597469747974897499750975197529753975497559756975797589759976097619762976397649765976697679768976997709771977297739774977597769777977897799780978197829783978497859786978797889789979097919792979397949795979697979798979998009801980298039804980598069807980898099810981198129813981498159816981798189819982098219822982398249825982698279828982998309831983298339834983598369837983898399840984198429843984498459846984798489849 | /******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2016 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @website http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php* @version 4.1.11 (2016-03-31)*******************************************************************************/(function (window, undefined) {	if (window.KindEditor) {		return;	}if (!window.console) {	window.console = {};}if (!console.log) {	console.log = function () {};}var _VERSION = '4.1.11 (2016-03-31)',	_ua = navigator.userAgent.toLowerCase(),	_IE = _ua.indexOf('msie') > -1 && _ua.indexOf('opera') == -1,	_NEWIE = _ua.indexOf('msie') == -1 && _ua.indexOf('trident') > -1,	_GECKO = _ua.indexOf('gecko') > -1 && _ua.indexOf('khtml') == -1,	_WEBKIT = _ua.indexOf('applewebkit') > -1,	_OPERA = _ua.indexOf('opera') > -1,	_MOBILE = _ua.indexOf('mobile') > -1,	_IOS = /ipad|iphone|ipod/.test(_ua),	_QUIRKS = document.compatMode != 'CSS1Compat',	_IERANGE = !window.getSelection,	_matches = /(?:msie|firefox|webkit|opera)[\/:\s](\d+)/.exec(_ua),	_V = _matches ? _matches[1] : '0',	_TIME = new Date().getTime();function _isArray(val) {	if (!val) {		return false;	}	return Object.prototype.toString.call(val) === '[object Array]';}function _isFunction(val) {	if (!val) {		return false;	}	return Object.prototype.toString.call(val) === '[object Function]';}function _inArray(val, arr) {	for (var i = 0, len = arr.length; i < len; i++) {		if (val === arr[i]) {			return i;		}	}	return -1;}function _each(obj, fn) {	if (_isArray(obj)) {		for (var i = 0, len = obj.length; i < len; i++) {			if (fn.call(obj[i], i, obj[i]) === false) {				break;			}		}	} else {		for (var key in obj) {			if (obj.hasOwnProperty(key)) {				if (fn.call(obj[key], key, obj[key]) === false) {					break;				}			}		}	}}function _trim(str) {	return str.replace(/(?:^[ \t\n\r]+)|(?:[ \t\n\r]+$)/g, '');}function _inString(val, str, delimiter) {	delimiter = delimiter === undefined ? ',' : delimiter;	return (delimiter + str + delimiter).indexOf(delimiter + val + delimiter) >= 0;}function _addUnit(val, unit) {	unit = unit || 'px';	return val && /^-?\d+(?:\.\d+)?$/.test(val) ? val + unit : val;}function _removeUnit(val) {	var match;	return val && (match = /(\d+)/.exec(val)) ? parseInt(match[1], 10) : 0;}function _escape(val) {	return val.replace(/&/g, '&').replace(/</g, '<').replace(/>/g, '>').replace(/"/g, '"');}function _unescape(val) {	return val.replace(/</g, '<').replace(/>/g, '>').replace(/"/g, '"').replace(/&/g, '&');}function _toCamel(str) {	var arr = str.split('-');	str = '';	_each(arr, function(key, val) {		str += (key > 0) ? val.charAt(0).toUpperCase() + val.substr(1) : val;	});	return str;}function _toHex(val) {	function hex(d) {		var s = parseInt(d, 10).toString(16).toUpperCase();		return s.length > 1 ? s : '0' + s;	}	return val.replace(/rgb\s*\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*\)/ig,		function($0, $1, $2, $3) {			return '#' + hex($1) + hex($2) + hex($3);		}	);}function _toMap(val, delimiter) {	delimiter = delimiter === undefined ? ',' : delimiter;	var map = {}, arr = _isArray(val) ? val : val.split(delimiter), match;	_each(arr, function(key, val) {		if ((match = /^(\d+)\.\.(\d+)$/.exec(val))) {			for (var i = parseInt(match[1], 10); i <= parseInt(match[2], 10); i++) {				map[i.toString()] = true;			}		} else {			map[val] = true;		}	});	return map;}function _toArray(obj, offset) {	return Array.prototype.slice.call(obj, offset || 0);}function _undef(val, defaultVal) {	return val === undefined ? defaultVal : val;}function _invalidUrl(url) {	return !url || /[<>"]/.test(url);}function _addParam(url, param) {	return url.indexOf('?') >= 0 ? url + '&' + param : url + '?' + param;}function _extend(child, parent, proto) {	if (!proto) {		proto = parent;		parent = null;	}	var childProto;	if (parent) {		var fn = function () {};		fn.prototype = parent.prototype;		childProto = new fn();		_each(proto, function(key, val) {			childProto[key] = val;		});	} else {		childProto = proto;	}	childProto.constructor = child;	child.prototype = childProto;	child.parent = parent ? parent.prototype : null;}function _json(text) {	var match;	if ((match = /\{[\s\S]*\}|\[[\s\S]*\]/.exec(text))) {		text = match[0];	}	var cx = /[\u0000\u00ad\u0600-\u0604\u070f\u17b4\u17b5\u200c-\u200f\u2028-\u202f\u2060-\u206f\ufeff\ufff0-\uffff]/g;	cx.lastIndex = 0;	if (cx.test(text)) {		text = text.replace(cx, function (a) {			return '\\u' + ('0000' + a.charCodeAt(0).toString(16)).slice(-4);		});	}	if (/^[\],:{}\s]*$/.	test(text.replace(/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g, '@').	replace(/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g, ']').	replace(/(?:^|:|,)(?:\s*\[)+/g, ''))) {		return eval('(' + text + ')');	}	throw 'JSON parse error';}var _round = Math.round;var K = {	DEBUG : false,	VERSION : _VERSION,	IE : _IE,	GECKO : _GECKO,	WEBKIT : _WEBKIT,	OPERA : _OPERA,	V : _V,	TIME : _TIME,	each : _each,	isArray : _isArray,	isFunction : _isFunction,	inArray : _inArray,	inString : _inString,	trim : _trim,	addUnit : _addUnit,	removeUnit : _removeUnit,	escape : _escape,	unescape : _unescape,	toCamel : _toCamel,	toHex : _toHex,	toMap : _toMap,	toArray : _toArray,	undef : _undef,	invalidUrl : _invalidUrl,	addParam : _addParam,	extend : _extend,	json : _json};var _INLINE_TAG_MAP = _toMap('a,abbr,acronym,b,basefont,bdo,big,br,button,cite,code,del,dfn,em,font,i,img,input,ins,kbd,label,map,q,s,samp,select,small,span,strike,strong,sub,sup,textarea,tt,u,var'),	_BLOCK_TAG_MAP = _toMap('address,applet,blockquote,body,center,dd,dir,div,dl,dt,fieldset,form,frameset,h1,h2,h3,h4,h5,h6,head,hr,html,iframe,ins,isindex,li,map,menu,meta,noframes,noscript,object,ol,p,pre,script,style,table,tbody,td,tfoot,th,thead,title,tr,ul'),	_SINGLE_TAG_MAP = _toMap('area,base,basefont,br,col,frame,hr,img,input,isindex,link,meta,param,embed'),	_STYLE_TAG_MAP = _toMap('b,basefont,big,del,em,font,i,s,small,span,strike,strong,sub,sup,u'),	_CONTROL_TAG_MAP = _toMap('img,table,input,textarea,button'),	_PRE_TAG_MAP = _toMap('pre,style,script'),	_NOSPLIT_TAG_MAP = _toMap('html,head,body,td,tr,table,ol,ul,li'),	_AUTOCLOSE_TAG_MAP = _toMap('colgroup,dd,dt,li,options,p,td,tfoot,th,thead,tr'),	_FILL_ATTR_MAP = _toMap('checked,compact,declare,defer,disabled,ismap,multiple,nohref,noresize,noshade,nowrap,readonly,selected'),	_VALUE_TAG_MAP = _toMap('input,button,textarea,select');function _getBasePath() {	var els = document.getElementsByTagName('script'), src;	for (var i = 0, len = els.length; i < len; i++) {		src = els[i].src || '';		if (/kindeditor[\w\-\.]*\.js/.test(src)) {			return src.substring(0, src.lastIndexOf('/') + 1);		}	}	return '';}K.basePath = _getBasePath();K.options = {	designMode : true,	fullscreenMode : false,	filterMode : true,	wellFormatMode : true,	shadowMode : true,	loadStyleMode : true,	basePath : K.basePath,	themesPath : K.basePath + 'themes/',	langPath : K.basePath + 'lang/',	pluginsPath : K.basePath + 'plugins/',	themeType : 'default',	langType : 'zh-CN',	urlType : '',	newlineTag : 'p',	resizeType : 2,	syncType : 'form',	pasteType : 2,	dialogAlignType : 'page',	useContextmenu : true,	fullscreenShortcut : false,	bodyClass : 'ke-content',	indentChar : '\t',	cssPath : '',	cssData : '',	minWidth : 650,	minHeight : 100,	minChangeSize : 50,	zIndex : 811213,	items : [		'source', '|', 'undo', 'redo', '|', 'preview', 'print', 'template', 'code', 'cut', 'copy', 'paste',		'plainpaste', 'wordpaste', '|', 'justifyleft', 'justifycenter', 'justifyright',		'justifyfull', 'insertorderedlist', 'insertunorderedlist', 'indent', 'outdent', 'subscript',		'superscript', 'clearhtml', 'quickformat', 'selectall', '|', 'fullscreen', '/',		'formatblock', 'fontname', 'fontsize', '|', 'forecolor', 'hilitecolor', 'bold',		'italic', 'underline', 'strikethrough', 'lineheight', 'removeformat', '|', 'image', 'multiimage',		'flash', 'media', 'insertfile', 'table', 'hr', 'emoticons', 'baidumap', 'pagebreak',		'anchor', 'link', 'unlink', '|', 'about'	],	noDisableItems : ['source', 'fullscreen'],	colorTable : [		['#E53333', '#E56600', '#FF9900', '#64451D', '#DFC5A4', '#FFE500'],		['#009900', '#006600', '#99BB00', '#B8D100', '#60D978', '#00D5FF'],		['#337FE5', '#003399', '#4C33E5', '#9933E5', '#CC33E5', '#EE33EE'],		['#FFFFFF', '#CCCCCC', '#999999', '#666666', '#333333', '#000000']	],	fontSizeTable : ['9px', '10px', '12px', '14px', '16px', '18px', '24px', '32px'],	htmlTags : {		font : ['id', 'class', 'color', 'size', 'face', '.background-color'],		span : [			'id', 'class', '.color', '.background-color', '.font-size', '.font-family', '.background',			'.font-weight', '.font-style', '.text-decoration', '.vertical-align', '.line-height'		],		div : [			'id', 'class', 'align', '.border', '.margin', '.padding', '.text-align', '.color',			'.background-color', '.font-size', '.font-family', '.font-weight', '.background',			'.font-style', '.text-decoration', '.vertical-align', '.margin-left'		],		table: [			'id', 'class', 'border', 'cellspacing', 'cellpadding', 'width', 'height', 'align', 'bordercolor',			'.padding', '.margin', '.border', 'bgcolor', '.text-align', '.color', '.background-color',			'.font-size', '.font-family', '.font-weight', '.font-style', '.text-decoration', '.background',			'.width', '.height', '.border-collapse'		],		'td,th': [			'id', 'class', 'align', 'valign', 'width', 'height', 'colspan', 'rowspan', 'bgcolor',			'.text-align', '.color', '.background-color', '.font-size', '.font-family', '.font-weight',			'.font-style', '.text-decoration', '.vertical-align', '.background', '.border'		],		a : ['id', 'class', 'href', 'target', 'name'],		embed : ['id', 'class', 'src', 'width', 'height', 'type', 'loop', 'autostart', 'quality', '.width', '.height', 'align', 'allowscriptaccess', 'wmode'],		img : ['id', 'class', 'src', 'width', 'height', 'border', 'alt', 'title', 'align', '.width', '.height', '.border'],		'p,ol,ul,li,blockquote,h1,h2,h3,h4,h5,h6' : [			'id', 'class', 'align', '.text-align', '.color', '.background-color', '.font-size', '.font-family', '.background',			'.font-weight', '.font-style', '.text-decoration', '.vertical-align', '.text-indent', '.margin-left'		],		pre : ['id', 'class'],		hr : ['id', 'class', '.page-break-after'],		'br,tbody,tr,strong,b,sub,sup,em,i,u,strike,s,del' : ['id', 'class'],		iframe : ['id', 'class', 'src', 'frameborder', 'width', 'height', '.width', '.height']	},	layout : '<div class="container"><div class="toolbar"></div><div class="edit"></div><div class="statusbar"></div></div>'};var _useCapture = false;var _INPUT_KEY_MAP = _toMap('8,9,13,32,46,48..57,59,61,65..90,106,109..111,188,190..192,219..222');var _CURSORMOVE_KEY_MAP = _toMap('33..40');var _CHANGE_KEY_MAP = {};_each(_INPUT_KEY_MAP, function(key, val) {	_CHANGE_KEY_MAP[key] = val;});_each(_CURSORMOVE_KEY_MAP, function(key, val) {	_CHANGE_KEY_MAP[key] = val;});function _bindEvent(el, type, fn) {	if (el.addEventListener){		el.addEventListener(type, fn, _useCapture);	} else if (el.attachEvent){		el.attachEvent('on' + type, fn);	}}function _unbindEvent(el, type, fn) {	if (el.removeEventListener){		el.removeEventListener(type, fn, _useCapture);	} else if (el.detachEvent){		el.detachEvent('on' + type, fn);	}}var _EVENT_PROPS = ('altKey,attrChange,attrName,bubbles,button,cancelable,charCode,clientX,clientY,ctrlKey,currentTarget,' +	'data,detail,eventPhase,fromElement,handler,keyCode,metaKey,newValue,offsetX,offsetY,originalTarget,pageX,' +	'pageY,prevValue,relatedNode,relatedTarget,screenX,screenY,shiftKey,srcElement,target,toElement,view,wheelDelta,which').split(',');function KEvent(el, event) {	this.init(el, event);}_extend(KEvent, {	init : function(el, event) {		var self = this, doc = el.ownerDocument || el.document || el;		self.event = event;		_each(_EVENT_PROPS, function(key, val) {			self[val] = event[val];		});		if (!self.target) {			self.target = self.srcElement || doc;		}		if (self.target.nodeType === 3) {			self.target = self.target.parentNode;		}		if (!self.relatedTarget && self.fromElement) {			self.relatedTarget = self.fromElement === self.target ? self.toElement : self.fromElement;		}		if (self.pageX == null && self.clientX != null) {			var d = doc.documentElement, body = doc.body;			self.pageX = self.clientX + (d && d.scrollLeft || body && body.scrollLeft || 0) - (d && d.clientLeft || body && body.clientLeft || 0);			self.pageY = self.clientY + (d && d.scrollTop  || body && body.scrollTop  || 0) - (d && d.clientTop  || body && body.clientTop  || 0);		}		if (!self.which && ((self.charCode || self.charCode === 0) ? self.charCode : self.keyCode)) {			self.which = self.charCode || self.keyCode;		}		if (!self.metaKey && self.ctrlKey) {			self.metaKey = self.ctrlKey;		}		if (!self.which && self.button !== undefined) {			self.which = (self.button & 1 ? 1 : (self.button & 2 ? 3 : (self.button & 4 ? 2 : 0)));		}		switch (self.which) {		case 186 :			self.which = 59;			break;		case 187 :		case 107 :		case 43 :			self.which = 61;			break;		case 189 :		case 45 :			self.which = 109;			break;		case 42 :			self.which = 106;			break;		case 47 :			self.which = 111;			break;		case 78 :			self.which = 110;			break;		}		if (self.which >= 96 && self.which <= 105) {			self.which -= 48;		}	},	preventDefault : function() {		var ev = this.event;		if (ev.preventDefault) {			ev.preventDefault();		} else {			ev.returnValue = false;		}	},	stopPropagation : function() {		var ev = this.event;		if (ev.stopPropagation) {			ev.stopPropagation();		} else {			ev.cancelBubble = true;		}	},	stop : function() {		this.preventDefault();		this.stopPropagation();	}});var _eventExpendo = 'kindeditor_' + _TIME, _eventId = 0, _eventData = {};function _getId(el) {	return el[_eventExpendo] || null;}function _setId(el) {	el[_eventExpendo] = ++_eventId;	return _eventId;}function _removeId(el) {	try {		delete el[_eventExpendo];	} catch(e) {		if (el.removeAttribute) {			el.removeAttribute(_eventExpendo);		}	}}function _bind(el, type, fn) {	if (type.indexOf(',') >= 0) {		_each(type.split(','), function() {			_bind(el, this, fn);		});		return;	}	var id = _getId(el);	if (!id) {		id = _setId(el);	}	if (_eventData[id] === undefined) {		_eventData[id] = {};	}	var events = _eventData[id][type];	if (events && events.length > 0) {		_unbindEvent(el, type, events[0]);	} else {		_eventData[id][type] = [];		_eventData[id].el = el;	}	events = _eventData[id][type];	if (events.length === 0) {		events[0] = function(e) {			var kevent = e ? new KEvent(el, e) : undefined;			_each(events, function(i, event) {				if (i > 0 && event) {					event.call(el, kevent);				}			});		};	}	if (_inArray(fn, events) < 0) {		events.push(fn);	}	_bindEvent(el, type, events[0]);}function _unbind(el, type, fn) {	if (type && type.indexOf(',') >= 0) {		_each(type.split(','), function() {			_unbind(el, this, fn);		});		return;	}	var id = _getId(el);	if (!id) {		return;	}	if (type === undefined) {		if (id in _eventData) {			_each(_eventData[id], function(key, events) {				if (key != 'el' && events.length > 0) {					_unbindEvent(el, key, events[0]);				}			});			delete _eventData[id];			_removeId(el);		}		return;	}	if (!_eventData[id]) {		return;	}	var events = _eventData[id][type];	if (events && events.length > 0) {		if (fn === undefined) {			_unbindEvent(el, type, events[0]);			delete _eventData[id][type];		} else {			_each(events, function(i, event) {				if (i > 0 && event === fn) {					events.splice(i, 1);				}			});			if (events.length == 1) {				_unbindEvent(el, type, events[0]);				delete _eventData[id][type];			}		}		var count = 0;		_each(_eventData[id], function() {			count++;		});		if (count < 2) {			delete _eventData[id];			_removeId(el);		}	}}function _fire(el, type) {	if (type.indexOf(',') >= 0) {		_each(type.split(','), function() {			_fire(el, this);		});		return;	}	var id = _getId(el);	if (!id) {		return;	}	var events = _eventData[id][type];	if (_eventData[id] && events && events.length > 0) {		events[0]();	}}function _ctrl(el, key, fn) {	var self = this;	key = /^\d{2,}$/.test(key) ? key : key.toUpperCase().charCodeAt(0);	_bind(el, 'keydown', function(e) {		if (e.ctrlKey && e.which == key && !e.shiftKey && !e.altKey) {			fn.call(el);			e.stop();		}	});}var _readyFinished = false;function _ready(fn) {	if (_readyFinished) {		fn(KindEditor);		return;	}	var loaded = false;	function readyFunc() {		if (!loaded) {			loaded = true;			fn(KindEditor);			_readyFinished = true;		}	}	function ieReadyFunc() {		if (!loaded) {			try {				document.documentElement.doScroll('left');			} catch(e) {				setTimeout(ieReadyFunc, 100);				return;			}			readyFunc();		}	}	function ieReadyStateFunc() {		if (document.readyState === 'complete') {			readyFunc();		}	}	if (document.addEventListener) {		_bind(document, 'DOMContentLoaded', readyFunc);	} else if (document.attachEvent) {		_bind(document, 'readystatechange', ieReadyStateFunc);		var toplevel = false;		try {			toplevel = window.frameElement == null;		} catch(e) {}		if (document.documentElement.doScroll && toplevel) {			ieReadyFunc();		}	}	_bind(window, 'load', readyFunc);}if (window.attachEvent) {	window.attachEvent('onunload', function() {		_each(_eventData, function(key, events) {			if (events.el) {				_unbind(events.el);			}		});	});}K.ctrl = _ctrl;K.ready = _ready;function _getCssList(css) {	var list = {},		reg = /\s*([\w\-]+)\s*:([^;]*)(;|$)/g,		match;	while ((match = reg.exec(css))) {		var key = _trim(match[1].toLowerCase()),			val = _trim(_toHex(match[2]));		list[key] = val;	}	return list;}function _getAttrList(tag) {	var list = {},		reg = /\s+(?:([\w\-:]+)|(?:([\w\-:]+)=([^\s"'<>]+))|(?:([\w\-:"]+)="([^"]*)")|(?:([\w\-:"]+)='([^']*)'))(?=(?:\s|\/|>)+)/g,		match;	while ((match = reg.exec(tag))) {		var key = (match[1] || match[2] || match[4] || match[6]).toLowerCase(),			val = (match[2] ? match[3] : (match[4] ? match[5] : match[7])) || '';		list[key] = val;	}	return list;}function _addClassToTag(tag, className) {	if (/\s+class\s*=/.test(tag)) {		tag = tag.replace(/(\s+class=["']?)([^"']*)(["']?[\s>])/, function($0, $1, $2, $3) {			if ((' ' + $2 + ' ').indexOf(' ' + className + ' ') < 0) {				return $2 === '' ? $1 + className + $3 : $1 + $2 + ' ' + className + $3;			} else {				return $0;			}		});	} else {		tag = tag.substr(0, tag.length - 1) + ' class="' + className + '">';	}	return tag;}function _formatCss(css) {	var str = '';	_each(_getCssList(css), function(key, val) {		str += key + ':' + val + ';';	});	return str;}function _formatUrl(url, mode, host, pathname) {	mode = _undef(mode, '').toLowerCase();	if (url.substr(0, 5) != 'data:') {		url = url.replace(/([^:])\/\//g, '$1/');	}	if (_inArray(mode, ['absolute', 'relative', 'domain']) < 0) {		return url;	}	host = host || location.protocol + '//' + location.host;	if (pathname === undefined) {		var m = location.pathname.match(/^(\/.*)\//);		pathname = m ? m[1] : '';	}	var match;	if ((match = /^(\w+:\/\/[^\/]*)/.exec(url))) {		if (match[1] !== host) {			return url;		}	} else if (/^\w+:/.test(url)) {		return url;	}	function getRealPath(path) {		var parts = path.split('/'), paths = [];		for (var i = 0, len = parts.length; i < len; i++) {			var part = parts[i];			if (part == '..') {				if (paths.length > 0) {					paths.pop();				}			} else if (part !== '' && part != '.') {				paths.push(part);			}		}		return '/' + paths.join('/');	}	if (/^\//.test(url)) {		url = host + getRealPath(url.substr(1));	} else if (!/^\w+:\/\//.test(url)) {		url = host + getRealPath(pathname + '/' + url);	}	function getRelativePath(path, depth) {		if (url.substr(0, path.length) === path) {			var arr = [];			for (var i = 0; i < depth; i++) {				arr.push('..');			}			var prefix = '.';			if (arr.length > 0) {				prefix += '/' + arr.join('/');			}			if (pathname == '/') {				prefix += '/';			}			return prefix + url.substr(path.length);		} else {			if ((match = /^(.*)\//.exec(path))) {				return getRelativePath(match[1], ++depth);			}		}	}	if (mode === 'relative') {		url = getRelativePath(host + pathname, 0).substr(2);	} else if (mode === 'absolute') {		if (url.substr(0, host.length) === host) {			url = url.substr(host.length);		}	}	return url;}function _formatHtml(html, htmlTags, urlType, wellFormatted, indentChar) {	if (html == null) {		html = '';	}	urlType = urlType || '';	wellFormatted = _undef(wellFormatted, false);	indentChar = _undef(indentChar, '\t');	var fontSizeList = 'xx-small,x-small,small,medium,large,x-large,xx-large'.split(',');	html = html.replace(/(<(?:pre|pre\s[^>]*)>)([\s\S]*?)(<\/pre>)/ig, function($0, $1, $2, $3) {		return $1 + $2.replace(/<(?:br|br\s[^>]*)>/ig, '\n') + $3;	});	html = html.replace(/<(?:br|br\s[^>]*)\s*\/?>\s*<\/p>/ig, '</p>');	html = html.replace(/(<(?:p|p\s[^>]*)>)\s*(<\/p>)/ig, '$1<br />$2');	html = html.replace(/\u200B/g, '');	html = html.replace(/\u00A9/g, '©');	html = html.replace(/\u00AE/g, '®');	html = html.replace(/\u2003/g, ' ');	html = html.replace(/\u3000/g, ' ');	html = html.replace(/<[^>]+/g, function($0) {		return $0.replace(/\s+/g, ' ');	});	var htmlTagMap = {};	if (htmlTags) {		_each(htmlTags, function(key, val) {			var arr = key.split(',');			for (var i = 0, len = arr.length; i < len; i++) {				htmlTagMap[arr[i]] = _toMap(val);			}		});		if (!htmlTagMap.script) {			html = html.replace(/(<(?:script|script\s[^>]*)>)([\s\S]*?)(<\/script>)/ig, '');		}		if (!htmlTagMap.style) {			html = html.replace(/(<(?:style|style\s[^>]*)>)([\s\S]*?)(<\/style>)/ig, '');		}	}	var re = /(\s*)<(\/)?([\w\-:]+)((?:\s+|(?:\s+[\w\-:]+)|(?:\s+[\w\-:]+=[^\s"'<>]+)|(?:\s+[\w\-:"]+="[^"]*")|(?:\s+[\w\-:"]+='[^']*'))*)(\/)?>(\s*)/g;	var tagStack = [];	html = html.replace(re, function($0, $1, $2, $3, $4, $5, $6) {		var full = $0,			startNewline = $1 || '',			startSlash = $2 || '',			tagName = $3.toLowerCase(),			attr = $4 || '',			endSlash = $5 ? ' ' + $5 : '',			endNewline = $6 || '';		if (htmlTags && !htmlTagMap[tagName]) {			return '';		}		if (endSlash === '' && _SINGLE_TAG_MAP[tagName]) {			endSlash = ' /';		}		if (_INLINE_TAG_MAP[tagName]) {			if (startNewline) {				startNewline = ' ';			}			if (endNewline) {				endNewline = ' ';			}		}		if (_PRE_TAG_MAP[tagName]) {			if (startSlash) {				endNewline = '\n';			} else {				startNewline = '\n';			}		}		if (wellFormatted && tagName == 'br') {			endNewline = '\n';		}		if (_BLOCK_TAG_MAP[tagName] && !_PRE_TAG_MAP[tagName]) {			if (wellFormatted) {				if (startSlash && tagStack.length > 0 && tagStack[tagStack.length - 1] === tagName) {					tagStack.pop();				} else {					tagStack.push(tagName);				}				startNewline = '\n';				endNewline = '\n';				for (var i = 0, len = startSlash ? tagStack.length : tagStack.length - 1; i < len; i++) {					startNewline += indentChar;					if (!startSlash) {						endNewline += indentChar;					}				}				if (endSlash) {					tagStack.pop();				} else if (!startSlash) {					endNewline += indentChar;				}			} else {				startNewline = endNewline = '';			}		}		if (attr !== '') {			var attrMap = _getAttrList(full);			if (tagName === 'font') {				var fontStyleMap = {}, fontStyle = '';				_each(attrMap, function(key, val) {					if (key === 'color') {						fontStyleMap.color = val;						delete attrMap[key];					}					if (key === 'size') {						fontStyleMap['font-size'] = fontSizeList[parseInt(val, 10) - 1] || '';						delete attrMap[key];					}					if (key === 'face') {						fontStyleMap['font-family'] = val;						delete attrMap[key];					}					if (key === 'style') {						fontStyle = val;					}				});				if (fontStyle && !/;$/.test(fontStyle)) {					fontStyle += ';';				}				_each(fontStyleMap, function(key, val) {					if (val === '') {						return;					}					if (/\s/.test(val)) {						val = "'" + val + "'";					}					fontStyle += key + ':' + val + ';';				});				attrMap.style = fontStyle;			}			_each(attrMap, function(key, val) {				if (_FILL_ATTR_MAP[key]) {					attrMap[key] = key;				}				if (_inArray(key, ['src', 'href']) >= 0) {					attrMap[key] = _formatUrl(val, urlType);				}				if (htmlTags && key !== 'style' && !htmlTagMap[tagName]['*'] && !htmlTagMap[tagName][key] ||					tagName === 'body' && key === 'contenteditable' ||					/^kindeditor_\d+$/.test(key)) {					delete attrMap[key];				}				if (key === 'style' && val !== '') {					var styleMap = _getCssList(val);					_each(styleMap, function(k, v) {						if (htmlTags && !htmlTagMap[tagName].style && !htmlTagMap[tagName]['.' + k]) {							delete styleMap[k];						}					});					var style = '';					_each(styleMap, function(k, v) {						style += k + ':' + v + ';';					});					attrMap.style = style;				}			});			attr = '';			_each(attrMap, function(key, val) {				if (key === 'style' && val === '') {					return;				}				val = val.replace(/"/g, '"');				attr += ' ' + key + '="' + val + '"';			});		}		if (tagName === 'font') {			tagName = 'span';		}		return startNewline + '<' + startSlash + tagName + attr + endSlash + '>' + endNewline;	});	html = html.replace(/(<(?:pre|pre\s[^>]*)>)([\s\S]*?)(<\/pre>)/ig, function($0, $1, $2, $3) {		return $1 + $2.replace(/\n/g, '<span id="__kindeditor_pre_newline__">\n') + $3;	});	html = html.replace(/\n\s*\n/g, '\n');	html = html.replace(/<span id="__kindeditor_pre_newline__">\n/g, '\n');	return _trim(html);}function _clearMsWord(html, htmlTags) {	html = html.replace(/<meta[\s\S]*?>/ig, '')		.replace(/<![\s\S]*?>/ig, '')		.replace(/<style[^>]*>[\s\S]*?<\/style>/ig, '')		.replace(/<script[^>]*>[\s\S]*?<\/script>/ig, '')		.replace(/<w:[^>]+>[\s\S]*?<\/w:[^>]+>/ig, '')		.replace(/<o:[^>]+>[\s\S]*?<\/o:[^>]+>/ig, '')		.replace(/<xml>[\s\S]*?<\/xml>/ig, '')		.replace(/<(?:table|td)[^>]*>/ig, function(full) {			return full.replace(/border-bottom:([#\w\s]+)/ig, 'border:$1');		});	return _formatHtml(html, htmlTags);}function _mediaType(src) {	if (/\.(rm|rmvb)(\?|$)/i.test(src)) {		return 'audio/x-pn-realaudio-plugin';	}	if (/\.(swf|flv)(\?|$)/i.test(src)) {		return 'application/x-shockwave-flash';	}	return 'video/x-ms-asf-plugin';}function _mediaClass(type) {	if (/realaudio/i.test(type)) {		return 'ke-rm';	}	if (/flash/i.test(type)) {		return 'ke-flash';	}	return 'ke-media';}function _mediaAttrs(srcTag) {	return _getAttrList(unescape(srcTag));}function _mediaEmbed(attrs) {	var html = '<embed ';	_each(attrs, function(key, val) {		html += key + '="' + val + '" ';	});	html += '/>';	return html;}function _mediaImg(blankPath, attrs) {	var width = attrs.width,		height = attrs.height,		type = attrs.type || _mediaType(attrs.src),		srcTag = _mediaEmbed(attrs),		style = '';	if (/\D/.test(width)) {		style += 'width:' + width + ';';	} else if (width > 0) {		style += 'width:' + width + 'px;';	}	if (/\D/.test(height)) {		style += 'height:' + height + ';';	} else if (height > 0) {		style += 'height:' + height + 'px;';	}	var html = '<img class="' + _mediaClass(type) + '" src="' + blankPath + '" ';	if (style !== '') {		html += 'style="' + style + '" ';	}	html += 'data-ke-tag="' + escape(srcTag) + '" alt="" />';	return html;}function _tmpl(str, data) {	var fn = new Function("obj",		"var p=[],print=function(){p.push.apply(p,arguments);};" +		"with(obj){p.push('" +		str.replace(/[\r\t\n]/g, " ")			.split("<%").join("\t")			.replace(/((^|%>)[^\t]*)'/g, "$1\r")			.replace(/\t=(.*?)%>/g, "',$1,'")			.split("\t").join("');")			.split("%>").join("p.push('")			.split("\r").join("\\'") + "');}return p.join('');");	return data ? fn(data) : fn;}K.formatUrl = _formatUrl;K.formatHtml = _formatHtml;K.getCssList = _getCssList;K.getAttrList = _getAttrList;K.mediaType = _mediaType;K.mediaAttrs = _mediaAttrs;K.mediaEmbed = _mediaEmbed;K.mediaImg = _mediaImg;K.clearMsWord = _clearMsWord;K.tmpl = _tmpl;function _contains(nodeA, nodeB) {	if (nodeA.nodeType == 9 && nodeB.nodeType != 9) {		return true;	}	while ((nodeB = nodeB.parentNode)) {		if (nodeB == nodeA) {			return true;		}	}	return false;}var _getSetAttrDiv = document.createElement('div');_getSetAttrDiv.setAttribute('className', 't');var _GET_SET_ATTRIBUTE = _getSetAttrDiv.className !== 't';function _getAttr(el, key) {	key = key.toLowerCase();	var val = null;	if (!_GET_SET_ATTRIBUTE && el.nodeName.toLowerCase() != 'script') {		var div = el.ownerDocument.createElement('div');		div.appendChild(el.cloneNode(false));		var list = _getAttrList(_unescape(div.innerHTML));		if (key in list) {			val = list[key];		}	} else {		try {			val = el.getAttribute(key, 2);		} catch(e) {			val = el.getAttribute(key, 1);		}	}	if (key === 'style' && val !== null) {		val = _formatCss(val);	}	return val;}function _queryAll(expr, root) {	var exprList = expr.split(',');	if (exprList.length > 1) {		var mergedResults = [];		_each(exprList, function() {			_each(_queryAll(this, root), function() {				if (_inArray(this, mergedResults) < 0) {					mergedResults.push(this);				}			});		});		return mergedResults;	}	root = root || document;	function escape(str) {		if (typeof str != 'string') {			return str;		}		return str.replace(/([^\w\-])/g, '\\$1');	}	function stripslashes(str) {		return str.replace(/\\/g, '');	}	function cmpTag(tagA, tagB) {		return tagA === '*' || tagA.toLowerCase() === escape(tagB.toLowerCase());	}	function byId(id, tag, root) {		var arr = [],			doc = root.ownerDocument || root,			el = doc.getElementById(stripslashes(id));		if (el) {			if (cmpTag(tag, el.nodeName) && _contains(root, el)) {				arr.push(el);			}		}		return arr;	}	function byClass(className, tag, root) {		var doc = root.ownerDocument || root, arr = [], els, i, len, el;		if (root.getElementsByClassName) {			els = root.getElementsByClassName(stripslashes(className));			for (i = 0, len = els.length; i < len; i++) {				el = els[i];				if (cmpTag(tag, el.nodeName)) {					arr.push(el);				}			}		} else if (doc.querySelectorAll) {			els = doc.querySelectorAll((root.nodeName !== '#document' ? root.nodeName + ' ' : '') + tag + '.' + className);			for (i = 0, len = els.length; i < len; i++) {				el = els[i];				if (_contains(root, el)) {					arr.push(el);				}			}		} else {			els = root.getElementsByTagName(tag);			className = ' ' + className + ' ';			for (i = 0, len = els.length; i < len; i++) {				el = els[i];				if (el.nodeType == 1) {					var cls = el.className;					if (cls && (' ' + cls + ' ').indexOf(className) > -1) {						arr.push(el);					}				}			}		}		return arr;	}	function byName(name, tag, root) {		var arr = [], doc = root.ownerDocument || root,			els = doc.getElementsByName(stripslashes(name)), el;		for (var i = 0, len = els.length; i < len; i++) {			el = els[i];			if (cmpTag(tag, el.nodeName) && _contains(root, el)) {				if (el.getAttribute('name') !== null) {					arr.push(el);				}			}		}		return arr;	}	function byAttr(key, val, tag, root) {		var arr = [], els = root.getElementsByTagName(tag), el;		for (var i = 0, len = els.length; i < len; i++) {			el = els[i];			if (el.nodeType == 1) {				if (val === null) {					if (_getAttr(el, key) !== null) {						arr.push(el);					}				} else {					if (val === escape(_getAttr(el, key))) {						arr.push(el);					}				}			}		}		return arr;	}	function select(expr, root) {		var arr = [], matches;		matches = /^((?:\\.|[^.#\s\[<>])+)/.exec(expr);		var tag = matches ? matches[1] : '*';		if ((matches = /#((?:[\w\-]|\\.)+)$/.exec(expr))) {			arr = byId(matches[1], tag, root);		} else if ((matches = /\.((?:[\w\-]|\\.)+)$/.exec(expr))) {			arr = byClass(matches[1], tag, root);		} else if ((matches = /\[((?:[\w\-]|\\.)+)\]/.exec(expr))) {			arr = byAttr(matches[1].toLowerCase(), null, tag, root);		} else if ((matches = /\[((?:[\w\-]|\\.)+)\s*=\s*['"]?((?:\\.|[^'"]+)+)['"]?\]/.exec(expr))) {			var key = matches[1].toLowerCase(), val = matches[2];			if (key === 'id') {				arr = byId(val, tag, root);			} else if (key === 'class') {				arr = byClass(val, tag, root);			} else if (key === 'name') {				arr = byName(val, tag, root);			} else {				arr = byAttr(key, val, tag, root);			}		} else {			var els = root.getElementsByTagName(tag), el;			for (var i = 0, len = els.length; i < len; i++) {				el = els[i];				if (el.nodeType == 1) {					arr.push(el);				}			}		}		return arr;	}	var parts = [], arr, re = /((?:\\.|[^\s>])+|[\s>])/g;	while ((arr = re.exec(expr))) {		if (arr[1] !== ' ') {			parts.push(arr[1]);		}	}	var results = [];	if (parts.length == 1) {		return select(parts[0], root);	}	var isChild = false, part, els, subResults, val, v, i, j, k, length, len, l;	for (i = 0, lenth = parts.length; i < lenth; i++) {		part = parts[i];		if (part === '>') {			isChild = true;			continue;		}		if (i > 0) {			els = [];			for (j = 0, len = results.length; j < len; j++) {				val = results[j];				subResults = select(part, val);				for (k = 0, l = subResults.length; k < l; k++) {					v = subResults[k];					if (isChild) {						if (val === v.parentNode) {							els.push(v);						}					} else {						els.push(v);					}				}			}			results = els;		} else {			results = select(part, root);		}		if (results.length === 0) {			return [];		}	}	return results;}function _query(expr, root) {	var arr = _queryAll(expr, root);	return arr.length > 0 ? arr[0] : null;}K.query = _query;K.queryAll = _queryAll;function _get(val) {	return K(val)[0];}function _getDoc(node) {	if (!node) {		return document;	}	return node.ownerDocument || node.document || node;}function _getWin(node) {	if (!node) {		return window;	}	var doc = _getDoc(node);	return doc.parentWindow || doc.defaultView;}function _setHtml(el, html) {	if (el.nodeType != 1) {		return;	}	var doc = _getDoc(el);	try {		el.innerHTML = '<img id="__kindeditor_temp_tag__" width="0" height="0" style="display:none;" />' + html;		var temp = doc.getElementById('__kindeditor_temp_tag__');		temp.parentNode.removeChild(temp);	} catch(e) {		K(el).empty();		K('@' + html, doc).each(function() {			el.appendChild(this);		});	}}function _hasClass(el, cls) {	return _inString(cls, el.className, ' ');}function _setAttr(el, key, val) {	if (_IE && _V < 8 && key.toLowerCase() == 'class') {		key = 'className';	}	el.setAttribute(key, '' + val);}function _removeAttr(el, key) {	if (_IE && _V < 8 && key.toLowerCase() == 'class') {		key = 'className';	}	_setAttr(el, key, '');	el.removeAttribute(key);}function _getNodeName(node) {	if (!node || !node.nodeName) {		return '';	}	return node.nodeName.toLowerCase();}function _computedCss(el, key) {	var self = this, win = _getWin(el), camelKey = _toCamel(key), val = '';	if (win.getComputedStyle) {		var style = win.getComputedStyle(el, null);		val = style[camelKey] || style.getPropertyValue(key) || el.style[camelKey];	} else if (el.currentStyle) {		val = el.currentStyle[camelKey] || el.style[camelKey];	}	return val;}function _hasVal(node) {	return !!_VALUE_TAG_MAP[_getNodeName(node)];}function _docElement(doc) {	doc = doc || document;	return _QUIRKS ? doc.body : doc.documentElement;}function _docHeight(doc) {	var el = _docElement(doc);	return Math.max(el.scrollHeight, el.clientHeight);}function _docWidth(doc) {	var el = _docElement(doc);	return Math.max(el.scrollWidth, el.clientWidth);}function _getScrollPos(doc) {	doc = doc || document;	var x, y;	if (_IE || _NEWIE || _OPERA) {		x = _docElement(doc).scrollLeft;		y = _docElement(doc).scrollTop;	} else {		x = _getWin(doc).scrollX;		y = _getWin(doc).scrollY;	}	return {x : x, y : y};}function KNode(node) {	this.init(node);}_extend(KNode, {	init : function(node) {		var self = this;		node = _isArray(node) ? node : [node];		var length = 0;		for (var i = 0, len = node.length; i < len; i++) {			if (node[i]) {				self[i] = node[i].constructor === KNode ? node[i][0] : node[i];				length++;			}		}		self.length = length;		self.doc = _getDoc(self[0]);		self.name = _getNodeName(self[0]);		self.type = self.length > 0 ? self[0].nodeType : null;		self.win = _getWin(self[0]);	},	each : function(fn) {		var self = this;		for (var i = 0; i < self.length; i++) {			if (fn.call(self[i], i, self[i]) === false) {				return self;			}		}		return self;	},	bind : function(type, fn) {		this.each(function() {			_bind(this, type, fn);		});		return this;	},	unbind : function(type, fn) {		this.each(function() {			_unbind(this, type, fn);		});		return this;	},	fire : function(type) {		if (this.length < 1) {			return this;		}		_fire(this[0], type);		return this;	},	hasAttr : function(key) {		if (this.length < 1) {			return false;		}		return !!_getAttr(this[0], key);	},	attr : function(key, val) {		var self = this;		if (key === undefined) {			return _getAttrList(self.outer());		}		if (typeof key === 'object') {			_each(key, function(k, v) {				self.attr(k, v);			});			return self;		}		if (val === undefined) {			val = self.length < 1 ? null : _getAttr(self[0], key);			return val === null ? '' : val;		}		self.each(function() {			_setAttr(this, key, val);		});		return self;	},	removeAttr : function(key) {		this.each(function() {			_removeAttr(this, key);		});		return this;	},	get : function(i) {		if (this.length < 1) {			return null;		}		return this[i || 0];	},	eq : function(i) {		if (this.length < 1) {			return null;		}		return this[i] ? new KNode(this[i]) : null;	},	hasClass : function(cls) {		if (this.length < 1) {			return false;		}		return _hasClass(this[0], cls);	},	addClass : function(cls) {		this.each(function() {			if (!_hasClass(this, cls)) {				this.className = _trim(this.className + ' ' + cls);			}		});		return this;	},	removeClass : function(cls) {		this.each(function() {			if (_hasClass(this, cls)) {				this.className = _trim(this.className.replace(new RegExp('(^|\\s)' + cls + '(\\s|$)'), ' '));			}		});		return this;	},	html : function(val) {		var self = this;		if (val === undefined) {			if (self.length < 1 || self.type != 1) {				return '';			}			return _formatHtml(self[0].innerHTML);		}		self.each(function() {			_setHtml(this, val);		});		return self;	},	text : function() {		var self = this;		if (self.length < 1) {			return '';		}		return _IE ? self[0].innerText : self[0].textContent;	},	hasVal : function() {		if (this.length < 1) {			return false;		}		return _hasVal(this[0]);	},	val : function(val) {		var self = this;		if (val === undefined) {			if (self.length < 1) {				return '';			}			return self.hasVal() ? self[0].value : self.attr('value');		} else {			self.each(function() {				if (_hasVal(this)) {					this.value = val;				} else {					_setAttr(this, 'value' , val);				}			});			return self;		}	},	css : function(key, val) {		var self = this;		if (key === undefined) {			return _getCssList(self.attr('style'));		}		if (typeof key === 'object') {			_each(key, function(k, v) {				self.css(k, v);			});			return self;		}		if (val === undefined) {			if (self.length < 1) {				return '';			}			return self[0].style[_toCamel(key)] || _computedCss(self[0], key) || '';		}		self.each(function() {			this.style[_toCamel(key)] = val;		});		return self;	},	width : function(val) {		var self = this;		if (val === undefined) {			if (self.length < 1) {				return 0;			}			return self[0].offsetWidth;		}		return self.css('width', _addUnit(val));	},	height : function(val) {		var self = this;		if (val === undefined) {			if (self.length < 1) {				return 0;			}			return self[0].offsetHeight;		}		return self.css('height', _addUnit(val));	},	opacity : function(val) {		this.each(function() {			if (this.style.opacity === undefined) {				this.style.filter = val == 1 ? '' : 'alpha(opacity=' + (val * 100) + ')';			} else {				this.style.opacity = val == 1 ? '' : val;			}		});		return this;	},	data : function(key, val) {		var self = this;		key = 'kindeditor_data_' + key;		if (val === undefined) {			if (self.length < 1) {				return null;			}			return self[0][key];		}		this.each(function() {			this[key] = val;		});		return self;	},	pos : function() {		var self = this, node = self[0], x = 0, y = 0;		if (node) {			if (node.getBoundingClientRect) {				var box = node.getBoundingClientRect(),					pos = _getScrollPos(self.doc);				x = box.left + pos.x;				y = box.top + pos.y;			} else {				while (node) {					x += node.offsetLeft;					y += node.offsetTop;					node = node.offsetParent;				}			}		}		return {x : _round(x), y : _round(y)};	},	clone : function(bool) {		if (this.length < 1) {			return new KNode([]);		}		return new KNode(this[0].cloneNode(bool));	},	append : function(expr) {		this.each(function() {			if (this.appendChild) {				this.appendChild(_get(expr));			}		});		return this;	},	appendTo : function(expr) {		this.each(function() {			_get(expr).appendChild(this);		});		return this;	},	before : function(expr) {		this.each(function() {			this.parentNode.insertBefore(_get(expr), this);		});		return this;	},	after : function(expr) {		this.each(function() {			if (this.nextSibling) {				this.parentNode.insertBefore(_get(expr), this.nextSibling);			} else {				this.parentNode.appendChild(_get(expr));			}		});		return this;	},	replaceWith : function(expr) {		var nodes = [];		this.each(function(i, node) {			_unbind(node);			var newNode = _get(expr);			node.parentNode.replaceChild(newNode, node);			nodes.push(newNode);		});		return K(nodes);	},	empty : function() {		var self = this;		self.each(function(i, node) {			var child = node.firstChild;			while (child) {				if (!node.parentNode) {					return;				}				var next = child.nextSibling;				child.parentNode.removeChild(child);				child = next;			}		});		return self;	},	remove : function(keepChilds) {		var self = this;		self.each(function(i, node) {			if (!node.parentNode) {				return;			}			_unbind(node);			if (keepChilds) {				var child = node.firstChild;				while (child) {					var next = child.nextSibling;					node.parentNode.insertBefore(child, node);					child = next;				}			}			node.parentNode.removeChild(node);			delete self[i];		});		self.length = 0;		return self;	},	show : function(val) {		var self = this;		if (val === undefined) {			val = self._originDisplay || '';		}		if (self.css('display') != 'none') {			return self;		}		return self.css('display', val);	},	hide : function() {		var self = this;		if (self.length < 1) {			return self;		}		self._originDisplay = self[0].style.display;		return self.css('display', 'none');	},	outer : function() {		var self = this;		if (self.length < 1) {			return '';		}		var div = self.doc.createElement('div'), html;		div.appendChild(self[0].cloneNode(true));		html = _formatHtml(div.innerHTML);		div = null;		return html;	},	isSingle : function() {		return !!_SINGLE_TAG_MAP[this.name];	},	isInline : function() {		return !!_INLINE_TAG_MAP[this.name];	},	isBlock : function() {		return !!_BLOCK_TAG_MAP[this.name];	},	isStyle : function() {		return !!_STYLE_TAG_MAP[this.name];	},	isControl : function() {		return !!_CONTROL_TAG_MAP[this.name];	},	contains : function(otherNode) {		if (this.length < 1) {			return false;		}		return _contains(this[0], _get(otherNode));	},	parent : function() {		if (this.length < 1) {			return null;		}		var node = this[0].parentNode;		return node ? new KNode(node) : null;	},	children : function() {		if (this.length < 1) {			return new KNode([]);		}		var list = [], child = this[0].firstChild;		while (child) {			if (child.nodeType != 3 || _trim(child.nodeValue) !== '') {				list.push(child);			}			child = child.nextSibling;		}		return new KNode(list);	},	first : function() {		var list = this.children();		return list.length > 0 ? list.eq(0) : null;	},	last : function() {		var list = this.children();		return list.length > 0 ? list.eq(list.length - 1) : null;	},	index : function() {		if (this.length < 1) {			return -1;		}		var i = -1, sibling = this[0];		while (sibling) {			i++;			sibling = sibling.previousSibling;		}		return i;	},	prev : function() {		if (this.length < 1) {			return null;		}		var node = this[0].previousSibling;		return node ? new KNode(node) : null;	},	next : function() {		if (this.length < 1) {			return null;		}		var node = this[0].nextSibling;		return node ? new KNode(node) : null;	},	scan : function(fn, order) {		if (this.length < 1) {			return;		}		order = (order === undefined) ? true : order;		function walk(node) {			var n = order ? node.firstChild : node.lastChild;			while (n) {				var next = order ? n.nextSibling : n.previousSibling;				if (fn(n) === false) {					return false;				}				if (walk(n) === false) {					return false;				}				n = next;			}		}		walk(this[0]);		return this;	}});_each(('blur,focus,focusin,focusout,load,resize,scroll,unload,click,dblclick,' +	'mousedown,mouseup,mousemove,mouseover,mouseout,mouseenter,mouseleave,' +	'change,select,submit,keydown,keypress,keyup,error,contextmenu').split(','), function(i, type) {	KNode.prototype[type] = function(fn) {		return fn ? this.bind(type, fn) : this.fire(type);	};});var _K = K;K = function(expr, root) {	if (expr === undefined || expr === null) {		return;	}	function newNode(node) {		if (!node[0]) {			node = [];		}		return new KNode(node);	}	if (typeof expr === 'string') {		if (root) {			root = _get(root);		}		var length = expr.length;		if (expr.charAt(0) === '@') {			expr = expr.substr(1);		}		if (expr.length !== length || /<.+>/.test(expr)) {			var doc = root ? root.ownerDocument || root : document,				div = doc.createElement('div'), list = [];			div.innerHTML = '<img id="__kindeditor_temp_tag__" width="0" height="0" style="display:none;" />' + expr;			for (var i = 0, len = div.childNodes.length; i < len; i++) {				var child = div.childNodes[i];				if (child.id == '__kindeditor_temp_tag__') {					continue;				}				list.push(child);			}			return newNode(list);		}		return newNode(_queryAll(expr, root));	}	if (expr && expr.constructor === KNode) {		return expr;	}	if (expr.toArray) {		expr = expr.toArray();	}	if (_isArray(expr)) {		return newNode(expr);	}	return newNode(_toArray(arguments));};_each(_K, function(key, val) {	K[key] = val;});K.NodeClass = KNode;window.KindEditor = K;var _START_TO_START = 0,	_START_TO_END = 1,	_END_TO_END = 2,	_END_TO_START = 3,	_BOOKMARK_ID = 0;function _updateCollapsed(range) {	range.collapsed = (range.startContainer === range.endContainer && range.startOffset === range.endOffset);	return range;}function _copyAndDelete(range, isCopy, isDelete) {	var doc = range.doc, nodeList = [];	function splitTextNode(node, startOffset, endOffset) {		var length = node.nodeValue.length, centerNode;		if (isCopy) {			var cloneNode = node.cloneNode(true);			if (startOffset > 0) {				centerNode = cloneNode.splitText(startOffset);			} else {				centerNode = cloneNode;			}			if (endOffset < length) {				centerNode.splitText(endOffset - startOffset);			}		}		if (isDelete) {			var center = node;			if (startOffset > 0) {				center = node.splitText(startOffset);				range.setStart(node, startOffset);			}			if (endOffset < length) {				var right = center.splitText(endOffset - startOffset);				range.setEnd(right, 0);			}			nodeList.push(center);		}		return centerNode;	}	function removeNodes() {		if (isDelete) {			range.up().collapse(true);		}		for (var i = 0, len = nodeList.length; i < len; i++) {			var node = nodeList[i];			if (node.parentNode) {				node.parentNode.removeChild(node);			}		}	}	var copyRange = range.cloneRange().down();	var start = -1, incStart = -1, incEnd = -1, end = -1,		ancestor = range.commonAncestor(), frag = doc.createDocumentFragment();	if (ancestor.nodeType == 3) {		var textNode = splitTextNode(ancestor, range.startOffset, range.endOffset);		if (isCopy) {			frag.appendChild(textNode);		}		removeNodes();		return isCopy ? frag : range;	}	function extractNodes(parent, frag) {		var node = parent.firstChild, nextNode;		while (node) {			var testRange = new KRange(doc).selectNode(node);			start = testRange.compareBoundaryPoints(_START_TO_END, range);			if (start >= 0 && incStart <= 0) {				incStart = testRange.compareBoundaryPoints(_START_TO_START, range);			}			if (incStart >= 0 && incEnd <= 0) {				incEnd = testRange.compareBoundaryPoints(_END_TO_END, range);			}			if (incEnd >= 0 && end <= 0) {				end = testRange.compareBoundaryPoints(_END_TO_START, range);			}			if (end >= 0) {				return false;			}			nextNode = node.nextSibling;			if (start > 0) {				if (node.nodeType == 1) {					if (incStart >= 0 && incEnd <= 0) {						if (isCopy) {							frag.appendChild(node.cloneNode(true));						}						if (isDelete) {							nodeList.push(node);						}					} else {						var childFlag;						if (isCopy) {							childFlag = node.cloneNode(false);							frag.appendChild(childFlag);						}						if (extractNodes(node, childFlag) === false) {							return false;						}					}				} else if (node.nodeType == 3) {					var textNode;					if (node == copyRange.startContainer) {						textNode = splitTextNode(node, copyRange.startOffset, node.nodeValue.length);					} else if (node == copyRange.endContainer) {						textNode = splitTextNode(node, 0, copyRange.endOffset);					} else {						textNode = splitTextNode(node, 0, node.nodeValue.length);					}					if (isCopy) {						try {							frag.appendChild(textNode);						} catch(e) {}					}				}			}			node = nextNode;		}	}	extractNodes(ancestor, frag);	if (isDelete) {		range.up().collapse(true);	}	for (var i = 0, len = nodeList.length; i < len; i++) {		var node = nodeList[i];		if (node.parentNode) {			node.parentNode.removeChild(node);		}	}	return isCopy ? frag : range;}function _moveToElementText(range, el) {	var node = el;	while (node) {		var knode = K(node);		if (knode.name == 'marquee' || knode.name == 'select') {			return;		}		node = node.parentNode;	}	try {		range.moveToElementText(el);	} catch(e) {}}function _getStartEnd(rng, isStart) {	var doc = rng.parentElement().ownerDocument,		pointRange = rng.duplicate();	pointRange.collapse(isStart);	var parent = pointRange.parentElement(),		nodes = parent.childNodes;	if (nodes.length === 0) {		return {node: parent.parentNode, offset: K(parent).index()};	}	var startNode = doc, startPos = 0, cmp = -1;	var testRange = rng.duplicate();	_moveToElementText(testRange, parent);	for (var i = 0, len = nodes.length; i < len; i++) {		var node = nodes[i];		cmp = testRange.compareEndPoints('StartToStart', pointRange);		if (cmp === 0) {			return {node: node.parentNode, offset: i};		}		if (node.nodeType == 1) {			var nodeRange = rng.duplicate(), dummy, knode = K(node), newNode = node;			if (knode.isControl()) {				dummy = doc.createElement('span');				knode.after(dummy);				newNode = dummy;				startPos += knode.text().replace(/\r\n|\n|\r/g, '').length;			}			_moveToElementText(nodeRange, newNode);			testRange.setEndPoint('StartToEnd', nodeRange);			if (cmp > 0) {				startPos += nodeRange.text.replace(/\r\n|\n|\r/g, '').length;			} else {				startPos = 0;			}			if (dummy) {				K(dummy).remove();			}		} else if (node.nodeType == 3) {			testRange.moveStart('character', node.nodeValue.length);			startPos += node.nodeValue.length;		}		if (cmp < 0) {			startNode = node;		}	}	if (cmp < 0 && startNode.nodeType == 1) {		return {node: parent, offset: K(parent.lastChild).index() + 1};	}	if (cmp > 0) {		while (startNode.nextSibling && startNode.nodeType == 1) {			startNode = startNode.nextSibling;		}	}	testRange = rng.duplicate();	_moveToElementText(testRange, parent);	testRange.setEndPoint('StartToEnd', pointRange);	startPos -= testRange.text.replace(/\r\n|\n|\r/g, '').length;	if (cmp > 0 && startNode.nodeType == 3) {		var prevNode = startNode.previousSibling;		while (prevNode && prevNode.nodeType == 3) {			startPos -= prevNode.nodeValue.length;			prevNode = prevNode.previousSibling;		}	}	return {node: startNode, offset: startPos};}function _getEndRange(node, offset) {	var doc = node.ownerDocument || node,		range = doc.body.createTextRange();	if (doc == node) {		range.collapse(true);		return range;	}	if (node.nodeType == 1 && node.childNodes.length > 0) {		var children = node.childNodes, isStart, child;		if (offset === 0) {			child = children[0];			isStart = true;		} else {			child = children[offset - 1];			isStart = false;		}		if (!child) {			return range;		}		if (K(child).name === 'head') {			if (offset === 1) {				isStart = true;			}			if (offset === 2) {				isStart = false;			}			range.collapse(isStart);			return range;		}		if (child.nodeType == 1) {			var kchild = K(child), span;			if (kchild.isControl()) {				span = doc.createElement('span');				if (isStart) {					kchild.before(span);				} else {					kchild.after(span);				}				child = span;			}			_moveToElementText(range, child);			range.collapse(isStart);			if (span) {				K(span).remove();			}			return range;		}		node = child;		offset = isStart ? 0 : child.nodeValue.length;	}	var dummy = doc.createElement('span');	K(node).before(dummy);	_moveToElementText(range, dummy);	range.moveStart('character', offset);	K(dummy).remove();	return range;}function _toRange(rng) {	var doc, range;	function tr2td(start) {		if (K(start.node).name == 'tr') {			start.node = start.node.cells[start.offset];			start.offset = 0;		}	}	if (_IERANGE) {		if (rng.item) {			doc = _getDoc(rng.item(0));			range = new KRange(doc);			range.selectNode(rng.item(0));			return range;		}		doc = rng.parentElement().ownerDocument;		var start = _getStartEnd(rng, true),			end = _getStartEnd(rng, false);		tr2td(start);		tr2td(end);		range = new KRange(doc);		range.setStart(start.node, start.offset);		range.setEnd(end.node, end.offset);		return range;	}	var startContainer = rng.startContainer;	doc = startContainer.ownerDocument || startContainer;	range = new KRange(doc);	range.setStart(startContainer, rng.startOffset);	range.setEnd(rng.endContainer, rng.endOffset);	return range;}function KRange(doc) {	this.init(doc);}_extend(KRange, {	init : function(doc) {		var self = this;		self.startContainer = doc;		self.startOffset = 0;		self.endContainer = doc;		self.endOffset = 0;		self.collapsed = true;		self.doc = doc;	},	commonAncestor : function() {		function getParents(node) {			var parents = [];			while (node) {				parents.push(node);				node = node.parentNode;			}			return parents;		}		var parentsA = getParents(this.startContainer),			parentsB = getParents(this.endContainer),			i = 0, lenA = parentsA.length, lenB = parentsB.length, parentA, parentB;		while (++i) {			parentA = parentsA[lenA - i];			parentB = parentsB[lenB - i];			if (!parentA || !parentB || parentA !== parentB) {				break;			}		}		return parentsA[lenA - i + 1];	},	setStart : function(node, offset) {		var self = this, doc = self.doc;		self.startContainer = node;		self.startOffset = offset;		if (self.endContainer === doc) {			self.endContainer = node;			self.endOffset = offset;		}		return _updateCollapsed(this);	},	setEnd : function(node, offset) {		var self = this, doc = self.doc;		self.endContainer = node;		self.endOffset = offset;		if (self.startContainer === doc) {			self.startContainer = node;			self.startOffset = offset;		}		return _updateCollapsed(this);	},	setStartBefore : function(node) {		return this.setStart(node.parentNode || this.doc, K(node).index());	},	setStartAfter : function(node) {		return this.setStart(node.parentNode || this.doc, K(node).index() + 1);	},	setEndBefore : function(node) {		return this.setEnd(node.parentNode || this.doc, K(node).index());	},	setEndAfter : function(node) {		return this.setEnd(node.parentNode || this.doc, K(node).index() + 1);	},	selectNode : function(node) {		return this.setStartBefore(node).setEndAfter(node);	},	selectNodeContents : function(node) {		var knode = K(node);		if (knode.type == 3 || knode.isSingle()) {			return this.selectNode(node);		}		var children = knode.children();		if (children.length > 0) {			return this.setStartBefore(children[0]).setEndAfter(children[children.length - 1]);		}		return this.setStart(node, 0).setEnd(node, 0);	},	collapse : function(toStart) {		if (toStart) {			return this.setEnd(this.startContainer, this.startOffset);		}		return this.setStart(this.endContainer, this.endOffset);	},	compareBoundaryPoints : function(how, range) {		var rangeA = this.get(), rangeB = range.get();		if (_IERANGE) {			var arr = {};			arr[_START_TO_START] = 'StartToStart';			arr[_START_TO_END] = 'EndToStart';			arr[_END_TO_END] = 'EndToEnd';			arr[_END_TO_START] = 'StartToEnd';			var cmp = rangeA.compareEndPoints(arr[how], rangeB);			if (cmp !== 0) {				return cmp;			}			var nodeA, nodeB, nodeC, posA, posB;			if (how === _START_TO_START || how === _END_TO_START) {				nodeA = this.startContainer;				posA = this.startOffset;			}			if (how === _START_TO_END || how === _END_TO_END) {				nodeA = this.endContainer;				posA = this.endOffset;			}			if (how === _START_TO_START || how === _START_TO_END) {				nodeB = range.startContainer;				posB = range.startOffset;			}			if (how === _END_TO_END || how === _END_TO_START) {				nodeB = range.endContainer;				posB = range.endOffset;			}			if (nodeA === nodeB) {				var diff = posA - posB;				return diff > 0 ? 1 : (diff < 0 ? -1 : 0);			}			nodeC = nodeB;			while (nodeC && nodeC.parentNode !== nodeA) {				nodeC = nodeC.parentNode;			}			if (nodeC) {				return K(nodeC).index() >= posA ? -1 : 1;			}			nodeC = nodeA;			while (nodeC && nodeC.parentNode !== nodeB) {				nodeC = nodeC.parentNode;			}			if (nodeC) {				return K(nodeC).index() >= posB ? 1 : -1;			}			nodeC = K(nodeB).next();			if (nodeC && nodeC.contains(nodeA)) {				return 1;			}			nodeC = K(nodeA).next();			if (nodeC && nodeC.contains(nodeB)) {				return -1;			}		} else {			return rangeA.compareBoundaryPoints(how, rangeB);		}	},	cloneRange : function() {		return new KRange(this.doc).setStart(this.startContainer, this.startOffset).setEnd(this.endContainer, this.endOffset);	},	toString : function() {		var rng = this.get(), str = _IERANGE ? rng.text : rng.toString();		return str.replace(/\r\n|\n|\r/g, '');	},	cloneContents : function() {		return _copyAndDelete(this, true, false);	},	deleteContents : function() {		return _copyAndDelete(this, false, true);	},	extractContents : function() {		return _copyAndDelete(this, true, true);	},	insertNode : function(node) {		var self = this,			sc = self.startContainer, so = self.startOffset,			ec = self.endContainer, eo = self.endOffset,			firstChild, lastChild, c, nodeCount = 1;		if (node.nodeName.toLowerCase() === '#document-fragment') {			firstChild = node.firstChild;			lastChild = node.lastChild;			nodeCount = node.childNodes.length;		}		if (sc.nodeType == 1) {			c = sc.childNodes[so];			if (c) {				sc.insertBefore(node, c);				if (sc === ec) {					eo += nodeCount;				}			} else {				sc.appendChild(node);			}		} else if (sc.nodeType == 3) {			if (so === 0) {				sc.parentNode.insertBefore(node, sc);				if (sc.parentNode === ec) {					eo += nodeCount;				}			} else if (so >= sc.nodeValue.length) {				if (sc.nextSibling) {					sc.parentNode.insertBefore(node, sc.nextSibling);				} else {					sc.parentNode.appendChild(node);				}			} else {				if (so > 0) {					c = sc.splitText(so);				} else {					c = sc;				}				sc.parentNode.insertBefore(node, c);				if (sc === ec) {					ec = c;					eo -= so;				}			}		}		if (firstChild) {			self.setStartBefore(firstChild).setEndAfter(lastChild);		} else {			self.selectNode(node);		}		if (self.compareBoundaryPoints(_END_TO_END, self.cloneRange().setEnd(ec, eo)) >= 1) {			return self;		}		return self.setEnd(ec, eo);	},	surroundContents : function(node) {		node.appendChild(this.extractContents());		return this.insertNode(node).selectNode(node);	},	isControl : function() {		var self = this,			sc = self.startContainer, so = self.startOffset,			ec = self.endContainer, eo = self.endOffset, rng;		return sc.nodeType == 1 && sc === ec && so + 1 === eo && K(sc.childNodes[so]).isControl();	},	get : function(hasControlRange) {		var self = this, doc = self.doc, node, rng;		if (!_IERANGE) {			rng = doc.createRange();			try {				rng.setStart(self.startContainer, self.startOffset);				rng.setEnd(self.endContainer, self.endOffset);			} catch (e) {}			return rng;		}		if (hasControlRange && self.isControl()) {			rng = doc.body.createControlRange();			rng.addElement(self.startContainer.childNodes[self.startOffset]);			return rng;		}		var range = self.cloneRange().down();		rng = doc.body.createTextRange();		rng.setEndPoint('StartToStart', _getEndRange(range.startContainer, range.startOffset));		rng.setEndPoint('EndToStart', _getEndRange(range.endContainer, range.endOffset));		return rng;	},	html : function() {		return K(this.cloneContents()).outer();	},	down : function() {		var self = this;		function downPos(node, pos, isStart) {			if (node.nodeType != 1) {				return;			}			var children = K(node).children();			if (children.length === 0) {				return;			}			var left, right, child, offset;			if (pos > 0) {				left = children.eq(pos - 1);			}			if (pos < children.length) {				right = children.eq(pos);			}			if (left && left.type == 3) {				child = left[0];				offset = child.nodeValue.length;			}			if (right && right.type == 3) {				child = right[0];				offset = 0;			}			if (!child) {				return;			}			if (isStart) {				self.setStart(child, offset);			} else {				self.setEnd(child, offset);			}		}		downPos(self.startContainer, self.startOffset, true);		downPos(self.endContainer, self.endOffset, false);		return self;	},	up : function() {		var self = this;		function upPos(node, pos, isStart) {			if (node.nodeType != 3) {				return;			}			if (pos === 0) {				if (isStart) {					self.setStartBefore(node);				} else {					self.setEndBefore(node);				}			} else if (pos == node.nodeValue.length) {				if (isStart) {					self.setStartAfter(node);				} else {					self.setEndAfter(node);				}			}		}		upPos(self.startContainer, self.startOffset, true);		upPos(self.endContainer, self.endOffset, false);		return self;	},	enlarge : function(toBlock) {		var self = this;		self.up();		function enlargePos(node, pos, isStart) {			var knode = K(node), parent;			if (knode.type == 3 || _NOSPLIT_TAG_MAP[knode.name] || !toBlock && knode.isBlock()) {				return;			}			if (pos === 0) {				while (!knode.prev()) {					parent = knode.parent();					if (!parent || _NOSPLIT_TAG_MAP[parent.name] || !toBlock && parent.isBlock()) {						break;					}					knode = parent;				}				if (isStart) {					self.setStartBefore(knode[0]);				} else {					self.setEndBefore(knode[0]);				}			} else if (pos == knode.children().length) {				while (!knode.next()) {					parent = knode.parent();					if (!parent || _NOSPLIT_TAG_MAP[parent.name] || !toBlock && parent.isBlock()) {						break;					}					knode = parent;				}				if (isStart) {					self.setStartAfter(knode[0]);				} else {					self.setEndAfter(knode[0]);				}			}		}		enlargePos(self.startContainer, self.startOffset, true);		enlargePos(self.endContainer, self.endOffset, false);		return self;	},	shrink : function() {		var self = this, child, collapsed = self.collapsed;		while (self.startContainer.nodeType == 1 && (child = self.startContainer.childNodes[self.startOffset]) && child.nodeType == 1 && !K(child).isSingle()) {			self.setStart(child, 0);		}		if (collapsed) {			return self.collapse(collapsed);		}		while (self.endContainer.nodeType == 1 && self.endOffset > 0 && (child = self.endContainer.childNodes[self.endOffset - 1]) && child.nodeType == 1 && !K(child).isSingle()) {			self.setEnd(child, child.childNodes.length);		}		return self;	},	createBookmark : function(serialize) {		var self = this, doc = self.doc, endNode,			startNode = K('<span style="display:none;"></span>', doc)[0];		startNode.id = '__kindeditor_bookmark_start_' + (_BOOKMARK_ID++) + '__';		if (!self.collapsed) {			endNode = startNode.cloneNode(true);			endNode.id = '__kindeditor_bookmark_end_' + (_BOOKMARK_ID++) + '__';		}		if (endNode) {			self.cloneRange().collapse(false).insertNode(endNode).setEndBefore(endNode);		}		self.insertNode(startNode).setStartAfter(startNode);		return {			start : serialize ? '#' + startNode.id : startNode,			end : endNode ? (serialize ? '#' + endNode.id : endNode) : null		};	},	moveToBookmark : function(bookmark) {		var self = this, doc = self.doc,			start = K(bookmark.start, doc), end = bookmark.end ? K(bookmark.end, doc) : null;		if (!start || start.length < 1) {			return self;		}		self.setStartBefore(start[0]);		start.remove();		if (end && end.length > 0) {			self.setEndBefore(end[0]);			end.remove();		} else {			self.collapse(true);		}		return self;	},	dump : function() {		console.log('--------------------');		console.log(this.startContainer.nodeType == 3 ? this.startContainer.nodeValue : this.startContainer, this.startOffset);		console.log(this.endContainer.nodeType == 3 ? this.endContainer.nodeValue : this.endContainer, this.endOffset);	}});function _range(mixed) {	if (!mixed.nodeName) {		return mixed.constructor === KRange ? mixed : _toRange(mixed);	}	return new KRange(mixed);}K.RangeClass = KRange;K.range = _range;K.START_TO_START = _START_TO_START;K.START_TO_END = _START_TO_END;K.END_TO_END = _END_TO_END;K.END_TO_START = _END_TO_START;function _nativeCommand(doc, key, val) {	try {		doc.execCommand(key, false, val);	} catch(e) {}}function _nativeCommandValue(doc, key) {	var val = '';	try {		val = doc.queryCommandValue(key);	} catch (e) {}	if (typeof val !== 'string') {		val = '';	}	return val;}function _getSel(doc) {	var win = _getWin(doc);	return _IERANGE ? doc.selection : win.getSelection();}function _getRng(doc) {	var sel = _getSel(doc), rng;	try {		if (sel.rangeCount > 0) {			rng = sel.getRangeAt(0);		} else {			rng = sel.createRange();		}	} catch(e) {}	if (_IERANGE && (!rng || (!rng.item && rng.parentElement().ownerDocument !== doc))) {		return null;	}	return rng;}function _singleKeyMap(map) {	var newMap = {}, arr, v;	_each(map, function(key, val) {		arr = key.split(',');		for (var i = 0, len = arr.length; i < len; i++) {			v = arr[i];			newMap[v] = val;		}	});	return newMap;}function _hasAttrOrCss(knode, map) {	return _hasAttrOrCssByKey(knode, map, '*') || _hasAttrOrCssByKey(knode, map);}function _hasAttrOrCssByKey(knode, map, mapKey) {	mapKey = mapKey || knode.name;	if (knode.type !== 1) {		return false;	}	var newMap = _singleKeyMap(map);	if (!newMap[mapKey]) {		return false;	}	var arr = newMap[mapKey].split(',');	for (var i = 0, len = arr.length; i < len; i++) {		var key = arr[i];		if (key === '*') {			return true;		}		var match = /^(\.?)([^=]+)(?:=([^=]*))?$/.exec(key);		var method = match[1] ? 'css' : 'attr';		key = match[2];		var val = match[3] || '';		if (val === '' && knode[method](key) !== '') {			return true;		}		if (val !== '' && knode[method](key) === val) {			return true;		}	}	return false;}function _removeAttrOrCss(knode, map) {	if (knode.type != 1) {		return;	}	_removeAttrOrCssByKey(knode, map, '*');	_removeAttrOrCssByKey(knode, map);}function _removeAttrOrCssByKey(knode, map, mapKey) {	mapKey = mapKey || knode.name;	if (knode.type !== 1) {		return;	}	var newMap = _singleKeyMap(map);	if (!newMap[mapKey]) {		return;	}	var arr = newMap[mapKey].split(','), allFlag = false;	for (var i = 0, len = arr.length; i < len; i++) {		var key = arr[i];		if (key === '*') {			allFlag = true;			break;		}		var match = /^(\.?)([^=]+)(?:=([^=]*))?$/.exec(key);		key = match[2];		if (match[1]) {			key = _toCamel(key);			if (knode[0].style[key]) {				knode[0].style[key] = '';			}		} else {			knode.removeAttr(key);		}	}	if (allFlag) {		knode.remove(true);	}}function _getInnerNode(knode) {	var inner = knode;	while (inner.first()) {		inner = inner.first();	}	return inner;}function _isEmptyNode(knode) {	if (knode.type != 1 || knode.isSingle()) {		return false;	}	return knode.html().replace(/<[^>]+>/g, '') === '';}function _mergeWrapper(a, b) {	a = a.clone(true);	var lastA = _getInnerNode(a), childA = a, merged = false;	while (b) {		while (childA) {			if (childA.name === b.name) {				_mergeAttrs(childA, b.attr(), b.css());				merged = true;			}			childA = childA.first();		}		if (!merged) {			lastA.append(b.clone(false));		}		merged = false;		b = b.first();	}	return a;}function _wrapNode(knode, wrapper) {	wrapper = wrapper.clone(true);	if (knode.type == 3) {		_getInnerNode(wrapper).append(knode.clone(false));		knode.replaceWith(wrapper);		return wrapper;	}	var nodeWrapper = knode, child;	while ((child = knode.first()) && child.children().length == 1) {		knode = child;	}	child = knode.first();	var frag = knode.doc.createDocumentFragment();	while (child) {		frag.appendChild(child[0]);		child = child.next();	}	wrapper = _mergeWrapper(nodeWrapper, wrapper);	if (frag.firstChild) {		_getInnerNode(wrapper).append(frag);	}	nodeWrapper.replaceWith(wrapper);	return wrapper;}function _mergeAttrs(knode, attrs, styles) {	_each(attrs, function(key, val) {		if (key !== 'style') {			knode.attr(key, val);		}	});	_each(styles, function(key, val) {		knode.css(key, val);	});}function _inPreElement(knode) {	while (knode && knode.name != 'body') {		if (_PRE_TAG_MAP[knode.name] || knode.name == 'div' && knode.hasClass('ke-script')) {			return true;		}		knode = knode.parent();	}	return false;}function KCmd(range) {	this.init(range);}_extend(KCmd, {	init : function(range) {		var self = this, doc = range.doc;		self.doc = doc;		self.win = _getWin(doc);		self.sel = _getSel(doc);		self.range = range;	},	selection : function(forceReset) {		var self = this, doc = self.doc, rng = _getRng(doc);		self.sel = _getSel(doc);		if (rng) {			self.range = _range(rng);			if (K(self.range.startContainer).name == 'html') {				self.range.selectNodeContents(doc.body).collapse(false);			}			return self;		}		if (forceReset) {			self.range.selectNodeContents(doc.body).collapse(false);		}		return self;	},	select : function(hasDummy) {		hasDummy = _undef(hasDummy, true);		var self = this, sel = self.sel, range = self.range.cloneRange().shrink(),			sc = range.startContainer, so = range.startOffset,			ec = range.endContainer, eo = range.endOffset,			doc = _getDoc(sc), win = self.win, rng, hasU200b = false;		if (hasDummy && sc.nodeType == 1 && range.collapsed) {			if (_IERANGE) {				var dummy = K('<span> </span>', doc);				range.insertNode(dummy[0]);				rng = doc.body.createTextRange();				try {					rng.moveToElementText(dummy[0]);				} catch(ex) {}				rng.collapse(false);				rng.select();				dummy.remove();				win.focus();				return self;			}			if (_WEBKIT) {				var children = sc.childNodes;				if (K(sc).isInline() || so > 0 && K(children[so - 1]).isInline() || children[so] && K(children[so]).isInline()) {					range.insertNode(doc.createTextNode('\u200B'));					hasU200b = true;				}			}		}		if (_IERANGE) {			try {				rng = range.get(true);				rng.select();			} catch(e) {}		} else {			if (hasU200b) {				range.collapse(false);			}			rng = range.get(true);			sel.removeAllRanges();			sel.addRange(rng);			if (doc !== document) {				var pos = K(rng.endContainer).pos();				win.scrollTo(pos.x, pos.y);			}		}		win.focus();		return self;	},	wrap : function(val) {		var self = this, doc = self.doc, range = self.range, wrapper;		wrapper = K(val, doc);		if (range.collapsed) {			range.shrink();			range.insertNode(wrapper[0]).selectNodeContents(wrapper[0]);			return self;		}		if (wrapper.isBlock()) {			var copyWrapper = wrapper.clone(true), child = copyWrapper;			while (child.first()) {				child = child.first();			}			child.append(range.extractContents());			range.insertNode(copyWrapper[0]).selectNode(copyWrapper[0]);			return self;		}		range.enlarge();		var bookmark = range.createBookmark(), ancestor = range.commonAncestor(), isStart = false;		K(ancestor).scan(function(node) {			if (!isStart && node == bookmark.start) {				isStart = true;				return;			}			if (isStart) {				if (node == bookmark.end) {					return false;				}				var knode = K(node);				if (_inPreElement(knode)) {					return;				}				if (knode.type == 3 && _trim(node.nodeValue).length > 0) {					var parent;					while ((parent = knode.parent()) && parent.isStyle() && parent.children().length == 1) {						knode = parent;					}					_wrapNode(knode, wrapper);				}			}		});		range.moveToBookmark(bookmark);		return self;	},	split : function(isStart, map) {		var range = this.range, doc = range.doc;		var tempRange = range.cloneRange().collapse(isStart);		var node = tempRange.startContainer, pos = tempRange.startOffset,			parent = node.nodeType == 3 ? node.parentNode : node,			needSplit = false, knode;		while (parent && parent.parentNode) {			knode = K(parent);			if (map) {				if (!knode.isStyle()) {					break;				}				if (!_hasAttrOrCss(knode, map)) {					break;				}			} else {				if (_NOSPLIT_TAG_MAP[knode.name]) {					break;				}			}			needSplit = true;			parent = parent.parentNode;		}		if (needSplit) {			var dummy = doc.createElement('span');			range.cloneRange().collapse(!isStart).insertNode(dummy);			if (isStart) {				tempRange.setStartBefore(parent.firstChild).setEnd(node, pos);			} else {				tempRange.setStart(node, pos).setEndAfter(parent.lastChild);			}			var frag = tempRange.extractContents(),				first = frag.firstChild, last = frag.lastChild;			if (isStart) {				tempRange.insertNode(frag);				range.setStartAfter(last).setEndBefore(dummy);			} else {				parent.appendChild(frag);				range.setStartBefore(dummy).setEndBefore(first);			}			var dummyParent = dummy.parentNode;			if (dummyParent == range.endContainer) {				var prev = K(dummy).prev(), next = K(dummy).next();				if (prev && next && prev.type == 3 && next.type == 3) {					range.setEnd(prev[0], prev[0].nodeValue.length);				} else if (!isStart) {					range.setEnd(range.endContainer, range.endOffset - 1);				}			}			dummyParent.removeChild(dummy);		}		return this;	},	remove : function(map) {		var self = this, doc = self.doc, range = self.range;		range.enlarge();		if (range.startOffset === 0) {			var ksc = K(range.startContainer), parent;			while ((parent = ksc.parent()) && parent.isStyle() && parent.children().length == 1) {				ksc = parent;			}			range.setStart(ksc[0], 0);			ksc = K(range.startContainer);			if (ksc.isBlock()) {				_removeAttrOrCss(ksc, map);			}			var kscp = ksc.parent();			if (kscp && kscp.isBlock()) {				_removeAttrOrCss(kscp, map);			}		}		var sc, so;		if (range.collapsed) {			self.split(true, map);			sc = range.startContainer;			so = range.startOffset;			if (so > 0) {				var sb = K(sc.childNodes[so - 1]);				if (sb && _isEmptyNode(sb)) {					sb.remove();					range.setStart(sc, so - 1);				}			}			var sa = K(sc.childNodes[so]);			if (sa && _isEmptyNode(sa)) {				sa.remove();			}			if (_isEmptyNode(sc)) {				range.startBefore(sc);				sc.remove();			}			range.collapse(true);			return self;		}		self.split(true, map);		self.split(false, map);		var startDummy = doc.createElement('span'), endDummy = doc.createElement('span');		range.cloneRange().collapse(false).insertNode(endDummy);		range.cloneRange().collapse(true).insertNode(startDummy);		var nodeList = [], cmpStart = false;		K(range.commonAncestor()).scan(function(node) {			if (!cmpStart && node == startDummy) {				cmpStart = true;				return;			}			if (node == endDummy) {				return false;			}			if (cmpStart) {				nodeList.push(node);			}		});		K(startDummy).remove();		K(endDummy).remove();		sc = range.startContainer;		so = range.startOffset;		var ec = range.endContainer, eo = range.endOffset;		if (so > 0) {			var startBefore = K(sc.childNodes[so - 1]);			if (startBefore && _isEmptyNode(startBefore)) {				startBefore.remove();				range.setStart(sc, so - 1);				if (sc == ec) {					range.setEnd(ec, eo - 1);				}			}			var startAfter = K(sc.childNodes[so]);			if (startAfter && _isEmptyNode(startAfter)) {				startAfter.remove();				if (sc == ec) {					range.setEnd(ec, eo - 1);				}			}		}		var endAfter = K(ec.childNodes[range.endOffset]);		if (endAfter && _isEmptyNode(endAfter)) {			endAfter.remove();		}		var bookmark = range.createBookmark(true);		_each(nodeList, function(i, node) {			_removeAttrOrCss(K(node), map);		});		range.moveToBookmark(bookmark);		return self;	},	commonNode : function(map) {		var range = this.range;		var ec = range.endContainer, eo = range.endOffset,			node = (ec.nodeType == 3 || eo === 0) ? ec : ec.childNodes[eo - 1];		function find(node) {			var child = node, parent = node;			while (parent) {				if (_hasAttrOrCss(K(parent), map)) {					return K(parent);				}				parent = parent.parentNode;			}			while (child && (child = child.lastChild)) {				if (_hasAttrOrCss(K(child), map)) {					return K(child);				}			}			return null;		}		var cNode = find(node);		if (cNode) {			return cNode;		}		if (node.nodeType == 1 || (ec.nodeType == 3 && eo === 0)) {			var prev = K(node).prev();			if (prev) {				return find(prev);			}		}		return null;	},	commonAncestor : function(tagName) {		var range = this.range,			sc = range.startContainer, so = range.startOffset,			ec = range.endContainer, eo = range.endOffset,			startNode = (sc.nodeType == 3 || so === 0) ? sc : sc.childNodes[so - 1],			endNode = (ec.nodeType == 3 || eo === 0) ? ec : ec.childNodes[eo - 1];		function find(node) {			while (node) {				if (node.nodeType == 1) {					if (node.tagName.toLowerCase() === tagName) {						return node;					}				}				node = node.parentNode;			}			return null;		}		var start = find(startNode), end = find(endNode);		if (start && end && start === end) {			return K(start);		}		return null;	},	state : function(key) {		var self = this, doc = self.doc, bool = false;		try {			bool = doc.queryCommandState(key);		} catch (e) {}		return bool;	},	val : function(key) {		var self = this, doc = self.doc, range = self.range;		function lc(val) {			return val.toLowerCase();		}		key = lc(key);		var val = '', knode;		if (key === 'fontfamily' || key === 'fontname') {			val = _nativeCommandValue(doc, 'fontname');			val = val.replace(/['"]/g, '');			return lc(val);		}		if (key === 'formatblock') {			val = _nativeCommandValue(doc, key);			if (val === '') {				knode = self.commonNode({'h1,h2,h3,h4,h5,h6,p,div,pre,address' : '*'});				if (knode) {					val = knode.name;				}			}			if (val === 'Normal') {				val = 'p';			}			return lc(val);		}		if (key === 'fontsize') {			knode = self.commonNode({'*' : '.font-size'});			if (knode) {				val = knode.css('font-size');			}			return lc(val);		}		if (key === 'forecolor') {			knode = self.commonNode({'*' : '.color'});			if (knode) {				val = knode.css('color');			}			val = _toHex(val);			if (val === '') {				val = 'default';			}			return lc(val);		}		if (key === 'hilitecolor') {			knode = self.commonNode({'*' : '.background-color'});			if (knode) {				val = knode.css('background-color');			}			val = _toHex(val);			if (val === '') {				val = 'default';			}			return lc(val);		}		return val;	},	toggle : function(wrapper, map) {		var self = this;		if (self.commonNode(map)) {			self.remove(map);		} else {			self.wrap(wrapper);		}		return self.select();	},	bold : function() {		return this.toggle('<strong></strong>', {			span : '.font-weight=bold',			strong : '*',			b : '*'		});	},	italic : function() {		return this.toggle('<em></em>', {			span : '.font-style=italic',			em : '*',			i : '*'		});	},	underline : function() {		return this.toggle('<u></u>', {			span : '.text-decoration=underline',			u : '*'		});	},	strikethrough : function() {		return this.toggle('<s></s>', {			span : '.text-decoration=line-through',			s : '*'		});	},	forecolor : function(val) {		return this.wrap('<span style="color:' + val + ';"></span>').select();	},	hilitecolor : function(val) {		return this.wrap('<span style="background-color:' + val + ';"></span>').select();	},	fontsize : function(val) {		return this.wrap('<span style="font-size:' + val + ';"></span>').select();	},	fontname : function(val) {		return this.fontfamily(val);	},	fontfamily : function(val) {		return this.wrap('<span style="font-family:' + val + ';"></span>').select();	},	removeformat : function() {		var map = {			'*' : '.font-weight,.font-style,.text-decoration,.color,.background-color,.font-size,.font-family,.text-indent'		},		tags = _STYLE_TAG_MAP;		_each(tags, function(key, val) {			map[key] = '*';		});		this.remove(map);		return this.select();	},	inserthtml : function(val, quickMode) {		var self = this, range = self.range;		if (val === '') {			return self;		}		function pasteHtml(range, val) {			val = '<img id="__kindeditor_temp_tag__" width="0" height="0" style="display:none;" />' + val;			var rng = range.get();			if (rng.item) {				rng.item(0).outerHTML = val;			} else {				rng.pasteHTML(val);			}			var temp = range.doc.getElementById('__kindeditor_temp_tag__');			temp.parentNode.removeChild(temp);			var newRange = _toRange(rng);			range.setEnd(newRange.endContainer, newRange.endOffset);			range.collapse(false);			self.select(false);		}		function insertHtml(range, val) {			var doc = range.doc,				frag = doc.createDocumentFragment();			K('@' + val, doc).each(function() {				frag.appendChild(this);			});			range.deleteContents();			range.insertNode(frag);			range.collapse(false);			self.select(false);		}		if (_IERANGE && quickMode) {			try {				pasteHtml(range, val);			} catch(e) {				insertHtml(range, val);			}			return self;		}		insertHtml(range, val);		return self;	},	hr : function() {		return this.inserthtml('<hr />');	},	print : function() {		this.win.print();		return this;	},	insertimage : function(url, title, width, height, border, align) {		title = _undef(title, '');		border = _undef(border, 0);		var html = '<img src="' + _escape(url) + '" data-ke-src="' + _escape(url) + '" ';		if (width) {			html += 'width="' + _escape(width) + '" ';		}		if (height) {			html += 'height="' + _escape(height) + '" ';		}		if (title) {			html += 'title="' + _escape(title) + '" ';		}		if (align) {			html += 'align="' + _escape(align) + '" ';		}		html += 'alt="' + _escape(title) + '" ';		html += '/>';		return this.inserthtml(html);	},	createlink : function(url, type) {		var self = this, doc = self.doc, range = self.range;		self.select();		var a = self.commonNode({ a : '*' });		if (a && !range.isControl()) {			range.selectNode(a.get());			self.select();		}		var html = '<a href="' + _escape(url) + '" data-ke-src="' + _escape(url) + '" ';		if (type) {			html += ' target="' + _escape(type) + '"';		}		if (range.collapsed) {			html += '>' + _escape(url) + '</a>';			return self.inserthtml(html);		}		if (range.isControl()) {			var node = K(range.startContainer.childNodes[range.startOffset]);			html += '></a>';			node.after(K(html, doc));			node.next().append(node);			range.selectNode(node[0]);			return self.select();		}		function setAttr(node, url, type) {			K(node).attr('href', url).attr('data-ke-src', url);			if (type) {				K(node).attr('target', type);			} else {				K(node).removeAttr('target');			}		}		var sc = range.startContainer, so = range.startOffset,			ec = range.endContainer, eo = range.endOffset;		if (sc.nodeType == 1 && sc === ec && so + 1 === eo) {			var child = sc.childNodes[so];			if (child.nodeName.toLowerCase() == 'a') {				setAttr(child, url, type);				return self;			}		}		_nativeCommand(doc, 'createlink', '__kindeditor_temp_url__');		K('a[href="__kindeditor_temp_url__"]', doc).each(function() {			setAttr(this, url, type);		});		return self;	},	unlink : function() {		var self = this, doc = self.doc, range = self.range;		self.select();		if (range.collapsed) {			var a = self.commonNode({ a : '*' });			if (a) {				range.selectNode(a.get());				self.select();			}			_nativeCommand(doc, 'unlink', null);			if (_WEBKIT && K(range.startContainer).name === 'img') {				var parent = K(range.startContainer).parent();				if (parent.name === 'a') {					parent.remove(true);				}			}		} else {			_nativeCommand(doc, 'unlink', null);		}		return self;	}});_each(('formatblock,selectall,justifyleft,justifycenter,justifyright,justifyfull,insertorderedlist,' +	'insertunorderedlist,indent,outdent,subscript,superscript').split(','), function(i, name) {	KCmd.prototype[name] = function(val) {		var self = this;		self.select();		_nativeCommand(self.doc, name, val);		if (_IERANGE && _inArray(name, 'justifyleft,justifycenter,justifyright,justifyfull'.split(',')) >= 0) {			self.selection();		}		if (!_IERANGE || _inArray(name, 'formatblock,selectall,insertorderedlist,insertunorderedlist'.split(',')) >= 0) {			self.selection();		}		return self;	};});_each('cut,copy,paste'.split(','), function(i, name) {	KCmd.prototype[name] = function() {		var self = this;		if (!self.doc.queryCommandSupported(name)) {			throw 'not supported';		}		self.select();		_nativeCommand(self.doc, name, null);		return self;	};});function _cmd(mixed) {	if (mixed.nodeName) {		var doc = _getDoc(mixed);		mixed = _range(doc).selectNodeContents(doc.body).collapse(false);	}	return new KCmd(mixed);}K.CmdClass = KCmd;K.cmd = _cmd;function _drag(options) {	var moveEl = options.moveEl,		moveFn = options.moveFn,		clickEl = options.clickEl || moveEl,		beforeDrag = options.beforeDrag,		iframeFix = options.iframeFix === undefined ? true : options.iframeFix;	var docs = [document];	if (iframeFix) {		K('iframe').each(function() {			var src = _formatUrl(this.src || '', 'absolute');			if (/^https?:\/\//.test(src)) {				return;			}			var doc;			try {				doc = _iframeDoc(this);			} catch(e) {}			if (doc) {				var pos = K(this).pos();				K(doc).data('pos-x', pos.x);				K(doc).data('pos-y', pos.y);				docs.push(doc);			}		});	}	clickEl.mousedown(function(e) {		if(e.button !== 0 && e.button !== 1) {			return;		}		e.stopPropagation();		var self = clickEl.get(),			x = _removeUnit(moveEl.css('left')),			y = _removeUnit(moveEl.css('top')),			width = moveEl.width(),			height = moveEl.height(),			pageX = e.pageX,			pageY = e.pageY;		if (beforeDrag) {			beforeDrag();		}		function moveListener(e) {			e.preventDefault();			var kdoc = K(_getDoc(e.target));			var diffX = _round((kdoc.data('pos-x') || 0) + e.pageX - pageX);			var diffY = _round((kdoc.data('pos-y') || 0) + e.pageY - pageY);			moveFn.call(clickEl, x, y, width, height, diffX, diffY);		}		function selectListener(e) {			e.preventDefault();		}		function upListener(e) {			e.preventDefault();			K(docs).unbind('mousemove', moveListener)				.unbind('mouseup', upListener)				.unbind('selectstart', selectListener);			if (self.releaseCapture) {				self.releaseCapture();			}		}		K(docs).mousemove(moveListener)			.mouseup(upListener)			.bind('selectstart', selectListener);		if (self.setCapture) {			self.setCapture();		}	});}function KWidget(options) {	this.init(options);}_extend(KWidget, {	init : function(options) {		var self = this;		self.name = options.name || '';		self.doc = options.doc || document;		self.win = _getWin(self.doc);		self.x = _addUnit(options.x);		self.y = _addUnit(options.y);		self.z = options.z;		self.width = _addUnit(options.width);		self.height = _addUnit(options.height);		self.div = K('<div style="display:block;"></div>');		self.options = options;		self._alignEl = options.alignEl;		if (self.width) {			self.div.css('width', self.width);		}		if (self.height) {			self.div.css('height', self.height);		}		if (self.z) {			self.div.css({				position : 'absolute',				left : self.x,				top : self.y,				'z-index' : self.z			});		}		if (self.z && (self.x === undefined || self.y === undefined)) {			self.autoPos(self.width, self.height);		}		if (options.cls) {			self.div.addClass(options.cls);		}		if (options.shadowMode) {			self.div.addClass('ke-shadow');		}		if (options.css) {			self.div.css(options.css);		}		if (options.src) {			K(options.src).replaceWith(self.div);		} else {			K(self.doc.body).append(self.div);		}		if (options.html) {			self.div.html(options.html);		}		if (options.autoScroll) {			if (_IE && _V < 7 || _QUIRKS) {				var scrollPos = _getScrollPos();				K(self.win).bind('scroll', function(e) {					var pos = _getScrollPos(),						diffX = pos.x - scrollPos.x,						diffY = pos.y - scrollPos.y;					self.pos(_removeUnit(self.x) + diffX, _removeUnit(self.y) + diffY, false);				});			} else {				self.div.css('position', 'fixed');			}		}	},	pos : function(x, y, updateProp) {		var self = this;		updateProp = _undef(updateProp, true);		if (x !== null) {			x = x < 0 ? 0 : _addUnit(x);			self.div.css('left', x);			if (updateProp) {				self.x = x;			}		}		if (y !== null) {			y = y < 0 ? 0 : _addUnit(y);			self.div.css('top', y);			if (updateProp) {				self.y = y;			}		}		return self;	},	autoPos : function(width, height) {		var self = this,			w = _removeUnit(width) || 0,			h = _removeUnit(height) || 0,			scrollPos = _getScrollPos();		if (self._alignEl) {			var knode = K(self._alignEl),				pos = knode.pos(),				diffX = _round(knode[0].clientWidth / 2 - w / 2),				diffY = _round(knode[0].clientHeight / 2 - h / 2);			x = diffX < 0 ? pos.x : pos.x + diffX;			y = diffY < 0 ? pos.y : pos.y + diffY;		} else {			var docEl = _docElement(self.doc);			x = _round(scrollPos.x + (docEl.clientWidth - w) / 2);			y = _round(scrollPos.y + (docEl.clientHeight - h) / 2);		}		if (!(_IE && _V < 7 || _QUIRKS)) {			x -= scrollPos.x;			y -= scrollPos.y;		}		return self.pos(x, y);	},	remove : function() {		var self = this;		if (_IE && _V < 7 || _QUIRKS) {			K(self.win).unbind('scroll');		}		self.div.remove();		_each(self, function(i) {			self[i] = null;		});		return this;	},	show : function() {		this.div.show();		return this;	},	hide : function() {		this.div.hide();		return this;	},	draggable : function(options) {		var self = this;		options = options || {};		options.moveEl = self.div;		options.moveFn = function(x, y, width, height, diffX, diffY) {			if ((x = x + diffX) < 0) {				x = 0;			}			if ((y = y + diffY) < 0) {				y = 0;			}			self.pos(x, y);		};		_drag(options);		return self;	}});function _widget(options) {	return new KWidget(options);}K.WidgetClass = KWidget;K.widget = _widget;function _iframeDoc(iframe) {	iframe = _get(iframe);	return iframe.contentDocument || iframe.contentWindow.document;}var html, _direction = '';if ((html = document.getElementsByTagName('html'))) {	_direction = html[0].dir;}function _getInitHtml(themesPath, bodyClass, cssPath, cssData) {	var arr = [		(_direction === '' ? '<html>' : '<html dir="' + _direction + '">'),		'<head><meta charset="utf-8" /><title></title>',		'<style>',		'html {margin:0;padding:0;}',		'body {margin:0;padding:5px;}',		'body, td {font:12px/1.5 "sans serif",tahoma,verdana,helvetica;}',		'body, p, div {word-wrap: break-word;}',		'p {margin:5px 0;}',		'table {border-collapse:collapse;}',		'img {border:0;}',		'noscript {display:none;}',		'table.ke-zeroborder td {border:1px dotted #AAA;}',		'img.ke-flash {',		'	border:1px solid #AAA;',		'	background-image:url(' + themesPath + 'common/flash.gif);',		'	background-position:center center;',		'	background-repeat:no-repeat;',		'	width:100px;',		'	height:100px;',		'}',		'img.ke-rm {',		'	border:1px solid #AAA;',		'	background-image:url(' + themesPath + 'common/rm.gif);',		'	background-position:center center;',		'	background-repeat:no-repeat;',		'	width:100px;',		'	height:100px;',		'}',		'img.ke-media {',		'	border:1px solid #AAA;',		'	background-image:url(' + themesPath + 'common/media.gif);',		'	background-position:center center;',		'	background-repeat:no-repeat;',		'	width:100px;',		'	height:100px;',		'}',		'img.ke-anchor {',		'	border:1px dashed #666;',		'	width:16px;',		'	height:16px;',		'}',		'.ke-script, .ke-noscript, .ke-display-none {',		'	display:none;',		'	font-size:0;',		'	width:0;',		'	height:0;',		'}',		'.ke-pagebreak {',		'	border:1px dotted #AAA;',		'	font-size:0;',		'	height:2px;',		'}',		'</style>'	];	if (!_isArray(cssPath)) {		cssPath = [cssPath];	}	_each(cssPath, function(i, path) {		if (path) {			arr.push('<link href="' + path + '" rel="stylesheet" />');		}	});	if (cssData) {		arr.push('<style>' + cssData + '</style>');	}	arr.push('</head><body ' + (bodyClass ? 'class="' + bodyClass + '"' : '') + '></body></html>');	return arr.join('\n');}function _elementVal(knode, val) {	if (knode.hasVal()) {		if (val === undefined) {			var html = knode.val();			html = html.replace(/(<(?:p|p\s[^>]*)>) *(<\/p>)/ig, '');			return html;		}		return knode.val(val);	}	return knode.html(val);}function KEdit(options) {	this.init(options);}_extend(KEdit, KWidget, {	init : function(options) {		var self = this;		KEdit.parent.init.call(self, options);		self.srcElement = K(options.srcElement);		self.div.addClass('ke-edit');		self.designMode = _undef(options.designMode, true);		self.beforeGetHtml = options.beforeGetHtml;		self.beforeSetHtml = options.beforeSetHtml;		self.afterSetHtml = options.afterSetHtml;		var themesPath = _undef(options.themesPath, ''),			bodyClass = options.bodyClass,			cssPath = options.cssPath,			cssData = options.cssData,			isDocumentDomain = location.protocol != 'res:' && location.host.replace(/:\d+/, '') !== document.domain,			srcScript = ('document.open();' +				(isDocumentDomain ? 'document.domain="' + document.domain + '";' : '') +				'document.close();'),			iframeSrc = _IE ? ' src="javascript:void(function(){' + encodeURIComponent(srcScript) + '}())"' : '';		self.iframe = K('<iframe class="ke-edit-iframe" hidefocus="true" frameborder="0"' + iframeSrc + '></iframe>').css('width', '100%');		self.textarea = K('<textarea class="ke-edit-textarea" hidefocus="true"></textarea>').css('width', '100%');		self.tabIndex = isNaN(parseInt(options.tabIndex, 10)) ? self.srcElement.attr('tabindex') : parseInt(options.tabIndex, 10);		self.iframe.attr('tabindex', self.tabIndex);		self.textarea.attr('tabindex', self.tabIndex);		if (self.width) {			self.setWidth(self.width);		}		if (self.height) {			self.setHeight(self.height);		}		if (self.designMode) {			self.textarea.hide();		} else {			self.iframe.hide();		}		function ready() {			var doc = _iframeDoc(self.iframe);			doc.open();			if (isDocumentDomain) {				doc.domain = document.domain;			}			doc.write(_getInitHtml(themesPath, bodyClass, cssPath, cssData));			doc.close();			self.win = self.iframe[0].contentWindow;			self.doc = doc;			var cmd = _cmd(doc);			self.afterChange(function(e) {				cmd.selection();			});			if (_WEBKIT) {				K(doc).click(function(e) {					if (K(e.target).name === 'img') {						cmd.selection(true);						cmd.range.selectNode(e.target);						cmd.select();					}				});			}			if (_IE) {				self._mousedownHandler = function() {					var newRange = cmd.range.cloneRange();					newRange.shrink();					if (newRange.isControl()) {						self.blur();					}				};				K(document).mousedown(self._mousedownHandler);				K(doc).keydown(function(e) {					if (e.which == 8) {						cmd.selection();						var rng = cmd.range;						if (rng.isControl()) {							rng.collapse(true);							K(rng.startContainer.childNodes[rng.startOffset]).remove();							e.preventDefault();						}					}				});			}			self.cmd = cmd;			self.html(_elementVal(self.srcElement));			if (_IE) {				doc.body.disabled = true;				doc.body.contentEditable = true;				doc.body.removeAttribute('disabled');			} else {				doc.designMode = 'on';			}			if (options.afterCreate) {				options.afterCreate.call(self);			}		}		if (isDocumentDomain) {			self.iframe.bind('load', function(e) {				self.iframe.unbind('load');				if (_IE) {					ready();				} else {					setTimeout(ready, 0);				}			});		}		self.div.append(self.iframe);		self.div.append(self.textarea);		self.srcElement.hide();		!isDocumentDomain && ready();	},	setWidth : function(val) {		var self = this;		val = _addUnit(val);		self.width = val;		self.div.css('width', val);		return self;	},	setHeight : function(val) {		var self = this;		val = _addUnit(val);		self.height = val;		self.div.css('height', val);		self.iframe.css('height', val);		if ((_IE && _V < 8) || _QUIRKS) {			val = _addUnit(_removeUnit(val) - 2);		}		self.textarea.css('height', val);		return self;	},	remove : function() {		var self = this, doc = self.doc;		K(doc.body).unbind();		K(doc).unbind();		K(self.win).unbind();		if (self._mousedownHandler) {			K(document).unbind('mousedown', self._mousedownHandler);		}		_elementVal(self.srcElement, self.html());		self.srcElement.show();		self.iframe.unbind();		self.textarea.unbind();		KEdit.parent.remove.call(self);	},	html : function(val, isFull) {		var self = this, doc = self.doc;		if (self.designMode) {			var body = doc.body;			if (val === undefined) {				if (isFull) {					val = '<!doctype html><html>' + body.parentNode.innerHTML + '</html>';				} else {					val = body.innerHTML;				}				if (self.beforeGetHtml) {					val = self.beforeGetHtml(val);				}				if (_GECKO && val == '<br />') {					val = '';				}				return val;			}			if (self.beforeSetHtml) {				val = self.beforeSetHtml(val);			}			if (_IE && _V >= 9) {				val = val.replace(/(<.*?checked=")checked(".*>)/ig, '$1$2');			}			K(body).html(val);			if (self.afterSetHtml) {				self.afterSetHtml();			}			return self;		}		if (val === undefined) {			return self.textarea.val();		}		self.textarea.val(val);		return self;	},	design : function(bool) {		var self = this, val;		if (bool === undefined ? !self.designMode : bool) {			if (!self.designMode) {				val = self.html();				self.designMode = true;				self.textarea.hide();				self.html(val);				var iframe = self.iframe;				var height = _removeUnit(self.height);				iframe.height(height - 2);				iframe.show();				setTimeout(function() {					iframe.height(height);				}, 0);			}		} else {			if (self.designMode) {				val = self.html();				self.designMode = false;				self.html(val);				self.iframe.hide();				self.textarea.show();			}		}		return self.focus();	},	focus : function() {		var self = this;		self.designMode ? self.win.focus() : self.textarea[0].focus();		return self;	},	blur : function() {		var self = this;		if (_IE) {			var input = K('<input type="text" style="float:left;width:0;height:0;padding:0;margin:0;border:0;" value="" />', self.div);			self.div.append(input);			input[0].focus();			input.remove();		} else {			self.designMode ? self.win.blur() : self.textarea[0].blur();		}		return self;	},	afterChange : function(fn) {		var self = this, doc = self.doc, body = doc.body;		K(doc).keyup(function(e) {			if (!e.ctrlKey && !e.altKey && _CHANGE_KEY_MAP[e.which]) {				fn(e);			}		});		K(doc).mouseup(fn).contextmenu(fn);		K(self.win).blur(fn);		function timeoutHandler(e) {			setTimeout(function() {				fn(e);			}, 1);		}		K(body).bind('paste', timeoutHandler);		K(body).bind('cut', timeoutHandler);		return self;	}});function _edit(options) {	return new KEdit(options);}K.EditClass = KEdit;K.edit = _edit;K.iframeDoc = _iframeDoc;function _selectToolbar(name, fn) {	var self = this,		knode = self.get(name);	if (knode) {		if (knode.hasClass('ke-disabled')) {			return;		}		fn(knode);	}}function KToolbar(options) {	this.init(options);}_extend(KToolbar, KWidget, {	init : function(options) {		var self = this;		KToolbar.parent.init.call(self, options);		self.disableMode = _undef(options.disableMode, false);		self.noDisableItemMap = _toMap(_undef(options.noDisableItems, []));		self._itemMap = {};		self.div.addClass('ke-toolbar').bind('contextmenu,mousedown,mousemove', function(e) {			e.preventDefault();		}).attr('unselectable', 'on');		function find(target) {			var knode = K(target);			if (knode.hasClass('ke-outline')) {				return knode;			}			if (knode.hasClass('ke-toolbar-icon')) {				return knode.parent();			}		}		function hover(e, method) {			var knode = find(e.target);			if (knode) {				if (knode.hasClass('ke-disabled')) {					return;				}				if (knode.hasClass('ke-selected')) {					return;				}				knode[method]('ke-on');			}		}		self.div.mouseover(function(e) {			hover(e, 'addClass');		})		.mouseout(function(e) {			hover(e, 'removeClass');		})		.click(function(e) {			var knode = find(e.target);			if (knode) {				if (knode.hasClass('ke-disabled')) {					return;				}				self.options.click.call(this, e, knode.attr('data-name'));			}		});	},	get : function(name) {		if (this._itemMap[name]) {			return this._itemMap[name];		}		return (this._itemMap[name] = K('span.ke-icon-' + name, this.div).parent());	},	select : function(name) {		_selectToolbar.call(this, name, function(knode) {			knode.addClass('ke-selected');		});		return self;	},	unselect : function(name) {		_selectToolbar.call(this, name, function(knode) {			knode.removeClass('ke-selected').removeClass('ke-on');		});		return self;	},	enable : function(name) {		var self = this,			knode = name.get ? name : self.get(name);		if (knode) {			knode.removeClass('ke-disabled');			knode.opacity(1);		}		return self;	},	disable : function(name) {		var self = this,			knode = name.get ? name : self.get(name);		if (knode) {			knode.removeClass('ke-selected').addClass('ke-disabled');			knode.opacity(0.5);		}		return self;	},	disableAll : function(bool, noDisableItems) {		var self = this, map = self.noDisableItemMap, item;		if (noDisableItems) {			map = _toMap(noDisableItems);		}		if (bool === undefined ? !self.disableMode : bool) {			K('span.ke-outline', self.div).each(function() {				var knode = K(this),					name = knode[0].getAttribute('data-name', 2);				if (!map[name]) {					self.disable(knode);				}			});			self.disableMode = true;		} else {			K('span.ke-outline', self.div).each(function() {				var knode = K(this),					name = knode[0].getAttribute('data-name', 2);				if (!map[name]) {					self.enable(knode);				}			});			self.disableMode = false;		}		return self;	}});function _toolbar(options) {	return new KToolbar(options);}K.ToolbarClass = KToolbar;K.toolbar = _toolbar;function KMenu(options) {	this.init(options);}_extend(KMenu, KWidget, {	init : function(options) {		var self = this;		options.z = options.z || 811213;		KMenu.parent.init.call(self, options);		self.centerLineMode = _undef(options.centerLineMode, true);		self.div.addClass('ke-menu').bind('click,mousedown', function(e){			e.stopPropagation();		}).attr('unselectable', 'on');	},	addItem : function(item) {		var self = this;		if (item.title === '-') {			self.div.append(K('<div class="ke-menu-separator"></div>'));			return;		}		var itemDiv = K('<div class="ke-menu-item" unselectable="on"></div>'),			leftDiv = K('<div class="ke-inline-block ke-menu-item-left"></div>'),			rightDiv = K('<div class="ke-inline-block ke-menu-item-right"></div>'),			height = _addUnit(item.height),			iconClass = _undef(item.iconClass, '');		self.div.append(itemDiv);		if (height) {			itemDiv.css('height', height);			rightDiv.css('line-height', height);		}		var centerDiv;		if (self.centerLineMode) {			centerDiv = K('<div class="ke-inline-block ke-menu-item-center"></div>');			if (height) {				centerDiv.css('height', height);			}		}		itemDiv.mouseover(function(e) {			K(this).addClass('ke-menu-item-on');			if (centerDiv) {				centerDiv.addClass('ke-menu-item-center-on');			}		})		.mouseout(function(e) {			K(this).removeClass('ke-menu-item-on');			if (centerDiv) {				centerDiv.removeClass('ke-menu-item-center-on');			}		})		.click(function(e) {			item.click.call(K(this));			e.stopPropagation();		})		.append(leftDiv);		if (centerDiv) {			itemDiv.append(centerDiv);		}		itemDiv.append(rightDiv);		if (item.checked) {			iconClass = 'ke-icon-checked';		}		if (iconClass !== '') {			leftDiv.html('<span class="ke-inline-block ke-toolbar-icon ke-toolbar-icon-url ' + iconClass + '"></span>');		}		rightDiv.html(item.title);		return self;	},	remove : function() {		var self = this;		if (self.options.beforeRemove) {			self.options.beforeRemove.call(self);		}		K('.ke-menu-item', self.div[0]).unbind();		KMenu.parent.remove.call(self);		return self;	}});function _menu(options) {	return new KMenu(options);}K.MenuClass = KMenu;K.menu = _menu;function KColorPicker(options) {	this.init(options);}_extend(KColorPicker, KWidget, {	init : function(options) {		var self = this;		options.z = options.z || 811213;		KColorPicker.parent.init.call(self, options);		var colors = options.colors || [			['#E53333', '#E56600', '#FF9900', '#64451D', '#DFC5A4', '#FFE500'],			['#009900', '#006600', '#99BB00', '#B8D100', '#60D978', '#00D5FF'],			['#337FE5', '#003399', '#4C33E5', '#9933E5', '#CC33E5', '#EE33EE'],			['#FFFFFF', '#CCCCCC', '#999999', '#666666', '#333333', '#000000']		];		self.selectedColor = (options.selectedColor || '').toLowerCase();		self._cells = [];		self.div.addClass('ke-colorpicker').bind('click,mousedown', function(e){			e.stopPropagation();		}).attr('unselectable', 'on');		var table = self.doc.createElement('table');		self.div.append(table);		table.className = 'ke-colorpicker-table';		table.cellPadding = 0;		table.cellSpacing = 0;		table.border = 0;		var row = table.insertRow(0), cell = row.insertCell(0);		cell.colSpan = colors[0].length;		self._addAttr(cell, '', 'ke-colorpicker-cell-top');		for (var i = 0; i < colors.length; i++) {			row = table.insertRow(i + 1);			for (var j = 0; j < colors[i].length; j++) {				cell = row.insertCell(j);				self._addAttr(cell, colors[i][j], 'ke-colorpicker-cell');			}		}	},	_addAttr : function(cell, color, cls) {		var self = this;		cell = K(cell).addClass(cls);		if (self.selectedColor === color.toLowerCase()) {			cell.addClass('ke-colorpicker-cell-selected');		}		cell.attr('title', color || self.options.noColor);		cell.mouseover(function(e) {			K(this).addClass('ke-colorpicker-cell-on');		});		cell.mouseout(function(e) {			K(this).removeClass('ke-colorpicker-cell-on');		});		cell.click(function(e) {			e.stop();			self.options.click.call(K(this), color);		});		if (color) {			cell.append(K('<div class="ke-colorpicker-cell-color" unselectable="on"></div>').css('background-color', color));		} else {			cell.html(self.options.noColor);		}		K(cell).attr('unselectable', 'on');		self._cells.push(cell);	},	remove : function() {		var self = this;		_each(self._cells, function() {			this.unbind();		});		KColorPicker.parent.remove.call(self);		return self;	}});function _colorpicker(options) {	return new KColorPicker(options);}K.ColorPickerClass = KColorPicker;K.colorpicker = _colorpicker;function KUploadButton(options) {	this.init(options);}_extend(KUploadButton, {	init : function(options) {		var self = this,			button = K(options.button),			fieldName = options.fieldName || 'file',			url = options.url || '',			title = button.val(),			extraParams = options.extraParams || {},			cls = button[0].className || '',			target = options.target || 'kindeditor_upload_iframe_' + new Date().getTime();		options.afterError = options.afterError || function(str) {			alert(str);		};		var hiddenElements = [];		for(var k in extraParams){			hiddenElements.push('<input type="hidden" name="' + k + '" value="' + extraParams[k] + '" />');		}		var html = [			'<div class="ke-inline-block ' + cls + '">',			(options.target ? '' : '<iframe name="' + target + '" style="display:none;"></iframe>'),			(options.form ? '<div class="ke-upload-area">' : '<form class="ke-upload-area ke-form" method="post" enctype="multipart/form-data" target="' + target + '" action="' + url + '">'),			'<span class="ke-button-common">',			hiddenElements.join(''),			'<input type="button" class="ke-button-common ke-button" value="' + title + '" />',			'</span>',			'<input type="file" class="ke-upload-file" name="' + fieldName + '" tabindex="-1" />',			(options.form ? '</div>' : '</form>'),			'</div>'].join('');		var div = K(html, button.doc);		button.hide();		button.before(div);		self.div = div;		self.button = button;		self.iframe = options.target ? K('iframe[name="' + target + '"]') : K('iframe', div);		self.form = options.form ? K(options.form) : K('form', div);		self.fileBox = K('.ke-upload-file', div);		var width = options.width || K('.ke-button-common', div).width();		K('.ke-upload-area', div).width(width);		self.options = options;	},	submit : function() {		var self = this,			iframe = self.iframe;		iframe.bind('load', function() {			iframe.unbind();			var tempForm = document.createElement('form');			self.fileBox.before(tempForm);			K(tempForm).append(self.fileBox);			tempForm.reset();			K(tempForm).remove(true);			var doc = K.iframeDoc(iframe),				pre = doc.getElementsByTagName('pre')[0],				str = '', data;			if (pre) {				str = pre.innerHTML;			} else {				str = doc.body.innerHTML;			}			str = _unescape(str);			iframe[0].src = 'javascript:false';			try {				data = K.json(str);			} catch (e) {				self.options.afterError.call(self, '<!doctype html><html>' + doc.body.parentNode.innerHTML + '</html>');			}			if (data) {				self.options.afterUpload.call(self, data);			}		});		self.form[0].submit();		return self;	},	remove : function() {		var self = this;		if (self.fileBox) {			self.fileBox.unbind();		}		self.iframe.remove();		self.div.remove();		self.button.show();		return self;	}});function _uploadbutton(options) {	return new KUploadButton(options);}K.UploadButtonClass = KUploadButton;K.uploadbutton = _uploadbutton;function _createButton(arg) {	arg = arg || {};	var name = arg.name || '',		span = K('<span class="ke-button-common ke-button-outer" title="' + name + '"></span>'),		btn = K('<input class="ke-button-common ke-button" type="button" value="' + name + '" />');	if (arg.click) {		btn.click(arg.click);	}	span.append(btn);	return span;}function KDialog(options) {	this.init(options);}_extend(KDialog, KWidget, {	init : function(options) {		var self = this;		var shadowMode = _undef(options.shadowMode, true);		options.z = options.z || 811213;		options.shadowMode = false;		options.autoScroll = _undef(options.autoScroll, true);		KDialog.parent.init.call(self, options);		var title = options.title,			body = K(options.body, self.doc),			previewBtn = options.previewBtn,			yesBtn = options.yesBtn,			noBtn = options.noBtn,			closeBtn = options.closeBtn,			showMask = _undef(options.showMask, true);		self.div.addClass('ke-dialog').bind('click,mousedown', function(e){			e.stopPropagation();		});		var contentDiv = K('<div class="ke-dialog-content"></div>').appendTo(self.div);		if (_IE && _V < 7) {			self.iframeMask = K('<iframe src="about:blank" class="ke-dialog-shadow"></iframe>').appendTo(self.div);		} else if (shadowMode) {			K('<div class="ke-dialog-shadow"></div>').appendTo(self.div);		}		var headerDiv = K('<div class="ke-dialog-header"></div>');		contentDiv.append(headerDiv);		headerDiv.html(title);		self.closeIcon = K('<span class="ke-dialog-icon-close" title="' + closeBtn.name + '"></span>').click(closeBtn.click);		headerDiv.append(self.closeIcon);		self.draggable({			clickEl : headerDiv,			beforeDrag : options.beforeDrag		});		var bodyDiv = K('<div class="ke-dialog-body"></div>');		contentDiv.append(bodyDiv);		bodyDiv.append(body);		var footerDiv = K('<div class="ke-dialog-footer"></div>');		if (previewBtn || yesBtn || noBtn) {			contentDiv.append(footerDiv);		}		_each([			{ btn : previewBtn, name : 'preview' },			{ btn : yesBtn, name : 'yes' },			{ btn : noBtn, name : 'no' }		], function() {			if (this.btn) {				var button = _createButton(this.btn);				button.addClass('ke-dialog-' + this.name);				footerDiv.append(button);			}		});		if (self.height) {			bodyDiv.height(_removeUnit(self.height) - headerDiv.height() - footerDiv.height());		}		self.div.width(self.div.width());		self.div.height(self.div.height());		self.mask = null;		if (showMask) {			var docEl = _docElement(self.doc),				docWidth = Math.max(docEl.scrollWidth, docEl.clientWidth),				docHeight = Math.max(docEl.scrollHeight, docEl.clientHeight);			self.mask = _widget({				x : 0,				y : 0,				z : self.z - 1,				cls : 'ke-dialog-mask',				width : docWidth,				height : docHeight			});		}		self.autoPos(self.div.width(), self.div.height());		self.footerDiv = footerDiv;		self.bodyDiv = bodyDiv;		self.headerDiv = headerDiv;		self.isLoading = false;	},	setMaskIndex : function(z) {		var self = this;		self.mask.div.css('z-index', z);	},	showLoading : function(msg) {		msg = _undef(msg, '');		var self = this, body = self.bodyDiv;		self.loading = K('<div class="ke-dialog-loading"><div class="ke-inline-block ke-dialog-loading-content" style="margin-top:' + Math.round(body.height() / 3) + 'px;">' + msg + '</div></div>')			.width(body.width()).height(body.height())			.css('top', self.headerDiv.height() + 'px');		body.css('visibility', 'hidden').after(self.loading);		self.isLoading = true;		return self;	},	hideLoading : function() {		this.loading && this.loading.remove();		this.bodyDiv.css('visibility', 'visible');		this.isLoading = false;		return this;	},	remove : function() {		var self = this;		if (self.options.beforeRemove) {			self.options.beforeRemove.call(self);		}		self.mask && self.mask.remove();		self.iframeMask && self.iframeMask.remove();		self.closeIcon.unbind();		K('input', self.div).unbind();		K('button', self.div).unbind();		self.footerDiv.unbind();		self.bodyDiv.unbind();		self.headerDiv.unbind();		K('iframe', self.div).each(function() {			K(this).remove();		});		KDialog.parent.remove.call(self);		return self;	}});function _dialog(options) {	return new KDialog(options);}K.DialogClass = KDialog;K.dialog = _dialog;function _tabs(options) {	var self = _widget(options),		remove = self.remove,		afterSelect = options.afterSelect,		div = self.div,		liList = [];	div.addClass('ke-tabs')		.bind('contextmenu,mousedown,mousemove', function(e) {			e.preventDefault();		});	var ul = K('<ul class="ke-tabs-ul ke-clearfix"></ul>');	div.append(ul);	self.add = function(tab) {		var li = K('<li class="ke-tabs-li">' + tab.title + '</li>');		li.data('tab', tab);		liList.push(li);		ul.append(li);	};	self.selectedIndex = 0;	self.select = function(index) {		self.selectedIndex = index;		_each(liList, function(i, li) {			li.unbind();			if (i === index) {				li.addClass('ke-tabs-li-selected');				K(li.data('tab').panel).show('');			} else {				li.removeClass('ke-tabs-li-selected').removeClass('ke-tabs-li-on')				.mouseover(function() {					K(this).addClass('ke-tabs-li-on');				})				.mouseout(function() {					K(this).removeClass('ke-tabs-li-on');				})				.click(function() {					self.select(i);				});				K(li.data('tab').panel).hide();			}		});		if (afterSelect) {			afterSelect.call(self, index);		}	};	self.remove = function() {		_each(liList, function() {			this.remove();		});		ul.remove();		remove.call(self);	};	return self;}K.tabs = _tabs;function _loadScript(url, fn) {	var head = document.getElementsByTagName('head')[0] || (_QUIRKS ? document.body : document.documentElement),		script = document.createElement('script');	head.appendChild(script);	script.src = url;	script.charset = 'utf-8';	script.onload = script.onreadystatechange = function() {		if (!this.readyState || this.readyState === 'loaded') {			if (fn) {				fn();			}			script.onload = script.onreadystatechange = null;			head.removeChild(script);		}	};}function _chopQuery(url) {	var index = url.indexOf('?');	return index > 0 ? url.substr(0, index) : url;}function _loadStyle(url) {	var head = document.getElementsByTagName('head')[0] || (_QUIRKS ? document.body : document.documentElement),		link = document.createElement('link'),		absoluteUrl = _chopQuery(_formatUrl(url, 'absolute'));	var links = K('link[rel="stylesheet"]', head);	for (var i = 0, len = links.length; i < len; i++) {		if (_chopQuery(_formatUrl(links[i].href, 'absolute')) === absoluteUrl) {			return;		}	}	head.appendChild(link);	link.href = url;	link.rel = 'stylesheet';}function _ajax(url, fn, method, param, dataType) {	method = method || 'GET';	dataType = dataType || 'json';	var xhr = window.XMLHttpRequest ? new window.XMLHttpRequest() : new ActiveXObject('Microsoft.XMLHTTP');	xhr.open(method, url, true);	xhr.onreadystatechange = function () {		if (xhr.readyState == 4 && xhr.status == 200) {			if (fn) {				var data = _trim(xhr.responseText);				if (dataType == 'json') {					data = _json(data);				}				fn(data);			}		}	};	if (method == 'POST') {		var params = [];		_each(param, function(key, val) {			params.push(encodeURIComponent(key) + '=' + encodeURIComponent(val));		});		try {			xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');		} catch (e) {}		xhr.send(params.join('&'));	} else {		xhr.send(null);	}}K.loadScript = _loadScript;K.loadStyle = _loadStyle;K.ajax = _ajax;var _plugins = {};function _plugin(name, fn) {	if (name === undefined) {		return _plugins;	}	if (!fn) {		return _plugins[name];	}	_plugins[name] = fn;}var _language = {};function _parseLangKey(key) {	var match, ns = 'core';	if ((match = /^(\w+)\.(\w+)$/.exec(key))) {		ns = match[1];		key = match[2];	}	return { ns : ns, key : key };}function _lang(mixed, langType) {	langType = langType === undefined ? K.options.langType : langType;	if (typeof mixed === 'string') {		if (!_language[langType]) {			return 'no language';		}		var pos = mixed.length - 1;		if (mixed.substr(pos) === '.') {			return _language[langType][mixed.substr(0, pos)];		}		var obj = _parseLangKey(mixed);		return _language[langType][obj.ns][obj.key];	}	_each(mixed, function(key, val) {		var obj = _parseLangKey(key);		if (!_language[langType]) {			_language[langType] = {};		}		if (!_language[langType][obj.ns]) {			_language[langType][obj.ns] = {};		}		_language[langType][obj.ns][obj.key] = val;	});}function _getImageFromRange(range, fn) {	if (range.collapsed) {		return;	}	range = range.cloneRange().up();	var sc = range.startContainer, so = range.startOffset;	if (!_WEBKIT && !range.isControl()) {		return;	}	var img = K(sc.childNodes[so]);	if (!img || img.name != 'img') {		return;	}	if (fn(img)) {		return img;	}}function _bindContextmenuEvent() {	var self = this, doc = self.edit.doc;	K(doc).contextmenu(function(e) {		if (self.menu) {			self.hideMenu();		}		if (!self.useContextmenu) {			e.preventDefault();			return;		}		if (self._contextmenus.length === 0) {			return;		}		var maxWidth = 0, items = [];		_each(self._contextmenus, function() {			if (this.title == '-') {				items.push(this);				return;			}			if (this.cond && this.cond()) {				items.push(this);				if (this.width && this.width > maxWidth) {					maxWidth = this.width;				}			}		});		while (items.length > 0 && items[0].title == '-') {			items.shift();		}		while (items.length > 0 && items[items.length - 1].title == '-') {			items.pop();		}		var prevItem = null;		_each(items, function(i) {			if (this.title == '-' && prevItem.title == '-') {				delete items[i];			}			prevItem = this;		});		if (items.length > 0) {			e.preventDefault();			var pos = K(self.edit.iframe).pos(),				menu = _menu({					x : pos.x + e.clientX,					y : pos.y + e.clientY,					width : maxWidth,					css : { visibility: 'hidden' },					shadowMode : self.shadowMode				});			_each(items, function() {				if (this.title) {					menu.addItem(this);				}			});			var docEl = _docElement(menu.doc),				menuHeight = menu.div.height();			if (e.clientY + menuHeight >= docEl.clientHeight - 100) {				menu.pos(menu.x, _removeUnit(menu.y) - menuHeight);			}			menu.div.css('visibility', 'visible');			self.menu = menu;		}	});}function _bindNewlineEvent() {	var self = this, doc = self.edit.doc, newlineTag = self.newlineTag;	if (_IE && newlineTag !== 'br') {		return;	}	if (_GECKO && _V < 3 && newlineTag !== 'p') {		return;	}	if (_OPERA && _V < 9) {		return;	}	var brSkipTagMap = _toMap('h1,h2,h3,h4,h5,h6,pre,li'),		pSkipTagMap = _toMap('p,h1,h2,h3,h4,h5,h6,pre,li,blockquote');	function getAncestorTagName(range) {		var ancestor = K(range.commonAncestor());		while (ancestor) {			if (ancestor.type == 1 && !ancestor.isStyle()) {				break;			}			ancestor = ancestor.parent();		}		return ancestor.name;	}	K(doc).keydown(function(e) {		if (e.which != 13 || e.shiftKey || e.ctrlKey || e.altKey) {			return;		}		self.cmd.selection();		var tagName = getAncestorTagName(self.cmd.range);		if (tagName == 'marquee' || tagName == 'select') {			return;		}		if (newlineTag === 'br' && !brSkipTagMap[tagName]) {			e.preventDefault();			self.insertHtml('<br />' + (_IE && _V < 9 ? '' : '\u200B'));			return;		}		if (!pSkipTagMap[tagName]) {			_nativeCommand(doc, 'formatblock', '<p>');		}	});	K(doc).keyup(function(e) {		if (e.which != 13 || e.shiftKey || e.ctrlKey || e.altKey) {			return;		}		if (newlineTag == 'br') {			return;		}		if (_GECKO) {			var root = self.cmd.commonAncestor('p');			var a = self.cmd.commonAncestor('a');			if (a && a.text() == '') {				a.remove(true);				self.cmd.range.selectNodeContents(root[0]).collapse(true);				self.cmd.select();			}			return;		}		self.cmd.selection();		var tagName = getAncestorTagName(self.cmd.range);		if (tagName == 'marquee' || tagName == 'select') {			return;		}		if (!pSkipTagMap[tagName]) {			_nativeCommand(doc, 'formatblock', '<p>');		}		var div = self.cmd.commonAncestor('div');		if (div) {			var p = K('<p></p>'),				child = div[0].firstChild;			while (child) {				var next = child.nextSibling;				p.append(child);				child = next;			}			div.before(p);			div.remove();			self.cmd.range.selectNodeContents(p[0]);			self.cmd.select();		}	});}function _bindTabEvent() {	var self = this, doc = self.edit.doc;	K(doc).keydown(function(e) {		if (e.which == 9) {			e.preventDefault();			if (self.afterTab) {				self.afterTab.call(self, e);				return;			}			var cmd = self.cmd, range = cmd.range;			range.shrink();			if (range.collapsed && range.startContainer.nodeType == 1) {				range.insertNode(K('@ ', doc)[0]);				cmd.select();			}			self.insertHtml('    ');		}	});}function _bindFocusEvent() {	var self = this;	K(self.edit.textarea[0], self.edit.win).focus(function(e) {		if (self.afterFocus) {			self.afterFocus.call(self, e);		}	}).blur(function(e) {		if (self.afterBlur) {			self.afterBlur.call(self, e);		}	});}function _removeBookmarkTag(html) {	return _trim(html.replace(/<span [^>]*id="?__kindeditor_bookmark_\w+_\d+__"?[^>]*><\/span>/ig, ''));}function _removeTempTag(html) {	return html.replace(/<div[^>]+class="?__kindeditor_paste__"?[^>]*>[\s\S]*?<\/div>/ig, '');}function _addBookmarkToStack(stack, bookmark) {	if (stack.length === 0) {		stack.push(bookmark);		return;	}	var prev = stack[stack.length - 1];	if (_removeBookmarkTag(bookmark.html) !== _removeBookmarkTag(prev.html)) {		stack.push(bookmark);	}}function _undoToRedo(fromStack, toStack) {	var self = this, edit = self.edit,		body = edit.doc.body,		range, bookmark;	if (fromStack.length === 0) {		return self;	}	if (edit.designMode) {		range = self.cmd.range;		bookmark = range.createBookmark(true);		bookmark.html = body.innerHTML;	} else {		bookmark = {			html : body.innerHTML		};	}	_addBookmarkToStack(toStack, bookmark);	var prev = fromStack.pop();	if (_removeBookmarkTag(bookmark.html) === _removeBookmarkTag(prev.html) && fromStack.length > 0) {		prev = fromStack.pop();	}	if (edit.designMode) {		edit.html(prev.html);		if (prev.start) {			range.moveToBookmark(prev);			self.select();		}	} else {		K(body).html(_removeBookmarkTag(prev.html));	}	return self;}function KEditor(options) {	var self = this;	self.options = {};	function setOption(key, val) {		if (KEditor.prototype[key] === undefined) {			self[key] = val;		}		self.options[key] = val;	}	_each(options, function(key, val) {		setOption(key, options[key]);	});	_each(K.options, function(key, val) {		if (self[key] === undefined) {			setOption(key, val);		}	});	var se = K(self.srcElement || '<textarea/>');	if (!self.width) {		self.width = se[0].style.width || se.width();	}	if (!self.height) {		self.height = se[0].style.height || se.height();	}	setOption('width', _undef(self.width, self.minWidth));	setOption('height', _undef(self.height, self.minHeight));	setOption('width', _addUnit(self.width));	setOption('height', _addUnit(self.height));	if (_MOBILE && (!_IOS || _V < 534)) {		self.designMode = false;	}	self.srcElement = se;	self.initContent = '';	self.plugin = {};	self.isCreated = false;	self._handlers = {};	self._contextmenus = [];	self._undoStack = [];	self._redoStack = [];	self._firstAddBookmark = true;	self.menu = self.contextmenu = null;	self.dialogs = [];}KEditor.prototype = {	lang : function(mixed) {		return _lang(mixed, this.langType);	},	loadPlugin : function(name, fn) {		var self = this;		var _pluginStatus = this._pluginStatus;		if (!_pluginStatus) {			_pluginStatus = this._pluginStatus = {};		}		if (_plugins[name]) {			if (!_isFunction(_plugins[name])) {				setTimeout(function() {					self.loadPlugin(name, fn);				}, 100);				return self;			}			if(!_pluginStatus[name]) {				_plugins[name].call(self, KindEditor);				_pluginStatus[name] = 'inited';			}			if (fn) {				fn.call(self);			}			return self;		}		_plugins[name] = 'loading';		_loadScript(self.pluginsPath + name + '/' + name + '.js?ver=' + encodeURIComponent(K.DEBUG ? _TIME : _VERSION), function() {			setTimeout(function() {				if (_plugins[name]) {					self.loadPlugin(name, fn);				}			}, 0);		});		return self;	},	handler : function(key, fn) {		var self = this;		if (!self._handlers[key]) {			self._handlers[key] = [];		}		if (_isFunction(fn)) {			self._handlers[key].push(fn);			return self;		}		_each(self._handlers[key], function() {			fn = this.call(self, fn);		});		return fn;	},	clickToolbar : function(name, fn) {		var self = this, key = 'clickToolbar' + name;		if (fn === undefined) {			if (self._handlers[key]) {				return self.handler(key);			}			self.loadPlugin(name, function() {				self.handler(key);			});			return self;		}		return self.handler(key, fn);	},	updateState : function() {		var self = this;		_each(('justifyleft,justifycenter,justifyright,justifyfull,insertorderedlist,insertunorderedlist,' +			'subscript,superscript,bold,italic,underline,strikethrough').split(','), function(i, name) {			self.cmd.state(name) ? self.toolbar.select(name) : self.toolbar.unselect(name);		});		return self;	},	addContextmenu : function(item) {		this._contextmenus.push(item);		return this;	},	afterCreate : function(fn) {		return this.handler('afterCreate', fn);	},	beforeRemove : function(fn) {		return this.handler('beforeRemove', fn);	},	beforeGetHtml : function(fn) {		return this.handler('beforeGetHtml', fn);	},	beforeSetHtml : function(fn) {		return this.handler('beforeSetHtml', fn);	},	afterSetHtml : function(fn) {		return this.handler('afterSetHtml', fn);	},	create : function() {		var self = this, fullscreenMode = self.fullscreenMode;		if (self.isCreated) {			return self;		}		if (self.srcElement.data('kindeditor')) {			return self;		}		self.srcElement.data('kindeditor', 'true');		if (fullscreenMode) {			_docElement().style.overflow = 'hidden';		} else {			_docElement().style.overflow = '';		}		var width = fullscreenMode ? _docElement().clientWidth + 'px' : self.width,			height = fullscreenMode ? _docElement().clientHeight + 'px' : self.height;		if ((_IE && _V < 8) || _QUIRKS) {			height = _addUnit(_removeUnit(height) + 2);		}		var container = self.container = K(self.layout);		if (fullscreenMode) {			K(document.body).append(container);		} else {			self.srcElement.before(container);		}		var toolbarDiv = K('.toolbar', container),			editDiv = K('.edit', container),			statusbar = self.statusbar = K('.statusbar', container);		container.removeClass('container')			.addClass('ke-container ke-container-' + self.themeType).css('width', width);		if (fullscreenMode) {			container.css({				position : 'absolute',				left : 0,				top : 0,				'z-index' : 811211			});			if (!_GECKO) {				self._scrollPos = _getScrollPos();			}			window.scrollTo(0, 0);			K(document.body).css({				'height' : '1px',				'overflow' : 'hidden'			});			K(document.body.parentNode).css('overflow', 'hidden');			self._fullscreenExecuted = true;		} else {			if (self._fullscreenExecuted) {				K(document.body).css({					'height' : '',					'overflow' : ''				});				K(document.body.parentNode).css('overflow', '');			}			if (self._scrollPos) {				window.scrollTo(self._scrollPos.x, self._scrollPos.y);			}		}		var htmlList = [];		K.each(self.items, function(i, name) {			if (name == '|') {				htmlList.push('<span class="ke-inline-block ke-separator"></span>');			} else if (name == '/') {				htmlList.push('<div class="ke-hr"></div>');			} else {				htmlList.push('<span class="ke-outline" data-name="' + name + '" title="' + self.lang(name) + '" unselectable="on">');				htmlList.push('<span class="ke-toolbar-icon ke-toolbar-icon-url ke-icon-' + name + '" unselectable="on"></span></span>');			}		});		var toolbar = self.toolbar = _toolbar({			src : toolbarDiv,			html : htmlList.join(''),			noDisableItems : self.noDisableItems,			click : function(e, name) {				e.stop();				if (self.menu) {					var menuName = self.menu.name;					self.hideMenu();					if (menuName === name) {						return;					}				}				self.clickToolbar(name);			}		});		var editHeight = _removeUnit(height) - toolbar.div.height();		var edit = self.edit = _edit({			height : editHeight > 0 && _removeUnit(height) > self.minHeight ? editHeight : self.minHeight,			src : editDiv,			srcElement : self.srcElement,			designMode : self.designMode,			themesPath : self.themesPath,			bodyClass : self.bodyClass,			cssPath : self.cssPath,			cssData : self.cssData,			beforeGetHtml : function(html) {				html = self.beforeGetHtml(html);				html = _removeBookmarkTag(_removeTempTag(html));				return _formatHtml(html, self.filterMode ? self.htmlTags : null, self.urlType, self.wellFormatMode, self.indentChar);			},			beforeSetHtml : function(html) {				html = _formatHtml(html, self.filterMode ? self.htmlTags : null, '', false);				return self.beforeSetHtml(html);			},			afterSetHtml : function() {				self.edit = edit = this;				self.afterSetHtml();			},			afterCreate : function() {				self.edit = edit = this;				self.cmd = edit.cmd;				self._docMousedownFn = function(e) {					if (self.menu) {						self.hideMenu();					}				};				K(edit.doc, document).mousedown(self._docMousedownFn);				_bindContextmenuEvent.call(self);				_bindNewlineEvent.call(self);				_bindTabEvent.call(self);				_bindFocusEvent.call(self);				edit.afterChange(function(e) {					if (!edit.designMode) {						return;					}					self.updateState();					self.addBookmark();					if (self.options.afterChange) {						self.options.afterChange.call(self);					}				});				edit.textarea.keyup(function(e) {					if (!e.ctrlKey && !e.altKey && _INPUT_KEY_MAP[e.which]) {						if (self.options.afterChange) {							self.options.afterChange.call(self);						}					}				});				if (self.readonlyMode) {					self.readonly();				}				self.isCreated = true;				if (self.initContent === '') {					self.initContent = self.html();				}				if (self._undoStack.length > 0) {					var prev = self._undoStack.pop();					if (prev.start) {						self.html(prev.html);						edit.cmd.range.moveToBookmark(prev);						self.select();					}				}				self.afterCreate();				if (self.options.afterCreate) {					self.options.afterCreate.call(self);				}			}		});		statusbar.removeClass('statusbar').addClass('ke-statusbar')			.append('<span class="ke-inline-block ke-statusbar-center-icon"></span>')			.append('<span class="ke-inline-block ke-statusbar-right-icon"></span>');		if (self._fullscreenResizeHandler) {			K(window).unbind('resize', self._fullscreenResizeHandler);			self._fullscreenResizeHandler = null;		}		function initResize() {			if (statusbar.height() === 0) {				setTimeout(initResize, 100);				return;			}			self.resize(width, height, false);		}		initResize();		if (fullscreenMode) {			self._fullscreenResizeHandler = function(e) {				if (self.isCreated) {					self.resize(_docElement().clientWidth, _docElement().clientHeight, false);				}			};			K(window).bind('resize', self._fullscreenResizeHandler);			toolbar.select('fullscreen');			statusbar.first().css('visibility', 'hidden');			statusbar.last().css('visibility', 'hidden');		} else {			if (_GECKO) {				K(window).bind('scroll', function(e) {					self._scrollPos = _getScrollPos();				});			}			if (self.resizeType > 0) {				_drag({					moveEl : container,					clickEl : statusbar,					moveFn : function(x, y, width, height, diffX, diffY) {						height += diffY;						self.resize(null, height);					}				});			} else {				statusbar.first().css('visibility', 'hidden');			}			if (self.resizeType === 2) {				_drag({					moveEl : container,					clickEl : statusbar.last(),					moveFn : function(x, y, width, height, diffX, diffY) {						width += diffX;						height += diffY;						self.resize(width, height);					}				});			} else {				statusbar.last().css('visibility', 'hidden');			}		}		return self;	},	remove : function() {		var self = this;		if (!self.isCreated) {			return self;		}		self.beforeRemove();		self.srcElement.data('kindeditor', '');		if (self.menu) {			self.hideMenu();		}		_each(self.dialogs, function() {			self.hideDialog();		});		K(document).unbind('mousedown', self._docMousedownFn);		self.toolbar.remove();		self.edit.remove();		self.statusbar.last().unbind();		self.statusbar.unbind();		self.container.remove();		self.container = self.toolbar = self.edit = self.menu = null;		self.dialogs = [];		self.isCreated = false;		return self;	},	resize : function(width, height, updateProp) {		var self = this;		updateProp = _undef(updateProp, true);		if (width) {			if (!/%/.test(width)) {				width = _removeUnit(width);				width = width < self.minWidth ? self.minWidth : width;			}			self.container.css('width', _addUnit(width));			if (updateProp) {				self.width = _addUnit(width);			}		}		if (height) {			height = _removeUnit(height);			editHeight = _removeUnit(height) - self.toolbar.div.height() - self.statusbar.height();			editHeight = editHeight < self.minHeight ? self.minHeight : editHeight;			self.edit.setHeight(editHeight);			if (updateProp) {				self.height = _addUnit(height);			}		}		return self;	},	select : function() {		this.isCreated && this.cmd.select();		return this;	},	html : function(val) {		var self = this;		if (val === undefined) {			return self.isCreated ? self.edit.html() : _elementVal(self.srcElement);		}		self.isCreated ? self.edit.html(val) : _elementVal(self.srcElement, val);		if (self.isCreated) {			self.cmd.selection();		}		return self;	},	fullHtml : function() {		return this.isCreated ? this.edit.html(undefined, true) : '';	},	text : function(val) {		var self = this;		if (val === undefined) {			return _trim(self.html().replace(/<(?!img|embed).*?>/ig, '').replace(/ /ig, ' '));		} else {			return self.html(_escape(val));		}	},	isEmpty : function() {		return _trim(this.text().replace(/\r\n|\n|\r/, '')) === '';	},	isDirty : function() {		return _trim(this.initContent.replace(/\r\n|\n|\r|t/g, '')) !== _trim(this.html().replace(/\r\n|\n|\r|t/g, ''));	},	selectedHtml : function() {		var val = this.isCreated ? this.cmd.range.html() : '';		val = _removeBookmarkTag(_removeTempTag(val));		return val;	},	count : function(mode) {		var self = this;		mode = (mode || 'html').toLowerCase();		if (mode === 'html') {			return self.html().length;		}		if (mode === 'text') {			return self.text().replace(/<(?:img|embed).*?>/ig, 'K').replace(/\r\n|\n|\r/g, '').length;		}		return 0;	},	exec : function(key) {		key = key.toLowerCase();		var self = this, cmd = self.cmd,			changeFlag = _inArray(key, 'selectall,copy,paste,print'.split(',')) < 0;		if (changeFlag) {			self.addBookmark(false);		}		cmd[key].apply(cmd, _toArray(arguments, 1));		if (changeFlag) {			self.updateState();			self.addBookmark(false);			if (self.options.afterChange) {				self.options.afterChange.call(self);			}		}		return self;	},	insertHtml : function(val, quickMode) {		if (!this.isCreated) {			return this;		}		val = this.beforeSetHtml(val);		this.exec('inserthtml', val, quickMode);		return this;	},	appendHtml : function(val) {		this.html(this.html() + val);		if (this.isCreated) {			var cmd = this.cmd;			cmd.range.selectNodeContents(cmd.doc.body).collapse(false);			cmd.select();		}		return this;	},	sync : function() {		_elementVal(this.srcElement, this.html());		return this;	},	focus : function() {		this.isCreated ? this.edit.focus() : this.srcElement[0].focus();		return this;	},	blur : function() {		this.isCreated ? this.edit.blur() : this.srcElement[0].blur();		return this;	},	addBookmark : function(checkSize) {		checkSize = _undef(checkSize, true);		var self = this, edit = self.edit,			body = edit.doc.body,			html = _removeTempTag(body.innerHTML), bookmark;		if (checkSize && self._undoStack.length > 0) {			var prev = self._undoStack[self._undoStack.length - 1];			if (Math.abs(html.length - _removeBookmarkTag(prev.html).length) < self.minChangeSize) {				return self;			}		}		if (edit.designMode && !self._firstAddBookmark) {			var range = self.cmd.range;			bookmark = range.createBookmark(true);			bookmark.html = _removeTempTag(body.innerHTML);			range.moveToBookmark(bookmark);		} else {			bookmark = {				html : html			};		}		self._firstAddBookmark = false;		_addBookmarkToStack(self._undoStack, bookmark);		return self;	},	undo : function() {		return _undoToRedo.call(this, this._undoStack, this._redoStack);	},	redo : function() {		return _undoToRedo.call(this, this._redoStack, this._undoStack);	},	fullscreen : function(bool) {		this.fullscreenMode = (bool === undefined ? !this.fullscreenMode : bool);		this.addBookmark(false);		return this.remove().create();	},	readonly : function(isReadonly) {		isReadonly = _undef(isReadonly, true);		var self = this, edit = self.edit, doc = edit.doc;		if (self.designMode) {			self.toolbar.disableAll(isReadonly, []);		} else {			_each(self.noDisableItems, function() {				self.toolbar[isReadonly ? 'disable' : 'enable'](this);			});		}		if (_IE) {			doc.body.contentEditable = !isReadonly;		} else {			doc.designMode = isReadonly ? 'off' : 'on';		}		edit.textarea[0].disabled = isReadonly;	},	createMenu : function(options) {		var self = this,			name = options.name,			knode = self.toolbar.get(name),			pos = knode.pos();		options.x = pos.x;		options.y = pos.y + knode.height();		options.z = self.options.zIndex;		options.shadowMode = _undef(options.shadowMode, self.shadowMode);		if (options.selectedColor !== undefined) {			options.cls = 'ke-colorpicker-' + self.themeType;			options.noColor = self.lang('noColor');			self.menu = _colorpicker(options);		} else {			options.cls = 'ke-menu-' + self.themeType;			options.centerLineMode = false;			self.menu = _menu(options);		}		return self.menu;	},	hideMenu : function() {		this.menu.remove();		this.menu = null;		return this;	},	hideContextmenu : function() {		this.contextmenu.remove();		this.contextmenu = null;		return this;	},	createDialog : function(options) {		var self = this, name = options.name;		options.z = self.options.zIndex;		options.shadowMode = _undef(options.shadowMode, self.shadowMode);		options.closeBtn = _undef(options.closeBtn, {			name : self.lang('close'),			click : function(e) {				self.hideDialog();				if (_IE && self.cmd) {					self.cmd.select();				}			}		});		options.noBtn = _undef(options.noBtn, {			name : self.lang(options.yesBtn ? 'no' : 'close'),			click : function(e) {				self.hideDialog();				if (_IE && self.cmd) {					self.cmd.select();				}			}		});		if (self.dialogAlignType != 'page') {			options.alignEl = self.container;		}		options.cls = 'ke-dialog-' + self.themeType;		if (self.dialogs.length > 0) {			var firstDialog = self.dialogs[0],				parentDialog = self.dialogs[self.dialogs.length - 1];			firstDialog.setMaskIndex(parentDialog.z + 2);			options.z = parentDialog.z + 3;			options.showMask = false;		}		var dialog = _dialog(options);		self.dialogs.push(dialog);		return dialog;	},	hideDialog : function() {		var self = this;		if (self.dialogs.length > 0) {			self.dialogs.pop().remove();		}		if (self.dialogs.length > 0) {			var firstDialog = self.dialogs[0],				parentDialog = self.dialogs[self.dialogs.length - 1];			firstDialog.setMaskIndex(parentDialog.z - 1);		}		return self;	},	errorDialog : function(html) {		var self = this;		var dialog = self.createDialog({			width : 750,			title : self.lang('uploadError'),			body : '<div style="padding:10px 20px;"><iframe frameborder="0" style="width:708px;height:400px;"></iframe></div>'		});		var iframe = K('iframe', dialog.div), doc = K.iframeDoc(iframe);		doc.open();		doc.write(html);		doc.close();		K(doc.body).css('background-color', '#FFF');		iframe[0].contentWindow.focus();		return self;	}};function _editor(options) {	return new KEditor(options);}_instances = [];function _create(expr, options) {	options = options || {};	options.basePath = _undef(options.basePath, K.basePath);	options.themesPath = _undef(options.themesPath, options.basePath + 'themes/');	options.langPath = _undef(options.langPath, options.basePath + 'lang/');	options.pluginsPath = _undef(options.pluginsPath, options.basePath + 'plugins/');	if (_undef(options.loadStyleMode, K.options.loadStyleMode)) {		var themeType = _undef(options.themeType, K.options.themeType);		_loadStyle(options.themesPath + 'default/default.css');		_loadStyle(options.themesPath + themeType + '/' + themeType + '.css');	}	function create(editor) {		_each(_plugins, function(name, fn) {			if (_isFunction(fn)) {				fn.call(editor, KindEditor);				if (!editor._pluginStatus) {					editor._pluginStatus = {};				}				editor._pluginStatus[name] = 'inited';			}		});		return editor.create();	}	var knode = K(expr);	if (!knode || knode.length === 0) {		return;	}	if (knode.length > 1) {		knode.each(function() {			_create(this, options);		});		return _instances[0];	}	options.srcElement = knode[0];	var editor = new KEditor(options);	_instances.push(editor);	if (_language[editor.langType]) {		return create(editor);	}	_loadScript(editor.langPath + editor.langType + '.js?ver=' + encodeURIComponent(K.DEBUG ? _TIME : _VERSION), function() {		create(editor);	});	return editor;}function _eachEditor(expr, fn) {	K(expr).each(function(i, el) {		K.each(_instances, function(j, editor) {			if (editor && editor.srcElement[0] == el) {				fn.call(editor, j);				return false;			}		});	});}K.remove = function(expr) {	_eachEditor(expr, function(i) {		this.remove();		_instances.splice(i, 1);	});};K.sync = function(expr) {	_eachEditor(expr, function() {		this.sync();	});};K.html = function(expr, val) {	_eachEditor(expr, function() {		this.html(val);	});};K.insertHtml = function(expr, val) {	_eachEditor(expr, function() {		this.insertHtml(val);	});};K.appendHtml = function(expr, val) {	_eachEditor(expr, function() {		this.appendHtml(val);	});};if (_IE && _V < 7) {	_nativeCommand(document, 'BackgroundImageCache', true);}K.EditorClass = KEditor;K.editor = _editor;K.create = _create;K.instances = _instances;K.plugin = _plugin;K.lang = _lang;_plugin('core', function(K) {	var self = this,		shortcutKeys = {			undo : 'Z', redo : 'Y', bold : 'B', italic : 'I', underline : 'U', print : 'P', selectall : 'A'		};	self.afterSetHtml(function() {		if (self.options.afterChange) {			self.options.afterChange.call(self);		}	});	self.afterCreate(function() {		if (self.syncType != 'form') {			return;		}		var el = K(self.srcElement), hasForm = false;		while ((el = el.parent())) {			if (el.name == 'form') {				hasForm = true;				break;			}		}		if (hasForm) {			el.bind('submit', function(e) {				self.sync();				K(window).bind('unload', function() {					self.edit.textarea.remove();				});			});			var resetBtn = K('[type="reset"]', el);			resetBtn.click(function() {				self.html(self.initContent);				self.cmd.selection();			});			self.beforeRemove(function() {				el.unbind();				resetBtn.unbind();			});		}	});	self.clickToolbar('source', function() {		if (self.edit.designMode) {			self.toolbar.disableAll(true);			self.edit.design(false);			self.toolbar.select('source');		} else {			self.toolbar.disableAll(false);			self.edit.design(true);			self.toolbar.unselect('source');			if (_GECKO) {				setTimeout(function() {					self.cmd.selection();				}, 0);			} else {				self.cmd.selection();			}		}		self.designMode = self.edit.designMode;	});	self.afterCreate(function() {		if (!self.designMode) {			self.toolbar.disableAll(true).select('source');		}	});	self.clickToolbar('fullscreen', function() {		self.fullscreen();	});	if (self.fullscreenShortcut) {		var loaded = false;		self.afterCreate(function() {			K(self.edit.doc, self.edit.textarea).keyup(function(e) {				if (e.which == 27) {					setTimeout(function() {						self.fullscreen();					}, 0);				}			});			if (loaded) {				if (_IE && !self.designMode) {					return;				}				self.focus();			}			if (!loaded) {				loaded = true;			}		});	}	_each('undo,redo'.split(','), function(i, name) {		if (shortcutKeys[name]) {			self.afterCreate(function() {				_ctrl(this.edit.doc, shortcutKeys[name], function() {					self.clickToolbar(name);				});			});		}		self.clickToolbar(name, function() {			self[name]();		});	});	self.clickToolbar('formatblock', function() {		var blocks = self.lang('formatblock.formatBlock'),			heights = {				h1 : 28,				h2 : 24,				h3 : 18,				H4 : 14,				p : 12			},			curVal = self.cmd.val('formatblock'),			menu = self.createMenu({				name : 'formatblock',				width : self.langType == 'en' ? 200 : 150			});		_each(blocks, function(key, val) {			var style = 'font-size:' + heights[key] + 'px;';			if (key.charAt(0) === 'h') {				style += 'font-weight:bold;';			}			menu.addItem({				title : '<span style="' + style + '" unselectable="on">' + val + '</span>',				height : heights[key] + 12,				checked : (curVal === key || curVal === val),				click : function() {					self.select().exec('formatblock', '<' + key + '>').hideMenu();				}			});		});	});	self.clickToolbar('fontname', function() {		var curVal = self.cmd.val('fontname'),			menu = self.createMenu({				name : 'fontname',				width : 150			});		_each(self.lang('fontname.fontName'), function(key, val) {			menu.addItem({				title : '<span style="font-family: ' + key + ';" unselectable="on">' + val + '</span>',				checked : (curVal === key.toLowerCase() || curVal === val.toLowerCase()),				click : function() {					self.exec('fontname', key).hideMenu();				}			});		});	});	self.clickToolbar('fontsize', function() {		var curVal = self.cmd.val('fontsize'),			menu = self.createMenu({				name : 'fontsize',				width : 150			});		_each(self.fontSizeTable, function(i, val) {			menu.addItem({				title : '<span style="font-size:' + val + ';" unselectable="on">' + val + '</span>',				height : _removeUnit(val) + 12,				checked : curVal === val,				click : function() {					self.exec('fontsize', val).hideMenu();				}			});		});	});	_each('forecolor,hilitecolor'.split(','), function(i, name) {		self.clickToolbar(name, function() {			self.createMenu({				name : name,				selectedColor : self.cmd.val(name) || 'default',				colors : self.colorTable,				click : function(color) {					self.exec(name, color).hideMenu();				}			});		});	});	_each(('cut,copy,paste').split(','), function(i, name) {		self.clickToolbar(name, function() {			self.focus();			try {				self.exec(name, null);			} catch(e) {				alert(self.lang(name + 'Error'));			}		});	});	self.clickToolbar('about', function() {		var html = '<div style="margin:20px;">' +			'<div>KindEditor ' + _VERSION + '</div>' +			'<div>Copyright © <a href="http://www.kindsoft.net/" target="_blank">kindsoft.net</a> All rights reserved.</div>' +			'</div>';		self.createDialog({			name : 'about',			width : 350,			title : self.lang('about'),			body : html		});	});	self.plugin.getSelectedLink = function() {		return self.cmd.commonAncestor('a');	};	self.plugin.getSelectedImage = function() {		return _getImageFromRange(self.edit.cmd.range, function(img) {			return !/^ke-\w+$/i.test(img[0].className);		});	};	self.plugin.getSelectedFlash = function() {		return _getImageFromRange(self.edit.cmd.range, function(img) {			return img[0].className == 'ke-flash';		});	};	self.plugin.getSelectedMedia = function() {		return _getImageFromRange(self.edit.cmd.range, function(img) {			return img[0].className == 'ke-media' || img[0].className == 'ke-rm';		});	};	self.plugin.getSelectedAnchor = function() {		return _getImageFromRange(self.edit.cmd.range, function(img) {			return img[0].className == 'ke-anchor';		});	};	_each('link,image,flash,media,anchor'.split(','), function(i, name) {		var uName = name.charAt(0).toUpperCase() + name.substr(1);		_each('edit,delete'.split(','), function(j, val) {			self.addContextmenu({				title : self.lang(val + uName),				click : function() {					self.loadPlugin(name, function() {						self.plugin[name][val]();						self.hideMenu();					});				},				cond : self.plugin['getSelected' + uName],				width : 150,				iconClass : val == 'edit' ? 'ke-icon-' + name : undefined			});		});		self.addContextmenu({ title : '-' });	});	self.plugin.getSelectedTable = function() {		return self.cmd.commonAncestor('table');	};	self.plugin.getSelectedRow = function() {		return self.cmd.commonAncestor('tr');	};	self.plugin.getSelectedCell = function() {		return self.cmd.commonAncestor('td');	};	_each(('prop,cellprop,colinsertleft,colinsertright,rowinsertabove,rowinsertbelow,rowmerge,colmerge,' +	'rowsplit,colsplit,coldelete,rowdelete,insert,delete').split(','), function(i, val) {		var cond = _inArray(val, ['prop', 'delete']) < 0 ? self.plugin.getSelectedCell : self.plugin.getSelectedTable;		self.addContextmenu({			title : self.lang('table' + val),			click : function() {				self.loadPlugin('table', function() {					self.plugin.table[val]();					self.hideMenu();				});			},			cond : cond,			width : 170,			iconClass : 'ke-icon-table' + val		});	});	self.addContextmenu({ title : '-' });	_each(('selectall,justifyleft,justifycenter,justifyright,justifyfull,insertorderedlist,' +		'insertunorderedlist,indent,outdent,subscript,superscript,hr,print,' +		'bold,italic,underline,strikethrough,removeformat,unlink').split(','), function(i, name) {		if (shortcutKeys[name]) {			self.afterCreate(function() {				_ctrl(this.edit.doc, shortcutKeys[name], function() {					self.cmd.selection();					self.clickToolbar(name);				});			});		}		self.clickToolbar(name, function() {			self.focus().exec(name, null);		});	});	self.afterCreate(function() {		var doc = self.edit.doc, cmd, bookmark, div,			cls = '__kindeditor_paste__', pasting = false;		function movePastedData() {			cmd.range.moveToBookmark(bookmark);			cmd.select();			if (_WEBKIT) {				K('div.' + cls, div).each(function() {					K(this).after('<br />').remove(true);				});				K('span.Apple-style-span', div).remove(true);				K('span.Apple-tab-span', div).remove(true);				K('span[style]', div).each(function() {					if (K(this).css('white-space') == 'nowrap') {						K(this).remove(true);					}				});				K('meta', div).remove();			}			var html = div[0].innerHTML;			div.remove();			if (html === '') {				return;			}			if (_WEBKIT) {				html = html.replace(/(<br>)\1/ig, '$1');			}			if (self.pasteType === 2) {				html = html.replace(/(<(?:p|p\s[^>]*)>) *(<\/p>)/ig, '');				if (/schemas-microsoft-com|worddocument|mso-\w+/i.test(html)) {					html = _clearMsWord(html, self.filterMode ? self.htmlTags : K.options.htmlTags);				} else {					html = _formatHtml(html, self.filterMode ? self.htmlTags : null);					html = self.beforeSetHtml(html);				}			}			if (self.pasteType === 1) {				html = html.replace(/ /ig, ' ');				html = html.replace(/\n\s*\n/g, '\n');				html = html.replace(/<br[^>]*>/ig, '\n');				html = html.replace(/<\/p><p[^>]*>/ig, '\n');				html = html.replace(/<[^>]+>/g, '');				html = html.replace(/ {2}/g, '  ');				if (self.newlineTag == 'p') {					if (/\n/.test(html)) {						html = html.replace(/^/, '<p>').replace(/$/, '<br /></p>').replace(/\n/g, '<br /></p><p>');					}				} else {					html = html.replace(/\n/g, '<br />$&');				}			}			self.insertHtml(html, true);		}		K(doc.body).bind('paste', function(e){			if (self.pasteType === 0) {				e.stop();				return;			}			if (pasting) {				return;			}			pasting = true;			K('div.' + cls, doc).remove();			cmd = self.cmd.selection();			bookmark = cmd.range.createBookmark();			div = K('<div class="' + cls + '"></div>', doc).css({				position : 'absolute',				width : '1px',				height : '1px',				overflow : 'hidden',				left : '-1981px',				top : K(bookmark.start).pos().y + 'px',				'white-space' : 'nowrap'			});			K(doc.body).append(div);			if (_IE) {				var rng = cmd.range.get(true);				rng.moveToElementText(div[0]);				rng.select();				rng.execCommand('paste');				e.preventDefault();			} else {				cmd.range.selectNodeContents(div[0]);				cmd.select();				div[0].tabIndex = -1;				div[0].focus();			}			setTimeout(function() {				movePastedData();				pasting = false;			}, 0);		});	});	self.beforeGetHtml(function(html) {		if (_IE && _V <= 8) {			html = html.replace(/<div\s+[^>]*data-ke-input-tag="([^"]*)"[^>]*>([\s\S]*?)<\/div>/ig, function(full, tag) {				return unescape(tag);			});			html = html.replace(/(<input)((?:\s+[^>]*)?>)/ig, function($0, $1, $2) {				if (!/\s+type="[^"]+"/i.test($0)) {					return $1 + ' type="text"' + $2;				}				return $0;			});		}		return html.replace(/(<(?:noscript|noscript\s[^>]*)>)([\s\S]*?)(<\/noscript>)/ig, function($0, $1, $2, $3) {			return $1 + _unescape($2).replace(/\s+/g, ' ') + $3;		})		.replace(/<img[^>]*class="?ke-(flash|rm|media)"?[^>]*>/ig, function(full) {			var imgAttrs = _getAttrList(full);			var styles = _getCssList(imgAttrs.style || '');			var attrs = _mediaAttrs(imgAttrs['data-ke-tag']);			var width = _undef(styles.width, '');			var height = _undef(styles.height, '');			if (/px/i.test(width)) {				width = _removeUnit(width);			}			if (/px/i.test(height)) {				height = _removeUnit(height);			}			attrs.width = _undef(imgAttrs.width, width);			attrs.height = _undef(imgAttrs.height, height);			return _mediaEmbed(attrs);		})		.replace(/<img[^>]*class="?ke-anchor"?[^>]*>/ig, function(full) {			var imgAttrs = _getAttrList(full);			return '<a name="' + unescape(imgAttrs['data-ke-name']) + '"></a>';		})		.replace(/<div\s+[^>]*data-ke-script-attr="([^"]*)"[^>]*>([\s\S]*?)<\/div>/ig, function(full, attr, code) {			return '<script' + unescape(attr) + '>' + unescape(code) + '</script>';		})		.replace(/<div\s+[^>]*data-ke-noscript-attr="([^"]*)"[^>]*>([\s\S]*?)<\/div>/ig, function(full, attr, code) {			return '<noscript' + unescape(attr) + '>' + unescape(code) + '</noscript>';		})		.replace(/(<[^>]*)data-ke-src="([^"]*)"([^>]*>)/ig, function(full, start, src, end) {			full = full.replace(/(\s+(?:href|src)=")[^"]*(")/i, function($0, $1, $2) {				return $1 + _unescape(src) + $2;			});			full = full.replace(/\s+data-ke-src="[^"]*"/i, '');			return full;		})		.replace(/(<[^>]+\s)data-ke-(on\w+="[^"]*"[^>]*>)/ig, function(full, start, end) {			return start + end;		});	});	self.beforeSetHtml(function(html) {		if (_IE && _V <= 8) {			html = html.replace(/<input[^>]*>|<(select|button)[^>]*>[\s\S]*?<\/\1>/ig, function(full) {				var attrs = _getAttrList(full);				var styles = _getCssList(attrs.style || '');				if (styles.display == 'none') {					return '<div class="ke-display-none" data-ke-input-tag="' + escape(full) + '"></div>';				}				return full;			});		}		return html.replace(/<embed[^>]*type="([^"]+)"[^>]*>(?:<\/embed>)?/ig, function(full) {			var attrs = _getAttrList(full);			attrs.src = _undef(attrs.src, '');			attrs.width = _undef(attrs.width, 0);			attrs.height = _undef(attrs.height, 0);			return _mediaImg(self.themesPath + 'common/blank.gif', attrs);		})		.replace(/<a[^>]*name="([^"]+)"[^>]*>(?:<\/a>)?/ig, function(full) {			var attrs = _getAttrList(full);			if (attrs.href !== undefined) {				return full;			}			return '<img class="ke-anchor" src="' + self.themesPath + 'common/anchor.gif" data-ke-name="' + escape(attrs.name) + '" />';		})		.replace(/<script([^>]*)>([\s\S]*?)<\/script>/ig, function(full, attr, code) {			return '<div class="ke-script" data-ke-script-attr="' + escape(attr) + '">' + escape(code) + '</div>';		})		.replace(/<noscript([^>]*)>([\s\S]*?)<\/noscript>/ig, function(full, attr, code) {			return '<div class="ke-noscript" data-ke-noscript-attr="' + escape(attr) + '">' + escape(code) + '</div>';		})		.replace(/(<[^>]*)(href|src)="([^"]*)"([^>]*>)/ig, function(full, start, key, src, end) {			if (full.match(/\sdata-ke-src="[^"]*"/i)) {				return full;			}			full = start + key + '="' + src + '"' + ' data-ke-src="' + _escape(src) + '"' + end;			return full;		})		.replace(/(<[^>]+\s)(on\w+="[^"]*"[^>]*>)/ig, function(full, start, end) {			return start + 'data-ke-' + end;		})		.replace(/<table[^>]*\s+border="0"[^>]*>/ig, function(full) {			if (full.indexOf('ke-zeroborder') >= 0) {				return full;			}			return _addClassToTag(full, 'ke-zeroborder');		});	});});})(window);/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.lang({	source : 'HTML代码',	preview : '预览',	undo : '后退(Ctrl+Z)',	redo : '前进(Ctrl+Y)',	cut : '剪切(Ctrl+X)',	copy : '复制(Ctrl+C)',	paste : '粘贴(Ctrl+V)',	plainpaste : '粘贴为无格式文本',	wordpaste : '从Word粘贴',	selectall : '全选(Ctrl+A)',	justifyleft : '左对齐',	justifycenter : '居中',	justifyright : '右对齐',	justifyfull : '两端对齐',	insertorderedlist : '编号',	insertunorderedlist : '项目符号',	indent : '增加缩进',	outdent : '减少缩进',	subscript : '下标',	superscript : '上标',	formatblock : '段落',	fontname : '字体',	fontsize : '文字大小',	forecolor : '文字颜色',	hilitecolor : '文字背景',	bold : '粗体(Ctrl+B)',	italic : '斜体(Ctrl+I)',	underline : '下划线(Ctrl+U)',	strikethrough : '删除线',	removeformat : '删除格式',	image : '图片',	multiimage : '批量图片上传',	flash : 'Flash',	media : '视音频',	table : '表格',	tablecell : '单元格',	hr : '插入横线',	emoticons : '插入表情',	link : '超级链接',	unlink : '取消超级链接',	fullscreen : '全屏显示',	about : '关于',	print : '打印(Ctrl+P)',	filemanager : '文件空间',	code : '插入程序代码',	map : 'Google地图',	baidumap : '百度地图',	lineheight : '行距',	clearhtml : '清理HTML代码',	pagebreak : '插入分页符',	quickformat : '一键排版',	insertfile : '插入文件',	template : '插入模板',	anchor : '锚点',	yes : '确定',	no : '取消',	close : '关闭',	editImage : '图片属性',	deleteImage : '删除图片',	editFlash : 'Flash属性',	deleteFlash : '删除Flash',	editMedia : '视音频属性',	deleteMedia : '删除视音频',	editLink : '超级链接属性',	deleteLink : '取消超级链接',	editAnchor : '锚点属性',	deleteAnchor : '删除锚点',	tableprop : '表格属性',	tablecellprop : '单元格属性',	tableinsert : '插入表格',	tabledelete : '删除表格',	tablecolinsertleft : '左侧插入列',	tablecolinsertright : '右侧插入列',	tablerowinsertabove : '上方插入行',	tablerowinsertbelow : '下方插入行',	tablerowmerge : '向下合并单元格',	tablecolmerge : '向右合并单元格',	tablerowsplit : '拆分行',	tablecolsplit : '拆分列',	tablecoldelete : '删除列',	tablerowdelete : '删除行',	noColor : '无颜色',	pleaseSelectFile : '请选择文件。',	invalidImg : "请输入有效的URL地址。\n只允许jpg,gif,bmp,png格式。",	invalidMedia : "请输入有效的URL地址。\n只允许swf,flv,mp3,wav,wma,wmv,mid,avi,mpg,asf,rm,rmvb格式。",	invalidWidth : "宽度必须为数字。",	invalidHeight : "高度必须为数字。",	invalidBorder : "边框必须为数字。",	invalidUrl : "请输入有效的URL地址。",	invalidRows : '行数为必选项,只允许输入大于0的数字。',	invalidCols : '列数为必选项,只允许输入大于0的数字。',	invalidPadding : '边距必须为数字。',	invalidSpacing : '间距必须为数字。',	invalidJson : '服务器发生故障。',	uploadSuccess : '上传成功。',	cutError : '您的浏览器安全设置不允许使用剪切操作,请使用快捷键(Ctrl+X)来完成。',	copyError : '您的浏览器安全设置不允许使用复制操作,请使用快捷键(Ctrl+C)来完成。',	pasteError : '您的浏览器安全设置不允许使用粘贴操作,请使用快捷键(Ctrl+V)来完成。',	ajaxLoading : '加载中,请稍候 ...',	uploadLoading : '上传中,请稍候 ...',	uploadError : '上传错误',	'plainpaste.comment' : '请使用快捷键(Ctrl+V)把内容粘贴到下面的方框里。',	'wordpaste.comment' : '请使用快捷键(Ctrl+V)把内容粘贴到下面的方框里。',	'code.pleaseInput' : '请输入程序代码。',	'link.url' : 'URL',	'link.linkType' : '打开类型',	'link.newWindow' : '新窗口',	'link.selfWindow' : '当前窗口',	'flash.url' : 'URL',	'flash.width' : '宽度',	'flash.height' : '高度',	'flash.upload' : '上传',	'flash.viewServer' : '文件空间',	'media.url' : 'URL',	'media.width' : '宽度',	'media.height' : '高度',	'media.autostart' : '自动播放',	'media.upload' : '上传',	'media.viewServer' : '文件空间',	'image.remoteImage' : '网络图片',	'image.localImage' : '本地上传',	'image.remoteUrl' : '图片地址',	'image.localUrl' : '上传文件',	'image.size' : '图片大小',	'image.width' : '宽',	'image.height' : '高',	'image.resetSize' : '重置大小',	'image.align' : '对齐方式',	'image.defaultAlign' : '默认方式',	'image.leftAlign' : '左对齐',	'image.rightAlign' : '右对齐',	'image.imgTitle' : '图片说明',	'image.upload' : '浏览...',	'image.viewServer' : '图片空间',	'multiimage.uploadDesc' : '允许用户同时上传<%=uploadLimit%>张图片,单张图片容量不超过<%=sizeLimit%>',	'multiimage.startUpload' : '开始上传',	'multiimage.clearAll' : '全部清空',	'multiimage.insertAll' : '全部插入',	'multiimage.queueLimitExceeded' : '文件数量超过限制。',	'multiimage.fileExceedsSizeLimit' : '文件大小超过限制。',	'multiimage.zeroByteFile' : '无法上传空文件。',	'multiimage.invalidFiletype' : '文件类型不正确。',	'multiimage.unknownError' : '发生异常,无法上传。',	'multiimage.pending' : '等待上传',	'multiimage.uploadError' : '上传失败',	'filemanager.emptyFolder' : '空文件夹',	'filemanager.moveup' : '移到上一级文件夹',	'filemanager.viewType' : '显示方式:',	'filemanager.viewImage' : '缩略图',	'filemanager.listImage' : '详细信息',	'filemanager.orderType' : '排序方式:',	'filemanager.fileName' : '名称',	'filemanager.fileSize' : '大小',	'filemanager.fileType' : '类型',	'insertfile.url' : 'URL',	'insertfile.title' : '文件说明',	'insertfile.upload' : '上传',	'insertfile.viewServer' : '文件空间',	'table.cells' : '单元格数',	'table.rows' : '行数',	'table.cols' : '列数',	'table.size' : '大小',	'table.width' : '宽度',	'table.height' : '高度',	'table.percent' : '%',	'table.px' : 'px',	'table.space' : '边距间距',	'table.padding' : '边距',	'table.spacing' : '间距',	'table.align' : '对齐方式',	'table.textAlign' : '水平对齐',	'table.verticalAlign' : '垂直对齐',	'table.alignDefault' : '默认',	'table.alignLeft' : '左对齐',	'table.alignCenter' : '居中',	'table.alignRight' : '右对齐',	'table.alignTop' : '顶部',	'table.alignMiddle' : '中部',	'table.alignBottom' : '底部',	'table.alignBaseline' : '基线',	'table.border' : '边框',	'table.borderWidth' : '边框',	'table.borderColor' : '颜色',	'table.backgroundColor' : '背景颜色',	'map.address' : '地址: ',	'map.search' : '搜索',	'baidumap.address' : '地址: ',	'baidumap.search' : '搜索',	'baidumap.insertDynamicMap' : '插入动态地图',	'anchor.name' : '锚点名称',	'formatblock.formatBlock' : {		h1 : '标题 1',		h2 : '标题 2',		h3 : '标题 3',		h4 : '标题 4',		p : '正 文'	},	'fontname.fontName' : {		'SimSun' : '宋体',		'NSimSun' : '新宋体',		'FangSong_GB2312' : '仿宋_GB2312',		'KaiTi_GB2312' : '楷体_GB2312',		'SimHei' : '黑体',		'Microsoft YaHei' : '微软雅黑',		'Arial' : 'Arial',		'Arial Black' : 'Arial Black',		'Times New Roman' : 'Times New Roman',		'Courier New' : 'Courier New',		'Tahoma' : 'Tahoma',		'Verdana' : 'Verdana'	},	'lineheight.lineHeight' : [		{'1' : '单倍行距'},		{'1.5' : '1.5倍行距'},		{'2' : '2倍行距'},		{'2.5' : '2.5倍行距'},		{'3' : '3倍行距'}	],	'template.selectTemplate' : '可选模板',	'template.replaceContent' : '替换当前内容',	'template.fileList' : {		'1.html' : '图片和文字',		'2.html' : '表格',		'3.html' : '项目编号'	}}, 'zh-CN');KindEditor.options.langType = 'zh-CN';/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('anchor', function(K) {	var self = this, name = 'anchor', lang = self.lang(name + '.');	self.plugin.anchor = {		edit : function() {			var html = ['<div style="padding:20px;">',					'<div class="ke-dialog-row">',					'<label for="keName">' + lang.name + '</label>',					'<input class="ke-input-text" type="text" id="keName" name="name" value="" style="width:100px;" />',					'</div>',					'</div>'].join('');			var dialog = self.createDialog({				name : name,				width : 300,				title : self.lang(name),				body : html,				yesBtn : {					name : self.lang('yes'),					click : function(e) {						self.insertHtml('<a name="' + nameBox.val() + '">').hideDialog().focus();					}				}			});			var div = dialog.div,				nameBox = K('input[name="name"]', div);			var img = self.plugin.getSelectedAnchor();			if (img) {				nameBox.val(unescape(img.attr('data-ke-name')));			}			nameBox[0].focus();			nameBox[0].select();		},		'delete' : function() {			self.plugin.getSelectedAnchor().remove();		}	};	self.clickToolbar(name, self.plugin.anchor.edit);});/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('autoheight', function(K) {	var self = this;	if (!self.autoHeightMode) {		return;	}	var minHeight;	function hideScroll() {		var edit = self.edit;		var body = edit.doc.body;		edit.iframe[0].scroll = 'no';		body.style.overflowY = 'hidden';	}	function resetHeight() {		var edit = self.edit;		var body = edit.doc.body;		edit.iframe.height(minHeight);		self.resize(null, Math.max((K.IE ? body.scrollHeight : body.offsetHeight) + 76, minHeight));	}	function init() {		minHeight = K.removeUnit(self.height);		self.edit.afterChange(resetHeight);		hideScroll();		resetHeight();	}	if (self.isCreated) {		init();	} else {		self.afterCreate(init);	}});/** 如何实现真正的自动高度?* 修改编辑器高度之后,再次获取body内容高度时,最小值只会是当前iframe的设置高度,这样就导致高度只增不减。* 所以每次获取body内容高度之前,先将iframe的高度重置为最小高度,这样就能获取body的实际高度。* 由此就实现了真正的自动高度* 测试:chrome、firefox、IE9、IE8* *//******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('baidumap', function(K) {	var self = this, name = 'baidumap', lang = self.lang(name + '.');	var mapWidth = K.undef(self.mapWidth, 558);	var mapHeight = K.undef(self.mapHeight, 360);	self.clickToolbar(name, function() {		var html = ['<div style="padding:10px 20px;">',			'<div class="ke-header">',			'<div class="ke-left">',			lang.address + ' <input id="kindeditor_plugin_map_address" name="address" class="ke-input-text" value="" style="width:200px;" /> ',			'<span class="ke-button-common ke-button-outer">',			'<input type="button" name="searchBtn" class="ke-button-common ke-button" value="' + lang.search + '" />',			'</span>',			'</div>',			'<div class="ke-right">',			'<input type="checkbox" id="keInsertDynamicMap" name="insertDynamicMap" value="1" /> <label for="keInsertDynamicMap">' + lang.insertDynamicMap + '</label>',			'</div>',			'<div class="ke-clearfix"></div>',			'</div>',			'<div class="ke-map" style="width:' + mapWidth + 'px;height:' + mapHeight + 'px;"></div>',			'</div>'].join('');		var dialog = self.createDialog({			name : name,			width : mapWidth + 42,			title : self.lang(name),			body : html,			yesBtn : {				name : self.lang('yes'),				click : function(e) {					var map = win.map;					var centerObj = map.getCenter();					var center = centerObj.lng + ',' + centerObj.lat;					var zoom = map.getZoom();					var url = [checkbox[0].checked ? self.pluginsPath + 'baidumap/index.html' : 'http://api.map.baidu.com/staticimage',						'?center=' + encodeURIComponent(center),						'&zoom=' + encodeURIComponent(zoom),						'&width=' + mapWidth,						'&height=' + mapHeight,						'&markers=' + encodeURIComponent(center),						'&markerStyles=' + encodeURIComponent('l,A')].join('');					if (checkbox[0].checked) {						self.insertHtml('<iframe src="' + url + '" frameborder="0" style="width:' + (mapWidth + 2) + 'px;height:' + (mapHeight + 2) + 'px;"></iframe>');					} else {						self.exec('insertimage', url);					}					self.hideDialog().focus();				}			},			beforeRemove : function() {				searchBtn.remove();				if (doc) {					doc.write('');				}				iframe.remove();			}		});		var div = dialog.div,			addressBox = K('[name="address"]', div),			searchBtn = K('[name="searchBtn"]', div),			checkbox = K('[name="insertDynamicMap"]', dialog.div),			win, doc;		var iframe = K('<iframe class="ke-textarea" frameborder="0" src="' + self.pluginsPath + 'baidumap/map.html" style="width:' + mapWidth + 'px;height:' + mapHeight + 'px;"></iframe>');		function ready() {			win = iframe[0].contentWindow;			doc = K.iframeDoc(iframe);		}		iframe.bind('load', function() {			iframe.unbind('load');			if (K.IE) {				ready();			} else {				setTimeout(ready, 0);			}		});		K('.ke-map', div).replaceWith(iframe);		searchBtn.click(function() {			win.search(addressBox.val());		});	});});/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('map', function(K) {	var self = this, name = 'map', lang = self.lang(name + '.');	self.clickToolbar(name, function() {		var html = ['<div style="padding:10px 20px;">',			'<div class="ke-dialog-row">',			lang.address + ' <input id="kindeditor_plugin_map_address" name="address" class="ke-input-text" value="" style="width:200px;" /> ',			'<span class="ke-button-common ke-button-outer">',			'<input type="button" name="searchBtn" class="ke-button-common ke-button" value="' + lang.search + '" />',			'</span>',			'</div>',			'<div class="ke-map" style="width:558px;height:360px;"></div>',			'</div>'].join('');		var dialog = self.createDialog({			name : name,			width : 600,			title : self.lang(name),			body : html,			yesBtn : {				name : self.lang('yes'),				click : function(e) {					var geocoder = win.geocoder,						map = win.map,						center = map.getCenter().lat() + ',' + map.getCenter().lng(),						zoom = map.getZoom(),						maptype = map.getMapTypeId(),						url = 'http://maps.googleapis.com/maps/api/staticmap';						url += '?center=' + encodeURIComponent(center);						url += '&zoom=' + encodeURIComponent(zoom);						url += '&size=558x360';						url += '&maptype=' + encodeURIComponent(maptype);						url += '&markers=' + encodeURIComponent(center);						url += '&language=' + self.langType;						url += '&sensor=false';					self.exec('insertimage', url).hideDialog().focus();				}			},			beforeRemove : function() {				searchBtn.remove();				if (doc) {					doc.write('');				}				iframe.remove();			}		});		var div = dialog.div,			addressBox = K('[name="address"]', div),			searchBtn = K('[name="searchBtn"]', div),			win, doc;		var iframeHtml = ['<!doctype html><html><head>',			'<meta name="viewport" content="initial-scale=1.0, user-scalable=no" />',			'<style>',			'	html { height: 100% }',			'	body { height: 100%; margin: 0; padding: 0; background-color: #FFF }',			'	#map_canvas { height: 100% }',			'</style>',			'<script src="http://maps.googleapis.com/maps/api/js?sensor=false&language=' + self.langType + '"></script>',			'<script>',			'var map, geocoder;',			'function initialize() {',			'	var latlng = new google.maps.LatLng(31.230393, 121.473704);',			'	var options = {',			'		zoom: 11,',			'		center: latlng,',			'		disableDefaultUI: true,',			'		panControl: true,',			'		zoomControl: true,',			'		mapTypeControl: true,',			'		scaleControl: true,',			'		streetViewControl: false,',			'		overviewMapControl: true,',			'		mapTypeId: google.maps.MapTypeId.ROADMAP',			'	};',			'	map = new google.maps.Map(document.getElementById("map_canvas"), options);',			'	geocoder = new google.maps.Geocoder();',			'	geocoder.geocode({latLng: latlng}, function(results, status) {',			'		if (status == google.maps.GeocoderStatus.OK) {',			'			if (results[3]) {',			'				parent.document.getElementById("kindeditor_plugin_map_address").value = results[3].formatted_address;',			'			}',			'		}',			'	});',			'}',			'function search(address) {',			'	if (!map) return;',			'	geocoder.geocode({address : address}, function(results, status) {',			'		if (status == google.maps.GeocoderStatus.OK) {',			'			map.setZoom(11);',			'			map.setCenter(results[0].geometry.location);',			'			var marker = new google.maps.Marker({',			'				map: map,',			'				position: results[0].geometry.location',			'			});',			'		} else {',			'			alert("Invalid address: " + address);',			'		}',			'	});',			'}',			'</script>',			'</head>',			'<body onload="initialize();">',			'<div id="map_canvas" style="width:100%; height:100%"></div>',			'</body></html>'].join('\n');		var iframe = K('<iframe class="ke-textarea" frameborder="0" src="' + self.pluginsPath + 'map/map.html" style="width:558px;height:360px;"></iframe>');		function ready() {			win = iframe[0].contentWindow;			doc = K.iframeDoc(iframe);		}		iframe.bind('load', function() {			iframe.unbind('load');			if (K.IE) {				ready();			} else {				setTimeout(ready, 0);			}		});		K('.ke-map', div).replaceWith(iframe);		searchBtn.click(function() {			win.search(addressBox.val());		});	});});/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('clearhtml', function(K) {	var self = this, name = 'clearhtml';	self.clickToolbar(name, function() {		self.focus();		var html = self.html();		html = html.replace(/(<script[^>]*>)([\s\S]*?)(<\/script>)/ig, '');		html = html.replace(/(<style[^>]*>)([\s\S]*?)(<\/style>)/ig, '');		html = K.formatHtml(html, {			a : ['href', 'target'],			embed : ['src', 'width', 'height', 'type', 'loop', 'autostart', 'quality', '.width', '.height', 'align', 'allowscriptaccess'],			img : ['src', 'width', 'height', 'border', 'alt', 'title', '.width', '.height'],			table : ['border'],			'td,th' : ['rowspan', 'colspan'],			'div,hr,br,tbody,tr,p,ol,ul,li,blockquote,h1,h2,h3,h4,h5,h6' : []		});		self.html(html);		self.cmd.selection(true);		self.addBookmark();	});});/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('code', function(K) {	var self = this, name = 'code';	self.clickToolbar(name, function() {		var lang = self.lang(name + '.'),			html = ['<div style="padding:10px 20px;">',				'<div class="ke-dialog-row">',				'<select class="ke-code-type">',				'<option value="js">JavaScript</option>',				'<option value="html">HTML</option>',				'<option value="css">CSS</option>',				'<option value="php">PHP</option>',				'<option value="pl">Perl</option>',				'<option value="py">Python</option>',				'<option value="rb">Ruby</option>',				'<option value="java">Java</option>',				'<option value="vb">ASP/VB</option>',				'<option value="cpp">C/C++</option>',				'<option value="cs">C#</option>',				'<option value="xml">XML</option>',				'<option value="bsh">Shell</option>',				'<option value="">Other</option>',				'</select>',				'</div>',				'<textarea class="ke-textarea" style="width:408px;height:260px;"></textarea>',				'</div>'].join(''),			dialog = self.createDialog({				name : name,				width : 450,				title : self.lang(name),				body : html,				yesBtn : {					name : self.lang('yes'),					click : function(e) {						var type = K('.ke-code-type', dialog.div).val(),							code = textarea.val(),							cls = type === '' ? '' :  ' lang-' + type,							html = '<pre class="prettyprint' + cls + '">\n' + K.escape(code) + '</pre> ';						if (K.trim(code) === '') {							alert(lang.pleaseInput);							textarea[0].focus();							return;						}						self.insertHtml(html).hideDialog().focus();					}				}			}),			textarea = K('textarea', dialog.div);		textarea[0].focus();	});});/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('emoticons', function(K) {	var self = this, name = 'emoticons',		path = (self.emoticonsPath || self.pluginsPath + 'emoticons/images/'),		allowPreview = self.allowPreviewEmoticons === undefined ? true : self.allowPreviewEmoticons,		currentPageNum = 1;	self.clickToolbar(name, function() {		var rows = 5, cols = 9, total = 135, startNum = 0,			cells = rows * cols, pages = Math.ceil(total / cells),			colsHalf = Math.floor(cols / 2),			wrapperDiv = K('<div class="ke-plugin-emoticons"></div>'),			elements = [],			menu = self.createMenu({				name : name,				beforeRemove : function() {					removeEvent();				}			});		menu.div.append(wrapperDiv);		var previewDiv, previewImg;		if (allowPreview) {			previewDiv = K('<div class="ke-preview"></div>').css('right', 0);			previewImg = K('<img class="ke-preview-img" src="' + path + startNum + '.gif" />');			wrapperDiv.append(previewDiv);			previewDiv.append(previewImg);		}		function bindCellEvent(cell, j, num) {			if (previewDiv) {				cell.mouseover(function() {					if (j > colsHalf) {						previewDiv.css('left', 0);						previewDiv.css('right', '');					} else {						previewDiv.css('left', '');						previewDiv.css('right', 0);					}					previewImg.attr('src', path + num + '.gif');					K(this).addClass('ke-on');				});			} else {				cell.mouseover(function() {					K(this).addClass('ke-on');				});			}			cell.mouseout(function() {				K(this).removeClass('ke-on');			});			cell.click(function(e) {				self.insertHtml('<img src="' + path + num + '.gif" border="0" alt="" />').hideMenu().focus();				e.stop();			});		}		function createEmoticonsTable(pageNum, parentDiv) {			var table = document.createElement('table');			parentDiv.append(table);			if (previewDiv) {				K(table).mouseover(function() {					previewDiv.show('block');				});				K(table).mouseout(function() {					previewDiv.hide();				});				elements.push(K(table));			}			table.className = 'ke-table';			table.cellPadding = 0;			table.cellSpacing = 0;			table.border = 0;			var num = (pageNum - 1) * cells + startNum;			for (var i = 0; i < rows; i++) {				var row = table.insertRow(i);				for (var j = 0; j < cols; j++) {					var cell = K(row.insertCell(j));					cell.addClass('ke-cell');					bindCellEvent(cell, j, num);					var span = K('<span class="ke-img"></span>')						.css('background-position', '-' + (24 * num) + 'px 0px')						.css('background-image', 'url(' + path + 'static.gif)');					cell.append(span);					elements.push(cell);					num++;				}			}			return table;		}		var table = createEmoticonsTable(currentPageNum, wrapperDiv);		function removeEvent() {			K.each(elements, function() {				this.unbind();			});		}		var pageDiv;		function bindPageEvent(el, pageNum) {			el.click(function(e) {				removeEvent();				table.parentNode.removeChild(table);				pageDiv.remove();				table = createEmoticonsTable(pageNum, wrapperDiv);				createPageTable(pageNum);				currentPageNum = pageNum;				e.stop();			});		}		function createPageTable(currentPageNum) {			pageDiv = K('<div class="ke-page"></div>');			wrapperDiv.append(pageDiv);			for (var pageNum = 1; pageNum <= pages; pageNum++) {				if (currentPageNum !== pageNum) {					var a = K('<a href="javascript:;">[' + pageNum + ']</a>');					bindPageEvent(a, pageNum);					pageDiv.append(a);					elements.push(a);				} else {					pageDiv.append(K('@[' + pageNum + ']'));				}				pageDiv.append(K('@ '));			}		}		createPageTable(currentPageNum);	});});/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('filemanager', function(K) {	var self = this, name = 'filemanager',		fileManagerJson = K.undef(self.fileManagerJson, self.basePath + 'php/file_manager_json.php'),		imgPath = self.pluginsPath + name + '/images/',		lang = self.lang(name + '.');	function makeFileTitle(filename, filesize, datetime) {		return filename + ' (' + Math.ceil(filesize / 1024) + 'KB, ' + datetime + ')';	}	function bindTitle(el, data) {		if (data.is_dir) {			el.attr('title', data.filename);		} else {			el.attr('title', makeFileTitle(data.filename, data.filesize, data.datetime));		}	}	self.plugin.filemanagerDialog = function(options) {		var width = K.undef(options.width, 650),			height = K.undef(options.height, 510),			dirName = K.undef(options.dirName, ''),			viewType = K.undef(options.viewType, 'VIEW').toUpperCase(),			clickFn = options.clickFn;		var html = [			'<div style="padding:10px 20px;">',			'<div class="ke-plugin-filemanager-header">',			'<div class="ke-left">',			'<img class="ke-inline-block" name="moveupImg" src="' + imgPath + 'go-up.gif" width="16" height="16" border="0" alt="" /> ',			'<a class="ke-inline-block" name="moveupLink" href="javascript:;">' + lang.moveup + '</a>',			'</div>',			'<div class="ke-right">',			lang.viewType + ' <select class="ke-inline-block" name="viewType">',			'<option value="VIEW">' + lang.viewImage + '</option>',			'<option value="LIST">' + lang.listImage + '</option>',			'</select> ',			lang.orderType + ' <select class="ke-inline-block" name="orderType">',			'<option value="NAME">' + lang.fileName + '</option>',			'<option value="SIZE">' + lang.fileSize + '</option>',			'<option value="TYPE">' + lang.fileType + '</option>',			'</select>',			'</div>',			'<div class="ke-clearfix"></div>',			'</div>',			'<div class="ke-plugin-filemanager-body"></div>',			'</div>'		].join('');		var dialog = self.createDialog({			name : name,			width : width,			height : height,			title : self.lang(name),			body : html		}),		div = dialog.div,		bodyDiv = K('.ke-plugin-filemanager-body', div),		moveupImg = K('[name="moveupImg"]', div),		moveupLink = K('[name="moveupLink"]', div),		viewServerBtn = K('[name="viewServer"]', div),		viewTypeBox = K('[name="viewType"]', div),		orderTypeBox = K('[name="orderType"]', div);		function reloadPage(path, order, func) {			var param = 'path=' + path + '&order=' + order + '&dir=' + dirName;			dialog.showLoading(self.lang('ajaxLoading'));			K.ajax(K.addParam(fileManagerJson, param + '&' + new Date().getTime()), function(data) {				dialog.hideLoading();				func(data);			});		}		var elList = [];		function bindEvent(el, result, data, createFunc) {			var fileUrl = K.formatUrl(result.current_url + data.filename, 'absolute'),				dirPath = encodeURIComponent(result.current_dir_path + data.filename + '/');			if (data.is_dir) {				el.click(function(e) {					reloadPage(dirPath, orderTypeBox.val(), createFunc);				});			} else if (data.is_photo) {				el.click(function(e) {					clickFn.call(this, fileUrl, data.filename);				});			} else {				el.click(function(e) {					clickFn.call(this, fileUrl, data.filename);				});			}			elList.push(el);		}		function createCommon(result, createFunc) {			K.each(elList, function() {				this.unbind();			});			moveupLink.unbind();			viewTypeBox.unbind();			orderTypeBox.unbind();			if (result.current_dir_path) {				moveupLink.click(function(e) {					reloadPage(result.moveup_dir_path, orderTypeBox.val(), createFunc);				});			}			function changeFunc() {				if (viewTypeBox.val() == 'VIEW') {					reloadPage(result.current_dir_path, orderTypeBox.val(), createView);				} else {					reloadPage(result.current_dir_path, orderTypeBox.val(), createList);				}			}			viewTypeBox.change(changeFunc);			orderTypeBox.change(changeFunc);			bodyDiv.html('');		}		function createList(result) {			createCommon(result, createList);			var table = document.createElement('table');			table.className = 'ke-table';			table.cellPadding = 0;			table.cellSpacing = 0;			table.border = 0;			bodyDiv.append(table);			var fileList = result.file_list;			for (var i = 0, len = fileList.length; i < len; i++) {				var data = fileList[i], row = K(table.insertRow(i));				row.mouseover(function(e) {					K(this).addClass('ke-on');				})				.mouseout(function(e) {					K(this).removeClass('ke-on');				});				var iconUrl = imgPath + (data.is_dir ? 'folder-16.gif' : 'file-16.gif'),					img = K('<img src="' + iconUrl + '" width="16" height="16" alt="' + data.filename + '" align="absmiddle" />'),					cell0 = K(row[0].insertCell(0)).addClass('ke-cell ke-name').append(img).append(document.createTextNode(' ' + data.filename));				if (!data.is_dir || data.has_file) {					row.css('cursor', 'pointer');					cell0.attr('title', data.filename);					bindEvent(cell0, result, data, createList);				} else {					cell0.attr('title', lang.emptyFolder);				}				K(row[0].insertCell(1)).addClass('ke-cell ke-size').html(data.is_dir ? '-' : Math.ceil(data.filesize / 1024) + 'KB');				K(row[0].insertCell(2)).addClass('ke-cell ke-datetime').html(data.datetime);			}		}		function createView(result) {			createCommon(result, createView);			var fileList = result.file_list;			for (var i = 0, len = fileList.length; i < len; i++) {				var data = fileList[i],					div = K('<div class="ke-inline-block ke-item"></div>');				bodyDiv.append(div);				var photoDiv = K('<div class="ke-inline-block ke-photo"></div>')					.mouseover(function(e) {						K(this).addClass('ke-on');					})					.mouseout(function(e) {						K(this).removeClass('ke-on');					});				div.append(photoDiv);				var fileUrl = result.current_url + data.filename,					iconUrl = data.is_dir ? imgPath + 'folder-64.gif' : (data.is_photo ? fileUrl : imgPath + 'file-64.gif');				var img = K('<img src="' + iconUrl + '" width="80" height="80" alt="' + data.filename + '" />');				if (!data.is_dir || data.has_file) {					photoDiv.css('cursor', 'pointer');					bindTitle(photoDiv, data);					bindEvent(photoDiv, result, data, createView);				} else {					photoDiv.attr('title', lang.emptyFolder);				}				photoDiv.append(img);				div.append('<div class="ke-name" title="' + data.filename + '">' + data.filename + '</div>');			}		}		viewTypeBox.val(viewType);		reloadPage('', orderTypeBox.val(), viewType == 'VIEW' ? createView : createList);		return dialog;	}});/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('flash', function(K) {	var self = this, name = 'flash', lang = self.lang(name + '.'),		allowFlashUpload = K.undef(self.allowFlashUpload, true),		allowFileManager = K.undef(self.allowFileManager, false),		formatUploadUrl = K.undef(self.formatUploadUrl, true),		extraParams = K.undef(self.extraFileUploadParams, {}),		filePostName = K.undef(self.filePostName, 'imgFile'),		uploadJson = K.undef(self.uploadJson, self.basePath + 'php/upload_json.php');	self.plugin.flash = {		edit : function() {			var html = [				'<div style="padding:20px;">',				'<div class="ke-dialog-row">',				'<label for="keUrl" style="width:60px;">' + lang.url + '</label>',				'<input class="ke-input-text" type="text" id="keUrl" name="url" value="" style="width:160px;" />  ',				'<input type="button" class="ke-upload-button" value="' + lang.upload + '" />  ',				'<span class="ke-button-common ke-button-outer">',				'<input type="button" class="ke-button-common ke-button" name="viewServer" value="' + lang.viewServer + '" />',				'</span>',				'</div>',				'<div class="ke-dialog-row">',				'<label for="keWidth" style="width:60px;">' + lang.width + '</label>',				'<input type="text" id="keWidth" class="ke-input-text ke-input-number" name="width" value="550" maxlength="4" /> ',				'</div>',				'<div class="ke-dialog-row">',				'<label for="keHeight" style="width:60px;">' + lang.height + '</label>',				'<input type="text" id="keHeight" class="ke-input-text ke-input-number" name="height" value="400" maxlength="4" /> ',				'</div>',				'</div>'			].join('');			var dialog = self.createDialog({				name : name,				width : 450,				title : self.lang(name),				body : html,				yesBtn : {					name : self.lang('yes'),					click : function(e) {						var url = K.trim(urlBox.val()),							width = widthBox.val(),							height = heightBox.val();						if (url == 'http://' || K.invalidUrl(url)) {							alert(self.lang('invalidUrl'));							urlBox[0].focus();							return;						}						if (!/^\d*$/.test(width)) {							alert(self.lang('invalidWidth'));							widthBox[0].focus();							return;						}						if (!/^\d*$/.test(height)) {							alert(self.lang('invalidHeight'));							heightBox[0].focus();							return;						}						var html = K.mediaImg(self.themesPath + 'common/blank.gif', {								src : url,								type : K.mediaType('.swf'),								width : width,								height : height,								quality : 'high'							});						self.insertHtml(html).hideDialog().focus();					}				}			}),			div = dialog.div,			urlBox = K('[name="url"]', div),			viewServerBtn = K('[name="viewServer"]', div),			widthBox = K('[name="width"]', div),			heightBox = K('[name="height"]', div);			urlBox.val('http://');			if (allowFlashUpload) {				var uploadbutton = K.uploadbutton({					button : K('.ke-upload-button', div)[0],					fieldName : filePostName,					extraParams : extraParams,					url : K.addParam(uploadJson, 'dir=flash'),					afterUpload : function(data) {						dialog.hideLoading();						if (data.error === 0) {							var url = data.url;							if (formatUploadUrl) {								url = K.formatUrl(url, 'absolute');							}							urlBox.val(url);							if (self.afterUpload) {								self.afterUpload.call(self, url, data, name);							}							alert(self.lang('uploadSuccess'));						} else {							alert(data.message);						}					},					afterError : function(html) {						dialog.hideLoading();						self.errorDialog(html);					}				});				uploadbutton.fileBox.change(function(e) {					dialog.showLoading(self.lang('uploadLoading'));					uploadbutton.submit();				});			} else {				K('.ke-upload-button', div).hide();			}			if (allowFileManager) {				viewServerBtn.click(function(e) {					self.loadPlugin('filemanager', function() {						self.plugin.filemanagerDialog({							viewType : 'LIST',							dirName : 'flash',							clickFn : function(url, title) {								if (self.dialogs.length > 1) {									K('[name="url"]', div).val(url);									if (self.afterSelectFile) {										self.afterSelectFile.call(self, url);									}									self.hideDialog();								}							}						});					});				});			} else {				viewServerBtn.hide();			}			var img = self.plugin.getSelectedFlash();			if (img) {				var attrs = K.mediaAttrs(img.attr('data-ke-tag'));				urlBox.val(attrs.src);				widthBox.val(K.removeUnit(img.css('width')) || attrs.width || 0);				heightBox.val(K.removeUnit(img.css('height')) || attrs.height || 0);			}			urlBox[0].focus();			urlBox[0].select();		},		'delete' : function() {			self.plugin.getSelectedFlash().remove();			self.addBookmark();		}	};	self.clickToolbar(name, self.plugin.flash.edit);});/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('image', function(K) {	var self = this, name = 'image',		allowImageUpload = K.undef(self.allowImageUpload, true),		allowImageRemote = K.undef(self.allowImageRemote, true),		formatUploadUrl = K.undef(self.formatUploadUrl, true),		allowFileManager = K.undef(self.allowFileManager, false),		uploadJson = K.undef(self.uploadJson, self.basePath + 'php/upload_json.php'),		imageTabIndex = K.undef(self.imageTabIndex, 0),		imgPath = self.pluginsPath + 'image/images/',		extraParams = K.undef(self.extraFileUploadParams, {}),		filePostName = K.undef(self.filePostName, 'imgFile'),		fillDescAfterUploadImage = K.undef(self.fillDescAfterUploadImage, false),		lang = self.lang(name + '.');	self.plugin.imageDialog = function(options) {		var imageUrl = options.imageUrl,			imageWidth = K.undef(options.imageWidth, ''),			imageHeight = K.undef(options.imageHeight, ''),			imageTitle = K.undef(options.imageTitle, ''),			imageAlign = K.undef(options.imageAlign, ''),			showRemote = K.undef(options.showRemote, true),			showLocal = K.undef(options.showLocal, true),			tabIndex = K.undef(options.tabIndex, 0),			clickFn = options.clickFn;		var target = 'kindeditor_upload_iframe_' + new Date().getTime();		var hiddenElements = [];		for(var k in extraParams){			hiddenElements.push('<input type="hidden" name="' + k + '" value="' + extraParams[k] + '" />');		}		var html = [			'<div style="padding:20px;">',			'<div class="tabs"></div>',			'<div class="tab1" style="display:none;">',			'<div class="ke-dialog-row">',			'<label for="remoteUrl" style="width:60px;">' + lang.remoteUrl + '</label>',			'<input type="text" id="remoteUrl" class="ke-input-text" name="url" value="" style="width:200px;" />  ',			'<span class="ke-button-common ke-button-outer">',			'<input type="button" class="ke-button-common ke-button" name="viewServer" value="' + lang.viewServer + '" />',			'</span>',			'</div>',			'<div class="ke-dialog-row">',			'<label for="remoteWidth" style="width:60px;">' + lang.size + '</label>',			lang.width + ' <input type="text" id="remoteWidth" class="ke-input-text ke-input-number" name="width" value="" maxlength="4" /> ',			lang.height + ' <input type="text" class="ke-input-text ke-input-number" name="height" value="" maxlength="4" /> ',			'<img class="ke-refresh-btn" src="' + imgPath + 'refresh.png" width="16" height="16" alt="" style="cursor:pointer;" title="' + lang.resetSize + '" />',			'</div>',			'<div class="ke-dialog-row">',			'<label style="width:60px;">' + lang.align + '</label>',			'<input type="radio" name="align" class="ke-inline-block" value="" checked="checked" /> <img name="defaultImg" src="' + imgPath + 'align_top.gif" width="23" height="25" alt="" />',			' <input type="radio" name="align" class="ke-inline-block" value="left" /> <img name="leftImg" src="' + imgPath + 'align_left.gif" width="23" height="25" alt="" />',			' <input type="radio" name="align" class="ke-inline-block" value="right" /> <img name="rightImg" src="' + imgPath + 'align_right.gif" width="23" height="25" alt="" />',			'</div>',			'<div class="ke-dialog-row">',			'<label for="remoteTitle" style="width:60px;">' + lang.imgTitle + '</label>',			'<input type="text" id="remoteTitle" class="ke-input-text" name="title" value="" style="width:200px;" />',			'</div>',			'</div>',			'<div class="tab2" style="display:none;">',			'<iframe name="' + target + '" style="display:none;"></iframe>',			'<form class="ke-upload-area ke-form" method="post" enctype="multipart/form-data" target="' + target + '" action="' + K.addParam(uploadJson, 'dir=image') + '">',			'<div class="ke-dialog-row">',			hiddenElements.join(''),			'<label style="width:60px;">' + lang.localUrl + '</label>',			'<input type="text" name="localUrl" class="ke-input-text" tabindex="-1" style="width:200px;" readonly="true" />  ',			'<input type="button" class="ke-upload-button" value="' + lang.upload + '" />',			'</div>',			'</form>',			'</div>',			'</div>'		].join('');		var dialogWidth = showLocal || allowFileManager ? 450 : 400,			dialogHeight = showLocal && showRemote ? 300 : 250;		var dialog = self.createDialog({			name : name,			width : dialogWidth,			height : dialogHeight,			title : self.lang(name),			body : html,			yesBtn : {				name : self.lang('yes'),				click : function(e) {					if (dialog.isLoading) {						return;					}					if (showLocal && showRemote && tabs && tabs.selectedIndex === 1 || !showRemote) {						if (uploadbutton.fileBox.val() == '') {							alert(self.lang('pleaseSelectFile'));							return;						}						dialog.showLoading(self.lang('uploadLoading'));						uploadbutton.submit();						localUrlBox.val('');						return;					}					var url = K.trim(urlBox.val()),						width = widthBox.val(),						height = heightBox.val(),						title = titleBox.val(),						align = '';					alignBox.each(function() {						if (this.checked) {							align = this.value;							return false;						}					});					if (url == 'http://' || K.invalidUrl(url)) {						alert(self.lang('invalidUrl'));						urlBox[0].focus();						return;					}					if (!/^\d*$/.test(width)) {						alert(self.lang('invalidWidth'));						widthBox[0].focus();						return;					}					if (!/^\d*$/.test(height)) {						alert(self.lang('invalidHeight'));						heightBox[0].focus();						return;					}					clickFn.call(self, url, title, width, height, 0, align);				}			},			beforeRemove : function() {				viewServerBtn.unbind();				widthBox.unbind();				heightBox.unbind();				refreshBtn.unbind();			}		}),		div = dialog.div;		var urlBox = K('[name="url"]', div),			localUrlBox = K('[name="localUrl"]', div),			viewServerBtn = K('[name="viewServer"]', div),			widthBox = K('.tab1 [name="width"]', div),			heightBox = K('.tab1 [name="height"]', div),			refreshBtn = K('.ke-refresh-btn', div),			titleBox = K('.tab1 [name="title"]', div),			alignBox = K('.tab1 [name="align"]', div);		var tabs;		if (showRemote && showLocal) {			tabs = K.tabs({				src : K('.tabs', div),				afterSelect : function(i) {}			});			tabs.add({				title : lang.remoteImage,				panel : K('.tab1', div)			});			tabs.add({				title : lang.localImage,				panel : K('.tab2', div)			});			tabs.select(tabIndex);		} else if (showRemote) {			K('.tab1', div).show();		} else if (showLocal) {			K('.tab2', div).show();		}		var uploadbutton = K.uploadbutton({			button : K('.ke-upload-button', div)[0],			fieldName : filePostName,			form : K('.ke-form', div),			target : target,			width: 60,			afterUpload : function(data) {				dialog.hideLoading();				if (data.error === 0) {					var url = data.url;					if (formatUploadUrl) {						url = K.formatUrl(url, 'absolute');					}					if (self.afterUpload) {						self.afterUpload.call(self, url, data, name);					}					if (!fillDescAfterUploadImage) {						clickFn.call(self, url, data.title, data.width, data.height, data.border, data.align);					} else {						K(".ke-dialog-row #remoteUrl", div).val(url);						K(".ke-tabs-li", div)[0].click();						K(".ke-refresh-btn", div).click();					}				} else {					alert(data.message);				}			},			afterError : function(html) {				dialog.hideLoading();				self.errorDialog(html);			}		});		uploadbutton.fileBox.change(function(e) {			localUrlBox.val(uploadbutton.fileBox.val());		});		if (allowFileManager) {			viewServerBtn.click(function(e) {				self.loadPlugin('filemanager', function() {					self.plugin.filemanagerDialog({						viewType : 'VIEW',						dirName : 'image',						clickFn : function(url, title) {							if (self.dialogs.length > 1) {								K('[name="url"]', div).val(url);								if (self.afterSelectFile) {									self.afterSelectFile.call(self, url);								}								self.hideDialog();							}						}					});				});			});		} else {			viewServerBtn.hide();		}		var originalWidth = 0, originalHeight = 0;		function setSize(width, height) {			widthBox.val(width);			heightBox.val(height);			originalWidth = width;			originalHeight = height;		}		refreshBtn.click(function(e) {			var tempImg = K('<img src="' + urlBox.val() + '" />', document).css({				position : 'absolute',				visibility : 'hidden',				top : 0,				left : '-1000px'			});			tempImg.bind('load', function() {				setSize(tempImg.width(), tempImg.height());				tempImg.remove();			});			K(document.body).append(tempImg);		});		widthBox.change(function(e) {			if (originalWidth > 0) {				heightBox.val(Math.round(originalHeight / originalWidth * parseInt(this.value, 10)));			}		});		heightBox.change(function(e) {			if (originalHeight > 0) {				widthBox.val(Math.round(originalWidth / originalHeight * parseInt(this.value, 10)));			}		});		urlBox.val(options.imageUrl);		setSize(options.imageWidth, options.imageHeight);		titleBox.val(options.imageTitle);		alignBox.each(function() {			if (this.value === options.imageAlign) {				this.checked = true;				return false;			}		});		if (showRemote && tabIndex === 0) {			urlBox[0].focus();			urlBox[0].select();		}		return dialog;	};	self.plugin.image = {		edit : function() {			var img = self.plugin.getSelectedImage();			self.plugin.imageDialog({				imageUrl : img ? img.attr('data-ke-src') : 'http://',				imageWidth : img ? img.width() : '',				imageHeight : img ? img.height() : '',				imageTitle : img ? img.attr('title') : '',				imageAlign : img ? img.attr('align') : '',				showRemote : allowImageRemote,				showLocal : allowImageUpload,				tabIndex: img ? 0 : imageTabIndex,				clickFn : function(url, title, width, height, border, align) {					if (img) {						img.attr('src', url);						img.attr('data-ke-src', url);						img.attr('width', width);						img.attr('height', height);						img.attr('title', title);						img.attr('align', align);						img.attr('alt', title);					} else {						self.exec('insertimage', url, title, width, height, border, align);					}					setTimeout(function() {						self.hideDialog().focus();					}, 0);				}			});		},		'delete' : function() {			var target = self.plugin.getSelectedImage();			if (target.parent().name == 'a') {				target = target.parent();			}			target.remove();			self.addBookmark();		}	};	self.clickToolbar(name, self.plugin.image.edit);});/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('insertfile', function(K) {	var self = this, name = 'insertfile',		allowFileUpload = K.undef(self.allowFileUpload, true),		allowFileManager = K.undef(self.allowFileManager, false),		formatUploadUrl = K.undef(self.formatUploadUrl, true),		uploadJson = K.undef(self.uploadJson, self.basePath + 'php/upload_json.php'),		extraParams = K.undef(self.extraFileUploadParams, {}),		filePostName = K.undef(self.filePostName, 'imgFile'),		lang = self.lang(name + '.');	self.plugin.fileDialog = function(options) {		var fileUrl = K.undef(options.fileUrl, 'http://'),			fileTitle = K.undef(options.fileTitle, ''),			clickFn = options.clickFn;		var html = [			'<div style="padding:20px;">',			'<div class="ke-dialog-row">',			'<label for="keUrl" style="width:60px;">' + lang.url + '</label>',			'<input type="text" id="keUrl" name="url" class="ke-input-text" style="width:160px;" />  ',			'<input type="button" class="ke-upload-button" value="' + lang.upload + '" />  ',			'<span class="ke-button-common ke-button-outer">',			'<input type="button" class="ke-button-common ke-button" name="viewServer" value="' + lang.viewServer + '" />',			'</span>',			'</div>',			'<div class="ke-dialog-row">',			'<label for="keTitle" style="width:60px;">' + lang.title + '</label>',			'<input type="text" id="keTitle" class="ke-input-text" name="title" value="" style="width:160px;" /></div>',			'</div>',			'</form>',			'</div>'			].join('');		var dialog = self.createDialog({			name : name,			width : 450,			title : self.lang(name),			body : html,			yesBtn : {				name : self.lang('yes'),				click : function(e) {					var url = K.trim(urlBox.val()),						title = titleBox.val();					if (url == 'http://' || K.invalidUrl(url)) {						alert(self.lang('invalidUrl'));						urlBox[0].focus();						return;					}					if (K.trim(title) === '') {						title = url;					}					clickFn.call(self, url, title);				}			}		}),		div = dialog.div;		var urlBox = K('[name="url"]', div),			viewServerBtn = K('[name="viewServer"]', div),			titleBox = K('[name="title"]', div);		if (allowFileUpload) {			var uploadbutton = K.uploadbutton({				button : K('.ke-upload-button', div)[0],				fieldName : filePostName,				url : K.addParam(uploadJson, 'dir=file'),				extraParams : extraParams,				afterUpload : function(data) {					dialog.hideLoading();					if (data.error === 0) {						var url = data.url;						if (formatUploadUrl) {							url = K.formatUrl(url, 'absolute');						}						urlBox.val(url);						if (self.afterUpload) {							self.afterUpload.call(self, url, data, name);						}						alert(self.lang('uploadSuccess'));					} else {						alert(data.message);					}				},				afterError : function(html) {					dialog.hideLoading();					self.errorDialog(html);				}			});			uploadbutton.fileBox.change(function(e) {				dialog.showLoading(self.lang('uploadLoading'));				uploadbutton.submit();			});		} else {			K('.ke-upload-button', div).hide();		}		if (allowFileManager) {			viewServerBtn.click(function(e) {				self.loadPlugin('filemanager', function() {					self.plugin.filemanagerDialog({						viewType : 'LIST',						dirName : 'file',						clickFn : function(url, title) {							if (self.dialogs.length > 1) {								K('[name="url"]', div).val(url);								if (self.afterSelectFile) {									self.afterSelectFile.call(self, url);								}								self.hideDialog();							}						}					});				});			});		} else {			viewServerBtn.hide();		}		urlBox.val(fileUrl);		titleBox.val(fileTitle);		urlBox[0].focus();		urlBox[0].select();	};	self.clickToolbar(name, function() {		self.plugin.fileDialog({			clickFn : function(url, title) {				var html = '<a class="ke-insertfile" href="' + url + '" data-ke-src="' + url + '" target="_blank">' + title + '</a>';				self.insertHtml(html).hideDialog().focus();			}		});	});});/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('lineheight', function(K) {	var self = this, name = 'lineheight', lang = self.lang(name + '.');	self.clickToolbar(name, function() {		var curVal = '', commonNode = self.cmd.commonNode({'*' : '.line-height'});		if (commonNode) {			curVal = commonNode.css('line-height');		}		var menu = self.createMenu({			name : name,			width : 150		});		K.each(lang.lineHeight, function(i, row) {			K.each(row, function(key, val) {				menu.addItem({					title : val,					checked : curVal === key,					click : function() {						self.cmd.toggle('<span style="line-height:' + key + ';"></span>', {							span : '.line-height=' + key						});						self.updateState();						self.addBookmark();						self.hideMenu();					}				});			});		});	});});/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('link', function(K) {	var self = this, name = 'link';	self.plugin.link = {		edit : function() {			var lang = self.lang(name + '.'),				html = '<div style="padding:20px;">' +					'<div class="ke-dialog-row">' +					'<label for="keUrl" style="width:60px;">' + lang.url + '</label>' +					'<input class="ke-input-text" type="text" id="keUrl" name="url" value="" style="width:260px;" /></div>' +					'<div class="ke-dialog-row"">' +					'<label for="keType" style="width:60px;">' + lang.linkType + '</label>' +					'<select id="keType" name="type"></select>' +					'</div>' +					'</div>',				dialog = self.createDialog({					name : name,					width : 450,					title : self.lang(name),					body : html,					yesBtn : {						name : self.lang('yes'),						click : function(e) {							var url = K.trim(urlBox.val());							if (url == 'http://' || K.invalidUrl(url)) {								alert(self.lang('invalidUrl'));								urlBox[0].focus();								return;							}							self.exec('createlink', url, typeBox.val()).hideDialog().focus();						}					}				}),				div = dialog.div,				urlBox = K('input[name="url"]', div),				typeBox = K('select[name="type"]', div);			urlBox.val('http://');			typeBox[0].options[0] = new Option(lang.newWindow, '_blank');			typeBox[0].options[1] = new Option(lang.selfWindow, '');			self.cmd.selection();			var a = self.plugin.getSelectedLink();			if (a) {				self.cmd.range.selectNode(a[0]);				self.cmd.select();				urlBox.val(a.attr('data-ke-src'));				typeBox.val(a.attr('target'));			}			urlBox[0].focus();			urlBox[0].select();		},		'delete' : function() {			self.exec('unlink', null);		}	};	self.clickToolbar(name, self.plugin.link.edit);});/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('media', function(K) {	var self = this, name = 'media', lang = self.lang(name + '.'),		allowMediaUpload = K.undef(self.allowMediaUpload, true),		allowFileManager = K.undef(self.allowFileManager, false),		formatUploadUrl = K.undef(self.formatUploadUrl, true),		extraParams = K.undef(self.extraFileUploadParams, {}),		filePostName = K.undef(self.filePostName, 'imgFile'),		uploadJson = K.undef(self.uploadJson, self.basePath + 'php/upload_json.php');	self.plugin.media = {		edit : function() {			var html = [				'<div style="padding:20px;">',				'<div class="ke-dialog-row">',				'<label for="keUrl" style="width:60px;">' + lang.url + '</label>',				'<input class="ke-input-text" type="text" id="keUrl" name="url" value="" style="width:160px;" />  ',				'<input type="button" class="ke-upload-button" value="' + lang.upload + '" />  ',				'<span class="ke-button-common ke-button-outer">',				'<input type="button" class="ke-button-common ke-button" name="viewServer" value="' + lang.viewServer + '" />',				'</span>',				'</div>',				'<div class="ke-dialog-row">',				'<label for="keWidth" style="width:60px;">' + lang.width + '</label>',				'<input type="text" id="keWidth" class="ke-input-text ke-input-number" name="width" value="550" maxlength="4" />',				'</div>',				'<div class="ke-dialog-row">',				'<label for="keHeight" style="width:60px;">' + lang.height + '</label>',				'<input type="text" id="keHeight" class="ke-input-text ke-input-number" name="height" value="400" maxlength="4" />',				'</div>',				'<div class="ke-dialog-row">',				'<label for="keAutostart">' + lang.autostart + '</label>',				'<input type="checkbox" id="keAutostart" name="autostart" value="" /> ',				'</div>',				'</div>'			].join('');			var dialog = self.createDialog({				name : name,				width : 450,				height : 230,				title : self.lang(name),				body : html,				yesBtn : {					name : self.lang('yes'),					click : function(e) {						var url = K.trim(urlBox.val()),							width = widthBox.val(),							height = heightBox.val();						if (url == 'http://' || K.invalidUrl(url)) {							alert(self.lang('invalidUrl'));							urlBox[0].focus();							return;						}						if (!/^\d*$/.test(width)) {							alert(self.lang('invalidWidth'));							widthBox[0].focus();							return;						}						if (!/^\d*$/.test(height)) {							alert(self.lang('invalidHeight'));							heightBox[0].focus();							return;						}						var html = K.mediaImg(self.themesPath + 'common/blank.gif', {								src : url,								type : K.mediaType(url),								width : width,								height : height,								autostart : autostartBox[0].checked ? 'true' : 'false',								loop : 'true'							});						self.insertHtml(html).hideDialog().focus();					}				}			}),			div = dialog.div,			urlBox = K('[name="url"]', div),			viewServerBtn = K('[name="viewServer"]', div),			widthBox = K('[name="width"]', div),			heightBox = K('[name="height"]', div),			autostartBox = K('[name="autostart"]', div);			urlBox.val('http://');			if (allowMediaUpload) {				var uploadbutton = K.uploadbutton({					button : K('.ke-upload-button', div)[0],					fieldName : filePostName,					extraParams : extraParams,					url : K.addParam(uploadJson, 'dir=media'),					afterUpload : function(data) {						dialog.hideLoading();						if (data.error === 0) {							var url = data.url;							if (formatUploadUrl) {								url = K.formatUrl(url, 'absolute');							}							urlBox.val(url);							if (self.afterUpload) {								self.afterUpload.call(self, url, data, name);							}							alert(self.lang('uploadSuccess'));						} else {							alert(data.message);						}					},					afterError : function(html) {						dialog.hideLoading();						self.errorDialog(html);					}				});				uploadbutton.fileBox.change(function(e) {					dialog.showLoading(self.lang('uploadLoading'));					uploadbutton.submit();				});			} else {				K('.ke-upload-button', div).hide();			}			if (allowFileManager) {				viewServerBtn.click(function(e) {					self.loadPlugin('filemanager', function() {						self.plugin.filemanagerDialog({							viewType : 'LIST',							dirName : 'media',							clickFn : function(url, title) {								if (self.dialogs.length > 1) {									K('[name="url"]', div).val(url);									if (self.afterSelectFile) {										self.afterSelectFile.call(self, url);									}									self.hideDialog();								}							}						});					});				});			} else {				viewServerBtn.hide();			}			var img = self.plugin.getSelectedMedia();			if (img) {				var attrs = K.mediaAttrs(img.attr('data-ke-tag'));				urlBox.val(attrs.src);				widthBox.val(K.removeUnit(img.css('width')) || attrs.width || 0);				heightBox.val(K.removeUnit(img.css('height')) || attrs.height || 0);				autostartBox[0].checked = (attrs.autostart === 'true');			}			urlBox[0].focus();			urlBox[0].select();		},		'delete' : function() {			self.plugin.getSelectedMedia().remove();			self.addBookmark();		}	};	self.clickToolbar(name, self.plugin.media.edit);});/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/(function(K) {function KSWFUpload(options) {	this.init(options);}K.extend(KSWFUpload, {	init : function(options) {		var self = this;		options.afterError = options.afterError || function(str) {			alert(str);		};		self.options = options;		self.progressbars = {};		self.div = K(options.container).html([			'<div class="ke-swfupload">',			'<div class="ke-swfupload-top">',			'<div class="ke-inline-block ke-swfupload-button">',			'<input type="button" value="Browse" />',			'</div>',			'<div class="ke-inline-block ke-swfupload-desc">' + options.uploadDesc + '</div>',			'<span class="ke-button-common ke-button-outer ke-swfupload-startupload">',			'<input type="button" class="ke-button-common ke-button" value="' + options.startButtonValue + '" />',			'</span>',			'</div>',			'<div class="ke-swfupload-body"></div>',			'</div>'		].join(''));		self.bodyDiv = K('.ke-swfupload-body', self.div);		function showError(itemDiv, msg) {			K('.ke-status > div', itemDiv).hide();			K('.ke-message', itemDiv).addClass('ke-error').show().html(K.escape(msg));		}		var settings = {			debug : false,			upload_url : options.uploadUrl,			flash_url : options.flashUrl,			file_post_name : options.filePostName,			button_placeholder : K('.ke-swfupload-button > input', self.div)[0],			button_image_url: options.buttonImageUrl,			button_width: options.buttonWidth,			button_height: options.buttonHeight,			button_cursor : SWFUpload.CURSOR.HAND,			file_types : options.fileTypes,			file_types_description : options.fileTypesDesc,			file_upload_limit : options.fileUploadLimit,			file_size_limit : options.fileSizeLimit,			post_params : options.postParams,			file_queued_handler : function(file) {				file.url = self.options.fileIconUrl;				self.appendFile(file);			},			file_queue_error_handler : function(file, errorCode, message) {				var errorName = '';				switch (errorCode) {					case SWFUpload.QUEUE_ERROR.QUEUE_LIMIT_EXCEEDED:						errorName = options.queueLimitExceeded;						break;					case SWFUpload.QUEUE_ERROR.FILE_EXCEEDS_SIZE_LIMIT:						errorName = options.fileExceedsSizeLimit;						break;					case SWFUpload.QUEUE_ERROR.ZERO_BYTE_FILE:						errorName = options.zeroByteFile;						break;					case SWFUpload.QUEUE_ERROR.INVALID_FILETYPE:						errorName = options.invalidFiletype;						break;					default:						errorName = options.unknownError;						break;				}				K.DEBUG && alert(errorName);			},			upload_start_handler : function(file) {				var self = this;				var itemDiv = K('div[data-id="' + file.id + '"]', self.bodyDiv);				K('.ke-status > div', itemDiv).hide();				K('.ke-progressbar', itemDiv).show();			},			upload_progress_handler : function(file, bytesLoaded, bytesTotal) {				var percent = Math.round(bytesLoaded * 100 / bytesTotal);				var progressbar = self.progressbars[file.id];				progressbar.bar.css('width', Math.round(percent * 80 / 100) + 'px');				progressbar.percent.html(percent + '%');			},			upload_error_handler : function(file, errorCode, message) {				if (file && file.filestatus == SWFUpload.FILE_STATUS.ERROR) {					var itemDiv = K('div[data-id="' + file.id + '"]', self.bodyDiv).eq(0);					showError(itemDiv, self.options.errorMessage);				}			},			upload_success_handler : function(file, serverData) {				var itemDiv = K('div[data-id="' + file.id + '"]', self.bodyDiv).eq(0);				var data = {};				try {					data = K.json(serverData);				} catch (e) {					self.options.afterError.call(this, '<!doctype html><html>' + serverData + '</html>');				}				if (data.error !== 0) {					showError(itemDiv, K.DEBUG ? data.message : self.options.errorMessage);					return;				}				file.url = data.url;				K('.ke-img', itemDiv).attr('src', file.url).attr('data-status', file.filestatus).data('data', data);				K('.ke-status > div', itemDiv).hide();			}		};		self.swfu = new SWFUpload(settings);		K('.ke-swfupload-startupload input', self.div).click(function() {			self.swfu.startUpload();		});	},	getUrlList : function() {		var list = [];		K('.ke-img', self.bodyDiv).each(function() {			var img = K(this);			var status = img.attr('data-status');			if (status == SWFUpload.FILE_STATUS.COMPLETE) {				list.push(img.data('data'));			}		});		return list;	},	removeFile : function(fileId) {		var self = this;		self.swfu.cancelUpload(fileId);		var itemDiv = K('div[data-id="' + fileId + '"]', self.bodyDiv);		K('.ke-photo', itemDiv).unbind();		K('.ke-delete', itemDiv).unbind();		itemDiv.remove();	},	removeFiles : function() {		var self = this;		K('.ke-item', self.bodyDiv).each(function() {			self.removeFile(K(this).attr('data-id'));		});	},	appendFile : function(file) {		var self = this;		var itemDiv = K('<div class="ke-inline-block ke-item" data-id="' + file.id + '"></div>');		self.bodyDiv.append(itemDiv);		var photoDiv = K('<div class="ke-inline-block ke-photo"></div>')			.mouseover(function(e) {				K(this).addClass('ke-on');			})			.mouseout(function(e) {				K(this).removeClass('ke-on');			});		itemDiv.append(photoDiv);		var img = K('<img src="' + file.url + '" class="ke-img" data-status="' + file.filestatus + '" width="80" height="80" alt="' + file.name + '" />');		photoDiv.append(img);		K('<span class="ke-delete"></span>').appendTo(photoDiv).click(function() {			self.removeFile(file.id);		});		var statusDiv = K('<div class="ke-status"></div>').appendTo(photoDiv);		K(['<div class="ke-progressbar">',			'<div class="ke-progressbar-bar"><div class="ke-progressbar-bar-inner"></div></div>',			'<div class="ke-progressbar-percent">0%</div></div>'].join('')).hide().appendTo(statusDiv);		K('<div class="ke-message">' + self.options.pendingMessage + '</div>').appendTo(statusDiv);		itemDiv.append('<div class="ke-name">' + file.name + '</div>');		self.progressbars[file.id] = {			bar : K('.ke-progressbar-bar-inner', photoDiv),			percent : K('.ke-progressbar-percent', photoDiv)		};	},	remove : function() {		this.removeFiles();		this.swfu.destroy();		this.div.html('');	}});K.swfupload = function(element, options) {	return new KSWFUpload(element, options);};})(KindEditor);KindEditor.plugin('multiimage', function(K) {	var self = this, name = 'multiimage',		formatUploadUrl = K.undef(self.formatUploadUrl, true),		uploadJson = K.undef(self.uploadJson, self.basePath + 'php/upload_json.php'),		imgPath = self.pluginsPath + 'multiimage/images/',		imageSizeLimit = K.undef(self.imageSizeLimit, '1MB'),		imageFileTypes = K.undef(self.imageFileTypes, '*.jpg;*.gif;*.png'),		imageUploadLimit = K.undef(self.imageUploadLimit, 20),		filePostName = K.undef(self.filePostName, 'imgFile'),		lang = self.lang(name + '.');	self.plugin.multiImageDialog = function(options) {		var clickFn = options.clickFn,			uploadDesc = K.tmpl(lang.uploadDesc, {uploadLimit : imageUploadLimit, sizeLimit : imageSizeLimit});		var html = [			'<div style="padding:20px;">',			'<div class="swfupload">',			'</div>',			'</div>'		].join('');		var dialog = self.createDialog({			name : name,			width : 650,			height : 510,			title : self.lang(name),			body : html,			previewBtn : {				name : lang.insertAll,				click : function(e) {					clickFn.call(self, swfupload.getUrlList());				}			},			yesBtn : {				name : lang.clearAll,				click : function(e) {					swfupload.removeFiles();				}			},			beforeRemove : function() {				if (!K.IE || K.V <= 8) {					swfupload.remove();				}			}		}),		div = dialog.div;		var swfupload = K.swfupload({			container : K('.swfupload', div),			buttonImageUrl : imgPath + (self.langType == 'zh-CN' ? 'select-files-zh-CN.png' : 'select-files-en.png'),			buttonWidth : self.langType == 'zh-CN' ? 72 : 88,			buttonHeight : 23,			fileIconUrl : imgPath + 'image.png',			uploadDesc : uploadDesc,			startButtonValue : lang.startUpload,			uploadUrl : K.addParam(uploadJson, 'dir=image'),			flashUrl : imgPath + 'swfupload.swf',			filePostName : filePostName,			fileTypes : '*.jpg;*.jpeg;*.gif;*.png;*.bmp',			fileTypesDesc : 'Image Files',			fileUploadLimit : imageUploadLimit,			fileSizeLimit : imageSizeLimit,			postParams :  K.undef(self.extraFileUploadParams, {}),			queueLimitExceeded : lang.queueLimitExceeded,			fileExceedsSizeLimit : lang.fileExceedsSizeLimit,			zeroByteFile : lang.zeroByteFile,			invalidFiletype : lang.invalidFiletype,			unknownError : lang.unknownError,			pendingMessage : lang.pending,			errorMessage : lang.uploadError,			afterError : function(html) {				self.errorDialog(html);			}		});		return dialog;	};	self.clickToolbar(name, function() {		self.plugin.multiImageDialog({			clickFn : function (urlList) {				if (urlList.length === 0) {					return;				}				K.each(urlList, function(i, data) {					if (self.afterUpload) {						self.afterUpload.call(self, data.url, data, 'multiimage');					}					self.exec('insertimage', data.url, data.title, data.width, data.height, data.border, data.align);				});				setTimeout(function() {					self.hideDialog().focus();				}, 0);			}		});	});});/* ******************* *//* Constructor & Init  *//* ******************* */(function() {window.SWFUpload = function (settings) {	this.initSWFUpload(settings);};SWFUpload.prototype.initSWFUpload = function (settings) {	try {		this.customSettings = {};		this.settings = settings;		this.eventQueue = [];		this.movieName = "KindEditor_SWFUpload_" + SWFUpload.movieCount++;		this.movieElement = null;		SWFUpload.instances[this.movieName] = this;		this.initSettings();		this.loadFlash();		this.displayDebugInfo();	} catch (ex) {		delete SWFUpload.instances[this.movieName];		throw ex;	}};/* *************** *//* Static Members  *//* *************** */SWFUpload.instances = {};SWFUpload.movieCount = 0;SWFUpload.version = "2.2.0 2009-03-25";SWFUpload.QUEUE_ERROR = {	QUEUE_LIMIT_EXCEEDED	  		: -100,	FILE_EXCEEDS_SIZE_LIMIT  		: -110,	ZERO_BYTE_FILE			  		: -120,	INVALID_FILETYPE		  		: -130};SWFUpload.UPLOAD_ERROR = {	HTTP_ERROR				  		: -200,	MISSING_UPLOAD_URL	      		: -210,	IO_ERROR				  		: -220,	SECURITY_ERROR			  		: -230,	UPLOAD_LIMIT_EXCEEDED	  		: -240,	UPLOAD_FAILED			  		: -250,	SPECIFIED_FILE_ID_NOT_FOUND		: -260,	FILE_VALIDATION_FAILED	  		: -270,	FILE_CANCELLED			  		: -280,	UPLOAD_STOPPED					: -290};SWFUpload.FILE_STATUS = {	QUEUED		 : -1,	IN_PROGRESS	 : -2,	ERROR		 : -3,	COMPLETE	 : -4,	CANCELLED	 : -5};SWFUpload.BUTTON_ACTION = {	SELECT_FILE  : -100,	SELECT_FILES : -110,	START_UPLOAD : -120};SWFUpload.CURSOR = {	ARROW : -1,	HAND : -2};SWFUpload.WINDOW_MODE = {	WINDOW : "window",	TRANSPARENT : "transparent",	OPAQUE : "opaque"};SWFUpload.completeURL = function(url) {	if (typeof(url) !== "string" || url.match(/^https?:\/\//i) || url.match(/^\//)) {		return url;	}	var currentURL = window.location.protocol + "//" + window.location.hostname + (window.location.port ? ":" + window.location.port : "");	var indexSlash = window.location.pathname.lastIndexOf("/");	if (indexSlash <= 0) {		path = "/";	} else {		path = window.location.pathname.substr(0, indexSlash) + "/";	}	return /*currentURL +*/ path + url;};/* ******************** *//* Instance Members  *//* ******************** */SWFUpload.prototype.initSettings = function () {	this.ensureDefault = function (settingName, defaultValue) {		this.settings[settingName] = (this.settings[settingName] == undefined) ? defaultValue : this.settings[settingName];	};	this.ensureDefault("upload_url", "");	this.ensureDefault("preserve_relative_urls", false);	this.ensureDefault("file_post_name", "Filedata");	this.ensureDefault("post_params", {});	this.ensureDefault("use_query_string", false);	this.ensureDefault("requeue_on_error", false);	this.ensureDefault("http_success", []);	this.ensureDefault("assume_success_timeout", 0);	this.ensureDefault("file_types", "*.*");	this.ensureDefault("file_types_description", "All Files");	this.ensureDefault("file_size_limit", 0);	this.ensureDefault("file_upload_limit", 0);	this.ensureDefault("file_queue_limit", 0);	this.ensureDefault("flash_url", "swfupload.swf");	this.ensureDefault("prevent_swf_caching", true);	this.ensureDefault("button_image_url", "");	this.ensureDefault("button_width", 1);	this.ensureDefault("button_height", 1);	this.ensureDefault("button_text", "");	this.ensureDefault("button_text_style", "color: #000000; font-size: 16pt;");	this.ensureDefault("button_text_top_padding", 0);	this.ensureDefault("button_text_left_padding", 0);	this.ensureDefault("button_action", SWFUpload.BUTTON_ACTION.SELECT_FILES);	this.ensureDefault("button_disabled", false);	this.ensureDefault("button_placeholder_id", "");	this.ensureDefault("button_placeholder", null);	this.ensureDefault("button_cursor", SWFUpload.CURSOR.ARROW);	this.ensureDefault("button_window_mode", SWFUpload.WINDOW_MODE.WINDOW);	this.ensureDefault("debug", false);	this.settings.debug_enabled = this.settings.debug;	this.settings.return_upload_start_handler = this.returnUploadStart;	this.ensureDefault("swfupload_loaded_handler", null);	this.ensureDefault("file_dialog_start_handler", null);	this.ensureDefault("file_queued_handler", null);	this.ensureDefault("file_queue_error_handler", null);	this.ensureDefault("file_dialog_complete_handler", null);	this.ensureDefault("upload_start_handler", null);	this.ensureDefault("upload_progress_handler", null);	this.ensureDefault("upload_error_handler", null);	this.ensureDefault("upload_success_handler", null);	this.ensureDefault("upload_complete_handler", null);	this.ensureDefault("debug_handler", this.debugMessage);	this.ensureDefault("custom_settings", {});	this.customSettings = this.settings.custom_settings;	if (!!this.settings.prevent_swf_caching) {		this.settings.flash_url = this.settings.flash_url + (this.settings.flash_url.indexOf("?") < 0 ? "?" : "&") + "preventswfcaching=" + new Date().getTime();	}	if (!this.settings.preserve_relative_urls) {		this.settings.upload_url = SWFUpload.completeURL(this.settings.upload_url);		this.settings.button_image_url = SWFUpload.completeURL(this.settings.button_image_url);	}	delete this.ensureDefault;};SWFUpload.prototype.loadFlash = function () {	var targetElement, tempParent;	if (document.getElementById(this.movieName) !== null) {		throw "ID " + this.movieName + " is already in use. The Flash Object could not be added";	}	targetElement = document.getElementById(this.settings.button_placeholder_id) || this.settings.button_placeholder;	if (targetElement == undefined) {		throw "Could not find the placeholder element: " + this.settings.button_placeholder_id;	}	tempParent = document.createElement("div");	tempParent.innerHTML = this.getFlashHTML();	targetElement.parentNode.replaceChild(tempParent.firstChild, targetElement);	if (window[this.movieName] == undefined) {		window[this.movieName] = this.getMovieElement();	}};SWFUpload.prototype.getFlashHTML = function () {	var classid = '';	if (KindEditor.IE && KindEditor.V > 8) {		classid = ' classid = "clsid:d27cdb6e-ae6d-11cf-96b8-444553540000"';	}	return ['<object id="', this.movieName, '"' + classid + ' type="application/x-shockwave-flash" data="', this.settings.flash_url, '" width="', this.settings.button_width, '" height="', this.settings.button_height, '" class="swfupload">',				'<param name="wmode" value="', this.settings.button_window_mode, '" />',				'<param name="movie" value="', this.settings.flash_url, '" />',				'<param name="quality" value="high" />',				'<param name="menu" value="false" />',				'<param name="allowScriptAccess" value="always" />',				'<param name="flashvars" value="' + this.getFlashVars() + '" />',				'</object>'].join("");};SWFUpload.prototype.getFlashVars = function () {	var paramString = this.buildParamString();	var httpSuccessString = this.settings.http_success.join(",");	return ["movieName=", encodeURIComponent(this.movieName),			"&uploadURL=", encodeURIComponent(this.settings.upload_url),			"&useQueryString=", encodeURIComponent(this.settings.use_query_string),			"&requeueOnError=", encodeURIComponent(this.settings.requeue_on_error),			"&httpSuccess=", encodeURIComponent(httpSuccessString),			"&assumeSuccessTimeout=", encodeURIComponent(this.settings.assume_success_timeout),			"&params=", encodeURIComponent(paramString),			"&filePostName=", encodeURIComponent(this.settings.file_post_name),			"&fileTypes=", encodeURIComponent(this.settings.file_types),			"&fileTypesDescription=", encodeURIComponent(this.settings.file_types_description),			"&fileSizeLimit=", encodeURIComponent(this.settings.file_size_limit),			"&fileUploadLimit=", encodeURIComponent(this.settings.file_upload_limit),			"&fileQueueLimit=", encodeURIComponent(this.settings.file_queue_limit),			"&debugEnabled=", encodeURIComponent(this.settings.debug_enabled),			"&buttonImageURL=", encodeURIComponent(this.settings.button_image_url),			"&buttonWidth=", encodeURIComponent(this.settings.button_width),			"&buttonHeight=", encodeURIComponent(this.settings.button_height),			"&buttonText=", encodeURIComponent(this.settings.button_text),			"&buttonTextTopPadding=", encodeURIComponent(this.settings.button_text_top_padding),			"&buttonTextLeftPadding=", encodeURIComponent(this.settings.button_text_left_padding),			"&buttonTextStyle=", encodeURIComponent(this.settings.button_text_style),			"&buttonAction=", encodeURIComponent(this.settings.button_action),			"&buttonDisabled=", encodeURIComponent(this.settings.button_disabled),			"&buttonCursor=", encodeURIComponent(this.settings.button_cursor)		].join("");};SWFUpload.prototype.getMovieElement = function () {	if (this.movieElement == undefined) {		this.movieElement = document.getElementById(this.movieName);	}	if (this.movieElement === null) {		throw "Could not find Flash element";	}	return this.movieElement;};SWFUpload.prototype.buildParamString = function () {	var postParams = this.settings.post_params;	var paramStringPairs = [];	if (typeof(postParams) === "object") {		for (var name in postParams) {			if (postParams.hasOwnProperty(name)) {				paramStringPairs.push(encodeURIComponent(name.toString()) + "=" + encodeURIComponent(postParams[name].toString()));			}		}	}	return paramStringPairs.join("&");};SWFUpload.prototype.destroy = function () {	try {		this.cancelUpload(null, false);		var movieElement = null;		movieElement = this.getMovieElement();		if (movieElement && typeof(movieElement.CallFunction) === "unknown") {			for (var i in movieElement) {				try {					if (typeof(movieElement[i]) === "function") {						movieElement[i] = null;					}				} catch (ex1) {}			}			try {				movieElement.parentNode.removeChild(movieElement);			} catch (ex) {}		}		window[this.movieName] = null;		SWFUpload.instances[this.movieName] = null;		delete SWFUpload.instances[this.movieName];		this.movieElement = null;		this.settings = null;		this.customSettings = null;		this.eventQueue = null;		this.movieName = null;		return true;	} catch (ex2) {		return false;	}};SWFUpload.prototype.displayDebugInfo = function () {	this.debug(		[			"---SWFUpload Instance Info---\n",			"Version: ", SWFUpload.version, "\n",			"Movie Name: ", this.movieName, "\n",			"Settings:\n",			"\t", "upload_url:               ", this.settings.upload_url, "\n",			"\t", "flash_url:                ", this.settings.flash_url, "\n",			"\t", "use_query_string:         ", this.settings.use_query_string.toString(), "\n",			"\t", "requeue_on_error:         ", this.settings.requeue_on_error.toString(), "\n",			"\t", "http_success:             ", this.settings.http_success.join(", "), "\n",			"\t", "assume_success_timeout:   ", this.settings.assume_success_timeout, "\n",			"\t", "file_post_name:           ", this.settings.file_post_name, "\n",			"\t", "post_params:              ", this.settings.post_params.toString(), "\n",			"\t", "file_types:               ", this.settings.file_types, "\n",			"\t", "file_types_description:   ", this.settings.file_types_description, "\n",			"\t", "file_size_limit:          ", this.settings.file_size_limit, "\n",			"\t", "file_upload_limit:        ", this.settings.file_upload_limit, "\n",			"\t", "file_queue_limit:         ", this.settings.file_queue_limit, "\n",			"\t", "debug:                    ", this.settings.debug.toString(), "\n",			"\t", "prevent_swf_caching:      ", this.settings.prevent_swf_caching.toString(), "\n",			"\t", "button_placeholder_id:    ", this.settings.button_placeholder_id.toString(), "\n",			"\t", "button_placeholder:       ", (this.settings.button_placeholder ? "Set" : "Not Set"), "\n",			"\t", "button_image_url:         ", this.settings.button_image_url.toString(), "\n",			"\t", "button_width:             ", this.settings.button_width.toString(), "\n",			"\t", "button_height:            ", this.settings.button_height.toString(), "\n",			"\t", "button_text:              ", this.settings.button_text.toString(), "\n",			"\t", "button_text_style:        ", this.settings.button_text_style.toString(), "\n",			"\t", "button_text_top_padding:  ", this.settings.button_text_top_padding.toString(), "\n",			"\t", "button_text_left_padding: ", this.settings.button_text_left_padding.toString(), "\n",			"\t", "button_action:            ", this.settings.button_action.toString(), "\n",			"\t", "button_disabled:          ", this.settings.button_disabled.toString(), "\n",			"\t", "custom_settings:          ", this.settings.custom_settings.toString(), "\n",			"Event Handlers:\n",			"\t", "swfupload_loaded_handler assigned:  ", (typeof this.settings.swfupload_loaded_handler === "function").toString(), "\n",			"\t", "file_dialog_start_handler assigned: ", (typeof this.settings.file_dialog_start_handler === "function").toString(), "\n",			"\t", "file_queued_handler assigned:       ", (typeof this.settings.file_queued_handler === "function").toString(), "\n",			"\t", "file_queue_error_handler assigned:  ", (typeof this.settings.file_queue_error_handler === "function").toString(), "\n",			"\t", "upload_start_handler assigned:      ", (typeof this.settings.upload_start_handler === "function").toString(), "\n",			"\t", "upload_progress_handler assigned:   ", (typeof this.settings.upload_progress_handler === "function").toString(), "\n",			"\t", "upload_error_handler assigned:      ", (typeof this.settings.upload_error_handler === "function").toString(), "\n",			"\t", "upload_success_handler assigned:    ", (typeof this.settings.upload_success_handler === "function").toString(), "\n",			"\t", "upload_complete_handler assigned:   ", (typeof this.settings.upload_complete_handler === "function").toString(), "\n",			"\t", "debug_handler assigned:             ", (typeof this.settings.debug_handler === "function").toString(), "\n"		].join("")	);};/* Note: addSetting and getSetting are no longer used by SWFUpload but are included	the maintain v2 API compatibility*/SWFUpload.prototype.addSetting = function (name, value, default_value) {    if (value == undefined) {        return (this.settings[name] = default_value);    } else {        return (this.settings[name] = value);	}};SWFUpload.prototype.getSetting = function (name) {    if (this.settings[name] != undefined) {        return this.settings[name];	}    return "";};SWFUpload.prototype.callFlash = function (functionName, argumentArray) {	argumentArray = argumentArray || [];	var movieElement = this.getMovieElement();	var returnValue, returnString;	try {		returnString = movieElement.CallFunction('<invoke name="' + functionName + '" returntype="javascript">' + __flash__argumentsToXML(argumentArray, 0) + '</invoke>');		returnValue = eval(returnString);	} catch (ex) {		throw "Call to " + functionName + " failed";	}	if (returnValue != undefined && typeof returnValue.post === "object") {		returnValue = this.unescapeFilePostParams(returnValue);	}	return returnValue;};/* *****************************	-- Flash control methods --	Your UI should use these	to operate SWFUpload   ***************************** */SWFUpload.prototype.selectFile = function () {	this.callFlash("SelectFile");};SWFUpload.prototype.selectFiles = function () {	this.callFlash("SelectFiles");};SWFUpload.prototype.startUpload = function (fileID) {	this.callFlash("StartUpload", [fileID]);};SWFUpload.prototype.cancelUpload = function (fileID, triggerErrorEvent) {	if (triggerErrorEvent !== false) {		triggerErrorEvent = true;	}	this.callFlash("CancelUpload", [fileID, triggerErrorEvent]);};SWFUpload.prototype.stopUpload = function () {	this.callFlash("StopUpload");};/* ************************ * Settings methods *   These methods change the SWFUpload settings. *   SWFUpload settings should not be changed directly on the settings object *   since many of the settings need to be passed to Flash in order to take *   effect. * *********************** */SWFUpload.prototype.getStats = function () {	return this.callFlash("GetStats");};SWFUpload.prototype.setStats = function (statsObject) {	this.callFlash("SetStats", [statsObject]);};SWFUpload.prototype.getFile = function (fileID) {	if (typeof(fileID) === "number") {		return this.callFlash("GetFileByIndex", [fileID]);	} else {		return this.callFlash("GetFile", [fileID]);	}};SWFUpload.prototype.addFileParam = function (fileID, name, value) {	return this.callFlash("AddFileParam", [fileID, name, value]);};SWFUpload.prototype.removeFileParam = function (fileID, name) {	this.callFlash("RemoveFileParam", [fileID, name]);};SWFUpload.prototype.setUploadURL = function (url) {	this.settings.upload_url = url.toString();	this.callFlash("SetUploadURL", [url]);};SWFUpload.prototype.setPostParams = function (paramsObject) {	this.settings.post_params = paramsObject;	this.callFlash("SetPostParams", [paramsObject]);};SWFUpload.prototype.addPostParam = function (name, value) {	this.settings.post_params[name] = value;	this.callFlash("SetPostParams", [this.settings.post_params]);};SWFUpload.prototype.removePostParam = function (name) {	delete this.settings.post_params[name];	this.callFlash("SetPostParams", [this.settings.post_params]);};SWFUpload.prototype.setFileTypes = function (types, description) {	this.settings.file_types = types;	this.settings.file_types_description = description;	this.callFlash("SetFileTypes", [types, description]);};SWFUpload.prototype.setFileSizeLimit = function (fileSizeLimit) {	this.settings.file_size_limit = fileSizeLimit;	this.callFlash("SetFileSizeLimit", [fileSizeLimit]);};SWFUpload.prototype.setFileUploadLimit = function (fileUploadLimit) {	this.settings.file_upload_limit = fileUploadLimit;	this.callFlash("SetFileUploadLimit", [fileUploadLimit]);};SWFUpload.prototype.setFileQueueLimit = function (fileQueueLimit) {	this.settings.file_queue_limit = fileQueueLimit;	this.callFlash("SetFileQueueLimit", [fileQueueLimit]);};SWFUpload.prototype.setFilePostName = function (filePostName) {	this.settings.file_post_name = filePostName;	this.callFlash("SetFilePostName", [filePostName]);};SWFUpload.prototype.setUseQueryString = function (useQueryString) {	this.settings.use_query_string = useQueryString;	this.callFlash("SetUseQueryString", [useQueryString]);};SWFUpload.prototype.setRequeueOnError = function (requeueOnError) {	this.settings.requeue_on_error = requeueOnError;	this.callFlash("SetRequeueOnError", [requeueOnError]);};SWFUpload.prototype.setHTTPSuccess = function (http_status_codes) {	if (typeof http_status_codes === "string") {		http_status_codes = http_status_codes.replace(" ", "").split(",");	}	this.settings.http_success = http_status_codes;	this.callFlash("SetHTTPSuccess", [http_status_codes]);};SWFUpload.prototype.setAssumeSuccessTimeout = function (timeout_seconds) {	this.settings.assume_success_timeout = timeout_seconds;	this.callFlash("SetAssumeSuccessTimeout", [timeout_seconds]);};SWFUpload.prototype.setDebugEnabled = function (debugEnabled) {	this.settings.debug_enabled = debugEnabled;	this.callFlash("SetDebugEnabled", [debugEnabled]);};SWFUpload.prototype.setButtonImageURL = function (buttonImageURL) {	if (buttonImageURL == undefined) {		buttonImageURL = "";	}	this.settings.button_image_url = buttonImageURL;	this.callFlash("SetButtonImageURL", [buttonImageURL]);};SWFUpload.prototype.setButtonDimensions = function (width, height) {	this.settings.button_width = width;	this.settings.button_height = height;	var movie = this.getMovieElement();	if (movie != undefined) {		movie.style.width = width + "px";		movie.style.height = height + "px";	}	this.callFlash("SetButtonDimensions", [width, height]);};SWFUpload.prototype.setButtonText = function (html) {	this.settings.button_text = html;	this.callFlash("SetButtonText", [html]);};SWFUpload.prototype.setButtonTextPadding = function (left, top) {	this.settings.button_text_top_padding = top;	this.settings.button_text_left_padding = left;	this.callFlash("SetButtonTextPadding", [left, top]);};SWFUpload.prototype.setButtonTextStyle = function (css) {	this.settings.button_text_style = css;	this.callFlash("SetButtonTextStyle", [css]);};SWFUpload.prototype.setButtonDisabled = function (isDisabled) {	this.settings.button_disabled = isDisabled;	this.callFlash("SetButtonDisabled", [isDisabled]);};SWFUpload.prototype.setButtonAction = function (buttonAction) {	this.settings.button_action = buttonAction;	this.callFlash("SetButtonAction", [buttonAction]);};SWFUpload.prototype.setButtonCursor = function (cursor) {	this.settings.button_cursor = cursor;	this.callFlash("SetButtonCursor", [cursor]);};/* *******************************	Flash Event Interfaces	These functions are used by Flash to trigger the various	events.	All these functions a Private.	Because the ExternalInterface library is buggy the event calls	are added to a queue and the queue then executed by a setTimeout.	This ensures that events are executed in a determinate order and that	the ExternalInterface bugs are avoided.******************************* */SWFUpload.prototype.queueEvent = function (handlerName, argumentArray) {	if (argumentArray == undefined) {		argumentArray = [];	} else if (!(argumentArray instanceof Array)) {		argumentArray = [argumentArray];	}	var self = this;	if (typeof this.settings[handlerName] === "function") {		this.eventQueue.push(function () {			this.settings[handlerName].apply(this, argumentArray);		});		setTimeout(function () {			self.executeNextEvent();		}, 0);	} else if (this.settings[handlerName] !== null) {		throw "Event handler " + handlerName + " is unknown or is not a function";	}};SWFUpload.prototype.executeNextEvent = function () {	var  f = this.eventQueue ? this.eventQueue.shift() : null;	if (typeof(f) === "function") {		f.apply(this);	}};SWFUpload.prototype.unescapeFilePostParams = function (file) {	var reg = /[$]([0-9a-f]{4})/i;	var unescapedPost = {};	var uk;	if (file != undefined) {		for (var k in file.post) {			if (file.post.hasOwnProperty(k)) {				uk = k;				var match;				while ((match = reg.exec(uk)) !== null) {					uk = uk.replace(match[0], String.fromCharCode(parseInt("0x" + match[1], 16)));				}				unescapedPost[uk] = file.post[k];			}		}		file.post = unescapedPost;	}	return file;};SWFUpload.prototype.testExternalInterface = function () {	try {		return this.callFlash("TestExternalInterface");	} catch (ex) {		return false;	}};SWFUpload.prototype.flashReady = function () {	var movieElement = this.getMovieElement();	if (!movieElement) {		this.debug("Flash called back ready but the flash movie can't be found.");		return;	}	this.cleanUp(movieElement);	this.queueEvent("swfupload_loaded_handler");};SWFUpload.prototype.cleanUp = function (movieElement) {	try {		if (this.movieElement && typeof(movieElement.CallFunction) === "unknown") {			this.debug("Removing Flash functions hooks (this should only run in IE and should prevent memory leaks)");			for (var key in movieElement) {				try {					if (typeof(movieElement[key]) === "function") {						movieElement[key] = null;					}				} catch (ex) {				}			}		}	} catch (ex1) {	}	window["__flash__removeCallback"] = function (instance, name) {		try {			if (instance) {				instance[name] = null;			}		} catch (flashEx) {		}	};};/* This is a chance to do something before the browse window opens */SWFUpload.prototype.fileDialogStart = function () {	this.queueEvent("file_dialog_start_handler");};/* Called when a file is successfully added to the queue. */SWFUpload.prototype.fileQueued = function (file) {	file = this.unescapeFilePostParams(file);	this.queueEvent("file_queued_handler", file);};/* Handle errors that occur when an attempt to queue a file fails. */SWFUpload.prototype.fileQueueError = function (file, errorCode, message) {	file = this.unescapeFilePostParams(file);	this.queueEvent("file_queue_error_handler", [file, errorCode, message]);};/* Called after the file dialog has closed and the selected files have been queued.	You could call startUpload here if you want the queued files to begin uploading immediately. */SWFUpload.prototype.fileDialogComplete = function (numFilesSelected, numFilesQueued, numFilesInQueue) {	this.queueEvent("file_dialog_complete_handler", [numFilesSelected, numFilesQueued, numFilesInQueue]);};SWFUpload.prototype.uploadStart = function (file) {	file = this.unescapeFilePostParams(file);	this.queueEvent("return_upload_start_handler", file);};SWFUpload.prototype.returnUploadStart = function (file) {	var returnValue;	if (typeof this.settings.upload_start_handler === "function") {		file = this.unescapeFilePostParams(file);		returnValue = this.settings.upload_start_handler.call(this, file);	} else if (this.settings.upload_start_handler != undefined) {		throw "upload_start_handler must be a function";	}	if (returnValue === undefined) {		returnValue = true;	}	returnValue = !!returnValue;	this.callFlash("ReturnUploadStart", [returnValue]);};SWFUpload.prototype.uploadProgress = function (file, bytesComplete, bytesTotal) {	file = this.unescapeFilePostParams(file);	this.queueEvent("upload_progress_handler", [file, bytesComplete, bytesTotal]);};SWFUpload.prototype.uploadError = function (file, errorCode, message) {	file = this.unescapeFilePostParams(file);	this.queueEvent("upload_error_handler", [file, errorCode, message]);};SWFUpload.prototype.uploadSuccess = function (file, serverData, responseReceived) {	file = this.unescapeFilePostParams(file);	this.queueEvent("upload_success_handler", [file, serverData, responseReceived]);};SWFUpload.prototype.uploadComplete = function (file) {	file = this.unescapeFilePostParams(file);	this.queueEvent("upload_complete_handler", file);};/* Called by SWFUpload JavaScript and Flash functions when debug is enabled. By default it writes messages to the   internal debug console.  You can override this event and have messages written where you want. */SWFUpload.prototype.debug = function (message) {	this.queueEvent("debug_handler", message);};/* **********************************	Debug Console	The debug console is a self contained, in page location	for debug message to be sent.  The Debug Console adds	itself to the body if necessary.	The console is automatically scrolled as messages appear.	If you are using your own debug handler or when you deploy to production and	have debug disabled you can remove these functions to reduce the file size	and complexity.********************************** */SWFUpload.prototype.debugMessage = function (message) {	if (this.settings.debug) {		var exceptionMessage, exceptionValues = [];		if (typeof message === "object" && typeof message.name === "string" && typeof message.message === "string") {			for (var key in message) {				if (message.hasOwnProperty(key)) {					exceptionValues.push(key + ": " + message[key]);				}			}			exceptionMessage = exceptionValues.join("\n") || "";			exceptionValues = exceptionMessage.split("\n");			exceptionMessage = "EXCEPTION: " + exceptionValues.join("\nEXCEPTION: ");			SWFUpload.Console.writeLine(exceptionMessage);		} else {			SWFUpload.Console.writeLine(message);		}	}};SWFUpload.Console = {};SWFUpload.Console.writeLine = function (message) {	var console, documentForm;	try {		console = document.getElementById("SWFUpload_Console");		if (!console) {			documentForm = document.createElement("form");			document.getElementsByTagName("body")[0].appendChild(documentForm);			console = document.createElement("textarea");			console.id = "SWFUpload_Console";			console.style.fontFamily = "monospace";			console.setAttribute("wrap", "off");			console.wrap = "off";			console.style.overflow = "auto";			console.style.width = "700px";			console.style.height = "350px";			console.style.margin = "5px";			documentForm.appendChild(console);		}		console.value += message + "\n";		console.scrollTop = console.scrollHeight - console.clientHeight;	} catch (ex) {		alert("Exception: " + ex.name + " Message: " + ex.message);	}};})();(function() {/*	Queue Plug-in	Features:		*Adds a cancelQueue() method for cancelling the entire queue.		*All queued files are uploaded when startUpload() is called.		*If false is returned from uploadComplete then the queue upload is stopped.		 If false is not returned (strict comparison) then the queue upload is continued.		*Adds a QueueComplete event that is fired when all the queued files have finished uploading.		 Set the event handler with the queue_complete_handler setting.	*/if (typeof(SWFUpload) === "function") {	SWFUpload.queue = {};	SWFUpload.prototype.initSettings = (function (oldInitSettings) {		return function () {			if (typeof(oldInitSettings) === "function") {				oldInitSettings.call(this);			}			this.queueSettings = {};			this.queueSettings.queue_cancelled_flag = false;			this.queueSettings.queue_upload_count = 0;			this.queueSettings.user_upload_complete_handler = this.settings.upload_complete_handler;			this.queueSettings.user_upload_start_handler = this.settings.upload_start_handler;			this.settings.upload_complete_handler = SWFUpload.queue.uploadCompleteHandler;			this.settings.upload_start_handler = SWFUpload.queue.uploadStartHandler;			this.settings.queue_complete_handler = this.settings.queue_complete_handler || null;		};	})(SWFUpload.prototype.initSettings);	SWFUpload.prototype.startUpload = function (fileID) {		this.queueSettings.queue_cancelled_flag = false;		this.callFlash("StartUpload", [fileID]);	};	SWFUpload.prototype.cancelQueue = function () {		this.queueSettings.queue_cancelled_flag = true;		this.stopUpload();		var stats = this.getStats();		while (stats.files_queued > 0) {			this.cancelUpload();			stats = this.getStats();		}	};	SWFUpload.queue.uploadStartHandler = function (file) {		var returnValue;		if (typeof(this.queueSettings.user_upload_start_handler) === "function") {			returnValue = this.queueSettings.user_upload_start_handler.call(this, file);		}		returnValue = (returnValue === false) ? false : true;		this.queueSettings.queue_cancelled_flag = !returnValue;		return returnValue;	};	SWFUpload.queue.uploadCompleteHandler = function (file) {		var user_upload_complete_handler = this.queueSettings.user_upload_complete_handler;		var continueUpload;		if (file.filestatus === SWFUpload.FILE_STATUS.COMPLETE) {			this.queueSettings.queue_upload_count++;		}		if (typeof(user_upload_complete_handler) === "function") {			continueUpload = (user_upload_complete_handler.call(this, file) === false) ? false : true;		} else if (file.filestatus === SWFUpload.FILE_STATUS.QUEUED) {			continueUpload = false;		} else {			continueUpload = true;		}		if (continueUpload) {			var stats = this.getStats();			if (stats.files_queued > 0 && this.queueSettings.queue_cancelled_flag === false) {				this.startUpload();			} else if (this.queueSettings.queue_cancelled_flag === false) {				this.queueEvent("queue_complete_handler", [this.queueSettings.queue_upload_count]);				this.queueSettings.queue_upload_count = 0;			} else {				this.queueSettings.queue_cancelled_flag = false;				this.queueSettings.queue_upload_count = 0;			}		}	};}})();/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('pagebreak', function(K) {	var self = this;	var name = 'pagebreak';	var pagebreakHtml = K.undef(self.pagebreakHtml, '<hr style="page-break-after: always;" class="ke-pagebreak" />');	self.clickToolbar(name, function() {		var cmd = self.cmd, range = cmd.range;		self.focus();		var tail = self.newlineTag == 'br' || K.WEBKIT ? '' : '<span id="__kindeditor_tail_tag__"></span>';		self.insertHtml(pagebreakHtml + tail);		if (tail !== '') {			var p = K('#__kindeditor_tail_tag__', self.edit.doc);			range.selectNodeContents(p[0]);			p.removeAttr('id');			cmd.select();		}	});});/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('plainpaste', function(K) {	var self = this, name = 'plainpaste';	self.clickToolbar(name, function() {		var lang = self.lang(name + '.'),			html = '<div style="padding:10px 20px;">' +				'<div style="margin-bottom:10px;">' + lang.comment + '</div>' +				'<textarea class="ke-textarea" style="width:408px;height:260px;"></textarea>' +				'</div>',			dialog = self.createDialog({				name : name,				width : 450,				title : self.lang(name),				body : html,				yesBtn : {					name : self.lang('yes'),					click : function(e) {						var html = textarea.val();						html = K.escape(html);						html = html.replace(/ {2}/g, '  ');						if (self.newlineTag == 'p') {							html = html.replace(/^/, '<p>').replace(/$/, '</p>').replace(/\n/g, '</p><p>');						} else {							html = html.replace(/\n/g, '<br />$&');						}						self.insertHtml(html).hideDialog().focus();					}				}			}),			textarea = K('textarea', dialog.div);		textarea[0].focus();	});});/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('preview', function(K) {	var self = this, name = 'preview', undefined;	self.clickToolbar(name, function() {		var lang = self.lang(name + '.'),			html = '<div style="padding:10px 20px;">' +				'<iframe class="ke-textarea" frameborder="0" style="width:708px;height:400px;"></iframe>' +				'</div>',			dialog = self.createDialog({				name : name,				width : 750,				title : self.lang(name),				body : html			}),			iframe = K('iframe', dialog.div),			doc = K.iframeDoc(iframe);		doc.open();		doc.write(self.fullHtml());		doc.close();		K(doc.body).css('background-color', '#FFF');		iframe[0].contentWindow.focus();	});});/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('quickformat', function(K) {	var self = this, name = 'quickformat',		blockMap = K.toMap('blockquote,center,div,h1,h2,h3,h4,h5,h6,p');	function getFirstChild(knode) {		var child = knode.first();		while (child && child.first()) {			child = child.first();		}		return child;	}	self.clickToolbar(name, function() {		self.focus();		var doc = self.edit.doc,			range = self.cmd.range,			child = K(doc.body).first(), next,			nodeList = [], subList = [],			bookmark = range.createBookmark(true);		while(child) {			next = child.next();			var firstChild = getFirstChild(child);			if (!firstChild || firstChild.name != 'img') {				if (blockMap[child.name]) {					child.html(child.html().replace(/^(\s| | )+/ig, ''));					child.css('text-indent', '2em');				} else {					subList.push(child);				}				if (!next || (blockMap[next.name] || blockMap[child.name] && !blockMap[next.name])) {					if (subList.length > 0) {						nodeList.push(subList);					}					subList = [];				}			}			child = next;		}		K.each(nodeList, function(i, subList) {			var wrapper = K('<p style="text-indent:2em;"></p>', doc);			subList[0].before(wrapper);			K.each(subList, function(i, knode) {				wrapper.append(knode);			});		});		range.moveToBookmark(bookmark);		self.addBookmark();	});});/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('table', function(K) {	var self = this, name = 'table', lang = self.lang(name + '.'), zeroborder = 'ke-zeroborder';	function _setColor(box, color) {		color = color.toUpperCase();		box.css('background-color', color);		box.css('color', color === '#000000' ? '#FFFFFF' : '#000000');		box.html(color);	}	var pickerList = [];	function _initColorPicker(dialogDiv, colorBox) {		colorBox.bind('click,mousedown', function(e){			e.stopPropagation();		});		function removePicker() {			K.each(pickerList, function() {				this.remove();			});			pickerList = [];			K(document).unbind('click,mousedown', removePicker);			dialogDiv.unbind('click,mousedown', removePicker);		}		colorBox.click(function(e) {			removePicker();			var box = K(this),				pos = box.pos();			var picker = K.colorpicker({				x : pos.x,				y : pos.y + box.height(),				z : 811214,				selectedColor : K(this).html(),				colors : self.colorTable,				noColor : self.lang('noColor'),				shadowMode : self.shadowMode,				click : function(color) {					_setColor(box, color);					removePicker();				}			});			pickerList.push(picker);			K(document).bind('click,mousedown', removePicker);			dialogDiv.bind('click,mousedown', removePicker);		});	}	function _getCellIndex(table, row, cell) {		var rowSpanCount = 0;		for (var i = 0, len = row.cells.length; i < len; i++) {			if (row.cells[i] == cell) {				break;			}			rowSpanCount += row.cells[i].rowSpan - 1;		}		return cell.cellIndex - rowSpanCount;	}	self.plugin.table = {		prop : function(isInsert) {			var html = [				'<div style="padding:20px;">',				'<div class="ke-dialog-row">',				'<label for="keRows" style="width:90px;">' + lang.cells + '</label>',				lang.rows + ' <input type="text" id="keRows" class="ke-input-text ke-input-number" name="rows" value="" maxlength="4" />   ',				lang.cols + ' <input type="text" class="ke-input-text ke-input-number" name="cols" value="" maxlength="4" />',				'</div>',				'<div class="ke-dialog-row">',				'<label for="keWidth" style="width:90px;">' + lang.size + '</label>',				lang.width + ' <input type="text" id="keWidth" class="ke-input-text ke-input-number" name="width" value="" maxlength="4" />   ',				'<select name="widthType">',				'<option value="%">' + lang.percent + '</option>',				'<option value="px">' + lang.px + '</option>',				'</select>   ',				lang.height + ' <input type="text" class="ke-input-text ke-input-number" name="height" value="" maxlength="4" />   ',				'<select name="heightType">',				'<option value="%">' + lang.percent + '</option>',				'<option value="px">' + lang.px + '</option>',				'</select>',				'</div>',				'<div class="ke-dialog-row">',				'<label for="kePadding" style="width:90px;">' + lang.space + '</label>',				lang.padding + ' <input type="text" id="kePadding" class="ke-input-text ke-input-number" name="padding" value="" maxlength="4" />   ',				lang.spacing + ' <input type="text" class="ke-input-text ke-input-number" name="spacing" value="" maxlength="4" />',				'</div>',				'<div class="ke-dialog-row">',				'<label for="keAlign" style="width:90px;">' + lang.align + '</label>',				'<select id="keAlign" name="align">',				'<option value="">' + lang.alignDefault + '</option>',				'<option value="left">' + lang.alignLeft + '</option>',				'<option value="center">' + lang.alignCenter + '</option>',				'<option value="right">' + lang.alignRight + '</option>',				'</select>',				'</div>',				'<div class="ke-dialog-row">',				'<label for="keBorder" style="width:90px;">' + lang.border + '</label>',				lang.borderWidth + ' <input type="text" id="keBorder" class="ke-input-text ke-input-number" name="border" value="" maxlength="4" />   ',				lang.borderColor + ' <span class="ke-inline-block ke-input-color"></span>',				'</div>',				'<div class="ke-dialog-row">',				'<label for="keBgColor" style="width:90px;">' + lang.backgroundColor + '</label>',				'<span class="ke-inline-block ke-input-color"></span>',				'</div>',				'</div>'			].join('');			var bookmark = self.cmd.range.createBookmark();			var dialog = self.createDialog({				name : name,				width : 500,				title : self.lang(name),				body : html,				beforeRemove : function() {					colorBox.unbind();				},				yesBtn : {					name : self.lang('yes'),					click : function(e) {						var rows = rowsBox.val(),							cols = colsBox.val(),							width = widthBox.val(),							height = heightBox.val(),							widthType = widthTypeBox.val(),							heightType = heightTypeBox.val(),							padding = paddingBox.val(),							spacing = spacingBox.val(),							align = alignBox.val(),							border = borderBox.val(),							borderColor = K(colorBox[0]).html() || '',							bgColor = K(colorBox[1]).html() || '';						if (rows == 0 || !/^\d+$/.test(rows)) {							alert(self.lang('invalidRows'));							rowsBox[0].focus();							return;						}						if (cols == 0 || !/^\d+$/.test(cols)) {							alert(self.lang('invalidRows'));							colsBox[0].focus();							return;						}						if (!/^\d*$/.test(width)) {							alert(self.lang('invalidWidth'));							widthBox[0].focus();							return;						}						if (!/^\d*$/.test(height)) {							alert(self.lang('invalidHeight'));							heightBox[0].focus();							return;						}						if (!/^\d*$/.test(padding)) {							alert(self.lang('invalidPadding'));							paddingBox[0].focus();							return;						}						if (!/^\d*$/.test(spacing)) {							alert(self.lang('invalidSpacing'));							spacingBox[0].focus();							return;						}						if (!/^\d*$/.test(border)) {							alert(self.lang('invalidBorder'));							borderBox[0].focus();							return;						}						if (table) {							if (width !== '') {								table.width(width + widthType);							} else {								table.css('width', '');							}							if (table[0].width !== undefined) {								table.removeAttr('width');							}							if (height !== '') {								table.height(height + heightType);							} else {								table.css('height', '');							}							if (table[0].height !== undefined) {								table.removeAttr('height');							}							table.css('background-color', bgColor);							if (table[0].bgColor !== undefined) {								table.removeAttr('bgColor');							}							if (padding !== '') {								table[0].cellPadding = padding;							} else {								table.removeAttr('cellPadding');							}							if (spacing !== '') {								table[0].cellSpacing = spacing;							} else {								table.removeAttr('cellSpacing');							}							if (align !== '') {								table[0].align = align;							} else {								table.removeAttr('align');							}							if (border !== '') {								table.attr('border', border);							} else {								table.removeAttr('border');							}							if (border === '' || border === '0') {								table.addClass(zeroborder);							} else {								table.removeClass(zeroborder);							}							if (borderColor !== '') {								table.attr('borderColor', borderColor);							} else {								table.removeAttr('borderColor');							}							self.hideDialog().focus();							self.cmd.range.moveToBookmark(bookmark);							self.cmd.select();							self.addBookmark();							return;						}						var style = '';						if (width !== '') {							style += 'width:' + width + widthType + ';';						}						if (height !== '') {							style += 'height:' + height + heightType + ';';						}						if (bgColor !== '') {							style += 'background-color:' + bgColor + ';';						}						var html = '<table';						if (style !== '') {							html += ' style="' + style + '"';						}						if (padding !== '') {							html += ' cellpadding="' + padding + '"';						}						if (spacing !== '') {							html += ' cellspacing="' + spacing + '"';						}						if (align !== '') {							html += ' align="' + align + '"';						}						if (border !== '') {							html += ' border="' + border + '"';						}						if (border === '' || border === '0') {							html += ' class="' + zeroborder + '"';						}						if (borderColor !== '') {							html += ' bordercolor="' + borderColor + '"';						}						html += '>';						for (var i = 0; i < rows; i++) {							html += '<tr>';							for (var j = 0; j < cols; j++) {								html += '<td>' + (K.IE ? ' ' : '<br />') + '</td>';							}							html += '</tr>';						}						html += '</table>';						if (!K.IE) {							html += '<br />';						}						self.insertHtml(html);						self.select().hideDialog().focus();						self.addBookmark();					}				}			}),			div = dialog.div,			rowsBox = K('[name="rows"]', div).val(3),			colsBox = K('[name="cols"]', div).val(2),			widthBox = K('[name="width"]', div).val(100),			heightBox = K('[name="height"]', div),			widthTypeBox = K('[name="widthType"]', div),			heightTypeBox = K('[name="heightType"]', div),			paddingBox = K('[name="padding"]', div).val(2),			spacingBox = K('[name="spacing"]', div).val(0),			alignBox = K('[name="align"]', div),			borderBox = K('[name="border"]', div).val(1),			colorBox = K('.ke-input-color', div);			_initColorPicker(div, colorBox.eq(0));			_initColorPicker(div, colorBox.eq(1));			_setColor(colorBox.eq(0), '#000000');			_setColor(colorBox.eq(1), '');			rowsBox[0].focus();			rowsBox[0].select();			var table;			if (isInsert) {				return;			}			table = self.plugin.getSelectedTable();			if (table) {				rowsBox.val(table[0].rows.length);				colsBox.val(table[0].rows.length > 0 ? table[0].rows[0].cells.length : 0);				rowsBox.attr('disabled', true);				colsBox.attr('disabled', true);				var match,					tableWidth = table[0].style.width || table[0].width,					tableHeight = table[0].style.height || table[0].height;				if (tableWidth !== undefined && (match = /^(\d+)((?:px|%)*)$/.exec(tableWidth))) {					widthBox.val(match[1]);					widthTypeBox.val(match[2]);				} else {					widthBox.val('');				}				if (tableHeight !== undefined && (match = /^(\d+)((?:px|%)*)$/.exec(tableHeight))) {					heightBox.val(match[1]);					heightTypeBox.val(match[2]);				}				paddingBox.val(table[0].cellPadding || '');				spacingBox.val(table[0].cellSpacing || '');				alignBox.val(table[0].align || '');				borderBox.val(table[0].border === undefined ? '' : table[0].border);				_setColor(colorBox.eq(0), K.toHex(table.attr('borderColor') || ''));				_setColor(colorBox.eq(1), K.toHex(table[0].style.backgroundColor || table[0].bgColor || ''));				widthBox[0].focus();				widthBox[0].select();			}		},		cellprop : function() {			var html = [				'<div style="padding:20px;">',				'<div class="ke-dialog-row">',				'<label for="keWidth" style="width:90px;">' + lang.size + '</label>',				lang.width + ' <input type="text" id="keWidth" class="ke-input-text ke-input-number" name="width" value="" maxlength="4" />   ',				'<select name="widthType">',				'<option value="%">' + lang.percent + '</option>',				'<option value="px">' + lang.px + '</option>',				'</select>   ',				lang.height + ' <input type="text" class="ke-input-text ke-input-number" name="height" value="" maxlength="4" />   ',				'<select name="heightType">',				'<option value="%">' + lang.percent + '</option>',				'<option value="px">' + lang.px + '</option>',				'</select>',				'</div>',				'<div class="ke-dialog-row">',				'<label for="keAlign" style="width:90px;">' + lang.align + '</label>',				lang.textAlign + ' <select id="keAlign" name="textAlign">',				'<option value="">' + lang.alignDefault + '</option>',				'<option value="left">' + lang.alignLeft + '</option>',				'<option value="center">' + lang.alignCenter + '</option>',				'<option value="right">' + lang.alignRight + '</option>',				'</select> ',				lang.verticalAlign + ' <select name="verticalAlign">',				'<option value="">' + lang.alignDefault + '</option>',				'<option value="top">' + lang.alignTop + '</option>',				'<option value="middle">' + lang.alignMiddle + '</option>',				'<option value="bottom">' + lang.alignBottom + '</option>',				'<option value="baseline">' + lang.alignBaseline + '</option>',				'</select>',				'</div>',				'<div class="ke-dialog-row">',				'<label for="keBorder" style="width:90px;">' + lang.border + '</label>',				lang.borderWidth + ' <input type="text" id="keBorder" class="ke-input-text ke-input-number" name="border" value="" maxlength="4" />   ',				lang.borderColor + ' <span class="ke-inline-block ke-input-color"></span>',				'</div>',				'<div class="ke-dialog-row">',				'<label for="keBgColor" style="width:90px;">' + lang.backgroundColor + '</label>',				'<span class="ke-inline-block ke-input-color"></span>',				'</div>',				'</div>'			].join('');			var bookmark = self.cmd.range.createBookmark();			var dialog = self.createDialog({				name : name,				width : 500,				title : self.lang('tablecell'),				body : html,				beforeRemove : function() {					colorBox.unbind();				},				yesBtn : {					name : self.lang('yes'),					click : function(e) {						var width = widthBox.val(),							height = heightBox.val(),							widthType = widthTypeBox.val(),							heightType = heightTypeBox.val(),							padding = paddingBox.val(),							spacing = spacingBox.val(),							textAlign = textAlignBox.val(),							verticalAlign = verticalAlignBox.val(),							border = borderBox.val(),							borderColor = K(colorBox[0]).html() || '',							bgColor = K(colorBox[1]).html() || '';						if (!/^\d*$/.test(width)) {							alert(self.lang('invalidWidth'));							widthBox[0].focus();							return;						}						if (!/^\d*$/.test(height)) {							alert(self.lang('invalidHeight'));							heightBox[0].focus();							return;						}						if (!/^\d*$/.test(border)) {							alert(self.lang('invalidBorder'));							borderBox[0].focus();							return;						}						cell.css({							width : width !== '' ? (width + widthType) : '',							height : height !== '' ? (height + heightType) : '',							'background-color' : bgColor,							'text-align' : textAlign,							'vertical-align' : verticalAlign,							'border-width' : border,							'border-style' : border !== '' ? 'solid' : '',							'border-color' : borderColor						});						self.hideDialog().focus();						self.cmd.range.moveToBookmark(bookmark);						self.cmd.select();						self.addBookmark();					}				}			}),			div = dialog.div,			widthBox = K('[name="width"]', div).val(100),			heightBox = K('[name="height"]', div),			widthTypeBox = K('[name="widthType"]', div),			heightTypeBox = K('[name="heightType"]', div),			paddingBox = K('[name="padding"]', div).val(2),			spacingBox = K('[name="spacing"]', div).val(0),			textAlignBox = K('[name="textAlign"]', div),			verticalAlignBox = K('[name="verticalAlign"]', div),			borderBox = K('[name="border"]', div).val(1),			colorBox = K('.ke-input-color', div);			_initColorPicker(div, colorBox.eq(0));			_initColorPicker(div, colorBox.eq(1));			_setColor(colorBox.eq(0), '#000000');			_setColor(colorBox.eq(1), '');			widthBox[0].focus();			widthBox[0].select();			var cell = self.plugin.getSelectedCell();			var match,				cellWidth = cell[0].style.width || cell[0].width || '',				cellHeight = cell[0].style.height || cell[0].height || '';			if ((match = /^(\d+)((?:px|%)*)$/.exec(cellWidth))) {				widthBox.val(match[1]);				widthTypeBox.val(match[2]);			} else {				widthBox.val('');			}			if ((match = /^(\d+)((?:px|%)*)$/.exec(cellHeight))) {				heightBox.val(match[1]);				heightTypeBox.val(match[2]);			}			textAlignBox.val(cell[0].style.textAlign || '');			verticalAlignBox.val(cell[0].style.verticalAlign || '');			var border = cell[0].style.borderWidth || '';			if (border) {				border = parseInt(border);			}			borderBox.val(border);			_setColor(colorBox.eq(0), K.toHex(cell[0].style.borderColor || ''));			_setColor(colorBox.eq(1), K.toHex(cell[0].style.backgroundColor || ''));			widthBox[0].focus();			widthBox[0].select();		},		insert : function() {			this.prop(true);		},		'delete' : function() {			var table = self.plugin.getSelectedTable();			self.cmd.range.setStartBefore(table[0]).collapse(true);			self.cmd.select();			table.remove();			self.addBookmark();		},		colinsert : function(offset) {			var table = self.plugin.getSelectedTable()[0],				row = self.plugin.getSelectedRow()[0],				cell = self.plugin.getSelectedCell()[0],				index = cell.cellIndex + offset;			index += table.rows[0].cells.length - row.cells.length;			for (var i = 0, len = table.rows.length; i < len; i++) {				var newRow = table.rows[i],					newCell = newRow.insertCell(index);				newCell.innerHTML = K.IE ? '' : '<br />';				index = _getCellIndex(table, newRow, newCell);			}			self.cmd.range.selectNodeContents(cell).collapse(true);			self.cmd.select();			self.addBookmark();		},		colinsertleft : function() {			this.colinsert(0);		},		colinsertright : function() {			this.colinsert(1);		},		rowinsert : function(offset) {			var table = self.plugin.getSelectedTable()[0],				row = self.plugin.getSelectedRow()[0],				cell = self.plugin.getSelectedCell()[0];			var rowIndex = row.rowIndex;			if (offset === 1) {				rowIndex = row.rowIndex + (cell.rowSpan - 1) + offset;			}			var newRow = table.insertRow(rowIndex);			for (var i = 0, len = row.cells.length; i < len; i++) {				if (row.cells[i].rowSpan > 1) {					len -= row.cells[i].rowSpan - 1;				}				var newCell = newRow.insertCell(i);				if (offset === 1 && row.cells[i].colSpan > 1) {					newCell.colSpan = row.cells[i].colSpan;				}				newCell.innerHTML = K.IE ? '' : '<br />';			}			for (var j = rowIndex; j >= 0; j--) {				var cells = table.rows[j].cells;				if (cells.length > i) {					for (var k = cell.cellIndex; k >= 0; k--) {						if (cells[k].rowSpan > 1) {							cells[k].rowSpan += 1;						}					}					break;				}			}			self.cmd.range.selectNodeContents(cell).collapse(true);			self.cmd.select();			self.addBookmark();		},		rowinsertabove : function() {			this.rowinsert(0);		},		rowinsertbelow : function() {			this.rowinsert(1);		},		rowmerge : function() {			var table = self.plugin.getSelectedTable()[0],				row = self.plugin.getSelectedRow()[0],				cell = self.plugin.getSelectedCell()[0],				rowIndex = row.rowIndex,				nextRowIndex = rowIndex + cell.rowSpan,				nextRow = table.rows[nextRowIndex];			if (table.rows.length <= nextRowIndex) {				return;			}			var cellIndex = cell.cellIndex;			if (nextRow.cells.length <= cellIndex) {				return;			}			var nextCell = nextRow.cells[cellIndex];			if (cell.colSpan !== nextCell.colSpan) {				return;			}			cell.rowSpan += nextCell.rowSpan;			nextRow.deleteCell(cellIndex);			self.cmd.range.selectNodeContents(cell).collapse(true);			self.cmd.select();			self.addBookmark();		},		colmerge : function() {			var table = self.plugin.getSelectedTable()[0],				row = self.plugin.getSelectedRow()[0],				cell = self.plugin.getSelectedCell()[0],				rowIndex = row.rowIndex,				cellIndex = cell.cellIndex,				nextCellIndex = cellIndex + 1;			if (row.cells.length <= nextCellIndex) {				return;			}			var nextCell = row.cells[nextCellIndex];			if (cell.rowSpan !== nextCell.rowSpan) {				return;			}			cell.colSpan += nextCell.colSpan;			row.deleteCell(nextCellIndex);			self.cmd.range.selectNodeContents(cell).collapse(true);			self.cmd.select();			self.addBookmark();		},		rowsplit : function() {			var table = self.plugin.getSelectedTable()[0],				row = self.plugin.getSelectedRow()[0],				cell = self.plugin.getSelectedCell()[0],				rowIndex = row.rowIndex;			if (cell.rowSpan === 1) {				return;			}			var cellIndex = _getCellIndex(table, row, cell);			for (var i = 1, len = cell.rowSpan; i < len; i++) {				var newRow = table.rows[rowIndex + i],					newCell = newRow.insertCell(cellIndex);				if (cell.colSpan > 1) {					newCell.colSpan = cell.colSpan;				}				newCell.innerHTML = K.IE ? '' : '<br />';				cellIndex = _getCellIndex(table, newRow, newCell);			}			K(cell).removeAttr('rowSpan');			self.cmd.range.selectNodeContents(cell).collapse(true);			self.cmd.select();			self.addBookmark();		},		colsplit : function() {			var table = self.plugin.getSelectedTable()[0],				row = self.plugin.getSelectedRow()[0],				cell = self.plugin.getSelectedCell()[0],				cellIndex = cell.cellIndex;			if (cell.colSpan === 1) {				return;			}			for (var i = 1, len = cell.colSpan; i < len; i++) {				var newCell = row.insertCell(cellIndex + i);				if (cell.rowSpan > 1) {					newCell.rowSpan = cell.rowSpan;				}				newCell.innerHTML = K.IE ? '' : '<br />';			}			K(cell).removeAttr('colSpan');			self.cmd.range.selectNodeContents(cell).collapse(true);			self.cmd.select();			self.addBookmark();		},		coldelete : function() {			var table = self.plugin.getSelectedTable()[0],				row = self.plugin.getSelectedRow()[0],				cell = self.plugin.getSelectedCell()[0],				index = cell.cellIndex;			for (var i = 0, len = table.rows.length; i < len; i++) {				var newRow = table.rows[i],					newCell = newRow.cells[index];				if (newCell.colSpan > 1) {					newCell.colSpan -= 1;					if (newCell.colSpan === 1) {						K(newCell).removeAttr('colSpan');					}				} else {					newRow.deleteCell(index);				}				if (newCell.rowSpan > 1) {					i += newCell.rowSpan - 1;				}			}			if (row.cells.length === 0) {				self.cmd.range.setStartBefore(table).collapse(true);				self.cmd.select();				K(table).remove();			} else {				self.cmd.selection(true);			}			self.addBookmark();		},		rowdelete : function() {			var table = self.plugin.getSelectedTable()[0],				row = self.plugin.getSelectedRow()[0],				cell = self.plugin.getSelectedCell()[0],				rowIndex = row.rowIndex;			for (var i = cell.rowSpan - 1; i >= 0; i--) {				table.deleteRow(rowIndex + i);			}			if (table.rows.length === 0) {				self.cmd.range.setStartBefore(table).collapse(true);				self.cmd.select();				K(table).remove();			} else {				self.cmd.selection(true);			}			self.addBookmark();		}	};	self.clickToolbar(name, self.plugin.table.prop);});/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('template', function(K) {	var self = this, name = 'template', lang = self.lang(name + '.'),		htmlPath = self.pluginsPath + name + '/html/';	function getFilePath(fileName) {		return htmlPath + fileName + '?ver=' + encodeURIComponent(K.DEBUG ? K.TIME : K.VERSION);	}	self.clickToolbar(name, function() {		var lang = self.lang(name + '.'),			arr = ['<div style="padding:10px 20px;">',				'<div class="ke-header">',				'<div class="ke-left">',				lang. selectTemplate + ' <select>'];			K.each(lang.fileList, function(key, val) {				arr.push('<option value="' + key + '">' + val + '</option>');			});			html = [arr.join(''),				'</select></div>',				'<div class="ke-right">',				'<input type="checkbox" id="keReplaceFlag" name="replaceFlag" value="1" /> <label for="keReplaceFlag">' + lang.replaceContent + '</label>',				'</div>',				'<div class="ke-clearfix"></div>',				'</div>',				'<iframe class="ke-textarea" frameborder="0" style="width:458px;height:260px;background-color:#FFF;"></iframe>',				'</div>'].join('');		var dialog = self.createDialog({			name : name,			width : 500,			title : self.lang(name),			body : html,			yesBtn : {				name : self.lang('yes'),				click : function(e) {					var doc = K.iframeDoc(iframe);					self[checkbox[0].checked ? 'html' : 'insertHtml'](doc.body.innerHTML).hideDialog().focus();				}			}		});		var selectBox = K('select', dialog.div),			checkbox = K('[name="replaceFlag"]', dialog.div),			iframe = K('iframe', dialog.div);		checkbox[0].checked = true;		iframe.attr('src', getFilePath(selectBox.val()));		selectBox.change(function() {			iframe.attr('src', getFilePath(this.value));		});	});});/******************************************************************************** KindEditor - WYSIWYG HTML Editor for Internet* Copyright (C) 2006-2011 kindsoft.net** @author Roddy <luolonghao@gmail.com>* @site http://www.kindsoft.net/* @licence http://www.kindsoft.net/license.php*******************************************************************************/KindEditor.plugin('wordpaste', function(K) {	var self = this, name = 'wordpaste';	self.clickToolbar(name, function() {		var lang = self.lang(name + '.'),			html = '<div style="padding:10px 20px;">' +				'<div style="margin-bottom:10px;">' + lang.comment + '</div>' +				'<iframe class="ke-textarea" frameborder="0" style="width:408px;height:260px;"></iframe>' +				'</div>',			dialog = self.createDialog({				name : name,				width : 450,				title : self.lang(name),				body : html,				yesBtn : {					name : self.lang('yes'),					click : function(e) {						var str = doc.body.innerHTML;						str = K.clearMsWord(str, self.filterMode ? self.htmlTags : K.options.htmlTags);						self.insertHtml(str).hideDialog().focus();					}				}			}),			div = dialog.div,			iframe = K('iframe', div),			doc = K.iframeDoc(iframe);		if (!K.IE) {			doc.designMode = 'on';		}		doc.open();		doc.write('<!doctype html><html><head><title>WordPaste</title></head>');		doc.write('<body style="background-color:#FFF;font-size:12px;margin:2px;">');		if (!K.IE) {			doc.write('<br />');		}		doc.write('</body></html>');		doc.close();		if (K.IE) {			doc.body.contentEditable = 'true';		}		iframe[0].contentWindow.focus();	});});KindEditor.plugin('fixtoolbar', function (K) {    var self = this;    if (!self.fixToolBar) {        return;    }    function init() {        var toolbar = K('.ke-toolbar');        var originY = toolbar.pos().y;        K(window).bind('scroll', function () {            if (toolbar.css('position') == 'fixed') {                if(document.body.scrollTop - originY < 0){                    toolbar.css('position', 'static');                    toolbar.css('top', 'auto');                }            } else {                if (toolbar.pos().y - document.body.scrollTop < 0) {                    toolbar.css('position', 'fixed');                    toolbar.css('top', 0);                }            }        });    }    if (self.isCreated) {        init();    } else {        self.afterCreate(init);    }});
 |