12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764676567666767676867696770677167726773677467756776677767786779678067816782678367846785678667876788678967906791679267936794679567966797679867996800680168026803680468056806680768086809681068116812681368146815681668176818681968206821682268236824682568266827682868296830683168326833683468356836683768386839684068416842684368446845684668476848684968506851685268536854685568566857685868596860686168626863686468656866686768686869687068716872687368746875687668776878687968806881688268836884688568866887688868896890689168926893689468956896689768986899690069016902690369046905690669076908690969106911691269136914691569166917691869196920692169226923692469256926692769286929693069316932693369346935693669376938693969406941694269436944694569466947694869496950695169526953695469556956695769586959696069616962696369646965696669676968696969706971697269736974697569766977697869796980698169826983698469856986698769886989699069916992699369946995699669976998699970007001700270037004700570067007700870097010701170127013701470157016701770187019702070217022702370247025702670277028702970307031703270337034703570367037703870397040704170427043704470457046704770487049705070517052705370547055705670577058705970607061706270637064706570667067706870697070707170727073707470757076707770787079708070817082708370847085708670877088708970907091709270937094709570967097709870997100710171027103710471057106710771087109711071117112711371147115711671177118711971207121712271237124712571267127712871297130713171327133713471357136713771387139714071417142714371447145714671477148714971507151715271537154715571567157715871597160716171627163716471657166716771687169717071717172717371747175717671777178717971807181718271837184718571867187718871897190719171927193719471957196719771987199720072017202720372047205720672077208720972107211721272137214721572167217721872197220722172227223722472257226722772287229723072317232723372347235723672377238723972407241724272437244724572467247724872497250725172527253725472557256725772587259726072617262726372647265726672677268726972707271727272737274727572767277727872797280728172827283728472857286728772887289729072917292729372947295729672977298729973007301730273037304730573067307730873097310731173127313731473157316731773187319732073217322732373247325732673277328732973307331733273337334733573367337733873397340734173427343734473457346734773487349735073517352735373547355735673577358735973607361736273637364736573667367736873697370737173727373737473757376737773787379738073817382738373847385738673877388738973907391739273937394739573967397739873997400740174027403740474057406740774087409741074117412741374147415741674177418741974207421742274237424742574267427742874297430743174327433743474357436743774387439744074417442744374447445744674477448744974507451745274537454745574567457745874597460746174627463746474657466746774687469747074717472747374747475747674777478747974807481748274837484748574867487748874897490749174927493749474957496749774987499750075017502750375047505750675077508750975107511751275137514751575167517751875197520752175227523752475257526752775287529753075317532753375347535753675377538753975407541754275437544754575467547754875497550755175527553755475557556755775587559756075617562756375647565756675677568756975707571757275737574757575767577757875797580758175827583758475857586758775887589759075917592759375947595759675977598759976007601760276037604760576067607760876097610761176127613761476157616761776187619762076217622762376247625762676277628762976307631763276337634763576367637763876397640764176427643764476457646764776487649765076517652765376547655765676577658765976607661766276637664766576667667766876697670767176727673767476757676767776787679768076817682768376847685768676877688768976907691769276937694769576967697769876997700770177027703770477057706770777087709771077117712771377147715771677177718771977207721772277237724772577267727772877297730773177327733773477357736773777387739774077417742774377447745774677477748774977507751775277537754775577567757775877597760776177627763776477657766776777687769777077717772777377747775777677777778777977807781778277837784778577867787778877897790779177927793779477957796779777987799780078017802780378047805780678077808780978107811781278137814781578167817781878197820782178227823782478257826782778287829783078317832783378347835783678377838783978407841784278437844784578467847784878497850785178527853785478557856785778587859786078617862786378647865786678677868786978707871787278737874787578767877787878797880788178827883788478857886788778887889789078917892789378947895789678977898789979007901790279037904790579067907790879097910791179127913791479157916791779187919792079217922792379247925792679277928792979307931793279337934793579367937793879397940794179427943794479457946794779487949795079517952795379547955795679577958795979607961796279637964796579667967796879697970797179727973797479757976797779787979798079817982798379847985798679877988798979907991799279937994799579967997799879998000800180028003800480058006800780088009801080118012801380148015801680178018801980208021802280238024802580268027802880298030803180328033803480358036803780388039804080418042804380448045804680478048804980508051805280538054805580568057805880598060806180628063806480658066806780688069807080718072807380748075807680778078807980808081808280838084808580868087808880898090809180928093809480958096809780988099810081018102810381048105810681078108810981108111811281138114811581168117811881198120812181228123812481258126812781288129813081318132813381348135813681378138813981408141814281438144814581468147814881498150815181528153815481558156815781588159816081618162816381648165816681678168816981708171817281738174817581768177817881798180818181828183818481858186818781888189819081918192819381948195819681978198819982008201820282038204820582068207820882098210821182128213821482158216821782188219822082218222822382248225822682278228822982308231823282338234823582368237823882398240824182428243824482458246824782488249825082518252825382548255825682578258825982608261826282638264826582668267826882698270827182728273827482758276827782788279828082818282828382848285828682878288828982908291829282938294829582968297829882998300830183028303830483058306830783088309831083118312831383148315831683178318831983208321832283238324832583268327832883298330833183328333833483358336833783388339834083418342834383448345834683478348834983508351835283538354835583568357835883598360836183628363836483658366836783688369837083718372837383748375837683778378837983808381838283838384838583868387838883898390839183928393839483958396839783988399840084018402840384048405840684078408840984108411841284138414841584168417841884198420842184228423842484258426842784288429843084318432843384348435843684378438843984408441844284438444844584468447844884498450845184528453845484558456845784588459846084618462846384648465846684678468846984708471847284738474847584768477847884798480848184828483848484858486848784888489849084918492849384948495849684978498849985008501850285038504850585068507850885098510851185128513851485158516851785188519852085218522852385248525852685278528852985308531853285338534853585368537853885398540854185428543854485458546854785488549855085518552855385548555855685578558855985608561856285638564856585668567856885698570857185728573857485758576857785788579858085818582858385848585858685878588858985908591859285938594859585968597859885998600860186028603860486058606860786088609861086118612861386148615861686178618861986208621862286238624862586268627862886298630863186328633863486358636863786388639864086418642864386448645864686478648864986508651865286538654865586568657865886598660866186628663866486658666866786688669867086718672867386748675867686778678867986808681868286838684868586868687868886898690869186928693869486958696869786988699870087018702870387048705870687078708870987108711871287138714871587168717871887198720872187228723872487258726872787288729873087318732873387348735873687378738873987408741874287438744874587468747874887498750875187528753875487558756875787588759876087618762876387648765876687678768876987708771877287738774877587768777877887798780878187828783878487858786878787888789879087918792879387948795879687978798879988008801880288038804880588068807880888098810881188128813881488158816881788188819882088218822882388248825882688278828882988308831883288338834883588368837883888398840884188428843884488458846884788488849885088518852885388548855885688578858885988608861886288638864886588668867886888698870887188728873887488758876887788788879888088818882888388848885888688878888888988908891889288938894889588968897889888998900890189028903890489058906890789088909891089118912891389148915891689178918891989208921892289238924892589268927892889298930893189328933893489358936893789388939894089418942894389448945894689478948894989508951895289538954895589568957895889598960896189628963896489658966896789688969897089718972897389748975897689778978897989808981898289838984898589868987898889898990899189928993899489958996899789988999900090019002900390049005900690079008900990109011901290139014901590169017901890199020902190229023902490259026902790289029903090319032903390349035903690379038903990409041904290439044904590469047904890499050905190529053905490559056905790589059906090619062906390649065906690679068906990709071907290739074907590769077907890799080908190829083908490859086908790889089909090919092909390949095909690979098909991009101910291039104910591069107910891099110911191129113911491159116911791189119912091219122912391249125912691279128912991309131913291339134913591369137913891399140914191429143914491459146914791489149915091519152915391549155915691579158915991609161916291639164916591669167916891699170917191729173917491759176917791789179918091819182918391849185918691879188918991909191919291939194919591969197919891999200920192029203920492059206920792089209921092119212921392149215921692179218921992209221922292239224922592269227922892299230923192329233923492359236923792389239924092419242924392449245924692479248924992509251925292539254925592569257925892599260926192629263926492659266926792689269927092719272927392749275927692779278927992809281928292839284928592869287928892899290929192929293929492959296929792989299930093019302930393049305930693079308930993109311931293139314931593169317931893199320932193229323932493259326932793289329933093319332933393349335933693379338933993409341934293439344934593469347934893499350935193529353935493559356935793589359936093619362936393649365936693679368936993709371937293739374937593769377937893799380938193829383938493859386938793889389939093919392939393949395939693979398939994009401940294039404940594069407940894099410941194129413941494159416941794189419942094219422942394249425942694279428942994309431943294339434943594369437943894399440944194429443944494459446944794489449945094519452945394549455945694579458945994609461946294639464946594669467946894699470947194729473947494759476947794789479948094819482948394849485948694879488948994909491949294939494949594969497949894999500950195029503950495059506950795089509951095119512951395149515951695179518951995209521952295239524952595269527952895299530953195329533953495359536953795389539954095419542954395449545954695479548954995509551955295539554955595569557955895599560956195629563956495659566956795689569957095719572957395749575957695779578957995809581958295839584958595869587958895899590959195929593959495959596959795989599960096019602960396049605960696079608960996109611961296139614961596169617961896199620962196229623962496259626962796289629963096319632963396349635963696379638963996409641964296439644964596469647964896499650965196529653965496559656965796589659966096619662966396649665966696679668966996709671967296739674967596769677967896799680968196829683968496859686968796889689969096919692969396949695969696979698969997009701970297039704970597069707970897099710971197129713971497159716971797189719972097219722972397249725972697279728972997309731973297339734973597369737973897399740974197429743974497459746974797489749975097519752975397549755975697579758975997609761976297639764976597669767976897699770977197729773977497759776977797789779978097819782978397849785978697879788978997909791979297939794979597969797979897999800980198029803980498059806980798089809981098119812981398149815981698179818981998209821982298239824982598269827982898299830983198329833983498359836983798389839984098419842984398449845984698479848984998509851985298539854985598569857985898599860986198629863986498659866986798689869987098719872987398749875987698779878987998809881988298839884988598869887988898899890989198929893989498959896989798989899990099019902990399049905990699079908990999109911991299139914991599169917991899199920992199229923992499259926992799289929993099319932993399349935993699379938993999409941994299439944994599469947994899499950995199529953995499559956995799589959996099619962996399649965996699679968996999709971997299739974997599769977997899799980998199829983998499859986998799889989999099919992999399949995999699979998999910000100011000210003100041000510006100071000810009100101001110012100131001410015100161001710018100191002010021100221002310024100251002610027100281002910030100311003210033100341003510036100371003810039100401004110042100431004410045100461004710048100491005010051100521005310054100551005610057100581005910060100611006210063100641006510066100671006810069100701007110072100731007410075100761007710078100791008010081100821008310084100851008610087100881008910090100911009210093100941009510096100971009810099101001010110102101031010410105101061010710108101091011010111101121011310114101151011610117101181011910120101211012210123101241012510126101271012810129101301013110132101331013410135101361013710138101391014010141101421014310144101451014610147101481014910150101511015210153101541015510156101571015810159101601016110162101631016410165101661016710168101691017010171101721017310174101751017610177101781017910180101811018210183101841018510186101871018810189101901019110192101931019410195101961019710198101991020010201102021020310204102051020610207102081020910210102111021210213102141021510216102171021810219102201022110222102231022410225102261022710228102291023010231102321023310234102351023610237102381023910240102411024210243102441024510246102471024810249102501025110252102531025410255102561025710258102591026010261102621026310264102651026610267102681026910270102711027210273102741027510276102771027810279102801028110282102831028410285102861028710288102891029010291102921029310294102951029610297102981029910300103011030210303103041030510306103071030810309103101031110312103131031410315103161031710318103191032010321103221032310324103251032610327103281032910330103311033210333103341033510336103371033810339103401034110342103431034410345103461034710348103491035010351103521035310354103551035610357103581035910360103611036210363103641036510366103671036810369103701037110372103731037410375103761037710378103791038010381103821038310384103851038610387103881038910390103911039210393103941039510396103971039810399104001040110402104031040410405104061040710408104091041010411104121041310414104151041610417104181041910420104211042210423104241042510426104271042810429104301043110432104331043410435104361043710438104391044010441104421044310444104451044610447104481044910450104511045210453104541045510456104571045810459104601046110462104631046410465104661046710468104691047010471104721047310474104751047610477104781047910480104811048210483104841048510486104871048810489104901049110492104931049410495104961049710498104991050010501105021050310504105051050610507105081050910510105111051210513105141051510516105171051810519105201052110522105231052410525105261052710528105291053010531105321053310534105351053610537105381053910540105411054210543105441054510546105471054810549105501055110552105531055410555105561055710558105591056010561105621056310564105651056610567105681056910570105711057210573105741057510576105771057810579105801058110582105831058410585105861058710588105891059010591105921059310594105951059610597105981059910600106011060210603106041060510606106071060810609106101061110612106131061410615106161061710618106191062010621106221062310624106251062610627106281062910630106311063210633106341063510636106371063810639106401064110642106431064410645106461064710648106491065010651106521065310654106551065610657106581065910660106611066210663106641066510666106671066810669106701067110672106731067410675106761067710678106791068010681106821068310684106851068610687106881068910690106911069210693106941069510696106971069810699107001070110702107031070410705107061070710708107091071010711107121071310714107151071610717107181071910720107211072210723107241072510726107271072810729107301073110732107331073410735107361073710738107391074010741107421074310744107451074610747107481074910750107511075210753107541075510756107571075810759107601076110762107631076410765107661076710768107691077010771107721077310774107751077610777107781077910780107811078210783107841078510786107871078810789107901079110792107931079410795107961079710798107991080010801108021080310804108051080610807108081080910810108111081210813108141081510816108171081810819108201082110822108231082410825108261082710828108291083010831108321083310834108351083610837108381083910840108411084210843108441084510846108471084810849108501085110852108531085410855108561085710858108591086010861108621086310864108651086610867108681086910870108711087210873108741087510876108771087810879108801088110882108831088410885108861088710888108891089010891108921089310894108951089610897108981089910900109011090210903109041090510906109071090810909109101091110912109131091410915109161091710918109191092010921109221092310924109251092610927109281092910930109311093210933109341093510936109371093810939109401094110942109431094410945109461094710948109491095010951109521095310954109551095610957109581095910960109611096210963109641096510966109671096810969109701097110972109731097410975109761097710978109791098010981109821098310984109851098610987109881098910990109911099210993109941099510996109971099810999110001100111002110031100411005110061100711008110091101011011110121101311014110151101611017110181101911020110211102211023110241102511026110271102811029110301103111032110331103411035110361103711038110391104011041110421104311044110451104611047110481104911050110511105211053110541105511056110571105811059110601106111062110631106411065110661106711068110691107011071110721107311074110751107611077110781107911080110811108211083110841108511086110871108811089110901109111092110931109411095110961109711098110991110011101111021110311104111051110611107111081110911110111111111211113111141111511116111171111811119111201112111122111231112411125111261112711128111291113011131111321113311134111351113611137111381113911140111411114211143111441114511146111471114811149111501115111152111531115411155111561115711158111591116011161111621116311164111651116611167111681116911170111711117211173111741117511176111771117811179111801118111182111831118411185111861118711188111891119011191111921119311194111951119611197111981119911200112011120211203112041120511206112071120811209112101121111212112131121411215112161121711218112191122011221112221122311224112251122611227112281122911230112311123211233112341123511236112371123811239112401124111242112431124411245112461124711248112491125011251112521125311254112551125611257112581125911260112611126211263112641126511266112671126811269112701127111272112731127411275112761127711278112791128011281112821128311284112851128611287112881128911290112911129211293112941129511296112971129811299113001130111302113031130411305113061130711308113091131011311113121131311314113151131611317113181131911320113211132211323113241132511326113271132811329113301133111332113331133411335113361133711338113391134011341113421134311344113451134611347113481134911350113511135211353113541135511356113571135811359113601136111362113631136411365113661136711368113691137011371113721137311374113751137611377113781137911380113811138211383113841138511386113871138811389113901139111392113931139411395113961139711398113991140011401114021140311404114051140611407114081140911410114111141211413114141141511416114171141811419114201142111422114231142411425114261142711428114291143011431114321143311434114351143611437114381143911440114411144211443114441144511446114471144811449114501145111452114531145411455114561145711458114591146011461114621146311464114651146611467114681146911470114711147211473114741147511476114771147811479114801148111482114831148411485114861148711488114891149011491114921149311494114951149611497114981149911500115011150211503115041150511506115071150811509115101151111512115131151411515115161151711518115191152011521115221152311524115251152611527115281152911530115311153211533115341153511536115371153811539115401154111542115431154411545115461154711548115491155011551115521155311554115551155611557115581155911560115611156211563115641156511566115671156811569115701157111572115731157411575115761157711578115791158011581115821158311584115851158611587115881158911590115911159211593115941159511596115971159811599116001160111602116031160411605116061160711608116091161011611116121161311614116151161611617116181161911620116211162211623116241162511626116271162811629116301163111632116331163411635116361163711638116391164011641116421164311644116451164611647116481164911650116511165211653116541165511656116571165811659116601166111662116631166411665116661166711668116691167011671116721167311674116751167611677116781167911680116811168211683116841168511686116871168811689116901169111692116931169411695116961169711698116991170011701117021170311704117051170611707117081170911710117111171211713117141171511716117171171811719117201172111722117231172411725117261172711728117291173011731117321173311734117351173611737117381173911740117411174211743117441174511746117471174811749117501175111752117531175411755117561175711758117591176011761117621176311764117651176611767117681176911770117711177211773117741177511776117771177811779117801178111782117831178411785117861178711788117891179011791117921179311794117951179611797117981179911800118011180211803118041180511806118071180811809118101181111812118131181411815118161181711818118191182011821118221182311824118251182611827118281182911830118311183211833118341183511836118371183811839118401184111842118431184411845118461184711848118491185011851118521185311854118551185611857118581185911860118611186211863118641186511866118671186811869118701187111872118731187411875118761187711878118791188011881118821188311884118851188611887118881188911890118911189211893118941189511896118971189811899119001190111902119031190411905119061190711908119091191011911119121191311914119151191611917119181191911920119211192211923119241192511926119271192811929119301193111932119331193411935119361193711938119391194011941119421194311944119451194611947119481194911950119511195211953119541195511956119571195811959119601196111962119631196411965119661196711968119691197011971119721197311974119751197611977119781197911980119811198211983119841198511986119871198811989119901199111992119931199411995119961199711998119991200012001120021200312004120051200612007120081200912010120111201212013120141201512016120171201812019120201202112022120231202412025120261202712028120291203012031120321203312034120351203612037120381203912040120411204212043120441204512046120471204812049120501205112052120531205412055120561205712058120591206012061120621206312064120651206612067120681206912070120711207212073120741207512076120771207812079120801208112082120831208412085120861208712088120891209012091120921209312094120951209612097120981209912100121011210212103121041210512106121071210812109121101211112112121131211412115121161211712118121191212012121121221212312124121251212612127121281212912130121311213212133121341213512136121371213812139121401214112142121431214412145121461214712148121491215012151121521215312154121551215612157121581215912160121611216212163121641216512166121671216812169121701217112172121731217412175121761217712178121791218012181121821218312184121851218612187121881218912190121911219212193121941219512196121971219812199122001220112202122031220412205122061220712208122091221012211122121221312214122151221612217122181221912220122211222212223122241222512226122271222812229122301223112232122331223412235122361223712238122391224012241122421224312244122451224612247122481224912250122511225212253122541225512256122571225812259122601226112262122631226412265122661226712268122691227012271122721227312274122751227612277122781227912280122811228212283122841228512286122871228812289122901229112292122931229412295122961229712298122991230012301123021230312304123051230612307123081230912310123111231212313123141231512316123171231812319123201232112322123231232412325123261232712328123291233012331123321233312334123351233612337123381233912340123411234212343123441234512346123471234812349123501235112352123531235412355123561235712358123591236012361123621236312364123651236612367123681236912370123711237212373123741237512376123771237812379123801238112382123831238412385123861238712388123891239012391123921239312394123951239612397123981239912400124011240212403124041240512406124071240812409124101241112412124131241412415124161241712418124191242012421124221242312424124251242612427124281242912430124311243212433124341243512436124371243812439124401244112442124431244412445124461244712448124491245012451124521245312454124551245612457124581245912460124611246212463124641246512466124671246812469124701247112472124731247412475124761247712478124791248012481124821248312484124851248612487124881248912490124911249212493124941249512496124971249812499125001250112502125031250412505125061250712508125091251012511125121251312514125151251612517125181251912520125211252212523125241252512526125271252812529125301253112532125331253412535125361253712538125391254012541125421254312544125451254612547125481254912550125511255212553125541255512556125571255812559125601256112562125631256412565125661256712568125691257012571125721257312574125751257612577125781257912580125811258212583125841258512586125871258812589125901259112592125931259412595125961259712598125991260012601126021260312604126051260612607126081260912610126111261212613126141261512616126171261812619126201262112622126231262412625126261262712628126291263012631126321263312634126351263612637126381263912640126411264212643126441264512646126471264812649126501265112652126531265412655126561265712658126591266012661126621266312664126651266612667126681266912670126711267212673126741267512676126771267812679126801268112682126831268412685126861268712688126891269012691126921269312694126951269612697126981269912700127011270212703127041270512706127071270812709127101271112712127131271412715127161271712718127191272012721127221272312724127251272612727127281272912730127311273212733127341273512736127371273812739127401274112742127431274412745127461274712748127491275012751127521275312754127551275612757127581275912760127611276212763127641276512766127671276812769127701277112772127731277412775127761277712778127791278012781127821278312784127851278612787127881278912790127911279212793127941279512796127971279812799128001280112802128031280412805128061280712808128091281012811128121281312814128151281612817128181281912820128211282212823128241282512826128271282812829128301283112832128331283412835128361283712838128391284012841128421284312844128451284612847128481284912850128511285212853128541285512856128571285812859128601286112862128631286412865128661286712868128691287012871128721287312874128751287612877128781287912880128811288212883128841288512886128871288812889128901289112892128931289412895128961289712898128991290012901129021290312904129051290612907129081290912910129111291212913129141291512916129171291812919129201292112922129231292412925129261292712928129291293012931129321293312934129351293612937129381293912940129411294212943129441294512946129471294812949129501295112952129531295412955129561295712958129591296012961129621296312964129651296612967129681296912970129711297212973129741297512976129771297812979129801298112982129831298412985129861298712988129891299012991129921299312994129951299612997129981299913000130011300213003130041300513006130071300813009130101301113012130131301413015130161301713018130191302013021130221302313024130251302613027130281302913030130311303213033130341303513036130371303813039130401304113042130431304413045130461304713048130491305013051130521305313054130551305613057130581305913060130611306213063130641306513066130671306813069130701307113072130731307413075130761307713078130791308013081130821308313084130851308613087130881308913090130911309213093130941309513096130971309813099131001310113102131031310413105131061310713108131091311013111131121311313114131151311613117131181311913120131211312213123131241312513126131271312813129131301313113132131331313413135131361313713138131391314013141131421314313144131451314613147131481314913150131511315213153131541315513156131571315813159131601316113162131631316413165131661316713168131691317013171131721317313174131751317613177131781317913180131811318213183131841318513186131871318813189131901319113192131931319413195131961319713198131991320013201132021320313204132051320613207132081320913210132111321213213132141321513216132171321813219132201322113222132231322413225132261322713228132291323013231132321323313234132351323613237132381323913240132411324213243132441324513246132471324813249132501325113252132531325413255132561325713258132591326013261132621326313264132651326613267132681326913270132711327213273132741327513276132771327813279132801328113282132831328413285132861328713288132891329013291132921329313294132951329613297132981329913300133011330213303133041330513306133071330813309133101331113312133131331413315133161331713318133191332013321133221332313324133251332613327133281332913330133311333213333133341333513336133371333813339133401334113342133431334413345133461334713348133491335013351133521335313354133551335613357133581335913360133611336213363133641336513366133671336813369133701337113372133731337413375133761337713378133791338013381133821338313384133851338613387133881338913390133911339213393133941339513396133971339813399134001340113402134031340413405134061340713408134091341013411134121341313414134151341613417134181341913420134211342213423134241342513426134271342813429134301343113432134331343413435134361343713438134391344013441134421344313444134451344613447134481344913450134511345213453134541345513456134571345813459134601346113462134631346413465134661346713468134691347013471134721347313474134751347613477134781347913480134811348213483134841348513486134871348813489134901349113492134931349413495134961349713498134991350013501135021350313504135051350613507135081350913510135111351213513135141351513516135171351813519135201352113522135231352413525135261352713528135291353013531135321353313534135351353613537135381353913540135411354213543135441354513546135471354813549135501355113552135531355413555135561355713558135591356013561135621356313564135651356613567135681356913570135711357213573135741357513576135771357813579135801358113582135831358413585135861358713588135891359013591135921359313594135951359613597135981359913600136011360213603136041360513606136071360813609136101361113612136131361413615136161361713618136191362013621136221362313624136251362613627136281362913630136311363213633136341363513636136371363813639136401364113642136431364413645136461364713648136491365013651136521365313654136551365613657136581365913660136611366213663136641366513666136671366813669136701367113672136731367413675136761367713678136791368013681136821368313684136851368613687136881368913690136911369213693136941369513696136971369813699137001370113702137031370413705137061370713708137091371013711137121371313714137151371613717137181371913720137211372213723137241372513726137271372813729137301373113732137331373413735137361373713738137391374013741137421374313744137451374613747137481374913750137511375213753137541375513756137571375813759137601376113762137631376413765137661376713768137691377013771137721377313774137751377613777137781377913780137811378213783137841378513786137871378813789137901379113792137931379413795137961379713798137991380013801138021380313804138051380613807138081380913810138111381213813138141381513816138171381813819138201382113822138231382413825138261382713828138291383013831138321383313834138351383613837138381383913840138411384213843138441384513846138471384813849138501385113852138531385413855138561385713858138591386013861138621386313864138651386613867138681386913870138711387213873138741387513876138771387813879138801388113882138831388413885138861388713888138891389013891138921389313894138951389613897138981389913900139011390213903139041390513906139071390813909139101391113912139131391413915139161391713918139191392013921139221392313924139251392613927139281392913930139311393213933139341393513936139371393813939139401394113942139431394413945139461394713948139491395013951139521395313954139551395613957139581395913960139611396213963139641396513966139671396813969139701397113972139731397413975139761397713978139791398013981139821398313984139851398613987139881398913990139911399213993139941399513996139971399813999140001400114002140031400414005140061400714008140091401014011140121401314014140151401614017140181401914020140211402214023140241402514026140271402814029140301403114032140331403414035140361403714038140391404014041140421404314044140451404614047140481404914050140511405214053140541405514056140571405814059140601406114062140631406414065140661406714068140691407014071140721407314074140751407614077140781407914080140811408214083140841408514086140871408814089140901409114092140931409414095140961409714098140991410014101141021410314104141051410614107141081410914110141111411214113141141411514116141171411814119141201412114122141231412414125141261412714128141291413014131141321413314134141351413614137141381413914140141411414214143141441414514146141471414814149141501415114152141531415414155141561415714158141591416014161141621416314164141651416614167141681416914170141711417214173141741417514176141771417814179141801418114182141831418414185141861418714188141891419014191141921419314194141951419614197141981419914200142011420214203142041420514206 |
- (function(factory) {
- if (typeof define === 'function' && define.amd) {
- define([ 'jquery', 'moment' ], factory);
- }
- else if (typeof exports === 'object') {
- module.exports = factory(require('jquery'), require('moment'));
- }
- else {
- factory(jQuery, moment);
- }
- })(function($, moment) {
- ;;
- var FC = $.fullCalendar = {
- version: "3.1.0",
- internalApiVersion: 7
- };
- var fcViews = FC.views = {};
- $.fn.fullCalendar = function(options) {
- var args = Array.prototype.slice.call(arguments, 1);
- var res = this;
- this.each(function(i, _element) {
- var element = $(_element);
- var calendar = element.data('fullCalendar');
- var singleRes;
-
- if (typeof options === 'string') {
- if (calendar && $.isFunction(calendar[options])) {
- singleRes = calendar[options].apply(calendar, args);
- if (!i) {
- res = singleRes;
- }
- if (options === 'destroy') {
- element.removeData('fullCalendar');
- }
- }
- }
-
- else if (!calendar) {
- calendar = new Calendar(element, options);
- element.data('fullCalendar', calendar);
- calendar.render();
- }
- });
- return res;
- };
- var complexOptions = [
- 'header',
- 'footer',
- 'buttonText',
- 'buttonIcons',
- 'themeButtonIcons'
- ];
- function mergeOptions(optionObjs) {
- return mergeProps(optionObjs, complexOptions);
- }
- ;;
- FC.intersectRanges = intersectRanges;
- FC.applyAll = applyAll;
- FC.debounce = debounce;
- FC.isInt = isInt;
- FC.htmlEscape = htmlEscape;
- FC.cssToStr = cssToStr;
- FC.proxy = proxy;
- FC.capitaliseFirstLetter = capitaliseFirstLetter;
- function compensateScroll(rowEls, scrollbarWidths) {
- if (scrollbarWidths.left) {
- rowEls.css({
- 'border-left-width': 1,
- 'margin-left': scrollbarWidths.left - 1
- });
- }
- if (scrollbarWidths.right) {
- rowEls.css({
- 'border-right-width': 1,
- 'margin-right': scrollbarWidths.right - 1
- });
- }
- }
- function uncompensateScroll(rowEls) {
- rowEls.css({
- 'margin-left': '',
- 'margin-right': '',
- 'border-left-width': '',
- 'border-right-width': ''
- });
- }
- function disableCursor() {
- $('body').addClass('fc-not-allowed');
- }
- function enableCursor() {
- $('body').removeClass('fc-not-allowed');
- }
- function distributeHeight(els, availableHeight, shouldRedistribute) {
-
-
- var minOffset1 = Math.floor(availableHeight / els.length);
- var minOffset2 = Math.floor(availableHeight - minOffset1 * (els.length - 1));
- var flexEls = [];
- var flexOffsets = [];
- var flexHeights = [];
- var usedHeight = 0;
- undistributeHeight(els);
-
-
- els.each(function(i, el) {
- var minOffset = i === els.length - 1 ? minOffset2 : minOffset1;
- var naturalOffset = $(el).outerHeight(true);
- if (naturalOffset < minOffset) {
- flexEls.push(el);
- flexOffsets.push(naturalOffset);
- flexHeights.push($(el).height());
- }
- else {
-
- usedHeight += naturalOffset;
- }
- });
-
- if (shouldRedistribute) {
- availableHeight -= usedHeight;
- minOffset1 = Math.floor(availableHeight / flexEls.length);
- minOffset2 = Math.floor(availableHeight - minOffset1 * (flexEls.length - 1));
- }
-
- $(flexEls).each(function(i, el) {
- var minOffset = i === flexEls.length - 1 ? minOffset2 : minOffset1;
- var naturalOffset = flexOffsets[i];
- var naturalHeight = flexHeights[i];
- var newHeight = minOffset - (naturalOffset - naturalHeight);
- if (naturalOffset < minOffset) {
- $(el).height(newHeight);
- }
- });
- }
- function undistributeHeight(els) {
- els.height('');
- }
- function matchCellWidths(els) {
- var maxInnerWidth = 0;
- els.find('> *').each(function(i, innerEl) {
- var innerWidth = $(innerEl).outerWidth();
- if (innerWidth > maxInnerWidth) {
- maxInnerWidth = innerWidth;
- }
- });
- maxInnerWidth++;
- els.width(maxInnerWidth);
- return maxInnerWidth;
- }
- function subtractInnerElHeight(outerEl, innerEl) {
- var both = outerEl.add(innerEl);
- var diff;
-
- both.css({
- position: 'relative',
- left: -1
- });
- diff = outerEl.outerHeight() - innerEl.outerHeight();
- both.css({ position: '', left: '' });
- return diff;
- }
- FC.getOuterRect = getOuterRect;
- FC.getClientRect = getClientRect;
- FC.getContentRect = getContentRect;
- FC.getScrollbarWidths = getScrollbarWidths;
- function getScrollParent(el) {
- var position = el.css('position'),
- scrollParent = el.parents().filter(function() {
- var parent = $(this);
- return (/(auto|scroll)/).test(
- parent.css('overflow') + parent.css('overflow-y') + parent.css('overflow-x')
- );
- }).eq(0);
- return position === 'fixed' || !scrollParent.length ? $(el[0].ownerDocument || document) : scrollParent;
- }
- function getOuterRect(el, origin) {
- var offset = el.offset();
- var left = offset.left - (origin ? origin.left : 0);
- var top = offset.top - (origin ? origin.top : 0);
- return {
- left: left,
- right: left + el.outerWidth(),
- top: top,
- bottom: top + el.outerHeight()
- };
- }
- function getClientRect(el, origin) {
- var offset = el.offset();
- var scrollbarWidths = getScrollbarWidths(el);
- var left = offset.left + getCssFloat(el, 'border-left-width') + scrollbarWidths.left - (origin ? origin.left : 0);
- var top = offset.top + getCssFloat(el, 'border-top-width') + scrollbarWidths.top - (origin ? origin.top : 0);
- return {
- left: left,
- right: left + el[0].clientWidth,
- top: top,
- bottom: top + el[0].clientHeight
- };
- }
- function getContentRect(el, origin) {
- var offset = el.offset();
- var left = offset.left + getCssFloat(el, 'border-left-width') + getCssFloat(el, 'padding-left') -
- (origin ? origin.left : 0);
- var top = offset.top + getCssFloat(el, 'border-top-width') + getCssFloat(el, 'padding-top') -
- (origin ? origin.top : 0);
- return {
- left: left,
- right: left + el.width(),
- top: top,
- bottom: top + el.height()
- };
- }
- function getScrollbarWidths(el) {
- var leftRightWidth = el.innerWidth() - el[0].clientWidth;
- var widths = {
- left: 0,
- right: 0,
- top: 0,
- bottom: el.innerHeight() - el[0].clientHeight
- };
- if (getIsLeftRtlScrollbars() && el.css('direction') == 'rtl') {
- widths.left = leftRightWidth;
- }
- else {
- widths.right = leftRightWidth;
- }
- return widths;
- }
- var _isLeftRtlScrollbars = null;
- function getIsLeftRtlScrollbars() {
- if (_isLeftRtlScrollbars === null) {
- _isLeftRtlScrollbars = computeIsLeftRtlScrollbars();
- }
- return _isLeftRtlScrollbars;
- }
- function computeIsLeftRtlScrollbars() {
- var el = $('<div><div/></div>')
- .css({
- position: 'absolute',
- top: -1000,
- left: 0,
- border: 0,
- padding: 0,
- overflow: 'scroll',
- direction: 'rtl'
- })
- .appendTo('body');
- var innerEl = el.children();
- var res = innerEl.offset().left > el.offset().left;
- el.remove();
- return res;
- }
- function getCssFloat(el, prop) {
- return parseFloat(el.css(prop)) || 0;
- }
- FC.preventDefault = preventDefault;
- function isPrimaryMouseButton(ev) {
- return ev.which == 1 && !ev.ctrlKey;
- }
- function getEvX(ev) {
- if (ev.pageX !== undefined) {
- return ev.pageX;
- }
- var touches = ev.originalEvent.touches;
- if (touches) {
- return touches[0].pageX;
- }
- }
- function getEvY(ev) {
- if (ev.pageY !== undefined) {
- return ev.pageY;
- }
- var touches = ev.originalEvent.touches;
- if (touches) {
- return touches[0].pageY;
- }
- }
- function getEvIsTouch(ev) {
- return /^touch/.test(ev.type);
- }
- function preventSelection(el) {
- el.addClass('fc-unselectable')
- .on('selectstart', preventDefault);
- }
- function preventDefault(ev) {
- ev.preventDefault();
- }
- function bindAnyScroll(handler) {
- if (window.addEventListener) {
- window.addEventListener('scroll', handler, true);
- return true;
- }
- return false;
- }
- function unbindAnyScroll(handler) {
- if (window.removeEventListener) {
- window.removeEventListener('scroll', handler, true);
- return true;
- }
- return false;
- }
- FC.intersectRects = intersectRects;
- function intersectRects(rect1, rect2) {
- var res = {
- left: Math.max(rect1.left, rect2.left),
- right: Math.min(rect1.right, rect2.right),
- top: Math.max(rect1.top, rect2.top),
- bottom: Math.min(rect1.bottom, rect2.bottom)
- };
- if (res.left < res.right && res.top < res.bottom) {
- return res;
- }
- return false;
- }
- function constrainPoint(point, rect) {
- return {
- left: Math.min(Math.max(point.left, rect.left), rect.right),
- top: Math.min(Math.max(point.top, rect.top), rect.bottom)
- };
- }
- function getRectCenter(rect) {
- return {
- left: (rect.left + rect.right) / 2,
- top: (rect.top + rect.bottom) / 2
- };
- }
- function diffPoints(point1, point2) {
- return {
- left: point1.left - point2.left,
- top: point1.top - point2.top
- };
- }
- FC.parseFieldSpecs = parseFieldSpecs;
- FC.compareByFieldSpecs = compareByFieldSpecs;
- FC.compareByFieldSpec = compareByFieldSpec;
- FC.flexibleCompare = flexibleCompare;
- function parseFieldSpecs(input) {
- var specs = [];
- var tokens = [];
- var i, token;
- if (typeof input === 'string') {
- tokens = input.split(/\s*,\s*/);
- }
- else if (typeof input === 'function') {
- tokens = [ input ];
- }
- else if ($.isArray(input)) {
- tokens = input;
- }
- for (i = 0; i < tokens.length; i++) {
- token = tokens[i];
- if (typeof token === 'string') {
- specs.push(
- token.charAt(0) == '-' ?
- { field: token.substring(1), order: -1 } :
- { field: token, order: 1 }
- );
- }
- else if (typeof token === 'function') {
- specs.push({ func: token });
- }
- }
- return specs;
- }
- function compareByFieldSpecs(obj1, obj2, fieldSpecs) {
- var i;
- var cmp;
- for (i = 0; i < fieldSpecs.length; i++) {
- cmp = compareByFieldSpec(obj1, obj2, fieldSpecs[i]);
- if (cmp) {
- return cmp;
- }
- }
- return 0;
- }
- function compareByFieldSpec(obj1, obj2, fieldSpec) {
- if (fieldSpec.func) {
- return fieldSpec.func(obj1, obj2);
- }
- return flexibleCompare(obj1[fieldSpec.field], obj2[fieldSpec.field]) *
- (fieldSpec.order || 1);
- }
- function flexibleCompare(a, b) {
- if (!a && !b) {
- return 0;
- }
- if (b == null) {
- return -1;
- }
- if (a == null) {
- return 1;
- }
- if ($.type(a) === 'string' || $.type(b) === 'string') {
- return String(a).localeCompare(String(b));
- }
- return a - b;
- }
- function intersectRanges(subjectRange, constraintRange) {
- var subjectStart = subjectRange.start;
- var subjectEnd = subjectRange.end;
- var constraintStart = constraintRange.start;
- var constraintEnd = constraintRange.end;
- var segStart, segEnd;
- var isStart, isEnd;
- if (subjectEnd > constraintStart && subjectStart < constraintEnd) {
- if (subjectStart >= constraintStart) {
- segStart = subjectStart.clone();
- isStart = true;
- }
- else {
- segStart = constraintStart.clone();
- isStart = false;
- }
- if (subjectEnd <= constraintEnd) {
- segEnd = subjectEnd.clone();
- isEnd = true;
- }
- else {
- segEnd = constraintEnd.clone();
- isEnd = false;
- }
- return {
- start: segStart,
- end: segEnd,
- isStart: isStart,
- isEnd: isEnd
- };
- }
- }
- FC.computeIntervalUnit = computeIntervalUnit;
- FC.divideRangeByDuration = divideRangeByDuration;
- FC.divideDurationByDuration = divideDurationByDuration;
- FC.multiplyDuration = multiplyDuration;
- FC.durationHasTime = durationHasTime;
- var dayIDs = [ 'sun', 'mon', 'tue', 'wed', 'thu', 'fri', 'sat' ];
- var intervalUnits = [ 'year', 'month', 'week', 'day', 'hour', 'minute', 'second', 'millisecond' ];
- function diffDayTime(a, b) {
- return moment.duration({
- days: a.clone().stripTime().diff(b.clone().stripTime(), 'days'),
- ms: a.time() - b.time()
- });
- }
- function diffDay(a, b) {
- return moment.duration({
- days: a.clone().stripTime().diff(b.clone().stripTime(), 'days')
- });
- }
- function diffByUnit(a, b, unit) {
- return moment.duration(
- Math.round(a.diff(b, unit, true)),
- unit
- );
- }
- function computeIntervalUnit(start, end) {
- var i, unit;
- var val;
- for (i = 0; i < intervalUnits.length; i++) {
- unit = intervalUnits[i];
- val = computeRangeAs(unit, start, end);
- if (val >= 1 && isInt(val)) {
- break;
- }
- }
- return unit;
- }
- function computeRangeAs(unit, start, end) {
- if (end != null) {
- return end.diff(start, unit, true);
- }
- else if (moment.isDuration(start)) {
- return start.as(unit);
- }
- else {
- return start.end.diff(start.start, unit, true);
- }
- }
- function divideRangeByDuration(start, end, dur) {
- var months;
- if (durationHasTime(dur)) {
- return (end - start) / dur;
- }
- months = dur.asMonths();
- if (Math.abs(months) >= 1 && isInt(months)) {
- return end.diff(start, 'months', true) / months;
- }
- return end.diff(start, 'days', true) / dur.asDays();
- }
- function divideDurationByDuration(dur1, dur2) {
- var months1, months2;
- if (durationHasTime(dur1) || durationHasTime(dur2)) {
- return dur1 / dur2;
- }
- months1 = dur1.asMonths();
- months2 = dur2.asMonths();
- if (
- Math.abs(months1) >= 1 && isInt(months1) &&
- Math.abs(months2) >= 1 && isInt(months2)
- ) {
- return months1 / months2;
- }
- return dur1.asDays() / dur2.asDays();
- }
- function multiplyDuration(dur, n) {
- var months;
- if (durationHasTime(dur)) {
- return moment.duration(dur * n);
- }
- months = dur.asMonths();
- if (Math.abs(months) >= 1 && isInt(months)) {
- return moment.duration({ months: months * n });
- }
- return moment.duration({ days: dur.asDays() * n });
- }
- function durationHasTime(dur) {
- return Boolean(dur.hours() || dur.minutes() || dur.seconds() || dur.milliseconds());
- }
- function isNativeDate(input) {
- return Object.prototype.toString.call(input) === '[object Date]' || input instanceof Date;
- }
- function isTimeString(str) {
- return /^\d+\:\d+(?:\:\d+\.?(?:\d{3})?)?$/.test(str);
- }
- FC.log = function() {
- var console = window.console;
- if (console && console.log) {
- return console.log.apply(console, arguments);
- }
- };
- FC.warn = function() {
- var console = window.console;
- if (console && console.warn) {
- return console.warn.apply(console, arguments);
- }
- else {
- return FC.log.apply(FC, arguments);
- }
- };
- var hasOwnPropMethod = {}.hasOwnProperty;
- function mergeProps(propObjs, complexProps) {
- var dest = {};
- var i, name;
- var complexObjs;
- var j, val;
- var props;
- if (complexProps) {
- for (i = 0; i < complexProps.length; i++) {
- name = complexProps[i];
- complexObjs = [];
-
- for (j = propObjs.length - 1; j >= 0; j--) {
- val = propObjs[j][name];
- if (typeof val === 'object') {
- complexObjs.unshift(val);
- }
- else if (val !== undefined) {
- dest[name] = val;
- break;
- }
- }
-
- if (complexObjs.length) {
- dest[name] = mergeProps(complexObjs);
- }
- }
- }
-
- for (i = propObjs.length - 1; i >= 0; i--) {
- props = propObjs[i];
- for (name in props) {
- if (!(name in dest)) {
- dest[name] = props[name];
- }
- }
- }
- return dest;
- }
- function createObject(proto) {
- var f = function() {};
- f.prototype = proto;
- return new f();
- }
- FC.createObject = createObject;
- function copyOwnProps(src, dest) {
- for (var name in src) {
- if (hasOwnProp(src, name)) {
- dest[name] = src[name];
- }
- }
- }
- function hasOwnProp(obj, name) {
- return hasOwnPropMethod.call(obj, name);
- }
- function isAtomic(val) {
- return /undefined|null|boolean|number|string/.test($.type(val));
- }
- function applyAll(functions, thisObj, args) {
- if ($.isFunction(functions)) {
- functions = [ functions ];
- }
- if (functions) {
- var i;
- var ret;
- for (i=0; i<functions.length; i++) {
- ret = functions[i].apply(thisObj, args) || ret;
- }
- return ret;
- }
- }
- function firstDefined() {
- for (var i=0; i<arguments.length; i++) {
- if (arguments[i] !== undefined) {
- return arguments[i];
- }
- }
- }
- function htmlEscape(s) {
- return (s + '').replace(/&/g, '&')
- .replace(/</g, '<')
- .replace(/>/g, '>')
- .replace(/'/g, ''')
- .replace(/"/g, '"')
- .replace(/\n/g, '<br />');
- }
- function stripHtmlEntities(text) {
- return text.replace(/&.*?;/g, '');
- }
- function cssToStr(cssProps) {
- var statements = [];
- $.each(cssProps, function(name, val) {
- if (val != null) {
- statements.push(name + ':' + val);
- }
- });
- return statements.join(';');
- }
- function attrsToStr(attrs) {
- var parts = [];
- $.each(attrs, function(name, val) {
- if (val != null) {
- parts.push(name + '="' + htmlEscape(val) + '"');
- }
- });
- return parts.join(' ');
- }
- function capitaliseFirstLetter(str) {
- return str.charAt(0).toUpperCase() + str.slice(1);
- }
- function compareNumbers(a, b) {
- return a - b;
- }
- function isInt(n) {
- return n % 1 === 0;
- }
- function proxy(obj, methodName) {
- var method = obj[methodName];
- return function() {
- return method.apply(obj, arguments);
- };
- }
- function debounce(func, wait, immediate) {
- var timeout, args, context, timestamp, result;
- var later = function() {
- var last = +new Date() - timestamp;
- if (last < wait) {
- timeout = setTimeout(later, wait - last);
- }
- else {
- timeout = null;
- if (!immediate) {
- result = func.apply(context, args);
- context = args = null;
- }
- }
- };
- return function() {
- context = this;
- args = arguments;
- timestamp = +new Date();
- var callNow = immediate && !timeout;
- if (!timeout) {
- timeout = setTimeout(later, wait);
- }
- if (callNow) {
- result = func.apply(context, args);
- context = args = null;
- }
- return result;
- };
- }
- ;;
- var ambigDateOfMonthRegex = /^\s*\d{4}-\d\d$/;
- var ambigTimeOrZoneRegex =
- /^\s*\d{4}-(?:(\d\d-\d\d)|(W\d\d$)|(W\d\d-\d)|(\d\d\d))((T| )(\d\d(:\d\d(:\d\d(\.\d+)?)?)?)?)?$/;
- var newMomentProto = moment.fn;
- var oldMomentProto = $.extend({}, newMomentProto);
- var momentProperties = moment.momentProperties;
- momentProperties.push('_fullCalendar');
- momentProperties.push('_ambigTime');
- momentProperties.push('_ambigZone');
- FC.moment = function() {
- return makeMoment(arguments);
- };
- FC.moment.utc = function() {
- var mom = makeMoment(arguments, true);
-
-
- if (mom.hasTime()) {
- mom.utc();
- }
- return mom;
- };
- FC.moment.parseZone = function() {
- return makeMoment(arguments, true, true);
- };
- function makeMoment(args, parseAsUTC, parseZone) {
- var input = args[0];
- var isSingleString = args.length == 1 && typeof input === 'string';
- var isAmbigTime;
- var isAmbigZone;
- var ambigMatch;
- var mom;
- if (moment.isMoment(input) || isNativeDate(input) || input === undefined) {
- mom = moment.apply(null, args);
- }
- else {
- isAmbigTime = false;
- isAmbigZone = false;
- if (isSingleString) {
- if (ambigDateOfMonthRegex.test(input)) {
-
- input += '-01';
- args = [ input ];
- isAmbigTime = true;
- isAmbigZone = true;
- }
- else if ((ambigMatch = ambigTimeOrZoneRegex.exec(input))) {
- isAmbigTime = !ambigMatch[5];
- isAmbigZone = true;
- }
- }
- else if ($.isArray(input)) {
-
- isAmbigZone = true;
- }
-
- if (parseAsUTC || isAmbigTime) {
- mom = moment.utc.apply(moment, args);
- }
- else {
- mom = moment.apply(null, args);
- }
- if (isAmbigTime) {
- mom._ambigTime = true;
- mom._ambigZone = true;
- }
- else if (parseZone) {
- if (isAmbigZone) {
- mom._ambigZone = true;
- }
- else if (isSingleString) {
- mom.utcOffset(input);
- }
- }
- }
- mom._fullCalendar = true;
- return mom;
- }
- newMomentProto.week = newMomentProto.weeks = function(input) {
- var weekCalc = this._locale._fullCalendar_weekCalc;
- if (input == null && typeof weekCalc === 'function') {
- return weekCalc(this);
- }
- else if (weekCalc === 'ISO') {
- return oldMomentProto.isoWeek.apply(this, arguments);
- }
- return oldMomentProto.week.apply(this, arguments);
- };
- newMomentProto.time = function(time) {
-
-
- if (!this._fullCalendar) {
- return oldMomentProto.time.apply(this, arguments);
- }
- if (time == null) {
- return moment.duration({
- hours: this.hours(),
- minutes: this.minutes(),
- seconds: this.seconds(),
- milliseconds: this.milliseconds()
- });
- }
- else {
- this._ambigTime = false;
- if (!moment.isDuration(time) && !moment.isMoment(time)) {
- time = moment.duration(time);
- }
-
-
- var dayHours = 0;
- if (moment.isDuration(time)) {
- dayHours = Math.floor(time.asDays()) * 24;
- }
-
-
- return this.hours(dayHours + time.hours())
- .minutes(time.minutes())
- .seconds(time.seconds())
- .milliseconds(time.milliseconds());
- }
- };
- newMomentProto.stripTime = function() {
- if (!this._ambigTime) {
- this.utc(true);
-
- this.set({
- hours: 0,
- minutes: 0,
- seconds: 0,
- ms: 0
- });
-
-
- this._ambigTime = true;
- this._ambigZone = true;
- }
- return this;
- };
- newMomentProto.hasTime = function() {
- return !this._ambigTime;
- };
- newMomentProto.stripZone = function() {
- var wasAmbigTime;
- if (!this._ambigZone) {
- wasAmbigTime = this._ambigTime;
- this.utc(true);
-
- this._ambigTime = wasAmbigTime || false;
-
-
- this._ambigZone = true;
- }
- return this;
- };
- newMomentProto.hasZone = function() {
- return !this._ambigZone;
- };
- newMomentProto.local = function(keepLocalTime) {
-
-
- oldMomentProto.local.call(this, this._ambigZone || keepLocalTime);
-
-
- this._ambigTime = false;
- this._ambigZone = false;
- return this;
- };
- newMomentProto.utc = function(keepLocalTime) {
- oldMomentProto.utc.call(this, keepLocalTime);
-
-
- this._ambigTime = false;
- this._ambigZone = false;
- return this;
- };
- newMomentProto.utcOffset = function(tzo) {
- if (tzo != null) {
-
-
- this._ambigTime = false;
- this._ambigZone = false;
- }
- return oldMomentProto.utcOffset.apply(this, arguments);
- };
- newMomentProto.format = function() {
- if (this._fullCalendar && arguments[0]) {
- return formatDate(this, arguments[0]);
- }
- if (this._ambigTime) {
- return oldMomentFormat(this, 'YYYY-MM-DD');
- }
- if (this._ambigZone) {
- return oldMomentFormat(this, 'YYYY-MM-DD[T]HH:mm:ss');
- }
- return oldMomentProto.format.apply(this, arguments);
- };
- newMomentProto.toISOString = function() {
- if (this._ambigTime) {
- return oldMomentFormat(this, 'YYYY-MM-DD');
- }
- if (this._ambigZone) {
- return oldMomentFormat(this, 'YYYY-MM-DD[T]HH:mm:ss');
- }
- return oldMomentProto.toISOString.apply(this, arguments);
- };
- ;;
- function oldMomentFormat(mom, formatStr) {
- return oldMomentProto.format.call(mom, formatStr);
- }
- function formatDate(date, formatStr) {
- return formatDateWithChunks(date, getFormatStringChunks(formatStr));
- }
- function formatDateWithChunks(date, chunks) {
- var s = '';
- var i;
- for (i=0; i<chunks.length; i++) {
- s += formatDateWithChunk(date, chunks[i]);
- }
- return s;
- }
- var tokenOverrides = {
- t: function(date) {
- return oldMomentFormat(date, 'a').charAt(0);
- },
- T: function(date) {
- return oldMomentFormat(date, 'A').charAt(0);
- }
- };
- function formatDateWithChunk(date, chunk) {
- var token;
- var maybeStr;
- if (typeof chunk === 'string') {
- return chunk;
- }
- else if ((token = chunk.token)) {
- if (tokenOverrides[token]) {
- return tokenOverrides[token](date);
- }
- return oldMomentFormat(date, token);
- }
- else if (chunk.maybe) {
- maybeStr = formatDateWithChunks(date, chunk.maybe);
- if (maybeStr.match(/[1-9]/)) {
- return maybeStr;
- }
- }
- return '';
- }
- function formatRange(date1, date2, formatStr, separator, isRTL) {
- var localeData;
- date1 = FC.moment.parseZone(date1);
- date2 = FC.moment.parseZone(date2);
- localeData = date1.localeData();
-
- formatStr = localeData.longDateFormat(formatStr) || formatStr;
-
-
- separator = separator || ' - ';
- return formatRangeWithChunks(
- date1,
- date2,
- getFormatStringChunks(formatStr),
- separator,
- isRTL
- );
- }
- FC.formatRange = formatRange;
- function formatRangeWithChunks(date1, date2, chunks, separator, isRTL) {
- var unzonedDate1 = date1.clone().stripZone();
- var unzonedDate2 = date2.clone().stripZone();
- var chunkStr;
- var leftI;
- var leftStr = '';
- var rightI;
- var rightStr = '';
- var middleI;
- var middleStr1 = '';
- var middleStr2 = '';
- var middleStr = '';
-
-
- for (leftI=0; leftI<chunks.length; leftI++) {
- chunkStr = formatSimilarChunk(date1, date2, unzonedDate1, unzonedDate2, chunks[leftI]);
- if (chunkStr === false) {
- break;
- }
- leftStr += chunkStr;
- }
-
- for (rightI=chunks.length-1; rightI>leftI; rightI--) {
- chunkStr = formatSimilarChunk(date1, date2, unzonedDate1, unzonedDate2, chunks[rightI]);
- if (chunkStr === false) {
- break;
- }
- rightStr = chunkStr + rightStr;
- }
-
-
- for (middleI=leftI; middleI<=rightI; middleI++) {
- middleStr1 += formatDateWithChunk(date1, chunks[middleI]);
- middleStr2 += formatDateWithChunk(date2, chunks[middleI]);
- }
- if (middleStr1 || middleStr2) {
- if (isRTL) {
- middleStr = middleStr2 + separator + middleStr1;
- }
- else {
- middleStr = middleStr1 + separator + middleStr2;
- }
- }
- return leftStr + middleStr + rightStr;
- }
- var similarUnitMap = {
- Y: 'year',
- M: 'month',
- D: 'day',
- d: 'day',
-
- A: 'second',
- a: 'second',
- T: 'second',
- t: 'second',
- H: 'second',
- h: 'second',
- m: 'second',
- s: 'second'
- };
- function formatSimilarChunk(date1, date2, unzonedDate1, unzonedDate2, chunk) {
- var token;
- var unit;
- if (typeof chunk === 'string') {
- return chunk;
- }
- else if ((token = chunk.token)) {
- unit = similarUnitMap[token.charAt(0)];
-
-
- if (unit && unzonedDate1.isSame(unzonedDate2, unit)) {
- return oldMomentFormat(date1, token);
-
- }
- }
- return false;
-
- }
- var formatStringChunkCache = {};
- function getFormatStringChunks(formatStr) {
- if (formatStr in formatStringChunkCache) {
- return formatStringChunkCache[formatStr];
- }
- return (formatStringChunkCache[formatStr] = chunkFormatString(formatStr));
- }
- function chunkFormatString(formatStr) {
- var chunks = [];
- var chunker = /\[([^\]]*)\]|\(([^\)]*)\)|(LTS|LT|(\w)\4*o?)|([^\w\[\(]+)/g;
- var match;
- while ((match = chunker.exec(formatStr))) {
- if (match[1]) {
- chunks.push(match[1]);
- }
- else if (match[2]) {
- chunks.push({ maybe: chunkFormatString(match[2]) });
- }
- else if (match[3]) {
- chunks.push({ token: match[3] });
- }
- else if (match[5]) {
- chunks.push(match[5]);
- }
- }
- return chunks;
- }
- var tokenGranularities = {
- Y: { value: 1, unit: 'year' },
- M: { value: 2, unit: 'month' },
- W: { value: 3, unit: 'week' },
- w: { value: 3, unit: 'week' },
- D: { value: 4, unit: 'day' },
- d: { value: 4, unit: 'day' }
- };
- FC.queryMostGranularFormatUnit = function(formatStr) {
- var chunks = getFormatStringChunks(formatStr);
- var i, chunk;
- var candidate;
- var best;
- for (i = 0; i < chunks.length; i++) {
- chunk = chunks[i];
- if (chunk.token) {
- candidate = tokenGranularities[chunk.token.charAt(0)];
- if (candidate) {
- if (!best || candidate.value > best.value) {
- best = candidate;
- }
- }
- }
- }
- if (best) {
- return best.unit;
- }
- return null;
- };
- ;;
- FC.Class = Class;
- function Class() { }
- Class.extend = function() {
- var len = arguments.length;
- var i;
- var members;
- for (i = 0; i < len; i++) {
- members = arguments[i];
- if (i < len - 1) {
- mixIntoClass(this, members);
- }
- }
- return extendClass(this, members || {});
- };
- Class.mixin = function(members) {
- mixIntoClass(this, members);
- };
- function extendClass(superClass, members) {
- var subClass;
-
- if (hasOwnProp(members, 'constructor')) {
- subClass = members.constructor;
- }
- if (typeof subClass !== 'function') {
- subClass = members.constructor = function() {
- superClass.apply(this, arguments);
- };
- }
-
- subClass.prototype = createObject(superClass.prototype);
-
- copyOwnProps(members, subClass.prototype);
-
- copyOwnProps(superClass, subClass);
- return subClass;
- }
- function mixIntoClass(theClass, members) {
- copyOwnProps(members, theClass.prototype);
- }
- ;;
- function Promise(executor) {
- var deferred = $.Deferred();
- var promise = deferred.promise();
- if (typeof executor === 'function') {
- executor(
- function(value) {
- if (Promise.immediate) {
- promise._value = value;
- }
- deferred.resolve(value);
- },
- function() {
- deferred.reject();
- }
- );
- }
-
- if (Promise.immediate) {
- var origThen = promise.then;
- promise.then = function(onFulfilled, onRejected) {
- var state = promise.state();
-
- if (state === 'resolved') {
- if (typeof onFulfilled === 'function') {
- return Promise.resolve(onFulfilled(promise._value));
- }
- }
- else if (state === 'rejected') {
- if (typeof onRejected === 'function') {
- onRejected();
- return promise;
- }
- }
- return origThen.call(promise, onFulfilled, onRejected);
- };
- }
- return promise;
- }
- FC.Promise = Promise;
- Promise.immediate = true;
- Promise.resolve = function(value) {
- if (value && typeof value.resolve === 'function') {
- return value.promise();
- }
- if (value && typeof value.then === 'function') {
- return value;
- }
- else {
- var deferred = $.Deferred().resolve(value);
- var promise = deferred.promise();
- if (Promise.immediate) {
- var origThen = promise.then;
- promise._value = value;
- promise.then = function(onFulfilled, onRejected) {
- if (typeof onFulfilled === 'function') {
- return Promise.resolve(onFulfilled(value));
- }
- return origThen.call(promise, onFulfilled, onRejected);
- };
- }
- return promise;
- }
- };
- Promise.reject = function() {
- return $.Deferred().reject().promise();
- };
- Promise.all = function(inputs) {
- var hasAllValues = false;
- var values;
- var i, input;
- if (Promise.immediate) {
- hasAllValues = true;
- values = [];
- for (i = 0; i < inputs.length; i++) {
- input = inputs[i];
- if (input && typeof input.state === 'function' && input.state() === 'resolved' && ('_value' in input)) {
- values.push(input._value);
- }
- else if (input && typeof input.then === 'function') {
- hasAllValues = false;
- break;
- }
- else {
- values.push(input);
- }
- }
- }
- if (hasAllValues) {
- return Promise.resolve(values);
- }
- else {
- return $.when.apply($.when, inputs).then(function() {
- return $.when($.makeArray(arguments));
- });
- }
- };
- ;;
- function TaskQueue(debounceWait) {
- var q = [];
- function addTask(taskFunc) {
- return new Promise(function(resolve) {
-
-
- var runFunc = function() {
- Promise.resolve(taskFunc())
- .then(resolve)
- .then(function() {
- q.shift();
-
- if (q.length) {
- q[0]();
- }
- });
- };
-
- q.push(runFunc);
-
- if (q.length === 1) {
- runFunc();
- }
- });
- }
- this.add =
- typeof debounceWait === 'number' ?
- debounce(addTask, debounceWait) :
- addTask;
- this.addQuickly = addTask;
- }
- FC.TaskQueue = TaskQueue;
- ;;
- var EmitterMixin = FC.EmitterMixin = {
-
-
- on: function(types, handler) {
- $(this).on(types, this._prepareIntercept(handler));
- return this;
- },
- one: function(types, handler) {
- $(this).one(types, this._prepareIntercept(handler));
- return this;
- },
- _prepareIntercept: function(handler) {
-
-
-
- var intercept = function(ev, extra) {
- return handler.apply(
- extra.context || this,
- extra.args || []
- );
- };
-
-
-
-
- if (!handler.guid) {
- handler.guid = $.guid++;
- }
- intercept.guid = handler.guid;
- return intercept;
- },
- off: function(types, handler) {
- $(this).off(types, handler);
- return this;
- },
- trigger: function(types) {
- var args = Array.prototype.slice.call(arguments, 1);
-
- $(this).triggerHandler(types, { args: args });
- return this;
- },
- triggerWith: function(types, context, args) {
-
-
- $(this).triggerHandler(types, { context: context, args: args });
- return this;
- }
- };
- ;;
- var ListenerMixin = FC.ListenerMixin = (function() {
- var guid = 0;
- var ListenerMixin = {
- listenerId: null,
-
- listenTo: function(other, arg, callback) {
- if (typeof arg === 'object') {
- for (var eventName in arg) {
- if (arg.hasOwnProperty(eventName)) {
- this.listenTo(other, eventName, arg[eventName]);
- }
- }
- }
- else if (typeof arg === 'string') {
- other.on(
- arg + '.' + this.getListenerNamespace(),
- $.proxy(callback, this)
-
-
- );
- }
- },
-
- stopListeningTo: function(other, eventName) {
- other.off((eventName || '') + '.' + this.getListenerNamespace());
- },
-
- getListenerNamespace: function() {
- if (this.listenerId == null) {
- this.listenerId = guid++;
- }
- return '_listener' + this.listenerId;
- }
- };
- return ListenerMixin;
- })();
- ;;
- var MouseIgnorerMixin = {
- isIgnoringMouse: false,
- delayUnignoreMouse: null,
- initMouseIgnoring: function(delay) {
- this.delayUnignoreMouse = debounce(proxy(this, 'unignoreMouse'), delay || 1000);
- },
-
- tempIgnoreMouse: function() {
- this.isIgnoringMouse = true;
- this.delayUnignoreMouse();
- },
-
- unignoreMouse: function() {
- this.isIgnoringMouse = false;
- }
- };
- ;;
- var Popover = Class.extend(ListenerMixin, {
- isHidden: true,
- options: null,
- el: null,
- margin: 10,
- constructor: function(options) {
- this.options = options || {};
- },
-
- show: function() {
- if (this.isHidden) {
- if (!this.el) {
- this.render();
- }
- this.el.show();
- this.position();
- this.isHidden = false;
- this.trigger('show');
- }
- },
-
- hide: function() {
- if (!this.isHidden) {
- this.el.hide();
- this.isHidden = true;
- this.trigger('hide');
- }
- },
-
- render: function() {
- var _this = this;
- var options = this.options;
- this.el = $('<div class="fc-popover"/>')
- .addClass(options.className || '')
- .css({
-
- top: 0,
- left: 0
- })
- .append(options.content)
- .appendTo(options.parentEl);
-
- this.el.on('click', '.fc-close', function() {
- _this.hide();
- });
- if (options.autoHide) {
- this.listenTo($(document), 'mousedown', this.documentMousedown);
- }
- },
-
- documentMousedown: function(ev) {
-
- if (this.el && !$(ev.target).closest(this.el).length) {
- this.hide();
- }
- },
-
- removeElement: function() {
- this.hide();
- if (this.el) {
- this.el.remove();
- this.el = null;
- }
- this.stopListeningTo($(document), 'mousedown');
- },
-
- position: function() {
- var options = this.options;
- var origin = this.el.offsetParent().offset();
- var width = this.el.outerWidth();
- var height = this.el.outerHeight();
- var windowEl = $(window);
- var viewportEl = getScrollParent(this.el);
- var viewportTop;
- var viewportLeft;
- var viewportOffset;
- var top;
- var left;
-
- top = options.top || 0;
- if (options.left !== undefined) {
- left = options.left;
- }
- else if (options.right !== undefined) {
- left = options.right - width;
- }
- else {
- left = 0;
- }
- if (viewportEl.is(window) || viewportEl.is(document)) {
- viewportEl = windowEl;
- viewportTop = 0;
- viewportLeft = 0;
- }
- else {
- viewportOffset = viewportEl.offset();
- viewportTop = viewportOffset.top;
- viewportLeft = viewportOffset.left;
- }
-
- viewportTop += windowEl.scrollTop();
- viewportLeft += windowEl.scrollLeft();
-
- if (options.viewportConstrain !== false) {
- top = Math.min(top, viewportTop + viewportEl.outerHeight() - height - this.margin);
- top = Math.max(top, viewportTop + this.margin);
- left = Math.min(left, viewportLeft + viewportEl.outerWidth() - width - this.margin);
- left = Math.max(left, viewportLeft + this.margin);
- }
- this.el.css({
- top: top - origin.top,
- left: left - origin.left
- });
- },
-
-
-
- trigger: function(name) {
- if (this.options[name]) {
- this.options[name].apply(this, Array.prototype.slice.call(arguments, 1));
- }
- }
- });
- ;;
- var CoordCache = FC.CoordCache = Class.extend({
- els: null,
- forcedOffsetParentEl: null,
- origin: null,
- boundingRect: null,
- isHorizontal: false,
- isVertical: false,
-
- lefts: null,
- rights: null,
- tops: null,
- bottoms: null,
- constructor: function(options) {
- this.els = $(options.els);
- this.isHorizontal = options.isHorizontal;
- this.isVertical = options.isVertical;
- this.forcedOffsetParentEl = options.offsetParent ? $(options.offsetParent) : null;
- },
-
-
- build: function() {
- var offsetParentEl = this.forcedOffsetParentEl;
- if (!offsetParentEl && this.els.length > 0) {
- offsetParentEl = this.els.eq(0).offsetParent();
- }
- this.origin = offsetParentEl ?
- offsetParentEl.offset() :
- null;
- this.boundingRect = this.queryBoundingRect();
- if (this.isHorizontal) {
- this.buildElHorizontals();
- }
- if (this.isVertical) {
- this.buildElVerticals();
- }
- },
-
- clear: function() {
- this.origin = null;
- this.boundingRect = null;
- this.lefts = null;
- this.rights = null;
- this.tops = null;
- this.bottoms = null;
- },
-
- ensureBuilt: function() {
- if (!this.origin) {
- this.build();
- }
- },
-
- buildElHorizontals: function() {
- var lefts = [];
- var rights = [];
- this.els.each(function(i, node) {
- var el = $(node);
- var left = el.offset().left;
- var width = el.outerWidth();
- lefts.push(left);
- rights.push(left + width);
- });
- this.lefts = lefts;
- this.rights = rights;
- },
-
- buildElVerticals: function() {
- var tops = [];
- var bottoms = [];
- this.els.each(function(i, node) {
- var el = $(node);
- var top = el.offset().top;
- var height = el.outerHeight();
- tops.push(top);
- bottoms.push(top + height);
- });
- this.tops = tops;
- this.bottoms = bottoms;
- },
-
-
- getHorizontalIndex: function(leftOffset) {
- this.ensureBuilt();
- var lefts = this.lefts;
- var rights = this.rights;
- var len = lefts.length;
- var i;
- for (i = 0; i < len; i++) {
- if (leftOffset >= lefts[i] && leftOffset < rights[i]) {
- return i;
- }
- }
- },
-
-
- getVerticalIndex: function(topOffset) {
- this.ensureBuilt();
- var tops = this.tops;
- var bottoms = this.bottoms;
- var len = tops.length;
- var i;
- for (i = 0; i < len; i++) {
- if (topOffset >= tops[i] && topOffset < bottoms[i]) {
- return i;
- }
- }
- },
-
- getLeftOffset: function(leftIndex) {
- this.ensureBuilt();
- return this.lefts[leftIndex];
- },
-
- getLeftPosition: function(leftIndex) {
- this.ensureBuilt();
- return this.lefts[leftIndex] - this.origin.left;
- },
-
-
- getRightOffset: function(leftIndex) {
- this.ensureBuilt();
- return this.rights[leftIndex];
- },
-
-
- getRightPosition: function(leftIndex) {
- this.ensureBuilt();
- return this.rights[leftIndex] - this.origin.left;
- },
-
- getWidth: function(leftIndex) {
- this.ensureBuilt();
- return this.rights[leftIndex] - this.lefts[leftIndex];
- },
-
- getTopOffset: function(topIndex) {
- this.ensureBuilt();
- return this.tops[topIndex];
- },
-
- getTopPosition: function(topIndex) {
- this.ensureBuilt();
- return this.tops[topIndex] - this.origin.top;
- },
-
-
- getBottomOffset: function(topIndex) {
- this.ensureBuilt();
- return this.bottoms[topIndex];
- },
-
-
- getBottomPosition: function(topIndex) {
- this.ensureBuilt();
- return this.bottoms[topIndex] - this.origin.top;
- },
-
- getHeight: function(topIndex) {
- this.ensureBuilt();
- return this.bottoms[topIndex] - this.tops[topIndex];
- },
-
-
-
-
-
- queryBoundingRect: function() {
- var scrollParentEl;
- if (this.els.length > 0) {
- scrollParentEl = getScrollParent(this.els.eq(0));
- if (!scrollParentEl.is(document)) {
- return getClientRect(scrollParentEl);
- }
- }
- return null;
- },
- isPointInBounds: function(leftOffset, topOffset) {
- return this.isLeftInBounds(leftOffset) && this.isTopInBounds(topOffset);
- },
- isLeftInBounds: function(leftOffset) {
- return !this.boundingRect || (leftOffset >= this.boundingRect.left && leftOffset < this.boundingRect.right);
- },
- isTopInBounds: function(topOffset) {
- return !this.boundingRect || (topOffset >= this.boundingRect.top && topOffset < this.boundingRect.bottom);
- }
- });
- ;;
- var DragListener = FC.DragListener = Class.extend(ListenerMixin, MouseIgnorerMixin, {
- options: null,
- subjectEl: null,
-
- originX: null,
- originY: null,
-
-
- scrollEl: null,
- isInteracting: false,
- isDistanceSurpassed: false,
- isDelayEnded: false,
- isDragging: false,
- isTouch: false,
- delay: null,
- delayTimeoutId: null,
- minDistance: null,
- handleTouchScrollProxy: null,
- constructor: function(options) {
- this.options = options || {};
- this.handleTouchScrollProxy = proxy(this, 'handleTouchScroll');
- this.initMouseIgnoring(500);
- },
-
-
- startInteraction: function(ev, extraOptions) {
- var isTouch = getEvIsTouch(ev);
- if (ev.type === 'mousedown') {
- if (this.isIgnoringMouse) {
- return;
- }
- else if (!isPrimaryMouseButton(ev)) {
- return;
- }
- else {
- ev.preventDefault();
- }
- }
- if (!this.isInteracting) {
-
- extraOptions = extraOptions || {};
- this.delay = firstDefined(extraOptions.delay, this.options.delay, 0);
- this.minDistance = firstDefined(extraOptions.distance, this.options.distance, 0);
- this.subjectEl = this.options.subjectEl;
- this.isInteracting = true;
- this.isTouch = isTouch;
- this.isDelayEnded = false;
- this.isDistanceSurpassed = false;
- this.originX = getEvX(ev);
- this.originY = getEvY(ev);
- this.scrollEl = getScrollParent($(ev.target));
- this.bindHandlers();
- this.initAutoScroll();
- this.handleInteractionStart(ev);
- this.startDelay(ev);
- if (!this.minDistance) {
- this.handleDistanceSurpassed(ev);
- }
- }
- },
- handleInteractionStart: function(ev) {
- this.trigger('interactionStart', ev);
- },
- endInteraction: function(ev, isCancelled) {
- if (this.isInteracting) {
- this.endDrag(ev);
- if (this.delayTimeoutId) {
- clearTimeout(this.delayTimeoutId);
- this.delayTimeoutId = null;
- }
- this.destroyAutoScroll();
- this.unbindHandlers();
- this.isInteracting = false;
- this.handleInteractionEnd(ev, isCancelled);
-
-
-
- if (this.isTouch) {
- this.tempIgnoreMouse();
- }
- }
- },
- handleInteractionEnd: function(ev, isCancelled) {
- this.trigger('interactionEnd', ev, isCancelled || false);
- },
-
-
- bindHandlers: function() {
- var _this = this;
- var touchStartIgnores = 1;
- if (this.isTouch) {
- this.listenTo($(document), {
- touchmove: this.handleTouchMove,
- touchend: this.endInteraction,
- touchcancel: this.endInteraction,
-
-
-
-
- touchstart: function(ev) {
- if (touchStartIgnores) {
- touchStartIgnores--;
- }
- else {
- _this.endInteraction(ev, true);
- }
- }
- });
-
- if (
- !bindAnyScroll(this.handleTouchScrollProxy) &&
- this.scrollEl
- ) {
- this.listenTo(this.scrollEl, 'scroll', this.handleTouchScroll);
- }
- }
- else {
- this.listenTo($(document), {
- mousemove: this.handleMouseMove,
- mouseup: this.endInteraction
- });
- }
- this.listenTo($(document), {
- selectstart: preventDefault,
- contextmenu: preventDefault
- });
- },
- unbindHandlers: function() {
- this.stopListeningTo($(document));
-
- unbindAnyScroll(this.handleTouchScrollProxy);
- if (this.scrollEl) {
- this.stopListeningTo(this.scrollEl, 'scroll');
- }
- },
-
-
-
- startDrag: function(ev, extraOptions) {
- this.startInteraction(ev, extraOptions);
- if (!this.isDragging) {
- this.isDragging = true;
- this.handleDragStart(ev);
- }
- },
- handleDragStart: function(ev) {
- this.trigger('dragStart', ev);
- },
- handleMove: function(ev) {
- var dx = getEvX(ev) - this.originX;
- var dy = getEvY(ev) - this.originY;
- var minDistance = this.minDistance;
- var distanceSq;
- if (!this.isDistanceSurpassed) {
- distanceSq = dx * dx + dy * dy;
- if (distanceSq >= minDistance * minDistance) {
- this.handleDistanceSurpassed(ev);
- }
- }
- if (this.isDragging) {
- this.handleDrag(dx, dy, ev);
- }
- },
-
- handleDrag: function(dx, dy, ev) {
- this.trigger('drag', dx, dy, ev);
- this.updateAutoScroll(ev);
- },
- endDrag: function(ev) {
- if (this.isDragging) {
- this.isDragging = false;
- this.handleDragEnd(ev);
- }
- },
- handleDragEnd: function(ev) {
- this.trigger('dragEnd', ev);
- },
-
-
- startDelay: function(initialEv) {
- var _this = this;
- if (this.delay) {
- this.delayTimeoutId = setTimeout(function() {
- _this.handleDelayEnd(initialEv);
- }, this.delay);
- }
- else {
- this.handleDelayEnd(initialEv);
- }
- },
- handleDelayEnd: function(initialEv) {
- this.isDelayEnded = true;
- if (this.isDistanceSurpassed) {
- this.startDrag(initialEv);
- }
- },
-
-
- handleDistanceSurpassed: function(ev) {
- this.isDistanceSurpassed = true;
- if (this.isDelayEnded) {
- this.startDrag(ev);
- }
- },
-
-
- handleTouchMove: function(ev) {
-
- if (this.isDragging) {
- ev.preventDefault();
- }
- this.handleMove(ev);
- },
- handleMouseMove: function(ev) {
- this.handleMove(ev);
- },
-
-
- handleTouchScroll: function(ev) {
-
-
- if (!this.isDragging) {
- this.endInteraction(ev, true);
- }
- },
-
-
-
-
- trigger: function(name) {
- if (this.options[name]) {
- this.options[name].apply(this, Array.prototype.slice.call(arguments, 1));
- }
-
- if (this['_' + name]) {
- this['_' + name].apply(this, Array.prototype.slice.call(arguments, 1));
- }
- }
- });
- ;;
- DragListener.mixin({
- isAutoScroll: false,
- scrollBounds: null,
- scrollTopVel: null,
- scrollLeftVel: null,
- scrollIntervalId: null,
-
- scrollSensitivity: 30,
- scrollSpeed: 200,
- scrollIntervalMs: 50,
- initAutoScroll: function() {
- var scrollEl = this.scrollEl;
- this.isAutoScroll =
- this.options.scroll &&
- scrollEl &&
- !scrollEl.is(window) &&
- !scrollEl.is(document);
- if (this.isAutoScroll) {
-
- this.listenTo(scrollEl, 'scroll', debounce(this.handleDebouncedScroll, 100));
- }
- },
- destroyAutoScroll: function() {
- this.endAutoScroll();
-
- if (this.isAutoScroll) {
- this.stopListeningTo(this.scrollEl, 'scroll');
- }
- },
-
- computeScrollBounds: function() {
- if (this.isAutoScroll) {
- this.scrollBounds = getOuterRect(this.scrollEl);
-
- }
- },
-
- updateAutoScroll: function(ev) {
- var sensitivity = this.scrollSensitivity;
- var bounds = this.scrollBounds;
- var topCloseness, bottomCloseness;
- var leftCloseness, rightCloseness;
- var topVel = 0;
- var leftVel = 0;
- if (bounds) {
-
- topCloseness = (sensitivity - (getEvY(ev) - bounds.top)) / sensitivity;
- bottomCloseness = (sensitivity - (bounds.bottom - getEvY(ev))) / sensitivity;
- leftCloseness = (sensitivity - (getEvX(ev) - bounds.left)) / sensitivity;
- rightCloseness = (sensitivity - (bounds.right - getEvX(ev))) / sensitivity;
-
-
- if (topCloseness >= 0 && topCloseness <= 1) {
- topVel = topCloseness * this.scrollSpeed * -1;
- }
- else if (bottomCloseness >= 0 && bottomCloseness <= 1) {
- topVel = bottomCloseness * this.scrollSpeed;
- }
-
- if (leftCloseness >= 0 && leftCloseness <= 1) {
- leftVel = leftCloseness * this.scrollSpeed * -1;
- }
- else if (rightCloseness >= 0 && rightCloseness <= 1) {
- leftVel = rightCloseness * this.scrollSpeed;
- }
- }
- this.setScrollVel(topVel, leftVel);
- },
-
- setScrollVel: function(topVel, leftVel) {
- this.scrollTopVel = topVel;
- this.scrollLeftVel = leftVel;
- this.constrainScrollVel();
-
- if ((this.scrollTopVel || this.scrollLeftVel) && !this.scrollIntervalId) {
- this.scrollIntervalId = setInterval(
- proxy(this, 'scrollIntervalFunc'),
- this.scrollIntervalMs
- );
- }
- },
-
- constrainScrollVel: function() {
- var el = this.scrollEl;
- if (this.scrollTopVel < 0) {
- if (el.scrollTop() <= 0) {
- this.scrollTopVel = 0;
- }
- }
- else if (this.scrollTopVel > 0) {
- if (el.scrollTop() + el[0].clientHeight >= el[0].scrollHeight) {
- this.scrollTopVel = 0;
- }
- }
- if (this.scrollLeftVel < 0) {
- if (el.scrollLeft() <= 0) {
- this.scrollLeftVel = 0;
- }
- }
- else if (this.scrollLeftVel > 0) {
- if (el.scrollLeft() + el[0].clientWidth >= el[0].scrollWidth) {
- this.scrollLeftVel = 0;
- }
- }
- },
-
- scrollIntervalFunc: function() {
- var el = this.scrollEl;
- var frac = this.scrollIntervalMs / 1000;
-
- if (this.scrollTopVel) {
- el.scrollTop(el.scrollTop() + this.scrollTopVel * frac);
- }
- if (this.scrollLeftVel) {
- el.scrollLeft(el.scrollLeft() + this.scrollLeftVel * frac);
- }
- this.constrainScrollVel();
-
- if (!this.scrollTopVel && !this.scrollLeftVel) {
- this.endAutoScroll();
- }
- },
-
- endAutoScroll: function() {
- if (this.scrollIntervalId) {
- clearInterval(this.scrollIntervalId);
- this.scrollIntervalId = null;
- this.handleScrollEnd();
- }
- },
-
- handleDebouncedScroll: function() {
-
- if (!this.scrollIntervalId) {
- this.handleScrollEnd();
- }
- },
-
- handleScrollEnd: function() {
- }
- });
- ;;
- var HitDragListener = DragListener.extend({
- component: null,
-
- origHit: null,
- hit: null,
- coordAdjust: null,
- constructor: function(component, options) {
- DragListener.call(this, options);
- this.component = component;
- },
-
-
- handleInteractionStart: function(ev) {
- var subjectEl = this.subjectEl;
- var subjectRect;
- var origPoint;
- var point;
- this.computeCoords();
- if (ev) {
- origPoint = { left: getEvX(ev), top: getEvY(ev) };
- point = origPoint;
-
- if (subjectEl) {
- subjectRect = getOuterRect(subjectEl);
- point = constrainPoint(point, subjectRect);
- }
- this.origHit = this.queryHit(point.left, point.top);
-
- if (subjectEl && this.options.subjectCenter) {
-
-
- if (this.origHit) {
- subjectRect = intersectRects(this.origHit, subjectRect) ||
- subjectRect;
- }
- point = getRectCenter(subjectRect);
- }
- this.coordAdjust = diffPoints(point, origPoint);
- }
- else {
- this.origHit = null;
- this.coordAdjust = null;
- }
-
- DragListener.prototype.handleInteractionStart.apply(this, arguments);
- },
-
- computeCoords: function() {
- this.component.prepareHits();
- this.computeScrollBounds();
- },
-
- handleDragStart: function(ev) {
- var hit;
- DragListener.prototype.handleDragStart.apply(this, arguments);
-
- hit = this.queryHit(getEvX(ev), getEvY(ev));
-
-
- if (hit) {
- this.handleHitOver(hit);
- }
- },
-
- handleDrag: function(dx, dy, ev) {
- var hit;
- DragListener.prototype.handleDrag.apply(this, arguments);
- hit = this.queryHit(getEvX(ev), getEvY(ev));
- if (!isHitsEqual(hit, this.hit)) {
- if (this.hit) {
- this.handleHitOut();
- }
- if (hit) {
- this.handleHitOver(hit);
- }
- }
- },
-
- handleDragEnd: function() {
- this.handleHitDone();
- DragListener.prototype.handleDragEnd.apply(this, arguments);
- },
-
- handleHitOver: function(hit) {
- var isOrig = isHitsEqual(hit, this.origHit);
- this.hit = hit;
- this.trigger('hitOver', this.hit, isOrig, this.origHit);
- },
-
- handleHitOut: function() {
- if (this.hit) {
- this.trigger('hitOut', this.hit);
- this.handleHitDone();
- this.hit = null;
- }
- },
-
- handleHitDone: function() {
- if (this.hit) {
- this.trigger('hitDone', this.hit);
- }
- },
-
- handleInteractionEnd: function() {
- DragListener.prototype.handleInteractionEnd.apply(this, arguments);
- this.origHit = null;
- this.hit = null;
- this.component.releaseHits();
- },
-
- handleScrollEnd: function() {
- DragListener.prototype.handleScrollEnd.apply(this, arguments);
- this.computeCoords();
- },
-
- queryHit: function(left, top) {
- if (this.coordAdjust) {
- left += this.coordAdjust.left;
- top += this.coordAdjust.top;
- }
- return this.component.queryHit(left, top);
- }
- });
- function isHitsEqual(hit0, hit1) {
- if (!hit0 && !hit1) {
- return true;
- }
- if (hit0 && hit1) {
- return hit0.component === hit1.component &&
- isHitPropsWithin(hit0, hit1) &&
- isHitPropsWithin(hit1, hit0);
- }
- return false;
- }
- function isHitPropsWithin(subHit, superHit) {
- for (var propName in subHit) {
- if (!/^(component|left|right|top|bottom)$/.test(propName)) {
- if (subHit[propName] !== superHit[propName]) {
- return false;
- }
- }
- }
- return true;
- }
- ;;
- var MouseFollower = Class.extend(ListenerMixin, {
- options: null,
- sourceEl: null,
- el: null,
- parentEl: null,
-
- top0: null,
- left0: null,
-
- y0: null,
- x0: null,
-
- topDelta: null,
- leftDelta: null,
- isFollowing: false,
- isHidden: false,
- isAnimating: false,
- constructor: function(sourceEl, options) {
- this.options = options = options || {};
- this.sourceEl = sourceEl;
- this.parentEl = options.parentEl ? $(options.parentEl) : sourceEl.parent();
- },
-
- start: function(ev) {
- if (!this.isFollowing) {
- this.isFollowing = true;
- this.y0 = getEvY(ev);
- this.x0 = getEvX(ev);
- this.topDelta = 0;
- this.leftDelta = 0;
- if (!this.isHidden) {
- this.updatePosition();
- }
- if (getEvIsTouch(ev)) {
- this.listenTo($(document), 'touchmove', this.handleMove);
- }
- else {
- this.listenTo($(document), 'mousemove', this.handleMove);
- }
- }
- },
-
-
- stop: function(shouldRevert, callback) {
- var _this = this;
- var revertDuration = this.options.revertDuration;
- function complete() {
- _this.isAnimating = false;
- _this.removeElement();
- _this.top0 = _this.left0 = null;
- if (callback) {
- callback();
- }
- }
- if (this.isFollowing && !this.isAnimating) {
- this.isFollowing = false;
- this.stopListeningTo($(document));
- if (shouldRevert && revertDuration && !this.isHidden) {
- this.isAnimating = true;
- this.el.animate({
- top: this.top0,
- left: this.left0
- }, {
- duration: revertDuration,
- complete: complete
- });
- }
- else {
- complete();
- }
- }
- },
-
- getEl: function() {
- var el = this.el;
- if (!el) {
- el = this.el = this.sourceEl.clone()
- .addClass(this.options.additionalClass || '')
- .css({
- position: 'absolute',
- visibility: '',
- display: this.isHidden ? 'none' : '',
- margin: 0,
- right: 'auto',
- bottom: 'auto',
- width: this.sourceEl.width(),
- height: this.sourceEl.height(),
- opacity: this.options.opacity || '',
- zIndex: this.options.zIndex
- });
-
-
- el.addClass('fc-unselectable');
- el.appendTo(this.parentEl);
- }
- return el;
- },
-
- removeElement: function() {
- if (this.el) {
- this.el.remove();
- this.el = null;
- }
- },
-
- updatePosition: function() {
- var sourceOffset;
- var origin;
- this.getEl();
-
- if (this.top0 === null) {
- sourceOffset = this.sourceEl.offset();
- origin = this.el.offsetParent().offset();
- this.top0 = sourceOffset.top - origin.top;
- this.left0 = sourceOffset.left - origin.left;
- }
- this.el.css({
- top: this.top0 + this.topDelta,
- left: this.left0 + this.leftDelta
- });
- },
-
- handleMove: function(ev) {
- this.topDelta = getEvY(ev) - this.y0;
- this.leftDelta = getEvX(ev) - this.x0;
- if (!this.isHidden) {
- this.updatePosition();
- }
- },
-
- hide: function() {
- if (!this.isHidden) {
- this.isHidden = true;
- if (this.el) {
- this.el.hide();
- }
- }
- },
-
- show: function() {
- if (this.isHidden) {
- this.isHidden = false;
- this.updatePosition();
- this.getEl().show();
- }
- }
- });
- ;;
- var Grid = FC.Grid = Class.extend(ListenerMixin, MouseIgnorerMixin, {
-
- hasDayInteractions: true,
- view: null,
- isRTL: null,
- start: null,
- end: null,
- el: null,
- elsByFill: null,
-
- eventTimeFormat: null,
- displayEventTime: null,
- displayEventEnd: null,
- minResizeDuration: null,
-
-
-
- largeUnit: null,
- dayDragListener: null,
- segDragListener: null,
- segResizeListener: null,
- externalDragListener: null,
- constructor: function(view) {
- this.view = view;
- this.isRTL = view.opt('isRTL');
- this.elsByFill = {};
- this.dayDragListener = this.buildDayDragListener();
- this.initMouseIgnoring();
- },
-
-
- computeEventTimeFormat: function() {
- return this.view.opt('smallTimeFormat');
- },
-
-
- computeDisplayEventTime: function() {
- return true;
- },
-
- computeDisplayEventEnd: function() {
- return true;
- },
-
-
-
- setRange: function(range) {
- this.start = range.start.clone();
- this.end = range.end.clone();
- this.rangeUpdated();
- this.processRangeOptions();
- },
-
- rangeUpdated: function() {
- },
-
- processRangeOptions: function() {
- var view = this.view;
- var displayEventTime;
- var displayEventEnd;
- this.eventTimeFormat =
- view.opt('eventTimeFormat') ||
- view.opt('timeFormat') ||
- this.computeEventTimeFormat();
- displayEventTime = view.opt('displayEventTime');
- if (displayEventTime == null) {
- displayEventTime = this.computeDisplayEventTime();
- }
- displayEventEnd = view.opt('displayEventEnd');
- if (displayEventEnd == null) {
- displayEventEnd = this.computeDisplayEventEnd();
- }
- this.displayEventTime = displayEventTime;
- this.displayEventEnd = displayEventEnd;
- },
-
-
- spanToSegs: function(span) {
-
- },
-
-
- diffDates: function(a, b) {
- if (this.largeUnit) {
- return diffByUnit(a, b, this.largeUnit);
- }
- else {
- return diffDayTime(a, b);
- }
- },
-
-
- prepareHits: function() {
- },
-
- releaseHits: function() {
- },
-
-
-
-
- queryHit: function(leftOffset, topOffset) {
- },
-
-
- getHitSpan: function(hit) {
- },
-
-
- getHitEl: function(hit) {
- },
-
-
-
- setElement: function(el) {
- this.el = el;
- if (this.hasDayInteractions) {
- preventSelection(el);
- this.bindDayHandler('touchstart', this.dayTouchStart);
- this.bindDayHandler('mousedown', this.dayMousedown);
- }
-
-
- this.bindSegHandlers();
- this.bindGlobalHandlers();
- },
- bindDayHandler: function(name, handler) {
- var _this = this;
-
-
- this.el.on(name, function(ev) {
- if (
- !$(ev.target).is(
- _this.segSelector + ',' +
- _this.segSelector + ' *,' +
- '.fc-more,' +
- 'a[data-goto]'
- )
- ) {
- return handler.call(_this, ev);
- }
- });
- },
-
-
- removeElement: function() {
- this.unbindGlobalHandlers();
- this.clearDragListeners();
- this.el.remove();
-
- },
-
- renderSkeleton: function() {
-
- },
-
-
- renderDates: function() {
-
- },
-
- unrenderDates: function() {
-
- },
-
-
- bindGlobalHandlers: function() {
- this.listenTo($(document), {
- dragstart: this.externalDragStart,
- sortstart: this.externalDragStart
- });
- },
-
- unbindGlobalHandlers: function() {
- this.stopListeningTo($(document));
- },
-
- dayMousedown: function(ev) {
- if (!this.isIgnoringMouse) {
- this.dayDragListener.startInteraction(ev, {
-
- });
- }
- },
- dayTouchStart: function(ev) {
- var view = this.view;
- var selectLongPressDelay = view.opt('selectLongPressDelay');
-
-
- if (view.isSelected || view.selectedEvent) {
- this.tempIgnoreMouse();
- }
- if (selectLongPressDelay == null) {
- selectLongPressDelay = view.opt('longPressDelay');
- }
- this.dayDragListener.startInteraction(ev, {
- delay: selectLongPressDelay
- });
- },
-
-
- buildDayDragListener: function() {
- var _this = this;
- var view = this.view;
- var isSelectable = view.opt('selectable');
- var dayClickHit;
- var selectionSpan;
-
-
-
- var dragListener = new HitDragListener(this, {
- scroll: view.opt('dragScroll'),
- interactionStart: function() {
- dayClickHit = dragListener.origHit;
- selectionSpan = null;
- },
- dragStart: function() {
- view.unselect();
- },
- hitOver: function(hit, isOrig, origHit) {
- if (origHit) {
-
- if (!isOrig) {
- dayClickHit = null;
- }
- if (isSelectable) {
- selectionSpan = _this.computeSelection(
- _this.getHitSpan(origHit),
- _this.getHitSpan(hit)
- );
- if (selectionSpan) {
- _this.renderSelection(selectionSpan);
- }
- else if (selectionSpan === false) {
- disableCursor();
- }
- }
- }
- },
- hitOut: function() {
- dayClickHit = null;
- selectionSpan = null;
- _this.unrenderSelection();
- },
- hitDone: function() {
- enableCursor();
- },
- interactionEnd: function(ev, isCancelled) {
- if (!isCancelled) {
- if (
- dayClickHit &&
- !_this.isIgnoringMouse
- ) {
- view.triggerDayClick(
- _this.getHitSpan(dayClickHit),
- _this.getHitEl(dayClickHit),
- ev
- );
- }
- if (selectionSpan) {
-
- view.reportSelection(selectionSpan, ev);
- }
- }
- }
- });
- return dragListener;
- },
-
-
-
- clearDragListeners: function() {
- this.dayDragListener.endInteraction();
- if (this.segDragListener) {
- this.segDragListener.endInteraction();
- }
- if (this.segResizeListener) {
- this.segResizeListener.endInteraction();
- }
- if (this.externalDragListener) {
- this.externalDragListener.endInteraction();
- }
- },
-
-
-
-
- renderEventLocationHelper: function(eventLocation, sourceSeg) {
- var fakeEvent = this.fabricateHelperEvent(eventLocation, sourceSeg);
- return this.renderHelper(fakeEvent, sourceSeg);
- },
-
-
-
- fabricateHelperEvent: function(eventLocation, sourceSeg) {
- var fakeEvent = sourceSeg ? createObject(sourceSeg.event) : {};
- fakeEvent.start = eventLocation.start.clone();
- fakeEvent.end = eventLocation.end ? eventLocation.end.clone() : null;
- fakeEvent.allDay = null;
- this.view.calendar.normalizeEventDates(fakeEvent);
-
- fakeEvent.className = (fakeEvent.className || []).concat('fc-helper');
-
- if (!sourceSeg) {
- fakeEvent.editable = false;
- }
- return fakeEvent;
- },
-
-
- renderHelper: function(eventLocation, sourceSeg) {
-
- },
-
- unrenderHelper: function() {
-
- },
-
-
-
- renderSelection: function(span) {
- this.renderHighlight(span);
- },
-
- unrenderSelection: function() {
- this.unrenderHighlight();
- },
-
-
-
-
- computeSelection: function(span0, span1) {
- var span = this.computeSelectionSpan(span0, span1);
- if (span && !this.view.calendar.isSelectionSpanAllowed(span)) {
- return false;
- }
- return span;
- },
-
-
- computeSelectionSpan: function(span0, span1) {
- var dates = [ span0.start, span0.end, span1.start, span1.end ];
- dates.sort(compareNumbers);
- return { start: dates[0].clone(), end: dates[3].clone() };
- },
-
-
- renderHighlight: function(span) {
- this.renderFill('highlight', this.spanToSegs(span));
- },
-
- unrenderHighlight: function() {
- this.unrenderFill('highlight');
- },
-
- highlightSegClasses: function() {
- return [ 'fc-highlight' ];
- },
-
- renderBusinessHours: function() {
- },
- unrenderBusinessHours: function() {
- },
-
- getNowIndicatorUnit: function() {
- },
- renderNowIndicator: function(date) {
- },
- unrenderNowIndicator: function() {
- },
-
-
-
-
- renderFill: function(type, segs) {
-
- },
-
- unrenderFill: function(type) {
- var el = this.elsByFill[type];
- if (el) {
- el.remove();
- delete this.elsByFill[type];
- }
- },
-
-
-
-
- renderFillSegEls: function(type, segs) {
- var _this = this;
- var segElMethod = this[type + 'SegEl'];
- var html = '';
- var renderedSegs = [];
- var i;
- if (segs.length) {
-
- for (i = 0; i < segs.length; i++) {
- html += this.fillSegHtml(type, segs[i]);
- }
-
-
- $(html).each(function(i, node) {
- var seg = segs[i];
- var el = $(node);
-
- if (segElMethod) {
- el = segElMethod.call(_this, seg, el);
- }
- if (el) {
- el = $(el);
-
- if (el.is(_this.fillSegTag)) {
- seg.el = el;
- renderedSegs.push(seg);
- }
- }
- });
- }
- return renderedSegs;
- },
- fillSegTag: 'div',
-
- fillSegHtml: function(type, seg) {
-
- var classesMethod = this[type + 'SegClasses'];
- var cssMethod = this[type + 'SegCss'];
- var classes = classesMethod ? classesMethod.call(this, seg) : [];
- var css = cssToStr(cssMethod ? cssMethod.call(this, seg) : {});
- return '<' + this.fillSegTag +
- (classes.length ? ' class="' + classes.join(' ') + '"' : '') +
- (css ? ' style="' + css + '"' : '') +
- ' />';
- },
-
-
- getDayClasses: function(date, noThemeHighlight) {
- var view = this.view;
- var today = view.calendar.getNow();
- var classes = [ 'fc-' + dayIDs[date.day()] ];
- if (
- view.intervalDuration.as('months') == 1 &&
- date.month() != view.intervalStart.month()
- ) {
- classes.push('fc-other-month');
- }
- if (date.isSame(today, 'day')) {
- classes.push('fc-today');
- if (noThemeHighlight !== true) {
- classes.push(view.highlightStateClass);
- }
- }
- else if (date < today) {
- classes.push('fc-past');
- }
- else {
- classes.push('fc-future');
- }
- return classes;
- }
- });
- ;;
- Grid.mixin({
-
- segSelector: '.fc-event-container > *',
- mousedOverSeg: null,
- isDraggingSeg: false,
- isResizingSeg: false,
- isDraggingExternal: false,
- segs: null,
-
- renderEvents: function(events) {
- var bgEvents = [];
- var fgEvents = [];
- var i;
- for (i = 0; i < events.length; i++) {
- (isBgEvent(events[i]) ? bgEvents : fgEvents).push(events[i]);
- }
- this.segs = [].concat(
- this.renderBgEvents(bgEvents),
- this.renderFgEvents(fgEvents)
- );
- },
- renderBgEvents: function(events) {
- var segs = this.eventsToSegs(events);
-
- return this.renderBgSegs(segs) || segs;
- },
- renderFgEvents: function(events) {
- var segs = this.eventsToSegs(events);
-
- return this.renderFgSegs(segs) || segs;
- },
-
- unrenderEvents: function() {
- this.handleSegMouseout();
- this.clearDragListeners();
- this.unrenderFgSegs();
- this.unrenderBgSegs();
- this.segs = null;
- },
-
- getEventSegs: function() {
- return this.segs || [];
- },
-
-
- renderFgSegs: function(segs) {
-
- },
-
- unrenderFgSegs: function() {
-
- },
-
-
-
- renderFgSegEls: function(segs, disableResizing) {
- var view = this.view;
- var html = '';
- var renderedSegs = [];
- var i;
- if (segs.length) {
-
- for (i = 0; i < segs.length; i++) {
- html += this.fgSegHtml(segs[i], disableResizing);
- }
-
-
- $(html).each(function(i, node) {
- var seg = segs[i];
- var el = view.resolveEventEl(seg.event, $(node));
- if (el) {
- el.data('fc-seg', seg);
- seg.el = el;
- renderedSegs.push(seg);
- }
- });
- }
- return renderedSegs;
- },
-
- fgSegHtml: function(seg, disableResizing) {
-
- },
-
-
-
- renderBgSegs: function(segs) {
- return this.renderFill('bgEvent', segs);
- },
-
- unrenderBgSegs: function() {
- this.unrenderFill('bgEvent');
- },
-
- bgEventSegEl: function(seg, el) {
- return this.view.resolveEventEl(seg.event, el);
- },
-
-
- bgEventSegClasses: function(seg) {
- var event = seg.event;
- var source = event.source || {};
- return [ 'fc-bgevent' ].concat(
- event.className,
- source.className || []
- );
- },
-
-
- bgEventSegCss: function(seg) {
- return {
- 'background-color': this.getSegSkinCss(seg)['background-color']
- };
- },
-
-
- businessHoursSegClasses: function(seg) {
- return [ 'fc-nonbusiness', 'fc-bgevent' ];
- },
-
-
-
-
- buildBusinessHourSegs: function(wholeDay, businessHours) {
- return this.eventsToSegs(
- this.buildBusinessHourEvents(wholeDay, businessHours)
- );
- },
-
-
-
- buildBusinessHourEvents: function(wholeDay, businessHours) {
- var calendar = this.view.calendar;
- var events;
- if (businessHours == null) {
-
-
- businessHours = calendar.options.businessHours;
- }
- events = calendar.computeBusinessHourEvents(wholeDay, businessHours);
-
-
-
- if (!events.length && businessHours) {
- events = [
- $.extend({}, BUSINESS_HOUR_EVENT_DEFAULTS, {
- start: this.view.end,
- end: this.view.end,
- dow: null
- })
- ];
- }
- return events;
- },
-
-
- bindSegHandlers: function() {
- this.bindSegHandlersToEl(this.el);
- },
-
- bindSegHandlersToEl: function(el) {
- this.bindSegHandlerToEl(el, 'touchstart', this.handleSegTouchStart);
- this.bindSegHandlerToEl(el, 'touchend', this.handleSegTouchEnd);
- this.bindSegHandlerToEl(el, 'mouseenter', this.handleSegMouseover);
- this.bindSegHandlerToEl(el, 'mouseleave', this.handleSegMouseout);
- this.bindSegHandlerToEl(el, 'mousedown', this.handleSegMousedown);
- this.bindSegHandlerToEl(el, 'click', this.handleSegClick);
- },
-
-
- bindSegHandlerToEl: function(el, name, handler) {
- var _this = this;
- el.on(name, this.segSelector, function(ev) {
- var seg = $(this).data('fc-seg');
-
- if (seg && !_this.isDraggingSeg && !_this.isResizingSeg) {
- return handler.call(_this, seg, ev);
- }
- });
- },
- handleSegClick: function(seg, ev) {
- var res = this.view.publiclyTrigger('eventClick', seg.el[0], seg.event, ev);
- if (res === false) {
- ev.preventDefault();
- }
- },
-
- handleSegMouseover: function(seg, ev) {
- if (
- !this.isIgnoringMouse &&
- !this.mousedOverSeg
- ) {
- this.mousedOverSeg = seg;
- if (this.view.isEventResizable(seg.event)) {
- seg.el.addClass('fc-allow-mouse-resize');
- }
- this.view.publiclyTrigger('eventMouseover', seg.el[0], seg.event, ev);
- }
- },
-
-
- handleSegMouseout: function(seg, ev) {
- ev = ev || {};
- if (this.mousedOverSeg) {
- seg = seg || this.mousedOverSeg;
- this.mousedOverSeg = null;
- if (this.view.isEventResizable(seg.event)) {
- seg.el.removeClass('fc-allow-mouse-resize');
- }
- this.view.publiclyTrigger('eventMouseout', seg.el[0], seg.event, ev);
- }
- },
- handleSegMousedown: function(seg, ev) {
- var isResizing = this.startSegResize(seg, ev, { distance: 5 });
- if (!isResizing && this.view.isEventDraggable(seg.event)) {
- this.buildSegDragListener(seg)
- .startInteraction(ev, {
- distance: 5
- });
- }
- },
- handleSegTouchStart: function(seg, ev) {
- var view = this.view;
- var event = seg.event;
- var isSelected = view.isEventSelected(event);
- var isDraggable = view.isEventDraggable(event);
- var isResizable = view.isEventResizable(event);
- var isResizing = false;
- var dragListener;
- var eventLongPressDelay;
- if (isSelected && isResizable) {
-
- isResizing = this.startSegResize(seg, ev);
- }
- if (!isResizing && (isDraggable || isResizable)) {
- eventLongPressDelay = view.opt('eventLongPressDelay');
- if (eventLongPressDelay == null) {
- eventLongPressDelay = view.opt('longPressDelay');
- }
- dragListener = isDraggable ?
- this.buildSegDragListener(seg) :
- this.buildSegSelectListener(seg);
- dragListener.startInteraction(ev, {
- delay: isSelected ? 0 : eventLongPressDelay
- });
- }
-
- this.tempIgnoreMouse();
- },
- handleSegTouchEnd: function(seg, ev) {
-
-
- this.tempIgnoreMouse();
- },
-
-
-
- startSegResize: function(seg, ev, dragOptions) {
- if ($(ev.target).is('.fc-resizer')) {
- this.buildSegResizeListener(seg, $(ev.target).is('.fc-start-resizer'))
- .startInteraction(ev, dragOptions);
- return true;
- }
- return false;
- },
-
-
-
-
- buildSegDragListener: function(seg) {
- var _this = this;
- var view = this.view;
- var calendar = view.calendar;
- var el = seg.el;
- var event = seg.event;
- var isDragging;
- var mouseFollower;
- var dropLocation;
- if (this.segDragListener) {
- return this.segDragListener;
- }
-
-
- var dragListener = this.segDragListener = new HitDragListener(view, {
- scroll: view.opt('dragScroll'),
- subjectEl: el,
- subjectCenter: true,
- interactionStart: function(ev) {
- seg.component = _this;
- isDragging = false;
- mouseFollower = new MouseFollower(seg.el, {
- additionalClass: 'fc-dragging',
- parentEl: view.el,
- opacity: dragListener.isTouch ? null : view.opt('dragOpacity'),
- revertDuration: view.opt('dragRevertDuration'),
- zIndex: 2
- });
- mouseFollower.hide();
- mouseFollower.start(ev);
- },
- dragStart: function(ev) {
- if (dragListener.isTouch && !view.isEventSelected(event)) {
-
- view.selectEvent(event);
- }
- isDragging = true;
- _this.handleSegMouseout(seg, ev);
- _this.segDragStart(seg, ev);
- view.hideEvent(event);
- },
- hitOver: function(hit, isOrig, origHit) {
- var dragHelperEls;
-
- if (seg.hit) {
- origHit = seg.hit;
- }
-
- dropLocation = _this.computeEventDrop(
- origHit.component.getHitSpan(origHit),
- hit.component.getHitSpan(hit),
- event
- );
- if (dropLocation && !calendar.isEventSpanAllowed(_this.eventToSpan(dropLocation), event)) {
- disableCursor();
- dropLocation = null;
- }
-
- if (dropLocation && (dragHelperEls = view.renderDrag(dropLocation, seg))) {
- dragHelperEls.addClass('fc-dragging');
- if (!dragListener.isTouch) {
- _this.applyDragOpacity(dragHelperEls);
- }
- mouseFollower.hide();
- }
- else {
- mouseFollower.show();
- }
- if (isOrig) {
- dropLocation = null;
- }
- },
- hitOut: function() {
- view.unrenderDrag();
- mouseFollower.show();
- dropLocation = null;
- },
- hitDone: function() {
- enableCursor();
- },
- interactionEnd: function(ev) {
- delete seg.component;
-
- mouseFollower.stop(!dropLocation, function() {
- if (isDragging) {
- view.unrenderDrag();
- _this.segDragStop(seg, ev);
- }
- if (dropLocation) {
-
- view.reportEventDrop(event, dropLocation, _this.largeUnit, el, ev);
- }
- else {
- view.showEvent(event);
- }
- });
- _this.segDragListener = null;
- }
- });
- return dragListener;
- },
-
-
-
- buildSegSelectListener: function(seg) {
- var _this = this;
- var view = this.view;
- var event = seg.event;
- if (this.segDragListener) {
- return this.segDragListener;
- }
- var dragListener = this.segDragListener = new DragListener({
- dragStart: function(ev) {
- if (dragListener.isTouch && !view.isEventSelected(event)) {
-
- view.selectEvent(event);
- }
- },
- interactionEnd: function(ev) {
- _this.segDragListener = null;
- }
- });
- return dragListener;
- },
-
- segDragStart: function(seg, ev) {
- this.isDraggingSeg = true;
- this.view.publiclyTrigger('eventDragStart', seg.el[0], seg.event, ev, {});
- },
-
- segDragStop: function(seg, ev) {
- this.isDraggingSeg = false;
- this.view.publiclyTrigger('eventDragStop', seg.el[0], seg.event, ev, {});
- },
-
-
-
-
- computeEventDrop: function(startSpan, endSpan, event) {
- var calendar = this.view.calendar;
- var dragStart = startSpan.start;
- var dragEnd = endSpan.start;
- var delta;
- var dropLocation;
- if (dragStart.hasTime() === dragEnd.hasTime()) {
- delta = this.diffDates(dragEnd, dragStart);
-
-
- if (event.allDay && durationHasTime(delta)) {
- dropLocation = {
- start: event.start.clone(),
- end: calendar.getEventEnd(event),
- allDay: false
- };
- calendar.normalizeEventTimes(dropLocation);
- }
-
- else {
- dropLocation = pluckEventDateProps(event);
- }
- dropLocation.start.add(delta);
- if (dropLocation.end) {
- dropLocation.end.add(delta);
- }
- }
- else {
-
- dropLocation = {
- start: dragEnd.clone(),
- end: null,
- allDay: !dragEnd.hasTime()
- };
- }
- return dropLocation;
- },
-
- applyDragOpacity: function(els) {
- var opacity = this.view.opt('dragOpacity');
- if (opacity != null) {
- els.css('opacity', opacity);
- }
- },
-
-
- externalDragStart: function(ev, ui) {
- var view = this.view;
- var el;
- var accept;
- if (view.opt('droppable')) {
- el = $((ui ? ui.item : null) || ev.target);
-
-
- accept = view.opt('dropAccept');
- if ($.isFunction(accept) ? accept.call(el[0], el) : el.is(accept)) {
- if (!this.isDraggingExternal) {
- this.listenToExternalDrag(el, ev, ui);
- }
- }
- }
- },
-
- listenToExternalDrag: function(el, ev, ui) {
- var _this = this;
- var calendar = this.view.calendar;
- var meta = getDraggedElMeta(el);
- var dropLocation;
-
- var dragListener = _this.externalDragListener = new HitDragListener(this, {
- interactionStart: function() {
- _this.isDraggingExternal = true;
- },
- hitOver: function(hit) {
- dropLocation = _this.computeExternalDrop(
- hit.component.getHitSpan(hit),
- meta
- );
- if (
- dropLocation &&
- !calendar.isExternalSpanAllowed(_this.eventToSpan(dropLocation), dropLocation, meta.eventProps)
- ) {
- disableCursor();
- dropLocation = null;
- }
- if (dropLocation) {
- _this.renderDrag(dropLocation);
- }
- },
- hitOut: function() {
- dropLocation = null;
- },
- hitDone: function() {
- enableCursor();
- _this.unrenderDrag();
- },
- interactionEnd: function(ev) {
- if (dropLocation) {
- _this.view.reportExternalDrop(meta, dropLocation, el, ev, ui);
- }
- _this.isDraggingExternal = false;
- _this.externalDragListener = null;
- }
- });
- dragListener.startDrag(ev);
- },
-
-
-
-
- computeExternalDrop: function(span, meta) {
- var calendar = this.view.calendar;
- var dropLocation = {
- start: calendar.applyTimezone(span.start),
- end: null
- };
-
- if (meta.startTime && !dropLocation.start.hasTime()) {
- dropLocation.start.time(meta.startTime);
- }
- if (meta.duration) {
- dropLocation.end = dropLocation.start.clone().add(meta.duration);
- }
- return dropLocation;
- },
-
-
-
-
-
-
- renderDrag: function(dropLocation, seg) {
-
- },
-
- unrenderDrag: function() {
-
- },
-
-
-
- buildSegResizeListener: function(seg, isStart) {
- var _this = this;
- var view = this.view;
- var calendar = view.calendar;
- var el = seg.el;
- var event = seg.event;
- var eventEnd = calendar.getEventEnd(event);
- var isDragging;
- var resizeLocation;
-
- var dragListener = this.segResizeListener = new HitDragListener(this, {
- scroll: view.opt('dragScroll'),
- subjectEl: el,
- interactionStart: function() {
- isDragging = false;
- },
- dragStart: function(ev) {
- isDragging = true;
- _this.handleSegMouseout(seg, ev);
- _this.segResizeStart(seg, ev);
- },
- hitOver: function(hit, isOrig, origHit) {
- var origHitSpan = _this.getHitSpan(origHit);
- var hitSpan = _this.getHitSpan(hit);
- resizeLocation = isStart ?
- _this.computeEventStartResize(origHitSpan, hitSpan, event) :
- _this.computeEventEndResize(origHitSpan, hitSpan, event);
- if (resizeLocation) {
- if (!calendar.isEventSpanAllowed(_this.eventToSpan(resizeLocation), event)) {
- disableCursor();
- resizeLocation = null;
- }
-
- else if (
- resizeLocation.start.isSame(event.start.clone().stripZone()) &&
- resizeLocation.end.isSame(eventEnd.clone().stripZone())
- ) {
- resizeLocation = null;
- }
- }
- if (resizeLocation) {
- view.hideEvent(event);
- _this.renderEventResize(resizeLocation, seg);
- }
- },
- hitOut: function() {
- resizeLocation = null;
- view.showEvent(event);
- },
- hitDone: function() {
- _this.unrenderEventResize();
- enableCursor();
- },
- interactionEnd: function(ev) {
- if (isDragging) {
- _this.segResizeStop(seg, ev);
- }
- if (resizeLocation) {
-
- view.reportEventResize(event, resizeLocation, _this.largeUnit, el, ev);
- }
- else {
- view.showEvent(event);
- }
- _this.segResizeListener = null;
- }
- });
- return dragListener;
- },
-
- segResizeStart: function(seg, ev) {
- this.isResizingSeg = true;
- this.view.publiclyTrigger('eventResizeStart', seg.el[0], seg.event, ev, {});
- },
-
- segResizeStop: function(seg, ev) {
- this.isResizingSeg = false;
- this.view.publiclyTrigger('eventResizeStop', seg.el[0], seg.event, ev, {});
- },
-
- computeEventStartResize: function(startSpan, endSpan, event) {
- return this.computeEventResize('start', startSpan, endSpan, event);
- },
-
- computeEventEndResize: function(startSpan, endSpan, event) {
- return this.computeEventResize('end', startSpan, endSpan, event);
- },
-
-
-
- computeEventResize: function(type, startSpan, endSpan, event) {
- var calendar = this.view.calendar;
- var delta = this.diffDates(endSpan[type], startSpan[type]);
- var resizeLocation;
- var defaultDuration;
-
- resizeLocation = {
- start: event.start.clone(),
- end: calendar.getEventEnd(event),
- allDay: event.allDay
- };
-
- if (resizeLocation.allDay && durationHasTime(delta)) {
- resizeLocation.allDay = false;
- calendar.normalizeEventTimes(resizeLocation);
- }
- resizeLocation[type].add(delta);
-
- if (!resizeLocation.start.isBefore(resizeLocation.end)) {
- defaultDuration =
- this.minResizeDuration ||
- (event.allDay ?
- calendar.defaultAllDayEventDuration :
- calendar.defaultTimedEventDuration);
- if (type == 'start') {
- resizeLocation.start = resizeLocation.end.clone().subtract(defaultDuration);
- }
- else {
- resizeLocation.end = resizeLocation.start.clone().add(defaultDuration);
- }
- }
- return resizeLocation;
- },
-
-
-
- renderEventResize: function(range, seg) {
-
- },
-
- unrenderEventResize: function() {
-
- },
-
-
-
-
-
-
- getEventTimeText: function(range, formatStr, displayEnd) {
- if (formatStr == null) {
- formatStr = this.eventTimeFormat;
- }
- if (displayEnd == null) {
- displayEnd = this.displayEventEnd;
- }
- if (this.displayEventTime && range.start.hasTime()) {
- if (displayEnd && range.end) {
- return this.view.formatRange(range, formatStr);
- }
- else {
- return range.start.format(formatStr);
- }
- }
- return '';
- },
-
- getSegClasses: function(seg, isDraggable, isResizable) {
- var view = this.view;
- var classes = [
- 'fc-event',
- seg.isStart ? 'fc-start' : 'fc-not-start',
- seg.isEnd ? 'fc-end' : 'fc-not-end'
- ].concat(this.getSegCustomClasses(seg));
- if (isDraggable) {
- classes.push('fc-draggable');
- }
- if (isResizable) {
- classes.push('fc-resizable');
- }
-
- if (view.isEventSelected(seg.event)) {
- classes.push('fc-selected');
- }
- return classes;
- },
-
- getSegCustomClasses: function(seg) {
- var event = seg.event;
- return [].concat(
- event.className,
- event.source ? event.source.className : []
- );
- },
-
- getSegSkinCss: function(seg) {
- return {
- 'background-color': this.getSegBackgroundColor(seg),
- 'border-color': this.getSegBorderColor(seg),
- color: this.getSegTextColor(seg)
- };
- },
-
- getSegBackgroundColor: function(seg) {
- return seg.event.backgroundColor ||
- seg.event.color ||
- this.getSegDefaultBackgroundColor(seg);
- },
- getSegDefaultBackgroundColor: function(seg) {
- var source = seg.event.source || {};
- return source.backgroundColor ||
- source.color ||
- this.view.opt('eventBackgroundColor') ||
- this.view.opt('eventColor');
- },
-
- getSegBorderColor: function(seg) {
- return seg.event.borderColor ||
- seg.event.color ||
- this.getSegDefaultBorderColor(seg);
- },
- getSegDefaultBorderColor: function(seg) {
- var source = seg.event.source || {};
- return source.borderColor ||
- source.color ||
- this.view.opt('eventBorderColor') ||
- this.view.opt('eventColor');
- },
-
- getSegTextColor: function(seg) {
- return seg.event.textColor ||
- this.getSegDefaultTextColor(seg);
- },
- getSegDefaultTextColor: function(seg) {
- var source = seg.event.source || {};
- return source.textColor ||
- this.view.opt('eventTextColor');
- },
-
-
-
- eventToSegs: function(event) {
- return this.eventsToSegs([ event ]);
- },
- eventToSpan: function(event) {
- return this.eventToSpans(event)[0];
- },
-
-
-
- eventToSpans: function(event) {
- var range = this.eventToRange(event);
- return this.eventRangeToSpans(range, event);
- },
-
-
-
- eventsToSegs: function(allEvents, segSliceFunc) {
- var _this = this;
- var eventsById = groupEventsById(allEvents);
- var segs = [];
- $.each(eventsById, function(id, events) {
- var ranges = [];
- var i;
- for (i = 0; i < events.length; i++) {
- ranges.push(_this.eventToRange(events[i]));
- }
-
- if (isInverseBgEvent(events[0])) {
- ranges = _this.invertRanges(ranges);
- for (i = 0; i < ranges.length; i++) {
- segs.push.apply(segs,
- _this.eventRangeToSegs(ranges[i], events[0], segSliceFunc));
- }
- }
-
- else {
- for (i = 0; i < ranges.length; i++) {
- segs.push.apply(segs,
- _this.eventRangeToSegs(ranges[i], events[i], segSliceFunc));
- }
- }
- });
- return segs;
- },
-
-
- eventToRange: function(event) {
- var calendar = this.view.calendar;
- var start = event.start.clone().stripZone();
- var end = (
- event.end ?
- event.end.clone() :
-
- calendar.getDefaultEventEnd(
- event.allDay != null ?
- event.allDay :
- !event.start.hasTime(),
- event.start
- )
- ).stripZone();
-
- calendar.localizeMoment(start);
- calendar.localizeMoment(end);
- return { start: start, end: end };
- },
-
-
- eventRangeToSegs: function(range, event, segSliceFunc) {
- var spans = this.eventRangeToSpans(range, event);
- var segs = [];
- var i;
- for (i = 0; i < spans.length; i++) {
- segs.push.apply(segs,
- this.eventSpanToSegs(spans[i], event, segSliceFunc));
- }
- return segs;
- },
-
-
- eventRangeToSpans: function(range, event) {
- return [ $.extend({}, range) ];
- },
-
-
- eventSpanToSegs: function(span, event, segSliceFunc) {
- var segs = segSliceFunc ? segSliceFunc(span) : this.spanToSegs(span);
- var i, seg;
- for (i = 0; i < segs.length; i++) {
- seg = segs[i];
- seg.event = event;
- seg.eventStartMS = +span.start;
- seg.eventDurationMS = span.end - span.start;
- }
- return segs;
- },
-
-
- invertRanges: function(ranges) {
- var view = this.view;
- var viewStart = view.start.clone();
- var viewEnd = view.end.clone();
- var inverseRanges = [];
- var start = viewStart;
- var i, range;
-
- ranges.sort(compareRanges);
- for (i = 0; i < ranges.length; i++) {
- range = ranges[i];
-
- if (range.start > start) {
- inverseRanges.push({
- start: start,
- end: range.start
- });
- }
- start = range.end;
- }
-
- if (start < viewEnd) {
- inverseRanges.push({
- start: start,
- end: viewEnd
- });
- }
- return inverseRanges;
- },
- sortEventSegs: function(segs) {
- segs.sort(proxy(this, 'compareEventSegs'));
- },
-
- compareEventSegs: function(seg1, seg2) {
- return seg1.eventStartMS - seg2.eventStartMS ||
- seg2.eventDurationMS - seg1.eventDurationMS ||
- seg2.event.allDay - seg1.event.allDay ||
- compareByFieldSpecs(seg1.event, seg2.event, this.view.eventOrderSpecs);
- }
- });
- function pluckEventDateProps(event) {
- return {
- start: event.start.clone(),
- end: event.end ? event.end.clone() : null,
- allDay: event.allDay
- };
- }
- FC.pluckEventDateProps = pluckEventDateProps;
- function isBgEvent(event) {
- var rendering = getEventRendering(event);
- return rendering === 'background' || rendering === 'inverse-background';
- }
- FC.isBgEvent = isBgEvent;
- function isInverseBgEvent(event) {
- return getEventRendering(event) === 'inverse-background';
- }
- function getEventRendering(event) {
- return firstDefined((event.source || {}).rendering, event.rendering);
- }
- function groupEventsById(events) {
- var eventsById = {};
- var i, event;
- for (i = 0; i < events.length; i++) {
- event = events[i];
- (eventsById[event._id] || (eventsById[event._id] = [])).push(event);
- }
- return eventsById;
- }
- function compareRanges(range1, range2) {
- return range1.start - range2.start;
- }
- FC.dataAttrPrefix = '';
- function getDraggedElMeta(el) {
- var prefix = FC.dataAttrPrefix;
- var eventProps;
- var startTime;
- var duration;
- var stick;
- if (prefix) { prefix += '-'; }
- eventProps = el.data(prefix + 'event') || null;
- if (eventProps) {
- if (typeof eventProps === 'object') {
- eventProps = $.extend({}, eventProps);
- }
- else {
- eventProps = {};
- }
-
- startTime = eventProps.start;
- if (startTime == null) { startTime = eventProps.time; }
- duration = eventProps.duration;
- stick = eventProps.stick;
- delete eventProps.start;
- delete eventProps.time;
- delete eventProps.duration;
- delete eventProps.stick;
- }
-
- if (startTime == null) { startTime = el.data(prefix + 'start'); }
- if (startTime == null) { startTime = el.data(prefix + 'time'); }
- if (duration == null) { duration = el.data(prefix + 'duration'); }
- if (stick == null) { stick = el.data(prefix + 'stick'); }
-
- startTime = startTime != null ? moment.duration(startTime) : null;
- duration = duration != null ? moment.duration(duration) : null;
- stick = Boolean(stick);
- return { eventProps: eventProps, startTime: startTime, duration: duration, stick: stick };
- }
- ;;
- var DayTableMixin = FC.DayTableMixin = {
- breakOnWeeks: false,
- dayDates: null,
- dayIndices: null,
- daysPerRow: null,
- rowCnt: null,
- colCnt: null,
- colHeadFormat: null,
-
- updateDayTable: function() {
- var view = this.view;
- var date = this.start.clone();
- var dayIndex = -1;
- var dayIndices = [];
- var dayDates = [];
- var daysPerRow;
- var firstDay;
- var rowCnt;
- while (date.isBefore(this.end)) {
- if (view.isHiddenDay(date)) {
- dayIndices.push(dayIndex + 0.5);
- }
- else {
- dayIndex++;
- dayIndices.push(dayIndex);
- dayDates.push(date.clone());
- }
- date.add(1, 'days');
- }
- if (this.breakOnWeeks) {
-
- firstDay = dayDates[0].day();
- for (daysPerRow = 1; daysPerRow < dayDates.length; daysPerRow++) {
- if (dayDates[daysPerRow].day() == firstDay) {
- break;
- }
- }
- rowCnt = Math.ceil(dayDates.length / daysPerRow);
- }
- else {
- rowCnt = 1;
- daysPerRow = dayDates.length;
- }
- this.dayDates = dayDates;
- this.dayIndices = dayIndices;
- this.daysPerRow = daysPerRow;
- this.rowCnt = rowCnt;
- this.updateDayTableCols();
- },
-
- updateDayTableCols: function() {
- this.colCnt = this.computeColCnt();
- this.colHeadFormat = this.view.opt('columnFormat') || this.computeColHeadFormat();
- },
-
- computeColCnt: function() {
- return this.daysPerRow;
- },
-
- getCellDate: function(row, col) {
- return this.dayDates[
- this.getCellDayIndex(row, col)
- ].clone();
- },
-
- getCellRange: function(row, col) {
- var start = this.getCellDate(row, col);
- var end = start.clone().add(1, 'days');
- return { start: start, end: end };
- },
-
- getCellDayIndex: function(row, col) {
- return row * this.daysPerRow + this.getColDayIndex(col);
- },
-
- getColDayIndex: function(col) {
- if (this.isRTL) {
- return this.colCnt - 1 - col;
- }
- else {
- return col;
- }
- },
-
-
-
-
-
- getDateDayIndex: function(date) {
- var dayIndices = this.dayIndices;
- var dayOffset = date.diff(this.start, 'days');
- if (dayOffset < 0) {
- return dayIndices[0] - 1;
- }
- else if (dayOffset >= dayIndices.length) {
- return dayIndices[dayIndices.length - 1] + 1;
- }
- else {
- return dayIndices[dayOffset];
- }
- },
-
-
- computeColHeadFormat: function() {
-
-
- if (this.rowCnt > 1 || this.colCnt > 10) {
- return 'ddd';
- }
-
- else if (this.colCnt > 1) {
- return this.view.opt('dayOfMonthFormat');
- }
-
- else {
- return 'dddd';
- }
- },
-
-
- sliceRangeByRow: function(range) {
- var daysPerRow = this.daysPerRow;
- var normalRange = this.view.computeDayRange(range);
- var rangeFirst = this.getDateDayIndex(normalRange.start);
- var rangeLast = this.getDateDayIndex(normalRange.end.clone().subtract(1, 'days'));
- var segs = [];
- var row;
- var rowFirst, rowLast;
- var segFirst, segLast;
- for (row = 0; row < this.rowCnt; row++) {
- rowFirst = row * daysPerRow;
- rowLast = rowFirst + daysPerRow - 1;
-
- segFirst = Math.max(rangeFirst, rowFirst);
- segLast = Math.min(rangeLast, rowLast);
-
- segFirst = Math.ceil(segFirst);
- segLast = Math.floor(segLast);
- if (segFirst <= segLast) {
- segs.push({
- row: row,
-
- firstRowDayIndex: segFirst - rowFirst,
- lastRowDayIndex: segLast - rowFirst,
-
- isStart: segFirst === rangeFirst,
- isEnd: segLast === rangeLast
- });
- }
- }
- return segs;
- },
-
-
- sliceRangeByDay: function(range) {
- var daysPerRow = this.daysPerRow;
- var normalRange = this.view.computeDayRange(range);
- var rangeFirst = this.getDateDayIndex(normalRange.start);
- var rangeLast = this.getDateDayIndex(normalRange.end.clone().subtract(1, 'days'));
- var segs = [];
- var row;
- var rowFirst, rowLast;
- var i;
- var segFirst, segLast;
- for (row = 0; row < this.rowCnt; row++) {
- rowFirst = row * daysPerRow;
- rowLast = rowFirst + daysPerRow - 1;
- for (i = rowFirst; i <= rowLast; i++) {
-
- segFirst = Math.max(rangeFirst, i);
- segLast = Math.min(rangeLast, i);
-
- segFirst = Math.ceil(segFirst);
- segLast = Math.floor(segLast);
- if (segFirst <= segLast) {
- segs.push({
- row: row,
-
- firstRowDayIndex: segFirst - rowFirst,
- lastRowDayIndex: segLast - rowFirst,
-
- isStart: segFirst === rangeFirst,
- isEnd: segLast === rangeLast
- });
- }
- }
- }
- return segs;
- },
-
- renderHeadHtml: function() {
- var view = this.view;
- return '' +
- '<div class="fc-row ' + view.widgetHeaderClass + '">' +
- '<table>' +
- '<thead>' +
- this.renderHeadTrHtml() +
- '</thead>' +
- '</table>' +
- '</div>';
- },
- renderHeadIntroHtml: function() {
- return this.renderIntroHtml();
- },
- renderHeadTrHtml: function() {
- return '' +
- '<tr>' +
- (this.isRTL ? '' : this.renderHeadIntroHtml()) +
- this.renderHeadDateCellsHtml() +
- (this.isRTL ? this.renderHeadIntroHtml() : '') +
- '</tr>';
- },
- renderHeadDateCellsHtml: function() {
- var htmls = [];
- var col, date;
- for (col = 0; col < this.colCnt; col++) {
- date = this.getCellDate(0, col);
- htmls.push(this.renderHeadDateCellHtml(date));
- }
- return htmls.join('');
- },
-
-
- renderHeadDateCellHtml: function(date, colspan, otherAttrs) {
- var view = this.view;
- var classNames = [
- 'fc-day-header',
- view.widgetHeaderClass
- ];
-
- if (this.rowCnt === 1) {
- classNames = classNames.concat(
-
-
- this.getDayClasses(date, true)
- );
- }
- else {
- classNames.push('fc-' + dayIDs[date.day()]);
- }
- return '' +
- '<th class="' + classNames.join(' ') + '"' +
- (this.rowCnt === 1 ?
- ' data-date="' + date.format('YYYY-MM-DD') + '"' :
- '') +
- (colspan > 1 ?
- ' colspan="' + colspan + '"' :
- '') +
- (otherAttrs ?
- ' ' + otherAttrs :
- '') +
- '>' +
-
- view.buildGotoAnchorHtml(
- { date: date, forceOff: this.rowCnt > 1 || this.colCnt === 1 },
- htmlEscape(date.format(this.colHeadFormat))
- ) +
- '</th>';
- },
-
- renderBgTrHtml: function(row) {
- return '' +
- '<tr>' +
- (this.isRTL ? '' : this.renderBgIntroHtml(row)) +
- this.renderBgCellsHtml(row) +
- (this.isRTL ? this.renderBgIntroHtml(row) : '') +
- '</tr>';
- },
- renderBgIntroHtml: function(row) {
- return this.renderIntroHtml();
- },
- renderBgCellsHtml: function(row) {
- var htmls = [];
- var col, date;
- for (col = 0; col < this.colCnt; col++) {
- date = this.getCellDate(row, col);
- htmls.push(this.renderBgCellHtml(date));
- }
- return htmls.join('');
- },
- renderBgCellHtml: function(date, otherAttrs) {
- var view = this.view;
- var classes = this.getDayClasses(date);
- classes.unshift('fc-day', view.widgetContentClass);
- return '<td class="' + classes.join(' ') + '"' +
- ' data-date="' + date.format('YYYY-MM-DD') + '"' +
- (otherAttrs ?
- ' ' + otherAttrs :
- '') +
- '></td>';
- },
-
-
- renderIntroHtml: function() {
- },
-
-
-
-
-
-
- bookendCells: function(trEl) {
- var introHtml = this.renderIntroHtml();
- if (introHtml) {
- if (this.isRTL) {
- trEl.append(introHtml);
- }
- else {
- trEl.prepend(introHtml);
- }
- }
- }
- };
- ;;
- var DayGrid = FC.DayGrid = Grid.extend(DayTableMixin, {
- numbersVisible: false,
- bottomCoordPadding: 0,
- rowEls: null,
- cellEls: null,
- helperEls: null,
- rowCoordCache: null,
- colCoordCache: null,
-
-
-
- renderDates: function(isRigid) {
- var view = this.view;
- var rowCnt = this.rowCnt;
- var colCnt = this.colCnt;
- var html = '';
- var row;
- var col;
- for (row = 0; row < rowCnt; row++) {
- html += this.renderDayRowHtml(row, isRigid);
- }
- this.el.html(html);
- this.rowEls = this.el.find('.fc-row');
- this.cellEls = this.el.find('.fc-day');
- this.rowCoordCache = new CoordCache({
- els: this.rowEls,
- isVertical: true
- });
- this.colCoordCache = new CoordCache({
- els: this.cellEls.slice(0, this.colCnt),
- isHorizontal: true
- });
-
- for (row = 0; row < rowCnt; row++) {
- for (col = 0; col < colCnt; col++) {
- view.publiclyTrigger(
- 'dayRender',
- null,
- this.getCellDate(row, col),
- this.getCellEl(row, col)
- );
- }
- }
- },
- unrenderDates: function() {
- this.removeSegPopover();
- },
- renderBusinessHours: function() {
- var segs = this.buildBusinessHourSegs(true);
- this.renderFill('businessHours', segs, 'bgevent');
- },
- unrenderBusinessHours: function() {
- this.unrenderFill('businessHours');
- },
-
-
- renderDayRowHtml: function(row, isRigid) {
- var view = this.view;
- var classes = [ 'fc-row', 'fc-week', view.widgetContentClass ];
- if (isRigid) {
- classes.push('fc-rigid');
- }
- return '' +
- '<div class="' + classes.join(' ') + '">' +
- '<div class="fc-bg">' +
- '<table>' +
- this.renderBgTrHtml(row) +
- '</table>' +
- '</div>' +
- '<div class="fc-content-skeleton">' +
- '<table>' +
- (this.numbersVisible ?
- '<thead>' +
- this.renderNumberTrHtml(row) +
- '</thead>' :
- ''
- ) +
- '</table>' +
- '</div>' +
- '</div>';
- },
-
- renderNumberTrHtml: function(row) {
- return '' +
- '<tr>' +
- (this.isRTL ? '' : this.renderNumberIntroHtml(row)) +
- this.renderNumberCellsHtml(row) +
- (this.isRTL ? this.renderNumberIntroHtml(row) : '') +
- '</tr>';
- },
- renderNumberIntroHtml: function(row) {
- return this.renderIntroHtml();
- },
- renderNumberCellsHtml: function(row) {
- var htmls = [];
- var col, date;
- for (col = 0; col < this.colCnt; col++) {
- date = this.getCellDate(row, col);
- htmls.push(this.renderNumberCellHtml(date));
- }
- return htmls.join('');
- },
-
-
- renderNumberCellHtml: function(date) {
- var html = '';
- var classes;
- var weekCalcFirstDoW;
- if (!this.view.dayNumbersVisible && !this.view.cellWeekNumbersVisible) {
-
- return '<td/>';
- }
- classes = this.getDayClasses(date);
- classes.unshift('fc-day-top');
- if (this.view.cellWeekNumbersVisible) {
-
-
-
-
-
- if (date._locale._fullCalendar_weekCalc === 'ISO') {
- weekCalcFirstDoW = 1;
- }
- else {
- weekCalcFirstDoW = date._locale.firstDayOfWeek();
- }
- }
- html += '<td class="' + classes.join(' ') + '" data-date="' + date.format() + '">';
- if (this.view.cellWeekNumbersVisible && (date.day() == weekCalcFirstDoW)) {
- html += this.view.buildGotoAnchorHtml(
- { date: date, type: 'week' },
- { 'class': 'fc-week-number' },
- date.format('w')
- );
- }
- if (this.view.dayNumbersVisible) {
- html += this.view.buildGotoAnchorHtml(
- date,
- { 'class': 'fc-day-number' },
- date.date()
- );
- }
- html += '</td>';
- return html;
- },
-
-
- computeEventTimeFormat: function() {
- return this.view.opt('extraSmallTimeFormat');
- },
-
- computeDisplayEventEnd: function() {
- return this.colCnt == 1;
- },
-
- rangeUpdated: function() {
- this.updateDayTable();
- },
-
- spanToSegs: function(span) {
- var segs = this.sliceRangeByRow(span);
- var i, seg;
- for (i = 0; i < segs.length; i++) {
- seg = segs[i];
- if (this.isRTL) {
- seg.leftCol = this.daysPerRow - 1 - seg.lastRowDayIndex;
- seg.rightCol = this.daysPerRow - 1 - seg.firstRowDayIndex;
- }
- else {
- seg.leftCol = seg.firstRowDayIndex;
- seg.rightCol = seg.lastRowDayIndex;
- }
- }
- return segs;
- },
-
- prepareHits: function() {
- this.colCoordCache.build();
- this.rowCoordCache.build();
- this.rowCoordCache.bottoms[this.rowCnt - 1] += this.bottomCoordPadding;
- },
- releaseHits: function() {
- this.colCoordCache.clear();
- this.rowCoordCache.clear();
- },
- queryHit: function(leftOffset, topOffset) {
- if (this.colCoordCache.isLeftInBounds(leftOffset) && this.rowCoordCache.isTopInBounds(topOffset)) {
- var col = this.colCoordCache.getHorizontalIndex(leftOffset);
- var row = this.rowCoordCache.getVerticalIndex(topOffset);
- if (row != null && col != null) {
- return this.getCellHit(row, col);
- }
- }
- },
- getHitSpan: function(hit) {
- return this.getCellRange(hit.row, hit.col);
- },
- getHitEl: function(hit) {
- return this.getCellEl(hit.row, hit.col);
- },
-
-
- getCellHit: function(row, col) {
- return {
- row: row,
- col: col,
- component: this,
- left: this.colCoordCache.getLeftOffset(col),
- right: this.colCoordCache.getRightOffset(col),
- top: this.rowCoordCache.getTopOffset(row),
- bottom: this.rowCoordCache.getBottomOffset(row)
- };
- },
- getCellEl: function(row, col) {
- return this.cellEls.eq(row * this.colCnt + col);
- },
-
-
-
-
- renderDrag: function(eventLocation, seg) {
-
- this.renderHighlight(this.eventToSpan(eventLocation));
-
- if (seg && seg.component !== this) {
- return this.renderEventLocationHelper(eventLocation, seg);
- }
- },
-
- unrenderDrag: function() {
- this.unrenderHighlight();
- this.unrenderHelper();
- },
-
-
- renderEventResize: function(eventLocation, seg) {
- this.renderHighlight(this.eventToSpan(eventLocation));
- return this.renderEventLocationHelper(eventLocation, seg);
- },
-
- unrenderEventResize: function() {
- this.unrenderHighlight();
- this.unrenderHelper();
- },
-
-
- renderHelper: function(event, sourceSeg) {
- var helperNodes = [];
- var segs = this.eventToSegs(event);
- var rowStructs;
- segs = this.renderFgSegEls(segs);
- rowStructs = this.renderSegRows(segs);
-
- this.rowEls.each(function(row, rowNode) {
- var rowEl = $(rowNode);
- var skeletonEl = $('<div class="fc-helper-skeleton"><table/></div>');
- var skeletonTop;
-
- if (sourceSeg && sourceSeg.row === row) {
- skeletonTop = sourceSeg.el.position().top;
- }
- else {
- skeletonTop = rowEl.find('.fc-content-skeleton tbody').position().top;
- }
- skeletonEl.css('top', skeletonTop)
- .find('table')
- .append(rowStructs[row].tbodyEl);
- rowEl.append(skeletonEl);
- helperNodes.push(skeletonEl[0]);
- });
- return (
- this.helperEls = $(helperNodes)
- );
- },
-
- unrenderHelper: function() {
- if (this.helperEls) {
- this.helperEls.remove();
- this.helperEls = null;
- }
- },
-
- fillSegTag: 'td',
-
-
- renderFill: function(type, segs, className) {
- var nodes = [];
- var i, seg;
- var skeletonEl;
- segs = this.renderFillSegEls(type, segs);
- for (i = 0; i < segs.length; i++) {
- seg = segs[i];
- skeletonEl = this.renderFillRow(type, seg, className);
- this.rowEls.eq(seg.row).append(skeletonEl);
- nodes.push(skeletonEl[0]);
- }
- this.elsByFill[type] = $(nodes);
- return segs;
- },
-
- renderFillRow: function(type, seg, className) {
- var colCnt = this.colCnt;
- var startCol = seg.leftCol;
- var endCol = seg.rightCol + 1;
- var skeletonEl;
- var trEl;
- className = className || type.toLowerCase();
- skeletonEl = $(
- '<div class="fc-' + className + '-skeleton">' +
- '<table><tr/></table>' +
- '</div>'
- );
- trEl = skeletonEl.find('tr');
- if (startCol > 0) {
- trEl.append('<td colspan="' + startCol + '"/>');
- }
- trEl.append(
- seg.el.attr('colspan', endCol - startCol)
- );
- if (endCol < colCnt) {
- trEl.append('<td colspan="' + (colCnt - endCol) + '"/>');
- }
- this.bookendCells(trEl);
- return skeletonEl;
- }
- });
- ;;
- DayGrid.mixin({
- rowStructs: null,
-
- unrenderEvents: function() {
- this.removeSegPopover();
- Grid.prototype.unrenderEvents.apply(this, arguments);
- },
-
- getEventSegs: function() {
- return Grid.prototype.getEventSegs.call(this)
- .concat(this.popoverSegs || []);
- },
-
- renderBgSegs: function(segs) {
-
- var allDaySegs = $.grep(segs, function(seg) {
- return seg.event.allDay;
- });
- return Grid.prototype.renderBgSegs.call(this, allDaySegs);
- },
-
- renderFgSegs: function(segs) {
- var rowStructs;
-
-
- segs = this.renderFgSegEls(segs);
- rowStructs = this.rowStructs = this.renderSegRows(segs);
-
- this.rowEls.each(function(i, rowNode) {
- $(rowNode).find('.fc-content-skeleton > table').append(
- rowStructs[i].tbodyEl
- );
- });
- return segs;
- },
-
- unrenderFgSegs: function() {
- var rowStructs = this.rowStructs || [];
- var rowStruct;
- while ((rowStruct = rowStructs.pop())) {
- rowStruct.tbodyEl.remove();
- }
- this.rowStructs = null;
- },
-
-
-
- renderSegRows: function(segs) {
- var rowStructs = [];
- var segRows;
- var row;
- segRows = this.groupSegRows(segs);
-
- for (row = 0; row < segRows.length; row++) {
- rowStructs.push(
- this.renderSegRow(row, segRows[row])
- );
- }
- return rowStructs;
- },
-
- fgSegHtml: function(seg, disableResizing) {
- var view = this.view;
- var event = seg.event;
- var isDraggable = view.isEventDraggable(event);
- var isResizableFromStart = !disableResizing && event.allDay &&
- seg.isStart && view.isEventResizableFromStart(event);
- var isResizableFromEnd = !disableResizing && event.allDay &&
- seg.isEnd && view.isEventResizableFromEnd(event);
- var classes = this.getSegClasses(seg, isDraggable, isResizableFromStart || isResizableFromEnd);
- var skinCss = cssToStr(this.getSegSkinCss(seg));
- var timeHtml = '';
- var timeText;
- var titleHtml;
- classes.unshift('fc-day-grid-event', 'fc-h-event');
-
- if (seg.isStart) {
- timeText = this.getEventTimeText(event);
- if (timeText) {
- timeHtml = '<span class="fc-time">' + htmlEscape(timeText) + '</span>';
- }
- }
- titleHtml =
- '<span class="fc-title">' +
- (htmlEscape(event.title || '') || ' ') +
- '</span>';
-
- return '<a class="' + classes.join(' ') + '"' +
- (event.url ?
- ' href="' + htmlEscape(event.url) + '"' :
- ''
- ) +
- (skinCss ?
- ' style="' + skinCss + '"' :
- ''
- ) +
- '>' +
- '<div class="fc-content">' +
- (this.isRTL ?
- titleHtml + ' ' + timeHtml :
- timeHtml + ' ' + titleHtml
- ) +
- '</div>' +
- (isResizableFromStart ?
- '<div class="fc-resizer fc-start-resizer" />' :
- ''
- ) +
- (isResizableFromEnd ?
- '<div class="fc-resizer fc-end-resizer" />' :
- ''
- ) +
- '</a>';
- },
-
-
-
- renderSegRow: function(row, rowSegs) {
- var colCnt = this.colCnt;
- var segLevels = this.buildSegLevels(rowSegs);
- var levelCnt = Math.max(1, segLevels.length);
- var tbody = $('<tbody/>');
- var segMatrix = [];
- var cellMatrix = [];
- var loneCellMatrix = [];
- var i, levelSegs;
- var col;
- var tr;
- var j, seg;
- var td;
-
- function emptyCellsUntil(endCol) {
- while (col < endCol) {
-
- td = (loneCellMatrix[i - 1] || [])[col];
- if (td) {
- td.attr(
- 'rowspan',
- parseInt(td.attr('rowspan') || 1, 10) + 1
- );
- }
- else {
- td = $('<td/>');
- tr.append(td);
- }
- cellMatrix[i][col] = td;
- loneCellMatrix[i][col] = td;
- col++;
- }
- }
- for (i = 0; i < levelCnt; i++) {
- levelSegs = segLevels[i];
- col = 0;
- tr = $('<tr/>');
- segMatrix.push([]);
- cellMatrix.push([]);
- loneCellMatrix.push([]);
-
-
- if (levelSegs) {
- for (j = 0; j < levelSegs.length; j++) {
- seg = levelSegs[j];
- emptyCellsUntil(seg.leftCol);
-
- td = $('<td class="fc-event-container"/>').append(seg.el);
- if (seg.leftCol != seg.rightCol) {
- td.attr('colspan', seg.rightCol - seg.leftCol + 1);
- }
- else {
- loneCellMatrix[i][col] = td;
- }
- while (col <= seg.rightCol) {
- cellMatrix[i][col] = td;
- segMatrix[i][col] = seg;
- col++;
- }
- tr.append(td);
- }
- }
- emptyCellsUntil(colCnt);
- this.bookendCells(tr);
- tbody.append(tr);
- }
- return {
- row: row,
- tbodyEl: tbody,
- cellMatrix: cellMatrix,
- segMatrix: segMatrix,
- segLevels: segLevels,
- segs: rowSegs
- };
- },
-
-
- buildSegLevels: function(segs) {
- var levels = [];
- var i, seg;
- var j;
-
-
- this.sortEventSegs(segs);
-
- for (i = 0; i < segs.length; i++) {
- seg = segs[i];
-
- for (j = 0; j < levels.length; j++) {
- if (!isDaySegCollision(seg, levels[j])) {
- break;
- }
- }
-
- seg.level = j;
-
- (levels[j] || (levels[j] = [])).push(seg);
- }
-
- for (j = 0; j < levels.length; j++) {
- levels[j].sort(compareDaySegCols);
- }
- return levels;
- },
-
- groupSegRows: function(segs) {
- var segRows = [];
- var i;
- for (i = 0; i < this.rowCnt; i++) {
- segRows.push([]);
- }
- for (i = 0; i < segs.length; i++) {
- segRows[segs[i].row].push(segs[i]);
- }
- return segRows;
- }
- });
- function isDaySegCollision(seg, otherSegs) {
- var i, otherSeg;
- for (i = 0; i < otherSegs.length; i++) {
- otherSeg = otherSegs[i];
- if (
- otherSeg.leftCol <= seg.rightCol &&
- otherSeg.rightCol >= seg.leftCol
- ) {
- return true;
- }
- }
- return false;
- }
- function compareDaySegCols(a, b) {
- return a.leftCol - b.leftCol;
- }
- ;;
- DayGrid.mixin({
- segPopover: null,
- popoverSegs: null,
- removeSegPopover: function() {
- if (this.segPopover) {
- this.segPopover.hide();
- }
- },
-
-
- limitRows: function(levelLimit) {
- var rowStructs = this.rowStructs || [];
- var row;
- var rowLevelLimit;
- for (row = 0; row < rowStructs.length; row++) {
- this.unlimitRow(row);
- if (!levelLimit) {
- rowLevelLimit = false;
- }
- else if (typeof levelLimit === 'number') {
- rowLevelLimit = levelLimit;
- }
- else {
- rowLevelLimit = this.computeRowLevelLimit(row);
- }
- if (rowLevelLimit !== false) {
- this.limitRow(row, rowLevelLimit);
- }
- }
- },
-
-
-
- computeRowLevelLimit: function(row) {
- var rowEl = this.rowEls.eq(row);
- var rowHeight = rowEl.height();
- var trEls = this.rowStructs[row].tbodyEl.children();
- var i, trEl;
- var trHeight;
- function iterInnerHeights(i, childNode) {
- trHeight = Math.max(trHeight, $(childNode).outerHeight());
- }
-
- for (i = 0; i < trEls.length; i++) {
- trEl = trEls.eq(i).removeClass('fc-limited');
-
-
- trHeight = 0;
- trEl.find('> td > :first-child').each(iterInnerHeights);
- if (trEl.position().top + trHeight > rowHeight) {
- return i;
- }
- }
- return false;
- },
-
-
-
- limitRow: function(row, levelLimit) {
- var _this = this;
- var rowStruct = this.rowStructs[row];
- var moreNodes = [];
- var col = 0;
- var levelSegs;
- var cellMatrix;
- var limitedNodes;
- var i, seg;
- var segsBelow;
- var totalSegsBelow;
- var colSegsBelow;
- var td, rowspan;
- var segMoreNodes;
- var j;
- var moreTd, moreWrap, moreLink;
-
- function emptyCellsUntil(endCol) {
- while (col < endCol) {
- segsBelow = _this.getCellSegs(row, col, levelLimit);
- if (segsBelow.length) {
- td = cellMatrix[levelLimit - 1][col];
- moreLink = _this.renderMoreLink(row, col, segsBelow);
- moreWrap = $('<div/>').append(moreLink);
- td.append(moreWrap);
- moreNodes.push(moreWrap[0]);
- }
- col++;
- }
- }
- if (levelLimit && levelLimit < rowStruct.segLevels.length) {
- levelSegs = rowStruct.segLevels[levelLimit - 1];
- cellMatrix = rowStruct.cellMatrix;
- limitedNodes = rowStruct.tbodyEl.children().slice(levelLimit)
- .addClass('fc-limited').get();
-
- for (i = 0; i < levelSegs.length; i++) {
- seg = levelSegs[i];
- emptyCellsUntil(seg.leftCol);
-
- colSegsBelow = [];
- totalSegsBelow = 0;
- while (col <= seg.rightCol) {
- segsBelow = this.getCellSegs(row, col, levelLimit);
- colSegsBelow.push(segsBelow);
- totalSegsBelow += segsBelow.length;
- col++;
- }
- if (totalSegsBelow) {
- td = cellMatrix[levelLimit - 1][seg.leftCol];
- rowspan = td.attr('rowspan') || 1;
- segMoreNodes = [];
-
- for (j = 0; j < colSegsBelow.length; j++) {
- moreTd = $('<td class="fc-more-cell"/>').attr('rowspan', rowspan);
- segsBelow = colSegsBelow[j];
- moreLink = this.renderMoreLink(
- row,
- seg.leftCol + j,
- [ seg ].concat(segsBelow)
- );
- moreWrap = $('<div/>').append(moreLink);
- moreTd.append(moreWrap);
- segMoreNodes.push(moreTd[0]);
- moreNodes.push(moreTd[0]);
- }
- td.addClass('fc-limited').after($(segMoreNodes));
- limitedNodes.push(td[0]);
- }
- }
- emptyCellsUntil(this.colCnt);
- rowStruct.moreEls = $(moreNodes);
- rowStruct.limitedEls = $(limitedNodes);
- }
- },
-
-
- unlimitRow: function(row) {
- var rowStruct = this.rowStructs[row];
- if (rowStruct.moreEls) {
- rowStruct.moreEls.remove();
- rowStruct.moreEls = null;
- }
- if (rowStruct.limitedEls) {
- rowStruct.limitedEls.removeClass('fc-limited');
- rowStruct.limitedEls = null;
- }
- },
-
-
- renderMoreLink: function(row, col, hiddenSegs) {
- var _this = this;
- var view = this.view;
- return $('<a class="fc-more"/>')
- .text(
- this.getMoreLinkText(hiddenSegs.length)
- )
- .on('click', function(ev) {
- var clickOption = view.opt('eventLimitClick');
- var date = _this.getCellDate(row, col);
- var moreEl = $(this);
- var dayEl = _this.getCellEl(row, col);
- var allSegs = _this.getCellSegs(row, col);
-
- var reslicedAllSegs = _this.resliceDaySegs(allSegs, date);
- var reslicedHiddenSegs = _this.resliceDaySegs(hiddenSegs, date);
- if (typeof clickOption === 'function') {
-
- clickOption = view.publiclyTrigger('eventLimitClick', null, {
- date: date,
- dayEl: dayEl,
- moreEl: moreEl,
- segs: reslicedAllSegs,
- hiddenSegs: reslicedHiddenSegs
- }, ev);
- }
- if (clickOption === 'popover') {
- _this.showSegPopover(row, col, moreEl, reslicedAllSegs);
- }
- else if (typeof clickOption === 'string') {
- view.calendar.zoomTo(date, clickOption);
- }
- });
- },
-
- showSegPopover: function(row, col, moreLink, segs) {
- var _this = this;
- var view = this.view;
- var moreWrap = moreLink.parent();
- var topEl;
- var options;
- if (this.rowCnt == 1) {
- topEl = view.el;
- }
- else {
- topEl = this.rowEls.eq(row);
- }
- options = {
- className: 'fc-more-popover',
- content: this.renderSegPopoverContent(row, col, segs),
- parentEl: this.view.el,
- top: topEl.offset().top,
- autoHide: true,
- viewportConstrain: view.opt('popoverViewportConstrain'),
- hide: function() {
-
-
- if (_this.popoverSegs) {
- var seg;
- for (var i = 0; i < _this.popoverSegs.length; ++i) {
- seg = _this.popoverSegs[i];
- view.publiclyTrigger('eventDestroy', seg.event, seg.event, seg.el);
- }
- }
- _this.segPopover.removeElement();
- _this.segPopover = null;
- _this.popoverSegs = null;
- }
- };
-
-
- if (this.isRTL) {
- options.right = moreWrap.offset().left + moreWrap.outerWidth() + 1;
- }
- else {
- options.left = moreWrap.offset().left - 1;
- }
- this.segPopover = new Popover(options);
- this.segPopover.show();
-
-
- this.bindSegHandlersToEl(this.segPopover.el);
- },
-
- renderSegPopoverContent: function(row, col, segs) {
- var view = this.view;
- var isTheme = view.opt('theme');
- var title = this.getCellDate(row, col).format(view.opt('dayPopoverFormat'));
- var content = $(
- '<div class="fc-header ' + view.widgetHeaderClass + '">' +
- '<span class="fc-close ' +
- (isTheme ? 'ui-icon ui-icon-closethick' : 'fc-icon fc-icon-x') +
- '"></span>' +
- '<span class="fc-title">' +
- htmlEscape(title) +
- '</span>' +
- '<div class="fc-clear"/>' +
- '</div>' +
- '<div class="fc-body ' + view.widgetContentClass + '">' +
- '<div class="fc-event-container"></div>' +
- '</div>'
- );
- var segContainer = content.find('.fc-event-container');
- var i;
-
- segs = this.renderFgSegEls(segs, true);
- this.popoverSegs = segs;
- for (i = 0; i < segs.length; i++) {
-
-
- this.prepareHits();
- segs[i].hit = this.getCellHit(row, col);
- this.releaseHits();
- segContainer.append(segs[i].el);
- }
- return content;
- },
-
- resliceDaySegs: function(segs, dayDate) {
-
- var events = $.map(segs, function(seg) {
- return seg.event;
- });
- var dayStart = dayDate.clone();
- var dayEnd = dayStart.clone().add(1, 'days');
- var dayRange = { start: dayStart, end: dayEnd };
-
- segs = this.eventsToSegs(
- events,
- function(range) {
- var seg = intersectRanges(range, dayRange);
- return seg ? [ seg ] : [];
- }
- );
-
- this.sortEventSegs(segs);
- return segs;
- },
-
- getMoreLinkText: function(num) {
- var opt = this.view.opt('eventLimitText');
- if (typeof opt === 'function') {
- return opt(num);
- }
- else {
- return '+' + num + ' ' + opt;
- }
- },
-
-
- getCellSegs: function(row, col, startLevel) {
- var segMatrix = this.rowStructs[row].segMatrix;
- var level = startLevel || 0;
- var segs = [];
- var seg;
- while (level < segMatrix.length) {
- seg = segMatrix[level][col];
- if (seg) {
- segs.push(seg);
- }
- level++;
- }
- return segs;
- }
- });
- ;;
- var TimeGrid = FC.TimeGrid = Grid.extend(DayTableMixin, {
- slotDuration: null,
- snapDuration: null,
- snapsPerSlot: null,
- minTime: null,
- maxTime: null,
- labelFormat: null,
- labelInterval: null,
- colEls: null,
- slatContainerEl: null,
- slatEls: null,
- nowIndicatorEls: null,
- colCoordCache: null,
- slatCoordCache: null,
- constructor: function() {
- Grid.apply(this, arguments);
- this.processOptions();
- },
-
-
- renderDates: function() {
- this.el.html(this.renderHtml());
- this.colEls = this.el.find('.fc-day');
- this.slatContainerEl = this.el.find('.fc-slats');
- this.slatEls = this.slatContainerEl.find('tr');
- this.colCoordCache = new CoordCache({
- els: this.colEls,
- isHorizontal: true
- });
- this.slatCoordCache = new CoordCache({
- els: this.slatEls,
- isVertical: true
- });
- this.renderContentSkeleton();
- },
-
- renderHtml: function() {
- return '' +
- '<div class="fc-bg">' +
- '<table>' +
- this.renderBgTrHtml(0) +
- '</table>' +
- '</div>' +
- '<div class="fc-slats">' +
- '<table>' +
- this.renderSlatRowHtml() +
- '</table>' +
- '</div>';
- },
-
- renderSlatRowHtml: function() {
- var view = this.view;
- var isRTL = this.isRTL;
- var html = '';
- var slotTime = moment.duration(+this.minTime);
- var slotDate;
- var isLabeled;
- var axisHtml;
-
- while (slotTime < this.maxTime) {
- slotDate = this.start.clone().time(slotTime);
- isLabeled = isInt(divideDurationByDuration(slotTime, this.labelInterval));
- axisHtml =
- '<td class="fc-axis fc-time ' + view.widgetContentClass + '" ' + view.axisStyleAttr() + '>' +
- (isLabeled ?
- '<span>' +
- htmlEscape(slotDate.format(this.labelFormat)) +
- '</span>' :
- ''
- ) +
- '</td>';
- html +=
- '<tr data-time="' + slotDate.format('HH:mm:ss') + '"' +
- (isLabeled ? '' : ' class="fc-minor"') +
- '>' +
- (!isRTL ? axisHtml : '') +
- '<td class="' + view.widgetContentClass + '"/>' +
- (isRTL ? axisHtml : '') +
- "</tr>";
- slotTime.add(this.slotDuration);
- }
- return html;
- },
-
-
- processOptions: function() {
- var view = this.view;
- var slotDuration = view.opt('slotDuration');
- var snapDuration = view.opt('snapDuration');
- var input;
- slotDuration = moment.duration(slotDuration);
- snapDuration = snapDuration ? moment.duration(snapDuration) : slotDuration;
- this.slotDuration = slotDuration;
- this.snapDuration = snapDuration;
- this.snapsPerSlot = slotDuration / snapDuration;
- this.minResizeDuration = snapDuration;
- this.minTime = moment.duration(view.opt('minTime'));
- this.maxTime = moment.duration(view.opt('maxTime'));
-
-
- input = view.opt('slotLabelFormat');
- if ($.isArray(input)) {
- input = input[input.length - 1];
- }
- this.labelFormat =
- input ||
- view.opt('smallTimeFormat');
- input = view.opt('slotLabelInterval');
- this.labelInterval = input ?
- moment.duration(input) :
- this.computeLabelInterval(slotDuration);
- },
-
- computeLabelInterval: function(slotDuration) {
- var i;
- var labelInterval;
- var slotsPerLabel;
-
- for (i = AGENDA_STOCK_SUB_DURATIONS.length - 1; i >= 0; i--) {
- labelInterval = moment.duration(AGENDA_STOCK_SUB_DURATIONS[i]);
- slotsPerLabel = divideDurationByDuration(labelInterval, slotDuration);
- if (isInt(slotsPerLabel) && slotsPerLabel > 1) {
- return labelInterval;
- }
- }
- return moment.duration(slotDuration);
- },
-
- computeEventTimeFormat: function() {
- return this.view.opt('noMeridiemTimeFormat');
- },
-
- computeDisplayEventEnd: function() {
- return true;
- },
-
- prepareHits: function() {
- this.colCoordCache.build();
- this.slatCoordCache.build();
- },
- releaseHits: function() {
- this.colCoordCache.clear();
-
- },
- queryHit: function(leftOffset, topOffset) {
- var snapsPerSlot = this.snapsPerSlot;
- var colCoordCache = this.colCoordCache;
- var slatCoordCache = this.slatCoordCache;
- if (colCoordCache.isLeftInBounds(leftOffset) && slatCoordCache.isTopInBounds(topOffset)) {
- var colIndex = colCoordCache.getHorizontalIndex(leftOffset);
- var slatIndex = slatCoordCache.getVerticalIndex(topOffset);
- if (colIndex != null && slatIndex != null) {
- var slatTop = slatCoordCache.getTopOffset(slatIndex);
- var slatHeight = slatCoordCache.getHeight(slatIndex);
- var partial = (topOffset - slatTop) / slatHeight;
- var localSnapIndex = Math.floor(partial * snapsPerSlot);
- var snapIndex = slatIndex * snapsPerSlot + localSnapIndex;
- var snapTop = slatTop + (localSnapIndex / snapsPerSlot) * slatHeight;
- var snapBottom = slatTop + ((localSnapIndex + 1) / snapsPerSlot) * slatHeight;
- return {
- col: colIndex,
- snap: snapIndex,
- component: this,
- left: colCoordCache.getLeftOffset(colIndex),
- right: colCoordCache.getRightOffset(colIndex),
- top: snapTop,
- bottom: snapBottom
- };
- }
- }
- },
- getHitSpan: function(hit) {
- var start = this.getCellDate(0, hit.col);
- var time = this.computeSnapTime(hit.snap);
- var end;
- start.time(time);
- end = start.clone().add(this.snapDuration);
- return { start: start, end: end };
- },
- getHitEl: function(hit) {
- return this.colEls.eq(hit.col);
- },
-
- rangeUpdated: function() {
- this.updateDayTable();
- },
-
- computeSnapTime: function(snapIndex) {
- return moment.duration(this.minTime + this.snapDuration * snapIndex);
- },
-
- spanToSegs: function(span) {
- var segs = this.sliceRangeByTimes(span);
- var i;
- for (i = 0; i < segs.length; i++) {
- if (this.isRTL) {
- segs[i].col = this.daysPerRow - 1 - segs[i].dayIndex;
- }
- else {
- segs[i].col = segs[i].dayIndex;
- }
- }
- return segs;
- },
- sliceRangeByTimes: function(range) {
- var segs = [];
- var seg;
- var dayIndex;
- var dayDate;
- var dayRange;
- for (dayIndex = 0; dayIndex < this.daysPerRow; dayIndex++) {
- dayDate = this.dayDates[dayIndex].clone();
- dayRange = {
- start: dayDate.clone().time(this.minTime),
- end: dayDate.clone().time(this.maxTime)
- };
- seg = intersectRanges(range, dayRange);
- if (seg) {
- seg.dayIndex = dayIndex;
- segs.push(seg);
- }
- }
- return segs;
- },
-
- updateSize: function(isResize) {
- this.slatCoordCache.build();
- if (isResize) {
- this.updateSegVerticals(
- [].concat(this.fgSegs || [], this.bgSegs || [], this.businessSegs || [])
- );
- }
- },
- getTotalSlatHeight: function() {
- return this.slatContainerEl.outerHeight();
- },
-
-
- computeDateTop: function(date, startOfDayDate) {
- return this.computeTimeTop(
- moment.duration(
- date - startOfDayDate.clone().stripTime()
- )
- );
- },
-
- computeTimeTop: function(time) {
- var len = this.slatEls.length;
- var slatCoverage = (time - this.minTime) / this.slotDuration;
- var slatIndex;
- var slatRemainder;
-
-
-
- slatCoverage = Math.max(0, slatCoverage);
- slatCoverage = Math.min(len, slatCoverage);
-
-
- slatIndex = Math.floor(slatCoverage);
- slatIndex = Math.min(slatIndex, len - 1);
-
-
- slatRemainder = slatCoverage - slatIndex;
- return this.slatCoordCache.getTopPosition(slatIndex) +
- this.slatCoordCache.getHeight(slatIndex) * slatRemainder;
- },
-
-
-
- renderDrag: function(eventLocation, seg) {
- if (seg) {
-
-
- return this.renderEventLocationHelper(eventLocation, seg);
- }
- else {
-
- this.renderHighlight(this.eventToSpan(eventLocation));
- }
- },
-
- unrenderDrag: function() {
- this.unrenderHelper();
- this.unrenderHighlight();
- },
-
-
- renderEventResize: function(eventLocation, seg) {
- return this.renderEventLocationHelper(eventLocation, seg);
- },
-
- unrenderEventResize: function() {
- this.unrenderHelper();
- },
-
-
- renderHelper: function(event, sourceSeg) {
- return this.renderHelperSegs(this.eventToSegs(event), sourceSeg);
- },
-
- unrenderHelper: function() {
- this.unrenderHelperSegs();
- },
-
- renderBusinessHours: function() {
- this.renderBusinessSegs(
- this.buildBusinessHourSegs()
- );
- },
- unrenderBusinessHours: function() {
- this.unrenderBusinessSegs();
- },
-
- getNowIndicatorUnit: function() {
- return 'minute';
- },
- renderNowIndicator: function(date) {
-
-
- var segs = this.spanToSegs({ start: date, end: date });
- var top = this.computeDateTop(date, date);
- var nodes = [];
- var i;
-
- for (i = 0; i < segs.length; i++) {
- nodes.push($('<div class="fc-now-indicator fc-now-indicator-line"></div>')
- .css('top', top)
- .appendTo(this.colContainerEls.eq(segs[i].col))[0]);
- }
-
- if (segs.length > 0) {
- nodes.push($('<div class="fc-now-indicator fc-now-indicator-arrow"></div>')
- .css('top', top)
- .appendTo(this.el.find('.fc-content-skeleton'))[0]);
- }
- this.nowIndicatorEls = $(nodes);
- },
- unrenderNowIndicator: function() {
- if (this.nowIndicatorEls) {
- this.nowIndicatorEls.remove();
- this.nowIndicatorEls = null;
- }
- },
-
-
- renderSelection: function(span) {
- if (this.view.opt('selectHelper')) {
-
- this.renderEventLocationHelper(span);
- }
- else {
- this.renderHighlight(span);
- }
- },
-
- unrenderSelection: function() {
- this.unrenderHelper();
- this.unrenderHighlight();
- },
-
- renderHighlight: function(span) {
- this.renderHighlightSegs(this.spanToSegs(span));
- },
- unrenderHighlight: function() {
- this.unrenderHighlightSegs();
- }
- });
- ;;
- TimeGrid.mixin({
- colContainerEls: null,
-
- fgContainerEls: null,
- bgContainerEls: null,
- helperContainerEls: null,
- highlightContainerEls: null,
- businessContainerEls: null,
-
- fgSegs: null,
- bgSegs: null,
- helperSegs: null,
- highlightSegs: null,
- businessSegs: null,
-
- renderContentSkeleton: function() {
- var cellHtml = '';
- var i;
- var skeletonEl;
- for (i = 0; i < this.colCnt; i++) {
- cellHtml +=
- '<td>' +
- '<div class="fc-content-col">' +
- '<div class="fc-event-container fc-helper-container"></div>' +
- '<div class="fc-event-container"></div>' +
- '<div class="fc-highlight-container"></div>' +
- '<div class="fc-bgevent-container"></div>' +
- '<div class="fc-business-container"></div>' +
- '</div>' +
- '</td>';
- }
- skeletonEl = $(
- '<div class="fc-content-skeleton">' +
- '<table>' +
- '<tr>' + cellHtml + '</tr>' +
- '</table>' +
- '</div>'
- );
- this.colContainerEls = skeletonEl.find('.fc-content-col');
- this.helperContainerEls = skeletonEl.find('.fc-helper-container');
- this.fgContainerEls = skeletonEl.find('.fc-event-container:not(.fc-helper-container)');
- this.bgContainerEls = skeletonEl.find('.fc-bgevent-container');
- this.highlightContainerEls = skeletonEl.find('.fc-highlight-container');
- this.businessContainerEls = skeletonEl.find('.fc-business-container');
- this.bookendCells(skeletonEl.find('tr'));
- this.el.append(skeletonEl);
- },
-
- renderFgSegs: function(segs) {
- segs = this.renderFgSegsIntoContainers(segs, this.fgContainerEls);
- this.fgSegs = segs;
- return segs;
- },
- unrenderFgSegs: function() {
- this.unrenderNamedSegs('fgSegs');
- },
-
- renderHelperSegs: function(segs, sourceSeg) {
- var helperEls = [];
- var i, seg;
- var sourceEl;
- segs = this.renderFgSegsIntoContainers(segs, this.helperContainerEls);
-
- for (i = 0; i < segs.length; i++) {
- seg = segs[i];
- if (sourceSeg && sourceSeg.col === seg.col) {
- sourceEl = sourceSeg.el;
- seg.el.css({
- left: sourceEl.css('left'),
- right: sourceEl.css('right'),
- 'margin-left': sourceEl.css('margin-left'),
- 'margin-right': sourceEl.css('margin-right')
- });
- }
- helperEls.push(seg.el[0]);
- }
- this.helperSegs = segs;
- return $(helperEls);
- },
- unrenderHelperSegs: function() {
- this.unrenderNamedSegs('helperSegs');
- },
-
- renderBgSegs: function(segs) {
- segs = this.renderFillSegEls('bgEvent', segs);
- this.updateSegVerticals(segs);
- this.attachSegsByCol(this.groupSegsByCol(segs), this.bgContainerEls);
- this.bgSegs = segs;
- return segs;
- },
- unrenderBgSegs: function() {
- this.unrenderNamedSegs('bgSegs');
- },
-
- renderHighlightSegs: function(segs) {
- segs = this.renderFillSegEls('highlight', segs);
- this.updateSegVerticals(segs);
- this.attachSegsByCol(this.groupSegsByCol(segs), this.highlightContainerEls);
- this.highlightSegs = segs;
- },
- unrenderHighlightSegs: function() {
- this.unrenderNamedSegs('highlightSegs');
- },
-
- renderBusinessSegs: function(segs) {
- segs = this.renderFillSegEls('businessHours', segs);
- this.updateSegVerticals(segs);
- this.attachSegsByCol(this.groupSegsByCol(segs), this.businessContainerEls);
- this.businessSegs = segs;
- },
- unrenderBusinessSegs: function() {
- this.unrenderNamedSegs('businessSegs');
- },
-
-
- groupSegsByCol: function(segs) {
- var segsByCol = [];
- var i;
- for (i = 0; i < this.colCnt; i++) {
- segsByCol.push([]);
- }
- for (i = 0; i < segs.length; i++) {
- segsByCol[segs[i].col].push(segs[i]);
- }
- return segsByCol;
- },
-
-
- attachSegsByCol: function(segsByCol, containerEls) {
- var col;
- var segs;
- var i;
- for (col = 0; col < this.colCnt; col++) {
- segs = segsByCol[col];
- for (i = 0; i < segs.length; i++) {
- containerEls.eq(col).append(segs[i].el);
- }
- }
- },
-
-
- unrenderNamedSegs: function(propName) {
- var segs = this[propName];
- var i;
- if (segs) {
- for (i = 0; i < segs.length; i++) {
- segs[i].el.remove();
- }
- this[propName] = null;
- }
- },
-
-
-
- renderFgSegsIntoContainers: function(segs, containerEls) {
- var segsByCol;
- var col;
- segs = this.renderFgSegEls(segs);
- segsByCol = this.groupSegsByCol(segs);
- for (col = 0; col < this.colCnt; col++) {
- this.updateFgSegCoords(segsByCol[col]);
- }
- this.attachSegsByCol(segsByCol, containerEls);
- return segs;
- },
-
- fgSegHtml: function(seg, disableResizing) {
- var view = this.view;
- var event = seg.event;
- var isDraggable = view.isEventDraggable(event);
- var isResizableFromStart = !disableResizing && seg.isStart && view.isEventResizableFromStart(event);
- var isResizableFromEnd = !disableResizing && seg.isEnd && view.isEventResizableFromEnd(event);
- var classes = this.getSegClasses(seg, isDraggable, isResizableFromStart || isResizableFromEnd);
- var skinCss = cssToStr(this.getSegSkinCss(seg));
- var timeText;
- var fullTimeText;
- var startTimeText;
- classes.unshift('fc-time-grid-event', 'fc-v-event');
- if (view.isMultiDayEvent(event)) {
-
-
-
- if (seg.isStart || seg.isEnd) {
- timeText = this.getEventTimeText(seg);
- fullTimeText = this.getEventTimeText(seg, 'LT');
- startTimeText = this.getEventTimeText(seg, null, false);
- }
- } else {
-
- timeText = this.getEventTimeText(event);
- fullTimeText = this.getEventTimeText(event, 'LT');
- startTimeText = this.getEventTimeText(event, null, false);
- }
- return '<a class="' + classes.join(' ') + '"' +
- (event.url ?
- ' href="' + htmlEscape(event.url) + '"' :
- ''
- ) +
- (skinCss ?
- ' style="' + skinCss + '"' :
- ''
- ) +
- '>' +
- '<div class="fc-content">' +
- (timeText ?
- '<div class="fc-time"' +
- ' data-start="' + htmlEscape(startTimeText) + '"' +
- ' data-full="' + htmlEscape(fullTimeText) + '"' +
- '>' +
- '<span>' + htmlEscape(timeText) + '</span>' +
- '</div>' :
- ''
- ) +
- (event.title ?
- '<div class="fc-title">' +
- htmlEscape(event.title) +
- '</div>' :
- ''
- ) +
- '</div>' +
- '<div class="fc-bg"/>' +
-
- (isResizableFromEnd ?
- '<div class="fc-resizer fc-end-resizer" />' :
- ''
- ) +
- '</a>';
- },
-
-
-
- updateSegVerticals: function(segs) {
- this.computeSegVerticals(segs);
- this.assignSegVerticals(segs);
- },
-
- computeSegVerticals: function(segs) {
- var i, seg;
- for (i = 0; i < segs.length; i++) {
- seg = segs[i];
- seg.top = this.computeDateTop(seg.start, seg.start);
- seg.bottom = this.computeDateTop(seg.end, seg.start);
- }
- },
-
-
- assignSegVerticals: function(segs) {
- var i, seg;
- for (i = 0; i < segs.length; i++) {
- seg = segs[i];
- seg.el.css(this.generateSegVerticalCss(seg));
- }
- },
-
- generateSegVerticalCss: function(seg) {
- return {
- top: seg.top,
- bottom: -seg.bottom
- };
- },
-
-
-
- updateFgSegCoords: function(segs) {
- this.computeSegVerticals(segs);
- this.computeFgSegHorizontals(segs);
- this.assignSegVerticals(segs);
- this.assignFgSegHorizontals(segs);
- },
-
-
- computeFgSegHorizontals: function(segs) {
- var levels;
- var level0;
- var i;
- this.sortEventSegs(segs);
- levels = buildSlotSegLevels(segs);
- computeForwardSlotSegs(levels);
- if ((level0 = levels[0])) {
- for (i = 0; i < level0.length; i++) {
- computeSlotSegPressures(level0[i]);
- }
- for (i = 0; i < level0.length; i++) {
- this.computeFgSegForwardBack(level0[i], 0, 0);
- }
- }
- },
-
-
-
-
-
-
-
-
- computeFgSegForwardBack: function(seg, seriesBackwardPressure, seriesBackwardCoord) {
- var forwardSegs = seg.forwardSegs;
- var i;
- if (seg.forwardCoord === undefined) {
- if (!forwardSegs.length) {
-
- seg.forwardCoord = 1;
- }
- else {
-
- this.sortForwardSegs(forwardSegs);
-
-
- this.computeFgSegForwardBack(forwardSegs[0], seriesBackwardPressure + 1, seriesBackwardCoord);
- seg.forwardCoord = forwardSegs[0].backwardCoord;
- }
-
- seg.backwardCoord = seg.forwardCoord -
- (seg.forwardCoord - seriesBackwardCoord) /
- (seriesBackwardPressure + 1);
-
-
- for (i=0; i<forwardSegs.length; i++) {
- this.computeFgSegForwardBack(forwardSegs[i], 0, seg.forwardCoord);
- }
- }
- },
- sortForwardSegs: function(forwardSegs) {
- forwardSegs.sort(proxy(this, 'compareForwardSegs'));
- },
-
- compareForwardSegs: function(seg1, seg2) {
-
- return seg2.forwardPressure - seg1.forwardPressure ||
-
- (seg1.backwardCoord || 0) - (seg2.backwardCoord || 0) ||
-
- this.compareEventSegs(seg1, seg2);
- },
-
-
- assignFgSegHorizontals: function(segs) {
- var i, seg;
- for (i = 0; i < segs.length; i++) {
- seg = segs[i];
- seg.el.css(this.generateFgSegHorizontalCss(seg));
-
- if (seg.bottom - seg.top < 30) {
- seg.el.addClass('fc-short');
- }
- }
- },
-
-
- generateFgSegHorizontalCss: function(seg) {
- var shouldOverlap = this.view.opt('slotEventOverlap');
- var backwardCoord = seg.backwardCoord;
- var forwardCoord = seg.forwardCoord;
- var props = this.generateSegVerticalCss(seg);
- var left;
- var right;
- if (shouldOverlap) {
-
- forwardCoord = Math.min(1, backwardCoord + (forwardCoord - backwardCoord) * 2);
- }
- if (this.isRTL) {
- left = 1 - forwardCoord;
- right = backwardCoord;
- }
- else {
- left = backwardCoord;
- right = 1 - forwardCoord;
- }
- props.zIndex = seg.level + 1;
- props.left = left * 100 + '%';
- props.right = right * 100 + '%';
- if (shouldOverlap && seg.forwardPressure) {
-
- props[this.isRTL ? 'marginLeft' : 'marginRight'] = 10 * 2;
- }
- return props;
- }
- });
- function buildSlotSegLevels(segs) {
- var levels = [];
- var i, seg;
- var j;
- for (i=0; i<segs.length; i++) {
- seg = segs[i];
-
- for (j=0; j<levels.length; j++) {
- if (!computeSlotSegCollisions(seg, levels[j]).length) {
- break;
- }
- }
- seg.level = j;
- (levels[j] || (levels[j] = [])).push(seg);
- }
- return levels;
- }
- function computeForwardSlotSegs(levels) {
- var i, level;
- var j, seg;
- var k;
- for (i=0; i<levels.length; i++) {
- level = levels[i];
- for (j=0; j<level.length; j++) {
- seg = level[j];
- seg.forwardSegs = [];
- for (k=i+1; k<levels.length; k++) {
- computeSlotSegCollisions(seg, levels[k], seg.forwardSegs);
- }
- }
- }
- }
- function computeSlotSegPressures(seg) {
- var forwardSegs = seg.forwardSegs;
- var forwardPressure = 0;
- var i, forwardSeg;
- if (seg.forwardPressure === undefined) {
- for (i=0; i<forwardSegs.length; i++) {
- forwardSeg = forwardSegs[i];
-
- computeSlotSegPressures(forwardSeg);
-
-
- forwardPressure = Math.max(
- forwardPressure,
- 1 + forwardSeg.forwardPressure
- );
- }
- seg.forwardPressure = forwardPressure;
- }
- }
- function computeSlotSegCollisions(seg, otherSegs, results) {
- results = results || [];
- for (var i=0; i<otherSegs.length; i++) {
- if (isSlotSegCollision(seg, otherSegs[i])) {
- results.push(otherSegs[i]);
- }
- }
- return results;
- }
- function isSlotSegCollision(seg1, seg2) {
- return seg1.bottom > seg2.top && seg1.top < seg2.bottom;
- }
- ;;
- var View = FC.View = Class.extend(EmitterMixin, ListenerMixin, {
- type: null,
- name: null,
- title: null,
- calendar: null,
- options: null,
- el: null,
- isDateSet: false,
- isDateRendered: false,
- dateRenderQueue: null,
- isEventsBound: false,
- isEventsSet: false,
- isEventsRendered: false,
- eventRenderQueue: null,
-
- start: null,
- end: null,
-
-
- intervalStart: null,
- intervalEnd: null,
- intervalDuration: null,
- intervalUnit: null,
- isRTL: false,
- isSelected: false,
- selectedEvent: null,
- eventOrderSpecs: null,
-
- widgetHeaderClass: null,
- widgetContentClass: null,
- highlightStateClass: null,
-
- nextDayThreshold: null,
- isHiddenDayHash: null,
-
- isNowIndicatorRendered: null,
- initialNowDate: null,
- initialNowQueriedMs: null,
- nowIndicatorTimeoutID: null,
- nowIndicatorIntervalID: null,
- constructor: function(calendar, type, options, intervalDuration) {
- this.calendar = calendar;
- this.type = this.name = type;
- this.options = options;
- this.intervalDuration = intervalDuration || moment.duration(1, 'day');
- this.nextDayThreshold = moment.duration(this.opt('nextDayThreshold'));
- this.initThemingProps();
- this.initHiddenDays();
- this.isRTL = this.opt('isRTL');
- this.eventOrderSpecs = parseFieldSpecs(this.opt('eventOrder'));
- this.dateRenderQueue = new TaskQueue();
- this.eventRenderQueue = new TaskQueue(this.opt('eventRenderWait'));
- this.initialize();
- },
-
- initialize: function() {
-
- },
-
- opt: function(name) {
- return this.options[name];
- },
-
- publiclyTrigger: function(name, thisObj) {
- var calendar = this.calendar;
- return calendar.publiclyTrigger.apply(
- calendar,
- [name, thisObj || this].concat(
- Array.prototype.slice.call(arguments, 2),
- [ this ]
- )
- );
- },
-
-
- rejectOn: function(eventName, promise) {
- var _this = this;
- return new Promise(function(resolve, reject) {
- _this.one(eventName, reject);
- function cleanup() {
- _this.off(eventName, reject);
- }
- promise.then(function(res) {
- cleanup();
- resolve(res);
- }, function() {
- cleanup();
- reject();
- });
- });
- },
-
-
- setRange: function(range) {
- $.extend(this, range);
- this.updateTitle();
- },
-
-
- computeRange: function(date) {
- var intervalUnit = computeIntervalUnit(this.intervalDuration);
- var intervalStart = date.clone().startOf(intervalUnit);
- var intervalEnd = intervalStart.clone().add(this.intervalDuration);
- var start, end;
-
- if (/year|month|week|day/.test(intervalUnit)) {
- intervalStart.stripTime();
- intervalEnd.stripTime();
- }
- else {
- if (!intervalStart.hasTime()) {
- intervalStart = this.calendar.time(0);
- }
- if (!intervalEnd.hasTime()) {
- intervalEnd = this.calendar.time(0);
- }
- }
- start = intervalStart.clone();
- start = this.skipHiddenDays(start);
- end = intervalEnd.clone();
- end = this.skipHiddenDays(end, -1, true);
- return {
- intervalUnit: intervalUnit,
- intervalStart: intervalStart,
- intervalEnd: intervalEnd,
- start: start,
- end: end
- };
- },
-
- computePrevDate: function(date) {
- return this.massageCurrentDate(
- date.clone().startOf(this.intervalUnit).subtract(this.intervalDuration), -1
- );
- },
-
- computeNextDate: function(date) {
- return this.massageCurrentDate(
- date.clone().startOf(this.intervalUnit).add(this.intervalDuration)
- );
- },
-
-
-
- massageCurrentDate: function(date, direction) {
- if (this.intervalDuration.as('days') <= 1) {
- if (this.isHiddenDay(date)) {
- date = this.skipHiddenDays(date, direction);
- date.startOf('day');
- }
- }
- return date;
- },
-
-
- updateTitle: function() {
- this.title = this.computeTitle();
- this.calendar.setToolbarsTitle(this.title);
- },
-
- computeTitle: function() {
- return this.formatRange(
- {
-
- start: this.calendar.applyTimezone(this.intervalStart),
- end: this.calendar.applyTimezone(this.intervalEnd)
- },
- this.opt('titleFormat') || this.computeTitleFormat(),
- this.opt('titleRangeSeparator')
- );
- },
-
-
- computeTitleFormat: function() {
- if (this.intervalUnit == 'year') {
- return 'YYYY';
- }
- else if (this.intervalUnit == 'month') {
- return this.opt('monthYearFormat');
- }
- else if (this.intervalDuration.as('days') > 1) {
- return 'll';
- }
- else {
- return 'LL';
- }
- },
-
-
-
- formatRange: function(range, formatStr, separator) {
- var end = range.end;
- if (!end.hasTime()) {
- end = end.clone().subtract(1);
- }
- return formatRange(range.start, end, formatStr, separator, this.opt('isRTL'));
- },
- getAllDayHtml: function() {
- return this.opt('allDayHtml') || htmlEscape(this.opt('allDayText'));
- },
-
-
-
-
-
-
-
- buildGotoAnchorHtml: function(gotoOptions, attrs, innerHtml) {
- var date, type, forceOff;
- var finalOptions;
- if ($.isPlainObject(gotoOptions)) {
- date = gotoOptions.date;
- type = gotoOptions.type;
- forceOff = gotoOptions.forceOff;
- }
- else {
- date = gotoOptions;
- }
- date = FC.moment(date);
- finalOptions = {
- date: date.format('YYYY-MM-DD'),
- type: type || 'day'
- };
- if (typeof attrs === 'string') {
- innerHtml = attrs;
- attrs = null;
- }
- attrs = attrs ? ' ' + attrsToStr(attrs) : '';
- innerHtml = innerHtml || '';
- if (!forceOff && this.opt('navLinks')) {
- return '<a' + attrs +
- ' data-goto="' + htmlEscape(JSON.stringify(finalOptions)) + '">' +
- innerHtml +
- '</a>';
- }
- else {
- return '<span' + attrs + '>' +
- innerHtml +
- '</span>';
- }
- },
-
-
-
-
- setElement: function(el) {
- this.el = el;
- this.bindGlobalHandlers();
- this.renderSkeleton();
- },
-
-
- removeElement: function() {
- this.unsetDate();
- this.unrenderSkeleton();
- this.unbindGlobalHandlers();
- this.el.remove();
-
-
-
- },
-
- renderSkeleton: function() {
-
- },
-
- unrenderSkeleton: function() {
-
- },
-
-
- setDate: function(date) {
- var isReset = this.isDateSet;
- this.isDateSet = true;
- this.handleDate(date, isReset);
- this.trigger(isReset ? 'dateReset' : 'dateSet', date);
- },
- unsetDate: function() {
- if (this.isDateSet) {
- this.isDateSet = false;
- this.handleDateUnset();
- this.trigger('dateUnset');
- }
- },
-
-
- handleDate: function(date, isReset) {
- var _this = this;
- this.unbindEvents();
- this.requestDateRender(date).then(function() {
-
- _this.bindEvents();
- });
- },
- handleDateUnset: function() {
- this.unbindEvents();
- this.requestDateUnrender();
- },
-
-
-
- requestDateRender: function(date) {
- var _this = this;
- return this.dateRenderQueue.add(function() {
- return _this.executeDateRender(date);
- });
- },
- requestDateUnrender: function() {
- var _this = this;
- return this.dateRenderQueue.add(function() {
- return _this.executeDateUnrender();
- });
- },
-
-
-
- executeDateRender: function(date) {
- var _this = this;
-
- if (date) {
- this.captureInitialScroll();
- }
- else {
- this.captureScroll();
- }
- this.freezeHeight();
- return this.executeDateUnrender().then(function() {
- if (date) {
- _this.setRange(_this.computeRange(date));
- }
- if (_this.render) {
- _this.render();
- }
- _this.renderDates();
- _this.updateSize();
- _this.renderBusinessHours();
- _this.startNowIndicator();
- _this.thawHeight();
- _this.releaseScroll();
- _this.isDateRendered = true;
- _this.onDateRender();
- _this.trigger('dateRender');
- });
- },
- executeDateUnrender: function() {
- var _this = this;
- if (_this.isDateRendered) {
- return this.requestEventsUnrender().then(function() {
- _this.unselect();
- _this.stopNowIndicator();
- _this.triggerUnrender();
- _this.unrenderBusinessHours();
- _this.unrenderDates();
- if (_this.destroy) {
- _this.destroy();
- }
- _this.isDateRendered = false;
- _this.trigger('dateUnrender');
- });
- }
- else {
- return Promise.resolve();
- }
- },
-
-
- onDateRender: function() {
- this.triggerRender();
- },
-
-
-
- renderDates: function() {
-
- },
-
- unrenderDates: function() {
-
- },
-
-
-
- triggerRender: function() {
- this.publiclyTrigger('viewRender', this, this, this.el);
- },
-
- triggerUnrender: function() {
- this.publiclyTrigger('viewDestroy', this, this, this.el);
- },
-
- bindGlobalHandlers: function() {
- this.listenTo($(document), 'mousedown', this.handleDocumentMousedown);
- this.listenTo($(document), 'touchstart', this.processUnselect);
- },
-
- unbindGlobalHandlers: function() {
- this.stopListeningTo($(document));
- },
-
- initThemingProps: function() {
- var tm = this.opt('theme') ? 'ui' : 'fc';
- this.widgetHeaderClass = tm + '-widget-header';
- this.widgetContentClass = tm + '-widget-content';
- this.highlightStateClass = tm + '-state-highlight';
- },
-
-
- renderBusinessHours: function() {
-
- },
-
- unrenderBusinessHours: function() {
-
- },
-
-
-
-
- startNowIndicator: function() {
- var _this = this;
- var unit;
- var update;
- var delay;
- if (this.opt('nowIndicator')) {
- unit = this.getNowIndicatorUnit();
- if (unit) {
- update = proxy(this, 'updateNowIndicator');
- this.initialNowDate = this.calendar.getNow();
- this.initialNowQueriedMs = +new Date();
- this.renderNowIndicator(this.initialNowDate);
- this.isNowIndicatorRendered = true;
-
- delay = this.initialNowDate.clone().startOf(unit).add(1, unit) - this.initialNowDate;
- this.nowIndicatorTimeoutID = setTimeout(function() {
- _this.nowIndicatorTimeoutID = null;
- update();
- delay = +moment.duration(1, unit);
- delay = Math.max(100, delay);
- _this.nowIndicatorIntervalID = setInterval(update, delay);
- }, delay);
- }
- }
- },
-
-
- updateNowIndicator: function() {
- if (this.isNowIndicatorRendered) {
- this.unrenderNowIndicator();
- this.renderNowIndicator(
- this.initialNowDate.clone().add(new Date() - this.initialNowQueriedMs)
- );
- }
- },
-
-
- stopNowIndicator: function() {
- if (this.isNowIndicatorRendered) {
- if (this.nowIndicatorTimeoutID) {
- clearTimeout(this.nowIndicatorTimeoutID);
- this.nowIndicatorTimeoutID = null;
- }
- if (this.nowIndicatorIntervalID) {
- clearTimeout(this.nowIndicatorIntervalID);
- this.nowIndicatorIntervalID = null;
- }
- this.unrenderNowIndicator();
- this.isNowIndicatorRendered = false;
- }
- },
-
-
- getNowIndicatorUnit: function() {
-
- },
-
- renderNowIndicator: function(date) {
-
- },
-
- unrenderNowIndicator: function() {
-
- },
-
-
- updateSize: function(isResize) {
- if (isResize) {
- this.captureScroll();
- }
- this.updateHeight(isResize);
- this.updateWidth(isResize);
- this.updateNowIndicator();
- if (isResize) {
- this.releaseScroll();
- }
- },
-
- updateWidth: function(isResize) {
-
- },
-
- updateHeight: function(isResize) {
- var calendar = this.calendar;
- this.setHeight(
- calendar.getSuggestedViewHeight(),
- calendar.isHeightAuto()
- );
- },
-
-
- setHeight: function(height, isAuto) {
-
- },
-
- capturedScroll: null,
- capturedScrollDepth: 0,
- captureScroll: function() {
- if (!(this.capturedScrollDepth++)) {
- this.capturedScroll = this.isDateRendered ? this.queryScroll() : {};
- return true;
- }
- return false;
- },
- captureInitialScroll: function(forcedScroll) {
- if (this.captureScroll()) {
- this.capturedScroll.isInitial = true;
- if (forcedScroll) {
- $.extend(this.capturedScroll, forcedScroll);
- }
- else {
- this.capturedScroll.isComputed = true;
- }
- }
- },
- releaseScroll: function() {
- var scroll = this.capturedScroll;
- var isRoot = this.discardScroll();
- if (scroll.isComputed) {
- if (isRoot) {
-
- $.extend(scroll, this.computeInitialScroll());
- }
- else {
- scroll = null;
- }
- }
- if (scroll) {
-
-
-
- if (scroll.isInitial) {
- this.hardSetScroll(scroll);
- }
- else {
- this.setScroll(scroll);
- }
- }
- },
- discardScroll: function() {
- if (!(--this.capturedScrollDepth)) {
- this.capturedScroll = null;
- return true;
- }
- return false;
- },
- computeInitialScroll: function() {
- return {};
- },
- queryScroll: function() {
- return {};
- },
- hardSetScroll: function(scroll) {
- var _this = this;
- var exec = function() { _this.setScroll(scroll); };
- exec();
- setTimeout(exec, 0);
- },
- setScroll: function(scroll) {
- },
-
- freezeHeight: function() {
- this.calendar.freezeContentHeight();
- },
- thawHeight: function() {
- this.calendar.thawContentHeight();
- },
-
-
- bindEvents: function() {
- var _this = this;
- if (!this.isEventsBound) {
- this.isEventsBound = true;
- this.rejectOn('eventsUnbind', this.requestEvents()).then(function(events) {
- _this.listenTo(_this.calendar, 'eventsReset', _this.setEvents);
- _this.setEvents(events);
- });
- }
- },
- unbindEvents: function() {
- if (this.isEventsBound) {
- this.isEventsBound = false;
- this.stopListeningTo(this.calendar, 'eventsReset');
- this.unsetEvents();
- this.trigger('eventsUnbind');
- }
- },
-
-
- setEvents: function(events) {
- var isReset = this.isEventSet;
- this.isEventsSet = true;
- this.handleEvents(events, isReset);
- this.trigger(isReset ? 'eventsReset' : 'eventsSet', events);
- },
- unsetEvents: function() {
- if (this.isEventsSet) {
- this.isEventsSet = false;
- this.handleEventsUnset();
- this.trigger('eventsUnset');
- }
- },
- whenEventsSet: function() {
- var _this = this;
- if (this.isEventsSet) {
- return Promise.resolve(this.getCurrentEvents());
- }
- else {
- return new Promise(function(resolve) {
- _this.one('eventsSet', resolve);
- });
- }
- },
-
-
- handleEvents: function(events, isReset) {
- this.requestEventsRender(events);
- },
- handleEventsUnset: function() {
- this.requestEventsUnrender();
- },
-
-
-
- requestEventsRender: function(events) {
- var _this = this;
- return this.eventRenderQueue.add(function() {
- return _this.executeEventsRender(events);
- });
- },
- requestEventsUnrender: function() {
- var _this = this;
- if (this.isEventsRendered) {
- return this.eventRenderQueue.addQuickly(function() {
- return _this.executeEventsUnrender();
- });
- }
- else {
- return Promise.resolve();
- }
- },
- requestCurrentEventsRender: function() {
- if (this.isEventsSet) {
- this.requestEventsRender(this.getCurrentEvents());
- }
- else {
- return Promise.reject();
- }
- },
-
-
- executeEventsRender: function(events) {
- var _this = this;
- this.captureScroll();
- this.freezeHeight();
- return this.executeEventsUnrender().then(function() {
- _this.renderEvents(events);
- _this.thawHeight();
- _this.releaseScroll();
- _this.isEventsRendered = true;
- _this.onEventsRender();
- _this.trigger('eventsRender');
- });
- },
- executeEventsUnrender: function() {
- if (this.isEventsRendered) {
- this.onBeforeEventsUnrender();
- this.captureScroll();
- this.freezeHeight();
- if (this.destroyEvents) {
- this.destroyEvents();
- }
- this.unrenderEvents();
- this.thawHeight();
- this.releaseScroll();
- this.isEventsRendered = false;
- this.trigger('eventsUnrender');
- }
- return Promise.resolve();
- },
-
-
-
- onEventsRender: function() {
- this.renderedEventSegEach(function(seg) {
- this.publiclyTrigger('eventAfterRender', seg.event, seg.event, seg.el);
- });
- this.publiclyTrigger('eventAfterAllRender');
- },
-
- onBeforeEventsUnrender: function() {
- this.renderedEventSegEach(function(seg) {
- this.publiclyTrigger('eventDestroy', seg.event, seg.event, seg.el);
- });
- },
-
-
-
- renderEvents: function(events) {
-
- },
-
- unrenderEvents: function() {
-
- },
-
-
- requestEvents: function() {
- return this.calendar.requestEvents(this.start, this.end);
- },
- getCurrentEvents: function() {
- return this.calendar.getPrunedEventCache();
- },
-
-
-
-
- resolveEventEl: function(event, el) {
- var custom = this.publiclyTrigger('eventRender', event, event, el);
- if (custom === false) {
- el = null;
- }
- else if (custom && custom !== true) {
- el = $(custom);
- }
- return el;
- },
-
- showEvent: function(event) {
- this.renderedEventSegEach(function(seg) {
- seg.el.css('visibility', '');
- }, event);
- },
-
- hideEvent: function(event) {
- this.renderedEventSegEach(function(seg) {
- seg.el.css('visibility', 'hidden');
- }, event);
- },
-
-
-
- renderedEventSegEach: function(func, event) {
- var segs = this.getEventSegs();
- var i;
- for (i = 0; i < segs.length; i++) {
- if (!event || segs[i].event._id === event._id) {
- if (segs[i].el) {
- func.call(this, segs[i]);
- }
- }
- }
- },
-
- getEventSegs: function() {
-
- return [];
- },
-
-
- isEventDraggable: function(event) {
- return this.isEventStartEditable(event);
- },
- isEventStartEditable: function(event) {
- return firstDefined(
- event.startEditable,
- (event.source || {}).startEditable,
- this.opt('eventStartEditable'),
- this.isEventGenerallyEditable(event)
- );
- },
- isEventGenerallyEditable: function(event) {
- return firstDefined(
- event.editable,
- (event.source || {}).editable,
- this.opt('editable')
- );
- },
-
-
- reportEventDrop: function(event, dropLocation, largeUnit, el, ev) {
- var calendar = this.calendar;
- var mutateResult = calendar.mutateEvent(event, dropLocation, largeUnit);
- var undoFunc = function() {
- mutateResult.undo();
- calendar.reportEventChange();
- };
- this.triggerEventDrop(event, mutateResult.dateDelta, undoFunc, el, ev);
- calendar.reportEventChange();
- },
-
- triggerEventDrop: function(event, dateDelta, undoFunc, el, ev) {
- this.publiclyTrigger('eventDrop', el[0], event, dateDelta, undoFunc, ev, {});
- },
-
-
-
-
- reportExternalDrop: function(meta, dropLocation, el, ev, ui) {
- var eventProps = meta.eventProps;
- var eventInput;
- var event;
-
- if (eventProps) {
- eventInput = $.extend({}, eventProps, dropLocation);
- event = this.calendar.renderEvent(eventInput, meta.stick)[0];
- }
- this.triggerExternalDrop(event, dropLocation, el, ev, ui);
- },
-
- triggerExternalDrop: function(event, dropLocation, el, ev, ui) {
-
- this.publiclyTrigger('drop', el[0], dropLocation.start, ev, ui);
- if (event) {
- this.publiclyTrigger('eventReceive', null, event);
- }
- },
-
-
-
-
- renderDrag: function(dropLocation, seg) {
-
- },
-
- unrenderDrag: function() {
-
- },
-
-
- isEventResizableFromStart: function(event) {
- return this.opt('eventResizableFromStart') && this.isEventResizable(event);
- },
-
- isEventResizableFromEnd: function(event) {
- return this.isEventResizable(event);
- },
-
- isEventResizable: function(event) {
- var source = event.source || {};
- return firstDefined(
- event.durationEditable,
- source.durationEditable,
- this.opt('eventDurationEditable'),
- event.editable,
- source.editable,
- this.opt('editable')
- );
- },
-
- reportEventResize: function(event, resizeLocation, largeUnit, el, ev) {
- var calendar = this.calendar;
- var mutateResult = calendar.mutateEvent(event, resizeLocation, largeUnit);
- var undoFunc = function() {
- mutateResult.undo();
- calendar.reportEventChange();
- };
- this.triggerEventResize(event, mutateResult.durationDelta, undoFunc, el, ev);
- calendar.reportEventChange();
- },
-
- triggerEventResize: function(event, durationDelta, undoFunc, el, ev) {
- this.publiclyTrigger('eventResize', el[0], event, durationDelta, undoFunc, ev, {});
- },
-
-
-
- select: function(span, ev) {
- this.unselect(ev);
- this.renderSelection(span);
- this.reportSelection(span, ev);
- },
-
- renderSelection: function(span) {
-
- },
-
- reportSelection: function(span, ev) {
- this.isSelected = true;
- this.triggerSelect(span, ev);
- },
-
- triggerSelect: function(span, ev) {
- this.publiclyTrigger(
- 'select',
- null,
- this.calendar.applyTimezone(span.start),
- this.calendar.applyTimezone(span.end),
- ev
- );
- },
-
-
- unselect: function(ev) {
- if (this.isSelected) {
- this.isSelected = false;
- if (this.destroySelection) {
- this.destroySelection();
- }
- this.unrenderSelection();
- this.publiclyTrigger('unselect', null, ev);
- }
- },
-
- unrenderSelection: function() {
-
- },
-
- selectEvent: function(event) {
- if (!this.selectedEvent || this.selectedEvent !== event) {
- this.unselectEvent();
- this.renderedEventSegEach(function(seg) {
- seg.el.addClass('fc-selected');
- }, event);
- this.selectedEvent = event;
- }
- },
- unselectEvent: function() {
- if (this.selectedEvent) {
- this.renderedEventSegEach(function(seg) {
- seg.el.removeClass('fc-selected');
- }, this.selectedEvent);
- this.selectedEvent = null;
- }
- },
- isEventSelected: function(event) {
-
-
- return this.selectedEvent && this.selectedEvent._id === event._id;
- },
-
-
-
- handleDocumentMousedown: function(ev) {
- if (isPrimaryMouseButton(ev)) {
- this.processUnselect(ev);
- }
- },
- processUnselect: function(ev) {
- this.processRangeUnselect(ev);
- this.processEventUnselect(ev);
- },
- processRangeUnselect: function(ev) {
- var ignore;
-
- if (this.isSelected && this.opt('unselectAuto')) {
-
- ignore = this.opt('unselectCancel');
- if (!ignore || !$(ev.target).closest(ignore).length) {
- this.unselect(ev);
- }
- }
- },
- processEventUnselect: function(ev) {
- if (this.selectedEvent) {
- if (!$(ev.target).closest('.fc-selected').length) {
- this.unselectEvent();
- }
- }
- },
-
-
-
- triggerDayClick: function(span, dayEl, ev) {
- this.publiclyTrigger(
- 'dayClick',
- dayEl,
- this.calendar.applyTimezone(span.start),
- ev
- );
- },
-
-
- initHiddenDays: function() {
- var hiddenDays = this.opt('hiddenDays') || [];
- var isHiddenDayHash = [];
- var dayCnt = 0;
- var i;
- if (this.opt('weekends') === false) {
- hiddenDays.push(0, 6);
- }
- for (i = 0; i < 7; i++) {
- if (
- !(isHiddenDayHash[i] = $.inArray(i, hiddenDays) !== -1)
- ) {
- dayCnt++;
- }
- }
- if (!dayCnt) {
- throw 'invalid hiddenDays';
- }
- this.isHiddenDayHash = isHiddenDayHash;
- },
-
-
- isHiddenDay: function(day) {
- if (moment.isMoment(day)) {
- day = day.day();
- }
- return this.isHiddenDayHash[day];
- },
-
-
-
-
- skipHiddenDays: function(date, inc, isExclusive) {
- var out = date.clone();
- inc = inc || 1;
- while (
- this.isHiddenDayHash[(out.day() + (isExclusive ? inc : 0) + 7) % 7]
- ) {
- out.add(inc, 'days');
- }
- return out;
- },
-
-
- computeDayRange: function(range) {
- var startDay = range.start.clone().stripTime();
- var end = range.end;
- var endDay = null;
- var endTimeMS;
- if (end) {
- endDay = end.clone().stripTime();
- endTimeMS = +end.time();
-
-
-
- if (endTimeMS && endTimeMS >= this.nextDayThreshold) {
- endDay.add(1, 'days');
- }
- }
-
-
- if (!end || endDay <= startDay) {
- endDay = startDay.clone().add(1, 'days');
- }
- return { start: startDay, end: endDay };
- },
-
- isMultiDayEvent: function(event) {
- var range = this.computeDayRange(event);
- return range.end.diff(range.start, 'days') > 1;
- }
- });
- ;;
- var Scroller = FC.Scroller = Class.extend({
- el: null,
- scrollEl: null,
- overflowX: null,
- overflowY: null,
- constructor: function(options) {
- options = options || {};
- this.overflowX = options.overflowX || options.overflow || 'auto';
- this.overflowY = options.overflowY || options.overflow || 'auto';
- },
- render: function() {
- this.el = this.renderEl();
- this.applyOverflow();
- },
- renderEl: function() {
- return (this.scrollEl = $('<div class="fc-scroller"></div>'));
- },
-
- clear: function() {
- this.setHeight('auto');
- this.applyOverflow();
- },
- destroy: function() {
- this.el.remove();
- },
-
-
- applyOverflow: function() {
- this.scrollEl.css({
- 'overflow-x': this.overflowX,
- 'overflow-y': this.overflowY
- });
- },
-
-
-
- lockOverflow: function(scrollbarWidths) {
- var overflowX = this.overflowX;
- var overflowY = this.overflowY;
- scrollbarWidths = scrollbarWidths || this.getScrollbarWidths();
- if (overflowX === 'auto') {
- overflowX = (
- scrollbarWidths.top || scrollbarWidths.bottom ||
-
- this.scrollEl[0].scrollWidth - 1 > this.scrollEl[0].clientWidth
-
- ) ? 'scroll' : 'hidden';
- }
- if (overflowY === 'auto') {
- overflowY = (
- scrollbarWidths.left || scrollbarWidths.right ||
-
- this.scrollEl[0].scrollHeight - 1 > this.scrollEl[0].clientHeight
-
- ) ? 'scroll' : 'hidden';
- }
- this.scrollEl.css({ 'overflow-x': overflowX, 'overflow-y': overflowY });
- },
-
-
- setHeight: function(height) {
- this.scrollEl.height(height);
- },
- getScrollTop: function() {
- return this.scrollEl.scrollTop();
- },
- setScrollTop: function(top) {
- this.scrollEl.scrollTop(top);
- },
- getClientWidth: function() {
- return this.scrollEl[0].clientWidth;
- },
- getClientHeight: function() {
- return this.scrollEl[0].clientHeight;
- },
- getScrollbarWidths: function() {
- return getScrollbarWidths(this.scrollEl);
- }
- });
- ;;
- function Iterator(items) {
- this.items = items || [];
- }
- Iterator.prototype.proxyCall = function(methodName) {
- var args = Array.prototype.slice.call(arguments, 1);
- var results = [];
- this.items.forEach(function(item) {
- results.push(item[methodName].apply(item, args));
- });
- return results;
- };
- ;;
- function Toolbar(calendar, toolbarOptions) {
- var t = this;
-
- t.setToolbarOptions = setToolbarOptions;
- t.render = render;
- t.removeElement = removeElement;
- t.updateTitle = updateTitle;
- t.activateButton = activateButton;
- t.deactivateButton = deactivateButton;
- t.disableButton = disableButton;
- t.enableButton = enableButton;
- t.getViewsWithButtons = getViewsWithButtons;
- t.el = null;
-
- var el;
- var viewsWithButtons = [];
- var tm;
-
- function setToolbarOptions(newToolbarOptions) {
- toolbarOptions = newToolbarOptions;
- }
-
- function render() {
- var sections = toolbarOptions.layout;
- tm = calendar.options.theme ? 'ui' : 'fc';
- if (sections) {
- if (!el) {
- el = this.el = $("<div class='fc-toolbar "+ toolbarOptions.extraClasses + "'/>");
- }
- else {
- el.empty();
- }
- el.append(renderSection('left'))
- .append(renderSection('right'))
- .append(renderSection('center'))
- .append('<div class="fc-clear"/>');
- }
- else {
- removeElement();
- }
- }
- function removeElement() {
- if (el) {
- el.remove();
- el = t.el = null;
- }
- }
- function renderSection(position) {
- var sectionEl = $('<div class="fc-' + position + '"/>');
- var buttonStr = toolbarOptions.layout[position];
- if (buttonStr) {
- $.each(buttonStr.split(' '), function(i) {
- var groupChildren = $();
- var isOnlyButtons = true;
- var groupEl;
- $.each(this.split(','), function(j, buttonName) {
- var customButtonProps;
- var viewSpec;
- var buttonClick;
- var overrideText;
- var defaultText;
- var themeIcon;
- var normalIcon;
- var innerHtml;
- var classes;
- var button;
- if (buttonName == 'title') {
- groupChildren = groupChildren.add($('<h2> </h2>'));
- isOnlyButtons = false;
- }
- else {
- if ((customButtonProps = (calendar.options.customButtons || {})[buttonName])) {
- buttonClick = function(ev) {
- if (customButtonProps.click) {
- customButtonProps.click.call(button[0], ev);
- }
- };
- overrideText = '';
- defaultText = customButtonProps.text;
- }
- else if ((viewSpec = calendar.getViewSpec(buttonName))) {
- buttonClick = function() {
- calendar.changeView(buttonName);
- };
- viewsWithButtons.push(buttonName);
- overrideText = viewSpec.buttonTextOverride;
- defaultText = viewSpec.buttonTextDefault;
- }
- else if (calendar[buttonName]) {
- buttonClick = function() {
- calendar[buttonName]();
- };
- overrideText = (calendar.overrides.buttonText || {})[buttonName];
- defaultText = calendar.options.buttonText[buttonName];
- }
- if (buttonClick) {
- themeIcon =
- customButtonProps ?
- customButtonProps.themeIcon :
- calendar.options.themeButtonIcons[buttonName];
- normalIcon =
- customButtonProps ?
- customButtonProps.icon :
- calendar.options.buttonIcons[buttonName];
- if (overrideText) {
- innerHtml = htmlEscape(overrideText);
- }
- else if (themeIcon && calendar.options.theme) {
- innerHtml = "<span class='ui-icon ui-icon-" + themeIcon + "'></span>";
- }
- else if (normalIcon && !calendar.options.theme) {
- innerHtml = "<span class='fc-icon fc-icon-" + normalIcon + "'></span>";
- }
- else {
- innerHtml = htmlEscape(defaultText);
- }
- classes = [
- 'fc-' + buttonName + '-button',
- tm + '-button',
- tm + '-state-default'
- ];
- button = $(
- '<button type="button" class="' + classes.join(' ') + '">' +
- innerHtml +
- '</button>'
- )
- .click(function(ev) {
-
- if (!button.hasClass(tm + '-state-disabled')) {
- buttonClick(ev);
-
-
- if (
- button.hasClass(tm + '-state-active') ||
- button.hasClass(tm + '-state-disabled')
- ) {
- button.removeClass(tm + '-state-hover');
- }
- }
- })
- .mousedown(function() {
-
-
- button
- .not('.' + tm + '-state-active')
- .not('.' + tm + '-state-disabled')
- .addClass(tm + '-state-down');
- })
- .mouseup(function() {
-
- button.removeClass(tm + '-state-down');
- })
- .hover(
- function() {
-
-
- button
- .not('.' + tm + '-state-active')
- .not('.' + tm + '-state-disabled')
- .addClass(tm + '-state-hover');
- },
- function() {
-
- button
- .removeClass(tm + '-state-hover')
- .removeClass(tm + '-state-down');
- }
- );
- groupChildren = groupChildren.add(button);
- }
- }
- });
- if (isOnlyButtons) {
- groupChildren
- .first().addClass(tm + '-corner-left').end()
- .last().addClass(tm + '-corner-right').end();
- }
- if (groupChildren.length > 1) {
- groupEl = $('<div/>');
- if (isOnlyButtons) {
- groupEl.addClass('fc-button-group');
- }
- groupEl.append(groupChildren);
- sectionEl.append(groupEl);
- }
- else {
- sectionEl.append(groupChildren);
- }
- });
- }
- return sectionEl;
- }
- function updateTitle(text) {
- if (el) {
- el.find('h2').text(text);
- }
- }
- function activateButton(buttonName) {
- if (el) {
- el.find('.fc-' + buttonName + '-button')
- .addClass(tm + '-state-active');
- }
- }
- function deactivateButton(buttonName) {
- if (el) {
- el.find('.fc-' + buttonName + '-button')
- .removeClass(tm + '-state-active');
- }
- }
- function disableButton(buttonName) {
- if (el) {
- el.find('.fc-' + buttonName + '-button')
- .prop('disabled', true)
- .addClass(tm + '-state-disabled');
- }
- }
- function enableButton(buttonName) {
- if (el) {
- el.find('.fc-' + buttonName + '-button')
- .prop('disabled', false)
- .removeClass(tm + '-state-disabled');
- }
- }
- function getViewsWithButtons() {
- return viewsWithButtons;
- }
- }
- ;;
- var Calendar = FC.Calendar = Class.extend({
- dirDefaults: null,
- localeDefaults: null,
- overrides: null,
- dynamicOverrides: null,
- options: null,
- viewSpecCache: null,
- view: null,
- header: null,
- footer: null,
- loadingLevel: 0,
-
-
- constructor: Calendar_constructor,
-
- initialize: function() {
- },
-
-
- populateOptionsHash: function() {
- var locale, localeDefaults;
- var isRTL, dirDefaults;
- locale = firstDefined(
- this.dynamicOverrides.locale,
- this.overrides.locale
- );
- localeDefaults = localeOptionHash[locale];
- if (!localeDefaults) {
- locale = Calendar.defaults.locale;
- localeDefaults = localeOptionHash[locale] || {};
- }
- isRTL = firstDefined(
- this.dynamicOverrides.isRTL,
- this.overrides.isRTL,
- localeDefaults.isRTL,
- Calendar.defaults.isRTL
- );
- dirDefaults = isRTL ? Calendar.rtlDefaults : {};
- this.dirDefaults = dirDefaults;
- this.localeDefaults = localeDefaults;
- this.options = mergeOptions([
- Calendar.defaults,
- dirDefaults,
- localeDefaults,
- this.overrides,
- this.dynamicOverrides
- ]);
- populateInstanceComputableOptions(this.options);
- },
-
- getViewSpec: function(viewType) {
- var cache = this.viewSpecCache;
- return cache[viewType] || (cache[viewType] = this.buildViewSpec(viewType));
- },
-
-
- getUnitViewSpec: function(unit) {
- var viewTypes;
- var i;
- var spec;
- if ($.inArray(unit, intervalUnits) != -1) {
-
- viewTypes = this.header.getViewsWithButtons();
- $.each(FC.views, function(viewType) {
- viewTypes.push(viewType);
- });
- for (i = 0; i < viewTypes.length; i++) {
- spec = this.getViewSpec(viewTypes[i]);
- if (spec) {
- if (spec.singleUnit == unit) {
- return spec;
- }
- }
- }
- }
- },
-
- buildViewSpec: function(requestedViewType) {
- var viewOverrides = this.overrides.views || {};
- var specChain = [];
- var defaultsChain = [];
- var overridesChain = [];
- var viewType = requestedViewType;
- var spec;
- var overrides;
- var duration;
- var unit;
-
- while (viewType) {
- spec = fcViews[viewType];
- overrides = viewOverrides[viewType];
- viewType = null;
- if (typeof spec === 'function') {
- spec = { 'class': spec };
- }
- if (spec) {
- specChain.unshift(spec);
- defaultsChain.unshift(spec.defaults || {});
- duration = duration || spec.duration;
- viewType = viewType || spec.type;
- }
- if (overrides) {
- overridesChain.unshift(overrides);
- duration = duration || overrides.duration;
- viewType = viewType || overrides.type;
- }
- }
- spec = mergeProps(specChain);
- spec.type = requestedViewType;
- if (!spec['class']) {
- return false;
- }
- if (duration) {
- duration = moment.duration(duration);
- if (duration.valueOf()) {
- spec.duration = duration;
- unit = computeIntervalUnit(duration);
-
-
- if (duration.as(unit) === 1) {
- spec.singleUnit = unit;
- overridesChain.unshift(viewOverrides[unit] || {});
- }
- }
- }
- spec.defaults = mergeOptions(defaultsChain);
- spec.overrides = mergeOptions(overridesChain);
- this.buildViewSpecOptions(spec);
- this.buildViewSpecButtonText(spec, requestedViewType);
- return spec;
- },
-
- buildViewSpecOptions: function(spec) {
- spec.options = mergeOptions([
- Calendar.defaults,
- spec.defaults,
- this.dirDefaults,
- this.localeDefaults,
- this.overrides,
- spec.overrides,
- this.dynamicOverrides
- ]);
- populateInstanceComputableOptions(spec.options);
- },
-
- buildViewSpecButtonText: function(spec, requestedViewType) {
-
-
- function queryButtonText(options) {
- var buttonText = options.buttonText || {};
- return buttonText[requestedViewType] ||
-
- (spec.buttonTextKey ? buttonText[spec.buttonTextKey] : null) ||
-
- (spec.singleUnit ? buttonText[spec.singleUnit] : null);
- }
-
- spec.buttonTextOverride =
- queryButtonText(this.dynamicOverrides) ||
- queryButtonText(this.overrides) ||
- spec.overrides.buttonText;
-
- spec.buttonTextDefault =
- queryButtonText(this.localeDefaults) ||
- queryButtonText(this.dirDefaults) ||
- spec.defaults.buttonText ||
- queryButtonText(Calendar.defaults) ||
- (spec.duration ? this.humanizeDuration(spec.duration) : null) ||
- requestedViewType;
- },
-
- instantiateView: function(viewType) {
- var spec = this.getViewSpec(viewType);
- return new spec['class'](this, viewType, spec.options, spec.duration);
- },
-
- isValidViewType: function(viewType) {
- return Boolean(this.getViewSpec(viewType));
- },
-
- pushLoading: function() {
- if (!(this.loadingLevel++)) {
- this.publiclyTrigger('loading', null, true, this.view);
- }
- },
-
- popLoading: function() {
- if (!(--this.loadingLevel)) {
- this.publiclyTrigger('loading', null, false, this.view);
- }
- },
-
- buildSelectSpan: function(zonedStartInput, zonedEndInput) {
- var start = this.moment(zonedStartInput).stripZone();
- var end;
- if (zonedEndInput) {
- end = this.moment(zonedEndInput).stripZone();
- }
- else if (start.hasTime()) {
- end = start.clone().add(this.defaultTimedEventDuration);
- }
- else {
- end = start.clone().add(this.defaultAllDayEventDuration);
- }
- return { start: start, end: end };
- }
- });
- Calendar.mixin(EmitterMixin);
- function Calendar_constructor(element, overrides) {
- var t = this;
-
-
- t.render = render;
- t.destroy = destroy;
- t.rerenderEvents = rerenderEvents;
- t.changeView = renderView;
- t.select = select;
- t.unselect = unselect;
- t.prev = prev;
- t.next = next;
- t.prevYear = prevYear;
- t.nextYear = nextYear;
- t.today = today;
- t.gotoDate = gotoDate;
- t.incrementDate = incrementDate;
- t.zoomTo = zoomTo;
- t.getDate = getDate;
- t.getCalendar = getCalendar;
- t.getView = getView;
- t.option = option;
- t.publiclyTrigger = publiclyTrigger;
-
-
- t.dynamicOverrides = {};
- t.viewSpecCache = {};
- t.optionHandlers = {};
- t.overrides = $.extend({}, overrides);
- t.populateOptionsHash();
-
-
-
- var localeData;
-
-
- t.bindOptions([
- 'locale', 'monthNames', 'monthNamesShort', 'dayNames', 'dayNamesShort', 'firstDay', 'weekNumberCalculation'
- ], function(locale, monthNames, monthNamesShort, dayNames, dayNamesShort, firstDay, weekNumberCalculation) {
-
- if (weekNumberCalculation === 'iso') {
- weekNumberCalculation = 'ISO';
- }
- localeData = createObject(
- getMomentLocaleData(locale)
- );
- if (monthNames) {
- localeData._months = monthNames;
- }
- if (monthNamesShort) {
- localeData._monthsShort = monthNamesShort;
- }
- if (dayNames) {
- localeData._weekdays = dayNames;
- }
- if (dayNamesShort) {
- localeData._weekdaysShort = dayNamesShort;
- }
- if (firstDay == null && weekNumberCalculation === 'ISO') {
- firstDay = 1;
- }
- if (firstDay != null) {
- var _week = createObject(localeData._week);
- _week.dow = firstDay;
- localeData._week = _week;
- }
- if (
- weekNumberCalculation === 'ISO' ||
- weekNumberCalculation === 'local' ||
- typeof weekNumberCalculation === 'function'
- ) {
- localeData._fullCalendar_weekCalc = weekNumberCalculation;
- }
-
-
- if (date) {
- localizeMoment(date);
- }
- });
-
-
- t.defaultAllDayEventDuration = moment.duration(t.options.defaultAllDayEventDuration);
- t.defaultTimedEventDuration = moment.duration(t.options.defaultTimedEventDuration);
-
-
- t.moment = function() {
- var mom;
- if (t.options.timezone === 'local') {
- mom = FC.moment.apply(null, arguments);
-
- if (mom.hasTime()) {
- mom.local();
- }
- }
- else if (t.options.timezone === 'UTC') {
- mom = FC.moment.utc.apply(null, arguments);
- }
- else {
- mom = FC.moment.parseZone.apply(null, arguments);
- }
- localizeMoment(mom);
- return mom;
- };
-
- function localizeMoment(mom) {
- mom._locale = localeData;
- }
- t.localizeMoment = localizeMoment;
-
-
- t.getIsAmbigTimezone = function() {
- return t.options.timezone !== 'local' && t.options.timezone !== 'UTC';
- };
-
- t.applyTimezone = function(date) {
- if (!date.hasTime()) {
- return date.clone();
- }
- var zonedDate = t.moment(date.toArray());
- var timeAdjust = date.time() - zonedDate.time();
- var adjustedZonedDate;
-
- if (timeAdjust) {
- adjustedZonedDate = zonedDate.clone().add(timeAdjust);
- if (date.time() - adjustedZonedDate.time() === 0) {
- zonedDate = adjustedZonedDate;
- }
- }
- return zonedDate;
- };
-
-
- t.getNow = function() {
- var now = t.options.now;
- if (typeof now === 'function') {
- now = now();
- }
- return t.moment(now).stripZone();
- };
-
- t.getEventEnd = function(event) {
- if (event.end) {
- return event.end.clone();
- }
- else {
- return t.getDefaultEventEnd(event.allDay, event.start);
- }
- };
-
-
- t.getDefaultEventEnd = function(allDay, zonedStart) {
- var end = zonedStart.clone();
- if (allDay) {
- end.stripTime().add(t.defaultAllDayEventDuration);
- }
- else {
- end.add(t.defaultTimedEventDuration);
- }
- if (t.getIsAmbigTimezone()) {
- end.stripZone();
- }
- return end;
- };
-
-
- t.humanizeDuration = function(duration) {
- return duration.locale(t.options.locale).humanize();
- };
-
-
- EventManager.call(t);
-
-
- var _element = element[0];
- var toolbarsManager;
- var header;
- var footer;
- var content;
- var tm;
- var currentView;
- var viewsByType = {};
- var suggestedViewHeight;
- var windowResizeProxy;
- var ignoreWindowResize = 0;
- var date;
-
-
-
- if (t.options.defaultDate != null) {
- date = t.moment(t.options.defaultDate).stripZone();
- }
- else {
- date = t.getNow();
- }
- function render() {
- if (!content) {
- initialRender();
- }
- else if (elementVisible()) {
-
- calcSize();
- renderView();
- }
- }
- function initialRender() {
- element.addClass('fc');
-
- element.on('click.fc', 'a[data-goto]', function(ev) {
- var anchorEl = $(this);
- var gotoOptions = anchorEl.data('goto');
- var date = t.moment(gotoOptions.date);
- var viewType = gotoOptions.type;
-
- var customAction = currentView.opt('navLink' + capitaliseFirstLetter(viewType) + 'Click');
- if (typeof customAction === 'function') {
- customAction(date, ev);
- }
- else {
- if (typeof customAction === 'string') {
- viewType = customAction;
- }
- zoomTo(date, viewType);
- }
- });
-
- t.bindOption('theme', function(theme) {
- tm = theme ? 'ui' : 'fc';
- element.toggleClass('ui-widget', theme);
- element.toggleClass('fc-unthemed', !theme);
- });
-
-
- t.bindOptions([ 'isRTL', 'locale' ], function(isRTL) {
- element.toggleClass('fc-ltr', !isRTL);
- element.toggleClass('fc-rtl', isRTL);
- });
- content = $("<div class='fc-view-container'/>").prependTo(element);
- var toolbars = buildToolbars();
- toolbarsManager = new Iterator(toolbars);
- header = t.header = toolbars[0];
- footer = t.footer = toolbars[1];
- renderHeader();
- renderFooter();
- renderView(t.options.defaultView);
- if (t.options.handleWindowResize) {
- windowResizeProxy = debounce(windowResize, t.options.windowResizeDelay);
- $(window).resize(windowResizeProxy);
- }
- }
- function destroy() {
- if (currentView) {
- currentView.removeElement();
-
-
- }
- toolbarsManager.proxyCall('removeElement');
- content.remove();
- element.removeClass('fc fc-ltr fc-rtl fc-unthemed ui-widget');
- element.off('.fc');
- if (windowResizeProxy) {
- $(window).unbind('resize', windowResizeProxy);
- }
- }
- function elementVisible() {
- return element.is(':visible');
- }
-
-
-
-
-
- function renderView(viewType, forcedScroll) {
- ignoreWindowResize++;
- var needsClearView = currentView && viewType && currentView.type !== viewType;
-
- if (needsClearView) {
- freezeContentHeight();
- clearView();
- }
-
- if (!currentView && viewType) {
- currentView = t.view =
- viewsByType[viewType] ||
- (viewsByType[viewType] = t.instantiateView(viewType));
- currentView.setElement(
- $("<div class='fc-view fc-" + viewType + "-view' />").appendTo(content)
- );
- toolbarsManager.proxyCall('activateButton', viewType);
- }
- if (currentView) {
-
- date = currentView.massageCurrentDate(date);
-
- if (
- !currentView.isDateSet ||
- !(
- date >= currentView.intervalStart &&
- date < currentView.intervalEnd
- )
- ) {
- if (elementVisible()) {
- if (forcedScroll) {
- currentView.captureInitialScroll(forcedScroll);
- }
- currentView.setDate(date, forcedScroll);
- if (forcedScroll) {
- currentView.releaseScroll();
- }
-
-
- updateToolbarsTodayButton();
- }
- }
- }
- if (needsClearView) {
- thawContentHeight();
- }
- ignoreWindowResize--;
- }
-
-
- function clearView() {
- toolbarsManager.proxyCall('deactivateButton', currentView.type);
- currentView.removeElement();
- currentView = t.view = null;
- }
-
-
-
- function reinitView() {
- ignoreWindowResize++;
- freezeContentHeight();
- var viewType = currentView.type;
- var scrollState = currentView.queryScroll();
- clearView();
- calcSize();
- renderView(viewType, scrollState);
- thawContentHeight();
- ignoreWindowResize--;
- }
-
-
- t.getSuggestedViewHeight = function() {
- if (suggestedViewHeight === undefined) {
- calcSize();
- }
- return suggestedViewHeight;
- };
- t.isHeightAuto = function() {
- return t.options.contentHeight === 'auto' || t.options.height === 'auto';
- };
- function updateSize(shouldRecalc) {
- if (elementVisible()) {
- if (shouldRecalc) {
- _calcSize();
- }
- ignoreWindowResize++;
- currentView.updateSize(true);
- ignoreWindowResize--;
- return true;
- }
- }
- function calcSize() {
- if (elementVisible()) {
- _calcSize();
- }
- }
- function _calcSize() {
- var contentHeightInput = t.options.contentHeight;
- var heightInput = t.options.height;
- if (typeof contentHeightInput === 'number') {
- suggestedViewHeight = contentHeightInput;
- }
- else if (typeof contentHeightInput === 'function') {
- suggestedViewHeight = contentHeightInput();
- }
- else if (typeof heightInput === 'number') {
- suggestedViewHeight = heightInput - queryToolbarsHeight();
- }
- else if (typeof heightInput === 'function') {
- suggestedViewHeight = heightInput() - queryToolbarsHeight();
- }
- else if (heightInput === 'parent') {
- suggestedViewHeight = element.parent().height() - queryToolbarsHeight();
- }
- else {
- suggestedViewHeight = Math.round(content.width() / Math.max(t.options.aspectRatio, .5));
- }
- }
- function queryToolbarsHeight() {
- return toolbarsManager.items.reduce(function(accumulator, toolbar) {
- var toolbarHeight = toolbar.el ? toolbar.el.outerHeight(true) : 0;
- return accumulator + toolbarHeight;
- }, 0);
- }
- function windowResize(ev) {
- if (
- !ignoreWindowResize &&
- ev.target === window &&
- currentView.start
- ) {
- if (updateSize(true)) {
- currentView.publiclyTrigger('windowResize', _element);
- }
- }
- }
-
- function rerenderEvents() {
- if (elementVisible()) {
- t.reportEventChange();
- }
- }
-
- function buildToolbars() {
- return [
- new Toolbar(t, computeHeaderOptions()),
- new Toolbar(t, computeFooterOptions())
- ];
- }
- function computeHeaderOptions() {
- return {
- extraClasses: 'fc-header-toolbar',
- layout: t.options.header
- };
- }
- function computeFooterOptions() {
- return {
- extraClasses: 'fc-footer-toolbar',
- layout: t.options.footer
- };
- }
-
- function renderHeader() {
- header.setToolbarOptions(computeHeaderOptions());
- header.render();
- if (header.el) {
- element.prepend(header.el);
- }
- }
-
- function renderFooter() {
- footer.setToolbarOptions(computeFooterOptions());
- footer.render();
- if (footer.el) {
- element.append(footer.el);
- }
- }
- t.setToolbarsTitle = function(title) {
- toolbarsManager.proxyCall('updateTitle', title);
- };
- function updateToolbarsTodayButton() {
- var now = t.getNow();
- if (now >= currentView.intervalStart && now < currentView.intervalEnd) {
- toolbarsManager.proxyCall('disableButton', 'today');
- }
- else {
- toolbarsManager.proxyCall('enableButton', 'today');
- }
- }
-
-
- function select(zonedStartInput, zonedEndInput) {
- currentView.select(
- t.buildSelectSpan.apply(t, arguments)
- );
- }
- function unselect() {
- if (currentView) {
- currentView.unselect();
- }
- }
-
- function prev() {
- date = currentView.computePrevDate(date);
- renderView();
- }
- function next() {
- date = currentView.computeNextDate(date);
- renderView();
- }
- function prevYear() {
- date.add(-1, 'years');
- renderView();
- }
- function nextYear() {
- date.add(1, 'years');
- renderView();
- }
- function today() {
- date = t.getNow();
- renderView();
- }
- function gotoDate(zonedDateInput) {
- date = t.moment(zonedDateInput).stripZone();
- renderView();
- }
- function incrementDate(delta) {
- date.add(moment.duration(delta));
- renderView();
- }
-
-
- function zoomTo(newDate, viewType) {
- var spec;
- viewType = viewType || 'day';
- spec = t.getViewSpec(viewType) || t.getUnitViewSpec(viewType);
- date = newDate.clone();
- renderView(spec ? spec.type : null);
- }
-
- function getDate() {
- return t.applyTimezone(date);
- }
-
- t.freezeContentHeight = freezeContentHeight;
- t.thawContentHeight = thawContentHeight;
- var freezeContentHeightDepth = 0;
- function freezeContentHeight() {
- if (!(freezeContentHeightDepth++)) {
- content.css({
- width: '100%',
- height: content.height(),
- overflow: 'hidden'
- });
- }
- }
- function thawContentHeight() {
- if (!(--freezeContentHeightDepth)) {
- content.css({
- width: '',
- height: '',
- overflow: ''
- });
- }
- }
-
- function getCalendar() {
- return t;
- }
- function getView() {
- return currentView;
- }
- function option(name, value) {
- var newOptionHash;
- if (typeof name === 'string') {
- if (value === undefined) {
- return t.options[name];
- }
- else {
- newOptionHash = {};
- newOptionHash[name] = value;
- setOptions(newOptionHash);
- }
- }
- else if (typeof name === 'object') {
- setOptions(name);
- }
- }
- function setOptions(newOptionHash) {
- var optionCnt = 0;
- var optionName;
- for (optionName in newOptionHash) {
- t.dynamicOverrides[optionName] = newOptionHash[optionName];
- }
- t.viewSpecCache = {};
- t.populateOptionsHash();
-
- for (optionName in newOptionHash) {
- t.triggerOptionHandlers(optionName);
- optionCnt++;
- }
-
-
- if (optionCnt === 1) {
- if (optionName === 'height' || optionName === 'contentHeight' || optionName === 'aspectRatio') {
- updateSize(true);
- return;
- }
- else if (optionName === 'defaultDate') {
- return;
- }
- else if (optionName === 'businessHours') {
- if (currentView) {
- currentView.unrenderBusinessHours();
- currentView.renderBusinessHours();
- }
- return;
- }
- else if (optionName === 'timezone') {
- t.rezoneArrayEventSources();
- t.refetchEvents();
- return;
- }
- }
-
- renderHeader();
- renderFooter();
- viewsByType = {};
- reinitView();
- }
- function publiclyTrigger(name, thisObj) {
- var args = Array.prototype.slice.call(arguments, 2);
- thisObj = thisObj || _element;
- this.triggerWith(name, thisObj, args);
- if (t.options[name]) {
- return t.options[name].apply(thisObj, args);
- }
- }
- t.initialize();
- }
- ;;
- Calendar.mixin({
-
-
-
-
-
-
- optionHandlers: null,
-
-
- bindOption: function(optionName, handlerFunc) {
- this.bindOptions([ optionName ], handlerFunc);
- },
-
-
- bindOptions: function(optionNames, handlerFunc) {
- var handlerObj = { func: handlerFunc, names: optionNames };
- var i;
- for (i = 0; i < optionNames.length; i++) {
- this.registerOptionHandlerObj(optionNames[i], handlerObj);
- }
- this.triggerOptionHandlerObj(handlerObj);
- },
-
- registerOptionHandlerObj: function(optionName, handlerObj) {
- (this.optionHandlers[optionName] || (this.optionHandlers[optionName] = []))
- .push(handlerObj);
- },
-
- triggerOptionHandlers: function(optionName) {
- var handlerObjs = this.optionHandlers[optionName] || [];
- var i;
- for (i = 0; i < handlerObjs.length; i++) {
- this.triggerOptionHandlerObj(handlerObjs[i]);
- }
- },
-
- triggerOptionHandlerObj: function(handlerObj) {
- var optionNames = handlerObj.names;
- var optionValues = [];
- var i;
- for (i = 0; i < optionNames.length; i++) {
- optionValues.push(this.options[optionNames[i]]);
- }
- handlerObj.func.apply(this, optionValues);
- }
- });
- ;;
- Calendar.defaults = {
- titleRangeSeparator: ' \u2013 ',
- monthYearFormat: 'MMMM YYYY',
- defaultTimedEventDuration: '02:00:00',
- defaultAllDayEventDuration: { days: 1 },
- forceEventDuration: false,
- nextDayThreshold: '09:00:00',
-
- defaultView: 'month',
- aspectRatio: 1.35,
- header: {
- left: 'title',
- center: '',
- right: 'today prev,next'
- },
- weekends: true,
- weekNumbers: false,
- weekNumberTitle: 'W',
- weekNumberCalculation: 'local',
-
-
-
- scrollTime: '06:00:00',
-
-
- lazyFetching: true,
- startParam: 'start',
- endParam: 'end',
- timezoneParam: 'timezone',
- timezone: false,
-
-
- isRTL: false,
- buttonText: {
- prev: "prev",
- next: "next",
- prevYear: "prev year",
- nextYear: "next year",
- year: 'year',
- today: 'today',
- month: 'month',
- week: 'week',
- day: 'day'
- },
- buttonIcons: {
- prev: 'left-single-arrow',
- next: 'right-single-arrow',
- prevYear: 'left-double-arrow',
- nextYear: 'right-double-arrow'
- },
- allDayText: 'all-day',
-
-
- theme: false,
- themeButtonIcons: {
- prev: 'circle-triangle-w',
- next: 'circle-triangle-e',
- prevYear: 'seek-prev',
- nextYear: 'seek-next'
- },
-
- dragOpacity: .75,
- dragRevertDuration: 500,
- dragScroll: true,
-
-
- unselectAuto: true,
-
- dropAccept: '*',
- eventOrder: 'title',
-
- eventLimit: false,
- eventLimitText: 'more',
- eventLimitClick: 'popover',
- dayPopoverFormat: 'LL',
-
- handleWindowResize: true,
- windowResizeDelay: 100,
- longPressDelay: 1000
-
- };
- Calendar.englishDefaults = {
- dayPopoverFormat: 'dddd, MMMM D'
- };
- Calendar.rtlDefaults = {
- header: {
- left: 'next,prev today',
- center: '',
- right: 'title'
- },
- buttonIcons: {
- prev: 'right-single-arrow',
- next: 'left-single-arrow',
- prevYear: 'right-double-arrow',
- nextYear: 'left-double-arrow'
- },
- themeButtonIcons: {
- prev: 'circle-triangle-e',
- next: 'circle-triangle-w',
- nextYear: 'seek-prev',
- prevYear: 'seek-next'
- }
- };
- ;;
- var localeOptionHash = FC.locales = {};
- FC.datepickerLocale = function(localeCode, dpLocaleCode, dpOptions) {
-
- var fcOptions = localeOptionHash[localeCode] || (localeOptionHash[localeCode] = {});
-
- fcOptions.isRTL = dpOptions.isRTL;
- fcOptions.weekNumberTitle = dpOptions.weekHeader;
-
- $.each(dpComputableOptions, function(name, func) {
- fcOptions[name] = func(dpOptions);
- });
-
- if ($.datepicker) {
-
-
-
-
- $.datepicker.regional[dpLocaleCode] =
- $.datepicker.regional[localeCode] =
- dpOptions;
-
- $.datepicker.regional.en = $.datepicker.regional[''];
-
- $.datepicker.setDefaults(dpOptions);
- }
- };
- FC.locale = function(localeCode, newFcOptions) {
- var fcOptions;
- var momOptions;
-
- fcOptions = localeOptionHash[localeCode] || (localeOptionHash[localeCode] = {});
-
- if (newFcOptions) {
- fcOptions = localeOptionHash[localeCode] = mergeOptions([ fcOptions, newFcOptions ]);
- }
-
-
-
- momOptions = getMomentLocaleData(localeCode);
- $.each(momComputableOptions, function(name, func) {
- if (fcOptions[name] == null) {
- fcOptions[name] = func(momOptions, fcOptions);
- }
- });
-
- Calendar.defaults.locale = localeCode;
- };
- var dpComputableOptions = {
- buttonText: function(dpOptions) {
- return {
-
- prev: stripHtmlEntities(dpOptions.prevText),
- next: stripHtmlEntities(dpOptions.nextText),
- today: stripHtmlEntities(dpOptions.currentText)
- };
- },
-
- monthYearFormat: function(dpOptions) {
- return dpOptions.showMonthAfterYear ?
- 'YYYY[' + dpOptions.yearSuffix + '] MMMM' :
- 'MMMM YYYY[' + dpOptions.yearSuffix + ']';
- }
- };
- var momComputableOptions = {
-
- dayOfMonthFormat: function(momOptions, fcOptions) {
- var format = momOptions.longDateFormat('l');
-
- format = format.replace(/^Y+[^\w\s]*|[^\w\s]*Y+$/g, '');
- if (fcOptions.isRTL) {
- format += ' ddd';
- }
- else {
- format = 'ddd ' + format;
- }
- return format;
- },
-
- mediumTimeFormat: function(momOptions) {
- return momOptions.longDateFormat('LT')
- .replace(/\s*a$/i, 'a');
- },
-
- smallTimeFormat: function(momOptions) {
- return momOptions.longDateFormat('LT')
- .replace(':mm', '(:mm)')
- .replace(/(\Wmm)$/, '($1)')
- .replace(/\s*a$/i, 'a');
- },
-
- extraSmallTimeFormat: function(momOptions) {
- return momOptions.longDateFormat('LT')
- .replace(':mm', '(:mm)')
- .replace(/(\Wmm)$/, '($1)')
- .replace(/\s*a$/i, 't');
- },
-
- hourFormat: function(momOptions) {
- return momOptions.longDateFormat('LT')
- .replace(':mm', '')
- .replace(/(\Wmm)$/, '')
- .replace(/\s*a$/i, 'a');
- },
-
- noMeridiemTimeFormat: function(momOptions) {
- return momOptions.longDateFormat('LT')
- .replace(/\s*a$/i, '');
- }
- };
- var instanceComputableOptions = {
-
- smallDayDateFormat: function(options) {
- return options.isRTL ?
- 'D dd' :
- 'dd D';
- },
-
- weekFormat: function(options) {
- return options.isRTL ?
- 'w[ ' + options.weekNumberTitle + ']' :
- '[' + options.weekNumberTitle + ' ]w';
- },
-
- smallWeekFormat: function(options) {
- return options.isRTL ?
- 'w[' + options.weekNumberTitle + ']' :
- '[' + options.weekNumberTitle + ']w';
- }
- };
- function populateInstanceComputableOptions(options) {
- $.each(instanceComputableOptions, function(name, func) {
- if (options[name] == null) {
- options[name] = func(options);
- }
- });
- }
- function getMomentLocaleData(localeCode) {
- return moment.localeData(localeCode) || moment.localeData('en');
- }
- FC.locale('en', Calendar.englishDefaults);
- ;;
- FC.sourceNormalizers = [];
- FC.sourceFetchers = [];
- var ajaxDefaults = {
- dataType: 'json',
- cache: false
- };
- var eventGUID = 1;
- function EventManager() {
- var t = this;
-
- t.requestEvents = requestEvents;
- t.reportEventChange = reportEventChange;
- t.isFetchNeeded = isFetchNeeded;
- t.fetchEvents = fetchEvents;
- t.fetchEventSources = fetchEventSources;
- t.refetchEvents = refetchEvents;
- t.refetchEventSources = refetchEventSources;
- t.getEventSources = getEventSources;
- t.getEventSourceById = getEventSourceById;
- t.addEventSource = addEventSource;
- t.removeEventSource = removeEventSource;
- t.removeEventSources = removeEventSources;
- t.updateEvent = updateEvent;
- t.updateEvents = updateEvents;
- t.renderEvent = renderEvent;
- t.renderEvents = renderEvents;
- t.removeEvents = removeEvents;
- t.clientEvents = clientEvents;
- t.mutateEvent = mutateEvent;
- t.normalizeEventDates = normalizeEventDates;
- t.normalizeEventTimes = normalizeEventTimes;
-
- var stickySource = { events: [] };
- var sources = [ stickySource ];
- var rangeStart, rangeEnd;
- var pendingSourceCnt = 0;
- var cache = [];
- var prunedCache;
- $.each(
- (t.options.events ? [ t.options.events ] : []).concat(t.options.eventSources || []),
- function(i, sourceInput) {
- var source = buildEventSource(sourceInput);
- if (source) {
- sources.push(source);
- }
- }
- );
- function requestEvents(start, end) {
- if (!t.options.lazyFetching || isFetchNeeded(start, end)) {
- return fetchEvents(start, end);
- }
- else {
- return Promise.resolve(prunedCache);
- }
- }
- function reportEventChange() {
- prunedCache = filterEventsWithinRange(cache);
- t.trigger('eventsReset', prunedCache);
- }
- function filterEventsWithinRange(events) {
- var filteredEvents = [];
- var i, event;
- for (i = 0; i < events.length; i++) {
- event = events[i];
- if (
- event.start.clone().stripZone() < rangeEnd &&
- t.getEventEnd(event).stripZone() > rangeStart
- ) {
- filteredEvents.push(event);
- }
- }
- return filteredEvents;
- }
- t.getEventCache = function() {
- return cache;
- };
- t.getPrunedEventCache = function() {
- return prunedCache;
- };
-
-
- function isFetchNeeded(start, end) {
- return !rangeStart ||
- start < rangeStart || end > rangeEnd;
- }
- function fetchEvents(start, end) {
- rangeStart = start;
- rangeEnd = end;
- return refetchEvents();
- }
-
- function refetchEvents() {
- return fetchEventSources(sources, 'reset');
- }
-
- function refetchEventSources(matchInputs) {
- return fetchEventSources(getEventSourcesByMatchArray(matchInputs));
- }
-
-
- function fetchEventSources(specificSources, specialFetchType) {
- var i, source;
- if (specialFetchType === 'reset') {
- cache = [];
- }
- else if (specialFetchType !== 'add') {
- cache = excludeEventsBySources(cache, specificSources);
- }
- for (i = 0; i < specificSources.length; i++) {
- source = specificSources[i];
-
- if (source._status !== 'pending') {
- pendingSourceCnt++;
- }
- source._fetchId = (source._fetchId || 0) + 1;
- source._status = 'pending';
- }
- for (i = 0; i < specificSources.length; i++) {
- source = specificSources[i];
- tryFetchEventSource(source, source._fetchId);
- }
- if (pendingSourceCnt) {
- return new Promise(function(resolve) {
- t.one('eventsReceived', resolve);
- });
- }
- else {
- return Promise.resolve(prunedCache);
- }
- }
-
-
- function tryFetchEventSource(source, fetchId) {
- _fetchEventSource(source, function(eventInputs) {
- var isArraySource = $.isArray(source.events);
- var i, eventInput;
- var abstractEvent;
- if (
-
-
- fetchId === source._fetchId &&
-
- source._status !== 'rejected'
- ) {
- source._status = 'resolved';
- if (eventInputs) {
- for (i = 0; i < eventInputs.length; i++) {
- eventInput = eventInputs[i];
- if (isArraySource) {
- abstractEvent = eventInput;
- }
- else {
- abstractEvent = buildEventFromInput(eventInput, source);
- }
- if (abstractEvent) {
- cache.push.apply(
- cache,
- expandEvent(abstractEvent)
- );
- }
- }
- }
- decrementPendingSourceCnt();
- }
- });
- }
- function rejectEventSource(source) {
- var wasPending = source._status === 'pending';
- source._status = 'rejected';
- if (wasPending) {
- decrementPendingSourceCnt();
- }
- }
- function decrementPendingSourceCnt() {
- pendingSourceCnt--;
- if (!pendingSourceCnt) {
- reportEventChange(cache);
- t.trigger('eventsReceived', prunedCache);
- }
- }
- function _fetchEventSource(source, callback) {
- var i;
- var fetchers = FC.sourceFetchers;
- var res;
- for (i=0; i<fetchers.length; i++) {
- res = fetchers[i].call(
- t,
- source,
- rangeStart.clone(),
- rangeEnd.clone(),
- t.options.timezone,
- callback
- );
- if (res === true) {
-
- return;
- }
- else if (typeof res == 'object') {
-
- _fetchEventSource(res, callback);
- return;
- }
- }
- var events = source.events;
- if (events) {
- if ($.isFunction(events)) {
- t.pushLoading();
- events.call(
- t,
- rangeStart.clone(),
- rangeEnd.clone(),
- t.options.timezone,
- function(events) {
- callback(events);
- t.popLoading();
- }
- );
- }
- else if ($.isArray(events)) {
- callback(events);
- }
- else {
- callback();
- }
- }else{
- var url = source.url;
- if (url) {
- var success = source.success;
- var error = source.error;
- var complete = source.complete;
-
- var customData;
- if ($.isFunction(source.data)) {
-
- customData = source.data();
- }
- else {
-
- customData = source.data;
- }
-
-
- var data = $.extend({}, customData || {});
- var startParam = firstDefined(source.startParam, t.options.startParam);
- var endParam = firstDefined(source.endParam, t.options.endParam);
- var timezoneParam = firstDefined(source.timezoneParam, t.options.timezoneParam);
- if (startParam) {
- data[startParam] = rangeStart.format();
- }
- if (endParam) {
- data[endParam] = rangeEnd.format();
- }
- if (t.options.timezone && t.options.timezone != 'local') {
- data[timezoneParam] = t.options.timezone;
- }
- t.pushLoading();
- $.ajax($.extend({}, ajaxDefaults, source, {
- data: data,
- success: function(events) {
- events = events || [];
- var res = applyAll(success, this, arguments);
- if ($.isArray(res)) {
- events = res;
- }
- callback(events);
- },
- error: function() {
- applyAll(error, this, arguments);
- callback();
- },
- complete: function() {
- applyAll(complete, this, arguments);
- t.popLoading();
- }
- }));
- }else{
- callback();
- }
- }
- }
-
- function addEventSource(sourceInput) {
- var source = buildEventSource(sourceInput);
- if (source) {
- sources.push(source);
- fetchEventSources([ source ], 'add');
- }
- }
- function buildEventSource(sourceInput) {
- var normalizers = FC.sourceNormalizers;
- var source;
- var i;
- if ($.isFunction(sourceInput) || $.isArray(sourceInput)) {
- source = { events: sourceInput };
- }
- else if (typeof sourceInput === 'string') {
- source = { url: sourceInput };
- }
- else if (typeof sourceInput === 'object') {
- source = $.extend({}, sourceInput);
- }
- if (source) {
-
- if (source.className) {
- if (typeof source.className === 'string') {
- source.className = source.className.split(/\s+/);
- }
-
- }
- else {
- source.className = [];
- }
-
- if ($.isArray(source.events)) {
- source.origArray = source.events;
- source.events = $.map(source.events, function(eventInput) {
- return buildEventFromInput(eventInput, source);
- });
- }
- for (i=0; i<normalizers.length; i++) {
- normalizers[i].call(t, source);
- }
- return source;
- }
- }
- function removeEventSource(matchInput) {
- removeSpecificEventSources(
- getEventSourcesByMatch(matchInput)
- );
- }
-
- function removeEventSources(matchInputs) {
- if (matchInputs == null) {
- removeSpecificEventSources(sources, true);
- }
- else {
- removeSpecificEventSources(
- getEventSourcesByMatchArray(matchInputs)
- );
- }
- }
- function removeSpecificEventSources(targetSources, isAll) {
- var i;
-
- for (i = 0; i < targetSources.length; i++) {
- rejectEventSource(targetSources[i]);
- }
- if (isAll) {
- sources = [];
- cache = [];
- }
- else {
-
- sources = $.grep(sources, function(source) {
- for (i = 0; i < targetSources.length; i++) {
- if (source === targetSources[i]) {
- return false;
- }
- }
- return true;
- });
- cache = excludeEventsBySources(cache, targetSources);
- }
- reportEventChange();
- }
- function getEventSources() {
- return sources.slice(1);
- }
- function getEventSourceById(id) {
- return $.grep(sources, function(source) {
- return source.id && source.id === id;
- })[0];
- }
-
- function getEventSourcesByMatchArray(matchInputs) {
-
- if (!matchInputs) {
- matchInputs = [];
- }
- else if (!$.isArray(matchInputs)) {
- matchInputs = [ matchInputs ];
- }
- var matchingSources = [];
- var i;
-
- for (i = 0; i < matchInputs.length; i++) {
- matchingSources.push.apply(
- matchingSources,
- getEventSourcesByMatch(matchInputs[i])
- );
- }
- return matchingSources;
- }
-
-
- function getEventSourcesByMatch(matchInput) {
- var i, source;
-
- for (i = 0; i < sources.length; i++) {
- source = sources[i];
- if (source === matchInput) {
- return [ source ];
- }
- }
-
- source = getEventSourceById(matchInput);
- if (source) {
- return [ source ];
- }
- return $.grep(sources, function(source) {
- return isSourcesEquivalent(matchInput, source);
- });
- }
- function isSourcesEquivalent(source1, source2) {
- return source1 && source2 && getSourcePrimitive(source1) == getSourcePrimitive(source2);
- }
- function getSourcePrimitive(source) {
- return (
- (typeof source === 'object') ?
- (source.origArray || source.googleCalendarId || source.url || source.events) :
- null
- ) ||
- source;
- }
-
-
- function excludeEventsBySources(specificEvents, specificSources) {
- return $.grep(specificEvents, function(event) {
- for (var i = 0; i < specificSources.length; i++) {
- if (event.source === specificSources[i]) {
- return false;
- }
- }
- return true;
- });
- }
-
-
- function updateEvent(event) {
- updateEvents([ event ]);
- }
-
- function updateEvents(events) {
- var i, event;
- for (i = 0; i < events.length; i++) {
- event = events[i];
-
- event.start = t.moment(event.start);
- if (event.end) {
- event.end = t.moment(event.end);
- }
- else {
- event.end = null;
- }
- mutateEvent(event, getMiscEventProps(event));
- }
- reportEventChange();
- }
-
- function getMiscEventProps(event) {
- var props = {};
- $.each(event, function(name, val) {
- if (isMiscEventPropName(name)) {
- if (val !== undefined && isAtomic(val)) {
- props[name] = val;
- }
- }
- });
- return props;
- }
-
- function isMiscEventPropName(name) {
- return !/^_|^(id|allDay|start|end)$/.test(name);
- }
-
- function renderEvent(eventInput, stick) {
- return renderEvents([ eventInput ], stick);
- }
-
- function renderEvents(eventInputs, stick) {
- var renderedEvents = [];
- var renderableEvents;
- var abstractEvent;
- var i, j, event;
- for (i = 0; i < eventInputs.length; i++) {
- abstractEvent = buildEventFromInput(eventInputs[i]);
- if (abstractEvent) {
- renderableEvents = expandEvent(abstractEvent);
- for (j = 0; j < renderableEvents.length; j++) {
- event = renderableEvents[j];
- if (!event.source) {
- if (stick) {
- stickySource.events.push(event);
- event.source = stickySource;
- }
- cache.push(event);
- }
- }
- renderedEvents = renderedEvents.concat(renderableEvents);
- }
- }
- if (renderedEvents.length) {
- reportEventChange();
- }
- return renderedEvents;
- }
- function removeEvents(filter) {
- var eventID;
- var i;
- if (filter == null) {
- filter = function() { return true; };
- }
- else if (!$.isFunction(filter)) {
- eventID = filter + '';
- filter = function(event) {
- return event._id == eventID;
- };
- }
-
- cache = $.grep(cache, filter, true);
-
-
-
- for (i=0; i<sources.length; i++) {
- if ($.isArray(sources[i].events)) {
- sources[i].events = $.grep(sources[i].events, filter, true);
- }
- }
- reportEventChange();
- }
- function clientEvents(filter) {
- if ($.isFunction(filter)) {
- return $.grep(cache, filter);
- }
- else if (filter != null) {
- filter += '';
- return $.grep(cache, function(e) {
- return e._id == filter;
- });
- }
- return cache;
- }
-
-
- t.rezoneArrayEventSources = function() {
- var i;
- var events;
- var j;
- for (i = 0; i < sources.length; i++) {
- events = sources[i].events;
- if ($.isArray(events)) {
- for (j = 0; j < events.length; j++) {
- rezoneEventDates(events[j]);
- }
- }
- }
- };
- function rezoneEventDates(event) {
- event.start = t.moment(event.start);
- if (event.end) {
- event.end = t.moment(event.end);
- }
- backupEventDates(event);
- }
-
-
-
-
-
- function buildEventFromInput(input, source) {
- var out = {};
- var start, end;
- var allDay;
- if (t.options.eventDataTransform) {
- input = t.options.eventDataTransform(input);
- }
- if (source && source.eventDataTransform) {
- input = source.eventDataTransform(input);
- }
-
-
- $.extend(out, input);
- if (source) {
- out.source = source;
- }
- out._id = input._id || (input.id === undefined ? '_fc' + eventGUID++ : input.id + '');
- if (input.className) {
- if (typeof input.className == 'string') {
- out.className = input.className.split(/\s+/);
- }
- else {
- out.className = input.className;
- }
- }
- else {
- out.className = [];
- }
- start = input.start || input.date;
- end = input.end;
-
- if (isTimeString(start)) {
- start = moment.duration(start);
- }
- if (isTimeString(end)) {
- end = moment.duration(end);
- }
- if (input.dow || moment.isDuration(start) || moment.isDuration(end)) {
-
- out.start = start ? moment.duration(start) : null;
- out.end = end ? moment.duration(end) : null;
- out._recurring = true;
- }
- else {
- if (start) {
- start = t.moment(start);
- if (!start.isValid()) {
- return false;
- }
- }
- if (end) {
- end = t.moment(end);
- if (!end.isValid()) {
- end = null;
- }
- }
- allDay = input.allDay;
- if (allDay === undefined) {
- allDay = firstDefined(
- source ? source.allDayDefault : undefined,
- t.options.allDayDefault
- );
-
- }
- assignDatesToEvent(start, end, allDay, out);
- }
- t.normalizeEvent(out);
- return out;
- }
- t.buildEventFromInput = buildEventFromInput;
-
-
- function assignDatesToEvent(start, end, allDay, event) {
- event.start = start;
- event.end = end;
- event.allDay = allDay;
- normalizeEventDates(event);
- backupEventDates(event);
- }
-
-
- function normalizeEventDates(eventProps) {
- normalizeEventTimes(eventProps);
- if (eventProps.end && !eventProps.end.isAfter(eventProps.start)) {
- eventProps.end = null;
- }
- if (!eventProps.end) {
- if (t.options.forceEventDuration) {
- eventProps.end = t.getDefaultEventEnd(eventProps.allDay, eventProps.start);
- }
- else {
- eventProps.end = null;
- }
- }
- }
-
- function normalizeEventTimes(eventProps) {
- if (eventProps.allDay == null) {
- eventProps.allDay = !(eventProps.start.hasTime() || (eventProps.end && eventProps.end.hasTime()));
- }
- if (eventProps.allDay) {
- eventProps.start.stripTime();
- if (eventProps.end) {
-
- eventProps.end.stripTime();
- }
- }
- else {
- if (!eventProps.start.hasTime()) {
- eventProps.start = t.applyTimezone(eventProps.start.time(0));
- }
- if (eventProps.end && !eventProps.end.hasTime()) {
- eventProps.end = t.applyTimezone(eventProps.end.time(0));
- }
- }
- }
-
-
-
-
- function expandEvent(abstractEvent, _rangeStart, _rangeEnd) {
- var events = [];
- var dowHash;
- var dow;
- var i;
- var date;
- var startTime, endTime;
- var start, end;
- var event;
- _rangeStart = _rangeStart || rangeStart;
- _rangeEnd = _rangeEnd || rangeEnd;
- if (abstractEvent) {
- if (abstractEvent._recurring) {
-
- if ((dow = abstractEvent.dow)) {
- dowHash = {};
- for (i = 0; i < dow.length; i++) {
- dowHash[dow[i]] = true;
- }
- }
-
- date = _rangeStart.clone().stripTime();
- while (date.isBefore(_rangeEnd)) {
- if (!dowHash || dowHash[date.day()]) {
- startTime = abstractEvent.start;
- endTime = abstractEvent.end;
- start = date.clone();
- end = null;
- if (startTime) {
- start = start.time(startTime);
- }
- if (endTime) {
- end = date.clone().time(endTime);
- }
- event = $.extend({}, abstractEvent);
- assignDatesToEvent(
- start, end,
- !startTime && !endTime,
- event
- );
- events.push(event);
- }
- date.add(1, 'days');
- }
- }
- else {
- events.push(abstractEvent);
- }
- }
- return events;
- }
- t.expandEvent = expandEvent;
-
-
-
-
-
-
-
-
- function mutateEvent(event, newProps, largeUnit) {
- var miscProps = {};
- var oldProps;
- var clearEnd;
- var startDelta;
- var endDelta;
- var durationDelta;
- var undoFunc;
-
- function diffDates(date1, date0) {
- if (largeUnit) {
- return diffByUnit(date1, date0, largeUnit);
- }
- else if (newProps.allDay) {
- return diffDay(date1, date0);
- }
- else {
- return diffDayTime(date1, date0);
- }
- }
- newProps = newProps || {};
-
- if (!newProps.start) {
- newProps.start = event.start.clone();
- }
- if (newProps.end === undefined) {
- newProps.end = event.end ? event.end.clone() : null;
- }
- if (newProps.allDay == null) {
- newProps.allDay = event.allDay;
- }
- normalizeEventDates(newProps);
-
-
- oldProps = {
- start: event._start.clone(),
- end: event._end ? event._end.clone() : t.getDefaultEventEnd(event._allDay, event._start),
- allDay: newProps.allDay
- };
- normalizeEventDates(oldProps);
-
- clearEnd = event._end !== null && newProps.end === null;
-
- startDelta = diffDates(newProps.start, oldProps.start);
-
- if (newProps.end) {
- endDelta = diffDates(newProps.end, oldProps.end);
- durationDelta = endDelta.subtract(startDelta);
- }
- else {
- durationDelta = null;
- }
-
- $.each(newProps, function(name, val) {
- if (isMiscEventPropName(name)) {
- if (val !== undefined) {
- miscProps[name] = val;
- }
- }
- });
-
- undoFunc = mutateEvents(
- clientEvents(event._id),
- clearEnd,
- newProps.allDay,
- startDelta,
- durationDelta,
- miscProps
- );
- return {
- dateDelta: startDelta,
- durationDelta: durationDelta,
- undo: undoFunc
- };
- }
-
-
-
-
-
-
-
-
-
-
-
- function mutateEvents(events, clearEnd, allDay, dateDelta, durationDelta, miscProps) {
- var isAmbigTimezone = t.getIsAmbigTimezone();
- var undoFunctions = [];
-
- if (dateDelta && !dateDelta.valueOf()) { dateDelta = null; }
- if (durationDelta && !durationDelta.valueOf()) { durationDelta = null; }
- $.each(events, function(i, event) {
- var oldProps;
- var newProps;
-
-
- oldProps = {
- start: event.start.clone(),
- end: event.end ? event.end.clone() : null,
- allDay: event.allDay
- };
- $.each(miscProps, function(name) {
- oldProps[name] = event[name];
- });
-
-
- newProps = {
- start: event._start,
- end: event._end,
- allDay: allDay
- };
- normalizeEventDates(newProps);
-
- if (clearEnd) {
- newProps.end = null;
- }
- else if (durationDelta && !newProps.end) {
- newProps.end = t.getDefaultEventEnd(newProps.allDay, newProps.start);
- }
- if (dateDelta) {
- newProps.start.add(dateDelta);
- if (newProps.end) {
- newProps.end.add(dateDelta);
- }
- }
- if (durationDelta) {
- newProps.end.add(durationDelta);
- }
-
-
- if (
- isAmbigTimezone &&
- !newProps.allDay &&
- (dateDelta || durationDelta)
- ) {
- newProps.start.stripZone();
- if (newProps.end) {
- newProps.end.stripZone();
- }
- }
- $.extend(event, miscProps, newProps);
- backupEventDates(event);
- undoFunctions.push(function() {
- $.extend(event, oldProps);
- backupEventDates(event);
- });
- });
- return function() {
- for (var i = 0; i < undoFunctions.length; i++) {
- undoFunctions[i]();
- }
- };
- }
- }
- Calendar.prototype.normalizeEvent = function(event) {
- };
- Calendar.prototype.spanContainsSpan = function(outerSpan, innerSpan) {
- var eventStart = outerSpan.start.clone().stripZone();
- var eventEnd = this.getEventEnd(outerSpan).stripZone();
- return innerSpan.start >= eventStart && innerSpan.end <= eventEnd;
- };
- Calendar.prototype.getPeerEvents = function(span, event) {
- var cache = this.getEventCache();
- var peerEvents = [];
- var i, otherEvent;
- for (i = 0; i < cache.length; i++) {
- otherEvent = cache[i];
- if (
- !event ||
- event._id !== otherEvent._id
- ) {
- peerEvents.push(otherEvent);
- }
- }
- return peerEvents;
- };
- function backupEventDates(event) {
- event._allDay = event.allDay;
- event._start = event.start.clone();
- event._end = event.end ? event.end.clone() : null;
- }
- Calendar.prototype.isEventSpanAllowed = function(span, event) {
- var source = event.source || {};
- var constraint = firstDefined(
- event.constraint,
- source.constraint,
- this.options.eventConstraint
- );
- var overlap = firstDefined(
- event.overlap,
- source.overlap,
- this.options.eventOverlap
- );
- return this.isSpanAllowed(span, constraint, overlap, event) &&
- (!this.options.eventAllow || this.options.eventAllow(span, event) !== false);
- };
- Calendar.prototype.isExternalSpanAllowed = function(eventSpan, eventLocation, eventProps) {
- var eventInput;
- var event;
-
- if (eventProps) {
- eventInput = $.extend({}, eventProps, eventLocation);
- event = this.expandEvent(
- this.buildEventFromInput(eventInput)
- )[0];
- }
- if (event) {
- return this.isEventSpanAllowed(eventSpan, event);
- }
- else {
- return this.isSelectionSpanAllowed(eventSpan);
- }
- };
- Calendar.prototype.isSelectionSpanAllowed = function(span) {
- return this.isSpanAllowed(span, this.options.selectConstraint, this.options.selectOverlap) &&
- (!this.options.selectAllow || this.options.selectAllow(span) !== false);
- };
- Calendar.prototype.isSpanAllowed = function(span, constraint, overlap, event) {
- var constraintEvents;
- var anyContainment;
- var peerEvents;
- var i, peerEvent;
- var peerOverlap;
-
- if (constraint != null) {
-
-
- constraintEvents = this.constraintToEvents(constraint);
- if (constraintEvents) {
- anyContainment = false;
- for (i = 0; i < constraintEvents.length; i++) {
- if (this.spanContainsSpan(constraintEvents[i], span)) {
- anyContainment = true;
- break;
- }
- }
- if (!anyContainment) {
- return false;
- }
- }
- }
- peerEvents = this.getPeerEvents(span, event);
- for (i = 0; i < peerEvents.length; i++) {
- peerEvent = peerEvents[i];
-
- if (this.eventIntersectsRange(peerEvent, span)) {
-
- if (overlap === false) {
- return false;
- }
-
- else if (typeof overlap === 'function' && !overlap(peerEvent, event)) {
- return false;
- }
-
-
- if (event) {
- peerOverlap = firstDefined(
- peerEvent.overlap,
- (peerEvent.source || {}).overlap
-
- );
- if (peerOverlap === false) {
- return false;
- }
-
- if (typeof peerOverlap === 'function' && !peerOverlap(event, peerEvent)) {
- return false;
- }
- }
- }
- }
- return true;
- };
- Calendar.prototype.constraintToEvents = function(constraintInput) {
- if (constraintInput === 'businessHours') {
- return this.getCurrentBusinessHourEvents();
- }
- if (typeof constraintInput === 'object') {
- if (constraintInput.start != null) {
- return this.expandEvent(this.buildEventFromInput(constraintInput));
- }
- else {
- return null;
- }
- }
- return this.clientEvents(constraintInput);
- };
- Calendar.prototype.eventIntersectsRange = function(event, range) {
- var eventStart = event.start.clone().stripZone();
- var eventEnd = this.getEventEnd(event).stripZone();
- return range.start < eventEnd && range.end > eventStart;
- };
- var BUSINESS_HOUR_EVENT_DEFAULTS = {
- id: '_fcBusinessHours',
- start: '09:00',
- end: '17:00',
- dow: [ 1, 2, 3, 4, 5 ],
- rendering: 'inverse-background'
-
- };
- Calendar.prototype.getCurrentBusinessHourEvents = function(wholeDay) {
- return this.computeBusinessHourEvents(wholeDay, this.options.businessHours);
- };
- Calendar.prototype.computeBusinessHourEvents = function(wholeDay, input) {
- if (input === true) {
- return this.expandBusinessHourEvents(wholeDay, [ {} ]);
- }
- else if ($.isPlainObject(input)) {
- return this.expandBusinessHourEvents(wholeDay, [ input ]);
- }
- else if ($.isArray(input)) {
- return this.expandBusinessHourEvents(wholeDay, input, true);
- }
- else {
- return [];
- }
- };
- Calendar.prototype.expandBusinessHourEvents = function(wholeDay, inputs, ignoreNoDow) {
- var view = this.getView();
- var events = [];
- var i, input;
- for (i = 0; i < inputs.length; i++) {
- input = inputs[i];
- if (ignoreNoDow && !input.dow) {
- continue;
- }
-
- input = $.extend({}, BUSINESS_HOUR_EVENT_DEFAULTS, input);
-
- if (wholeDay) {
- input.start = null;
- input.end = null;
- }
- events.push.apply(events,
- this.expandEvent(
- this.buildEventFromInput(input),
- view.start,
- view.end
- )
- );
- }
- return events;
- };
- ;;
- var BasicView = FC.BasicView = View.extend({
- scroller: null,
- dayGridClass: DayGrid,
- dayGrid: null,
- dayNumbersVisible: false,
- colWeekNumbersVisible: false,
- cellWeekNumbersVisible: false,
- weekNumberWidth: null,
- headContainerEl: null,
- headRowEl: null,
- initialize: function() {
- this.dayGrid = this.instantiateDayGrid();
- this.scroller = new Scroller({
- overflowX: 'hidden',
- overflowY: 'auto'
- });
- },
-
- instantiateDayGrid: function() {
-
-
- var subclass = this.dayGridClass.extend(basicDayGridMethods);
- return new subclass(this);
- },
-
- setRange: function(range) {
- View.prototype.setRange.call(this, range);
- this.dayGrid.breakOnWeeks = /year|month|week/.test(this.intervalUnit);
- this.dayGrid.setRange(range);
- },
-
- computeRange: function(date) {
- var range = View.prototype.computeRange.call(this, date);
-
- if (/year|month/.test(range.intervalUnit)) {
- range.start.startOf('week');
- range.start = this.skipHiddenDays(range.start);
-
- if (range.end.weekday()) {
- range.end.add(1, 'week').startOf('week');
- range.end = this.skipHiddenDays(range.end, -1, true);
- }
- }
- return range;
- },
-
- renderDates: function() {
- this.dayNumbersVisible = this.dayGrid.rowCnt > 1;
- if (this.opt('weekNumbers')) {
- if (this.opt('weekNumbersWithinDays')) {
- this.cellWeekNumbersVisible = true;
- this.colWeekNumbersVisible = false;
- }
- else {
- this.cellWeekNumbersVisible = false;
- this.colWeekNumbersVisible = true;
- };
- }
- this.dayGrid.numbersVisible = this.dayNumbersVisible ||
- this.cellWeekNumbersVisible || this.colWeekNumbersVisible;
- this.el.addClass('fc-basic-view').html(this.renderSkeletonHtml());
- this.renderHead();
- this.scroller.render();
- var dayGridContainerEl = this.scroller.el.addClass('fc-day-grid-container');
- var dayGridEl = $('<div class="fc-day-grid" />').appendTo(dayGridContainerEl);
- this.el.find('.fc-body > tr > td').append(dayGridContainerEl);
- this.dayGrid.setElement(dayGridEl);
- this.dayGrid.renderDates(this.hasRigidRows());
- },
-
- renderHead: function() {
- this.headContainerEl =
- this.el.find('.fc-head-container')
- .html(this.dayGrid.renderHeadHtml());
- this.headRowEl = this.headContainerEl.find('.fc-row');
- },
-
-
- unrenderDates: function() {
- this.dayGrid.unrenderDates();
- this.dayGrid.removeElement();
- this.scroller.destroy();
- },
- renderBusinessHours: function() {
- this.dayGrid.renderBusinessHours();
- },
- unrenderBusinessHours: function() {
- this.dayGrid.unrenderBusinessHours();
- },
-
-
- renderSkeletonHtml: function() {
- return '' +
- '<table>' +
- '<thead class="fc-head">' +
- '<tr>' +
- '<td class="fc-head-container ' + this.widgetHeaderClass + '"></td>' +
- '</tr>' +
- '</thead>' +
- '<tbody class="fc-body">' +
- '<tr>' +
- '<td class="' + this.widgetContentClass + '"></td>' +
- '</tr>' +
- '</tbody>' +
- '</table>';
- },
-
- weekNumberStyleAttr: function() {
- if (this.weekNumberWidth !== null) {
- return 'style="width:' + this.weekNumberWidth + 'px"';
- }
- return '';
- },
-
- hasRigidRows: function() {
- var eventLimit = this.opt('eventLimit');
- return eventLimit && typeof eventLimit !== 'number';
- },
-
-
- updateWidth: function() {
- if (this.colWeekNumbersVisible) {
-
-
- this.weekNumberWidth = matchCellWidths(
- this.el.find('.fc-week-number')
- );
- }
- },
-
- setHeight: function(totalHeight, isAuto) {
- var eventLimit = this.opt('eventLimit');
- var scrollerHeight;
- var scrollbarWidths;
-
- this.scroller.clear();
- uncompensateScroll(this.headRowEl);
- this.dayGrid.removeSegPopover();
-
- if (eventLimit && typeof eventLimit === 'number') {
- this.dayGrid.limitRows(eventLimit);
- }
-
-
- scrollerHeight = this.computeScrollerHeight(totalHeight);
- this.setGridHeight(scrollerHeight, isAuto);
-
- if (eventLimit && typeof eventLimit !== 'number') {
- this.dayGrid.limitRows(eventLimit);
- }
- if (!isAuto) {
- this.scroller.setHeight(scrollerHeight);
- scrollbarWidths = this.scroller.getScrollbarWidths();
- if (scrollbarWidths.left || scrollbarWidths.right) {
- compensateScroll(this.headRowEl, scrollbarWidths);
-
- scrollerHeight = this.computeScrollerHeight(totalHeight);
- this.scroller.setHeight(scrollerHeight);
- }
-
- this.scroller.lockOverflow(scrollbarWidths);
- }
- },
-
- computeScrollerHeight: function(totalHeight) {
- return totalHeight -
- subtractInnerElHeight(this.el, this.scroller.el);
- },
-
- setGridHeight: function(height, isAuto) {
- if (isAuto) {
- undistributeHeight(this.dayGrid.rowEls);
- }
- else {
- distributeHeight(this.dayGrid.rowEls, height, true);
- }
- },
-
- computeInitialScroll: function() {
- return { top: 0 };
- },
- queryScroll: function() {
- return { top: this.scroller.getScrollTop() };
- },
- setScroll: function(scroll) {
- this.scroller.setScrollTop(scroll.top);
- },
-
-
- prepareHits: function() {
- this.dayGrid.prepareHits();
- },
- releaseHits: function() {
- this.dayGrid.releaseHits();
- },
- queryHit: function(left, top) {
- return this.dayGrid.queryHit(left, top);
- },
- getHitSpan: function(hit) {
- return this.dayGrid.getHitSpan(hit);
- },
- getHitEl: function(hit) {
- return this.dayGrid.getHitEl(hit);
- },
-
-
- renderEvents: function(events) {
- this.dayGrid.renderEvents(events);
- this.updateHeight();
- },
-
- getEventSegs: function() {
- return this.dayGrid.getEventSegs();
- },
-
- unrenderEvents: function() {
- this.dayGrid.unrenderEvents();
-
-
- },
-
-
- renderDrag: function(dropLocation, seg) {
- return this.dayGrid.renderDrag(dropLocation, seg);
- },
- unrenderDrag: function() {
- this.dayGrid.unrenderDrag();
- },
-
-
- renderSelection: function(span) {
- this.dayGrid.renderSelection(span);
- },
-
- unrenderSelection: function() {
- this.dayGrid.unrenderSelection();
- }
- });
- var basicDayGridMethods = {
-
- renderHeadIntroHtml: function() {
- var view = this.view;
- if (view.colWeekNumbersVisible) {
- return '' +
- '<th class="fc-week-number ' + view.widgetHeaderClass + '" ' + view.weekNumberStyleAttr() + '>' +
- '<span>' +
- htmlEscape(view.opt('weekNumberTitle')) +
- '</span>' +
- '</th>';
- }
- return '';
- },
-
- renderNumberIntroHtml: function(row) {
- var view = this.view;
- var weekStart = this.getCellDate(row, 0);
- if (view.colWeekNumbersVisible) {
- return '' +
- '<td class="fc-week-number" ' + view.weekNumberStyleAttr() + '>' +
- view.buildGotoAnchorHtml(
- { date: weekStart, type: 'week', forceOff: this.colCnt === 1 },
- weekStart.format('w')
- ) +
- '</td>';
- }
- return '';
- },
-
- renderBgIntroHtml: function() {
- var view = this.view;
- if (view.colWeekNumbersVisible) {
- return '<td class="fc-week-number ' + view.widgetContentClass + '" ' +
- view.weekNumberStyleAttr() + '></td>';
- }
- return '';
- },
-
-
- renderIntroHtml: function() {
- var view = this.view;
- if (view.colWeekNumbersVisible) {
- return '<td class="fc-week-number" ' + view.weekNumberStyleAttr() + '></td>';
- }
- return '';
- }
- };
- ;;
- var MonthView = FC.MonthView = BasicView.extend({
-
- computeRange: function(date) {
- var range = BasicView.prototype.computeRange.call(this, date);
- var rowCnt;
-
- if (this.isFixedWeeks()) {
- rowCnt = Math.ceil(range.end.diff(range.start, 'weeks', true));
- range.end.add(6 - rowCnt, 'weeks');
- }
- return range;
- },
-
- setGridHeight: function(height, isAuto) {
-
- if (isAuto) {
- height *= this.rowCnt / 6;
- }
- distributeHeight(this.dayGrid.rowEls, height, !isAuto);
- },
- isFixedWeeks: function() {
- return this.opt('fixedWeekCount');
- }
- });
- ;;
- fcViews.basic = {
- 'class': BasicView
- };
- fcViews.basicDay = {
- type: 'basic',
- duration: { days: 1 }
- };
- fcViews.basicWeek = {
- type: 'basic',
- duration: { weeks: 1 }
- };
- fcViews.month = {
- 'class': MonthView,
- duration: { months: 1 },
- defaults: {
- fixedWeekCount: true
- }
- };
- ;;
- var AgendaView = FC.AgendaView = View.extend({
- scroller: null,
- timeGridClass: TimeGrid,
- timeGrid: null,
- dayGridClass: DayGrid,
- dayGrid: null,
- axisWidth: null,
- headContainerEl: null,
- noScrollRowEls: null,
-
- bottomRuleEl: null,
- initialize: function() {
- this.timeGrid = this.instantiateTimeGrid();
- if (this.opt('allDaySlot')) {
- this.dayGrid = this.instantiateDayGrid();
- }
- this.scroller = new Scroller({
- overflowX: 'hidden',
- overflowY: 'auto'
- });
- },
-
- instantiateTimeGrid: function() {
- var subclass = this.timeGridClass.extend(agendaTimeGridMethods);
- return new subclass(this);
- },
-
- instantiateDayGrid: function() {
- var subclass = this.dayGridClass.extend(agendaDayGridMethods);
- return new subclass(this);
- },
-
-
- setRange: function(range) {
- View.prototype.setRange.call(this, range);
- this.timeGrid.setRange(range);
- if (this.dayGrid) {
- this.dayGrid.setRange(range);
- }
- },
-
- renderDates: function() {
- this.el.addClass('fc-agenda-view').html(this.renderSkeletonHtml());
- this.renderHead();
- this.scroller.render();
- var timeGridWrapEl = this.scroller.el.addClass('fc-time-grid-container');
- var timeGridEl = $('<div class="fc-time-grid" />').appendTo(timeGridWrapEl);
- this.el.find('.fc-body > tr > td').append(timeGridWrapEl);
- this.timeGrid.setElement(timeGridEl);
- this.timeGrid.renderDates();
-
- this.bottomRuleEl = $('<hr class="fc-divider ' + this.widgetHeaderClass + '"/>')
- .appendTo(this.timeGrid.el);
- if (this.dayGrid) {
- this.dayGrid.setElement(this.el.find('.fc-day-grid'));
- this.dayGrid.renderDates();
-
- this.dayGrid.bottomCoordPadding = this.dayGrid.el.next('hr').outerHeight();
- }
- this.noScrollRowEls = this.el.find('.fc-row:not(.fc-scroller *)');
- },
-
- renderHead: function() {
- this.headContainerEl =
- this.el.find('.fc-head-container')
- .html(this.timeGrid.renderHeadHtml());
- },
-
-
- unrenderDates: function() {
- this.timeGrid.unrenderDates();
- this.timeGrid.removeElement();
- if (this.dayGrid) {
- this.dayGrid.unrenderDates();
- this.dayGrid.removeElement();
- }
- this.scroller.destroy();
- },
-
-
- renderSkeletonHtml: function() {
- return '' +
- '<table>' +
- '<thead class="fc-head">' +
- '<tr>' +
- '<td class="fc-head-container ' + this.widgetHeaderClass + '"></td>' +
- '</tr>' +
- '</thead>' +
- '<tbody class="fc-body">' +
- '<tr>' +
- '<td class="' + this.widgetContentClass + '">' +
- (this.dayGrid ?
- '<div class="fc-day-grid"/>' +
- '<hr class="fc-divider ' + this.widgetHeaderClass + '"/>' :
- ''
- ) +
- '</td>' +
- '</tr>' +
- '</tbody>' +
- '</table>';
- },
-
- axisStyleAttr: function() {
- if (this.axisWidth !== null) {
- return 'style="width:' + this.axisWidth + 'px"';
- }
- return '';
- },
-
- renderBusinessHours: function() {
- this.timeGrid.renderBusinessHours();
- if (this.dayGrid) {
- this.dayGrid.renderBusinessHours();
- }
- },
- unrenderBusinessHours: function() {
- this.timeGrid.unrenderBusinessHours();
- if (this.dayGrid) {
- this.dayGrid.unrenderBusinessHours();
- }
- },
-
- getNowIndicatorUnit: function() {
- return this.timeGrid.getNowIndicatorUnit();
- },
- renderNowIndicator: function(date) {
- this.timeGrid.renderNowIndicator(date);
- },
- unrenderNowIndicator: function() {
- this.timeGrid.unrenderNowIndicator();
- },
-
- updateSize: function(isResize) {
- this.timeGrid.updateSize(isResize);
- View.prototype.updateSize.call(this, isResize);
- },
-
- updateWidth: function() {
-
- this.axisWidth = matchCellWidths(this.el.find('.fc-axis'));
- },
-
- setHeight: function(totalHeight, isAuto) {
- var eventLimit;
- var scrollerHeight;
- var scrollbarWidths;
-
- this.bottomRuleEl.hide();
- this.scroller.clear();
- uncompensateScroll(this.noScrollRowEls);
-
- if (this.dayGrid) {
- this.dayGrid.removeSegPopover();
- eventLimit = this.opt('eventLimit');
- if (eventLimit && typeof eventLimit !== 'number') {
- eventLimit = AGENDA_ALL_DAY_EVENT_LIMIT;
- }
- if (eventLimit) {
- this.dayGrid.limitRows(eventLimit);
- }
- }
- if (!isAuto) {
- scrollerHeight = this.computeScrollerHeight(totalHeight);
- this.scroller.setHeight(scrollerHeight);
- scrollbarWidths = this.scroller.getScrollbarWidths();
- if (scrollbarWidths.left || scrollbarWidths.right) {
-
- compensateScroll(this.noScrollRowEls, scrollbarWidths);
-
-
- scrollerHeight = this.computeScrollerHeight(totalHeight);
- this.scroller.setHeight(scrollerHeight);
- }
-
- this.scroller.lockOverflow(scrollbarWidths);
-
-
- if (this.timeGrid.getTotalSlatHeight() < scrollerHeight) {
- this.bottomRuleEl.show();
- }
- }
- },
-
- computeScrollerHeight: function(totalHeight) {
- return totalHeight -
- subtractInnerElHeight(this.el, this.scroller.el);
- },
-
-
- computeInitialScroll: function() {
- var scrollTime = moment.duration(this.opt('scrollTime'));
- var top = this.timeGrid.computeTimeTop(scrollTime);
-
- top = Math.ceil(top);
- if (top) {
- top++;
- }
- return { top: top };
- },
- queryScroll: function() {
- return { top: this.scroller.getScrollTop() };
- },
- setScroll: function(scroll) {
- this.scroller.setScrollTop(scroll.top);
- },
-
-
- prepareHits: function() {
- this.timeGrid.prepareHits();
- if (this.dayGrid) {
- this.dayGrid.prepareHits();
- }
- },
- releaseHits: function() {
- this.timeGrid.releaseHits();
- if (this.dayGrid) {
- this.dayGrid.releaseHits();
- }
- },
- queryHit: function(left, top) {
- var hit = this.timeGrid.queryHit(left, top);
- if (!hit && this.dayGrid) {
- hit = this.dayGrid.queryHit(left, top);
- }
- return hit;
- },
- getHitSpan: function(hit) {
-
- return hit.component.getHitSpan(hit);
- },
- getHitEl: function(hit) {
-
- return hit.component.getHitEl(hit);
- },
-
-
- renderEvents: function(events) {
- var dayEvents = [];
- var timedEvents = [];
- var daySegs = [];
- var timedSegs;
- var i;
-
- for (i = 0; i < events.length; i++) {
- if (events[i].allDay) {
- dayEvents.push(events[i]);
- }
- else {
- timedEvents.push(events[i]);
- }
- }
-
- timedSegs = this.timeGrid.renderEvents(timedEvents);
- if (this.dayGrid) {
- daySegs = this.dayGrid.renderEvents(dayEvents);
- }
-
- this.updateHeight();
- },
-
- getEventSegs: function() {
- return this.timeGrid.getEventSegs().concat(
- this.dayGrid ? this.dayGrid.getEventSegs() : []
- );
- },
-
- unrenderEvents: function() {
-
- this.timeGrid.unrenderEvents();
- if (this.dayGrid) {
- this.dayGrid.unrenderEvents();
- }
-
-
- },
-
-
- renderDrag: function(dropLocation, seg) {
- if (dropLocation.start.hasTime()) {
- return this.timeGrid.renderDrag(dropLocation, seg);
- }
- else if (this.dayGrid) {
- return this.dayGrid.renderDrag(dropLocation, seg);
- }
- },
- unrenderDrag: function() {
- this.timeGrid.unrenderDrag();
- if (this.dayGrid) {
- this.dayGrid.unrenderDrag();
- }
- },
-
-
- renderSelection: function(span) {
- if (span.start.hasTime() || span.end.hasTime()) {
- this.timeGrid.renderSelection(span);
- }
- else if (this.dayGrid) {
- this.dayGrid.renderSelection(span);
- }
- },
-
- unrenderSelection: function() {
- this.timeGrid.unrenderSelection();
- if (this.dayGrid) {
- this.dayGrid.unrenderSelection();
- }
- }
- });
- var agendaTimeGridMethods = {
-
- renderHeadIntroHtml: function() {
- var view = this.view;
- var weekText;
- if (view.opt('weekNumbers')) {
- weekText = this.start.format(view.opt('smallWeekFormat'));
- return '' +
- '<th class="fc-axis fc-week-number ' + view.widgetHeaderClass + '" ' + view.axisStyleAttr() + '>' +
- view.buildGotoAnchorHtml(
- { date: this.start, type: 'week', forceOff: this.colCnt > 1 },
- htmlEscape(weekText)
- ) +
- '</th>';
- }
- else {
- return '<th class="fc-axis ' + view.widgetHeaderClass + '" ' + view.axisStyleAttr() + '></th>';
- }
- },
-
- renderBgIntroHtml: function() {
- var view = this.view;
- return '<td class="fc-axis ' + view.widgetContentClass + '" ' + view.axisStyleAttr() + '></td>';
- },
-
-
- renderIntroHtml: function() {
- var view = this.view;
- return '<td class="fc-axis" ' + view.axisStyleAttr() + '></td>';
- }
- };
- var agendaDayGridMethods = {
-
- renderBgIntroHtml: function() {
- var view = this.view;
- return '' +
- '<td class="fc-axis ' + view.widgetContentClass + '" ' + view.axisStyleAttr() + '>' +
- '<span>' +
- view.getAllDayHtml() +
- '</span>' +
- '</td>';
- },
-
-
- renderIntroHtml: function() {
- var view = this.view;
- return '<td class="fc-axis" ' + view.axisStyleAttr() + '></td>';
- }
- };
- ;;
- var AGENDA_ALL_DAY_EVENT_LIMIT = 5;
- var AGENDA_STOCK_SUB_DURATIONS = [
- { hours: 1 },
- { minutes: 30 },
- { minutes: 15 },
- { seconds: 30 },
- { seconds: 15 }
- ];
- fcViews.agenda = {
- 'class': AgendaView,
- defaults: {
- allDaySlot: true,
- slotDuration: '00:30:00',
- minTime: '00:00:00',
- maxTime: '24:00:00',
- slotEventOverlap: true
- }
- };
- fcViews.agendaDay = {
- type: 'agenda',
- duration: { days: 1 }
- };
- fcViews.agendaWeek = {
- type: 'agenda',
- duration: { weeks: 1 }
- };
- ;;
- var ListView = View.extend({
- grid: null,
- scroller: null,
- initialize: function() {
- this.grid = new ListViewGrid(this);
- this.scroller = new Scroller({
- overflowX: 'hidden',
- overflowY: 'auto'
- });
- },
- setRange: function(range) {
- View.prototype.setRange.call(this, range);
- this.grid.setRange(range);
- },
- renderSkeleton: function() {
- this.el.addClass(
- 'fc-list-view ' +
- this.widgetContentClass
- );
- this.scroller.render();
- this.scroller.el.appendTo(this.el);
- this.grid.setElement(this.scroller.scrollEl);
- },
- unrenderSkeleton: function() {
- this.scroller.destroy();
- },
- setHeight: function(totalHeight, isAuto) {
- this.scroller.setHeight(this.computeScrollerHeight(totalHeight));
- },
- computeScrollerHeight: function(totalHeight) {
- return totalHeight -
- subtractInnerElHeight(this.el, this.scroller.el);
- },
- renderEvents: function(events) {
- this.grid.renderEvents(events);
- },
- unrenderEvents: function() {
- this.grid.unrenderEvents();
- },
- isEventResizable: function(event) {
- return false;
- },
- isEventDraggable: function(event) {
- return false;
- }
- });
- var ListViewGrid = Grid.extend({
- segSelector: '.fc-list-item',
- hasDayInteractions: false,
-
- spanToSegs: function(span) {
- var view = this.view;
- var dayStart = view.start.clone().time(0);
- var dayIndex = 0;
- var seg;
- var segs = [];
- while (dayStart < view.end) {
- seg = intersectRanges(span, {
- start: dayStart,
- end: dayStart.clone().add(1, 'day')
- });
- if (seg) {
- seg.dayIndex = dayIndex;
- segs.push(seg);
- }
- dayStart.add(1, 'day');
- dayIndex++;
-
-
- if (
- seg && !seg.isEnd && span.end.hasTime() &&
- span.end < dayStart.clone().add(this.view.nextDayThreshold)
- ) {
- seg.end = span.end.clone();
- seg.isEnd = true;
- break;
- }
- }
- return segs;
- },
-
- computeEventTimeFormat: function() {
- return this.view.opt('mediumTimeFormat');
- },
-
-
- handleSegClick: function(seg, ev) {
- var url;
- Grid.prototype.handleSegClick.apply(this, arguments);
-
- if (!$(ev.target).closest('a[href]').length) {
- url = seg.event.url;
- if (url && !ev.isDefaultPrevented()) {
- window.location.href = url;
- }
- }
- },
-
- renderFgSegs: function(segs) {
- segs = this.renderFgSegEls(segs);
- if (!segs.length) {
- this.renderEmptyMessage();
- }
- else {
- this.renderSegList(segs);
- }
- return segs;
- },
- renderEmptyMessage: function() {
- this.el.html(
- '<div class="fc-list-empty-wrap2">' +
- '<div class="fc-list-empty-wrap1">' +
- '<div class="fc-list-empty">' +
- htmlEscape(this.view.opt('noEventsMessage')) +
- '</div>' +
- '</div>' +
- '</div>'
- );
- },
-
- renderSegList: function(allSegs) {
- var segsByDay = this.groupSegsByDay(allSegs);
- var dayIndex;
- var daySegs;
- var i;
- var tableEl = $('<table class="fc-list-table"><tbody/></table>');
- var tbodyEl = tableEl.find('tbody');
- for (dayIndex = 0; dayIndex < segsByDay.length; dayIndex++) {
- daySegs = segsByDay[dayIndex];
- if (daySegs) {
-
- tbodyEl.append(this.dayHeaderHtml(
- this.view.start.clone().add(dayIndex, 'days')
- ));
- this.sortEventSegs(daySegs);
- for (i = 0; i < daySegs.length; i++) {
- tbodyEl.append(daySegs[i].el);
- }
- }
- }
- this.el.empty().append(tableEl);
- },
-
- groupSegsByDay: function(segs) {
- var segsByDay = [];
- var i, seg;
- for (i = 0; i < segs.length; i++) {
- seg = segs[i];
- (segsByDay[seg.dayIndex] || (segsByDay[seg.dayIndex] = []))
- .push(seg);
- }
- return segsByDay;
- },
-
- dayHeaderHtml: function(dayDate) {
- var view = this.view;
- var mainFormat = view.opt('listDayFormat');
- var altFormat = view.opt('listDayAltFormat');
- return '<tr class="fc-list-heading" data-date="' + dayDate.format('YYYY-MM-DD') + '">' +
- '<td class="' + view.widgetHeaderClass + '" colspan="3">' +
- (mainFormat ?
- view.buildGotoAnchorHtml(
- dayDate,
- { 'class': 'fc-list-heading-main' },
- htmlEscape(dayDate.format(mainFormat))
- ) :
- '') +
- (altFormat ?
- view.buildGotoAnchorHtml(
- dayDate,
- { 'class': 'fc-list-heading-alt' },
- htmlEscape(dayDate.format(altFormat))
- ) :
- '') +
- '</td>' +
- '</tr>';
- },
-
- fgSegHtml: function(seg) {
- var view = this.view;
- var classes = [ 'fc-list-item' ].concat(this.getSegCustomClasses(seg));
- var bgColor = this.getSegBackgroundColor(seg);
- var event = seg.event;
- var url = event.url;
- var timeHtml;
- if (event.allDay) {
- timeHtml = view.getAllDayHtml();
- }
- else if (view.isMultiDayEvent(event)) {
- if (seg.isStart || seg.isEnd) {
- timeHtml = htmlEscape(this.getEventTimeText(seg));
- }
- else {
- timeHtml = view.getAllDayHtml();
- }
- }
- else {
-
- timeHtml = htmlEscape(this.getEventTimeText(event));
- }
- if (url) {
- classes.push('fc-has-url');
- }
- return '<tr class="' + classes.join(' ') + '">' +
- (this.displayEventTime ?
- '<td class="fc-list-item-time ' + view.widgetContentClass + '">' +
- (timeHtml || '') +
- '</td>' :
- '') +
- '<td class="fc-list-item-marker ' + view.widgetContentClass + '">' +
- '<span class="fc-event-dot"' +
- (bgColor ?
- ' style="background-color:' + bgColor + '"' :
- '') +
- '></span>' +
- '</td>' +
- '<td class="fc-list-item-title ' + view.widgetContentClass + '">' +
- '<a' + (url ? ' href="' + htmlEscape(url) + '"' : '') + '>' +
- htmlEscape(seg.event.title || '') +
- '</a>' +
- '</td>' +
- '</tr>';
- }
- });
- ;;
- fcViews.list = {
- 'class': ListView,
- buttonTextKey: 'list',
- defaults: {
- buttonText: 'list',
- listDayFormat: 'LL',
- noEventsMessage: 'No events to display'
- }
- };
- fcViews.listDay = {
- type: 'list',
- duration: { days: 1 },
- defaults: {
- listDayFormat: 'dddd'
- }
- };
- fcViews.listWeek = {
- type: 'list',
- duration: { weeks: 1 },
- defaults: {
- listDayFormat: 'dddd',
- listDayAltFormat: 'LL'
- }
- };
- fcViews.listMonth = {
- type: 'list',
- duration: { month: 1 },
- defaults: {
- listDayAltFormat: 'dddd'
- }
- };
- fcViews.listYear = {
- type: 'list',
- duration: { year: 1 },
- defaults: {
- listDayAltFormat: 'dddd'
- }
- };
- ;;
- return FC;
- });
|