ag-grid-community.amd.js 3.2 MB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764676567666767676867696770677167726773677467756776677767786779678067816782678367846785678667876788678967906791679267936794679567966797679867996800680168026803680468056806680768086809681068116812681368146815681668176818681968206821682268236824682568266827682868296830683168326833683468356836683768386839684068416842684368446845684668476848684968506851685268536854685568566857685868596860686168626863686468656866686768686869687068716872687368746875687668776878687968806881688268836884688568866887688868896890689168926893689468956896689768986899690069016902690369046905690669076908690969106911691269136914691569166917691869196920692169226923692469256926692769286929693069316932693369346935693669376938693969406941694269436944694569466947694869496950695169526953695469556956695769586959696069616962696369646965696669676968696969706971697269736974697569766977697869796980698169826983698469856986698769886989699069916992699369946995699669976998699970007001700270037004700570067007700870097010701170127013701470157016701770187019702070217022702370247025702670277028702970307031703270337034703570367037703870397040704170427043704470457046704770487049705070517052705370547055705670577058705970607061706270637064706570667067706870697070707170727073707470757076707770787079708070817082708370847085708670877088708970907091709270937094709570967097709870997100710171027103710471057106710771087109711071117112711371147115711671177118711971207121712271237124712571267127712871297130713171327133713471357136713771387139714071417142714371447145714671477148714971507151715271537154715571567157715871597160716171627163716471657166716771687169717071717172717371747175717671777178717971807181718271837184718571867187718871897190719171927193719471957196719771987199720072017202720372047205720672077208720972107211721272137214721572167217721872197220722172227223722472257226722772287229723072317232723372347235723672377238723972407241724272437244724572467247724872497250725172527253725472557256725772587259726072617262726372647265726672677268726972707271727272737274727572767277727872797280728172827283728472857286728772887289729072917292729372947295729672977298729973007301730273037304730573067307730873097310731173127313731473157316731773187319732073217322732373247325732673277328732973307331733273337334733573367337733873397340734173427343734473457346734773487349735073517352735373547355735673577358735973607361736273637364736573667367736873697370737173727373737473757376737773787379738073817382738373847385738673877388738973907391739273937394739573967397739873997400740174027403740474057406740774087409741074117412741374147415741674177418741974207421742274237424742574267427742874297430743174327433743474357436743774387439744074417442744374447445744674477448744974507451745274537454745574567457745874597460746174627463746474657466746774687469747074717472747374747475747674777478747974807481748274837484748574867487748874897490749174927493749474957496749774987499750075017502750375047505750675077508750975107511751275137514751575167517751875197520752175227523752475257526752775287529753075317532753375347535753675377538753975407541754275437544754575467547754875497550755175527553755475557556755775587559756075617562756375647565756675677568756975707571757275737574757575767577757875797580758175827583758475857586758775887589759075917592759375947595759675977598759976007601760276037604760576067607760876097610761176127613761476157616761776187619762076217622762376247625762676277628762976307631763276337634763576367637763876397640764176427643764476457646764776487649765076517652765376547655765676577658765976607661766276637664766576667667766876697670767176727673767476757676767776787679768076817682768376847685768676877688768976907691769276937694769576967697769876997700770177027703770477057706770777087709771077117712771377147715771677177718771977207721772277237724772577267727772877297730773177327733773477357736773777387739774077417742774377447745774677477748774977507751775277537754775577567757775877597760776177627763776477657766776777687769777077717772777377747775777677777778777977807781778277837784778577867787778877897790779177927793779477957796779777987799780078017802780378047805780678077808780978107811781278137814781578167817781878197820782178227823782478257826782778287829783078317832783378347835783678377838783978407841784278437844784578467847784878497850785178527853785478557856785778587859786078617862786378647865786678677868786978707871787278737874787578767877787878797880788178827883788478857886788778887889789078917892789378947895789678977898789979007901790279037904790579067907790879097910791179127913791479157916791779187919792079217922792379247925792679277928792979307931793279337934793579367937793879397940794179427943794479457946794779487949795079517952795379547955795679577958795979607961796279637964796579667967796879697970797179727973797479757976797779787979798079817982798379847985798679877988798979907991799279937994799579967997799879998000800180028003800480058006800780088009801080118012801380148015801680178018801980208021802280238024802580268027802880298030803180328033803480358036803780388039804080418042804380448045804680478048804980508051805280538054805580568057805880598060806180628063806480658066806780688069807080718072807380748075807680778078807980808081808280838084808580868087808880898090809180928093809480958096809780988099810081018102810381048105810681078108810981108111811281138114811581168117811881198120812181228123812481258126812781288129813081318132813381348135813681378138813981408141814281438144814581468147814881498150815181528153815481558156815781588159816081618162816381648165816681678168816981708171817281738174817581768177817881798180818181828183818481858186818781888189819081918192819381948195819681978198819982008201820282038204820582068207820882098210821182128213821482158216821782188219822082218222822382248225822682278228822982308231823282338234823582368237823882398240824182428243824482458246824782488249825082518252825382548255825682578258825982608261826282638264826582668267826882698270827182728273827482758276827782788279828082818282828382848285828682878288828982908291829282938294829582968297829882998300830183028303830483058306830783088309831083118312831383148315831683178318831983208321832283238324832583268327832883298330833183328333833483358336833783388339834083418342834383448345834683478348834983508351835283538354835583568357835883598360836183628363836483658366836783688369837083718372837383748375837683778378837983808381838283838384838583868387838883898390839183928393839483958396839783988399840084018402840384048405840684078408840984108411841284138414841584168417841884198420842184228423842484258426842784288429843084318432843384348435843684378438843984408441844284438444844584468447844884498450845184528453845484558456845784588459846084618462846384648465846684678468846984708471847284738474847584768477847884798480848184828483848484858486848784888489849084918492849384948495849684978498849985008501850285038504850585068507850885098510851185128513851485158516851785188519852085218522852385248525852685278528852985308531853285338534853585368537853885398540854185428543854485458546854785488549855085518552855385548555855685578558855985608561856285638564856585668567856885698570857185728573857485758576857785788579858085818582858385848585858685878588858985908591859285938594859585968597859885998600860186028603860486058606860786088609861086118612861386148615861686178618861986208621862286238624862586268627862886298630863186328633863486358636863786388639864086418642864386448645864686478648864986508651865286538654865586568657865886598660866186628663866486658666866786688669867086718672867386748675867686778678867986808681868286838684868586868687868886898690869186928693869486958696869786988699870087018702870387048705870687078708870987108711871287138714871587168717871887198720872187228723872487258726872787288729873087318732873387348735873687378738873987408741874287438744874587468747874887498750875187528753875487558756875787588759876087618762876387648765876687678768876987708771877287738774877587768777877887798780878187828783878487858786878787888789879087918792879387948795879687978798879988008801880288038804880588068807880888098810881188128813881488158816881788188819882088218822882388248825882688278828882988308831883288338834883588368837883888398840884188428843884488458846884788488849885088518852885388548855885688578858885988608861886288638864886588668867886888698870887188728873887488758876887788788879888088818882888388848885888688878888888988908891889288938894889588968897889888998900890189028903890489058906890789088909891089118912891389148915891689178918891989208921892289238924892589268927892889298930893189328933893489358936893789388939894089418942894389448945894689478948894989508951895289538954895589568957895889598960896189628963896489658966896789688969897089718972897389748975897689778978897989808981898289838984898589868987898889898990899189928993899489958996899789988999900090019002900390049005900690079008900990109011901290139014901590169017901890199020902190229023902490259026902790289029903090319032903390349035903690379038903990409041904290439044904590469047904890499050905190529053905490559056905790589059906090619062906390649065906690679068906990709071907290739074907590769077907890799080908190829083908490859086908790889089909090919092909390949095909690979098909991009101910291039104910591069107910891099110911191129113911491159116911791189119912091219122912391249125912691279128912991309131913291339134913591369137913891399140914191429143914491459146914791489149915091519152915391549155915691579158915991609161916291639164916591669167916891699170917191729173917491759176917791789179918091819182918391849185918691879188918991909191919291939194919591969197919891999200920192029203920492059206920792089209921092119212921392149215921692179218921992209221922292239224922592269227922892299230923192329233923492359236923792389239924092419242924392449245924692479248924992509251925292539254925592569257925892599260926192629263926492659266926792689269927092719272927392749275927692779278927992809281928292839284928592869287928892899290929192929293929492959296929792989299930093019302930393049305930693079308930993109311931293139314931593169317931893199320932193229323932493259326932793289329933093319332933393349335933693379338933993409341934293439344934593469347934893499350935193529353935493559356935793589359936093619362936393649365936693679368936993709371937293739374937593769377937893799380938193829383938493859386938793889389939093919392939393949395939693979398939994009401940294039404940594069407940894099410941194129413941494159416941794189419942094219422942394249425942694279428942994309431943294339434943594369437943894399440944194429443944494459446944794489449945094519452945394549455945694579458945994609461946294639464946594669467946894699470947194729473947494759476947794789479948094819482948394849485948694879488948994909491949294939494949594969497949894999500950195029503950495059506950795089509951095119512951395149515951695179518951995209521952295239524952595269527952895299530953195329533953495359536953795389539954095419542954395449545954695479548954995509551955295539554955595569557955895599560956195629563956495659566956795689569957095719572957395749575957695779578957995809581958295839584958595869587958895899590959195929593959495959596959795989599960096019602960396049605960696079608960996109611961296139614961596169617961896199620962196229623962496259626962796289629963096319632963396349635963696379638963996409641964296439644964596469647964896499650965196529653965496559656965796589659966096619662966396649665966696679668966996709671967296739674967596769677967896799680968196829683968496859686968796889689969096919692969396949695969696979698969997009701970297039704970597069707970897099710971197129713971497159716971797189719972097219722972397249725972697279728972997309731973297339734973597369737973897399740974197429743974497459746974797489749975097519752975397549755975697579758975997609761976297639764976597669767976897699770977197729773977497759776977797789779978097819782978397849785978697879788978997909791979297939794979597969797979897999800980198029803980498059806980798089809981098119812981398149815981698179818981998209821982298239824982598269827982898299830983198329833983498359836983798389839984098419842984398449845984698479848984998509851985298539854985598569857985898599860986198629863986498659866986798689869987098719872987398749875987698779878987998809881988298839884988598869887988898899890989198929893989498959896989798989899990099019902990399049905990699079908990999109911991299139914991599169917991899199920992199229923992499259926992799289929993099319932993399349935993699379938993999409941994299439944994599469947994899499950995199529953995499559956995799589959996099619962996399649965996699679968996999709971997299739974997599769977997899799980998199829983998499859986998799889989999099919992999399949995999699979998999910000100011000210003100041000510006100071000810009100101001110012100131001410015100161001710018100191002010021100221002310024100251002610027100281002910030100311003210033100341003510036100371003810039100401004110042100431004410045100461004710048100491005010051100521005310054100551005610057100581005910060100611006210063100641006510066100671006810069100701007110072100731007410075100761007710078100791008010081100821008310084100851008610087100881008910090100911009210093100941009510096100971009810099101001010110102101031010410105101061010710108101091011010111101121011310114101151011610117101181011910120101211012210123101241012510126101271012810129101301013110132101331013410135101361013710138101391014010141101421014310144101451014610147101481014910150101511015210153101541015510156101571015810159101601016110162101631016410165101661016710168101691017010171101721017310174101751017610177101781017910180101811018210183101841018510186101871018810189101901019110192101931019410195101961019710198101991020010201102021020310204102051020610207102081020910210102111021210213102141021510216102171021810219102201022110222102231022410225102261022710228102291023010231102321023310234102351023610237102381023910240102411024210243102441024510246102471024810249102501025110252102531025410255102561025710258102591026010261102621026310264102651026610267102681026910270102711027210273102741027510276102771027810279102801028110282102831028410285102861028710288102891029010291102921029310294102951029610297102981029910300103011030210303103041030510306103071030810309103101031110312103131031410315103161031710318103191032010321103221032310324103251032610327103281032910330103311033210333103341033510336103371033810339103401034110342103431034410345103461034710348103491035010351103521035310354103551035610357103581035910360103611036210363103641036510366103671036810369103701037110372103731037410375103761037710378103791038010381103821038310384103851038610387103881038910390103911039210393103941039510396103971039810399104001040110402104031040410405104061040710408104091041010411104121041310414104151041610417104181041910420104211042210423104241042510426104271042810429104301043110432104331043410435104361043710438104391044010441104421044310444104451044610447104481044910450104511045210453104541045510456104571045810459104601046110462104631046410465104661046710468104691047010471104721047310474104751047610477104781047910480104811048210483104841048510486104871048810489104901049110492104931049410495104961049710498104991050010501105021050310504105051050610507105081050910510105111051210513105141051510516105171051810519105201052110522105231052410525105261052710528105291053010531105321053310534105351053610537105381053910540105411054210543105441054510546105471054810549105501055110552105531055410555105561055710558105591056010561105621056310564105651056610567105681056910570105711057210573105741057510576105771057810579105801058110582105831058410585105861058710588105891059010591105921059310594105951059610597105981059910600106011060210603106041060510606106071060810609106101061110612106131061410615106161061710618106191062010621106221062310624106251062610627106281062910630106311063210633106341063510636106371063810639106401064110642106431064410645106461064710648106491065010651106521065310654106551065610657106581065910660106611066210663106641066510666106671066810669106701067110672106731067410675106761067710678106791068010681106821068310684106851068610687106881068910690106911069210693106941069510696106971069810699107001070110702107031070410705107061070710708107091071010711107121071310714107151071610717107181071910720107211072210723107241072510726107271072810729107301073110732107331073410735107361073710738107391074010741107421074310744107451074610747107481074910750107511075210753107541075510756107571075810759107601076110762107631076410765107661076710768107691077010771107721077310774107751077610777107781077910780107811078210783107841078510786107871078810789107901079110792107931079410795107961079710798107991080010801108021080310804108051080610807108081080910810108111081210813108141081510816108171081810819108201082110822108231082410825108261082710828108291083010831108321083310834108351083610837108381083910840108411084210843108441084510846108471084810849108501085110852108531085410855108561085710858108591086010861108621086310864108651086610867108681086910870108711087210873108741087510876108771087810879108801088110882108831088410885108861088710888108891089010891108921089310894108951089610897108981089910900109011090210903109041090510906109071090810909109101091110912109131091410915109161091710918109191092010921109221092310924109251092610927109281092910930109311093210933109341093510936109371093810939109401094110942109431094410945109461094710948109491095010951109521095310954109551095610957109581095910960109611096210963109641096510966109671096810969109701097110972109731097410975109761097710978109791098010981109821098310984109851098610987109881098910990109911099210993109941099510996109971099810999110001100111002110031100411005110061100711008110091101011011110121101311014110151101611017110181101911020110211102211023110241102511026110271102811029110301103111032110331103411035110361103711038110391104011041110421104311044110451104611047110481104911050110511105211053110541105511056110571105811059110601106111062110631106411065110661106711068110691107011071110721107311074110751107611077110781107911080110811108211083110841108511086110871108811089110901109111092110931109411095110961109711098110991110011101111021110311104111051110611107111081110911110111111111211113111141111511116111171111811119111201112111122111231112411125111261112711128111291113011131111321113311134111351113611137111381113911140111411114211143111441114511146111471114811149111501115111152111531115411155111561115711158111591116011161111621116311164111651116611167111681116911170111711117211173111741117511176111771117811179111801118111182111831118411185111861118711188111891119011191111921119311194111951119611197111981119911200112011120211203112041120511206112071120811209112101121111212112131121411215112161121711218112191122011221112221122311224112251122611227112281122911230112311123211233112341123511236112371123811239112401124111242112431124411245112461124711248112491125011251112521125311254112551125611257112581125911260112611126211263112641126511266112671126811269112701127111272112731127411275112761127711278112791128011281112821128311284112851128611287112881128911290112911129211293112941129511296112971129811299113001130111302113031130411305113061130711308113091131011311113121131311314113151131611317113181131911320113211132211323113241132511326113271132811329113301133111332113331133411335113361133711338113391134011341113421134311344113451134611347113481134911350113511135211353113541135511356113571135811359113601136111362113631136411365113661136711368113691137011371113721137311374113751137611377113781137911380113811138211383113841138511386113871138811389113901139111392113931139411395113961139711398113991140011401114021140311404114051140611407114081140911410114111141211413114141141511416114171141811419114201142111422114231142411425114261142711428114291143011431114321143311434114351143611437114381143911440114411144211443114441144511446114471144811449114501145111452114531145411455114561145711458114591146011461114621146311464114651146611467114681146911470114711147211473114741147511476114771147811479114801148111482114831148411485114861148711488114891149011491114921149311494114951149611497114981149911500115011150211503115041150511506115071150811509115101151111512115131151411515115161151711518115191152011521115221152311524115251152611527115281152911530115311153211533115341153511536115371153811539115401154111542115431154411545115461154711548115491155011551115521155311554115551155611557115581155911560115611156211563115641156511566115671156811569115701157111572115731157411575115761157711578115791158011581115821158311584115851158611587115881158911590115911159211593115941159511596115971159811599116001160111602116031160411605116061160711608116091161011611116121161311614116151161611617116181161911620116211162211623116241162511626116271162811629116301163111632116331163411635116361163711638116391164011641116421164311644116451164611647116481164911650116511165211653116541165511656116571165811659116601166111662116631166411665116661166711668116691167011671116721167311674116751167611677116781167911680116811168211683116841168511686116871168811689116901169111692116931169411695116961169711698116991170011701117021170311704117051170611707117081170911710117111171211713117141171511716117171171811719117201172111722117231172411725117261172711728117291173011731117321173311734117351173611737117381173911740117411174211743117441174511746117471174811749117501175111752117531175411755117561175711758117591176011761117621176311764117651176611767117681176911770117711177211773117741177511776117771177811779117801178111782117831178411785117861178711788117891179011791117921179311794117951179611797117981179911800118011180211803118041180511806118071180811809118101181111812118131181411815118161181711818118191182011821118221182311824118251182611827118281182911830118311183211833118341183511836118371183811839118401184111842118431184411845118461184711848118491185011851118521185311854118551185611857118581185911860118611186211863118641186511866118671186811869118701187111872118731187411875118761187711878118791188011881118821188311884118851188611887118881188911890118911189211893118941189511896118971189811899119001190111902119031190411905119061190711908119091191011911119121191311914119151191611917119181191911920119211192211923119241192511926119271192811929119301193111932119331193411935119361193711938119391194011941119421194311944119451194611947119481194911950119511195211953119541195511956119571195811959119601196111962119631196411965119661196711968119691197011971119721197311974119751197611977119781197911980119811198211983119841198511986119871198811989119901199111992119931199411995119961199711998119991200012001120021200312004120051200612007120081200912010120111201212013120141201512016120171201812019120201202112022120231202412025120261202712028120291203012031120321203312034120351203612037120381203912040120411204212043120441204512046120471204812049120501205112052120531205412055120561205712058120591206012061120621206312064120651206612067120681206912070120711207212073120741207512076120771207812079120801208112082120831208412085120861208712088120891209012091120921209312094120951209612097120981209912100121011210212103121041210512106121071210812109121101211112112121131211412115121161211712118121191212012121121221212312124121251212612127121281212912130121311213212133121341213512136121371213812139121401214112142121431214412145121461214712148121491215012151121521215312154121551215612157121581215912160121611216212163121641216512166121671216812169121701217112172121731217412175121761217712178121791218012181121821218312184121851218612187121881218912190121911219212193121941219512196121971219812199122001220112202122031220412205122061220712208122091221012211122121221312214122151221612217122181221912220122211222212223122241222512226122271222812229122301223112232122331223412235122361223712238122391224012241122421224312244122451224612247122481224912250122511225212253122541225512256122571225812259122601226112262122631226412265122661226712268122691227012271122721227312274122751227612277122781227912280122811228212283122841228512286122871228812289122901229112292122931229412295122961229712298122991230012301123021230312304123051230612307123081230912310123111231212313123141231512316123171231812319123201232112322123231232412325123261232712328123291233012331123321233312334123351233612337123381233912340123411234212343123441234512346123471234812349123501235112352123531235412355123561235712358123591236012361123621236312364123651236612367123681236912370123711237212373123741237512376123771237812379123801238112382123831238412385123861238712388123891239012391123921239312394123951239612397123981239912400124011240212403124041240512406124071240812409124101241112412124131241412415124161241712418124191242012421124221242312424124251242612427124281242912430124311243212433124341243512436124371243812439124401244112442124431244412445124461244712448124491245012451124521245312454124551245612457124581245912460124611246212463124641246512466124671246812469124701247112472124731247412475124761247712478124791248012481124821248312484124851248612487124881248912490124911249212493124941249512496124971249812499125001250112502125031250412505125061250712508125091251012511125121251312514125151251612517125181251912520125211252212523125241252512526125271252812529125301253112532125331253412535125361253712538125391254012541125421254312544125451254612547125481254912550125511255212553125541255512556125571255812559125601256112562125631256412565125661256712568125691257012571125721257312574125751257612577125781257912580125811258212583125841258512586125871258812589125901259112592125931259412595125961259712598125991260012601126021260312604126051260612607126081260912610126111261212613126141261512616126171261812619126201262112622126231262412625126261262712628126291263012631126321263312634126351263612637126381263912640126411264212643126441264512646126471264812649126501265112652126531265412655126561265712658126591266012661126621266312664126651266612667126681266912670126711267212673126741267512676126771267812679126801268112682126831268412685126861268712688126891269012691126921269312694126951269612697126981269912700127011270212703127041270512706127071270812709127101271112712127131271412715127161271712718127191272012721127221272312724127251272612727127281272912730127311273212733127341273512736127371273812739127401274112742127431274412745127461274712748127491275012751127521275312754127551275612757127581275912760127611276212763127641276512766127671276812769127701277112772127731277412775127761277712778127791278012781127821278312784127851278612787127881278912790127911279212793127941279512796127971279812799128001280112802128031280412805128061280712808128091281012811128121281312814128151281612817128181281912820128211282212823128241282512826128271282812829128301283112832128331283412835128361283712838128391284012841128421284312844128451284612847128481284912850128511285212853128541285512856128571285812859128601286112862128631286412865128661286712868128691287012871128721287312874128751287612877128781287912880128811288212883128841288512886128871288812889128901289112892128931289412895128961289712898128991290012901129021290312904129051290612907129081290912910129111291212913129141291512916129171291812919129201292112922129231292412925129261292712928129291293012931129321293312934129351293612937129381293912940129411294212943129441294512946129471294812949129501295112952129531295412955129561295712958129591296012961129621296312964129651296612967129681296912970129711297212973129741297512976129771297812979129801298112982129831298412985129861298712988129891299012991129921299312994129951299612997129981299913000130011300213003130041300513006130071300813009130101301113012130131301413015130161301713018130191302013021130221302313024130251302613027130281302913030130311303213033130341303513036130371303813039130401304113042130431304413045130461304713048130491305013051130521305313054130551305613057130581305913060130611306213063130641306513066130671306813069130701307113072130731307413075130761307713078130791308013081130821308313084130851308613087130881308913090130911309213093130941309513096130971309813099131001310113102131031310413105131061310713108131091311013111131121311313114131151311613117131181311913120131211312213123131241312513126131271312813129131301313113132131331313413135131361313713138131391314013141131421314313144131451314613147131481314913150131511315213153131541315513156131571315813159131601316113162131631316413165131661316713168131691317013171131721317313174131751317613177131781317913180131811318213183131841318513186131871318813189131901319113192131931319413195131961319713198131991320013201132021320313204132051320613207132081320913210132111321213213132141321513216132171321813219132201322113222132231322413225132261322713228132291323013231132321323313234132351323613237132381323913240132411324213243132441324513246132471324813249132501325113252132531325413255132561325713258132591326013261132621326313264132651326613267132681326913270132711327213273132741327513276132771327813279132801328113282132831328413285132861328713288132891329013291132921329313294132951329613297132981329913300133011330213303133041330513306133071330813309133101331113312133131331413315133161331713318133191332013321133221332313324133251332613327133281332913330133311333213333133341333513336133371333813339133401334113342133431334413345133461334713348133491335013351133521335313354133551335613357133581335913360133611336213363133641336513366133671336813369133701337113372133731337413375133761337713378133791338013381133821338313384133851338613387133881338913390133911339213393133941339513396133971339813399134001340113402134031340413405134061340713408134091341013411134121341313414134151341613417134181341913420134211342213423134241342513426134271342813429134301343113432134331343413435134361343713438134391344013441134421344313444134451344613447134481344913450134511345213453134541345513456134571345813459134601346113462134631346413465134661346713468134691347013471134721347313474134751347613477134781347913480134811348213483134841348513486134871348813489134901349113492134931349413495134961349713498134991350013501135021350313504135051350613507135081350913510135111351213513135141351513516135171351813519135201352113522135231352413525135261352713528135291353013531135321353313534135351353613537135381353913540135411354213543135441354513546135471354813549135501355113552135531355413555135561355713558135591356013561135621356313564135651356613567135681356913570135711357213573135741357513576135771357813579135801358113582135831358413585135861358713588135891359013591135921359313594135951359613597135981359913600136011360213603136041360513606136071360813609136101361113612136131361413615136161361713618136191362013621136221362313624136251362613627136281362913630136311363213633136341363513636136371363813639136401364113642136431364413645136461364713648136491365013651136521365313654136551365613657136581365913660136611366213663136641366513666136671366813669136701367113672136731367413675136761367713678136791368013681136821368313684136851368613687136881368913690136911369213693136941369513696136971369813699137001370113702137031370413705137061370713708137091371013711137121371313714137151371613717137181371913720137211372213723137241372513726137271372813729137301373113732137331373413735137361373713738137391374013741137421374313744137451374613747137481374913750137511375213753137541375513756137571375813759137601376113762137631376413765137661376713768137691377013771137721377313774137751377613777137781377913780137811378213783137841378513786137871378813789137901379113792137931379413795137961379713798137991380013801138021380313804138051380613807138081380913810138111381213813138141381513816138171381813819138201382113822138231382413825138261382713828138291383013831138321383313834138351383613837138381383913840138411384213843138441384513846138471384813849138501385113852138531385413855138561385713858138591386013861138621386313864138651386613867138681386913870138711387213873138741387513876138771387813879138801388113882138831388413885138861388713888138891389013891138921389313894138951389613897138981389913900139011390213903139041390513906139071390813909139101391113912139131391413915139161391713918139191392013921139221392313924139251392613927139281392913930139311393213933139341393513936139371393813939139401394113942139431394413945139461394713948139491395013951139521395313954139551395613957139581395913960139611396213963139641396513966139671396813969139701397113972139731397413975139761397713978139791398013981139821398313984139851398613987139881398913990139911399213993139941399513996139971399813999140001400114002140031400414005140061400714008140091401014011140121401314014140151401614017140181401914020140211402214023140241402514026140271402814029140301403114032140331403414035140361403714038140391404014041140421404314044140451404614047140481404914050140511405214053140541405514056140571405814059140601406114062140631406414065140661406714068140691407014071140721407314074140751407614077140781407914080140811408214083140841408514086140871408814089140901409114092140931409414095140961409714098140991410014101141021410314104141051410614107141081410914110141111411214113141141411514116141171411814119141201412114122141231412414125141261412714128141291413014131141321413314134141351413614137141381413914140141411414214143141441414514146141471414814149141501415114152141531415414155141561415714158141591416014161141621416314164141651416614167141681416914170141711417214173141741417514176141771417814179141801418114182141831418414185141861418714188141891419014191141921419314194141951419614197141981419914200142011420214203142041420514206142071420814209142101421114212142131421414215142161421714218142191422014221142221422314224142251422614227142281422914230142311423214233142341423514236142371423814239142401424114242142431424414245142461424714248142491425014251142521425314254142551425614257142581425914260142611426214263142641426514266142671426814269142701427114272142731427414275142761427714278142791428014281142821428314284142851428614287142881428914290142911429214293142941429514296142971429814299143001430114302143031430414305143061430714308143091431014311143121431314314143151431614317143181431914320143211432214323143241432514326143271432814329143301433114332143331433414335143361433714338143391434014341143421434314344143451434614347143481434914350143511435214353143541435514356143571435814359143601436114362143631436414365143661436714368143691437014371143721437314374143751437614377143781437914380143811438214383143841438514386143871438814389143901439114392143931439414395143961439714398143991440014401144021440314404144051440614407144081440914410144111441214413144141441514416144171441814419144201442114422144231442414425144261442714428144291443014431144321443314434144351443614437144381443914440144411444214443144441444514446144471444814449144501445114452144531445414455144561445714458144591446014461144621446314464144651446614467144681446914470144711447214473144741447514476144771447814479144801448114482144831448414485144861448714488144891449014491144921449314494144951449614497144981449914500145011450214503145041450514506145071450814509145101451114512145131451414515145161451714518145191452014521145221452314524145251452614527145281452914530145311453214533145341453514536145371453814539145401454114542145431454414545145461454714548145491455014551145521455314554145551455614557145581455914560145611456214563145641456514566145671456814569145701457114572145731457414575145761457714578145791458014581145821458314584145851458614587145881458914590145911459214593145941459514596145971459814599146001460114602146031460414605146061460714608146091461014611146121461314614146151461614617146181461914620146211462214623146241462514626146271462814629146301463114632146331463414635146361463714638146391464014641146421464314644146451464614647146481464914650146511465214653146541465514656146571465814659146601466114662146631466414665146661466714668146691467014671146721467314674146751467614677146781467914680146811468214683146841468514686146871468814689146901469114692146931469414695146961469714698146991470014701147021470314704147051470614707147081470914710147111471214713147141471514716147171471814719147201472114722147231472414725147261472714728147291473014731147321473314734147351473614737147381473914740147411474214743147441474514746147471474814749147501475114752147531475414755147561475714758147591476014761147621476314764147651476614767147681476914770147711477214773147741477514776147771477814779147801478114782147831478414785147861478714788147891479014791147921479314794147951479614797147981479914800148011480214803148041480514806148071480814809148101481114812148131481414815148161481714818148191482014821148221482314824148251482614827148281482914830148311483214833148341483514836148371483814839148401484114842148431484414845148461484714848148491485014851148521485314854148551485614857148581485914860148611486214863148641486514866148671486814869148701487114872148731487414875148761487714878148791488014881148821488314884148851488614887148881488914890148911489214893148941489514896148971489814899149001490114902149031490414905149061490714908149091491014911149121491314914149151491614917149181491914920149211492214923149241492514926149271492814929149301493114932149331493414935149361493714938149391494014941149421494314944149451494614947149481494914950149511495214953149541495514956149571495814959149601496114962149631496414965149661496714968149691497014971149721497314974149751497614977149781497914980149811498214983149841498514986149871498814989149901499114992149931499414995149961499714998149991500015001150021500315004150051500615007150081500915010150111501215013150141501515016150171501815019150201502115022150231502415025150261502715028150291503015031150321503315034150351503615037150381503915040150411504215043150441504515046150471504815049150501505115052150531505415055150561505715058150591506015061150621506315064150651506615067150681506915070150711507215073150741507515076150771507815079150801508115082150831508415085150861508715088150891509015091150921509315094150951509615097150981509915100151011510215103151041510515106151071510815109151101511115112151131511415115151161511715118151191512015121151221512315124151251512615127151281512915130151311513215133151341513515136151371513815139151401514115142151431514415145151461514715148151491515015151151521515315154151551515615157151581515915160151611516215163151641516515166151671516815169151701517115172151731517415175151761517715178151791518015181151821518315184151851518615187151881518915190151911519215193151941519515196151971519815199152001520115202152031520415205152061520715208152091521015211152121521315214152151521615217152181521915220152211522215223152241522515226152271522815229152301523115232152331523415235152361523715238152391524015241152421524315244152451524615247152481524915250152511525215253152541525515256152571525815259152601526115262152631526415265152661526715268152691527015271152721527315274152751527615277152781527915280152811528215283152841528515286152871528815289152901529115292152931529415295152961529715298152991530015301153021530315304153051530615307153081530915310153111531215313153141531515316153171531815319153201532115322153231532415325153261532715328153291533015331153321533315334153351533615337153381533915340153411534215343153441534515346153471534815349153501535115352153531535415355153561535715358153591536015361153621536315364153651536615367153681536915370153711537215373153741537515376153771537815379153801538115382153831538415385153861538715388153891539015391153921539315394153951539615397153981539915400154011540215403154041540515406154071540815409154101541115412154131541415415154161541715418154191542015421154221542315424154251542615427154281542915430154311543215433154341543515436154371543815439154401544115442154431544415445154461544715448154491545015451154521545315454154551545615457154581545915460154611546215463154641546515466154671546815469154701547115472154731547415475154761547715478154791548015481154821548315484154851548615487154881548915490154911549215493154941549515496154971549815499155001550115502155031550415505155061550715508155091551015511155121551315514155151551615517155181551915520155211552215523155241552515526155271552815529155301553115532155331553415535155361553715538155391554015541155421554315544155451554615547155481554915550155511555215553155541555515556155571555815559155601556115562155631556415565155661556715568155691557015571155721557315574155751557615577155781557915580155811558215583155841558515586155871558815589155901559115592155931559415595155961559715598155991560015601156021560315604156051560615607156081560915610156111561215613156141561515616156171561815619156201562115622156231562415625156261562715628156291563015631156321563315634156351563615637156381563915640156411564215643156441564515646156471564815649156501565115652156531565415655156561565715658156591566015661156621566315664156651566615667156681566915670156711567215673156741567515676156771567815679156801568115682156831568415685156861568715688156891569015691156921569315694156951569615697156981569915700157011570215703157041570515706157071570815709157101571115712157131571415715157161571715718157191572015721157221572315724157251572615727157281572915730157311573215733157341573515736157371573815739157401574115742157431574415745157461574715748157491575015751157521575315754157551575615757157581575915760157611576215763157641576515766157671576815769157701577115772157731577415775157761577715778157791578015781157821578315784157851578615787157881578915790157911579215793157941579515796157971579815799158001580115802158031580415805158061580715808158091581015811158121581315814158151581615817158181581915820158211582215823158241582515826158271582815829158301583115832158331583415835158361583715838158391584015841158421584315844158451584615847158481584915850158511585215853158541585515856158571585815859158601586115862158631586415865158661586715868158691587015871158721587315874158751587615877158781587915880158811588215883158841588515886158871588815889158901589115892158931589415895158961589715898158991590015901159021590315904159051590615907159081590915910159111591215913159141591515916159171591815919159201592115922159231592415925159261592715928159291593015931159321593315934159351593615937159381593915940159411594215943159441594515946159471594815949159501595115952159531595415955159561595715958159591596015961159621596315964159651596615967159681596915970159711597215973159741597515976159771597815979159801598115982159831598415985159861598715988159891599015991159921599315994159951599615997159981599916000160011600216003160041600516006160071600816009160101601116012160131601416015160161601716018160191602016021160221602316024160251602616027160281602916030160311603216033160341603516036160371603816039160401604116042160431604416045160461604716048160491605016051160521605316054160551605616057160581605916060160611606216063160641606516066160671606816069160701607116072160731607416075160761607716078160791608016081160821608316084160851608616087160881608916090160911609216093160941609516096160971609816099161001610116102161031610416105161061610716108161091611016111161121611316114161151611616117161181611916120161211612216123161241612516126161271612816129161301613116132161331613416135161361613716138161391614016141161421614316144161451614616147161481614916150161511615216153161541615516156161571615816159161601616116162161631616416165161661616716168161691617016171161721617316174161751617616177161781617916180161811618216183161841618516186161871618816189161901619116192161931619416195161961619716198161991620016201162021620316204162051620616207162081620916210162111621216213162141621516216162171621816219162201622116222162231622416225162261622716228162291623016231162321623316234162351623616237162381623916240162411624216243162441624516246162471624816249162501625116252162531625416255162561625716258162591626016261162621626316264162651626616267162681626916270162711627216273162741627516276162771627816279162801628116282162831628416285162861628716288162891629016291162921629316294162951629616297162981629916300163011630216303163041630516306163071630816309163101631116312163131631416315163161631716318163191632016321163221632316324163251632616327163281632916330163311633216333163341633516336163371633816339163401634116342163431634416345163461634716348163491635016351163521635316354163551635616357163581635916360163611636216363163641636516366163671636816369163701637116372163731637416375163761637716378163791638016381163821638316384163851638616387163881638916390163911639216393163941639516396163971639816399164001640116402164031640416405164061640716408164091641016411164121641316414164151641616417164181641916420164211642216423164241642516426164271642816429164301643116432164331643416435164361643716438164391644016441164421644316444164451644616447164481644916450164511645216453164541645516456164571645816459164601646116462164631646416465164661646716468164691647016471164721647316474164751647616477164781647916480164811648216483164841648516486164871648816489164901649116492164931649416495164961649716498164991650016501165021650316504165051650616507165081650916510165111651216513165141651516516165171651816519165201652116522165231652416525165261652716528165291653016531165321653316534165351653616537165381653916540165411654216543165441654516546165471654816549165501655116552165531655416555165561655716558165591656016561165621656316564165651656616567165681656916570165711657216573165741657516576165771657816579165801658116582165831658416585165861658716588165891659016591165921659316594165951659616597165981659916600166011660216603166041660516606166071660816609166101661116612166131661416615166161661716618166191662016621166221662316624166251662616627166281662916630166311663216633166341663516636166371663816639166401664116642166431664416645166461664716648166491665016651166521665316654166551665616657166581665916660166611666216663166641666516666166671666816669166701667116672166731667416675166761667716678166791668016681166821668316684166851668616687166881668916690166911669216693166941669516696166971669816699167001670116702167031670416705167061670716708167091671016711167121671316714167151671616717167181671916720167211672216723167241672516726167271672816729167301673116732167331673416735167361673716738167391674016741167421674316744167451674616747167481674916750167511675216753167541675516756167571675816759167601676116762167631676416765167661676716768167691677016771167721677316774167751677616777167781677916780167811678216783167841678516786167871678816789167901679116792167931679416795167961679716798167991680016801168021680316804168051680616807168081680916810168111681216813168141681516816168171681816819168201682116822168231682416825168261682716828168291683016831168321683316834168351683616837168381683916840168411684216843168441684516846168471684816849168501685116852168531685416855168561685716858168591686016861168621686316864168651686616867168681686916870168711687216873168741687516876168771687816879168801688116882168831688416885168861688716888168891689016891168921689316894168951689616897168981689916900169011690216903169041690516906169071690816909169101691116912169131691416915169161691716918169191692016921169221692316924169251692616927169281692916930169311693216933169341693516936169371693816939169401694116942169431694416945169461694716948169491695016951169521695316954169551695616957169581695916960169611696216963169641696516966169671696816969169701697116972169731697416975169761697716978169791698016981169821698316984169851698616987169881698916990169911699216993169941699516996169971699816999170001700117002170031700417005170061700717008170091701017011170121701317014170151701617017170181701917020170211702217023170241702517026170271702817029170301703117032170331703417035170361703717038170391704017041170421704317044170451704617047170481704917050170511705217053170541705517056170571705817059170601706117062170631706417065170661706717068170691707017071170721707317074170751707617077170781707917080170811708217083170841708517086170871708817089170901709117092170931709417095170961709717098170991710017101171021710317104171051710617107171081710917110171111711217113171141711517116171171711817119171201712117122171231712417125171261712717128171291713017131171321713317134171351713617137171381713917140171411714217143171441714517146171471714817149171501715117152171531715417155171561715717158171591716017161171621716317164171651716617167171681716917170171711717217173171741717517176171771717817179171801718117182171831718417185171861718717188171891719017191171921719317194171951719617197171981719917200172011720217203172041720517206172071720817209172101721117212172131721417215172161721717218172191722017221172221722317224172251722617227172281722917230172311723217233172341723517236172371723817239172401724117242172431724417245172461724717248172491725017251172521725317254172551725617257172581725917260172611726217263172641726517266172671726817269172701727117272172731727417275172761727717278172791728017281172821728317284172851728617287172881728917290172911729217293172941729517296172971729817299173001730117302173031730417305173061730717308173091731017311173121731317314173151731617317173181731917320173211732217323173241732517326173271732817329173301733117332173331733417335173361733717338173391734017341173421734317344173451734617347173481734917350173511735217353173541735517356173571735817359173601736117362173631736417365173661736717368173691737017371173721737317374173751737617377173781737917380173811738217383173841738517386173871738817389173901739117392173931739417395173961739717398173991740017401174021740317404174051740617407174081740917410174111741217413174141741517416174171741817419174201742117422174231742417425174261742717428174291743017431174321743317434174351743617437174381743917440174411744217443174441744517446174471744817449174501745117452174531745417455174561745717458174591746017461174621746317464174651746617467174681746917470174711747217473174741747517476174771747817479174801748117482174831748417485174861748717488174891749017491174921749317494174951749617497174981749917500175011750217503175041750517506175071750817509175101751117512175131751417515175161751717518175191752017521175221752317524175251752617527175281752917530175311753217533175341753517536175371753817539175401754117542175431754417545175461754717548175491755017551175521755317554175551755617557175581755917560175611756217563175641756517566175671756817569175701757117572175731757417575175761757717578175791758017581175821758317584175851758617587175881758917590175911759217593175941759517596175971759817599176001760117602176031760417605176061760717608176091761017611176121761317614176151761617617176181761917620176211762217623176241762517626176271762817629176301763117632176331763417635176361763717638176391764017641176421764317644176451764617647176481764917650176511765217653176541765517656176571765817659176601766117662176631766417665176661766717668176691767017671176721767317674176751767617677176781767917680176811768217683176841768517686176871768817689176901769117692176931769417695176961769717698176991770017701177021770317704177051770617707177081770917710177111771217713177141771517716177171771817719177201772117722177231772417725177261772717728177291773017731177321773317734177351773617737177381773917740177411774217743177441774517746177471774817749177501775117752177531775417755177561775717758177591776017761177621776317764177651776617767177681776917770177711777217773177741777517776177771777817779177801778117782177831778417785177861778717788177891779017791177921779317794177951779617797177981779917800178011780217803178041780517806178071780817809178101781117812178131781417815178161781717818178191782017821178221782317824178251782617827178281782917830178311783217833178341783517836178371783817839178401784117842178431784417845178461784717848178491785017851178521785317854178551785617857178581785917860178611786217863178641786517866178671786817869178701787117872178731787417875178761787717878178791788017881178821788317884178851788617887178881788917890178911789217893178941789517896178971789817899179001790117902179031790417905179061790717908179091791017911179121791317914179151791617917179181791917920179211792217923179241792517926179271792817929179301793117932179331793417935179361793717938179391794017941179421794317944179451794617947179481794917950179511795217953179541795517956179571795817959179601796117962179631796417965179661796717968179691797017971179721797317974179751797617977179781797917980179811798217983179841798517986179871798817989179901799117992179931799417995179961799717998179991800018001180021800318004180051800618007180081800918010180111801218013180141801518016180171801818019180201802118022180231802418025180261802718028180291803018031180321803318034180351803618037180381803918040180411804218043180441804518046180471804818049180501805118052180531805418055180561805718058180591806018061180621806318064180651806618067180681806918070180711807218073180741807518076180771807818079180801808118082180831808418085180861808718088180891809018091180921809318094180951809618097180981809918100181011810218103181041810518106181071810818109181101811118112181131811418115181161811718118181191812018121181221812318124181251812618127181281812918130181311813218133181341813518136181371813818139181401814118142181431814418145181461814718148181491815018151181521815318154181551815618157181581815918160181611816218163181641816518166181671816818169181701817118172181731817418175181761817718178181791818018181181821818318184181851818618187181881818918190181911819218193181941819518196181971819818199182001820118202182031820418205182061820718208182091821018211182121821318214182151821618217182181821918220182211822218223182241822518226182271822818229182301823118232182331823418235182361823718238182391824018241182421824318244182451824618247182481824918250182511825218253182541825518256182571825818259182601826118262182631826418265182661826718268182691827018271182721827318274182751827618277182781827918280182811828218283182841828518286182871828818289182901829118292182931829418295182961829718298182991830018301183021830318304183051830618307183081830918310183111831218313183141831518316183171831818319183201832118322183231832418325183261832718328183291833018331183321833318334183351833618337183381833918340183411834218343183441834518346183471834818349183501835118352183531835418355183561835718358183591836018361183621836318364183651836618367183681836918370183711837218373183741837518376183771837818379183801838118382183831838418385183861838718388183891839018391183921839318394183951839618397183981839918400184011840218403184041840518406184071840818409184101841118412184131841418415184161841718418184191842018421184221842318424184251842618427184281842918430184311843218433184341843518436184371843818439184401844118442184431844418445184461844718448184491845018451184521845318454184551845618457184581845918460184611846218463184641846518466184671846818469184701847118472184731847418475184761847718478184791848018481184821848318484184851848618487184881848918490184911849218493184941849518496184971849818499185001850118502185031850418505185061850718508185091851018511185121851318514185151851618517185181851918520185211852218523185241852518526185271852818529185301853118532185331853418535185361853718538185391854018541185421854318544185451854618547185481854918550185511855218553185541855518556185571855818559185601856118562185631856418565185661856718568185691857018571185721857318574185751857618577185781857918580185811858218583185841858518586185871858818589185901859118592185931859418595185961859718598185991860018601186021860318604186051860618607186081860918610186111861218613186141861518616186171861818619186201862118622186231862418625186261862718628186291863018631186321863318634186351863618637186381863918640186411864218643186441864518646186471864818649186501865118652186531865418655186561865718658186591866018661186621866318664186651866618667186681866918670186711867218673186741867518676186771867818679186801868118682186831868418685186861868718688186891869018691186921869318694186951869618697186981869918700187011870218703187041870518706187071870818709187101871118712187131871418715187161871718718187191872018721187221872318724187251872618727187281872918730187311873218733187341873518736187371873818739187401874118742187431874418745187461874718748187491875018751187521875318754187551875618757187581875918760187611876218763187641876518766187671876818769187701877118772187731877418775187761877718778187791878018781187821878318784187851878618787187881878918790187911879218793187941879518796187971879818799188001880118802188031880418805188061880718808188091881018811188121881318814188151881618817188181881918820188211882218823188241882518826188271882818829188301883118832188331883418835188361883718838188391884018841188421884318844188451884618847188481884918850188511885218853188541885518856188571885818859188601886118862188631886418865188661886718868188691887018871188721887318874188751887618877188781887918880188811888218883188841888518886188871888818889188901889118892188931889418895188961889718898188991890018901189021890318904189051890618907189081890918910189111891218913189141891518916189171891818919189201892118922189231892418925189261892718928189291893018931189321893318934189351893618937189381893918940189411894218943189441894518946189471894818949189501895118952189531895418955189561895718958189591896018961189621896318964189651896618967189681896918970189711897218973189741897518976189771897818979189801898118982189831898418985189861898718988189891899018991189921899318994189951899618997189981899919000190011900219003190041900519006190071900819009190101901119012190131901419015190161901719018190191902019021190221902319024190251902619027190281902919030190311903219033190341903519036190371903819039190401904119042190431904419045190461904719048190491905019051190521905319054190551905619057190581905919060190611906219063190641906519066190671906819069190701907119072190731907419075190761907719078190791908019081190821908319084190851908619087190881908919090190911909219093190941909519096190971909819099191001910119102191031910419105191061910719108191091911019111191121911319114191151911619117191181911919120191211912219123191241912519126191271912819129191301913119132191331913419135191361913719138191391914019141191421914319144191451914619147191481914919150191511915219153191541915519156191571915819159191601916119162191631916419165191661916719168191691917019171191721917319174191751917619177191781917919180191811918219183191841918519186191871918819189191901919119192191931919419195191961919719198191991920019201192021920319204192051920619207192081920919210192111921219213192141921519216192171921819219192201922119222192231922419225192261922719228192291923019231192321923319234192351923619237192381923919240192411924219243192441924519246192471924819249192501925119252192531925419255192561925719258192591926019261192621926319264192651926619267192681926919270192711927219273192741927519276192771927819279192801928119282192831928419285192861928719288192891929019291192921929319294192951929619297192981929919300193011930219303193041930519306193071930819309193101931119312193131931419315193161931719318193191932019321193221932319324193251932619327193281932919330193311933219333193341933519336193371933819339193401934119342193431934419345193461934719348193491935019351193521935319354193551935619357193581935919360193611936219363193641936519366193671936819369193701937119372193731937419375193761937719378193791938019381193821938319384193851938619387193881938919390193911939219393193941939519396193971939819399194001940119402194031940419405194061940719408194091941019411194121941319414194151941619417194181941919420194211942219423194241942519426194271942819429194301943119432194331943419435194361943719438194391944019441194421944319444194451944619447194481944919450194511945219453194541945519456194571945819459194601946119462194631946419465194661946719468194691947019471194721947319474194751947619477194781947919480194811948219483194841948519486194871948819489194901949119492194931949419495194961949719498194991950019501195021950319504195051950619507195081950919510195111951219513195141951519516195171951819519195201952119522195231952419525195261952719528195291953019531195321953319534195351953619537195381953919540195411954219543195441954519546195471954819549195501955119552195531955419555195561955719558195591956019561195621956319564195651956619567195681956919570195711957219573195741957519576195771957819579195801958119582195831958419585195861958719588195891959019591195921959319594195951959619597195981959919600196011960219603196041960519606196071960819609196101961119612196131961419615196161961719618196191962019621196221962319624196251962619627196281962919630196311963219633196341963519636196371963819639196401964119642196431964419645196461964719648196491965019651196521965319654196551965619657196581965919660196611966219663196641966519666196671966819669196701967119672196731967419675196761967719678196791968019681196821968319684196851968619687196881968919690196911969219693196941969519696196971969819699197001970119702197031970419705197061970719708197091971019711197121971319714197151971619717197181971919720197211972219723197241972519726197271972819729197301973119732197331973419735197361973719738197391974019741197421974319744197451974619747197481974919750197511975219753197541975519756197571975819759197601976119762197631976419765197661976719768197691977019771197721977319774197751977619777197781977919780197811978219783197841978519786197871978819789197901979119792197931979419795197961979719798197991980019801198021980319804198051980619807198081980919810198111981219813198141981519816198171981819819198201982119822198231982419825198261982719828198291983019831198321983319834198351983619837198381983919840198411984219843198441984519846198471984819849198501985119852198531985419855198561985719858198591986019861198621986319864198651986619867198681986919870198711987219873198741987519876198771987819879198801988119882198831988419885198861988719888198891989019891198921989319894198951989619897198981989919900199011990219903199041990519906199071990819909199101991119912199131991419915199161991719918199191992019921199221992319924199251992619927199281992919930199311993219933199341993519936199371993819939199401994119942199431994419945199461994719948199491995019951199521995319954199551995619957199581995919960199611996219963199641996519966199671996819969199701997119972199731997419975199761997719978199791998019981199821998319984199851998619987199881998919990199911999219993199941999519996199971999819999200002000120002200032000420005200062000720008200092001020011200122001320014200152001620017200182001920020200212002220023200242002520026200272002820029200302003120032200332003420035200362003720038200392004020041200422004320044200452004620047200482004920050200512005220053200542005520056200572005820059200602006120062200632006420065200662006720068200692007020071200722007320074200752007620077200782007920080200812008220083200842008520086200872008820089200902009120092200932009420095200962009720098200992010020101201022010320104201052010620107201082010920110201112011220113201142011520116201172011820119201202012120122201232012420125201262012720128201292013020131201322013320134201352013620137201382013920140201412014220143201442014520146201472014820149201502015120152201532015420155201562015720158201592016020161201622016320164201652016620167201682016920170201712017220173201742017520176201772017820179201802018120182201832018420185201862018720188201892019020191201922019320194201952019620197201982019920200202012020220203202042020520206202072020820209202102021120212202132021420215202162021720218202192022020221202222022320224202252022620227202282022920230202312023220233202342023520236202372023820239202402024120242202432024420245202462024720248202492025020251202522025320254202552025620257202582025920260202612026220263202642026520266202672026820269202702027120272202732027420275202762027720278202792028020281202822028320284202852028620287202882028920290202912029220293202942029520296202972029820299203002030120302203032030420305203062030720308203092031020311203122031320314203152031620317203182031920320203212032220323203242032520326203272032820329203302033120332203332033420335203362033720338203392034020341203422034320344203452034620347203482034920350203512035220353203542035520356203572035820359203602036120362203632036420365203662036720368203692037020371203722037320374203752037620377203782037920380203812038220383203842038520386203872038820389203902039120392203932039420395203962039720398203992040020401204022040320404204052040620407204082040920410204112041220413204142041520416204172041820419204202042120422204232042420425204262042720428204292043020431204322043320434204352043620437204382043920440204412044220443204442044520446204472044820449204502045120452204532045420455204562045720458204592046020461204622046320464204652046620467204682046920470204712047220473204742047520476204772047820479204802048120482204832048420485204862048720488204892049020491204922049320494204952049620497204982049920500205012050220503205042050520506205072050820509205102051120512205132051420515205162051720518205192052020521205222052320524205252052620527205282052920530205312053220533205342053520536205372053820539205402054120542205432054420545205462054720548205492055020551205522055320554205552055620557205582055920560205612056220563205642056520566205672056820569205702057120572205732057420575205762057720578205792058020581205822058320584205852058620587205882058920590205912059220593205942059520596205972059820599206002060120602206032060420605206062060720608206092061020611206122061320614206152061620617206182061920620206212062220623206242062520626206272062820629206302063120632206332063420635206362063720638206392064020641206422064320644206452064620647206482064920650206512065220653206542065520656206572065820659206602066120662206632066420665206662066720668206692067020671206722067320674206752067620677206782067920680206812068220683206842068520686206872068820689206902069120692206932069420695206962069720698206992070020701207022070320704207052070620707207082070920710207112071220713207142071520716207172071820719207202072120722207232072420725207262072720728207292073020731207322073320734207352073620737207382073920740207412074220743207442074520746207472074820749207502075120752207532075420755207562075720758207592076020761207622076320764207652076620767207682076920770207712077220773207742077520776207772077820779207802078120782207832078420785207862078720788207892079020791207922079320794207952079620797207982079920800208012080220803208042080520806208072080820809208102081120812208132081420815208162081720818208192082020821208222082320824208252082620827208282082920830208312083220833208342083520836208372083820839208402084120842208432084420845208462084720848208492085020851208522085320854208552085620857208582085920860208612086220863208642086520866208672086820869208702087120872208732087420875208762087720878208792088020881208822088320884208852088620887208882088920890208912089220893208942089520896208972089820899209002090120902209032090420905209062090720908209092091020911209122091320914209152091620917209182091920920209212092220923209242092520926209272092820929209302093120932209332093420935209362093720938209392094020941209422094320944209452094620947209482094920950209512095220953209542095520956209572095820959209602096120962209632096420965209662096720968209692097020971209722097320974209752097620977209782097920980209812098220983209842098520986209872098820989209902099120992209932099420995209962099720998209992100021001210022100321004210052100621007210082100921010210112101221013210142101521016210172101821019210202102121022210232102421025210262102721028210292103021031210322103321034210352103621037210382103921040210412104221043210442104521046210472104821049210502105121052210532105421055210562105721058210592106021061210622106321064210652106621067210682106921070210712107221073210742107521076210772107821079210802108121082210832108421085210862108721088210892109021091210922109321094210952109621097210982109921100211012110221103211042110521106211072110821109211102111121112211132111421115211162111721118211192112021121211222112321124211252112621127211282112921130211312113221133211342113521136211372113821139211402114121142211432114421145211462114721148211492115021151211522115321154211552115621157211582115921160211612116221163211642116521166211672116821169211702117121172211732117421175211762117721178211792118021181211822118321184211852118621187211882118921190211912119221193211942119521196211972119821199212002120121202212032120421205212062120721208212092121021211212122121321214212152121621217212182121921220212212122221223212242122521226212272122821229212302123121232212332123421235212362123721238212392124021241212422124321244212452124621247212482124921250212512125221253212542125521256212572125821259212602126121262212632126421265212662126721268212692127021271212722127321274212752127621277212782127921280212812128221283212842128521286212872128821289212902129121292212932129421295212962129721298212992130021301213022130321304213052130621307213082130921310213112131221313213142131521316213172131821319213202132121322213232132421325213262132721328213292133021331213322133321334213352133621337213382133921340213412134221343213442134521346213472134821349213502135121352213532135421355213562135721358213592136021361213622136321364213652136621367213682136921370213712137221373213742137521376213772137821379213802138121382213832138421385213862138721388213892139021391213922139321394213952139621397213982139921400214012140221403214042140521406214072140821409214102141121412214132141421415214162141721418214192142021421214222142321424214252142621427214282142921430214312143221433214342143521436214372143821439214402144121442214432144421445214462144721448214492145021451214522145321454214552145621457214582145921460214612146221463214642146521466214672146821469214702147121472214732147421475214762147721478214792148021481214822148321484214852148621487214882148921490214912149221493214942149521496214972149821499215002150121502215032150421505215062150721508215092151021511215122151321514215152151621517215182151921520215212152221523215242152521526215272152821529215302153121532215332153421535215362153721538215392154021541215422154321544215452154621547215482154921550215512155221553215542155521556215572155821559215602156121562215632156421565215662156721568215692157021571215722157321574215752157621577215782157921580215812158221583215842158521586215872158821589215902159121592215932159421595215962159721598215992160021601216022160321604216052160621607216082160921610216112161221613216142161521616216172161821619216202162121622216232162421625216262162721628216292163021631216322163321634216352163621637216382163921640216412164221643216442164521646216472164821649216502165121652216532165421655216562165721658216592166021661216622166321664216652166621667216682166921670216712167221673216742167521676216772167821679216802168121682216832168421685216862168721688216892169021691216922169321694216952169621697216982169921700217012170221703217042170521706217072170821709217102171121712217132171421715217162171721718217192172021721217222172321724217252172621727217282172921730217312173221733217342173521736217372173821739217402174121742217432174421745217462174721748217492175021751217522175321754217552175621757217582175921760217612176221763217642176521766217672176821769217702177121772217732177421775217762177721778217792178021781217822178321784217852178621787217882178921790217912179221793217942179521796217972179821799218002180121802218032180421805218062180721808218092181021811218122181321814218152181621817218182181921820218212182221823218242182521826218272182821829218302183121832218332183421835218362183721838218392184021841218422184321844218452184621847218482184921850218512185221853218542185521856218572185821859218602186121862218632186421865218662186721868218692187021871218722187321874218752187621877218782187921880218812188221883218842188521886218872188821889218902189121892218932189421895218962189721898218992190021901219022190321904219052190621907219082190921910219112191221913219142191521916219172191821919219202192121922219232192421925219262192721928219292193021931219322193321934219352193621937219382193921940219412194221943219442194521946219472194821949219502195121952219532195421955219562195721958219592196021961219622196321964219652196621967219682196921970219712197221973219742197521976219772197821979219802198121982219832198421985219862198721988219892199021991219922199321994219952199621997219982199922000220012200222003220042200522006220072200822009220102201122012220132201422015220162201722018220192202022021220222202322024220252202622027220282202922030220312203222033220342203522036220372203822039220402204122042220432204422045220462204722048220492205022051220522205322054220552205622057220582205922060220612206222063220642206522066220672206822069220702207122072220732207422075220762207722078220792208022081220822208322084220852208622087220882208922090220912209222093220942209522096220972209822099221002210122102221032210422105221062210722108221092211022111221122211322114221152211622117221182211922120221212212222123221242212522126221272212822129221302213122132221332213422135221362213722138221392214022141221422214322144221452214622147221482214922150221512215222153221542215522156221572215822159221602216122162221632216422165221662216722168221692217022171221722217322174221752217622177221782217922180221812218222183221842218522186221872218822189221902219122192221932219422195221962219722198221992220022201222022220322204222052220622207222082220922210222112221222213222142221522216222172221822219222202222122222222232222422225222262222722228222292223022231222322223322234222352223622237222382223922240222412224222243222442224522246222472224822249222502225122252222532225422255222562225722258222592226022261222622226322264222652226622267222682226922270222712227222273222742227522276222772227822279222802228122282222832228422285222862228722288222892229022291222922229322294222952229622297222982229922300223012230222303223042230522306223072230822309223102231122312223132231422315223162231722318223192232022321223222232322324223252232622327223282232922330223312233222333223342233522336223372233822339223402234122342223432234422345223462234722348223492235022351223522235322354223552235622357223582235922360223612236222363223642236522366223672236822369223702237122372223732237422375223762237722378223792238022381223822238322384223852238622387223882238922390223912239222393223942239522396223972239822399224002240122402224032240422405224062240722408224092241022411224122241322414224152241622417224182241922420224212242222423224242242522426224272242822429224302243122432224332243422435224362243722438224392244022441224422244322444224452244622447224482244922450224512245222453224542245522456224572245822459224602246122462224632246422465224662246722468224692247022471224722247322474224752247622477224782247922480224812248222483224842248522486224872248822489224902249122492224932249422495224962249722498224992250022501225022250322504225052250622507225082250922510225112251222513225142251522516225172251822519225202252122522225232252422525225262252722528225292253022531225322253322534225352253622537225382253922540225412254222543225442254522546225472254822549225502255122552225532255422555225562255722558225592256022561225622256322564225652256622567225682256922570225712257222573225742257522576225772257822579225802258122582225832258422585225862258722588225892259022591225922259322594225952259622597225982259922600226012260222603226042260522606226072260822609226102261122612226132261422615226162261722618226192262022621226222262322624226252262622627226282262922630226312263222633226342263522636226372263822639226402264122642226432264422645226462264722648226492265022651226522265322654226552265622657226582265922660226612266222663226642266522666226672266822669226702267122672226732267422675226762267722678226792268022681226822268322684226852268622687226882268922690226912269222693226942269522696226972269822699227002270122702227032270422705227062270722708227092271022711227122271322714227152271622717227182271922720227212272222723227242272522726227272272822729227302273122732227332273422735227362273722738227392274022741227422274322744227452274622747227482274922750227512275222753227542275522756227572275822759227602276122762227632276422765227662276722768227692277022771227722277322774227752277622777227782277922780227812278222783227842278522786227872278822789227902279122792227932279422795227962279722798227992280022801228022280322804228052280622807228082280922810228112281222813228142281522816228172281822819228202282122822228232282422825228262282722828228292283022831228322283322834228352283622837228382283922840228412284222843228442284522846228472284822849228502285122852228532285422855228562285722858228592286022861228622286322864228652286622867228682286922870228712287222873228742287522876228772287822879228802288122882228832288422885228862288722888228892289022891228922289322894228952289622897228982289922900229012290222903229042290522906229072290822909229102291122912229132291422915229162291722918229192292022921229222292322924229252292622927229282292922930229312293222933229342293522936229372293822939229402294122942229432294422945229462294722948229492295022951229522295322954229552295622957229582295922960229612296222963229642296522966229672296822969229702297122972229732297422975229762297722978229792298022981229822298322984229852298622987229882298922990229912299222993229942299522996229972299822999230002300123002230032300423005230062300723008230092301023011230122301323014230152301623017230182301923020230212302223023230242302523026230272302823029230302303123032230332303423035230362303723038230392304023041230422304323044230452304623047230482304923050230512305223053230542305523056230572305823059230602306123062230632306423065230662306723068230692307023071230722307323074230752307623077230782307923080230812308223083230842308523086230872308823089230902309123092230932309423095230962309723098230992310023101231022310323104231052310623107231082310923110231112311223113231142311523116231172311823119231202312123122231232312423125231262312723128231292313023131231322313323134231352313623137231382313923140231412314223143231442314523146231472314823149231502315123152231532315423155231562315723158231592316023161231622316323164231652316623167231682316923170231712317223173231742317523176231772317823179231802318123182231832318423185231862318723188231892319023191231922319323194231952319623197231982319923200232012320223203232042320523206232072320823209232102321123212232132321423215232162321723218232192322023221232222322323224232252322623227232282322923230232312323223233232342323523236232372323823239232402324123242232432324423245232462324723248232492325023251232522325323254232552325623257232582325923260232612326223263232642326523266232672326823269232702327123272232732327423275232762327723278232792328023281232822328323284232852328623287232882328923290232912329223293232942329523296232972329823299233002330123302233032330423305233062330723308233092331023311233122331323314233152331623317233182331923320233212332223323233242332523326233272332823329233302333123332233332333423335233362333723338233392334023341233422334323344233452334623347233482334923350233512335223353233542335523356233572335823359233602336123362233632336423365233662336723368233692337023371233722337323374233752337623377233782337923380233812338223383233842338523386233872338823389233902339123392233932339423395233962339723398233992340023401234022340323404234052340623407234082340923410234112341223413234142341523416234172341823419234202342123422234232342423425234262342723428234292343023431234322343323434234352343623437234382343923440234412344223443234442344523446234472344823449234502345123452234532345423455234562345723458234592346023461234622346323464234652346623467234682346923470234712347223473234742347523476234772347823479234802348123482234832348423485234862348723488234892349023491234922349323494234952349623497234982349923500235012350223503235042350523506235072350823509235102351123512235132351423515235162351723518235192352023521235222352323524235252352623527235282352923530235312353223533235342353523536235372353823539235402354123542235432354423545235462354723548235492355023551235522355323554235552355623557235582355923560235612356223563235642356523566235672356823569235702357123572235732357423575235762357723578235792358023581235822358323584235852358623587235882358923590235912359223593235942359523596235972359823599236002360123602236032360423605236062360723608236092361023611236122361323614236152361623617236182361923620236212362223623236242362523626236272362823629236302363123632236332363423635236362363723638236392364023641236422364323644236452364623647236482364923650236512365223653236542365523656236572365823659236602366123662236632366423665236662366723668236692367023671236722367323674236752367623677236782367923680236812368223683236842368523686236872368823689236902369123692236932369423695236962369723698236992370023701237022370323704237052370623707237082370923710237112371223713237142371523716237172371823719237202372123722237232372423725237262372723728237292373023731237322373323734237352373623737237382373923740237412374223743237442374523746237472374823749237502375123752237532375423755237562375723758237592376023761237622376323764237652376623767237682376923770237712377223773237742377523776237772377823779237802378123782237832378423785237862378723788237892379023791237922379323794237952379623797237982379923800238012380223803238042380523806238072380823809238102381123812238132381423815238162381723818238192382023821238222382323824238252382623827238282382923830238312383223833238342383523836238372383823839238402384123842238432384423845238462384723848238492385023851238522385323854238552385623857238582385923860238612386223863238642386523866238672386823869238702387123872238732387423875238762387723878238792388023881238822388323884238852388623887238882388923890238912389223893238942389523896238972389823899239002390123902239032390423905239062390723908239092391023911239122391323914239152391623917239182391923920239212392223923239242392523926239272392823929239302393123932239332393423935239362393723938239392394023941239422394323944239452394623947239482394923950239512395223953239542395523956239572395823959239602396123962239632396423965239662396723968239692397023971239722397323974239752397623977239782397923980239812398223983239842398523986239872398823989239902399123992239932399423995239962399723998239992400024001240022400324004240052400624007240082400924010240112401224013240142401524016240172401824019240202402124022240232402424025240262402724028240292403024031240322403324034240352403624037240382403924040240412404224043240442404524046240472404824049240502405124052240532405424055240562405724058240592406024061240622406324064240652406624067240682406924070240712407224073240742407524076240772407824079240802408124082240832408424085240862408724088240892409024091240922409324094240952409624097240982409924100241012410224103241042410524106241072410824109241102411124112241132411424115241162411724118241192412024121241222412324124241252412624127241282412924130241312413224133241342413524136241372413824139241402414124142241432414424145241462414724148241492415024151241522415324154241552415624157241582415924160241612416224163241642416524166241672416824169241702417124172241732417424175241762417724178241792418024181241822418324184241852418624187241882418924190241912419224193241942419524196241972419824199242002420124202242032420424205242062420724208242092421024211242122421324214242152421624217242182421924220242212422224223242242422524226242272422824229242302423124232242332423424235242362423724238242392424024241242422424324244242452424624247242482424924250242512425224253242542425524256242572425824259242602426124262242632426424265242662426724268242692427024271242722427324274242752427624277242782427924280242812428224283242842428524286242872428824289242902429124292242932429424295242962429724298242992430024301243022430324304243052430624307243082430924310243112431224313243142431524316243172431824319243202432124322243232432424325243262432724328243292433024331243322433324334243352433624337243382433924340243412434224343243442434524346243472434824349243502435124352243532435424355243562435724358243592436024361243622436324364243652436624367243682436924370243712437224373243742437524376243772437824379243802438124382243832438424385243862438724388243892439024391243922439324394243952439624397243982439924400244012440224403244042440524406244072440824409244102441124412244132441424415244162441724418244192442024421244222442324424244252442624427244282442924430244312443224433244342443524436244372443824439244402444124442244432444424445244462444724448244492445024451244522445324454244552445624457244582445924460244612446224463244642446524466244672446824469244702447124472244732447424475244762447724478244792448024481244822448324484244852448624487244882448924490244912449224493244942449524496244972449824499245002450124502245032450424505245062450724508245092451024511245122451324514245152451624517245182451924520245212452224523245242452524526245272452824529245302453124532245332453424535245362453724538245392454024541245422454324544245452454624547245482454924550245512455224553245542455524556245572455824559245602456124562245632456424565245662456724568245692457024571245722457324574245752457624577245782457924580245812458224583245842458524586245872458824589245902459124592245932459424595245962459724598245992460024601246022460324604246052460624607246082460924610246112461224613246142461524616246172461824619246202462124622246232462424625246262462724628246292463024631246322463324634246352463624637246382463924640246412464224643246442464524646246472464824649246502465124652246532465424655246562465724658246592466024661246622466324664246652466624667246682466924670246712467224673246742467524676246772467824679246802468124682246832468424685246862468724688246892469024691246922469324694246952469624697246982469924700247012470224703247042470524706247072470824709247102471124712247132471424715247162471724718247192472024721247222472324724247252472624727247282472924730247312473224733247342473524736247372473824739247402474124742247432474424745247462474724748247492475024751247522475324754247552475624757247582475924760247612476224763247642476524766247672476824769247702477124772247732477424775247762477724778247792478024781247822478324784247852478624787247882478924790247912479224793247942479524796247972479824799248002480124802248032480424805248062480724808248092481024811248122481324814248152481624817248182481924820248212482224823248242482524826248272482824829248302483124832248332483424835248362483724838248392484024841248422484324844248452484624847248482484924850248512485224853248542485524856248572485824859248602486124862248632486424865248662486724868248692487024871248722487324874248752487624877248782487924880248812488224883248842488524886248872488824889248902489124892248932489424895248962489724898248992490024901249022490324904249052490624907249082490924910249112491224913249142491524916249172491824919249202492124922249232492424925249262492724928249292493024931249322493324934249352493624937249382493924940249412494224943249442494524946249472494824949249502495124952249532495424955249562495724958249592496024961249622496324964249652496624967249682496924970249712497224973249742497524976249772497824979249802498124982249832498424985249862498724988249892499024991249922499324994249952499624997249982499925000250012500225003250042500525006250072500825009250102501125012250132501425015250162501725018250192502025021250222502325024250252502625027250282502925030250312503225033250342503525036250372503825039250402504125042250432504425045250462504725048250492505025051250522505325054250552505625057250582505925060250612506225063250642506525066250672506825069250702507125072250732507425075250762507725078250792508025081250822508325084250852508625087250882508925090250912509225093250942509525096250972509825099251002510125102251032510425105251062510725108251092511025111251122511325114251152511625117251182511925120251212512225123251242512525126251272512825129251302513125132251332513425135251362513725138251392514025141251422514325144251452514625147251482514925150251512515225153251542515525156251572515825159251602516125162251632516425165251662516725168251692517025171251722517325174251752517625177251782517925180251812518225183251842518525186251872518825189251902519125192251932519425195251962519725198251992520025201252022520325204252052520625207252082520925210252112521225213252142521525216252172521825219252202522125222252232522425225252262522725228252292523025231252322523325234252352523625237252382523925240252412524225243252442524525246252472524825249252502525125252252532525425255252562525725258252592526025261252622526325264252652526625267252682526925270252712527225273252742527525276252772527825279252802528125282252832528425285252862528725288252892529025291252922529325294252952529625297252982529925300253012530225303253042530525306253072530825309253102531125312253132531425315253162531725318253192532025321253222532325324253252532625327253282532925330253312533225333253342533525336253372533825339253402534125342253432534425345253462534725348253492535025351253522535325354253552535625357253582535925360253612536225363253642536525366253672536825369253702537125372253732537425375253762537725378253792538025381253822538325384253852538625387253882538925390253912539225393253942539525396253972539825399254002540125402254032540425405254062540725408254092541025411254122541325414254152541625417254182541925420254212542225423254242542525426254272542825429254302543125432254332543425435254362543725438254392544025441254422544325444254452544625447254482544925450254512545225453254542545525456254572545825459254602546125462254632546425465254662546725468254692547025471254722547325474254752547625477254782547925480254812548225483254842548525486254872548825489254902549125492254932549425495254962549725498254992550025501255022550325504255052550625507255082550925510255112551225513255142551525516255172551825519255202552125522255232552425525255262552725528255292553025531255322553325534255352553625537255382553925540255412554225543255442554525546255472554825549255502555125552255532555425555255562555725558255592556025561255622556325564255652556625567255682556925570255712557225573255742557525576255772557825579255802558125582255832558425585255862558725588255892559025591255922559325594255952559625597255982559925600256012560225603256042560525606256072560825609256102561125612256132561425615256162561725618256192562025621256222562325624256252562625627256282562925630256312563225633256342563525636256372563825639256402564125642256432564425645256462564725648256492565025651256522565325654256552565625657256582565925660256612566225663256642566525666256672566825669256702567125672256732567425675256762567725678256792568025681256822568325684256852568625687256882568925690256912569225693256942569525696256972569825699257002570125702257032570425705257062570725708257092571025711257122571325714257152571625717257182571925720257212572225723257242572525726257272572825729257302573125732257332573425735257362573725738257392574025741257422574325744257452574625747257482574925750257512575225753257542575525756257572575825759257602576125762257632576425765257662576725768257692577025771257722577325774257752577625777257782577925780257812578225783257842578525786257872578825789257902579125792257932579425795257962579725798257992580025801258022580325804258052580625807258082580925810258112581225813258142581525816258172581825819258202582125822258232582425825258262582725828258292583025831258322583325834258352583625837258382583925840258412584225843258442584525846258472584825849258502585125852258532585425855258562585725858258592586025861258622586325864258652586625867258682586925870258712587225873258742587525876258772587825879258802588125882258832588425885258862588725888258892589025891258922589325894258952589625897258982589925900259012590225903259042590525906259072590825909259102591125912259132591425915259162591725918259192592025921259222592325924259252592625927259282592925930259312593225933259342593525936259372593825939259402594125942259432594425945259462594725948259492595025951259522595325954259552595625957259582595925960259612596225963259642596525966259672596825969259702597125972259732597425975259762597725978259792598025981259822598325984259852598625987259882598925990259912599225993259942599525996259972599825999260002600126002260032600426005260062600726008260092601026011260122601326014260152601626017260182601926020260212602226023260242602526026260272602826029260302603126032260332603426035260362603726038260392604026041260422604326044260452604626047260482604926050260512605226053260542605526056260572605826059260602606126062260632606426065260662606726068260692607026071260722607326074260752607626077260782607926080260812608226083260842608526086260872608826089260902609126092260932609426095260962609726098260992610026101261022610326104261052610626107261082610926110261112611226113261142611526116261172611826119261202612126122261232612426125261262612726128261292613026131261322613326134261352613626137261382613926140261412614226143261442614526146261472614826149261502615126152261532615426155261562615726158261592616026161261622616326164261652616626167261682616926170261712617226173261742617526176261772617826179261802618126182261832618426185261862618726188261892619026191261922619326194261952619626197261982619926200262012620226203262042620526206262072620826209262102621126212262132621426215262162621726218262192622026221262222622326224262252622626227262282622926230262312623226233262342623526236262372623826239262402624126242262432624426245262462624726248262492625026251262522625326254262552625626257262582625926260262612626226263262642626526266262672626826269262702627126272262732627426275262762627726278262792628026281262822628326284262852628626287262882628926290262912629226293262942629526296262972629826299263002630126302263032630426305263062630726308263092631026311263122631326314263152631626317263182631926320263212632226323263242632526326263272632826329263302633126332263332633426335263362633726338263392634026341263422634326344263452634626347263482634926350263512635226353263542635526356263572635826359263602636126362263632636426365263662636726368263692637026371263722637326374263752637626377263782637926380263812638226383263842638526386263872638826389263902639126392263932639426395263962639726398263992640026401264022640326404264052640626407264082640926410264112641226413264142641526416264172641826419264202642126422264232642426425264262642726428264292643026431264322643326434264352643626437264382643926440264412644226443264442644526446264472644826449264502645126452264532645426455264562645726458264592646026461264622646326464264652646626467264682646926470264712647226473264742647526476264772647826479264802648126482264832648426485264862648726488264892649026491264922649326494264952649626497264982649926500265012650226503265042650526506265072650826509265102651126512265132651426515265162651726518265192652026521265222652326524265252652626527265282652926530265312653226533265342653526536265372653826539265402654126542265432654426545265462654726548265492655026551265522655326554265552655626557265582655926560265612656226563265642656526566265672656826569265702657126572265732657426575265762657726578265792658026581265822658326584265852658626587265882658926590265912659226593265942659526596265972659826599266002660126602266032660426605266062660726608266092661026611266122661326614266152661626617266182661926620266212662226623266242662526626266272662826629266302663126632266332663426635266362663726638266392664026641266422664326644266452664626647266482664926650266512665226653266542665526656266572665826659266602666126662266632666426665266662666726668266692667026671266722667326674266752667626677266782667926680266812668226683266842668526686266872668826689266902669126692266932669426695266962669726698266992670026701267022670326704267052670626707267082670926710267112671226713267142671526716267172671826719267202672126722267232672426725267262672726728267292673026731267322673326734267352673626737267382673926740267412674226743267442674526746267472674826749267502675126752267532675426755267562675726758267592676026761267622676326764267652676626767267682676926770267712677226773267742677526776267772677826779267802678126782267832678426785267862678726788267892679026791267922679326794267952679626797267982679926800268012680226803268042680526806268072680826809268102681126812268132681426815268162681726818268192682026821268222682326824268252682626827268282682926830268312683226833268342683526836268372683826839268402684126842268432684426845268462684726848268492685026851268522685326854268552685626857268582685926860268612686226863268642686526866268672686826869268702687126872268732687426875268762687726878268792688026881268822688326884268852688626887268882688926890268912689226893268942689526896268972689826899269002690126902269032690426905269062690726908269092691026911269122691326914269152691626917269182691926920269212692226923269242692526926269272692826929269302693126932269332693426935269362693726938269392694026941269422694326944269452694626947269482694926950269512695226953269542695526956269572695826959269602696126962269632696426965269662696726968269692697026971269722697326974269752697626977269782697926980269812698226983269842698526986269872698826989269902699126992269932699426995269962699726998269992700027001270022700327004270052700627007270082700927010270112701227013270142701527016270172701827019270202702127022270232702427025270262702727028270292703027031270322703327034270352703627037270382703927040270412704227043270442704527046270472704827049270502705127052270532705427055270562705727058270592706027061270622706327064270652706627067270682706927070270712707227073270742707527076270772707827079270802708127082270832708427085270862708727088270892709027091270922709327094270952709627097270982709927100271012710227103271042710527106271072710827109271102711127112271132711427115271162711727118271192712027121271222712327124271252712627127271282712927130271312713227133271342713527136271372713827139271402714127142271432714427145271462714727148271492715027151271522715327154271552715627157271582715927160271612716227163271642716527166271672716827169271702717127172271732717427175271762717727178271792718027181271822718327184271852718627187271882718927190271912719227193271942719527196271972719827199272002720127202272032720427205272062720727208272092721027211272122721327214272152721627217272182721927220272212722227223272242722527226272272722827229272302723127232272332723427235272362723727238272392724027241272422724327244272452724627247272482724927250272512725227253272542725527256272572725827259272602726127262272632726427265272662726727268272692727027271272722727327274272752727627277272782727927280272812728227283272842728527286272872728827289272902729127292272932729427295272962729727298272992730027301273022730327304273052730627307273082730927310273112731227313273142731527316273172731827319273202732127322273232732427325273262732727328273292733027331273322733327334273352733627337273382733927340273412734227343273442734527346273472734827349273502735127352273532735427355273562735727358273592736027361273622736327364273652736627367273682736927370273712737227373273742737527376273772737827379273802738127382273832738427385273862738727388273892739027391273922739327394273952739627397273982739927400274012740227403274042740527406274072740827409274102741127412274132741427415274162741727418274192742027421274222742327424274252742627427274282742927430274312743227433274342743527436274372743827439274402744127442274432744427445274462744727448274492745027451274522745327454274552745627457274582745927460274612746227463274642746527466274672746827469274702747127472274732747427475274762747727478274792748027481274822748327484274852748627487274882748927490274912749227493274942749527496274972749827499275002750127502275032750427505275062750727508275092751027511275122751327514275152751627517275182751927520275212752227523275242752527526275272752827529275302753127532275332753427535275362753727538275392754027541275422754327544275452754627547275482754927550275512755227553275542755527556275572755827559275602756127562275632756427565275662756727568275692757027571275722757327574275752757627577275782757927580275812758227583275842758527586275872758827589275902759127592275932759427595275962759727598275992760027601276022760327604276052760627607276082760927610276112761227613276142761527616276172761827619276202762127622276232762427625276262762727628276292763027631276322763327634276352763627637276382763927640276412764227643276442764527646276472764827649276502765127652276532765427655276562765727658276592766027661276622766327664276652766627667276682766927670276712767227673276742767527676276772767827679276802768127682276832768427685276862768727688276892769027691276922769327694276952769627697276982769927700277012770227703277042770527706277072770827709277102771127712277132771427715277162771727718277192772027721277222772327724277252772627727277282772927730277312773227733277342773527736277372773827739277402774127742277432774427745277462774727748277492775027751277522775327754277552775627757277582775927760277612776227763277642776527766277672776827769277702777127772277732777427775277762777727778277792778027781277822778327784277852778627787277882778927790277912779227793277942779527796277972779827799278002780127802278032780427805278062780727808278092781027811278122781327814278152781627817278182781927820278212782227823278242782527826278272782827829278302783127832278332783427835278362783727838278392784027841278422784327844278452784627847278482784927850278512785227853278542785527856278572785827859278602786127862278632786427865278662786727868278692787027871278722787327874278752787627877278782787927880278812788227883278842788527886278872788827889278902789127892278932789427895278962789727898278992790027901279022790327904279052790627907279082790927910279112791227913279142791527916279172791827919279202792127922279232792427925279262792727928279292793027931279322793327934279352793627937279382793927940279412794227943279442794527946279472794827949279502795127952279532795427955279562795727958279592796027961279622796327964279652796627967279682796927970279712797227973279742797527976279772797827979279802798127982279832798427985279862798727988279892799027991279922799327994279952799627997279982799928000280012800228003280042800528006280072800828009280102801128012280132801428015280162801728018280192802028021280222802328024280252802628027280282802928030280312803228033280342803528036280372803828039280402804128042280432804428045280462804728048280492805028051280522805328054280552805628057280582805928060280612806228063280642806528066280672806828069280702807128072280732807428075280762807728078280792808028081280822808328084280852808628087280882808928090280912809228093280942809528096280972809828099281002810128102281032810428105281062810728108281092811028111281122811328114281152811628117281182811928120281212812228123281242812528126281272812828129281302813128132281332813428135281362813728138281392814028141281422814328144281452814628147281482814928150281512815228153281542815528156281572815828159281602816128162281632816428165281662816728168281692817028171281722817328174281752817628177281782817928180281812818228183281842818528186281872818828189281902819128192281932819428195281962819728198281992820028201282022820328204282052820628207282082820928210282112821228213282142821528216282172821828219282202822128222282232822428225282262822728228282292823028231282322823328234282352823628237282382823928240282412824228243282442824528246282472824828249282502825128252282532825428255282562825728258282592826028261282622826328264282652826628267282682826928270282712827228273282742827528276282772827828279282802828128282282832828428285282862828728288282892829028291282922829328294282952829628297282982829928300283012830228303283042830528306283072830828309283102831128312283132831428315283162831728318283192832028321283222832328324283252832628327283282832928330283312833228333283342833528336283372833828339283402834128342283432834428345283462834728348283492835028351283522835328354283552835628357283582835928360283612836228363283642836528366283672836828369283702837128372283732837428375283762837728378283792838028381283822838328384283852838628387283882838928390283912839228393283942839528396283972839828399284002840128402284032840428405284062840728408284092841028411284122841328414284152841628417284182841928420284212842228423284242842528426284272842828429284302843128432284332843428435284362843728438284392844028441284422844328444284452844628447284482844928450284512845228453284542845528456284572845828459284602846128462284632846428465284662846728468284692847028471284722847328474284752847628477284782847928480284812848228483284842848528486284872848828489284902849128492284932849428495284962849728498284992850028501285022850328504285052850628507285082850928510285112851228513285142851528516285172851828519285202852128522285232852428525285262852728528285292853028531285322853328534285352853628537285382853928540285412854228543285442854528546285472854828549285502855128552285532855428555285562855728558285592856028561285622856328564285652856628567285682856928570285712857228573285742857528576285772857828579285802858128582285832858428585285862858728588285892859028591285922859328594285952859628597285982859928600286012860228603286042860528606286072860828609286102861128612286132861428615286162861728618286192862028621286222862328624286252862628627286282862928630286312863228633286342863528636286372863828639286402864128642286432864428645286462864728648286492865028651286522865328654286552865628657286582865928660286612866228663286642866528666286672866828669286702867128672286732867428675286762867728678286792868028681286822868328684286852868628687286882868928690286912869228693286942869528696286972869828699287002870128702287032870428705287062870728708287092871028711287122871328714287152871628717287182871928720287212872228723287242872528726287272872828729287302873128732287332873428735287362873728738287392874028741287422874328744287452874628747287482874928750287512875228753287542875528756287572875828759287602876128762287632876428765287662876728768287692877028771287722877328774287752877628777287782877928780287812878228783287842878528786287872878828789287902879128792287932879428795287962879728798287992880028801288022880328804288052880628807288082880928810288112881228813288142881528816288172881828819288202882128822288232882428825288262882728828288292883028831288322883328834288352883628837288382883928840288412884228843288442884528846288472884828849288502885128852288532885428855288562885728858288592886028861288622886328864288652886628867288682886928870288712887228873288742887528876288772887828879288802888128882288832888428885288862888728888288892889028891288922889328894288952889628897288982889928900289012890228903289042890528906289072890828909289102891128912289132891428915289162891728918289192892028921289222892328924289252892628927289282892928930289312893228933289342893528936289372893828939289402894128942289432894428945289462894728948289492895028951289522895328954289552895628957289582895928960289612896228963289642896528966289672896828969289702897128972289732897428975289762897728978289792898028981289822898328984289852898628987289882898928990289912899228993289942899528996289972899828999290002900129002290032900429005290062900729008290092901029011290122901329014290152901629017290182901929020290212902229023290242902529026290272902829029290302903129032290332903429035290362903729038290392904029041290422904329044290452904629047290482904929050290512905229053290542905529056290572905829059290602906129062290632906429065290662906729068290692907029071290722907329074290752907629077290782907929080290812908229083290842908529086290872908829089290902909129092290932909429095290962909729098290992910029101291022910329104291052910629107291082910929110291112911229113291142911529116291172911829119291202912129122291232912429125291262912729128291292913029131291322913329134291352913629137291382913929140291412914229143291442914529146291472914829149291502915129152291532915429155291562915729158291592916029161291622916329164291652916629167291682916929170291712917229173291742917529176291772917829179291802918129182291832918429185291862918729188291892919029191291922919329194291952919629197291982919929200292012920229203292042920529206292072920829209292102921129212292132921429215292162921729218292192922029221292222922329224292252922629227292282922929230292312923229233292342923529236292372923829239292402924129242292432924429245292462924729248292492925029251292522925329254292552925629257292582925929260292612926229263292642926529266292672926829269292702927129272292732927429275292762927729278292792928029281292822928329284292852928629287292882928929290292912929229293292942929529296292972929829299293002930129302293032930429305293062930729308293092931029311293122931329314293152931629317293182931929320293212932229323293242932529326293272932829329293302933129332293332933429335293362933729338293392934029341293422934329344293452934629347293482934929350293512935229353293542935529356293572935829359293602936129362293632936429365293662936729368293692937029371293722937329374293752937629377293782937929380293812938229383293842938529386293872938829389293902939129392293932939429395293962939729398293992940029401294022940329404294052940629407294082940929410294112941229413294142941529416294172941829419294202942129422294232942429425294262942729428294292943029431294322943329434294352943629437294382943929440294412944229443294442944529446294472944829449294502945129452294532945429455294562945729458294592946029461294622946329464294652946629467294682946929470294712947229473294742947529476294772947829479294802948129482294832948429485294862948729488294892949029491294922949329494294952949629497294982949929500295012950229503295042950529506295072950829509295102951129512295132951429515295162951729518295192952029521295222952329524295252952629527295282952929530295312953229533295342953529536295372953829539295402954129542295432954429545295462954729548295492955029551295522955329554295552955629557295582955929560295612956229563295642956529566295672956829569295702957129572295732957429575295762957729578295792958029581295822958329584295852958629587295882958929590295912959229593295942959529596295972959829599296002960129602296032960429605296062960729608296092961029611296122961329614296152961629617296182961929620296212962229623296242962529626296272962829629296302963129632296332963429635296362963729638296392964029641296422964329644296452964629647296482964929650296512965229653296542965529656296572965829659296602966129662296632966429665296662966729668296692967029671296722967329674296752967629677296782967929680296812968229683296842968529686296872968829689296902969129692296932969429695296962969729698296992970029701297022970329704297052970629707297082970929710297112971229713297142971529716297172971829719297202972129722297232972429725297262972729728297292973029731297322973329734297352973629737297382973929740297412974229743297442974529746297472974829749297502975129752297532975429755297562975729758297592976029761297622976329764297652976629767297682976929770297712977229773297742977529776297772977829779297802978129782297832978429785297862978729788297892979029791297922979329794297952979629797297982979929800298012980229803298042980529806298072980829809298102981129812298132981429815298162981729818298192982029821298222982329824298252982629827298282982929830298312983229833298342983529836298372983829839298402984129842298432984429845298462984729848298492985029851298522985329854298552985629857298582985929860298612986229863298642986529866298672986829869298702987129872298732987429875298762987729878298792988029881298822988329884298852988629887298882988929890298912989229893298942989529896298972989829899299002990129902299032990429905299062990729908299092991029911299122991329914299152991629917299182991929920299212992229923299242992529926299272992829929299302993129932299332993429935299362993729938299392994029941299422994329944299452994629947299482994929950299512995229953299542995529956299572995829959299602996129962299632996429965299662996729968299692997029971299722997329974299752997629977299782997929980299812998229983299842998529986299872998829989299902999129992299932999429995299962999729998299993000030001300023000330004300053000630007300083000930010300113001230013300143001530016300173001830019300203002130022300233002430025300263002730028300293003030031300323003330034300353003630037300383003930040300413004230043300443004530046300473004830049300503005130052300533005430055300563005730058300593006030061300623006330064300653006630067300683006930070300713007230073300743007530076300773007830079300803008130082300833008430085300863008730088300893009030091300923009330094300953009630097300983009930100301013010230103301043010530106301073010830109301103011130112301133011430115301163011730118301193012030121301223012330124301253012630127301283012930130301313013230133301343013530136301373013830139301403014130142301433014430145301463014730148301493015030151301523015330154301553015630157301583015930160301613016230163301643016530166301673016830169301703017130172301733017430175301763017730178301793018030181301823018330184301853018630187301883018930190301913019230193301943019530196301973019830199302003020130202302033020430205302063020730208302093021030211302123021330214302153021630217302183021930220302213022230223302243022530226302273022830229302303023130232302333023430235302363023730238302393024030241302423024330244302453024630247302483024930250302513025230253302543025530256302573025830259302603026130262302633026430265302663026730268302693027030271302723027330274302753027630277302783027930280302813028230283302843028530286302873028830289302903029130292302933029430295302963029730298302993030030301303023030330304303053030630307303083030930310303113031230313303143031530316303173031830319303203032130322303233032430325303263032730328303293033030331303323033330334303353033630337303383033930340303413034230343303443034530346303473034830349303503035130352303533035430355303563035730358303593036030361303623036330364303653036630367303683036930370303713037230373303743037530376303773037830379303803038130382303833038430385303863038730388303893039030391303923039330394303953039630397303983039930400304013040230403304043040530406304073040830409304103041130412304133041430415304163041730418304193042030421304223042330424304253042630427304283042930430304313043230433304343043530436304373043830439304403044130442304433044430445304463044730448304493045030451304523045330454304553045630457304583045930460304613046230463304643046530466304673046830469304703047130472304733047430475304763047730478304793048030481304823048330484304853048630487304883048930490304913049230493304943049530496304973049830499305003050130502305033050430505305063050730508305093051030511305123051330514305153051630517305183051930520305213052230523305243052530526305273052830529305303053130532305333053430535305363053730538305393054030541305423054330544305453054630547305483054930550305513055230553305543055530556305573055830559305603056130562305633056430565305663056730568305693057030571305723057330574305753057630577305783057930580305813058230583305843058530586305873058830589305903059130592305933059430595305963059730598305993060030601306023060330604306053060630607306083060930610306113061230613306143061530616306173061830619306203062130622306233062430625306263062730628306293063030631306323063330634306353063630637306383063930640306413064230643306443064530646306473064830649306503065130652306533065430655306563065730658306593066030661306623066330664306653066630667306683066930670306713067230673306743067530676306773067830679306803068130682306833068430685306863068730688306893069030691306923069330694306953069630697306983069930700307013070230703307043070530706307073070830709307103071130712307133071430715307163071730718307193072030721307223072330724307253072630727307283072930730307313073230733307343073530736307373073830739307403074130742307433074430745307463074730748307493075030751307523075330754307553075630757307583075930760307613076230763307643076530766307673076830769307703077130772307733077430775307763077730778307793078030781307823078330784307853078630787307883078930790307913079230793307943079530796307973079830799308003080130802308033080430805308063080730808308093081030811308123081330814308153081630817308183081930820308213082230823308243082530826308273082830829308303083130832308333083430835308363083730838308393084030841308423084330844308453084630847308483084930850308513085230853308543085530856308573085830859308603086130862308633086430865308663086730868308693087030871308723087330874308753087630877308783087930880308813088230883308843088530886308873088830889308903089130892308933089430895308963089730898308993090030901309023090330904309053090630907309083090930910309113091230913309143091530916309173091830919309203092130922309233092430925309263092730928309293093030931309323093330934309353093630937309383093930940309413094230943309443094530946309473094830949309503095130952309533095430955309563095730958309593096030961309623096330964309653096630967309683096930970309713097230973309743097530976309773097830979309803098130982309833098430985309863098730988309893099030991309923099330994309953099630997309983099931000310013100231003310043100531006310073100831009310103101131012310133101431015310163101731018310193102031021310223102331024310253102631027310283102931030310313103231033310343103531036310373103831039310403104131042310433104431045310463104731048310493105031051310523105331054310553105631057310583105931060310613106231063310643106531066310673106831069310703107131072310733107431075310763107731078310793108031081310823108331084310853108631087310883108931090310913109231093310943109531096310973109831099311003110131102311033110431105311063110731108311093111031111311123111331114311153111631117311183111931120311213112231123311243112531126311273112831129311303113131132311333113431135311363113731138311393114031141311423114331144311453114631147311483114931150311513115231153311543115531156311573115831159311603116131162311633116431165311663116731168311693117031171311723117331174311753117631177311783117931180311813118231183311843118531186311873118831189311903119131192311933119431195311963119731198311993120031201312023120331204312053120631207312083120931210312113121231213312143121531216312173121831219312203122131222312233122431225312263122731228312293123031231312323123331234312353123631237312383123931240312413124231243312443124531246312473124831249312503125131252312533125431255312563125731258312593126031261312623126331264312653126631267312683126931270312713127231273312743127531276312773127831279312803128131282312833128431285312863128731288312893129031291312923129331294312953129631297312983129931300313013130231303313043130531306313073130831309313103131131312313133131431315313163131731318313193132031321313223132331324313253132631327313283132931330313313133231333313343133531336313373133831339313403134131342313433134431345313463134731348313493135031351313523135331354313553135631357313583135931360313613136231363313643136531366313673136831369313703137131372313733137431375313763137731378313793138031381313823138331384313853138631387313883138931390313913139231393313943139531396313973139831399314003140131402314033140431405314063140731408314093141031411314123141331414314153141631417314183141931420314213142231423314243142531426314273142831429314303143131432314333143431435314363143731438314393144031441314423144331444314453144631447314483144931450314513145231453314543145531456314573145831459314603146131462314633146431465314663146731468314693147031471314723147331474314753147631477314783147931480314813148231483314843148531486314873148831489314903149131492314933149431495314963149731498314993150031501315023150331504315053150631507315083150931510315113151231513315143151531516315173151831519315203152131522315233152431525315263152731528315293153031531315323153331534315353153631537315383153931540315413154231543315443154531546315473154831549315503155131552315533155431555315563155731558315593156031561315623156331564315653156631567315683156931570315713157231573315743157531576315773157831579315803158131582315833158431585315863158731588315893159031591315923159331594315953159631597315983159931600316013160231603316043160531606316073160831609316103161131612316133161431615316163161731618316193162031621316223162331624316253162631627316283162931630316313163231633316343163531636316373163831639316403164131642316433164431645316463164731648316493165031651316523165331654316553165631657316583165931660316613166231663316643166531666316673166831669316703167131672316733167431675316763167731678316793168031681316823168331684316853168631687316883168931690316913169231693316943169531696316973169831699317003170131702317033170431705317063170731708317093171031711317123171331714317153171631717317183171931720317213172231723317243172531726317273172831729317303173131732317333173431735317363173731738317393174031741317423174331744317453174631747317483174931750317513175231753317543175531756317573175831759317603176131762317633176431765317663176731768317693177031771317723177331774317753177631777317783177931780317813178231783317843178531786317873178831789317903179131792317933179431795317963179731798317993180031801318023180331804318053180631807318083180931810318113181231813318143181531816318173181831819318203182131822318233182431825318263182731828318293183031831318323183331834318353183631837318383183931840318413184231843318443184531846318473184831849318503185131852318533185431855318563185731858318593186031861318623186331864318653186631867318683186931870318713187231873318743187531876318773187831879318803188131882318833188431885318863188731888318893189031891318923189331894318953189631897318983189931900319013190231903319043190531906319073190831909319103191131912319133191431915319163191731918319193192031921319223192331924319253192631927319283192931930319313193231933319343193531936319373193831939319403194131942319433194431945319463194731948319493195031951319523195331954319553195631957319583195931960319613196231963319643196531966319673196831969319703197131972319733197431975319763197731978319793198031981319823198331984319853198631987319883198931990319913199231993319943199531996319973199831999320003200132002320033200432005320063200732008320093201032011320123201332014320153201632017320183201932020320213202232023320243202532026320273202832029320303203132032320333203432035320363203732038320393204032041320423204332044320453204632047320483204932050320513205232053320543205532056320573205832059320603206132062320633206432065320663206732068320693207032071320723207332074320753207632077320783207932080320813208232083320843208532086320873208832089320903209132092320933209432095320963209732098320993210032101321023210332104321053210632107321083210932110321113211232113321143211532116321173211832119321203212132122321233212432125321263212732128321293213032131321323213332134321353213632137321383213932140321413214232143321443214532146321473214832149321503215132152321533215432155321563215732158321593216032161321623216332164321653216632167321683216932170321713217232173321743217532176321773217832179321803218132182321833218432185321863218732188321893219032191321923219332194321953219632197321983219932200322013220232203322043220532206322073220832209322103221132212322133221432215322163221732218322193222032221322223222332224322253222632227322283222932230322313223232233322343223532236322373223832239322403224132242322433224432245322463224732248322493225032251322523225332254322553225632257322583225932260322613226232263322643226532266322673226832269322703227132272322733227432275322763227732278322793228032281322823228332284322853228632287322883228932290322913229232293322943229532296322973229832299323003230132302323033230432305323063230732308323093231032311323123231332314323153231632317323183231932320323213232232323323243232532326323273232832329323303233132332323333233432335323363233732338323393234032341323423234332344323453234632347323483234932350323513235232353323543235532356323573235832359323603236132362323633236432365323663236732368323693237032371323723237332374323753237632377323783237932380323813238232383323843238532386323873238832389323903239132392323933239432395323963239732398323993240032401324023240332404324053240632407324083240932410324113241232413324143241532416324173241832419324203242132422324233242432425324263242732428324293243032431324323243332434324353243632437324383243932440324413244232443324443244532446324473244832449324503245132452324533245432455324563245732458324593246032461324623246332464324653246632467324683246932470324713247232473324743247532476324773247832479324803248132482324833248432485324863248732488324893249032491324923249332494324953249632497324983249932500325013250232503325043250532506325073250832509325103251132512325133251432515325163251732518325193252032521325223252332524325253252632527325283252932530325313253232533325343253532536325373253832539325403254132542325433254432545325463254732548325493255032551325523255332554325553255632557325583255932560325613256232563325643256532566325673256832569325703257132572325733257432575325763257732578325793258032581325823258332584325853258632587325883258932590325913259232593325943259532596325973259832599326003260132602326033260432605326063260732608326093261032611326123261332614326153261632617326183261932620326213262232623326243262532626326273262832629326303263132632326333263432635326363263732638326393264032641326423264332644326453264632647326483264932650326513265232653326543265532656326573265832659326603266132662326633266432665326663266732668326693267032671326723267332674326753267632677326783267932680326813268232683326843268532686326873268832689326903269132692326933269432695326963269732698326993270032701327023270332704327053270632707327083270932710327113271232713327143271532716327173271832719327203272132722327233272432725327263272732728327293273032731327323273332734327353273632737327383273932740327413274232743327443274532746327473274832749327503275132752327533275432755327563275732758327593276032761327623276332764327653276632767327683276932770327713277232773327743277532776327773277832779327803278132782327833278432785327863278732788327893279032791327923279332794327953279632797327983279932800328013280232803328043280532806328073280832809328103281132812328133281432815328163281732818328193282032821328223282332824328253282632827328283282932830328313283232833328343283532836328373283832839328403284132842328433284432845328463284732848328493285032851328523285332854328553285632857328583285932860328613286232863328643286532866328673286832869328703287132872328733287432875328763287732878328793288032881328823288332884328853288632887328883288932890328913289232893328943289532896328973289832899329003290132902329033290432905329063290732908329093291032911329123291332914329153291632917329183291932920329213292232923329243292532926329273292832929329303293132932329333293432935329363293732938329393294032941329423294332944329453294632947329483294932950329513295232953329543295532956329573295832959329603296132962329633296432965329663296732968329693297032971329723297332974329753297632977329783297932980329813298232983329843298532986329873298832989329903299132992329933299432995329963299732998329993300033001330023300333004330053300633007330083300933010330113301233013330143301533016330173301833019330203302133022330233302433025330263302733028330293303033031330323303333034330353303633037330383303933040330413304233043330443304533046330473304833049330503305133052330533305433055330563305733058330593306033061330623306333064330653306633067330683306933070330713307233073330743307533076330773307833079330803308133082330833308433085330863308733088330893309033091330923309333094330953309633097330983309933100331013310233103331043310533106331073310833109331103311133112331133311433115331163311733118331193312033121331223312333124331253312633127331283312933130331313313233133331343313533136331373313833139331403314133142331433314433145331463314733148331493315033151331523315333154331553315633157331583315933160331613316233163331643316533166331673316833169331703317133172331733317433175331763317733178331793318033181331823318333184331853318633187331883318933190331913319233193331943319533196331973319833199332003320133202332033320433205332063320733208332093321033211332123321333214332153321633217332183321933220332213322233223332243322533226332273322833229332303323133232332333323433235332363323733238332393324033241332423324333244332453324633247332483324933250332513325233253332543325533256332573325833259332603326133262332633326433265332663326733268332693327033271332723327333274332753327633277332783327933280332813328233283332843328533286332873328833289332903329133292332933329433295332963329733298332993330033301333023330333304333053330633307333083330933310333113331233313333143331533316333173331833319333203332133322333233332433325333263332733328333293333033331333323333333334333353333633337333383333933340333413334233343333443334533346333473334833349333503335133352333533335433355333563335733358333593336033361333623336333364333653336633367333683336933370333713337233373333743337533376333773337833379333803338133382333833338433385333863338733388333893339033391333923339333394333953339633397333983339933400334013340233403334043340533406334073340833409334103341133412334133341433415334163341733418334193342033421334223342333424334253342633427334283342933430334313343233433334343343533436334373343833439334403344133442334433344433445334463344733448334493345033451334523345333454334553345633457334583345933460334613346233463334643346533466334673346833469334703347133472334733347433475334763347733478334793348033481334823348333484334853348633487334883348933490334913349233493334943349533496334973349833499335003350133502335033350433505335063350733508335093351033511335123351333514335153351633517335183351933520335213352233523335243352533526335273352833529335303353133532335333353433535335363353733538335393354033541335423354333544335453354633547335483354933550335513355233553335543355533556335573355833559335603356133562335633356433565335663356733568335693357033571335723357333574335753357633577335783357933580335813358233583335843358533586335873358833589335903359133592335933359433595335963359733598335993360033601336023360333604336053360633607336083360933610336113361233613336143361533616336173361833619336203362133622336233362433625336263362733628336293363033631336323363333634336353363633637336383363933640336413364233643336443364533646336473364833649336503365133652336533365433655336563365733658336593366033661336623366333664336653366633667336683366933670336713367233673336743367533676336773367833679336803368133682336833368433685336863368733688336893369033691336923369333694336953369633697336983369933700337013370233703337043370533706337073370833709337103371133712337133371433715337163371733718337193372033721337223372333724337253372633727337283372933730337313373233733337343373533736337373373833739337403374133742337433374433745337463374733748337493375033751337523375333754337553375633757337583375933760337613376233763337643376533766337673376833769337703377133772337733377433775337763377733778337793378033781337823378333784337853378633787337883378933790337913379233793337943379533796337973379833799338003380133802338033380433805338063380733808338093381033811338123381333814338153381633817338183381933820338213382233823338243382533826338273382833829338303383133832338333383433835338363383733838338393384033841338423384333844338453384633847338483384933850338513385233853338543385533856338573385833859338603386133862338633386433865338663386733868338693387033871338723387333874338753387633877338783387933880338813388233883338843388533886338873388833889338903389133892338933389433895338963389733898338993390033901339023390333904339053390633907339083390933910339113391233913339143391533916339173391833919339203392133922339233392433925339263392733928339293393033931339323393333934339353393633937339383393933940339413394233943339443394533946339473394833949339503395133952339533395433955339563395733958339593396033961339623396333964339653396633967339683396933970339713397233973339743397533976339773397833979339803398133982339833398433985339863398733988339893399033991339923399333994339953399633997339983399934000340013400234003340043400534006340073400834009340103401134012340133401434015340163401734018340193402034021340223402334024340253402634027340283402934030340313403234033340343403534036340373403834039340403404134042340433404434045340463404734048340493405034051340523405334054340553405634057340583405934060340613406234063340643406534066340673406834069340703407134072340733407434075340763407734078340793408034081340823408334084340853408634087340883408934090340913409234093340943409534096340973409834099341003410134102341033410434105341063410734108341093411034111341123411334114341153411634117341183411934120341213412234123341243412534126341273412834129341303413134132341333413434135341363413734138341393414034141341423414334144341453414634147341483414934150341513415234153341543415534156341573415834159341603416134162341633416434165341663416734168341693417034171341723417334174341753417634177341783417934180341813418234183341843418534186341873418834189341903419134192341933419434195341963419734198341993420034201342023420334204342053420634207342083420934210342113421234213342143421534216342173421834219342203422134222342233422434225342263422734228342293423034231342323423334234342353423634237342383423934240342413424234243342443424534246342473424834249342503425134252342533425434255342563425734258342593426034261342623426334264342653426634267342683426934270342713427234273342743427534276342773427834279342803428134282342833428434285342863428734288342893429034291342923429334294342953429634297342983429934300343013430234303343043430534306343073430834309343103431134312343133431434315343163431734318343193432034321343223432334324343253432634327343283432934330343313433234333343343433534336343373433834339343403434134342343433434434345343463434734348343493435034351343523435334354343553435634357343583435934360343613436234363343643436534366343673436834369343703437134372343733437434375343763437734378343793438034381343823438334384343853438634387343883438934390343913439234393343943439534396343973439834399344003440134402344033440434405344063440734408344093441034411344123441334414344153441634417344183441934420344213442234423344243442534426344273442834429344303443134432344333443434435344363443734438344393444034441344423444334444344453444634447344483444934450344513445234453344543445534456344573445834459344603446134462344633446434465344663446734468344693447034471344723447334474344753447634477344783447934480344813448234483344843448534486344873448834489344903449134492344933449434495344963449734498344993450034501345023450334504345053450634507345083450934510345113451234513345143451534516345173451834519345203452134522345233452434525345263452734528345293453034531345323453334534345353453634537345383453934540345413454234543345443454534546345473454834549345503455134552345533455434555345563455734558345593456034561345623456334564345653456634567345683456934570345713457234573345743457534576345773457834579345803458134582345833458434585345863458734588345893459034591345923459334594345953459634597345983459934600346013460234603346043460534606346073460834609346103461134612346133461434615346163461734618346193462034621346223462334624346253462634627346283462934630346313463234633346343463534636346373463834639346403464134642346433464434645346463464734648346493465034651346523465334654346553465634657346583465934660346613466234663346643466534666346673466834669346703467134672346733467434675346763467734678346793468034681346823468334684346853468634687346883468934690346913469234693346943469534696346973469834699347003470134702347033470434705347063470734708347093471034711347123471334714347153471634717347183471934720347213472234723347243472534726347273472834729347303473134732347333473434735347363473734738347393474034741347423474334744347453474634747347483474934750347513475234753347543475534756347573475834759347603476134762347633476434765347663476734768347693477034771347723477334774347753477634777347783477934780347813478234783347843478534786347873478834789347903479134792347933479434795347963479734798347993480034801348023480334804348053480634807348083480934810348113481234813348143481534816348173481834819348203482134822348233482434825348263482734828348293483034831348323483334834348353483634837348383483934840348413484234843348443484534846348473484834849348503485134852348533485434855348563485734858348593486034861348623486334864348653486634867348683486934870348713487234873348743487534876348773487834879348803488134882348833488434885348863488734888348893489034891348923489334894348953489634897348983489934900349013490234903349043490534906349073490834909349103491134912349133491434915349163491734918349193492034921349223492334924349253492634927349283492934930349313493234933349343493534936349373493834939349403494134942349433494434945349463494734948349493495034951349523495334954349553495634957349583495934960349613496234963349643496534966349673496834969349703497134972349733497434975349763497734978349793498034981349823498334984349853498634987349883498934990349913499234993349943499534996349973499834999350003500135002350033500435005350063500735008350093501035011350123501335014350153501635017350183501935020350213502235023350243502535026350273502835029350303503135032350333503435035350363503735038350393504035041350423504335044350453504635047350483504935050350513505235053350543505535056350573505835059350603506135062350633506435065350663506735068350693507035071350723507335074350753507635077350783507935080350813508235083350843508535086350873508835089350903509135092350933509435095350963509735098350993510035101351023510335104351053510635107351083510935110351113511235113351143511535116351173511835119351203512135122351233512435125351263512735128351293513035131351323513335134351353513635137351383513935140351413514235143351443514535146351473514835149351503515135152351533515435155351563515735158351593516035161351623516335164351653516635167351683516935170351713517235173351743517535176351773517835179351803518135182351833518435185351863518735188351893519035191351923519335194351953519635197351983519935200352013520235203352043520535206352073520835209352103521135212352133521435215352163521735218352193522035221352223522335224352253522635227352283522935230352313523235233352343523535236352373523835239352403524135242352433524435245352463524735248352493525035251352523525335254352553525635257352583525935260352613526235263352643526535266352673526835269352703527135272352733527435275352763527735278352793528035281352823528335284352853528635287352883528935290352913529235293352943529535296352973529835299353003530135302353033530435305353063530735308353093531035311353123531335314353153531635317353183531935320353213532235323353243532535326353273532835329353303533135332353333533435335353363533735338353393534035341353423534335344353453534635347353483534935350353513535235353353543535535356353573535835359353603536135362353633536435365353663536735368353693537035371353723537335374353753537635377353783537935380353813538235383353843538535386353873538835389353903539135392353933539435395353963539735398353993540035401354023540335404354053540635407354083540935410354113541235413354143541535416354173541835419354203542135422354233542435425354263542735428354293543035431354323543335434354353543635437354383543935440354413544235443354443544535446354473544835449354503545135452354533545435455354563545735458354593546035461354623546335464354653546635467354683546935470354713547235473354743547535476354773547835479354803548135482354833548435485354863548735488354893549035491354923549335494354953549635497354983549935500355013550235503355043550535506355073550835509355103551135512355133551435515355163551735518355193552035521355223552335524355253552635527355283552935530355313553235533355343553535536355373553835539355403554135542355433554435545355463554735548355493555035551355523555335554355553555635557355583555935560355613556235563355643556535566355673556835569355703557135572355733557435575355763557735578355793558035581355823558335584355853558635587355883558935590355913559235593355943559535596355973559835599356003560135602356033560435605356063560735608356093561035611356123561335614356153561635617356183561935620356213562235623356243562535626356273562835629356303563135632356333563435635356363563735638356393564035641356423564335644356453564635647356483564935650356513565235653356543565535656356573565835659356603566135662356633566435665356663566735668356693567035671356723567335674356753567635677356783567935680356813568235683356843568535686356873568835689356903569135692356933569435695356963569735698356993570035701357023570335704357053570635707357083570935710357113571235713357143571535716357173571835719357203572135722357233572435725357263572735728357293573035731357323573335734357353573635737357383573935740357413574235743357443574535746357473574835749357503575135752357533575435755357563575735758357593576035761357623576335764357653576635767357683576935770357713577235773357743577535776357773577835779357803578135782357833578435785357863578735788357893579035791357923579335794357953579635797357983579935800358013580235803358043580535806358073580835809358103581135812358133581435815358163581735818358193582035821358223582335824358253582635827358283582935830358313583235833358343583535836358373583835839358403584135842358433584435845358463584735848358493585035851358523585335854358553585635857358583585935860358613586235863358643586535866358673586835869358703587135872358733587435875358763587735878358793588035881358823588335884358853588635887358883588935890358913589235893358943589535896358973589835899359003590135902359033590435905359063590735908359093591035911359123591335914359153591635917359183591935920359213592235923359243592535926359273592835929359303593135932359333593435935359363593735938359393594035941359423594335944359453594635947359483594935950359513595235953359543595535956359573595835959359603596135962359633596435965359663596735968359693597035971359723597335974359753597635977359783597935980359813598235983359843598535986359873598835989359903599135992359933599435995359963599735998359993600036001360023600336004360053600636007360083600936010360113601236013360143601536016360173601836019360203602136022360233602436025360263602736028360293603036031360323603336034360353603636037360383603936040360413604236043360443604536046360473604836049360503605136052360533605436055360563605736058360593606036061360623606336064360653606636067360683606936070360713607236073360743607536076360773607836079360803608136082360833608436085360863608736088360893609036091360923609336094360953609636097360983609936100361013610236103361043610536106361073610836109361103611136112361133611436115361163611736118361193612036121361223612336124361253612636127361283612936130361313613236133361343613536136361373613836139361403614136142361433614436145361463614736148361493615036151361523615336154361553615636157361583615936160361613616236163361643616536166361673616836169361703617136172361733617436175361763617736178361793618036181361823618336184361853618636187361883618936190361913619236193361943619536196361973619836199362003620136202362033620436205362063620736208362093621036211362123621336214362153621636217362183621936220362213622236223362243622536226362273622836229362303623136232362333623436235362363623736238362393624036241362423624336244362453624636247362483624936250362513625236253362543625536256362573625836259362603626136262362633626436265362663626736268362693627036271362723627336274362753627636277362783627936280362813628236283362843628536286362873628836289362903629136292362933629436295362963629736298362993630036301363023630336304363053630636307363083630936310363113631236313363143631536316363173631836319363203632136322363233632436325363263632736328363293633036331363323633336334363353633636337363383633936340363413634236343363443634536346363473634836349363503635136352363533635436355363563635736358363593636036361363623636336364363653636636367363683636936370363713637236373363743637536376363773637836379363803638136382363833638436385363863638736388363893639036391363923639336394363953639636397363983639936400364013640236403364043640536406364073640836409364103641136412364133641436415364163641736418364193642036421364223642336424364253642636427364283642936430364313643236433364343643536436364373643836439364403644136442364433644436445364463644736448364493645036451364523645336454364553645636457364583645936460364613646236463364643646536466364673646836469364703647136472364733647436475364763647736478364793648036481364823648336484364853648636487364883648936490364913649236493364943649536496364973649836499365003650136502365033650436505365063650736508365093651036511365123651336514365153651636517365183651936520365213652236523365243652536526365273652836529365303653136532365333653436535365363653736538365393654036541365423654336544365453654636547365483654936550365513655236553365543655536556365573655836559365603656136562365633656436565365663656736568365693657036571365723657336574365753657636577365783657936580365813658236583365843658536586365873658836589365903659136592365933659436595365963659736598365993660036601366023660336604366053660636607366083660936610366113661236613366143661536616366173661836619366203662136622366233662436625366263662736628366293663036631366323663336634366353663636637366383663936640366413664236643366443664536646366473664836649366503665136652366533665436655366563665736658366593666036661366623666336664366653666636667366683666936670366713667236673366743667536676366773667836679366803668136682366833668436685366863668736688366893669036691366923669336694366953669636697366983669936700367013670236703367043670536706367073670836709367103671136712367133671436715367163671736718367193672036721367223672336724367253672636727367283672936730367313673236733367343673536736367373673836739367403674136742367433674436745367463674736748367493675036751367523675336754367553675636757367583675936760367613676236763367643676536766367673676836769367703677136772367733677436775367763677736778367793678036781367823678336784367853678636787367883678936790367913679236793367943679536796367973679836799368003680136802368033680436805368063680736808368093681036811368123681336814368153681636817368183681936820368213682236823368243682536826368273682836829368303683136832368333683436835368363683736838368393684036841368423684336844368453684636847368483684936850368513685236853368543685536856368573685836859368603686136862368633686436865368663686736868368693687036871368723687336874368753687636877368783687936880368813688236883368843688536886368873688836889368903689136892368933689436895368963689736898368993690036901369023690336904369053690636907369083690936910369113691236913369143691536916369173691836919369203692136922369233692436925369263692736928369293693036931369323693336934369353693636937369383693936940369413694236943369443694536946369473694836949369503695136952369533695436955369563695736958369593696036961369623696336964369653696636967369683696936970369713697236973369743697536976369773697836979369803698136982369833698436985369863698736988369893699036991369923699336994369953699636997369983699937000370013700237003370043700537006370073700837009370103701137012370133701437015370163701737018370193702037021370223702337024370253702637027370283702937030370313703237033370343703537036370373703837039370403704137042370433704437045370463704737048370493705037051370523705337054370553705637057370583705937060370613706237063370643706537066370673706837069370703707137072370733707437075370763707737078370793708037081370823708337084370853708637087370883708937090370913709237093370943709537096370973709837099371003710137102371033710437105371063710737108371093711037111371123711337114371153711637117371183711937120371213712237123371243712537126371273712837129371303713137132371333713437135371363713737138371393714037141371423714337144371453714637147371483714937150371513715237153371543715537156371573715837159371603716137162371633716437165371663716737168371693717037171371723717337174371753717637177371783717937180371813718237183371843718537186371873718837189371903719137192371933719437195371963719737198371993720037201372023720337204372053720637207372083720937210372113721237213372143721537216372173721837219372203722137222372233722437225372263722737228372293723037231372323723337234372353723637237372383723937240372413724237243372443724537246372473724837249372503725137252372533725437255372563725737258372593726037261372623726337264372653726637267372683726937270372713727237273372743727537276372773727837279372803728137282372833728437285372863728737288372893729037291372923729337294372953729637297372983729937300373013730237303373043730537306373073730837309373103731137312373133731437315373163731737318373193732037321373223732337324373253732637327373283732937330373313733237333373343733537336373373733837339373403734137342373433734437345373463734737348373493735037351373523735337354373553735637357373583735937360373613736237363373643736537366373673736837369373703737137372373733737437375373763737737378373793738037381373823738337384373853738637387373883738937390373913739237393373943739537396373973739837399374003740137402374033740437405374063740737408374093741037411374123741337414374153741637417374183741937420374213742237423374243742537426374273742837429374303743137432374333743437435374363743737438374393744037441374423744337444374453744637447374483744937450374513745237453374543745537456374573745837459374603746137462374633746437465374663746737468374693747037471374723747337474374753747637477374783747937480374813748237483374843748537486374873748837489374903749137492374933749437495374963749737498374993750037501375023750337504375053750637507375083750937510375113751237513375143751537516375173751837519375203752137522375233752437525375263752737528375293753037531375323753337534375353753637537375383753937540375413754237543375443754537546375473754837549375503755137552375533755437555375563755737558375593756037561375623756337564375653756637567375683756937570375713757237573375743757537576375773757837579375803758137582375833758437585375863758737588375893759037591375923759337594375953759637597375983759937600376013760237603376043760537606376073760837609376103761137612376133761437615376163761737618376193762037621376223762337624376253762637627376283762937630376313763237633376343763537636376373763837639376403764137642376433764437645376463764737648376493765037651376523765337654376553765637657376583765937660376613766237663376643766537666376673766837669376703767137672376733767437675376763767737678376793768037681376823768337684376853768637687376883768937690376913769237693376943769537696376973769837699377003770137702377033770437705377063770737708377093771037711377123771337714377153771637717377183771937720377213772237723377243772537726377273772837729377303773137732377333773437735377363773737738377393774037741377423774337744377453774637747377483774937750377513775237753377543775537756377573775837759377603776137762377633776437765377663776737768377693777037771377723777337774377753777637777377783777937780377813778237783377843778537786377873778837789377903779137792377933779437795377963779737798377993780037801378023780337804378053780637807378083780937810378113781237813378143781537816378173781837819378203782137822378233782437825378263782737828378293783037831378323783337834378353783637837378383783937840378413784237843378443784537846378473784837849378503785137852378533785437855378563785737858378593786037861378623786337864378653786637867378683786937870378713787237873378743787537876378773787837879378803788137882378833788437885378863788737888378893789037891378923789337894378953789637897378983789937900379013790237903379043790537906379073790837909379103791137912379133791437915379163791737918379193792037921379223792337924379253792637927379283792937930379313793237933379343793537936379373793837939379403794137942379433794437945379463794737948379493795037951379523795337954379553795637957379583795937960379613796237963379643796537966379673796837969379703797137972379733797437975379763797737978379793798037981379823798337984379853798637987379883798937990379913799237993379943799537996379973799837999380003800138002380033800438005380063800738008380093801038011380123801338014380153801638017380183801938020380213802238023380243802538026380273802838029380303803138032380333803438035380363803738038380393804038041380423804338044380453804638047380483804938050380513805238053380543805538056380573805838059380603806138062380633806438065380663806738068380693807038071380723807338074380753807638077380783807938080380813808238083380843808538086380873808838089380903809138092380933809438095380963809738098380993810038101381023810338104381053810638107381083810938110381113811238113381143811538116381173811838119381203812138122381233812438125381263812738128381293813038131381323813338134381353813638137381383813938140381413814238143381443814538146381473814838149381503815138152381533815438155381563815738158381593816038161381623816338164381653816638167381683816938170381713817238173381743817538176381773817838179381803818138182381833818438185381863818738188381893819038191381923819338194381953819638197381983819938200382013820238203382043820538206382073820838209382103821138212382133821438215382163821738218382193822038221382223822338224382253822638227382283822938230382313823238233382343823538236382373823838239382403824138242382433824438245382463824738248382493825038251382523825338254382553825638257382583825938260382613826238263382643826538266382673826838269382703827138272382733827438275382763827738278382793828038281382823828338284382853828638287382883828938290382913829238293382943829538296382973829838299383003830138302383033830438305383063830738308383093831038311383123831338314383153831638317383183831938320383213832238323383243832538326383273832838329383303833138332383333833438335383363833738338383393834038341383423834338344383453834638347383483834938350383513835238353383543835538356383573835838359383603836138362383633836438365383663836738368383693837038371383723837338374383753837638377383783837938380383813838238383383843838538386383873838838389383903839138392383933839438395383963839738398383993840038401384023840338404384053840638407384083840938410384113841238413384143841538416384173841838419384203842138422384233842438425384263842738428384293843038431384323843338434384353843638437384383843938440384413844238443384443844538446384473844838449384503845138452384533845438455384563845738458384593846038461384623846338464384653846638467384683846938470384713847238473384743847538476384773847838479384803848138482384833848438485384863848738488384893849038491384923849338494384953849638497384983849938500385013850238503385043850538506385073850838509385103851138512385133851438515385163851738518385193852038521385223852338524385253852638527385283852938530385313853238533385343853538536385373853838539385403854138542385433854438545385463854738548385493855038551385523855338554385553855638557385583855938560385613856238563385643856538566385673856838569385703857138572385733857438575385763857738578385793858038581385823858338584385853858638587385883858938590385913859238593385943859538596385973859838599386003860138602386033860438605386063860738608386093861038611386123861338614386153861638617386183861938620386213862238623386243862538626386273862838629386303863138632386333863438635386363863738638386393864038641386423864338644386453864638647386483864938650386513865238653386543865538656386573865838659386603866138662386633866438665386663866738668386693867038671386723867338674386753867638677386783867938680386813868238683386843868538686386873868838689386903869138692386933869438695386963869738698386993870038701387023870338704387053870638707387083870938710387113871238713387143871538716387173871838719387203872138722387233872438725387263872738728387293873038731387323873338734387353873638737387383873938740387413874238743387443874538746387473874838749387503875138752387533875438755387563875738758387593876038761387623876338764387653876638767387683876938770387713877238773387743877538776387773877838779387803878138782387833878438785387863878738788387893879038791387923879338794387953879638797387983879938800388013880238803388043880538806388073880838809388103881138812388133881438815388163881738818388193882038821388223882338824388253882638827388283882938830388313883238833388343883538836388373883838839388403884138842388433884438845388463884738848388493885038851388523885338854388553885638857388583885938860388613886238863388643886538866388673886838869388703887138872388733887438875388763887738878388793888038881388823888338884388853888638887388883888938890388913889238893388943889538896388973889838899389003890138902389033890438905389063890738908389093891038911389123891338914389153891638917389183891938920389213892238923389243892538926389273892838929389303893138932389333893438935389363893738938389393894038941389423894338944389453894638947389483894938950389513895238953389543895538956389573895838959389603896138962389633896438965389663896738968389693897038971389723897338974389753897638977389783897938980389813898238983389843898538986389873898838989389903899138992389933899438995389963899738998389993900039001390023900339004390053900639007390083900939010390113901239013390143901539016390173901839019390203902139022390233902439025390263902739028390293903039031390323903339034390353903639037390383903939040390413904239043390443904539046390473904839049390503905139052390533905439055390563905739058390593906039061390623906339064390653906639067390683906939070390713907239073390743907539076390773907839079390803908139082390833908439085390863908739088390893909039091390923909339094390953909639097390983909939100391013910239103391043910539106391073910839109391103911139112391133911439115391163911739118391193912039121391223912339124391253912639127391283912939130391313913239133391343913539136391373913839139391403914139142391433914439145391463914739148391493915039151391523915339154391553915639157391583915939160391613916239163391643916539166391673916839169391703917139172391733917439175391763917739178391793918039181391823918339184391853918639187391883918939190391913919239193391943919539196391973919839199392003920139202392033920439205392063920739208392093921039211392123921339214392153921639217392183921939220392213922239223392243922539226392273922839229392303923139232392333923439235392363923739238392393924039241392423924339244392453924639247392483924939250392513925239253392543925539256392573925839259392603926139262392633926439265392663926739268392693927039271392723927339274392753927639277392783927939280392813928239283392843928539286392873928839289392903929139292392933929439295392963929739298392993930039301393023930339304393053930639307393083930939310393113931239313393143931539316393173931839319393203932139322393233932439325393263932739328393293933039331393323933339334393353933639337393383933939340393413934239343393443934539346393473934839349393503935139352393533935439355393563935739358393593936039361393623936339364393653936639367393683936939370393713937239373393743937539376393773937839379393803938139382393833938439385393863938739388393893939039391393923939339394393953939639397393983939939400394013940239403394043940539406394073940839409394103941139412394133941439415394163941739418394193942039421394223942339424394253942639427394283942939430394313943239433394343943539436394373943839439394403944139442394433944439445394463944739448394493945039451394523945339454394553945639457394583945939460394613946239463394643946539466394673946839469394703947139472394733947439475394763947739478394793948039481394823948339484394853948639487394883948939490394913949239493394943949539496394973949839499395003950139502395033950439505395063950739508395093951039511395123951339514395153951639517395183951939520395213952239523395243952539526395273952839529395303953139532395333953439535395363953739538395393954039541395423954339544395453954639547395483954939550395513955239553395543955539556395573955839559395603956139562395633956439565395663956739568395693957039571395723957339574395753957639577395783957939580395813958239583395843958539586395873958839589395903959139592395933959439595395963959739598395993960039601396023960339604396053960639607396083960939610396113961239613396143961539616396173961839619396203962139622396233962439625396263962739628396293963039631396323963339634396353963639637396383963939640396413964239643396443964539646396473964839649396503965139652396533965439655396563965739658396593966039661396623966339664396653966639667396683966939670396713967239673396743967539676396773967839679396803968139682396833968439685396863968739688396893969039691396923969339694396953969639697396983969939700397013970239703397043970539706397073970839709397103971139712397133971439715397163971739718397193972039721397223972339724397253972639727397283972939730397313973239733397343973539736397373973839739397403974139742397433974439745397463974739748397493975039751397523975339754397553975639757397583975939760397613976239763397643976539766397673976839769397703977139772397733977439775397763977739778397793978039781397823978339784397853978639787397883978939790397913979239793397943979539796397973979839799398003980139802398033980439805398063980739808398093981039811398123981339814398153981639817398183981939820398213982239823398243982539826398273982839829398303983139832398333983439835398363983739838398393984039841398423984339844398453984639847398483984939850398513985239853398543985539856398573985839859398603986139862398633986439865398663986739868398693987039871398723987339874398753987639877398783987939880398813988239883398843988539886398873988839889398903989139892398933989439895398963989739898398993990039901399023990339904399053990639907399083990939910399113991239913399143991539916399173991839919399203992139922399233992439925399263992739928399293993039931399323993339934399353993639937399383993939940399413994239943399443994539946399473994839949399503995139952399533995439955399563995739958399593996039961399623996339964399653996639967399683996939970399713997239973399743997539976399773997839979399803998139982399833998439985399863998739988399893999039991399923999339994399953999639997399983999940000400014000240003400044000540006400074000840009400104001140012400134001440015400164001740018400194002040021400224002340024400254002640027400284002940030400314003240033400344003540036400374003840039400404004140042400434004440045400464004740048400494005040051400524005340054400554005640057400584005940060400614006240063400644006540066400674006840069400704007140072400734007440075400764007740078400794008040081400824008340084400854008640087400884008940090400914009240093400944009540096400974009840099401004010140102401034010440105401064010740108401094011040111401124011340114401154011640117401184011940120401214012240123401244012540126401274012840129401304013140132401334013440135401364013740138401394014040141401424014340144401454014640147401484014940150401514015240153401544015540156401574015840159401604016140162401634016440165401664016740168401694017040171401724017340174401754017640177401784017940180401814018240183401844018540186401874018840189401904019140192401934019440195401964019740198401994020040201402024020340204402054020640207402084020940210402114021240213402144021540216402174021840219402204022140222402234022440225402264022740228402294023040231402324023340234402354023640237402384023940240402414024240243402444024540246402474024840249402504025140252402534025440255402564025740258402594026040261402624026340264402654026640267402684026940270402714027240273402744027540276402774027840279402804028140282402834028440285402864028740288402894029040291402924029340294402954029640297402984029940300403014030240303403044030540306403074030840309403104031140312403134031440315403164031740318403194032040321403224032340324403254032640327403284032940330403314033240333403344033540336403374033840339403404034140342403434034440345403464034740348403494035040351403524035340354403554035640357403584035940360403614036240363403644036540366403674036840369403704037140372403734037440375403764037740378403794038040381403824038340384403854038640387403884038940390403914039240393403944039540396403974039840399404004040140402404034040440405404064040740408404094041040411404124041340414404154041640417404184041940420404214042240423404244042540426404274042840429404304043140432404334043440435404364043740438404394044040441404424044340444404454044640447404484044940450404514045240453404544045540456404574045840459404604046140462404634046440465404664046740468404694047040471404724047340474404754047640477404784047940480404814048240483404844048540486404874048840489404904049140492404934049440495404964049740498404994050040501405024050340504405054050640507405084050940510405114051240513405144051540516405174051840519405204052140522405234052440525405264052740528405294053040531405324053340534405354053640537405384053940540405414054240543405444054540546405474054840549405504055140552405534055440555405564055740558405594056040561405624056340564405654056640567405684056940570405714057240573405744057540576405774057840579405804058140582405834058440585405864058740588405894059040591405924059340594405954059640597405984059940600406014060240603406044060540606406074060840609406104061140612406134061440615406164061740618406194062040621406224062340624406254062640627406284062940630406314063240633406344063540636406374063840639406404064140642406434064440645406464064740648406494065040651406524065340654406554065640657406584065940660406614066240663406644066540666406674066840669406704067140672406734067440675406764067740678406794068040681406824068340684406854068640687406884068940690406914069240693406944069540696406974069840699407004070140702407034070440705407064070740708407094071040711407124071340714407154071640717407184071940720407214072240723407244072540726407274072840729407304073140732407334073440735407364073740738407394074040741407424074340744407454074640747407484074940750407514075240753407544075540756407574075840759407604076140762407634076440765407664076740768407694077040771407724077340774407754077640777407784077940780407814078240783407844078540786407874078840789407904079140792407934079440795407964079740798407994080040801408024080340804408054080640807408084080940810408114081240813408144081540816408174081840819408204082140822408234082440825408264082740828408294083040831408324083340834408354083640837408384083940840408414084240843408444084540846408474084840849408504085140852408534085440855408564085740858408594086040861408624086340864408654086640867408684086940870408714087240873408744087540876408774087840879408804088140882408834088440885408864088740888408894089040891408924089340894408954089640897408984089940900409014090240903409044090540906409074090840909409104091140912409134091440915409164091740918409194092040921409224092340924409254092640927409284092940930409314093240933409344093540936409374093840939409404094140942409434094440945409464094740948409494095040951409524095340954409554095640957409584095940960409614096240963409644096540966409674096840969409704097140972409734097440975409764097740978409794098040981409824098340984409854098640987409884098940990409914099240993409944099540996409974099840999410004100141002410034100441005410064100741008410094101041011410124101341014410154101641017410184101941020410214102241023410244102541026410274102841029410304103141032410334103441035410364103741038410394104041041410424104341044410454104641047410484104941050410514105241053410544105541056410574105841059410604106141062410634106441065410664106741068410694107041071410724107341074410754107641077410784107941080410814108241083410844108541086410874108841089410904109141092410934109441095410964109741098410994110041101411024110341104411054110641107411084110941110411114111241113411144111541116411174111841119411204112141122411234112441125411264112741128411294113041131411324113341134411354113641137411384113941140411414114241143411444114541146411474114841149411504115141152411534115441155411564115741158411594116041161411624116341164411654116641167411684116941170411714117241173411744117541176411774117841179411804118141182411834118441185411864118741188411894119041191411924119341194411954119641197411984119941200412014120241203412044120541206412074120841209412104121141212412134121441215412164121741218412194122041221412224122341224412254122641227412284122941230412314123241233412344123541236412374123841239412404124141242412434124441245412464124741248412494125041251412524125341254412554125641257412584125941260412614126241263412644126541266412674126841269412704127141272412734127441275412764127741278412794128041281412824128341284412854128641287412884128941290412914129241293412944129541296412974129841299413004130141302413034130441305413064130741308413094131041311413124131341314413154131641317413184131941320413214132241323413244132541326413274132841329413304133141332413334133441335413364133741338413394134041341413424134341344413454134641347413484134941350413514135241353413544135541356413574135841359413604136141362413634136441365413664136741368413694137041371413724137341374413754137641377413784137941380413814138241383413844138541386413874138841389413904139141392413934139441395413964139741398413994140041401414024140341404414054140641407414084140941410414114141241413414144141541416414174141841419414204142141422414234142441425414264142741428414294143041431414324143341434414354143641437414384143941440414414144241443414444144541446414474144841449414504145141452414534145441455414564145741458414594146041461414624146341464414654146641467414684146941470414714147241473414744147541476414774147841479414804148141482414834148441485414864148741488414894149041491414924149341494414954149641497414984149941500415014150241503415044150541506415074150841509415104151141512415134151441515415164151741518415194152041521415224152341524415254152641527415284152941530415314153241533415344153541536415374153841539415404154141542415434154441545415464154741548415494155041551415524155341554415554155641557415584155941560415614156241563415644156541566415674156841569415704157141572415734157441575415764157741578415794158041581415824158341584415854158641587415884158941590415914159241593415944159541596415974159841599416004160141602416034160441605416064160741608416094161041611416124161341614416154161641617416184161941620416214162241623416244162541626416274162841629416304163141632416334163441635416364163741638416394164041641416424164341644416454164641647416484164941650416514165241653416544165541656416574165841659416604166141662416634166441665416664166741668416694167041671416724167341674416754167641677416784167941680416814168241683416844168541686416874168841689416904169141692416934169441695416964169741698416994170041701417024170341704417054170641707417084170941710417114171241713417144171541716417174171841719417204172141722417234172441725417264172741728417294173041731417324173341734417354173641737417384173941740417414174241743417444174541746417474174841749417504175141752417534175441755417564175741758417594176041761417624176341764417654176641767417684176941770417714177241773417744177541776417774177841779417804178141782417834178441785417864178741788417894179041791417924179341794417954179641797417984179941800418014180241803418044180541806418074180841809418104181141812418134181441815418164181741818418194182041821418224182341824418254182641827418284182941830418314183241833418344183541836418374183841839418404184141842418434184441845418464184741848418494185041851418524185341854418554185641857418584185941860418614186241863418644186541866418674186841869418704187141872418734187441875418764187741878418794188041881418824188341884418854188641887418884188941890418914189241893418944189541896418974189841899419004190141902419034190441905419064190741908419094191041911419124191341914419154191641917419184191941920419214192241923419244192541926419274192841929419304193141932419334193441935419364193741938419394194041941419424194341944419454194641947419484194941950419514195241953419544195541956419574195841959419604196141962419634196441965419664196741968419694197041971419724197341974419754197641977419784197941980419814198241983419844198541986419874198841989419904199141992419934199441995419964199741998419994200042001420024200342004420054200642007420084200942010420114201242013420144201542016420174201842019420204202142022420234202442025420264202742028420294203042031420324203342034420354203642037420384203942040420414204242043420444204542046420474204842049420504205142052420534205442055420564205742058420594206042061420624206342064420654206642067420684206942070420714207242073420744207542076420774207842079420804208142082420834208442085420864208742088420894209042091420924209342094420954209642097420984209942100421014210242103421044210542106421074210842109421104211142112421134211442115421164211742118421194212042121421224212342124421254212642127421284212942130421314213242133421344213542136421374213842139421404214142142421434214442145421464214742148421494215042151421524215342154421554215642157421584215942160421614216242163421644216542166421674216842169421704217142172421734217442175421764217742178421794218042181421824218342184421854218642187421884218942190421914219242193421944219542196421974219842199422004220142202422034220442205422064220742208422094221042211422124221342214422154221642217422184221942220422214222242223422244222542226422274222842229422304223142232422334223442235422364223742238422394224042241422424224342244422454224642247422484224942250422514225242253422544225542256422574225842259422604226142262422634226442265422664226742268422694227042271422724227342274422754227642277422784227942280422814228242283422844228542286422874228842289422904229142292422934229442295422964229742298422994230042301423024230342304423054230642307423084230942310423114231242313423144231542316423174231842319423204232142322423234232442325423264232742328423294233042331423324233342334423354233642337423384233942340423414234242343423444234542346423474234842349423504235142352423534235442355423564235742358423594236042361423624236342364423654236642367423684236942370423714237242373423744237542376423774237842379423804238142382423834238442385423864238742388423894239042391423924239342394423954239642397423984239942400424014240242403424044240542406424074240842409424104241142412424134241442415424164241742418424194242042421424224242342424424254242642427424284242942430424314243242433424344243542436424374243842439424404244142442424434244442445424464244742448424494245042451424524245342454424554245642457424584245942460424614246242463424644246542466424674246842469424704247142472424734247442475424764247742478424794248042481424824248342484424854248642487424884248942490424914249242493424944249542496424974249842499425004250142502425034250442505425064250742508425094251042511425124251342514425154251642517425184251942520425214252242523425244252542526425274252842529425304253142532425334253442535425364253742538425394254042541425424254342544425454254642547425484254942550425514255242553425544255542556425574255842559425604256142562425634256442565425664256742568425694257042571425724257342574425754257642577425784257942580425814258242583425844258542586425874258842589425904259142592425934259442595425964259742598425994260042601426024260342604426054260642607426084260942610426114261242613426144261542616426174261842619426204262142622426234262442625426264262742628426294263042631426324263342634426354263642637426384263942640426414264242643426444264542646426474264842649426504265142652426534265442655426564265742658426594266042661426624266342664426654266642667426684266942670426714267242673426744267542676426774267842679426804268142682426834268442685426864268742688426894269042691426924269342694426954269642697426984269942700427014270242703427044270542706427074270842709427104271142712427134271442715427164271742718427194272042721427224272342724427254272642727427284272942730427314273242733427344273542736427374273842739427404274142742427434274442745427464274742748427494275042751427524275342754427554275642757427584275942760427614276242763427644276542766427674276842769427704277142772427734277442775427764277742778427794278042781427824278342784427854278642787427884278942790427914279242793427944279542796427974279842799428004280142802428034280442805428064280742808428094281042811428124281342814428154281642817428184281942820428214282242823428244282542826428274282842829428304283142832428334283442835428364283742838428394284042841428424284342844428454284642847428484284942850428514285242853428544285542856428574285842859428604286142862428634286442865428664286742868428694287042871428724287342874428754287642877428784287942880428814288242883428844288542886428874288842889428904289142892428934289442895428964289742898428994290042901429024290342904429054290642907429084290942910429114291242913429144291542916429174291842919429204292142922429234292442925429264292742928429294293042931429324293342934429354293642937429384293942940429414294242943429444294542946429474294842949429504295142952429534295442955429564295742958429594296042961429624296342964429654296642967429684296942970429714297242973429744297542976429774297842979429804298142982429834298442985429864298742988429894299042991429924299342994429954299642997429984299943000430014300243003430044300543006430074300843009430104301143012430134301443015430164301743018430194302043021430224302343024430254302643027430284302943030430314303243033430344303543036430374303843039430404304143042430434304443045430464304743048430494305043051430524305343054430554305643057430584305943060430614306243063430644306543066430674306843069430704307143072430734307443075430764307743078430794308043081430824308343084430854308643087430884308943090430914309243093430944309543096430974309843099431004310143102431034310443105431064310743108431094311043111431124311343114431154311643117431184311943120431214312243123431244312543126431274312843129431304313143132431334313443135431364313743138431394314043141431424314343144431454314643147431484314943150431514315243153431544315543156431574315843159431604316143162431634316443165431664316743168431694317043171431724317343174431754317643177431784317943180431814318243183431844318543186431874318843189431904319143192431934319443195431964319743198431994320043201432024320343204432054320643207432084320943210432114321243213432144321543216432174321843219432204322143222432234322443225432264322743228432294323043231432324323343234432354323643237432384323943240432414324243243432444324543246432474324843249432504325143252432534325443255432564325743258432594326043261432624326343264432654326643267432684326943270432714327243273432744327543276432774327843279432804328143282432834328443285432864328743288432894329043291432924329343294432954329643297432984329943300433014330243303433044330543306433074330843309433104331143312433134331443315433164331743318433194332043321433224332343324433254332643327433284332943330433314333243333433344333543336433374333843339433404334143342433434334443345433464334743348433494335043351433524335343354433554335643357433584335943360433614336243363433644336543366433674336843369433704337143372433734337443375433764337743378433794338043381433824338343384433854338643387433884338943390433914339243393433944339543396433974339843399434004340143402434034340443405434064340743408434094341043411434124341343414434154341643417434184341943420434214342243423434244342543426434274342843429434304343143432434334343443435434364343743438434394344043441434424344343444434454344643447434484344943450434514345243453434544345543456434574345843459434604346143462434634346443465434664346743468434694347043471434724347343474434754347643477434784347943480434814348243483434844348543486434874348843489434904349143492434934349443495434964349743498434994350043501435024350343504435054350643507435084350943510435114351243513435144351543516435174351843519435204352143522435234352443525435264352743528435294353043531435324353343534435354353643537435384353943540435414354243543435444354543546435474354843549435504355143552435534355443555435564355743558435594356043561435624356343564435654356643567435684356943570435714357243573435744357543576435774357843579435804358143582435834358443585435864358743588435894359043591435924359343594435954359643597435984359943600436014360243603436044360543606436074360843609436104361143612436134361443615436164361743618436194362043621436224362343624436254362643627436284362943630436314363243633436344363543636436374363843639436404364143642436434364443645436464364743648436494365043651436524365343654436554365643657436584365943660436614366243663436644366543666436674366843669436704367143672436734367443675436764367743678436794368043681436824368343684436854368643687436884368943690436914369243693436944369543696436974369843699437004370143702437034370443705437064370743708437094371043711437124371343714437154371643717437184371943720437214372243723437244372543726437274372843729437304373143732437334373443735437364373743738437394374043741437424374343744437454374643747437484374943750437514375243753437544375543756437574375843759437604376143762437634376443765437664376743768437694377043771437724377343774437754377643777437784377943780437814378243783437844378543786437874378843789437904379143792437934379443795437964379743798437994380043801438024380343804438054380643807438084380943810438114381243813438144381543816438174381843819438204382143822438234382443825438264382743828438294383043831438324383343834438354383643837438384383943840438414384243843438444384543846438474384843849438504385143852438534385443855438564385743858438594386043861438624386343864438654386643867438684386943870438714387243873438744387543876438774387843879438804388143882438834388443885438864388743888438894389043891438924389343894438954389643897438984389943900439014390243903439044390543906439074390843909439104391143912439134391443915439164391743918439194392043921439224392343924439254392643927439284392943930439314393243933439344393543936439374393843939439404394143942439434394443945439464394743948439494395043951439524395343954439554395643957439584395943960439614396243963439644396543966439674396843969439704397143972439734397443975439764397743978439794398043981439824398343984439854398643987439884398943990439914399243993439944399543996439974399843999440004400144002440034400444005440064400744008440094401044011440124401344014440154401644017440184401944020440214402244023440244402544026440274402844029440304403144032440334403444035440364403744038440394404044041440424404344044440454404644047440484404944050440514405244053440544405544056440574405844059440604406144062440634406444065440664406744068440694407044071440724407344074440754407644077440784407944080440814408244083440844408544086440874408844089440904409144092440934409444095440964409744098440994410044101441024410344104441054410644107441084410944110441114411244113441144411544116441174411844119441204412144122441234412444125441264412744128441294413044131441324413344134441354413644137441384413944140441414414244143441444414544146441474414844149441504415144152441534415444155441564415744158441594416044161441624416344164441654416644167441684416944170441714417244173441744417544176441774417844179441804418144182441834418444185441864418744188441894419044191441924419344194441954419644197441984419944200442014420244203442044420544206442074420844209442104421144212442134421444215442164421744218442194422044221442224422344224442254422644227442284422944230442314423244233442344423544236442374423844239442404424144242442434424444245442464424744248442494425044251442524425344254442554425644257442584425944260442614426244263442644426544266442674426844269442704427144272442734427444275442764427744278442794428044281442824428344284442854428644287442884428944290442914429244293442944429544296442974429844299443004430144302443034430444305443064430744308443094431044311443124431344314443154431644317443184431944320443214432244323443244432544326443274432844329443304433144332443334433444335443364433744338443394434044341443424434344344443454434644347443484434944350443514435244353443544435544356443574435844359443604436144362443634436444365443664436744368443694437044371443724437344374443754437644377443784437944380443814438244383443844438544386443874438844389443904439144392443934439444395443964439744398443994440044401444024440344404444054440644407444084440944410444114441244413444144441544416444174441844419444204442144422444234442444425444264442744428444294443044431444324443344434444354443644437444384443944440444414444244443444444444544446444474444844449444504445144452444534445444455444564445744458444594446044461444624446344464444654446644467444684446944470444714447244473444744447544476444774447844479444804448144482444834448444485444864448744488444894449044491444924449344494444954449644497444984449944500445014450244503445044450544506445074450844509445104451144512445134451444515445164451744518445194452044521445224452344524445254452644527445284452944530445314453244533445344453544536445374453844539445404454144542445434454444545445464454744548445494455044551445524455344554445554455644557445584455944560445614456244563445644456544566445674456844569445704457144572445734457444575445764457744578445794458044581445824458344584445854458644587445884458944590445914459244593445944459544596445974459844599446004460144602446034460444605446064460744608446094461044611446124461344614446154461644617446184461944620446214462244623446244462544626446274462844629446304463144632446334463444635446364463744638446394464044641446424464344644446454464644647446484464944650446514465244653446544465544656446574465844659446604466144662446634466444665446664466744668446694467044671446724467344674446754467644677446784467944680446814468244683446844468544686446874468844689446904469144692446934469444695446964469744698446994470044701447024470344704447054470644707447084470944710447114471244713447144471544716447174471844719447204472144722447234472444725447264472744728447294473044731447324473344734447354473644737447384473944740447414474244743447444474544746447474474844749447504475144752447534475444755447564475744758447594476044761447624476344764447654476644767447684476944770447714477244773447744477544776447774477844779447804478144782447834478444785447864478744788447894479044791447924479344794447954479644797447984479944800448014480244803448044480544806448074480844809448104481144812448134481444815448164481744818448194482044821448224482344824448254482644827448284482944830448314483244833448344483544836448374483844839448404484144842448434484444845448464484744848448494485044851448524485344854448554485644857448584485944860448614486244863448644486544866448674486844869448704487144872448734487444875448764487744878448794488044881448824488344884448854488644887448884488944890448914489244893448944489544896448974489844899449004490144902449034490444905449064490744908449094491044911449124491344914449154491644917449184491944920449214492244923449244492544926449274492844929449304493144932449334493444935449364493744938449394494044941449424494344944449454494644947449484494944950449514495244953449544495544956449574495844959449604496144962449634496444965449664496744968449694497044971449724497344974449754497644977449784497944980449814498244983449844498544986449874498844989449904499144992449934499444995449964499744998449994500045001450024500345004450054500645007450084500945010450114501245013450144501545016450174501845019450204502145022450234502445025450264502745028450294503045031450324503345034450354503645037450384503945040450414504245043450444504545046450474504845049450504505145052450534505445055450564505745058450594506045061450624506345064450654506645067450684506945070450714507245073450744507545076450774507845079450804508145082450834508445085450864508745088450894509045091450924509345094450954509645097450984509945100451014510245103451044510545106451074510845109451104511145112451134511445115451164511745118451194512045121451224512345124451254512645127451284512945130451314513245133451344513545136451374513845139451404514145142451434514445145451464514745148451494515045151451524515345154451554515645157451584515945160451614516245163451644516545166451674516845169451704517145172451734517445175451764517745178451794518045181451824518345184451854518645187451884518945190451914519245193451944519545196451974519845199452004520145202452034520445205452064520745208452094521045211452124521345214452154521645217452184521945220452214522245223452244522545226452274522845229452304523145232452334523445235452364523745238452394524045241452424524345244452454524645247452484524945250452514525245253452544525545256452574525845259452604526145262452634526445265452664526745268452694527045271452724527345274452754527645277452784527945280452814528245283452844528545286452874528845289452904529145292452934529445295452964529745298452994530045301453024530345304453054530645307453084530945310453114531245313453144531545316453174531845319453204532145322453234532445325453264532745328453294533045331453324533345334453354533645337453384533945340453414534245343453444534545346453474534845349453504535145352453534535445355453564535745358453594536045361453624536345364453654536645367453684536945370453714537245373453744537545376453774537845379453804538145382453834538445385453864538745388453894539045391453924539345394453954539645397453984539945400454014540245403454044540545406454074540845409454104541145412454134541445415454164541745418454194542045421454224542345424454254542645427454284542945430454314543245433454344543545436454374543845439454404544145442454434544445445454464544745448454494545045451454524545345454454554545645457454584545945460454614546245463454644546545466454674546845469454704547145472454734547445475454764547745478454794548045481454824548345484454854548645487454884548945490454914549245493454944549545496454974549845499455004550145502455034550445505455064550745508455094551045511455124551345514455154551645517455184551945520455214552245523455244552545526455274552845529455304553145532455334553445535455364553745538455394554045541455424554345544455454554645547455484554945550455514555245553455544555545556455574555845559455604556145562455634556445565455664556745568455694557045571455724557345574455754557645577455784557945580455814558245583455844558545586455874558845589455904559145592455934559445595455964559745598455994560045601456024560345604456054560645607456084560945610456114561245613456144561545616456174561845619456204562145622456234562445625456264562745628456294563045631456324563345634456354563645637456384563945640456414564245643456444564545646456474564845649456504565145652456534565445655456564565745658456594566045661456624566345664456654566645667456684566945670456714567245673456744567545676456774567845679456804568145682456834568445685456864568745688456894569045691456924569345694456954569645697456984569945700457014570245703457044570545706457074570845709457104571145712457134571445715457164571745718457194572045721457224572345724457254572645727457284572945730457314573245733457344573545736457374573845739457404574145742457434574445745457464574745748457494575045751457524575345754457554575645757457584575945760457614576245763457644576545766457674576845769457704577145772457734577445775457764577745778457794578045781457824578345784457854578645787457884578945790457914579245793457944579545796457974579845799458004580145802458034580445805458064580745808458094581045811458124581345814458154581645817458184581945820458214582245823458244582545826458274582845829458304583145832458334583445835458364583745838458394584045841458424584345844458454584645847458484584945850458514585245853458544585545856458574585845859458604586145862458634586445865458664586745868458694587045871458724587345874458754587645877458784587945880458814588245883458844588545886458874588845889458904589145892458934589445895458964589745898458994590045901459024590345904459054590645907459084590945910459114591245913459144591545916459174591845919459204592145922459234592445925459264592745928459294593045931459324593345934459354593645937459384593945940459414594245943459444594545946459474594845949459504595145952459534595445955459564595745958459594596045961459624596345964459654596645967459684596945970459714597245973459744597545976459774597845979459804598145982459834598445985459864598745988459894599045991459924599345994459954599645997459984599946000460014600246003460044600546006460074600846009460104601146012460134601446015460164601746018460194602046021460224602346024460254602646027460284602946030460314603246033460344603546036460374603846039460404604146042460434604446045460464604746048460494605046051460524605346054460554605646057460584605946060460614606246063460644606546066460674606846069460704607146072460734607446075460764607746078460794608046081460824608346084460854608646087460884608946090460914609246093460944609546096460974609846099461004610146102461034610446105461064610746108461094611046111461124611346114461154611646117461184611946120461214612246123461244612546126461274612846129461304613146132461334613446135461364613746138461394614046141461424614346144461454614646147461484614946150461514615246153461544615546156461574615846159461604616146162461634616446165461664616746168461694617046171461724617346174461754617646177461784617946180461814618246183461844618546186461874618846189461904619146192461934619446195461964619746198461994620046201462024620346204462054620646207462084620946210462114621246213462144621546216462174621846219462204622146222462234622446225462264622746228462294623046231462324623346234462354623646237462384623946240462414624246243462444624546246462474624846249462504625146252462534625446255462564625746258462594626046261462624626346264462654626646267462684626946270462714627246273462744627546276462774627846279462804628146282462834628446285462864628746288462894629046291462924629346294462954629646297462984629946300463014630246303463044630546306463074630846309463104631146312463134631446315463164631746318463194632046321463224632346324463254632646327463284632946330463314633246333463344633546336463374633846339463404634146342463434634446345463464634746348463494635046351463524635346354463554635646357463584635946360463614636246363463644636546366463674636846369463704637146372463734637446375463764637746378463794638046381463824638346384463854638646387463884638946390463914639246393463944639546396463974639846399464004640146402464034640446405464064640746408464094641046411464124641346414464154641646417464184641946420464214642246423464244642546426464274642846429464304643146432464334643446435464364643746438464394644046441464424644346444464454644646447464484644946450464514645246453464544645546456464574645846459464604646146462464634646446465464664646746468464694647046471464724647346474464754647646477464784647946480464814648246483464844648546486464874648846489464904649146492464934649446495464964649746498464994650046501465024650346504465054650646507465084650946510465114651246513465144651546516465174651846519465204652146522465234652446525465264652746528465294653046531465324653346534465354653646537465384653946540465414654246543465444654546546465474654846549465504655146552465534655446555465564655746558465594656046561465624656346564465654656646567465684656946570465714657246573465744657546576465774657846579465804658146582465834658446585465864658746588465894659046591465924659346594465954659646597465984659946600466014660246603466044660546606466074660846609466104661146612466134661446615466164661746618466194662046621466224662346624466254662646627466284662946630466314663246633466344663546636466374663846639466404664146642466434664446645466464664746648466494665046651466524665346654466554665646657466584665946660466614666246663466644666546666466674666846669466704667146672466734667446675466764667746678466794668046681466824668346684466854668646687466884668946690466914669246693466944669546696466974669846699467004670146702467034670446705467064670746708467094671046711467124671346714467154671646717467184671946720467214672246723467244672546726467274672846729467304673146732467334673446735467364673746738467394674046741467424674346744467454674646747467484674946750467514675246753467544675546756467574675846759467604676146762467634676446765467664676746768467694677046771467724677346774467754677646777467784677946780467814678246783467844678546786467874678846789467904679146792467934679446795467964679746798467994680046801468024680346804468054680646807468084680946810468114681246813468144681546816468174681846819468204682146822468234682446825468264682746828468294683046831468324683346834468354683646837468384683946840468414684246843468444684546846468474684846849468504685146852468534685446855468564685746858468594686046861468624686346864468654686646867468684686946870468714687246873468744687546876468774687846879468804688146882468834688446885468864688746888468894689046891468924689346894468954689646897468984689946900469014690246903469044690546906469074690846909469104691146912469134691446915469164691746918469194692046921469224692346924469254692646927469284692946930469314693246933469344693546936469374693846939469404694146942469434694446945469464694746948469494695046951469524695346954469554695646957469584695946960469614696246963469644696546966469674696846969469704697146972469734697446975469764697746978469794698046981469824698346984469854698646987469884698946990469914699246993469944699546996469974699846999470004700147002470034700447005470064700747008470094701047011470124701347014470154701647017470184701947020470214702247023470244702547026470274702847029470304703147032470334703447035470364703747038470394704047041470424704347044470454704647047470484704947050470514705247053470544705547056470574705847059470604706147062470634706447065470664706747068470694707047071470724707347074470754707647077470784707947080470814708247083470844708547086470874708847089470904709147092470934709447095470964709747098470994710047101471024710347104471054710647107471084710947110471114711247113471144711547116471174711847119471204712147122471234712447125471264712747128471294713047131471324713347134471354713647137471384713947140471414714247143471444714547146471474714847149471504715147152471534715447155471564715747158471594716047161471624716347164471654716647167471684716947170471714717247173471744717547176471774717847179471804718147182471834718447185471864718747188471894719047191471924719347194471954719647197471984719947200472014720247203472044720547206472074720847209472104721147212472134721447215472164721747218472194722047221472224722347224472254722647227472284722947230472314723247233472344723547236472374723847239472404724147242472434724447245472464724747248472494725047251472524725347254472554725647257472584725947260472614726247263472644726547266472674726847269472704727147272472734727447275472764727747278472794728047281472824728347284472854728647287472884728947290472914729247293472944729547296472974729847299473004730147302473034730447305473064730747308473094731047311473124731347314473154731647317473184731947320473214732247323473244732547326473274732847329473304733147332473334733447335473364733747338473394734047341473424734347344473454734647347473484734947350473514735247353473544735547356473574735847359473604736147362473634736447365473664736747368473694737047371473724737347374473754737647377473784737947380473814738247383473844738547386473874738847389473904739147392473934739447395473964739747398473994740047401474024740347404474054740647407474084740947410474114741247413474144741547416474174741847419474204742147422474234742447425474264742747428474294743047431474324743347434474354743647437474384743947440474414744247443474444744547446474474744847449474504745147452474534745447455474564745747458474594746047461474624746347464474654746647467474684746947470474714747247473474744747547476474774747847479474804748147482474834748447485474864748747488474894749047491474924749347494474954749647497474984749947500475014750247503475044750547506475074750847509475104751147512475134751447515475164751747518475194752047521475224752347524475254752647527475284752947530475314753247533475344753547536475374753847539475404754147542475434754447545475464754747548475494755047551475524755347554475554755647557475584755947560475614756247563475644756547566475674756847569475704757147572475734757447575475764757747578475794758047581475824758347584475854758647587475884758947590475914759247593475944759547596475974759847599476004760147602476034760447605476064760747608476094761047611476124761347614476154761647617476184761947620476214762247623476244762547626476274762847629476304763147632476334763447635476364763747638476394764047641476424764347644476454764647647476484764947650476514765247653476544765547656476574765847659476604766147662476634766447665476664766747668476694767047671476724767347674476754767647677476784767947680476814768247683476844768547686476874768847689476904769147692476934769447695476964769747698476994770047701477024770347704477054770647707477084770947710477114771247713477144771547716477174771847719477204772147722477234772447725477264772747728477294773047731477324773347734477354773647737477384773947740477414774247743477444774547746477474774847749477504775147752477534775447755477564775747758477594776047761477624776347764477654776647767477684776947770477714777247773477744777547776477774777847779477804778147782477834778447785477864778747788477894779047791477924779347794477954779647797477984779947800478014780247803478044780547806478074780847809478104781147812478134781447815478164781747818478194782047821478224782347824478254782647827478284782947830478314783247833478344783547836478374783847839478404784147842478434784447845478464784747848478494785047851478524785347854478554785647857478584785947860478614786247863478644786547866478674786847869478704787147872478734787447875478764787747878478794788047881478824788347884478854788647887478884788947890478914789247893478944789547896478974789847899479004790147902479034790447905479064790747908479094791047911479124791347914479154791647917479184791947920479214792247923479244792547926479274792847929479304793147932479334793447935479364793747938479394794047941479424794347944479454794647947479484794947950479514795247953479544795547956479574795847959479604796147962479634796447965479664796747968479694797047971479724797347974479754797647977479784797947980479814798247983479844798547986479874798847989479904799147992479934799447995479964799747998479994800048001480024800348004480054800648007480084800948010480114801248013480144801548016480174801848019480204802148022480234802448025480264802748028480294803048031480324803348034480354803648037480384803948040480414804248043480444804548046480474804848049480504805148052480534805448055480564805748058480594806048061480624806348064480654806648067480684806948070480714807248073480744807548076480774807848079480804808148082480834808448085480864808748088480894809048091480924809348094480954809648097480984809948100481014810248103481044810548106481074810848109481104811148112481134811448115481164811748118481194812048121481224812348124481254812648127481284812948130481314813248133481344813548136481374813848139481404814148142481434814448145481464814748148481494815048151481524815348154481554815648157481584815948160481614816248163481644816548166481674816848169481704817148172481734817448175481764817748178481794818048181481824818348184481854818648187481884818948190481914819248193481944819548196481974819848199482004820148202482034820448205482064820748208482094821048211482124821348214482154821648217482184821948220482214822248223482244822548226482274822848229482304823148232482334823448235482364823748238482394824048241482424824348244482454824648247482484824948250482514825248253482544825548256482574825848259482604826148262482634826448265482664826748268482694827048271482724827348274482754827648277482784827948280482814828248283482844828548286482874828848289482904829148292482934829448295482964829748298482994830048301483024830348304483054830648307483084830948310483114831248313483144831548316483174831848319483204832148322483234832448325483264832748328483294833048331483324833348334483354833648337483384833948340483414834248343483444834548346483474834848349483504835148352483534835448355483564835748358483594836048361483624836348364483654836648367483684836948370483714837248373483744837548376483774837848379483804838148382483834838448385483864838748388483894839048391483924839348394483954839648397483984839948400484014840248403484044840548406484074840848409484104841148412484134841448415484164841748418484194842048421484224842348424484254842648427484284842948430484314843248433484344843548436484374843848439484404844148442484434844448445484464844748448484494845048451484524845348454484554845648457484584845948460484614846248463484644846548466484674846848469484704847148472484734847448475484764847748478484794848048481484824848348484484854848648487484884848948490484914849248493484944849548496484974849848499485004850148502485034850448505485064850748508485094851048511485124851348514485154851648517485184851948520485214852248523485244852548526485274852848529485304853148532485334853448535485364853748538485394854048541485424854348544485454854648547485484854948550485514855248553485544855548556485574855848559485604856148562485634856448565485664856748568485694857048571485724857348574485754857648577485784857948580485814858248583485844858548586485874858848589485904859148592485934859448595485964859748598485994860048601486024860348604486054860648607486084860948610486114861248613486144861548616486174861848619486204862148622486234862448625486264862748628486294863048631486324863348634486354863648637486384863948640486414864248643486444864548646486474864848649486504865148652486534865448655486564865748658486594866048661486624866348664486654866648667486684866948670486714867248673486744867548676486774867848679486804868148682486834868448685486864868748688486894869048691486924869348694486954869648697486984869948700487014870248703487044870548706487074870848709487104871148712487134871448715487164871748718487194872048721487224872348724487254872648727487284872948730487314873248733487344873548736487374873848739487404874148742487434874448745487464874748748487494875048751487524875348754487554875648757487584875948760487614876248763487644876548766487674876848769487704877148772487734877448775487764877748778487794878048781487824878348784487854878648787487884878948790487914879248793487944879548796487974879848799488004880148802488034880448805488064880748808488094881048811488124881348814488154881648817488184881948820488214882248823488244882548826488274882848829488304883148832488334883448835488364883748838488394884048841488424884348844488454884648847488484884948850488514885248853488544885548856488574885848859488604886148862488634886448865488664886748868488694887048871488724887348874488754887648877488784887948880488814888248883488844888548886488874888848889488904889148892488934889448895488964889748898488994890048901489024890348904489054890648907489084890948910489114891248913489144891548916489174891848919489204892148922489234892448925489264892748928489294893048931489324893348934489354893648937489384893948940489414894248943489444894548946489474894848949489504895148952
  1. /**
  2. * @ag-grid-community/all-modules - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  3. * @version v23.2.1
  4. * @link http://www.ag-grid.com/
  5. * @license MIT
  6. */
  7. // @ag-grid-community/all-modules v23.2.1
  8. define("agGrid", [], function() { return /******/ (function(modules) { // webpackBootstrap
  9. /******/ // The module cache
  10. /******/ var installedModules = {};
  11. /******/
  12. /******/ // The require function
  13. /******/ function __webpack_require__(moduleId) {
  14. /******/
  15. /******/ // Check if module is in cache
  16. /******/ if(installedModules[moduleId]) {
  17. /******/ return installedModules[moduleId].exports;
  18. /******/ }
  19. /******/ // Create a new module (and put it into the cache)
  20. /******/ var module = installedModules[moduleId] = {
  21. /******/ i: moduleId,
  22. /******/ l: false,
  23. /******/ exports: {}
  24. /******/ };
  25. /******/
  26. /******/ // Execute the module function
  27. /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
  28. /******/
  29. /******/ // Flag the module as loaded
  30. /******/ module.l = true;
  31. /******/
  32. /******/ // Return the exports of the module
  33. /******/ return module.exports;
  34. /******/ }
  35. /******/
  36. /******/
  37. /******/ // expose the modules object (__webpack_modules__)
  38. /******/ __webpack_require__.m = modules;
  39. /******/
  40. /******/ // expose the module cache
  41. /******/ __webpack_require__.c = installedModules;
  42. /******/
  43. /******/ // define getter function for harmony exports
  44. /******/ __webpack_require__.d = function(exports, name, getter) {
  45. /******/ if(!__webpack_require__.o(exports, name)) {
  46. /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
  47. /******/ }
  48. /******/ };
  49. /******/
  50. /******/ // define __esModule on exports
  51. /******/ __webpack_require__.r = function(exports) {
  52. /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
  53. /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
  54. /******/ }
  55. /******/ Object.defineProperty(exports, '__esModule', { value: true });
  56. /******/ };
  57. /******/
  58. /******/ // create a fake namespace object
  59. /******/ // mode & 1: value is a module id, require it
  60. /******/ // mode & 2: merge all properties of value into the ns
  61. /******/ // mode & 4: return value when already ns object
  62. /******/ // mode & 8|1: behave like require
  63. /******/ __webpack_require__.t = function(value, mode) {
  64. /******/ if(mode & 1) value = __webpack_require__(value);
  65. /******/ if(mode & 8) return value;
  66. /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
  67. /******/ var ns = Object.create(null);
  68. /******/ __webpack_require__.r(ns);
  69. /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
  70. /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
  71. /******/ return ns;
  72. /******/ };
  73. /******/
  74. /******/ // getDefaultExport function for compatibility with non-harmony modules
  75. /******/ __webpack_require__.n = function(module) {
  76. /******/ var getter = module && module.__esModule ?
  77. /******/ function getDefault() { return module['default']; } :
  78. /******/ function getModuleExports() { return module; };
  79. /******/ __webpack_require__.d(getter, 'a', getter);
  80. /******/ return getter;
  81. /******/ };
  82. /******/
  83. /******/ // Object.prototype.hasOwnProperty.call
  84. /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
  85. /******/
  86. /******/ // __webpack_public_path__
  87. /******/ __webpack_require__.p = "";
  88. /******/
  89. /******/
  90. /******/ // Load entry module and return exports
  91. /******/ return __webpack_require__(__webpack_require__.s = 0);
  92. /******/ })
  93. /************************************************************************/
  94. /******/ ([
  95. /* 0 */
  96. /***/ (function(module, exports, __webpack_require__) {
  97. /**
  98. * AUTOMATICALLY GENERATED FILE, DO NOT EDIT MANUALLY!
  99. * Update this file by running `lerna run webpack-updater` in the monorepo root folder.
  100. */
  101. var ClientSideRowModelModule = __webpack_require__(1);
  102. var GridCoreModule = __webpack_require__(3);
  103. var CsvExportModule = __webpack_require__(211);
  104. var InfiniteRowModelModule = __webpack_require__(218);
  105. var agGrid = __webpack_require__(223);
  106. Object.keys(agGrid).forEach(function(key) {
  107. exports[key] = agGrid[key];
  108. });
  109. agGrid.ModuleRegistry.register(ClientSideRowModelModule.ClientSideRowModelModule);
  110. agGrid.ModuleRegistry.register(CsvExportModule.CsvExportModule);
  111. agGrid.ModuleRegistry.register(InfiniteRowModelModule.InfiniteRowModelModule);
  112. __webpack_require__(224);
  113. __webpack_require__(228);
  114. __webpack_require__(230);
  115. __webpack_require__(232);
  116. __webpack_require__(234);
  117. __webpack_require__(236);
  118. __webpack_require__(238);
  119. __webpack_require__(240);
  120. __webpack_require__(242);
  121. __webpack_require__(244);
  122. __webpack_require__(246);
  123. __webpack_require__(248);
  124. __webpack_require__(250);
  125. __webpack_require__(252);
  126. /***/ }),
  127. /* 1 */
  128. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  129. "use strict";
  130. __webpack_require__.r(__webpack_exports__);
  131. /* harmony import */ var _clientSideRowModelModule__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(2);
  132. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ClientSideRowModelModule", function() { return _clientSideRowModelModule__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelModule"]; });
  133. /***/ }),
  134. /* 2 */
  135. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  136. "use strict";
  137. __webpack_require__.r(__webpack_exports__);
  138. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ClientSideRowModelModule", function() { return ClientSideRowModelModule; });
  139. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
  140. /* harmony import */ var _clientSideRowModel_clientSideRowModel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(203);
  141. /* harmony import */ var _clientSideRowModel_filterStage__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(205);
  142. /* harmony import */ var _clientSideRowModel_sortStage__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(206);
  143. /* harmony import */ var _clientSideRowModel_flattenStage__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(207);
  144. /* harmony import */ var _clientSideRowModel_sortService__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(208);
  145. /* harmony import */ var _clientSideRowModel_filterService__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(209);
  146. /* harmony import */ var _clientSideRowModel_immutableService__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(210);
  147. var ClientSideRowModelModule = {
  148. moduleName: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ModuleNames"].ClientSideRowModelModule,
  149. beans: [_clientSideRowModel_filterStage__WEBPACK_IMPORTED_MODULE_2__["FilterStage"], _clientSideRowModel_sortStage__WEBPACK_IMPORTED_MODULE_3__["SortStage"], _clientSideRowModel_flattenStage__WEBPACK_IMPORTED_MODULE_4__["FlattenStage"], _clientSideRowModel_sortService__WEBPACK_IMPORTED_MODULE_5__["SortService"], _clientSideRowModel_filterService__WEBPACK_IMPORTED_MODULE_6__["FilterService"], _clientSideRowModel_immutableService__WEBPACK_IMPORTED_MODULE_7__["ImmutableService"]],
  150. rowModels: { clientSide: _clientSideRowModel_clientSideRowModel__WEBPACK_IMPORTED_MODULE_1__["ClientSideRowModel"] }
  151. };
  152. /***/ }),
  153. /* 3 */
  154. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  155. "use strict";
  156. __webpack_require__.r(__webpack_exports__);
  157. /* WEBPACK VAR INJECTION */(function(global) {/* harmony import */ var _columnController_columnFactory__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(5);
  158. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnFactory", function() { return _columnController_columnFactory__WEBPACK_IMPORTED_MODULE_0__["ColumnFactory"]; });
  159. /* harmony import */ var _columnController_columnController__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(42);
  160. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnController", function() { return _columnController_columnController__WEBPACK_IMPORTED_MODULE_1__["ColumnController"]; });
  161. /* harmony import */ var _columnController_columnKeyCreator__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(6);
  162. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnKeyCreator", function() { return _columnController_columnKeyCreator__WEBPACK_IMPORTED_MODULE_2__["ColumnKeyCreator"]; });
  163. /* harmony import */ var _columnController_columnUtils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(46);
  164. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnUtils", function() { return _columnController_columnUtils__WEBPACK_IMPORTED_MODULE_3__["ColumnUtils"]; });
  165. /* harmony import */ var _columnController_displayedGroupCreator__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(47);
  166. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DisplayedGroupCreator", function() { return _columnController_displayedGroupCreator__WEBPACK_IMPORTED_MODULE_4__["DisplayedGroupCreator"]; });
  167. /* harmony import */ var _columnController_groupInstanceIdCreator__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(45);
  168. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GroupInstanceIdCreator", function() { return _columnController_groupInstanceIdCreator__WEBPACK_IMPORTED_MODULE_5__["GroupInstanceIdCreator"]; });
  169. /* harmony import */ var _components_componentUtil__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(48);
  170. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ComponentUtil", function() { return _components_componentUtil__WEBPACK_IMPORTED_MODULE_6__["ComponentUtil"]; });
  171. /* harmony import */ var _components_colDefUtil__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(51);
  172. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColDefUtil", function() { return _components_colDefUtil__WEBPACK_IMPORTED_MODULE_7__["ColDefUtil"]; });
  173. /* harmony import */ var _components_framework_userComponentRegistry__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(53);
  174. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "UserComponentRegistry", function() { return _components_framework_userComponentRegistry__WEBPACK_IMPORTED_MODULE_8__["UserComponentRegistry"]; });
  175. /* harmony import */ var _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(74);
  176. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "UserComponentFactory", function() { return _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_9__["UserComponentFactory"]; });
  177. /* harmony import */ var _components_agGridNg1__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(94);
  178. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "initialiseAgGridWithAngular1", function() { return _components_agGridNg1__WEBPACK_IMPORTED_MODULE_10__["initialiseAgGridWithAngular1"]; });
  179. /* harmony import */ var _components_agGridWebComponent__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(193);
  180. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "initialiseAgGridWithWebComponents", function() { return _components_agGridWebComponent__WEBPACK_IMPORTED_MODULE_11__["initialiseAgGridWithWebComponents"]; });
  181. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(41);
  182. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BeanStub", function() { return _context_beanStub__WEBPACK_IMPORTED_MODULE_12__["BeanStub"]; });
  183. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(37);
  184. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Context", function() { return _context_context__WEBPACK_IMPORTED_MODULE_13__["Context"]; });
  185. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Autowired", function() { return _context_context__WEBPACK_IMPORTED_MODULE_13__["Autowired"]; });
  186. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PostConstruct", function() { return _context_context__WEBPACK_IMPORTED_MODULE_13__["PostConstruct"]; });
  187. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PreConstruct", function() { return _context_context__WEBPACK_IMPORTED_MODULE_13__["PreConstruct"]; });
  188. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Optional", function() { return _context_context__WEBPACK_IMPORTED_MODULE_13__["Optional"]; });
  189. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Bean", function() { return _context_context__WEBPACK_IMPORTED_MODULE_13__["Bean"]; });
  190. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Qualifier", function() { return _context_context__WEBPACK_IMPORTED_MODULE_13__["Qualifier"]; });
  191. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PreDestroy", function() { return _context_context__WEBPACK_IMPORTED_MODULE_13__["PreDestroy"]; });
  192. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(57);
  193. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "QuerySelector", function() { return _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_14__["QuerySelector"]; });
  194. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GuiListener", function() { return _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_14__["GuiListener"]; });
  195. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RefSelector", function() { return _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_14__["RefSelector"]; });
  196. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridListener", function() { return _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_14__["GridListener"]; });
  197. /* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(104);
  198. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DragAndDropService", function() { return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_15__["DragAndDropService"]; });
  199. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DragSourceType", function() { return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_15__["DragSourceType"]; });
  200. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HorizontalDirection", function() { return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_15__["HorizontalDirection"]; });
  201. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "VerticalDirection", function() { return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_15__["VerticalDirection"]; });
  202. /* harmony import */ var _dragAndDrop_dragService__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(139);
  203. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DragService", function() { return _dragAndDrop_dragService__WEBPACK_IMPORTED_MODULE_16__["DragService"]; });
  204. /* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(35);
  205. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Column", function() { return _entities_column__WEBPACK_IMPORTED_MODULE_17__["Column"]; });
  206. /* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(34);
  207. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnGroup", function() { return _entities_columnGroup__WEBPACK_IMPORTED_MODULE_18__["ColumnGroup"]; });
  208. /* harmony import */ var _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(33);
  209. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "OriginalColumnGroup", function() { return _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_19__["OriginalColumnGroup"]; });
  210. /* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(68);
  211. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNode", function() { return _entities_rowNode__WEBPACK_IMPORTED_MODULE_20__["RowNode"]; });
  212. /* harmony import */ var _filter_filterManager__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(125);
  213. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "FilterManager", function() { return _filter_filterManager__WEBPACK_IMPORTED_MODULE_21__["FilterManager"]; });
  214. /* harmony import */ var _filter_provided_providedFilter__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(62);
  215. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ProvidedFilter", function() { return _filter_provided_providedFilter__WEBPACK_IMPORTED_MODULE_22__["ProvidedFilter"]; });
  216. /* harmony import */ var _filter_provided_simpleFilter__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(60);
  217. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SimpleFilter", function() { return _filter_provided_simpleFilter__WEBPACK_IMPORTED_MODULE_23__["SimpleFilter"]; });
  218. /* harmony import */ var _filter_provided_scalarFilter__WEBPACK_IMPORTED_MODULE_24__ = __webpack_require__(63);
  219. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ScalarFilter", function() { return _filter_provided_scalarFilter__WEBPACK_IMPORTED_MODULE_24__["ScalarFilter"]; });
  220. /* harmony import */ var _filter_provided_number_numberFilter__WEBPACK_IMPORTED_MODULE_25__ = __webpack_require__(83);
  221. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "NumberFilter", function() { return _filter_provided_number_numberFilter__WEBPACK_IMPORTED_MODULE_25__["NumberFilter"]; });
  222. /* harmony import */ var _filter_provided_text_textFilter__WEBPACK_IMPORTED_MODULE_26__ = __webpack_require__(90);
  223. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TextFilter", function() { return _filter_provided_text_textFilter__WEBPACK_IMPORTED_MODULE_26__["TextFilter"]; });
  224. /* harmony import */ var _filter_provided_date_dateFilter__WEBPACK_IMPORTED_MODULE_27__ = __webpack_require__(58);
  225. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DateFilter", function() { return _filter_provided_date_dateFilter__WEBPACK_IMPORTED_MODULE_27__["DateFilter"]; });
  226. /* harmony import */ var _gridPanel_gridPanel__WEBPACK_IMPORTED_MODULE_28__ = __webpack_require__(127);
  227. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridPanel", function() { return _gridPanel_gridPanel__WEBPACK_IMPORTED_MODULE_28__["GridPanel"]; });
  228. /* harmony import */ var _gridPanel_scrollVisibleService__WEBPACK_IMPORTED_MODULE_29__ = __webpack_require__(148);
  229. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ScrollVisibleService", function() { return _gridPanel_scrollVisibleService__WEBPACK_IMPORTED_MODULE_29__["ScrollVisibleService"]; });
  230. /* harmony import */ var _gridPanel_mouseEventService__WEBPACK_IMPORTED_MODULE_30__ = __webpack_require__(142);
  231. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MouseEventService", function() { return _gridPanel_mouseEventService__WEBPACK_IMPORTED_MODULE_30__["MouseEventService"]; });
  232. /* harmony import */ var _headerRendering_bodyDropPivotTarget__WEBPACK_IMPORTED_MODULE_31__ = __webpack_require__(123);
  233. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BodyDropPivotTarget", function() { return _headerRendering_bodyDropPivotTarget__WEBPACK_IMPORTED_MODULE_31__["BodyDropPivotTarget"]; });
  234. /* harmony import */ var _headerRendering_bodyDropTarget__WEBPACK_IMPORTED_MODULE_32__ = __webpack_require__(121);
  235. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BodyDropTarget", function() { return _headerRendering_bodyDropTarget__WEBPACK_IMPORTED_MODULE_32__["BodyDropTarget"]; });
  236. /* harmony import */ var _headerRendering_cssClassApplier__WEBPACK_IMPORTED_MODULE_33__ = __webpack_require__(112);
  237. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CssClassApplier", function() { return _headerRendering_cssClassApplier__WEBPACK_IMPORTED_MODULE_33__["CssClassApplier"]; });
  238. /* harmony import */ var _headerRendering_headerContainer__WEBPACK_IMPORTED_MODULE_34__ = __webpack_require__(109);
  239. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderContainer", function() { return _headerRendering_headerContainer__WEBPACK_IMPORTED_MODULE_34__["HeaderContainer"]; });
  240. /* harmony import */ var _headerRendering_headerRootComp__WEBPACK_IMPORTED_MODULE_35__ = __webpack_require__(108);
  241. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderRootComp", function() { return _headerRendering_headerRootComp__WEBPACK_IMPORTED_MODULE_35__["HeaderRootComp"]; });
  242. /* harmony import */ var _headerRendering_headerRowComp__WEBPACK_IMPORTED_MODULE_36__ = __webpack_require__(110);
  243. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderRowComp", function() { return _headerRendering_headerRowComp__WEBPACK_IMPORTED_MODULE_36__["HeaderRowComp"]; });
  244. /* harmony import */ var _headerRendering_horizontalResizeService__WEBPACK_IMPORTED_MODULE_37__ = __webpack_require__(136);
  245. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HorizontalResizeService", function() { return _headerRendering_horizontalResizeService__WEBPACK_IMPORTED_MODULE_37__["HorizontalResizeService"]; });
  246. /* harmony import */ var _headerRendering_moveColumnController__WEBPACK_IMPORTED_MODULE_38__ = __webpack_require__(122);
  247. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MoveColumnController", function() { return _headerRendering_moveColumnController__WEBPACK_IMPORTED_MODULE_38__["MoveColumnController"]; });
  248. /* harmony import */ var _headerRendering_standardMenu__WEBPACK_IMPORTED_MODULE_39__ = __webpack_require__(138);
  249. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "StandardMenuFactory", function() { return _headerRendering_standardMenu__WEBPACK_IMPORTED_MODULE_39__["StandardMenuFactory"]; });
  250. /* harmony import */ var _layout_tabbedLayout__WEBPACK_IMPORTED_MODULE_40__ = __webpack_require__(194);
  251. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TabbedLayout", function() { return _layout_tabbedLayout__WEBPACK_IMPORTED_MODULE_40__["TabbedLayout"]; });
  252. /* harmony import */ var _misc_simpleHttpRequest__WEBPACK_IMPORTED_MODULE_41__ = __webpack_require__(195);
  253. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "simpleHttpRequest", function() { return _misc_simpleHttpRequest__WEBPACK_IMPORTED_MODULE_41__["simpleHttpRequest"]; });
  254. /* harmony import */ var _misc_resizeObserverService__WEBPACK_IMPORTED_MODULE_42__ = __webpack_require__(168);
  255. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ResizeObserverService", function() { return _misc_resizeObserverService__WEBPACK_IMPORTED_MODULE_42__["ResizeObserverService"]; });
  256. /* harmony import */ var _rendering_cellEditors_largeTextCellEditor__WEBPACK_IMPORTED_MODULE_43__ = __webpack_require__(82);
  257. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "LargeTextCellEditor", function() { return _rendering_cellEditors_largeTextCellEditor__WEBPACK_IMPORTED_MODULE_43__["LargeTextCellEditor"]; });
  258. /* harmony import */ var _rendering_cellEditors_popupEditorWrapper__WEBPACK_IMPORTED_MODULE_44__ = __webpack_require__(105);
  259. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupEditorWrapper", function() { return _rendering_cellEditors_popupEditorWrapper__WEBPACK_IMPORTED_MODULE_44__["PopupEditorWrapper"]; });
  260. /* harmony import */ var _rendering_cellEditors_popupSelectCellEditor__WEBPACK_IMPORTED_MODULE_45__ = __webpack_require__(81);
  261. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupSelectCellEditor", function() { return _rendering_cellEditors_popupSelectCellEditor__WEBPACK_IMPORTED_MODULE_45__["PopupSelectCellEditor"]; });
  262. /* harmony import */ var _rendering_cellEditors_popupTextCellEditor__WEBPACK_IMPORTED_MODULE_46__ = __webpack_require__(80);
  263. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupTextCellEditor", function() { return _rendering_cellEditors_popupTextCellEditor__WEBPACK_IMPORTED_MODULE_46__["PopupTextCellEditor"]; });
  264. /* harmony import */ var _rendering_cellEditors_selectCellEditor__WEBPACK_IMPORTED_MODULE_47__ = __webpack_require__(79);
  265. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectCellEditor", function() { return _rendering_cellEditors_selectCellEditor__WEBPACK_IMPORTED_MODULE_47__["SelectCellEditor"]; });
  266. /* harmony import */ var _rendering_cellEditors_textCellEditor__WEBPACK_IMPORTED_MODULE_48__ = __webpack_require__(54);
  267. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TextCellEditor", function() { return _rendering_cellEditors_textCellEditor__WEBPACK_IMPORTED_MODULE_48__["TextCellEditor"]; });
  268. /* harmony import */ var _rendering_cellRenderers_animateShowChangeCellRenderer__WEBPACK_IMPORTED_MODULE_49__ = __webpack_require__(76);
  269. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AnimateShowChangeCellRenderer", function() { return _rendering_cellRenderers_animateShowChangeCellRenderer__WEBPACK_IMPORTED_MODULE_49__["AnimateShowChangeCellRenderer"]; });
  270. /* harmony import */ var _rendering_cellRenderers_animateSlideCellRenderer__WEBPACK_IMPORTED_MODULE_50__ = __webpack_require__(77);
  271. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AnimateSlideCellRenderer", function() { return _rendering_cellRenderers_animateSlideCellRenderer__WEBPACK_IMPORTED_MODULE_50__["AnimateSlideCellRenderer"]; });
  272. /* harmony import */ var _rendering_cellRenderers_groupCellRenderer__WEBPACK_IMPORTED_MODULE_51__ = __webpack_require__(67);
  273. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GroupCellRenderer", function() { return _rendering_cellRenderers_groupCellRenderer__WEBPACK_IMPORTED_MODULE_51__["GroupCellRenderer"]; });
  274. /* harmony import */ var _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_52__ = __webpack_require__(114);
  275. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SetLeftFeature", function() { return _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_52__["SetLeftFeature"]; });
  276. /* harmony import */ var _rendering_autoWidthCalculator__WEBPACK_IMPORTED_MODULE_53__ = __webpack_require__(135);
  277. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AutoWidthCalculator", function() { return _rendering_autoWidthCalculator__WEBPACK_IMPORTED_MODULE_53__["AutoWidthCalculator"]; });
  278. /* harmony import */ var _rendering_cellRendererFactory__WEBPACK_IMPORTED_MODULE_54__ = __webpack_require__(144);
  279. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellRendererFactory", function() { return _rendering_cellRendererFactory__WEBPACK_IMPORTED_MODULE_54__["CellRendererFactory"]; });
  280. /* harmony import */ var _rendering_checkboxSelectionComponent__WEBPACK_IMPORTED_MODULE_55__ = __webpack_require__(69);
  281. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CheckboxSelectionComponent", function() { return _rendering_checkboxSelectionComponent__WEBPACK_IMPORTED_MODULE_55__["CheckboxSelectionComponent"]; });
  282. /* harmony import */ var _rendering_cellComp__WEBPACK_IMPORTED_MODULE_56__ = __webpack_require__(101);
  283. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellComp", function() { return _rendering_cellComp__WEBPACK_IMPORTED_MODULE_56__["CellComp"]; });
  284. /* harmony import */ var _rendering_rowComp__WEBPACK_IMPORTED_MODULE_57__ = __webpack_require__(100);
  285. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowComp", function() { return _rendering_rowComp__WEBPACK_IMPORTED_MODULE_57__["RowComp"]; });
  286. /* harmony import */ var _rendering_rowRenderer__WEBPACK_IMPORTED_MODULE_58__ = __webpack_require__(99);
  287. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowRenderer", function() { return _rendering_rowRenderer__WEBPACK_IMPORTED_MODULE_58__["RowRenderer"]; });
  288. /* harmony import */ var _rendering_valueFormatterService__WEBPACK_IMPORTED_MODULE_59__ = __webpack_require__(145);
  289. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ValueFormatterService", function() { return _rendering_valueFormatterService__WEBPACK_IMPORTED_MODULE_59__["ValueFormatterService"]; });
  290. /* harmony import */ var _pinnedRowModel_pinnedRowModel__WEBPACK_IMPORTED_MODULE_60__ = __webpack_require__(188);
  291. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PinnedRowModel", function() { return _pinnedRowModel_pinnedRowModel__WEBPACK_IMPORTED_MODULE_60__["PinnedRowModel"]; });
  292. /* harmony import */ var _utils_changedPath__WEBPACK_IMPORTED_MODULE_61__ = __webpack_require__(97);
  293. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ChangedPath", function() { return _utils_changedPath__WEBPACK_IMPORTED_MODULE_61__["ChangedPath"]; });
  294. /* harmony import */ var _modules_rowNodeCache_rowNodeBlock__WEBPACK_IMPORTED_MODULE_62__ = __webpack_require__(196);
  295. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNodeBlock", function() { return _modules_rowNodeCache_rowNodeBlock__WEBPACK_IMPORTED_MODULE_62__["RowNodeBlock"]; });
  296. /* harmony import */ var _modules_rowNodeCache_rowNodeBlockLoader__WEBPACK_IMPORTED_MODULE_63__ = __webpack_require__(197);
  297. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNodeBlockLoader", function() { return _modules_rowNodeCache_rowNodeBlockLoader__WEBPACK_IMPORTED_MODULE_63__["RowNodeBlockLoader"]; });
  298. /* harmony import */ var _modules_rowNodeCache_rowNodeCache__WEBPACK_IMPORTED_MODULE_64__ = __webpack_require__(198);
  299. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNodeCache", function() { return _modules_rowNodeCache_rowNodeCache__WEBPACK_IMPORTED_MODULE_64__["RowNodeCache"]; });
  300. /* harmony import */ var _pagination_paginationProxy__WEBPACK_IMPORTED_MODULE_65__ = __webpack_require__(153);
  301. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PaginationProxy", function() { return _pagination_paginationProxy__WEBPACK_IMPORTED_MODULE_65__["PaginationProxy"]; });
  302. /* harmony import */ var _styling_stylingService__WEBPACK_IMPORTED_MODULE_66__ = __webpack_require__(149);
  303. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "StylingService", function() { return _styling_stylingService__WEBPACK_IMPORTED_MODULE_66__["StylingService"]; });
  304. /* harmony import */ var _widgets_agAbstractField__WEBPACK_IMPORTED_MODULE_67__ = __webpack_require__(72);
  305. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgAbstractField", function() { return _widgets_agAbstractField__WEBPACK_IMPORTED_MODULE_67__["AgAbstractField"]; });
  306. /* harmony import */ var _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_68__ = __webpack_require__(70);
  307. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgCheckbox", function() { return _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_68__["AgCheckbox"]; });
  308. /* harmony import */ var _widgets_agRadioButton__WEBPACK_IMPORTED_MODULE_69__ = __webpack_require__(146);
  309. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgRadioButton", function() { return _widgets_agRadioButton__WEBPACK_IMPORTED_MODULE_69__["AgRadioButton"]; });
  310. /* harmony import */ var _widgets_agToggleButton__WEBPACK_IMPORTED_MODULE_70__ = __webpack_require__(184);
  311. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgToggleButton", function() { return _widgets_agToggleButton__WEBPACK_IMPORTED_MODULE_70__["AgToggleButton"]; });
  312. /* harmony import */ var _widgets_agInputTextField__WEBPACK_IMPORTED_MODULE_71__ = __webpack_require__(173);
  313. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgInputTextField", function() { return _widgets_agInputTextField__WEBPACK_IMPORTED_MODULE_71__["AgInputTextField"]; });
  314. /* harmony import */ var _widgets_agInputTextArea__WEBPACK_IMPORTED_MODULE_72__ = __webpack_require__(174);
  315. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgInputTextArea", function() { return _widgets_agInputTextArea__WEBPACK_IMPORTED_MODULE_72__["AgInputTextArea"]; });
  316. /* harmony import */ var _widgets_agInputNumberField__WEBPACK_IMPORTED_MODULE_73__ = __webpack_require__(179);
  317. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgInputNumberField", function() { return _widgets_agInputNumberField__WEBPACK_IMPORTED_MODULE_73__["AgInputNumberField"]; });
  318. /* harmony import */ var _widgets_agInputRange__WEBPACK_IMPORTED_MODULE_74__ = __webpack_require__(180);
  319. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgInputRange", function() { return _widgets_agInputRange__WEBPACK_IMPORTED_MODULE_74__["AgInputRange"]; });
  320. /* harmony import */ var _widgets_agSelect__WEBPACK_IMPORTED_MODULE_75__ = __webpack_require__(181);
  321. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgSelect", function() { return _widgets_agSelect__WEBPACK_IMPORTED_MODULE_75__["AgSelect"]; });
  322. /* harmony import */ var _widgets_agSlider__WEBPACK_IMPORTED_MODULE_76__ = __webpack_require__(175);
  323. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgSlider", function() { return _widgets_agSlider__WEBPACK_IMPORTED_MODULE_76__["AgSlider"]; });
  324. /* harmony import */ var _widgets_agAngleSelect__WEBPACK_IMPORTED_MODULE_77__ = __webpack_require__(183);
  325. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgAngleSelect", function() { return _widgets_agAngleSelect__WEBPACK_IMPORTED_MODULE_77__["AgAngleSelect"]; });
  326. /* harmony import */ var _widgets_agColorPicker__WEBPACK_IMPORTED_MODULE_78__ = __webpack_require__(176);
  327. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgColorPicker", function() { return _widgets_agColorPicker__WEBPACK_IMPORTED_MODULE_78__["AgColorPicker"]; });
  328. /* harmony import */ var _widgets_agGroupComponent__WEBPACK_IMPORTED_MODULE_79__ = __webpack_require__(170);
  329. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgGroupComponent", function() { return _widgets_agGroupComponent__WEBPACK_IMPORTED_MODULE_79__["AgGroupComponent"]; });
  330. /* harmony import */ var _widgets_agDialog__WEBPACK_IMPORTED_MODULE_80__ = __webpack_require__(171);
  331. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgDialog", function() { return _widgets_agDialog__WEBPACK_IMPORTED_MODULE_80__["AgDialog"]; });
  332. /* harmony import */ var _widgets_agPanel__WEBPACK_IMPORTED_MODULE_81__ = __webpack_require__(172);
  333. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgPanel", function() { return _widgets_agPanel__WEBPACK_IMPORTED_MODULE_81__["AgPanel"]; });
  334. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_82__ = __webpack_require__(56);
  335. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Component", function() { return _widgets_component__WEBPACK_IMPORTED_MODULE_82__["Component"]; });
  336. /* harmony import */ var _widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_83__ = __webpack_require__(117);
  337. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ManagedFocusComponent", function() { return _widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_83__["ManagedFocusComponent"]; });
  338. /* harmony import */ var _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_84__ = __webpack_require__(55);
  339. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupComponent", function() { return _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_84__["PopupComponent"]; });
  340. /* harmony import */ var _widgets_popupService__WEBPACK_IMPORTED_MODULE_85__ = __webpack_require__(133);
  341. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupService", function() { return _widgets_popupService__WEBPACK_IMPORTED_MODULE_85__["PopupService"]; });
  342. /* harmony import */ var _widgets_touchListener__WEBPACK_IMPORTED_MODULE_86__ = __webpack_require__(65);
  343. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TouchListener", function() { return _widgets_touchListener__WEBPACK_IMPORTED_MODULE_86__["TouchListener"]; });
  344. /* harmony import */ var _widgets_virtualList__WEBPACK_IMPORTED_MODULE_87__ = __webpack_require__(199);
  345. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "VirtualList", function() { return _widgets_virtualList__WEBPACK_IMPORTED_MODULE_87__["VirtualList"]; });
  346. /* harmony import */ var _interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_88__ = __webpack_require__(102);
  347. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellRangeType", function() { return _interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_88__["CellRangeType"]; });
  348. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectionHandleType", function() { return _interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_88__["SelectionHandleType"]; });
  349. /* harmony import */ var _vanillaFrameworkOverrides__WEBPACK_IMPORTED_MODULE_89__ = __webpack_require__(147);
  350. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "VanillaFrameworkOverrides", function() { return _vanillaFrameworkOverrides__WEBPACK_IMPORTED_MODULE_89__["VanillaFrameworkOverrides"]; });
  351. /* harmony import */ var _cellNavigationService__WEBPACK_IMPORTED_MODULE_90__ = __webpack_require__(143);
  352. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellNavigationService", function() { return _cellNavigationService__WEBPACK_IMPORTED_MODULE_90__["CellNavigationService"]; });
  353. /* harmony import */ var _alignedGridsService__WEBPACK_IMPORTED_MODULE_91__ = __webpack_require__(157);
  354. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AlignedGridsService", function() { return _alignedGridsService__WEBPACK_IMPORTED_MODULE_91__["AlignedGridsService"]; });
  355. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_92__ = __webpack_require__(25);
  356. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Constants", function() { return _constants__WEBPACK_IMPORTED_MODULE_92__["Constants"]; });
  357. /* harmony import */ var _grid__WEBPACK_IMPORTED_MODULE_93__ = __webpack_require__(95);
  358. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Grid", function() { return _grid__WEBPACK_IMPORTED_MODULE_93__["Grid"]; });
  359. /* harmony import */ var _gridApi__WEBPACK_IMPORTED_MODULE_94__ = __webpack_require__(130);
  360. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridApi", function() { return _gridApi__WEBPACK_IMPORTED_MODULE_94__["GridApi"]; });
  361. /* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_95__ = __webpack_require__(44);
  362. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Events", function() { return _eventKeys__WEBPACK_IMPORTED_MODULE_95__["Events"]; });
  363. /* harmony import */ var _focusController__WEBPACK_IMPORTED_MODULE_96__ = __webpack_require__(141);
  364. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "FocusController", function() { return _focusController__WEBPACK_IMPORTED_MODULE_96__["FocusController"]; });
  365. /* harmony import */ var _functions__WEBPACK_IMPORTED_MODULE_97__ = __webpack_require__(200);
  366. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "defaultGroupComparator", function() { return _functions__WEBPACK_IMPORTED_MODULE_97__["defaultGroupComparator"]; });
  367. /* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_98__ = __webpack_require__(50);
  368. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridOptionsWrapper", function() { return _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_98__["GridOptionsWrapper"]; });
  369. /* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_99__ = __webpack_require__(36);
  370. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "EventService", function() { return _eventService__WEBPACK_IMPORTED_MODULE_99__["EventService"]; });
  371. /* harmony import */ var _rowNodes_selectableService__WEBPACK_IMPORTED_MODULE_100__ = __webpack_require__(165);
  372. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectableService", function() { return _rowNodes_selectableService__WEBPACK_IMPORTED_MODULE_100__["SelectableService"]; });
  373. /* harmony import */ var _gridCore__WEBPACK_IMPORTED_MODULE_101__ = __webpack_require__(137);
  374. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridCore", function() { return _gridCore__WEBPACK_IMPORTED_MODULE_101__["GridCore"]; });
  375. /* harmony import */ var _logger__WEBPACK_IMPORTED_MODULE_102__ = __webpack_require__(134);
  376. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Logger", function() { return _logger__WEBPACK_IMPORTED_MODULE_102__["Logger"]; });
  377. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "LoggerFactory", function() { return _logger__WEBPACK_IMPORTED_MODULE_102__["LoggerFactory"]; });
  378. /* harmony import */ var _selectionController__WEBPACK_IMPORTED_MODULE_103__ = __webpack_require__(96);
  379. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectionController", function() { return _selectionController__WEBPACK_IMPORTED_MODULE_103__["SelectionController"]; });
  380. /* harmony import */ var _sortController__WEBPACK_IMPORTED_MODULE_104__ = __webpack_require__(140);
  381. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SortController", function() { return _sortController__WEBPACK_IMPORTED_MODULE_104__["SortController"]; });
  382. /* harmony import */ var _templateService__WEBPACK_IMPORTED_MODULE_105__ = __webpack_require__(132);
  383. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TemplateService", function() { return _templateService__WEBPACK_IMPORTED_MODULE_105__["TemplateService"]; });
  384. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_106__ = __webpack_require__(7);
  385. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Color", function() { return _utils__WEBPACK_IMPORTED_MODULE_106__["Color"]; });
  386. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "stringToArray", function() { return _utils__WEBPACK_IMPORTED_MODULE_106__["stringToArray"]; });
  387. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "_", function() { return _utils__WEBPACK_IMPORTED_MODULE_106__["_"]; });
  388. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "NumberSequence", function() { return _utils__WEBPACK_IMPORTED_MODULE_106__["NumberSequence"]; });
  389. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PromiseStatus", function() { return _utils__WEBPACK_IMPORTED_MODULE_106__["PromiseStatus"]; });
  390. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Promise", function() { return _utils__WEBPACK_IMPORTED_MODULE_106__["Promise"]; });
  391. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Timer", function() { return _utils__WEBPACK_IMPORTED_MODULE_106__["Timer"]; });
  392. /* harmony import */ var _valueService_valueService__WEBPACK_IMPORTED_MODULE_107__ = __webpack_require__(126);
  393. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ValueService", function() { return _valueService_valueService__WEBPACK_IMPORTED_MODULE_107__["ValueService"]; });
  394. /* harmony import */ var _valueService_valueCache__WEBPACK_IMPORTED_MODULE_108__ = __webpack_require__(155);
  395. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ValueCache", function() { return _valueService_valueCache__WEBPACK_IMPORTED_MODULE_108__["ValueCache"]; });
  396. /* harmony import */ var _valueService_expressionService__WEBPACK_IMPORTED_MODULE_109__ = __webpack_require__(131);
  397. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ExpressionService", function() { return _valueService_expressionService__WEBPACK_IMPORTED_MODULE_109__["ExpressionService"]; });
  398. /* harmony import */ var _entities_cellPosition__WEBPACK_IMPORTED_MODULE_110__ = __webpack_require__(187);
  399. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellPositionUtils", function() { return _entities_cellPosition__WEBPACK_IMPORTED_MODULE_110__["CellPositionUtils"]; });
  400. /* harmony import */ var _entities_rowPosition__WEBPACK_IMPORTED_MODULE_111__ = __webpack_require__(186);
  401. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowPositionUtils", function() { return _entities_rowPosition__WEBPACK_IMPORTED_MODULE_111__["RowPositionUtils"]; });
  402. /* harmony import */ var _headerRendering_header_headerPosition__WEBPACK_IMPORTED_MODULE_112__ = __webpack_require__(192);
  403. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderPositionUtils", function() { return _headerRendering_header_headerPosition__WEBPACK_IMPORTED_MODULE_112__["HeaderPositionUtils"]; });
  404. /* harmony import */ var _headerRendering_header_headerNavigationService__WEBPACK_IMPORTED_MODULE_113__ = __webpack_require__(124);
  405. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderNavigationService", function() { return _headerRendering_header_headerNavigationService__WEBPACK_IMPORTED_MODULE_113__["HeaderNavigationService"]; });
  406. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderNavigationDirection", function() { return _headerRendering_header_headerNavigationService__WEBPACK_IMPORTED_MODULE_113__["HeaderNavigationDirection"]; });
  407. /* harmony import */ var _propertyKeys__WEBPACK_IMPORTED_MODULE_114__ = __webpack_require__(49);
  408. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PropertyKeys", function() { return _propertyKeys__WEBPACK_IMPORTED_MODULE_114__["PropertyKeys"]; });
  409. /* harmony import */ var _columnController_columnApi__WEBPACK_IMPORTED_MODULE_115__ = __webpack_require__(98);
  410. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnApi", function() { return _columnController_columnApi__WEBPACK_IMPORTED_MODULE_115__["ColumnApi"]; });
  411. /* harmony import */ var _components_framework_frameworkComponentWrapper__WEBPACK_IMPORTED_MODULE_116__ = __webpack_require__(201);
  412. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BaseComponentWrapper", function() { return _components_framework_frameworkComponentWrapper__WEBPACK_IMPORTED_MODULE_116__["BaseComponentWrapper"]; });
  413. /* harmony import */ var _environment__WEBPACK_IMPORTED_MODULE_117__ = __webpack_require__(161);
  414. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Environment", function() { return _environment__WEBPACK_IMPORTED_MODULE_117__["Environment"]; });
  415. /* harmony import */ var _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_118__ = __webpack_require__(107);
  416. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TooltipFeature", function() { return _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_118__["TooltipFeature"]; });
  417. /* harmony import */ var _interfaces_iChartOptions__WEBPACK_IMPORTED_MODULE_119__ = __webpack_require__(202);
  418. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ChartType", function() { return _interfaces_iChartOptions__WEBPACK_IMPORTED_MODULE_119__["ChartType"]; });
  419. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "LegendPosition", function() { return _interfaces_iChartOptions__WEBPACK_IMPORTED_MODULE_119__["LegendPosition"]; });
  420. /* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_120__ = __webpack_require__(38);
  421. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ModuleNames", function() { return _modules_moduleNames__WEBPACK_IMPORTED_MODULE_120__["ModuleNames"]; });
  422. /* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_121__ = __webpack_require__(39);
  423. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ModuleRegistry", function() { return _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_121__["ModuleRegistry"]; });
  424. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_122__ = __webpack_require__(43);
  425. /* empty/unused harmony star reexport *//**
  426. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  427. * @version v23.2.1
  428. * @link http://www.ag-grid.com/
  429. * @license MIT
  430. */
  431. var globalObj = typeof global === 'undefined' ? {} : global;
  432. globalObj.HTMLElement = typeof HTMLElement === 'undefined' ? {} : HTMLElement;
  433. globalObj.HTMLButtonElement = typeof HTMLButtonElement === 'undefined' ? {} : HTMLButtonElement;
  434. globalObj.HTMLSelectElement = typeof HTMLSelectElement === 'undefined' ? {} : HTMLSelectElement;
  435. globalObj.HTMLInputElement = typeof HTMLInputElement === 'undefined' ? {} : HTMLInputElement;
  436. globalObj.Node = typeof Node === 'undefined' ? {} : Node;
  437. globalObj.MouseEvent = typeof MouseEvent === 'undefined' ? {} : MouseEvent;
  438. // columnController
  439. // components
  440. // context
  441. // dragAndDrop
  442. // entities
  443. // filter
  444. // gridPanel
  445. // headerRendering
  446. // layout
  447. // misc
  448. // features
  449. // rendering
  450. // row models
  451. //styling
  452. // widgets
  453. // range
  454. // root
  455. // charts
  456. // events
  457. /* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(4)))
  458. /***/ }),
  459. /* 4 */
  460. /***/ (function(module, exports) {
  461. var g;
  462. // This works in non-strict mode
  463. g = (function() {
  464. return this;
  465. })();
  466. try {
  467. // This works if eval is allowed (see CSP)
  468. g = g || new Function("return this")();
  469. } catch (e) {
  470. // This works if the window reference is available
  471. if (typeof window === "object") g = window;
  472. }
  473. // g can still be undefined, but nothing to do about it...
  474. // We return undefined, instead of nothing here, so it's
  475. // easier to handle this case. if(!global) { ...}
  476. module.exports = g;
  477. /***/ }),
  478. /* 5 */
  479. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  480. "use strict";
  481. __webpack_require__.r(__webpack_exports__);
  482. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnFactory", function() { return ColumnFactory; });
  483. /* harmony import */ var _columnKeyCreator__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(6);
  484. /* harmony import */ var _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(33);
  485. /* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(35);
  486. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(37);
  487. /* harmony import */ var _entities_defaultColumnTypes__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(40);
  488. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7);
  489. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(41);
  490. /**
  491. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  492. * @version v23.2.1
  493. * @link http://www.ag-grid.com/
  494. * @license MIT
  495. */
  496. var __extends = (undefined && undefined.__extends) || (function () {
  497. var extendStatics = function (d, b) {
  498. extendStatics = Object.setPrototypeOf ||
  499. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  500. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  501. return extendStatics(d, b);
  502. };
  503. return function (d, b) {
  504. extendStatics(d, b);
  505. function __() { this.constructor = d; }
  506. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  507. };
  508. })();
  509. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  510. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  511. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  512. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  513. return c > 3 && r && Object.defineProperty(target, key, r), r;
  514. };
  515. var __param = (undefined && undefined.__param) || function (paramIndex, decorator) {
  516. return function (target, key) { decorator(target, key, paramIndex); }
  517. };
  518. // takes ColDefs and ColGroupDefs and turns them into Columns and OriginalGroups
  519. var ColumnFactory = /** @class */ (function (_super) {
  520. __extends(ColumnFactory, _super);
  521. function ColumnFactory() {
  522. return _super !== null && _super.apply(this, arguments) || this;
  523. }
  524. ColumnFactory.prototype.setBeans = function (loggerFactory) {
  525. this.logger = loggerFactory.create('ColumnFactory');
  526. };
  527. ColumnFactory.prototype.createColumnTree = function (defs, primaryColumns, existingColumns) {
  528. // column key creator dishes out unique column id's in a deterministic way,
  529. // so if we have two grids (that could be master/slave) with same column definitions,
  530. // then this ensures the two grids use identical id's.
  531. var columnKeyCreator = new _columnKeyCreator__WEBPACK_IMPORTED_MODULE_0__["ColumnKeyCreator"]();
  532. if (existingColumns) {
  533. var existingKeys = existingColumns.map(function (col) { return col.getId(); });
  534. columnKeyCreator.addExistingKeys(existingKeys);
  535. }
  536. // we take a copy of the columns as we are going to be removing from them
  537. var existingColsCopy = existingColumns ? existingColumns.slice() : null;
  538. // create am unbalanced tree that maps the provided definitions
  539. var unbalancedTree = this.recursivelyCreateColumns(defs, 0, primaryColumns, existingColsCopy, columnKeyCreator, null);
  540. var treeDept = this.findMaxDept(unbalancedTree, 0);
  541. this.logger.log('Number of levels for grouped columns is ' + treeDept);
  542. var columnTree = this.balanceColumnTree(unbalancedTree, 0, treeDept, columnKeyCreator);
  543. var deptFirstCallback = function (child, parent) {
  544. if (child instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"]) {
  545. child.setupExpandable();
  546. }
  547. // we set the original parents at the end, rather than when we go along, as balancing the tree
  548. // adds extra levels into the tree. so we can only set parents when balancing is done.
  549. child.setOriginalParent(parent);
  550. };
  551. this.columnUtils.depthFirstOriginalTreeSearch(null, columnTree, deptFirstCallback);
  552. return {
  553. columnTree: columnTree,
  554. treeDept: treeDept
  555. };
  556. };
  557. ColumnFactory.prototype.createForAutoGroups = function (autoGroupCols, gridBalancedTree) {
  558. var _this = this;
  559. var autoColBalancedTree = [];
  560. autoGroupCols.forEach(function (col) {
  561. var fakeTreeItem = _this.createAutoGroupTreeItem(gridBalancedTree, col);
  562. autoColBalancedTree.push(fakeTreeItem);
  563. });
  564. return autoColBalancedTree;
  565. };
  566. ColumnFactory.prototype.createAutoGroupTreeItem = function (balancedColumnTree, column) {
  567. var dept = this.findDepth(balancedColumnTree);
  568. // at the end, this will be the top of the tree item.
  569. var nextChild = column;
  570. for (var i = dept - 1; i >= 0; i--) {
  571. var autoGroup = new _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"](null, "FAKE_PATH_" + column.getId() + "}_" + i, true, i);
  572. this.context.createBean(autoGroup);
  573. autoGroup.setChildren([nextChild]);
  574. nextChild.setOriginalParent(autoGroup);
  575. nextChild = autoGroup;
  576. }
  577. // at this point, the nextChild is the top most item in the tree
  578. return nextChild;
  579. };
  580. ColumnFactory.prototype.findDepth = function (balancedColumnTree) {
  581. var dept = 0;
  582. var pointer = balancedColumnTree;
  583. while (pointer && pointer[0] && pointer[0] instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"]) {
  584. dept++;
  585. pointer = pointer[0].getChildren();
  586. }
  587. return dept;
  588. };
  589. ColumnFactory.prototype.balanceColumnTree = function (unbalancedTree, currentDept, columnDept, columnKeyCreator) {
  590. var result = [];
  591. // go through each child, for groups, recurse a level deeper,
  592. // for columns we need to pad
  593. for (var i = 0; i < unbalancedTree.length; i++) {
  594. var child = unbalancedTree[i];
  595. if (child instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"]) {
  596. // child is a group, all we do is go to the next level of recursion
  597. var originalGroup = child;
  598. var newChildren = this.balanceColumnTree(originalGroup.getChildren(), currentDept + 1, columnDept, columnKeyCreator);
  599. originalGroup.setChildren(newChildren);
  600. result.push(originalGroup);
  601. }
  602. else {
  603. // child is a column - so here we add in the padded column groups if needed
  604. var firstPaddedGroup = void 0;
  605. var currentPaddedGroup = void 0;
  606. // this for loop will NOT run any loops if no padded column groups are needed
  607. for (var j = columnDept - 1; j >= currentDept; j--) {
  608. var newColId = columnKeyCreator.getUniqueKey(null, null);
  609. var colGroupDefMerged = this.createMergedColGroupDef(null);
  610. var paddedGroup = new _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"](colGroupDefMerged, newColId, true, currentDept);
  611. this.context.createBean(paddedGroup);
  612. if (currentPaddedGroup) {
  613. currentPaddedGroup.setChildren([paddedGroup]);
  614. }
  615. currentPaddedGroup = paddedGroup;
  616. if (!firstPaddedGroup) {
  617. firstPaddedGroup = currentPaddedGroup;
  618. }
  619. }
  620. // likewise this if statement will not run if no padded groups
  621. if (firstPaddedGroup) {
  622. result.push(firstPaddedGroup);
  623. var hasGroups = unbalancedTree.some(function (child) { return child instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"]; });
  624. if (hasGroups) {
  625. currentPaddedGroup.setChildren([child]);
  626. continue;
  627. }
  628. else {
  629. currentPaddedGroup.setChildren(unbalancedTree);
  630. break;
  631. }
  632. }
  633. result.push(child);
  634. }
  635. }
  636. return result;
  637. };
  638. ColumnFactory.prototype.findMaxDept = function (treeChildren, dept) {
  639. var maxDeptThisLevel = dept;
  640. for (var i = 0; i < treeChildren.length; i++) {
  641. var abstractColumn = treeChildren[i];
  642. if (abstractColumn instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"]) {
  643. var originalGroup = abstractColumn;
  644. var newDept = this.findMaxDept(originalGroup.getChildren(), dept + 1);
  645. if (maxDeptThisLevel < newDept) {
  646. maxDeptThisLevel = newDept;
  647. }
  648. }
  649. }
  650. return maxDeptThisLevel;
  651. };
  652. ColumnFactory.prototype.recursivelyCreateColumns = function (defs, level, primaryColumns, existingColsCopy, columnKeyCreator, parent) {
  653. var _this = this;
  654. var result = [];
  655. if (!defs) {
  656. return result;
  657. }
  658. defs.forEach(function (def) {
  659. var newGroupOrColumn;
  660. if (_this.isColumnGroup(def)) {
  661. newGroupOrColumn = _this.createColumnGroup(primaryColumns, def, level, existingColsCopy, columnKeyCreator, parent);
  662. }
  663. else {
  664. newGroupOrColumn = _this.createColumn(primaryColumns, def, existingColsCopy, columnKeyCreator, parent);
  665. }
  666. result.push(newGroupOrColumn);
  667. });
  668. return result;
  669. };
  670. ColumnFactory.prototype.createColumnGroup = function (primaryColumns, colGroupDef, level, existingColumns, columnKeyCreator, parent) {
  671. var colGroupDefMerged = this.createMergedColGroupDef(colGroupDef);
  672. var groupId = columnKeyCreator.getUniqueKey(colGroupDefMerged.groupId, null);
  673. var originalGroup = new _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"](colGroupDefMerged, groupId, false, level);
  674. this.context.createBean(originalGroup);
  675. var children = this.recursivelyCreateColumns(colGroupDefMerged.children, level + 1, primaryColumns, existingColumns, columnKeyCreator, originalGroup);
  676. originalGroup.setChildren(children);
  677. return originalGroup;
  678. };
  679. ColumnFactory.prototype.createMergedColGroupDef = function (colGroupDef) {
  680. var colGroupDefMerged = {};
  681. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].assign(colGroupDefMerged, this.gridOptionsWrapper.getDefaultColGroupDef());
  682. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].assign(colGroupDefMerged, colGroupDef);
  683. this.checkForDeprecatedItems(colGroupDefMerged);
  684. return colGroupDefMerged;
  685. };
  686. ColumnFactory.prototype.createColumn = function (primaryColumns, colDef, existingColsCopy, columnKeyCreator, parent) {
  687. var colDefMerged = this.mergeColDefs(colDef);
  688. this.checkForDeprecatedItems(colDefMerged);
  689. // see if column already exists
  690. var column = this.findExistingColumn(colDef, existingColsCopy);
  691. if (!column) {
  692. // no existing column, need to create one
  693. var colId = columnKeyCreator.getUniqueKey(colDefMerged.colId, colDefMerged.field);
  694. column = new _entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"](colDefMerged, colDef, colId, primaryColumns);
  695. this.context.createBean(column);
  696. }
  697. else {
  698. column.setColDef(colDefMerged, colDef);
  699. }
  700. return column;
  701. };
  702. ColumnFactory.prototype.findExistingColumn = function (colDef, existingColsCopy) {
  703. var res = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].find(existingColsCopy, function (col) {
  704. var oldColDef = col.getUserProvidedColDef();
  705. if (!oldColDef) {
  706. return false;
  707. }
  708. // first check object references
  709. if (oldColDef === colDef) {
  710. return true;
  711. }
  712. // second check id's
  713. var oldColHadId = oldColDef.colId !== null && oldColDef.colId !== undefined;
  714. if (oldColHadId) {
  715. return oldColDef.colId === colDef.colId;
  716. }
  717. return false;
  718. });
  719. // make sure we remove, so if user provided duplicate id, then we don't have more than
  720. // one column instance for colDef with common id
  721. if (res) {
  722. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].removeFromArray(existingColsCopy, res);
  723. }
  724. return res;
  725. };
  726. ColumnFactory.prototype.mergeColDefs = function (colDef) {
  727. // start with empty merged definition
  728. var colDefMerged = {};
  729. // merge properties from default column definitions
  730. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].assign(colDefMerged, this.gridOptionsWrapper.getDefaultColDef());
  731. // merge properties from column type properties
  732. if (colDef.type) {
  733. this.assignColumnTypes(colDef, colDefMerged);
  734. }
  735. // merge properties from column definitions
  736. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].assign(colDefMerged, colDef);
  737. return colDefMerged;
  738. };
  739. ColumnFactory.prototype.assignColumnTypes = function (colDef, colDefMerged) {
  740. var typeKeys;
  741. if (colDef.type instanceof Array) {
  742. var invalidArray = colDef.type.some(function (a) { return typeof a !== 'string'; });
  743. if (invalidArray) {
  744. console.warn("ag-grid: if colDef.type is supplied an array it should be of type 'string[]'");
  745. }
  746. else {
  747. typeKeys = colDef.type;
  748. }
  749. }
  750. else if (typeof colDef.type === 'string') {
  751. typeKeys = colDef.type.split(',');
  752. }
  753. else {
  754. console.warn("ag-grid: colDef.type should be of type 'string' | 'string[]'");
  755. return;
  756. }
  757. // merge user defined with default column types
  758. var allColumnTypes = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].assign({}, _entities_defaultColumnTypes__WEBPACK_IMPORTED_MODULE_4__["DefaultColumnTypes"]);
  759. var userTypes = this.gridOptionsWrapper.getColumnTypes() || {};
  760. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].iterateObject(userTypes, function (key, value) {
  761. if (key in allColumnTypes) {
  762. console.warn("ag-Grid: the column type '" + key + "' is a default column type and cannot be overridden.");
  763. }
  764. else {
  765. allColumnTypes[key] = value;
  766. }
  767. });
  768. typeKeys.forEach(function (t) {
  769. var typeColDef = allColumnTypes[t.trim()];
  770. if (typeColDef) {
  771. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].assign(colDefMerged, typeColDef);
  772. }
  773. else {
  774. console.warn("ag-grid: colDef.type '" + t + "' does not correspond to defined gridOptions.columnTypes");
  775. }
  776. });
  777. };
  778. ColumnFactory.prototype.checkForDeprecatedItems = function (colDef) {
  779. if (colDef) {
  780. var colDefNoType = colDef; // take out the type, so we can access attributes not defined in the type
  781. if (colDefNoType.group !== undefined) {
  782. console.warn('ag-grid: colDef.group is invalid, please check documentation on how to do grouping as it changed in version 3');
  783. }
  784. if (colDefNoType.headerGroup !== undefined) {
  785. console.warn('ag-grid: colDef.headerGroup is invalid, please check documentation on how to do grouping as it changed in version 3');
  786. }
  787. if (colDefNoType.headerGroupShow !== undefined) {
  788. console.warn('ag-grid: colDef.headerGroupShow is invalid, should be columnGroupShow, please check documentation on how to do grouping as it changed in version 3');
  789. }
  790. if (colDefNoType.suppressRowGroup !== undefined) {
  791. console.warn('ag-grid: colDef.suppressRowGroup is deprecated, please use colDef.type instead');
  792. }
  793. if (colDefNoType.suppressAggregation !== undefined) {
  794. console.warn('ag-grid: colDef.suppressAggregation is deprecated, please use colDef.type instead');
  795. }
  796. if (colDefNoType.suppressRowGroup || colDefNoType.suppressAggregation) {
  797. console.warn('ag-grid: colDef.suppressAggregation and colDef.suppressRowGroup are deprecated, use allowRowGroup, allowPivot and allowValue instead');
  798. }
  799. if (colDefNoType.displayName) {
  800. console.warn("ag-grid: Found displayName " + colDefNoType.displayName + ", please use headerName instead, displayName is deprecated.");
  801. colDefNoType.headerName = colDefNoType.displayName;
  802. }
  803. }
  804. };
  805. // if object has children, we assume it's a group
  806. ColumnFactory.prototype.isColumnGroup = function (abstractColDef) {
  807. return abstractColDef.children !== undefined;
  808. };
  809. __decorate([
  810. Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('gridOptionsWrapper')
  811. ], ColumnFactory.prototype, "gridOptionsWrapper", void 0);
  812. __decorate([
  813. Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('columnUtils')
  814. ], ColumnFactory.prototype, "columnUtils", void 0);
  815. __decorate([
  816. __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Qualifier"])('loggerFactory'))
  817. ], ColumnFactory.prototype, "setBeans", null);
  818. ColumnFactory = __decorate([
  819. Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Bean"])('columnFactory')
  820. ], ColumnFactory);
  821. return ColumnFactory;
  822. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_6__["BeanStub"]));
  823. /***/ }),
  824. /* 6 */
  825. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  826. "use strict";
  827. __webpack_require__.r(__webpack_exports__);
  828. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnKeyCreator", function() { return ColumnKeyCreator; });
  829. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7);
  830. /**
  831. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  832. * @version v23.2.1
  833. * @link http://www.ag-grid.com/
  834. * @license MIT
  835. */
  836. // class returns a unique id to use for the column. it checks the existing columns, and if the requested
  837. // id is already taken, it will start appending numbers until it gets a unique id.
  838. // eg, if the col field is 'name', it will try ids: {name, name_1, name_2...}
  839. // if no field or id provided in the col, it will try the ids of natural numbers
  840. var ColumnKeyCreator = /** @class */ (function () {
  841. function ColumnKeyCreator() {
  842. this.existingKeys = {};
  843. }
  844. ColumnKeyCreator.prototype.addExistingKeys = function (keys) {
  845. for (var i = 0; i < keys.length; i++) {
  846. this.existingKeys[keys[i]] = true;
  847. }
  848. };
  849. ColumnKeyCreator.prototype.getUniqueKey = function (colId, colField) {
  850. // in case user passed in number for colId, convert to string
  851. colId = _utils__WEBPACK_IMPORTED_MODULE_0__["_"].toStringOrNull(colId);
  852. var count = 0;
  853. while (true) {
  854. var idToTry = void 0;
  855. if (colId) {
  856. idToTry = colId;
  857. if (count !== 0) {
  858. idToTry += '_' + count;
  859. }
  860. }
  861. else if (colField) {
  862. idToTry = colField;
  863. if (count !== 0) {
  864. idToTry += '_' + count;
  865. }
  866. }
  867. else {
  868. idToTry = '' + count;
  869. }
  870. if (!this.existingKeys[idToTry]) {
  871. this.existingKeys[idToTry] = true;
  872. return idToTry;
  873. }
  874. count++;
  875. }
  876. };
  877. return ColumnKeyCreator;
  878. }());
  879. /***/ }),
  880. /* 7 */
  881. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  882. "use strict";
  883. __webpack_require__.r(__webpack_exports__);
  884. /* harmony import */ var _color__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(8);
  885. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Color", function() { return _color__WEBPACK_IMPORTED_MODULE_0__["Color"]; });
  886. /* harmony import */ var _csv__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(9);
  887. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "stringToArray", function() { return _csv__WEBPACK_IMPORTED_MODULE_1__["stringToArray"]; });
  888. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(10);
  889. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "_", function() { return _utils__WEBPACK_IMPORTED_MODULE_2__["_"]; });
  890. /* harmony import */ var _numberSequence__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(30);
  891. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "NumberSequence", function() { return _numberSequence__WEBPACK_IMPORTED_MODULE_3__["NumberSequence"]; });
  892. /* harmony import */ var _promise__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(31);
  893. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PromiseStatus", function() { return _promise__WEBPACK_IMPORTED_MODULE_4__["PromiseStatus"]; });
  894. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Promise", function() { return _promise__WEBPACK_IMPORTED_MODULE_4__["Promise"]; });
  895. /* harmony import */ var _timer__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(32);
  896. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Timer", function() { return _timer__WEBPACK_IMPORTED_MODULE_5__["Timer"]; });
  897. /**
  898. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  899. * @version v23.2.1
  900. * @link http://www.ag-grid.com/
  901. * @license MIT
  902. */
  903. /***/ }),
  904. /* 8 */
  905. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  906. "use strict";
  907. __webpack_require__.r(__webpack_exports__);
  908. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Color", function() { return Color; });
  909. /**
  910. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  911. * @version v23.2.1
  912. * @link http://www.ag-grid.com/
  913. * @license MIT
  914. */
  915. var Color = /** @class */ (function () {
  916. /**
  917. * Every color component should be in the [0, 1] range.
  918. * Some easing functions (such as elastic easing) can overshoot the target value by some amount.
  919. * So, when animating colors, if the source or target color components are already near
  920. * or at the edge of the allowed [0, 1] range, it is possible for the intermediate color
  921. * component value to end up outside of that range mid-animation. For this reason the constructor
  922. * performs range checking/constraining.
  923. * @param r Red component.
  924. * @param g Green component.
  925. * @param b Blue component.
  926. * @param a Alpha (opacity) component.
  927. */
  928. function Color(r, g, b, a) {
  929. if (a === void 0) { a = 1; }
  930. // NaN is treated as 0.
  931. this.r = Math.min(1, Math.max(0, r || 0));
  932. this.g = Math.min(1, Math.max(0, g || 0));
  933. this.b = Math.min(1, Math.max(0, b || 0));
  934. this.a = Math.min(1, Math.max(0, a || 0));
  935. }
  936. /**
  937. * The given string can be in one of the following formats:
  938. * - #rgb
  939. * - #rrggbb
  940. * - rgb(r, g, b)
  941. * - rgba(r, g, b, a)
  942. * - CSS color name such as 'white', 'orange', 'cyan', etc.
  943. * @param str
  944. */
  945. Color.fromString = function (str) {
  946. // hexadecimal notation
  947. if (str.indexOf('#') >= 0) { // there can be some leading whitespace
  948. return Color.fromHexString(str);
  949. }
  950. // color name
  951. var hex = Color.nameToHex[str];
  952. if (hex) {
  953. return Color.fromHexString(hex);
  954. }
  955. // rgb(a) notation
  956. if (str.indexOf('rgb') >= 0) {
  957. return Color.fromRgbaString(str);
  958. }
  959. throw new Error("Invalid color string: '" + str + "'");
  960. };
  961. // Using separate RegExp for the short hex notation because strings like `#abcd`
  962. // are matched as ['#abcd', 'ab', 'c', 'd', undefined] when the `{1,2}` quantifier is used.
  963. Color.fromHexString = function (str) {
  964. var values = str.match(Color.hexRe);
  965. if (values) {
  966. var r = parseInt(values[1], 16);
  967. var g = parseInt(values[2], 16);
  968. var b = parseInt(values[3], 16);
  969. var a = values[4] !== undefined ? parseInt(values[4], 16) : 255;
  970. return new Color(r / 255, g / 255, b / 255, a / 255);
  971. }
  972. values = str.match(Color.shortHexRe);
  973. if (values) {
  974. var r = parseInt(values[1], 16);
  975. var g = parseInt(values[2], 16);
  976. var b = parseInt(values[3], 16);
  977. var a = values[4] !== undefined ? parseInt(values[4], 16) : 15;
  978. r += r * 16;
  979. g += g * 16;
  980. b += b * 16;
  981. a += a * 16;
  982. return new Color(r / 255, g / 255, b / 255, a / 255);
  983. }
  984. throw new Error("Malformed hexadecimal color string: '" + str + "'");
  985. };
  986. Color.fromRgbaString = function (str) {
  987. var values = str.match(Color.rgbRe);
  988. if (values) {
  989. return new Color(+values[1] / 255, +values[2] / 255, +values[3] / 255);
  990. }
  991. values = str.match(Color.rgbaRe);
  992. if (values) {
  993. return new Color(+values[1] / 255, +values[2] / 255, +values[3] / 255, +values[4]);
  994. }
  995. throw new Error("Malformed rgb/rgba color string: '" + str + "'");
  996. };
  997. Color.fromArray = function (arr) {
  998. if (arr.length === 4) {
  999. return new Color(arr[0], arr[1], arr[2], arr[3]);
  1000. }
  1001. if (arr.length === 3) {
  1002. return new Color(arr[0], arr[1], arr[2]);
  1003. }
  1004. throw new Error('The given array should contain 3 or 4 color components (numbers).');
  1005. };
  1006. /**
  1007. * Creates an instance of the Color class from the given HSB(A) components.
  1008. * @param h Hue in the [0, 360) range.
  1009. * @param s Saturation in the [0, 1] range.
  1010. * @param b Brightness in the [0, 1] range.
  1011. * @param alpha Opacity in the [0, 1] range. Defaults to 1 (completely opaque).
  1012. */
  1013. Color.fromHSB = function (h, s, b, alpha) {
  1014. if (alpha === void 0) { alpha = 1; }
  1015. var rgb = Color.HSBtoRGB(h, s, b);
  1016. return new Color(rgb[0], rgb[1], rgb[2], alpha);
  1017. };
  1018. Color.padHex = function (str) {
  1019. // Can't use `padStart(2, '0')` here because of IE.
  1020. return str.length === 1 ? '0' + str : str;
  1021. };
  1022. Color.prototype.toHexString = function () {
  1023. var hex = '#'
  1024. + Color.padHex(Math.round(this.r * 255).toString(16))
  1025. + Color.padHex(Math.round(this.g * 255).toString(16))
  1026. + Color.padHex(Math.round(this.b * 255).toString(16));
  1027. if (this.a < 1) {
  1028. hex += Color.padHex(Math.round(this.a * 255).toString(16));
  1029. }
  1030. return hex;
  1031. };
  1032. Color.prototype.toRgbaString = function (fractionDigits) {
  1033. if (fractionDigits === void 0) { fractionDigits = 3; }
  1034. var components = [
  1035. Math.round(this.r * 255),
  1036. Math.round(this.g * 255),
  1037. Math.round(this.b * 255)
  1038. ];
  1039. var k = Math.pow(10, fractionDigits);
  1040. if (this.a !== 1) {
  1041. components.push(Math.round(this.a * k) / k);
  1042. return "rgba(" + components.join(', ') + ")";
  1043. }
  1044. return "rgb(" + components.join(', ') + ")";
  1045. };
  1046. Color.prototype.toString = function () {
  1047. if (this.a === 1) {
  1048. return this.toHexString();
  1049. }
  1050. return this.toRgbaString();
  1051. };
  1052. Color.prototype.toHSB = function () {
  1053. return Color.RGBtoHSB(this.r, this.g, this.b);
  1054. };
  1055. /**
  1056. * Converts the given RGB triple to an array of HSB (HSV) components.
  1057. * The hue component will be `NaN` for achromatic colors.
  1058. */
  1059. Color.RGBtoHSB = function (r, g, b) {
  1060. var min = Math.min(r, g, b);
  1061. var max = Math.max(r, g, b);
  1062. var S = max !== 0 ? (max - min) / max : 0;
  1063. var H = NaN;
  1064. // min == max, means all components are the same
  1065. // and the color is a shade of gray with no hue (H is NaN)
  1066. if (min !== max) {
  1067. var delta = max - min;
  1068. var rc = (max - r) / delta;
  1069. var gc = (max - g) / delta;
  1070. var bc = (max - b) / delta;
  1071. if (r === max) {
  1072. H = bc - gc;
  1073. }
  1074. else if (g === max) {
  1075. H = 2.0 + rc - bc;
  1076. }
  1077. else {
  1078. H = 4.0 + gc - rc;
  1079. }
  1080. H /= 6.0;
  1081. if (H < 0) {
  1082. H = H + 1.0;
  1083. }
  1084. }
  1085. return [H * 360, S, max];
  1086. };
  1087. /**
  1088. * Converts the given HSB (HSV) triple to an array of RGB components.
  1089. */
  1090. Color.HSBtoRGB = function (H, S, B) {
  1091. if (isNaN(H)) {
  1092. H = 0;
  1093. }
  1094. H = (((H % 360) + 360) % 360) / 360; // normalize hue to [0, 360] interval, then scale to [0, 1]
  1095. var r = 0;
  1096. var g = 0;
  1097. var b = 0;
  1098. if (S === 0) {
  1099. r = g = b = B;
  1100. }
  1101. else {
  1102. var h = (H - Math.floor(H)) * 6;
  1103. var f = h - Math.floor(h);
  1104. var p = B * (1 - S);
  1105. var q = B * (1 - S * f);
  1106. var t = B * (1 - (S * (1 - f)));
  1107. switch (h >> 0) { // discard the floating point part of the number
  1108. case 0:
  1109. r = B;
  1110. g = t;
  1111. b = p;
  1112. break;
  1113. case 1:
  1114. r = q;
  1115. g = B;
  1116. b = p;
  1117. break;
  1118. case 2:
  1119. r = p;
  1120. g = B;
  1121. b = t;
  1122. break;
  1123. case 3:
  1124. r = p;
  1125. g = q;
  1126. b = B;
  1127. break;
  1128. case 4:
  1129. r = t;
  1130. g = p;
  1131. b = B;
  1132. break;
  1133. case 5:
  1134. r = B;
  1135. g = p;
  1136. b = q;
  1137. break;
  1138. }
  1139. }
  1140. return [r, g, b];
  1141. };
  1142. Color.prototype.derive = function (hueShift, saturationFactor, brightnessFactor, opacityFactor) {
  1143. var hsb = Color.RGBtoHSB(this.r, this.g, this.b);
  1144. var b = hsb[2];
  1145. if (b == 0 && brightnessFactor > 1.0) {
  1146. b = 0.05;
  1147. }
  1148. var h = (((hsb[0] + hueShift) % 360) + 360) % 360;
  1149. var s = Math.max(Math.min(hsb[1] * saturationFactor, 1.0), 0.0);
  1150. b = Math.max(Math.min(b * brightnessFactor, 1.0), 0.0);
  1151. var a = Math.max(Math.min(this.a * opacityFactor, 1.0), 0.0);
  1152. var rgba = Color.HSBtoRGB(h, s, b);
  1153. rgba.push(a);
  1154. return Color.fromArray(rgba);
  1155. };
  1156. Color.prototype.brighter = function () {
  1157. return this.derive(0, 1.0, 1.0 / 0.7, 1.0);
  1158. };
  1159. Color.prototype.darker = function () {
  1160. return this.derive(0, 1.0, 0.7, 1.0);
  1161. };
  1162. // See https://drafts.csswg.org/css-color/#hex-notation
  1163. Color.hexRe = /\s*#([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})?\s*$/;
  1164. Color.shortHexRe = /\s*#([0-9a-fA-F])([0-9a-fA-F])([0-9a-fA-F])([0-9a-fA-F])?\s*$/;
  1165. Color.rgbRe = /\s*rgb\((\d+),\s*(\d+),\s*(\d+)\)\s*/;
  1166. Color.rgbaRe = /\s*rgba\((\d+),\s*(\d+),\s*(\d+),\s*([.\d]+)\)\s*/;
  1167. /**
  1168. * CSS Color Module Level 4:
  1169. * https://drafts.csswg.org/css-color/#named-colors
  1170. */
  1171. Color.nameToHex = Object.freeze({
  1172. aliceblue: '#F0F8FF',
  1173. antiquewhite: '#FAEBD7',
  1174. aqua: '#00FFFF',
  1175. aquamarine: '#7FFFD4',
  1176. azure: '#F0FFFF',
  1177. beige: '#F5F5DC',
  1178. bisque: '#FFE4C4',
  1179. black: '#000000',
  1180. blanchedalmond: '#FFEBCD',
  1181. blue: '#0000FF',
  1182. blueviolet: '#8A2BE2',
  1183. brown: '#A52A2A',
  1184. burlywood: '#DEB887',
  1185. cadetblue: '#5F9EA0',
  1186. chartreuse: '#7FFF00',
  1187. chocolate: '#D2691E',
  1188. coral: '#FF7F50',
  1189. cornflowerblue: '#6495ED',
  1190. cornsilk: '#FFF8DC',
  1191. crimson: '#DC143C',
  1192. cyan: '#00FFFF',
  1193. darkblue: '#00008B',
  1194. darkcyan: '#008B8B',
  1195. darkgoldenrod: '#B8860B',
  1196. darkgray: '#A9A9A9',
  1197. darkgreen: '#006400',
  1198. darkgrey: '#A9A9A9',
  1199. darkkhaki: '#BDB76B',
  1200. darkmagenta: '#8B008B',
  1201. darkolivegreen: '#556B2F',
  1202. darkorange: '#FF8C00',
  1203. darkorchid: '#9932CC',
  1204. darkred: '#8B0000',
  1205. darksalmon: '#E9967A',
  1206. darkseagreen: '#8FBC8F',
  1207. darkslateblue: '#483D8B',
  1208. darkslategray: '#2F4F4F',
  1209. darkslategrey: '#2F4F4F',
  1210. darkturquoise: '#00CED1',
  1211. darkviolet: '#9400D3',
  1212. deeppink: '#FF1493',
  1213. deepskyblue: '#00BFFF',
  1214. dimgray: '#696969',
  1215. dimgrey: '#696969',
  1216. dodgerblue: '#1E90FF',
  1217. firebrick: '#B22222',
  1218. floralwhite: '#FFFAF0',
  1219. forestgreen: '#228B22',
  1220. fuchsia: '#FF00FF',
  1221. gainsboro: '#DCDCDC',
  1222. ghostwhite: '#F8F8FF',
  1223. gold: '#FFD700',
  1224. goldenrod: '#DAA520',
  1225. gray: '#808080',
  1226. green: '#008000',
  1227. greenyellow: '#ADFF2F',
  1228. grey: '#808080',
  1229. honeydew: '#F0FFF0',
  1230. hotpink: '#FF69B4',
  1231. indianred: '#CD5C5C',
  1232. indigo: '#4B0082',
  1233. ivory: '#FFFFF0',
  1234. khaki: '#F0E68C',
  1235. lavender: '#E6E6FA',
  1236. lavenderblush: '#FFF0F5',
  1237. lawngreen: '#7CFC00',
  1238. lemonchiffon: '#FFFACD',
  1239. lightblue: '#ADD8E6',
  1240. lightcoral: '#F08080',
  1241. lightcyan: '#E0FFFF',
  1242. lightgoldenrodyellow: '#FAFAD2',
  1243. lightgray: '#D3D3D3',
  1244. lightgreen: '#90EE90',
  1245. lightgrey: '#D3D3D3',
  1246. lightpink: '#FFB6C1',
  1247. lightsalmon: '#FFA07A',
  1248. lightseagreen: '#20B2AA',
  1249. lightskyblue: '#87CEFA',
  1250. lightslategray: '#778899',
  1251. lightslategrey: '#778899',
  1252. lightsteelblue: '#B0C4DE',
  1253. lightyellow: '#FFFFE0',
  1254. lime: '#00FF00',
  1255. limegreen: '#32CD32',
  1256. linen: '#FAF0E6',
  1257. magenta: '#FF00FF',
  1258. maroon: '#800000',
  1259. mediumaquamarine: '#66CDAA',
  1260. mediumblue: '#0000CD',
  1261. mediumorchid: '#BA55D3',
  1262. mediumpurple: '#9370DB',
  1263. mediumseagreen: '#3CB371',
  1264. mediumslateblue: '#7B68EE',
  1265. mediumspringgreen: '#00FA9A',
  1266. mediumturquoise: '#48D1CC',
  1267. mediumvioletred: '#C71585',
  1268. midnightblue: '#191970',
  1269. mintcream: '#F5FFFA',
  1270. mistyrose: '#FFE4E1',
  1271. moccasin: '#FFE4B5',
  1272. navajowhite: '#FFDEAD',
  1273. navy: '#000080',
  1274. oldlace: '#FDF5E6',
  1275. olive: '#808000',
  1276. olivedrab: '#6B8E23',
  1277. orange: '#FFA500',
  1278. orangered: '#FF4500',
  1279. orchid: '#DA70D6',
  1280. palegoldenrod: '#EEE8AA',
  1281. palegreen: '#98FB98',
  1282. paleturquoise: '#AFEEEE',
  1283. palevioletred: '#DB7093',
  1284. papayawhip: '#FFEFD5',
  1285. peachpuff: '#FFDAB9',
  1286. peru: '#CD853F',
  1287. pink: '#FFC0CB',
  1288. plum: '#DDA0DD',
  1289. powderblue: '#B0E0E6',
  1290. purple: '#800080',
  1291. rebeccapurple: '#663399',
  1292. red: '#FF0000',
  1293. rosybrown: '#BC8F8F',
  1294. royalblue: '#4169E1',
  1295. saddlebrown: '#8B4513',
  1296. salmon: '#FA8072',
  1297. sandybrown: '#F4A460',
  1298. seagreen: '#2E8B57',
  1299. seashell: '#FFF5EE',
  1300. sienna: '#A0522D',
  1301. silver: '#C0C0C0',
  1302. skyblue: '#87CEEB',
  1303. slateblue: '#6A5ACD',
  1304. slategray: '#708090',
  1305. slategrey: '#708090',
  1306. snow: '#FFFAFA',
  1307. springgreen: '#00FF7F',
  1308. steelblue: '#4682B4',
  1309. tan: '#D2B48C',
  1310. teal: '#008080',
  1311. thistle: '#D8BFD8',
  1312. tomato: '#FF6347',
  1313. turquoise: '#40E0D0',
  1314. violet: '#EE82EE',
  1315. wheat: '#F5DEB3',
  1316. white: '#FFFFFF',
  1317. whitesmoke: '#F5F5F5',
  1318. yellow: '#FFFF00',
  1319. yellowgreen: '#9ACD32'
  1320. });
  1321. return Color;
  1322. }());
  1323. /***/ }),
  1324. /* 9 */
  1325. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  1326. "use strict";
  1327. __webpack_require__.r(__webpack_exports__);
  1328. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "stringToArray", function() { return stringToArray; });
  1329. /**
  1330. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  1331. * @version v23.2.1
  1332. * @link http://www.ag-grid.com/
  1333. * @license MIT
  1334. */
  1335. // Based on https://stackoverflow.com/a/14991797
  1336. // This will parse a delimited string into an array of arrays.
  1337. function stringToArray(strData, delimiter) {
  1338. if (delimiter === void 0) { delimiter = ','; }
  1339. var data = [];
  1340. var isNewline = function (char) { return char === '\r' || char === '\n'; };
  1341. var insideQuotedField = false;
  1342. var _loop_1 = function (row, column, position) {
  1343. var previousChar = strData[position - 1];
  1344. var currentChar = strData[position];
  1345. var nextChar = strData[position + 1];
  1346. var ensureDataExists = function () {
  1347. if (!data[row]) {
  1348. // create row if it doesn't exist
  1349. data[row] = [];
  1350. }
  1351. if (!data[row][column]) {
  1352. // create column if it doesn't exist
  1353. data[row][column] = '';
  1354. }
  1355. };
  1356. ensureDataExists();
  1357. if (currentChar === '"') {
  1358. if (insideQuotedField) {
  1359. if (nextChar === '"') {
  1360. // unescape double quote
  1361. data[row][column] += '"';
  1362. position++;
  1363. }
  1364. else {
  1365. // exit quoted field
  1366. insideQuotedField = false;
  1367. }
  1368. return out_row_1 = row, out_column_1 = column, out_position_1 = position, "continue";
  1369. }
  1370. else if (previousChar === undefined || previousChar === delimiter || isNewline(previousChar)) {
  1371. // enter quoted field
  1372. insideQuotedField = true;
  1373. return out_row_1 = row, out_column_1 = column, out_position_1 = position, "continue";
  1374. }
  1375. }
  1376. if (!insideQuotedField) {
  1377. if (currentChar === delimiter) {
  1378. // move to next column
  1379. column++;
  1380. ensureDataExists();
  1381. return out_row_1 = row, out_column_1 = column, out_position_1 = position, "continue";
  1382. }
  1383. else if (isNewline(currentChar)) {
  1384. // move to next row
  1385. column = 0;
  1386. row++;
  1387. ensureDataExists();
  1388. if (currentChar === '\r' && nextChar === '\n') {
  1389. // skip over second newline character if it exists
  1390. position++;
  1391. }
  1392. return out_row_1 = row, out_column_1 = column, out_position_1 = position, "continue";
  1393. }
  1394. }
  1395. // add current character to current column
  1396. data[row][column] += currentChar;
  1397. out_row_1 = row;
  1398. out_column_1 = column;
  1399. out_position_1 = position;
  1400. };
  1401. var out_row_1, out_column_1, out_position_1;
  1402. // iterate over each character, keep track of current row and column (of the returned array)
  1403. for (var row = 0, column = 0, position = 0; position < strData.length; position++) {
  1404. _loop_1(row, column, position);
  1405. row = out_row_1;
  1406. column = out_column_1;
  1407. position = out_position_1;
  1408. }
  1409. return data;
  1410. }
  1411. /***/ }),
  1412. /* 10 */
  1413. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  1414. "use strict";
  1415. __webpack_require__.r(__webpack_exports__);
  1416. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "_", function() { return _; });
  1417. /* harmony import */ var _general__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(11);
  1418. /* harmony import */ var _array__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(17);
  1419. /* harmony import */ var _browser__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(13);
  1420. /* harmony import */ var _csv__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(9);
  1421. /* harmony import */ var _date__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(18);
  1422. /* harmony import */ var _dom__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(12);
  1423. /* harmony import */ var _event__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(20);
  1424. /* harmony import */ var _function__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(21);
  1425. /* harmony import */ var _fuzzyMatch__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(22);
  1426. /* harmony import */ var _generic__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(14);
  1427. /* harmony import */ var _icon__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(23);
  1428. /* harmony import */ var _keyboard__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(24);
  1429. /* harmony import */ var _map__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(26);
  1430. /* harmony import */ var _mouse__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(27);
  1431. /* harmony import */ var _number__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(19);
  1432. /* harmony import */ var _object__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(16);
  1433. /* harmony import */ var _rowNode__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(28);
  1434. /* harmony import */ var _set__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(29);
  1435. /* harmony import */ var _string__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(15);
  1436. /**
  1437. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  1438. * @version v23.2.1
  1439. * @link http://www.ag-grid.com/
  1440. * @license MIT
  1441. */
  1442. var __assign = (undefined && undefined.__assign) || function () {
  1443. __assign = Object.assign || function(t) {
  1444. for (var s, i = 1, n = arguments.length; i < n; i++) {
  1445. s = arguments[i];
  1446. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
  1447. t[p] = s[p];
  1448. }
  1449. return t;
  1450. };
  1451. return __assign.apply(this, arguments);
  1452. };
  1453. var utils = __assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign(__assign({}, _general__WEBPACK_IMPORTED_MODULE_0__), _array__WEBPACK_IMPORTED_MODULE_1__), _browser__WEBPACK_IMPORTED_MODULE_2__), _csv__WEBPACK_IMPORTED_MODULE_3__), _date__WEBPACK_IMPORTED_MODULE_4__), _dom__WEBPACK_IMPORTED_MODULE_5__), _event__WEBPACK_IMPORTED_MODULE_6__), _function__WEBPACK_IMPORTED_MODULE_7__), _fuzzyMatch__WEBPACK_IMPORTED_MODULE_8__), _generic__WEBPACK_IMPORTED_MODULE_9__), _icon__WEBPACK_IMPORTED_MODULE_10__), _keyboard__WEBPACK_IMPORTED_MODULE_11__), _map__WEBPACK_IMPORTED_MODULE_12__), _mouse__WEBPACK_IMPORTED_MODULE_13__), _number__WEBPACK_IMPORTED_MODULE_14__), _object__WEBPACK_IMPORTED_MODULE_15__), _rowNode__WEBPACK_IMPORTED_MODULE_16__), _set__WEBPACK_IMPORTED_MODULE_17__), _string__WEBPACK_IMPORTED_MODULE_18__);
  1454. var _ = utils;
  1455. /***/ }),
  1456. /* 11 */
  1457. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  1458. "use strict";
  1459. __webpack_require__.r(__webpack_exports__);
  1460. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getNameOfClass", function() { return getNameOfClass; });
  1461. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "findLineByLeastSquares", function() { return findLineByLeastSquares; });
  1462. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cssStyleObjectToMarkup", function() { return cssStyleObjectToMarkup; });
  1463. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "message", function() { return message; });
  1464. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "bindCellRendererToHtmlElement", function() { return bindCellRendererToHtmlElement; });
  1465. /* harmony import */ var _dom__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12);
  1466. /* harmony import */ var _string__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(15);
  1467. /* harmony import */ var _object__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(16);
  1468. /**
  1469. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  1470. * @version v23.2.1
  1471. * @link http://www.ag-grid.com/
  1472. * @license MIT
  1473. */
  1474. /** @deprecated */
  1475. function getNameOfClass(theClass) {
  1476. var funcNameRegex = /function (.{1,})\(/;
  1477. var funcAsString = theClass.toString();
  1478. var results = funcNameRegex.exec(funcAsString);
  1479. return results && results.length > 1 ? results[1] : "";
  1480. }
  1481. function findLineByLeastSquares(values) {
  1482. var len = values.length;
  1483. var maxDecimals = 0;
  1484. if (len <= 1) {
  1485. return values;
  1486. }
  1487. for (var i = 0; i < values.length; i++) {
  1488. var value = values[i];
  1489. if (Math.floor(value) === value) {
  1490. continue;
  1491. }
  1492. maxDecimals = Math.max(maxDecimals, value.toString().split('.')[1].length);
  1493. }
  1494. var sum_x = 0;
  1495. var sum_y = 0;
  1496. var sum_xy = 0;
  1497. var sum_xx = 0;
  1498. var y = 0;
  1499. for (var x = 0; x < len; x++) {
  1500. y = values[x];
  1501. sum_x += x;
  1502. sum_y += y;
  1503. sum_xx += x * x;
  1504. sum_xy += x * y;
  1505. }
  1506. var m = (len * sum_xy - sum_x * sum_y) / (len * sum_xx - sum_x * sum_x);
  1507. var b = (sum_y / len) - (m * sum_x) / len;
  1508. var result = [];
  1509. for (var x = 0; x <= len; x++) {
  1510. result.push(parseFloat((x * m + b).toFixed(maxDecimals)));
  1511. }
  1512. return result;
  1513. }
  1514. /**
  1515. * Converts a CSS object into string
  1516. * @param {Object} stylesToUse an object eg: {color: 'black', top: '25px'}
  1517. * @return {string} A string like "color: black; top: 25px;" for html
  1518. */
  1519. function cssStyleObjectToMarkup(stylesToUse) {
  1520. if (!stylesToUse) {
  1521. return '';
  1522. }
  1523. var resParts = [];
  1524. Object(_object__WEBPACK_IMPORTED_MODULE_2__["iterateObject"])(stylesToUse, function (styleKey, styleValue) {
  1525. var styleKeyDashed = Object(_string__WEBPACK_IMPORTED_MODULE_1__["camelCaseToHyphen"])(styleKey);
  1526. resParts.push(styleKeyDashed + ": " + styleValue + ";");
  1527. });
  1528. return resParts.join(' ');
  1529. }
  1530. /**
  1531. * Displays a message to the browser. this is useful in iPad, where you can't easily see the console.
  1532. * so the javascript code can use this to give feedback. this is NOT intended to be called in production.
  1533. * it is intended the ag-Grid developer calls this to troubleshoot, but then takes out the calls before
  1534. * checking in.
  1535. * @param {string} msg
  1536. */
  1537. function message(msg) {
  1538. var eMessage = document.createElement('div');
  1539. var eBox = document.querySelector('#__ag__message');
  1540. eMessage.innerHTML = msg;
  1541. if (!eBox) {
  1542. var template = "<div id=\"__ag__message\" style=\"display: inline-block; position: absolute; top: 0px; left: 0px; color: white; background-color: black; z-index: 20; padding: 2px; border: 1px solid darkred; height: 200px; overflow-y: auto;\"></div>";
  1543. eBox = Object(_dom__WEBPACK_IMPORTED_MODULE_0__["loadTemplate"])(template);
  1544. if (document.body) {
  1545. document.body.appendChild(eBox);
  1546. }
  1547. }
  1548. eBox.insertBefore(eMessage, eBox.children[0]);
  1549. }
  1550. /**
  1551. * cell renderers are used in a few places. they bind to dom slightly differently to other cell renderes as they
  1552. * can return back strings (instead of html elemnt) in the getGui() method. common code placed here to handle that.
  1553. * @param {Promise<ICellRendererComp>} cellRendererPromise
  1554. * @param {HTMLElement} eTarget
  1555. */
  1556. function bindCellRendererToHtmlElement(cellRendererPromise, eTarget) {
  1557. cellRendererPromise.then(function (cellRenderer) {
  1558. var gui = cellRenderer.getGui();
  1559. if (gui != null) {
  1560. if (typeof gui === 'object') {
  1561. eTarget.appendChild(gui);
  1562. }
  1563. else {
  1564. eTarget.innerHTML = gui;
  1565. }
  1566. }
  1567. });
  1568. }
  1569. /***/ }),
  1570. /* 12 */
  1571. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  1572. "use strict";
  1573. __webpack_require__.r(__webpack_exports__);
  1574. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "addCssClass", function() { return addCssClass; });
  1575. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "removeCssClass", function() { return removeCssClass; });
  1576. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "addOrRemoveCssClass", function() { return addOrRemoveCssClass; });
  1577. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "radioCssClass", function() { return radioCssClass; });
  1578. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "containsClass", function() { return containsClass; });
  1579. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setDisplayed", function() { return setDisplayed; });
  1580. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setVisible", function() { return setVisible; });
  1581. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setDisabled", function() { return setDisabled; });
  1582. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isElementChildOfClass", function() { return isElementChildOfClass; });
  1583. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getElementSize", function() { return getElementSize; });
  1584. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getInnerHeight", function() { return getInnerHeight; });
  1585. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getInnerWidth", function() { return getInnerWidth; });
  1586. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getAbsoluteHeight", function() { return getAbsoluteHeight; });
  1587. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getAbsoluteWidth", function() { return getAbsoluteWidth; });
  1588. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getScrollLeft", function() { return getScrollLeft; });
  1589. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setScrollLeft", function() { return setScrollLeft; });
  1590. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "clearElement", function() { return clearElement; });
  1591. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "removeElement", function() { return removeElement; });
  1592. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "removeFromParent", function() { return removeFromParent; });
  1593. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isVisible", function() { return isVisible; });
  1594. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "loadTemplate", function() { return loadTemplate; });
  1595. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "appendHtml", function() { return appendHtml; });
  1596. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getElementAttribute", function() { return getElementAttribute; });
  1597. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "offsetHeight", function() { return offsetHeight; });
  1598. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "offsetWidth", function() { return offsetWidth; });
  1599. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ensureDomOrder", function() { return ensureDomOrder; });
  1600. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setDomChildOrder", function() { return setDomChildOrder; });
  1601. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "insertTemplateWithDomOrder", function() { return insertTemplateWithDomOrder; });
  1602. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "prependDC", function() { return prependDC; });
  1603. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "addStylesToElement", function() { return addStylesToElement; });
  1604. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isHorizontalScrollShowing", function() { return isHorizontalScrollShowing; });
  1605. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isVerticalScrollShowing", function() { return isVerticalScrollShowing; });
  1606. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setElementWidth", function() { return setElementWidth; });
  1607. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setFixedWidth", function() { return setFixedWidth; });
  1608. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setElementHeight", function() { return setElementHeight; });
  1609. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setFixedHeight", function() { return setFixedHeight; });
  1610. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "formatSize", function() { return formatSize; });
  1611. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isNode", function() { return isNode; });
  1612. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isElement", function() { return isElement; });
  1613. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isNodeOrElement", function() { return isNodeOrElement; });
  1614. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "copyNodeList", function() { return copyNodeList; });
  1615. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "iterateNamedNodeMap", function() { return iterateNamedNodeMap; });
  1616. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setCheckboxState", function() { return setCheckboxState; });
  1617. /* harmony import */ var _browser__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(13);
  1618. /* harmony import */ var _generic__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(14);
  1619. /* harmony import */ var _string__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(15);
  1620. /**
  1621. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  1622. * @version v23.2.1
  1623. * @link http://www.ag-grid.com/
  1624. * @license MIT
  1625. */
  1626. function addCssClass(element, className) {
  1627. if (!className || className.length === 0) {
  1628. return;
  1629. }
  1630. if (className.indexOf(' ') >= 0) {
  1631. className.split(' ').forEach(function (value) { return addCssClass(element, value); });
  1632. return;
  1633. }
  1634. if (element.classList) {
  1635. element.classList.add(className);
  1636. }
  1637. else if (element.className && element.className.length > 0) {
  1638. var cssClasses = element.className.split(' ');
  1639. if (cssClasses.indexOf(className) < 0) {
  1640. cssClasses.push(className);
  1641. element.setAttribute('class', cssClasses.join(' '));
  1642. }
  1643. }
  1644. else {
  1645. // do not use element.classList = className here, it will cause
  1646. // a read-only assignment error on some browsers (IE/Edge).
  1647. element.setAttribute('class', className);
  1648. }
  1649. return element;
  1650. }
  1651. function removeCssClass(element, className) {
  1652. if (element.classList) {
  1653. element.classList.remove(className);
  1654. }
  1655. else if (element.className && element.className.length > 0) {
  1656. var newClassName = element.className.split(' ').filter(function (c) { return c !== className; }).join(' ');
  1657. element.setAttribute('class', newClassName);
  1658. }
  1659. }
  1660. function addOrRemoveCssClass(element, className, addOrRemove) {
  1661. if (addOrRemove) {
  1662. addCssClass(element, className);
  1663. }
  1664. else {
  1665. removeCssClass(element, className);
  1666. }
  1667. }
  1668. /**
  1669. * This method adds a class to an element and remove that class from all siblings.
  1670. * Useful for toggling state.
  1671. * @param {HTMLElement} element The element to receive the class
  1672. * @param {string} elementClass The class to be assigned to the element
  1673. * @param {boolean} otherElementClass The class to be assigned to siblings of the element, but not the element itself
  1674. */
  1675. function radioCssClass(element, elementClass, otherElementClass) {
  1676. var parent = element.parentElement;
  1677. var sibling = parent.firstChild;
  1678. while (sibling) {
  1679. if (elementClass) {
  1680. addOrRemoveCssClass(sibling, elementClass, sibling === element);
  1681. }
  1682. if (otherElementClass) {
  1683. addOrRemoveCssClass(sibling, otherElementClass, sibling !== element);
  1684. }
  1685. sibling = sibling.nextSibling;
  1686. }
  1687. }
  1688. function containsClass(element, className) {
  1689. if (element.classList) {
  1690. // for modern browsers
  1691. return element.classList.contains(className);
  1692. }
  1693. if (element.className) {
  1694. // for older browsers, check against the string of class names
  1695. // if only one class, can check for exact match
  1696. var onlyClass = element.className === className;
  1697. // if many classes, check for class name, we have to pad with ' ' to stop other
  1698. // class names that are a substring of this class
  1699. var contains = element.className.indexOf(' ' + className + ' ') >= 0;
  1700. // the padding above then breaks when it's the first or last class names
  1701. var startsWithClass = element.className.indexOf(className + ' ') === 0;
  1702. var endsWithClass = element.className.lastIndexOf(' ' + className) === (element.className.length - className.length - 1);
  1703. return onlyClass || contains || startsWithClass || endsWithClass;
  1704. }
  1705. // if item is not a node
  1706. return false;
  1707. }
  1708. function setDisplayed(element, displayed) {
  1709. addOrRemoveCssClass(element, 'ag-hidden', !displayed);
  1710. }
  1711. function setVisible(element, visible) {
  1712. addOrRemoveCssClass(element, 'ag-invisible', !visible);
  1713. }
  1714. function setDisabled(element, disabled) {
  1715. var attributeName = 'disabled';
  1716. if (disabled) {
  1717. element.setAttribute(attributeName, '');
  1718. }
  1719. else {
  1720. element.removeAttribute(attributeName);
  1721. }
  1722. }
  1723. function isElementChildOfClass(element, cls, maxNest) {
  1724. var counter = 0;
  1725. while (element) {
  1726. if (containsClass(element, cls)) {
  1727. return true;
  1728. }
  1729. element = element.parentElement;
  1730. if (maxNest && ++counter > maxNest) {
  1731. break;
  1732. }
  1733. }
  1734. return false;
  1735. }
  1736. function getElementSize(el) {
  1737. var _a = window.getComputedStyle(el), height = _a.height, width = _a.width, paddingTop = _a.paddingTop, paddingRight = _a.paddingRight, paddingBottom = _a.paddingBottom, paddingLeft = _a.paddingLeft, marginTop = _a.marginTop, marginRight = _a.marginRight, marginBottom = _a.marginBottom, marginLeft = _a.marginLeft, boxSizing = _a.boxSizing;
  1738. return {
  1739. height: parseFloat(height),
  1740. width: parseFloat(width),
  1741. paddingTop: parseFloat(paddingTop),
  1742. paddingRight: parseFloat(paddingRight),
  1743. paddingBottom: parseFloat(paddingBottom),
  1744. paddingLeft: parseFloat(paddingLeft),
  1745. marginTop: parseFloat(marginTop),
  1746. marginRight: parseFloat(marginRight),
  1747. marginBottom: parseFloat(marginBottom),
  1748. marginLeft: parseFloat(marginLeft),
  1749. boxSizing: boxSizing
  1750. };
  1751. }
  1752. function getInnerHeight(el) {
  1753. var size = getElementSize(el);
  1754. if (size.boxSizing === 'border-box') {
  1755. return size.height - size.paddingTop - size.paddingBottom;
  1756. }
  1757. return size.height;
  1758. }
  1759. function getInnerWidth(el) {
  1760. var size = getElementSize(el);
  1761. if (size.boxSizing === 'border-box') {
  1762. return size.width - size.paddingLeft - size.paddingRight;
  1763. }
  1764. return size.width;
  1765. }
  1766. function getAbsoluteHeight(el) {
  1767. var size = getElementSize(el);
  1768. var marginRight = size.marginBottom + size.marginTop;
  1769. return Math.ceil(el.offsetHeight + marginRight);
  1770. }
  1771. function getAbsoluteWidth(el) {
  1772. var size = getElementSize(el);
  1773. var marginWidth = size.marginLeft + size.marginRight;
  1774. return Math.ceil(el.offsetWidth + marginWidth);
  1775. }
  1776. function getScrollLeft(element, rtl) {
  1777. var scrollLeft = element.scrollLeft;
  1778. if (rtl) {
  1779. // Absolute value - for FF that reports RTL scrolls in negative numbers
  1780. scrollLeft = Math.abs(scrollLeft);
  1781. // Get Chrome to return the same value as well
  1782. if (Object(_browser__WEBPACK_IMPORTED_MODULE_0__["isBrowserChrome"])()) {
  1783. scrollLeft = element.scrollWidth - element.clientWidth - scrollLeft;
  1784. }
  1785. }
  1786. return scrollLeft;
  1787. }
  1788. function setScrollLeft(element, value, rtl) {
  1789. if (rtl) {
  1790. // Chrome and Safari when doing RTL have the END position of the scroll as zero, not the start
  1791. if (Object(_browser__WEBPACK_IMPORTED_MODULE_0__["isBrowserSafari"])() || Object(_browser__WEBPACK_IMPORTED_MODULE_0__["isBrowserChrome"])()) {
  1792. value = element.scrollWidth - element.clientWidth - value;
  1793. }
  1794. // Firefox uses negative numbers when doing RTL scrolling
  1795. if (Object(_browser__WEBPACK_IMPORTED_MODULE_0__["isBrowserFirefox"])()) {
  1796. value *= -1;
  1797. }
  1798. }
  1799. element.scrollLeft = value;
  1800. }
  1801. function clearElement(el) {
  1802. while (el && el.firstChild) {
  1803. el.removeChild(el.firstChild);
  1804. }
  1805. }
  1806. /** @deprecated */
  1807. function removeElement(parent, cssSelector) {
  1808. removeFromParent(parent.querySelector(cssSelector));
  1809. }
  1810. function removeFromParent(node) {
  1811. if (node && node.parentNode) {
  1812. node.parentNode.removeChild(node);
  1813. }
  1814. }
  1815. function isVisible(element) {
  1816. return element.offsetParent !== null;
  1817. }
  1818. /**
  1819. * Loads the template and returns it as an element. makes up for no simple way in
  1820. * the dom api to load html directly, eg we cannot do this: document.createElement(template)
  1821. * @param {string} template
  1822. * @returns {HTMLElement}
  1823. */
  1824. function loadTemplate(template) {
  1825. var tempDiv = document.createElement('div');
  1826. tempDiv.innerHTML = (template || '').trim();
  1827. return tempDiv.firstChild;
  1828. }
  1829. function appendHtml(eContainer, htmlTemplate) {
  1830. if (eContainer.lastChild) {
  1831. // https://developer.mozilla.org/en-US/docs/Web/API/Element/insertAdjacentHTML
  1832. // we put the items at the start, so new items appear underneath old items,
  1833. // so when expanding/collapsing groups, the new rows don't go on top of the
  1834. // rows below that are moving our of the way
  1835. eContainer.insertAdjacentHTML('afterbegin', htmlTemplate);
  1836. }
  1837. else {
  1838. eContainer.innerHTML = htmlTemplate;
  1839. }
  1840. }
  1841. /** @deprecated */
  1842. function getElementAttribute(element, attributeName) {
  1843. if (element.attributes && element.attributes[attributeName]) {
  1844. var attribute = element.attributes[attributeName];
  1845. return attribute.value;
  1846. }
  1847. return null;
  1848. }
  1849. function offsetHeight(element) {
  1850. return element && element.clientHeight ? element.clientHeight : 0;
  1851. }
  1852. function offsetWidth(element) {
  1853. return element && element.clientWidth ? element.clientWidth : 0;
  1854. }
  1855. function ensureDomOrder(eContainer, eChild, eChildBefore) {
  1856. // if already in right order, do nothing
  1857. if (eChildBefore && eChildBefore.nextSibling === eChild) {
  1858. return;
  1859. }
  1860. if (eChildBefore) {
  1861. if (eChildBefore.nextSibling) {
  1862. // insert between the eRowBefore and the row after it
  1863. eContainer.insertBefore(eChild, eChildBefore.nextSibling);
  1864. }
  1865. else {
  1866. // if nextSibling is missing, means other row is at end, so just append new row at the end
  1867. eContainer.appendChild(eChild);
  1868. }
  1869. }
  1870. else {
  1871. // otherwise put at start
  1872. if (eContainer.firstChild && eContainer.firstChild !== eChild) {
  1873. // insert it at the first location
  1874. eContainer.insertAdjacentElement('afterbegin', eChild);
  1875. }
  1876. }
  1877. }
  1878. function setDomChildOrder(eContainer, orderedChildren) {
  1879. for (var i = 0; i < orderedChildren.length; i++) {
  1880. var correctCellAtIndex = orderedChildren[i];
  1881. var actualCellAtIndex = eContainer.children[i];
  1882. if (actualCellAtIndex !== correctCellAtIndex) {
  1883. eContainer.insertBefore(correctCellAtIndex, actualCellAtIndex);
  1884. }
  1885. }
  1886. }
  1887. function insertTemplateWithDomOrder(eContainer, htmlTemplate, eChildBefore) {
  1888. var res;
  1889. if (eChildBefore) {
  1890. // if previous element exists, just slot in after the previous element
  1891. eChildBefore.insertAdjacentHTML('afterend', htmlTemplate);
  1892. res = eChildBefore.nextSibling;
  1893. }
  1894. else {
  1895. if (eContainer.firstChild) {
  1896. // insert it at the first location
  1897. eContainer.insertAdjacentHTML('afterbegin', htmlTemplate);
  1898. }
  1899. else {
  1900. // otherwise eContainer is empty, so just append it
  1901. eContainer.innerHTML = htmlTemplate;
  1902. }
  1903. res = eContainer.firstChild;
  1904. }
  1905. return res;
  1906. }
  1907. /** @deprecated */
  1908. function prependDC(parent, documentFragment) {
  1909. if (Object(_generic__WEBPACK_IMPORTED_MODULE_1__["exists"])(parent.firstChild)) {
  1910. parent.insertBefore(documentFragment, parent.firstChild);
  1911. }
  1912. else {
  1913. parent.appendChild(documentFragment);
  1914. }
  1915. }
  1916. function addStylesToElement(eElement, styles) {
  1917. if (!styles) {
  1918. return;
  1919. }
  1920. Object.keys(styles).forEach(function (key) {
  1921. var keyCamelCase = Object(_string__WEBPACK_IMPORTED_MODULE_2__["hyphenToCamelCase"])(key);
  1922. if (keyCamelCase) {
  1923. eElement.style[keyCamelCase] = styles[key];
  1924. }
  1925. });
  1926. }
  1927. function isHorizontalScrollShowing(element) {
  1928. return element.clientWidth < element.scrollWidth;
  1929. }
  1930. function isVerticalScrollShowing(element) {
  1931. return element.clientHeight < element.scrollHeight;
  1932. }
  1933. function setElementWidth(element, width) {
  1934. if (width === 'flex') {
  1935. element.style.width = null;
  1936. element.style.minWidth = null;
  1937. element.style.maxWidth = null;
  1938. element.style.flex = '1 1 auto';
  1939. }
  1940. else {
  1941. setFixedWidth(element, width);
  1942. }
  1943. }
  1944. function setFixedWidth(element, width) {
  1945. width = formatSize(width);
  1946. element.style.width = width.toString();
  1947. element.style.maxWidth = width.toString();
  1948. element.style.minWidth = width.toString();
  1949. }
  1950. function setElementHeight(element, height) {
  1951. if (height === 'flex') {
  1952. element.style.height = null;
  1953. element.style.minHeight = null;
  1954. element.style.maxHeight = null;
  1955. element.style.flex = '1 1 auto';
  1956. }
  1957. else {
  1958. setFixedHeight(element, height);
  1959. }
  1960. }
  1961. function setFixedHeight(element, height) {
  1962. height = formatSize(height);
  1963. element.style.height = height.toString();
  1964. element.style.maxHeight = height.toString();
  1965. element.style.minHeight = height.toString();
  1966. }
  1967. function formatSize(size) {
  1968. if (typeof size === 'number') {
  1969. return size + "px";
  1970. }
  1971. return size;
  1972. }
  1973. /**
  1974. * Returns true if it is a DOM node
  1975. * taken from: http://stackoverflow.com/questions/384286/javascript-isdom-how-do-you-check-if-a-javascript-object-is-a-dom-object
  1976. * @param {any} o
  1977. * @return {boolean}
  1978. */
  1979. function isNode(o) {
  1980. return (typeof Node === 'function'
  1981. ? o instanceof Node
  1982. : o && typeof o === 'object' && typeof o.nodeType === 'number' && typeof o.nodeName === 'string');
  1983. }
  1984. //
  1985. /**
  1986. * Returns true if it is a DOM element
  1987. * taken from: http://stackoverflow.com/questions/384286/javascript-isdom-how-do-you-check-if-a-javascript-object-is-a-dom-object
  1988. * @param {any} o
  1989. * @returns {boolean}
  1990. */
  1991. function isElement(o) {
  1992. return (typeof HTMLElement === 'function'
  1993. ? o instanceof HTMLElement //DOM2
  1994. : o && typeof o === 'object' && o !== null && o.nodeType === 1 && typeof o.nodeName === 'string');
  1995. }
  1996. function isNodeOrElement(o) {
  1997. return isNode(o) || isElement(o);
  1998. }
  1999. /**
  2000. * Makes a copy of a node list into a list
  2001. * @param {NodeList} nodeList
  2002. * @returns {Node[]}
  2003. */
  2004. function copyNodeList(nodeList) {
  2005. var childCount = nodeList ? nodeList.length : 0;
  2006. var res = [];
  2007. for (var i = 0; i < childCount; i++) {
  2008. res.push(nodeList[i]);
  2009. }
  2010. return res;
  2011. }
  2012. function iterateNamedNodeMap(map, callback) {
  2013. if (!map) {
  2014. return;
  2015. }
  2016. for (var i = 0; i < map.length; i++) {
  2017. var attr = map[i];
  2018. callback(attr.name, attr.value);
  2019. }
  2020. }
  2021. /** @deprecated */
  2022. function setCheckboxState(eCheckbox, state) {
  2023. if (typeof state === 'boolean') {
  2024. eCheckbox.checked = state;
  2025. eCheckbox.indeterminate = false;
  2026. }
  2027. else {
  2028. // isNodeSelected returns back undefined if it's a group and the children
  2029. // are a mix of selected and unselected
  2030. eCheckbox.indeterminate = true;
  2031. }
  2032. }
  2033. /***/ }),
  2034. /* 13 */
  2035. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  2036. "use strict";
  2037. __webpack_require__.r(__webpack_exports__);
  2038. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isBrowserIE", function() { return isBrowserIE; });
  2039. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isBrowserEdge", function() { return isBrowserEdge; });
  2040. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isBrowserSafari", function() { return isBrowserSafari; });
  2041. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isBrowserChrome", function() { return isBrowserChrome; });
  2042. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isBrowserFirefox", function() { return isBrowserFirefox; });
  2043. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isIOSUserAgent", function() { return isIOSUserAgent; });
  2044. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getTabIndex", function() { return getTabIndex; });
  2045. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getMaxDivHeight", function() { return getMaxDivHeight; });
  2046. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getScrollbarWidth", function() { return getScrollbarWidth; });
  2047. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "hasOverflowScrolling", function() { return hasOverflowScrolling; });
  2048. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getBodyWidth", function() { return getBodyWidth; });
  2049. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getBodyHeight", function() { return getBodyHeight; });
  2050. /**
  2051. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  2052. * @version v23.2.1
  2053. * @link http://www.ag-grid.com/
  2054. * @license MIT
  2055. */
  2056. /**
  2057. * These variables are lazy loaded, as otherwise they try and get initialised when we are loading
  2058. * unit tests and we don't have references to window or document in the unit tests
  2059. * from http://stackoverflow.com/questions/9847580/how-to-detect-safari-chrome-ie-firefox-and-opera-browser
  2060. */
  2061. var isSafari;
  2062. var isIE;
  2063. var isEdge;
  2064. var isChrome;
  2065. var isFirefox;
  2066. var isIOS;
  2067. function isBrowserIE() {
  2068. if (isIE === undefined) {
  2069. isIE = /*@cc_on!@*/ false || !!document.documentMode; // At least IE6
  2070. }
  2071. return isIE;
  2072. }
  2073. function isBrowserEdge() {
  2074. if (isEdge === undefined) {
  2075. isEdge = !isBrowserIE() && !!window.StyleMedia;
  2076. }
  2077. return isEdge;
  2078. }
  2079. function isBrowserSafari() {
  2080. if (isSafari === undefined) {
  2081. // taken from https://github.com/ag-grid/ag-grid/issues/550
  2082. var anyWindow = window;
  2083. var hasNotification = function (p) { return p && p.toString() === '[object SafariRemoteNotification]'; };
  2084. isSafari = Object.prototype.toString.call(anyWindow.HTMLElement).indexOf('Constructor') > 0
  2085. || hasNotification(anyWindow.safari && anyWindow.safari.pushNotification);
  2086. }
  2087. return isSafari;
  2088. }
  2089. function isBrowserChrome() {
  2090. if (isChrome === undefined) {
  2091. var win = window;
  2092. isChrome = (!!win.chrome && (!!win.chrome.webstore || !!win.chrome.runtime)) ||
  2093. (/Chrome/.test(navigator.userAgent) && /Google Inc/.test(navigator.vendor));
  2094. }
  2095. return isChrome;
  2096. }
  2097. function isBrowserFirefox() {
  2098. if (isFirefox === undefined) {
  2099. var win = window;
  2100. isFirefox = typeof win.InstallTrigger !== 'undefined';
  2101. }
  2102. return isFirefox;
  2103. }
  2104. function isIOSUserAgent() {
  2105. if (isIOS === undefined) {
  2106. // taken from https://stackoverflow.com/a/58064481/1388233
  2107. isIOS = (/iPad|iPhone|iPod/.test(navigator.platform) ||
  2108. // eslint-disable-next-line
  2109. (navigator.platform === 'MacIntel' && navigator.maxTouchPoints > 1)) &&
  2110. !window.MSStream;
  2111. }
  2112. return isIOS;
  2113. }
  2114. function getTabIndex(el) {
  2115. if (!el) {
  2116. return null;
  2117. }
  2118. var numberTabIndex = el.tabIndex;
  2119. var tabIndex = el.getAttribute('tabIndex');
  2120. if (isBrowserIE() && numberTabIndex === 0 && el.getAttribute('tabIndex') === null) {
  2121. var map = {
  2122. a: true,
  2123. body: true,
  2124. button: true,
  2125. frame: true,
  2126. iframe: true,
  2127. img: true,
  2128. input: true,
  2129. isindex: true,
  2130. object: true,
  2131. select: true,
  2132. textarea: true
  2133. };
  2134. return map[el.nodeName.toLowerCase()] === true ? '0' : null;
  2135. }
  2136. if (numberTabIndex === -1 && (tabIndex === null || (tabIndex === '' && !isBrowserFirefox()))) {
  2137. return null;
  2138. }
  2139. return numberTabIndex.toString();
  2140. }
  2141. function getMaxDivHeight() {
  2142. if (!document.body) {
  2143. return -1;
  2144. }
  2145. var res = 1000000;
  2146. // FF reports the height back but still renders blank after ~6M px
  2147. var testUpTo = navigator.userAgent.toLowerCase().match(/firefox/) ? 6000000 : 1000000000;
  2148. var div = document.createElement('div');
  2149. document.body.appendChild(div);
  2150. while (true) {
  2151. var test_1 = res * 2;
  2152. div.style.height = test_1 + 'px';
  2153. if (test_1 > testUpTo || div.clientHeight !== test_1) {
  2154. break;
  2155. }
  2156. else {
  2157. res = test_1;
  2158. }
  2159. }
  2160. document.body.removeChild(div);
  2161. return res;
  2162. }
  2163. function getScrollbarWidth() {
  2164. var body = document.body;
  2165. var div = document.createElement('div');
  2166. div.style.width = div.style.height = '100px';
  2167. div.style.opacity = '0';
  2168. div.style.overflow = 'scroll';
  2169. div.style.msOverflowStyle = 'scrollbar'; // needed for WinJS apps
  2170. div.style.position = 'absolute';
  2171. body.appendChild(div);
  2172. var width = div.offsetWidth - div.clientWidth;
  2173. // remove divs
  2174. if (div.parentNode) {
  2175. div.parentNode.removeChild(div);
  2176. }
  2177. return width;
  2178. }
  2179. /** @deprecated */
  2180. function hasOverflowScrolling() {
  2181. var prefixes = ['webkit', 'moz', 'o', 'ms'];
  2182. var div = document.createElement('div');
  2183. var body = document.getElementsByTagName('body')[0];
  2184. var found = false;
  2185. var p;
  2186. body.appendChild(div);
  2187. div.setAttribute('style', prefixes.map(function (prefix) { return "-" + prefix + "-overflow-scrolling: touch"; }).concat('overflow-scrolling: touch').join(';'));
  2188. var computedStyle = window.getComputedStyle(div);
  2189. if (computedStyle.overflowScrolling === 'touch') {
  2190. found = true;
  2191. }
  2192. if (!found) {
  2193. for (var _i = 0, prefixes_1 = prefixes; _i < prefixes_1.length; _i++) {
  2194. p = prefixes_1[_i];
  2195. if (computedStyle[p + "OverflowScrolling"] === 'touch') {
  2196. found = true;
  2197. break;
  2198. }
  2199. }
  2200. }
  2201. if (div.parentNode) {
  2202. div.parentNode.removeChild(div);
  2203. }
  2204. return found;
  2205. }
  2206. /**
  2207. * Gets the document body width
  2208. * from: http://stackoverflow.com/questions/1038727/how-to-get-browser-width-using-javascript-code
  2209. * @returns {number}
  2210. */
  2211. function getBodyWidth() {
  2212. if (document.body) {
  2213. return document.body.clientWidth;
  2214. }
  2215. if (window.innerHeight) {
  2216. return window.innerWidth;
  2217. }
  2218. if (document.documentElement && document.documentElement.clientWidth) {
  2219. return document.documentElement.clientWidth;
  2220. }
  2221. return -1;
  2222. }
  2223. /**
  2224. * Gets the body height
  2225. * from: http://stackoverflow.com/questions/1038727/how-to-get-browser-width-using-javascript-code
  2226. * @returns {number}
  2227. */
  2228. function getBodyHeight() {
  2229. if (document.body) {
  2230. return document.body.clientHeight;
  2231. }
  2232. if (window.innerHeight) {
  2233. return window.innerHeight;
  2234. }
  2235. if (document.documentElement && document.documentElement.clientHeight) {
  2236. return document.documentElement.clientHeight;
  2237. }
  2238. return -1;
  2239. }
  2240. /***/ }),
  2241. /* 14 */
  2242. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  2243. "use strict";
  2244. __webpack_require__.r(__webpack_exports__);
  2245. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "makeNull", function() { return makeNull; });
  2246. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "exists", function() { return exists; });
  2247. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "missing", function() { return missing; });
  2248. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "missingOrEmpty", function() { return missingOrEmpty; });
  2249. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "toStringOrNull", function() { return toStringOrNull; });
  2250. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "referenceCompare", function() { return referenceCompare; });
  2251. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "jsonEquals", function() { return jsonEquals; });
  2252. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "defaultComparator", function() { return defaultComparator; });
  2253. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "find", function() { return find; });
  2254. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "values", function() { return values; });
  2255. /**
  2256. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  2257. * @version v23.2.1
  2258. * @link http://www.ag-grid.com/
  2259. * @license MIT
  2260. */
  2261. /**
  2262. * If value is undefined, null or blank, returns null, otherwise returns the value
  2263. * @param {T} value
  2264. * @returns {T | null}
  2265. */
  2266. function makeNull(value) {
  2267. return value == null || value === '' ? null : value;
  2268. }
  2269. function exists(value, allowEmptyString) {
  2270. if (allowEmptyString === void 0) { allowEmptyString = false; }
  2271. return value != null && (allowEmptyString || value !== '');
  2272. }
  2273. function missing(value) {
  2274. return !exists(value);
  2275. }
  2276. function missingOrEmpty(value) {
  2277. return !value || missing(value) || value.length === 0;
  2278. }
  2279. function toStringOrNull(value) {
  2280. return exists(value) && value.toString ? value.toString() : null;
  2281. }
  2282. /** @deprecated */
  2283. function referenceCompare(left, right) {
  2284. if (left == null && right == null) {
  2285. return true;
  2286. }
  2287. if (left == null && right != null) {
  2288. return false;
  2289. }
  2290. if (left != null && right == null) {
  2291. return false;
  2292. }
  2293. return left === right;
  2294. }
  2295. function jsonEquals(val1, val2) {
  2296. var val1Json = val1 ? JSON.stringify(val1) : null;
  2297. var val2Json = val2 ? JSON.stringify(val2) : null;
  2298. return val1Json === val2Json;
  2299. }
  2300. function defaultComparator(valueA, valueB, accentedCompare) {
  2301. if (accentedCompare === void 0) { accentedCompare = false; }
  2302. var valueAMissing = valueA == null;
  2303. var valueBMissing = valueB == null;
  2304. // this is for aggregations sum and avg, where the result can be a number that is wrapped.
  2305. // if we didn't do this, then the toString() value would be used, which would result in
  2306. // the strings getting used instead of the numbers.
  2307. if (valueA && valueA.toNumber) {
  2308. valueA = valueA.toNumber();
  2309. }
  2310. if (valueB && valueB.toNumber) {
  2311. valueB = valueB.toNumber();
  2312. }
  2313. if (valueAMissing && valueBMissing) {
  2314. return 0;
  2315. }
  2316. if (valueAMissing) {
  2317. return -1;
  2318. }
  2319. if (valueBMissing) {
  2320. return 1;
  2321. }
  2322. function doQuickCompare(a, b) {
  2323. return (a > b ? 1 : (a < b ? -1 : 0));
  2324. }
  2325. if (typeof valueA === 'string') {
  2326. if (!accentedCompare) {
  2327. return doQuickCompare(valueA, valueB);
  2328. }
  2329. try {
  2330. // using local compare also allows chinese comparisons
  2331. return valueA.localeCompare(valueB);
  2332. }
  2333. catch (e) {
  2334. // if something wrong with localeCompare, eg not supported
  2335. // by browser, then just continue with the quick one
  2336. return doQuickCompare(valueA, valueB);
  2337. }
  2338. }
  2339. return doQuickCompare(valueA, valueB);
  2340. }
  2341. function find(collection, predicate, value) {
  2342. if (collection === null || collection === undefined) {
  2343. return null;
  2344. }
  2345. if (!Array.isArray(collection)) {
  2346. var objToArray = values(collection);
  2347. return find(objToArray, predicate, value);
  2348. }
  2349. var collectionAsArray = collection;
  2350. var firstMatchingItem = null;
  2351. for (var i = 0; i < collectionAsArray.length; i++) {
  2352. var item = collectionAsArray[i];
  2353. if (typeof predicate === 'string') {
  2354. if (item[predicate] === value) {
  2355. firstMatchingItem = item;
  2356. break;
  2357. }
  2358. }
  2359. else {
  2360. var callback = predicate;
  2361. if (callback(item)) {
  2362. firstMatchingItem = item;
  2363. break;
  2364. }
  2365. }
  2366. }
  2367. return firstMatchingItem;
  2368. }
  2369. function values(object) {
  2370. if (object instanceof Set || object instanceof Map) {
  2371. var values_1 = [];
  2372. object.forEach(function (value) { return values_1.push(value); });
  2373. return values_1;
  2374. }
  2375. return Object.keys(object).map(function (key) { return object[key]; });
  2376. }
  2377. /***/ }),
  2378. /* 15 */
  2379. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  2380. "use strict";
  2381. __webpack_require__.r(__webpack_exports__);
  2382. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "utf8_encode", function() { return utf8_encode; });
  2383. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "camelCaseToHyphen", function() { return camelCaseToHyphen; });
  2384. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "hyphenToCamelCase", function() { return hyphenToCamelCase; });
  2385. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "capitalise", function() { return capitalise; });
  2386. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "escape", function() { return escape; });
  2387. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "camelCaseToHumanText", function() { return camelCaseToHumanText; });
  2388. /**
  2389. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  2390. * @version v23.2.1
  2391. * @link http://www.ag-grid.com/
  2392. * @license MIT
  2393. */
  2394. var reUnescapedHtml = /[&<>"']/g;
  2395. /**
  2396. * HTML Escapes.
  2397. */
  2398. var HTML_ESCAPES = {
  2399. '&': '&amp;',
  2400. '<': '&lt;',
  2401. '>': '&gt;',
  2402. '"': '&quot;',
  2403. "'": '&#39;'
  2404. };
  2405. /**
  2406. * It encodes any string in UTF-8 format
  2407. * taken from https://github.com/mathiasbynens/utf8.js
  2408. * @param {string} s
  2409. * @returns {string}
  2410. */
  2411. function utf8_encode(s) {
  2412. var stringFromCharCode = String.fromCharCode;
  2413. function ucs2decode(string) {
  2414. var output = [];
  2415. var counter = 0;
  2416. var length = string.length;
  2417. var value;
  2418. var extra;
  2419. while (counter < length) {
  2420. value = string.charCodeAt(counter++);
  2421. if (value >= 0xD800 && value <= 0xDBFF && counter < length) {
  2422. // high surrogate, and there is a next character
  2423. extra = string.charCodeAt(counter++);
  2424. if ((extra & 0xFC00) == 0xDC00) { // low surrogate
  2425. output.push(((value & 0x3FF) << 10) + (extra & 0x3FF) + 0x10000);
  2426. }
  2427. else {
  2428. // unmatched surrogate; only append this code unit, in case the next
  2429. // code unit is the high surrogate of a surrogate pair
  2430. output.push(value);
  2431. counter--;
  2432. }
  2433. }
  2434. else {
  2435. output.push(value);
  2436. }
  2437. }
  2438. return output;
  2439. }
  2440. function checkScalarValue(codePoint) {
  2441. if (codePoint >= 0xD800 && codePoint <= 0xDFFF) {
  2442. throw Error('Lone surrogate U+' + codePoint.toString(16).toUpperCase() +
  2443. ' is not a scalar value');
  2444. }
  2445. }
  2446. function createByte(codePoint, shift) {
  2447. return stringFromCharCode(((codePoint >> shift) & 0x3F) | 0x80);
  2448. }
  2449. function encodeCodePoint(codePoint) {
  2450. if ((codePoint & 0xFFFFFF80) == 0) { // 1-byte sequence
  2451. return stringFromCharCode(codePoint);
  2452. }
  2453. var symbol = '';
  2454. if ((codePoint & 0xFFFFF800) == 0) { // 2-byte sequence
  2455. symbol = stringFromCharCode(((codePoint >> 6) & 0x1F) | 0xC0);
  2456. }
  2457. else if ((codePoint & 0xFFFF0000) == 0) { // 3-byte sequence
  2458. checkScalarValue(codePoint);
  2459. symbol = stringFromCharCode(((codePoint >> 12) & 0x0F) | 0xE0);
  2460. symbol += createByte(codePoint, 6);
  2461. }
  2462. else if ((codePoint & 0xFFE00000) == 0) { // 4-byte sequence
  2463. symbol = stringFromCharCode(((codePoint >> 18) & 0x07) | 0xF0);
  2464. symbol += createByte(codePoint, 12);
  2465. symbol += createByte(codePoint, 6);
  2466. }
  2467. symbol += stringFromCharCode((codePoint & 0x3F) | 0x80);
  2468. return symbol;
  2469. }
  2470. var codePoints = ucs2decode(s);
  2471. var length = codePoints.length;
  2472. var index = -1;
  2473. var codePoint;
  2474. var byteString = '';
  2475. while (++index < length) {
  2476. codePoint = codePoints[index];
  2477. byteString += encodeCodePoint(codePoint);
  2478. }
  2479. return byteString;
  2480. }
  2481. /**
  2482. * Converts a camelCase string into hyphenated string
  2483. * from https://gist.github.com/youssman/745578062609e8acac9f
  2484. * @param {string} str
  2485. * @return {string}
  2486. */
  2487. function camelCaseToHyphen(str) {
  2488. if (str === null || str === undefined) {
  2489. return null;
  2490. }
  2491. return str.replace(/([A-Z])/g, function (g) { return '-' + g[0].toLowerCase(); });
  2492. }
  2493. /**
  2494. * Converts a hyphenated string into camelCase string
  2495. * from https://stackoverflow.com/questions/6660977/convert-hyphens-to-camel-case-camelcase
  2496. * @param {string} str
  2497. * @return {string}
  2498. */
  2499. function hyphenToCamelCase(str) {
  2500. if (str === null || str === undefined) {
  2501. return null;
  2502. }
  2503. return str.replace(/-([a-z])/g, function (g) { return g[1].toUpperCase(); });
  2504. }
  2505. function capitalise(str) {
  2506. return str[0].toUpperCase() + str.substr(1).toLowerCase();
  2507. }
  2508. function escape(toEscape) {
  2509. return toEscape == null || !toEscape.replace ? toEscape : toEscape.replace(reUnescapedHtml, function (chr) { return HTML_ESCAPES[chr]; });
  2510. }
  2511. /**
  2512. * Converts a camelCase string into regular text
  2513. * from: https://stackoverflow.com/questions/15369566/putting-space-in-camel-case-string-using-regular-expression
  2514. * @param {string} camelCase
  2515. * @return {string}
  2516. */
  2517. function camelCaseToHumanText(camelCase) {
  2518. if (!camelCase || camelCase == null) {
  2519. return null;
  2520. }
  2521. var rex = /([A-Z])([A-Z])([a-z])|([a-z])([A-Z])/g;
  2522. var words = camelCase.replace(rex, '$1$4 $2$3$5').replace('.', ' ').split(' ');
  2523. return words.map(function (word) { return word.substring(0, 1).toUpperCase() + ((word.length > 1) ? word.substring(1, word.length) : ''); }).join(' ');
  2524. }
  2525. /***/ }),
  2526. /* 16 */
  2527. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  2528. "use strict";
  2529. __webpack_require__.r(__webpack_exports__);
  2530. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "iterateObject", function() { return iterateObject; });
  2531. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cloneObject", function() { return cloneObject; });
  2532. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "deepCloneObject", function() { return deepCloneObject; });
  2533. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getProperty", function() { return getProperty; });
  2534. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "setProperty", function() { return setProperty; });
  2535. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "copyPropertiesIfPresent", function() { return copyPropertiesIfPresent; });
  2536. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "copyPropertyIfPresent", function() { return copyPropertyIfPresent; });
  2537. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getAllKeysInObjects", function() { return getAllKeysInObjects; });
  2538. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "mergeDeep", function() { return mergeDeep; });
  2539. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "assign", function() { return assign; });
  2540. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "missingOrEmptyObject", function() { return missingOrEmptyObject; });
  2541. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "get", function() { return get; });
  2542. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "set", function() { return set; });
  2543. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "deepFreeze", function() { return deepFreeze; });
  2544. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getValueUsingField", function() { return getValueUsingField; });
  2545. /* harmony import */ var _generic__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(14);
  2546. /* harmony import */ var _array__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(17);
  2547. /**
  2548. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  2549. * @version v23.2.1
  2550. * @link http://www.ag-grid.com/
  2551. * @license MIT
  2552. */
  2553. function iterateObject(object, callback) {
  2554. if (object == null) {
  2555. return;
  2556. }
  2557. if (Array.isArray(object)) {
  2558. Object(_array__WEBPACK_IMPORTED_MODULE_1__["forEach"])(object, function (value, index) { return callback("" + index, value); });
  2559. }
  2560. else {
  2561. Object(_array__WEBPACK_IMPORTED_MODULE_1__["forEach"])(Object.keys(object), function (key) { return callback(key, object[key]); });
  2562. }
  2563. }
  2564. function cloneObject(object) {
  2565. var copy = {};
  2566. var keys = Object.keys(object);
  2567. for (var i = 0; i < keys.length; i++) {
  2568. var key = keys[i];
  2569. var value = object[key];
  2570. copy[key] = value;
  2571. }
  2572. return copy;
  2573. }
  2574. function deepCloneObject(object) {
  2575. return JSON.parse(JSON.stringify(object));
  2576. }
  2577. function getProperty(object, key) {
  2578. return object[key];
  2579. }
  2580. function setProperty(object, key, value) {
  2581. object[key] = value;
  2582. }
  2583. /**
  2584. * Will copy the specified properties from `source` into the equivalent properties on `target`, ignoring properties with
  2585. * a value of `undefined`.
  2586. */
  2587. function copyPropertiesIfPresent(source, target) {
  2588. var properties = [];
  2589. for (var _i = 2; _i < arguments.length; _i++) {
  2590. properties[_i - 2] = arguments[_i];
  2591. }
  2592. Object(_array__WEBPACK_IMPORTED_MODULE_1__["forEach"])(properties, function (p) { return copyPropertyIfPresent(source, target, p); });
  2593. }
  2594. /**
  2595. * Will copy the specified property from `source` into the equivalent property on `target`, unless the property has a
  2596. * value of `undefined`. If a transformation is provided, it will be applied to the value before being set on `target`.
  2597. */
  2598. function copyPropertyIfPresent(source, target, property, transform) {
  2599. var value = getProperty(source, property);
  2600. if (value !== undefined) {
  2601. setProperty(target, property, transform ? transform(value) : value);
  2602. }
  2603. }
  2604. function getAllKeysInObjects(objects) {
  2605. var allValues = {};
  2606. objects.filter(function (obj) { return obj != null; }).forEach(function (obj) {
  2607. Object(_array__WEBPACK_IMPORTED_MODULE_1__["forEach"])(Object.keys(obj), function (key) { return allValues[key] = null; });
  2608. });
  2609. return Object.keys(allValues);
  2610. }
  2611. function mergeDeep(dest, source, copyUndefined) {
  2612. if (copyUndefined === void 0) { copyUndefined = true; }
  2613. if (!Object(_generic__WEBPACK_IMPORTED_MODULE_0__["exists"])(source)) {
  2614. return;
  2615. }
  2616. iterateObject(source, function (key, newValue) {
  2617. var oldValue = dest[key];
  2618. if (oldValue === newValue) {
  2619. return;
  2620. }
  2621. if (typeof oldValue === 'object' && typeof newValue === 'object' && !Array.isArray(oldValue)) {
  2622. mergeDeep(oldValue, newValue);
  2623. }
  2624. else if (copyUndefined || newValue !== undefined) {
  2625. dest[key] = newValue;
  2626. }
  2627. });
  2628. }
  2629. function assign(object) {
  2630. var sources = [];
  2631. for (var _i = 1; _i < arguments.length; _i++) {
  2632. sources[_i - 1] = arguments[_i];
  2633. }
  2634. Object(_array__WEBPACK_IMPORTED_MODULE_1__["forEach"])(sources, function (source) { return iterateObject(source, function (key, value) { return object[key] = value; }); });
  2635. return object;
  2636. }
  2637. function missingOrEmptyObject(value) {
  2638. return Object(_generic__WEBPACK_IMPORTED_MODULE_0__["missing"])(value) || Object.keys(value).length === 0;
  2639. }
  2640. function get(source, expression, defaultValue) {
  2641. if (source == null) {
  2642. return defaultValue;
  2643. }
  2644. var keys = expression.split('.');
  2645. var objectToRead = source;
  2646. while (keys.length > 1) {
  2647. objectToRead = objectToRead[keys.shift()];
  2648. if (objectToRead == null) {
  2649. return defaultValue;
  2650. }
  2651. }
  2652. var value = objectToRead[keys[0]];
  2653. return value != null ? value : defaultValue;
  2654. }
  2655. function set(target, expression, value) {
  2656. if (target == null) {
  2657. return;
  2658. }
  2659. var keys = expression.split('.');
  2660. var objectToUpdate = target;
  2661. while (keys.length > 1) {
  2662. objectToUpdate = objectToUpdate[keys.shift()];
  2663. if (objectToUpdate == null) {
  2664. return;
  2665. }
  2666. }
  2667. objectToUpdate[keys[0]] = value;
  2668. }
  2669. function deepFreeze(object) {
  2670. Object.freeze(object);
  2671. Object(_array__WEBPACK_IMPORTED_MODULE_1__["forEach"])(Object(_generic__WEBPACK_IMPORTED_MODULE_0__["values"])(object), function (v) {
  2672. if (v != null && (typeof v === 'object' || typeof v === 'function')) {
  2673. deepFreeze(v);
  2674. }
  2675. });
  2676. return object;
  2677. }
  2678. function getValueUsingField(data, field, fieldContainsDots) {
  2679. if (!field || !data) {
  2680. return;
  2681. }
  2682. // if no '.', then it's not a deep value
  2683. if (!fieldContainsDots) {
  2684. return data[field];
  2685. }
  2686. // otherwise it is a deep value, so need to dig for it
  2687. var fields = field.split('.');
  2688. var currentObject = data;
  2689. for (var i = 0; i < fields.length; i++) {
  2690. currentObject = currentObject[fields[i]];
  2691. if (Object(_generic__WEBPACK_IMPORTED_MODULE_0__["missing"])(currentObject)) {
  2692. return null;
  2693. }
  2694. }
  2695. return currentObject;
  2696. }
  2697. /***/ }),
  2698. /* 17 */
  2699. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  2700. "use strict";
  2701. __webpack_require__.r(__webpack_exports__);
  2702. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "firstExistingValue", function() { return firstExistingValue; });
  2703. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "anyExists", function() { return anyExists; });
  2704. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "existsAndNotEmpty", function() { return existsAndNotEmpty; });
  2705. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "last", function() { return last; });
  2706. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "areEqual", function() { return areEqual; });
  2707. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "compareArrays", function() { return compareArrays; });
  2708. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "shallowCompare", function() { return shallowCompare; });
  2709. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "sortNumerically", function() { return sortNumerically; });
  2710. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "removeRepeatsFromArray", function() { return removeRepeatsFromArray; });
  2711. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "removeFromArray", function() { return removeFromArray; });
  2712. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "removeAllFromArray", function() { return removeAllFromArray; });
  2713. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "insertIntoArray", function() { return insertIntoArray; });
  2714. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "insertArrayIntoArray", function() { return insertArrayIntoArray; });
  2715. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "moveInArray", function() { return moveInArray; });
  2716. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "includes", function() { return includes; });
  2717. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "flatten", function() { return flatten; });
  2718. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "pushAll", function() { return pushAll; });
  2719. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "toStrings", function() { return toStrings; });
  2720. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "findIndex", function() { return findIndex; });
  2721. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "every", function() { return every; });
  2722. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "some", function() { return some; });
  2723. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "forEach", function() { return forEach; });
  2724. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "map", function() { return map; });
  2725. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "filter", function() { return filter; });
  2726. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "reduce", function() { return reduce; });
  2727. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "forEachSnapshotFirst", function() { return forEachSnapshotFirst; });
  2728. /* harmony import */ var _generic__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(14);
  2729. /**
  2730. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  2731. * @version v23.2.1
  2732. * @link http://www.ag-grid.com/
  2733. * @license MIT
  2734. */
  2735. function firstExistingValue() {
  2736. var values = [];
  2737. for (var _i = 0; _i < arguments.length; _i++) {
  2738. values[_i] = arguments[_i];
  2739. }
  2740. for (var i = 0; i < values.length; i++) {
  2741. var value = values[i];
  2742. if (Object(_generic__WEBPACK_IMPORTED_MODULE_0__["exists"])(value)) {
  2743. return value;
  2744. }
  2745. }
  2746. return null;
  2747. }
  2748. /** @deprecated */
  2749. function anyExists(values) {
  2750. return values && firstExistingValue(values) != null;
  2751. }
  2752. function existsAndNotEmpty(value) {
  2753. return value != null && value.length > 0;
  2754. }
  2755. function last(arr) {
  2756. if (!arr || !arr.length) {
  2757. return undefined;
  2758. }
  2759. return arr[arr.length - 1];
  2760. }
  2761. function areEqual(a, b, comparator) {
  2762. if (a == null && b == null) {
  2763. return true;
  2764. }
  2765. return a != null &&
  2766. b != null &&
  2767. a.length === b.length &&
  2768. every(a, function (value, index) { return comparator ? comparator(value, b[index]) : b[index] === value; });
  2769. }
  2770. /** @deprecated */
  2771. function compareArrays(array1, array2) {
  2772. return areEqual(array1, array2);
  2773. }
  2774. /** @deprecated */
  2775. function shallowCompare(arr1, arr2) {
  2776. return areEqual(arr1, arr2);
  2777. }
  2778. function sortNumerically(array) {
  2779. return array.sort(function (a, b) { return a - b; });
  2780. }
  2781. function removeRepeatsFromArray(array, object) {
  2782. if (!array) {
  2783. return;
  2784. }
  2785. for (var index = array.length - 2; index >= 0; index--) {
  2786. var thisOneMatches = array[index] === object;
  2787. var nextOneMatches = array[index + 1] === object;
  2788. if (thisOneMatches && nextOneMatches) {
  2789. array.splice(index + 1, 1);
  2790. }
  2791. }
  2792. }
  2793. function removeFromArray(array, object) {
  2794. var index = array.indexOf(object);
  2795. if (index >= 0) {
  2796. array.splice(index, 1);
  2797. }
  2798. }
  2799. function removeAllFromArray(array, toRemove) {
  2800. forEach(toRemove, function (item) { return removeFromArray(array, item); });
  2801. }
  2802. function insertIntoArray(array, object, toIndex) {
  2803. array.splice(toIndex, 0, object);
  2804. }
  2805. function insertArrayIntoArray(dest, src, toIndex) {
  2806. if (dest == null || src == null) {
  2807. return;
  2808. }
  2809. // put items in backwards, otherwise inserted items end up in reverse order
  2810. for (var i = src.length - 1; i >= 0; i--) {
  2811. var item = src[i];
  2812. insertIntoArray(dest, item, toIndex);
  2813. }
  2814. }
  2815. function moveInArray(array, objectsToMove, toIndex) {
  2816. // first take out items from the array
  2817. removeAllFromArray(array, objectsToMove);
  2818. // now add the objects, in same order as provided to us, that means we start at the end
  2819. // as the objects will be pushed to the right as they are inserted
  2820. forEach(objectsToMove.slice().reverse(), function (obj) { return insertIntoArray(array, obj, toIndex); });
  2821. }
  2822. function includes(array, value) {
  2823. return array.indexOf(value) > -1;
  2824. }
  2825. function flatten(arrayOfArrays) {
  2826. return [].concat.apply([], arrayOfArrays);
  2827. }
  2828. function pushAll(target, source) {
  2829. if (source == null || target == null) {
  2830. return;
  2831. }
  2832. forEach(source, function (value) { return target.push(value); });
  2833. }
  2834. function toStrings(array) {
  2835. return map(array, _generic__WEBPACK_IMPORTED_MODULE_0__["toStringOrNull"]);
  2836. }
  2837. function findIndex(collection, predicate) {
  2838. for (var i = 0; i < collection.length; i++) {
  2839. if (predicate(collection[i], i, collection)) {
  2840. return i;
  2841. }
  2842. }
  2843. return -1;
  2844. }
  2845. /**
  2846. * The implementation of Array.prototype.every in browsers is always slower than just using a simple for loop, so
  2847. * use this for improved performance.
  2848. * https://jsbench.me/bek91dtit8/
  2849. */
  2850. function every(list, predicate) {
  2851. if (list == null) {
  2852. return true;
  2853. }
  2854. for (var i = 0; i < list.length; i++) {
  2855. if (!predicate(list[i], i)) {
  2856. return false;
  2857. }
  2858. }
  2859. return true;
  2860. }
  2861. /**
  2862. * The implementation of Array.prototype.some in browsers is always slower than just using a simple for loop, so
  2863. * use this for improved performance.
  2864. * https://jsbench.me/5dk91e4tmt/
  2865. */
  2866. function some(list, predicate) {
  2867. if (list == null) {
  2868. return false;
  2869. }
  2870. for (var i = 0; i < list.length; i++) {
  2871. if (predicate(list[i], i)) {
  2872. return true;
  2873. }
  2874. }
  2875. return false;
  2876. }
  2877. /**
  2878. * The implementation of Array.prototype.forEach in browsers is often slower than just using a simple for loop, so
  2879. * use this for improved performance.
  2880. * https://jsbench.me/apk91elt8a/
  2881. */
  2882. function forEach(list, action) {
  2883. if (list == null) {
  2884. return;
  2885. }
  2886. for (var i = 0; i < list.length; i++) {
  2887. action(list[i], i);
  2888. }
  2889. }
  2890. /**
  2891. * The implementation of Array.prototype.map in browsers is generally the same as just using a simple for loop. However,
  2892. * Firefox does exhibit some difference, and this performs no worse in other browsers, so use this if you want improved
  2893. * performance.
  2894. * https://jsbench.me/njk91ez8pc/
  2895. */
  2896. function map(list, process) {
  2897. if (list == null) {
  2898. return null;
  2899. }
  2900. var mapped = [];
  2901. for (var i = 0; i < list.length; i++) {
  2902. mapped.push(process(list[i], i));
  2903. }
  2904. return mapped;
  2905. }
  2906. /**
  2907. * The implementation of Array.prototype.filter in browsers is always slower than just using a simple for loop, so
  2908. * use this for improved performance.
  2909. * https://jsbench.me/7bk91fk08c/
  2910. */
  2911. function filter(list, predicate) {
  2912. if (list == null) {
  2913. return null;
  2914. }
  2915. var filtered = [];
  2916. for (var i = 0; i < list.length; i++) {
  2917. if (predicate(list[i], i)) {
  2918. filtered.push(list[i]);
  2919. }
  2920. }
  2921. return filtered;
  2922. }
  2923. /**
  2924. * The implementation of Array.prototype.reduce in browsers is generally the same as just using a simple for loop. However,
  2925. * Chrome does exhibit some difference, and this performs no worse in other browsers, so use this if you want improved
  2926. * performance.
  2927. * https://jsbench.me/7vk92n6u1f/
  2928. */
  2929. function reduce(list, step, initial) {
  2930. if (list == null || initial == null) {
  2931. return null;
  2932. }
  2933. var result = initial;
  2934. for (var i = 0; i < list.length; i++) {
  2935. result = step(result, list[i], i);
  2936. }
  2937. return result;
  2938. }
  2939. /** @deprecated */
  2940. function forEachSnapshotFirst(list, callback) {
  2941. if (!list) {
  2942. return;
  2943. }
  2944. var arrayCopy = list.slice(0);
  2945. arrayCopy.forEach(callback);
  2946. }
  2947. /***/ }),
  2948. /* 18 */
  2949. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  2950. "use strict";
  2951. __webpack_require__.r(__webpack_exports__);
  2952. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "serialiseDate", function() { return serialiseDate; });
  2953. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "parseDateTimeFromString", function() { return parseDateTimeFromString; });
  2954. /* harmony import */ var _number__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(19);
  2955. /**
  2956. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  2957. * @version v23.2.1
  2958. * @link http://www.ag-grid.com/
  2959. * @license MIT
  2960. */
  2961. /**
  2962. * Serialises a Date to a string of format `yyyy-MM-dd HH:mm:ss`.
  2963. * An alternative separator can be provided to be used instead of hyphens.
  2964. * @param date The date to serialise
  2965. * @param includeTime Whether to include the time in the serialised string
  2966. * @param separator The separator to use between date parts
  2967. */
  2968. function serialiseDate(date, includeTime, separator) {
  2969. if (includeTime === void 0) { includeTime = true; }
  2970. if (separator === void 0) { separator = '-'; }
  2971. if (!date) {
  2972. return null;
  2973. }
  2974. var serialised = [date.getFullYear(), date.getMonth() + 1, date.getDate()].map(function (part) { return Object(_number__WEBPACK_IMPORTED_MODULE_0__["padStart"])(part, 2); }).join(separator);
  2975. if (includeTime) {
  2976. serialised += ' ' + [date.getHours(), date.getMinutes(), date.getSeconds()].map(function (part) { return Object(_number__WEBPACK_IMPORTED_MODULE_0__["padStart"])(part, 2); }).join(':');
  2977. }
  2978. return serialised;
  2979. }
  2980. /**
  2981. * Parses a date and time from a string in the format `yyyy-MM-dd HH:mm:ss`
  2982. */
  2983. function parseDateTimeFromString(value) {
  2984. if (!value) {
  2985. return null;
  2986. }
  2987. var _a = value.split(' '), dateStr = _a[0], timeStr = _a[1];
  2988. if (!dateStr) {
  2989. return null;
  2990. }
  2991. var fields = dateStr.split('-').map(function (f) { return parseInt(f, 10); });
  2992. if (fields.filter(function (f) { return !isNaN(f); }).length !== 3) {
  2993. return null;
  2994. }
  2995. var year = fields[0], month = fields[1], day = fields[2];
  2996. var date = new Date(year, month - 1, day);
  2997. if (date.getFullYear() !== year ||
  2998. date.getMonth() !== month - 1 ||
  2999. date.getDate() !== day) {
  3000. // date was not parsed as expected so must have been invalid
  3001. return null;
  3002. }
  3003. if (!timeStr || timeStr === '00:00:00') {
  3004. return date;
  3005. }
  3006. var _b = timeStr.split(':').map(function (part) { return parseInt(part, 10); }), hours = _b[0], minutes = _b[1], seconds = _b[2];
  3007. if (hours >= 0 && hours < 24) {
  3008. date.setHours(hours);
  3009. }
  3010. if (minutes >= 0 && minutes < 60) {
  3011. date.setMinutes(minutes);
  3012. }
  3013. if (seconds >= 0 && seconds < 60) {
  3014. date.setSeconds(seconds);
  3015. }
  3016. return date;
  3017. }
  3018. /***/ }),
  3019. /* 19 */
  3020. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  3021. "use strict";
  3022. __webpack_require__.r(__webpack_exports__);
  3023. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "padStart", function() { return padStart; });
  3024. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "createArrayOfNumbers", function() { return createArrayOfNumbers; });
  3025. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isNumeric", function() { return isNumeric; });
  3026. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getMaxSafeInteger", function() { return getMaxSafeInteger; });
  3027. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "cleanNumber", function() { return cleanNumber; });
  3028. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "decToHex", function() { return decToHex; });
  3029. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "formatNumberTwoDecimalPlacesAndCommas", function() { return formatNumberTwoDecimalPlacesAndCommas; });
  3030. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "formatNumberCommas", function() { return formatNumberCommas; });
  3031. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "sum", function() { return sum; });
  3032. /**
  3033. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  3034. * @version v23.2.1
  3035. * @link http://www.ag-grid.com/
  3036. * @license MIT
  3037. */
  3038. function padStart(value, totalStringSize) {
  3039. var asString = "" + value;
  3040. while (asString.length < totalStringSize) {
  3041. asString = "0" + asString;
  3042. }
  3043. return asString;
  3044. }
  3045. function createArrayOfNumbers(first, last) {
  3046. var result = [];
  3047. for (var i = first; i <= last; i++) {
  3048. result.push(i);
  3049. }
  3050. return result;
  3051. }
  3052. /**
  3053. * Check if a value is numeric
  3054. * from http://stackoverflow.com/questions/9716468/is-there-any-function-like-isnumeric-in-javascript-to-validate-numbers
  3055. * @param {any} value
  3056. * @return {boolean}
  3057. */
  3058. function isNumeric(value) {
  3059. return value !== '' && !isNaN(parseFloat(value)) && isFinite(value);
  3060. }
  3061. function getMaxSafeInteger() {
  3062. // eslint-disable-next-line
  3063. return Number.MAX_SAFE_INTEGER || 9007199254740991;
  3064. }
  3065. function cleanNumber(value) {
  3066. if (typeof value === 'string') {
  3067. value = parseInt(value, 10);
  3068. }
  3069. if (typeof value === 'number') {
  3070. return Math.floor(value);
  3071. }
  3072. else {
  3073. return null;
  3074. }
  3075. }
  3076. function decToHex(number, bytes) {
  3077. var hex = '';
  3078. for (var i = 0; i < bytes; i++) {
  3079. hex += String.fromCharCode(number & 0xff);
  3080. number >>>= 8;
  3081. }
  3082. return hex;
  3083. }
  3084. function formatNumberTwoDecimalPlacesAndCommas(value) {
  3085. if (typeof value !== 'number') {
  3086. return '';
  3087. }
  3088. return formatNumberCommas(Math.round(value * 100) / 100);
  3089. }
  3090. /**
  3091. * the native method number.toLocaleString(undefined, {minimumFractionDigits: 0})
  3092. * puts in decimal places in IE, so we use this method instead
  3093. * from: http://blog.tompawlak.org/number-currency-formatting-javascript
  3094. * @param {number} value
  3095. * @returns {string}
  3096. */
  3097. function formatNumberCommas(value) {
  3098. if (typeof value !== 'number') {
  3099. return '';
  3100. }
  3101. return value.toString().replace(/(\d)(?=(\d{3})+(?!\d))/g, "$1,");
  3102. }
  3103. function sum(values) {
  3104. return values == null ? null : values.reduce(function (total, value) { return total + value; }, 0);
  3105. }
  3106. /***/ }),
  3107. /* 20 */
  3108. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  3109. "use strict";
  3110. __webpack_require__.r(__webpack_exports__);
  3111. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "stopPropagationForAgGrid", function() { return stopPropagationForAgGrid; });
  3112. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isStopPropagationForAgGrid", function() { return isStopPropagationForAgGrid; });
  3113. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isEventSupported", function() { return isEventSupported; });
  3114. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getCellCompForEvent", function() { return getCellCompForEvent; });
  3115. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "addChangeListener", function() { return addChangeListener; });
  3116. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getTarget", function() { return getTarget; });
  3117. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isElementInEventPath", function() { return isElementInEventPath; });
  3118. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "createEventPath", function() { return createEventPath; });
  3119. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "addAgGridEventPath", function() { return addAgGridEventPath; });
  3120. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getEventPath", function() { return getEventPath; });
  3121. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "addSafePassiveEventListener", function() { return addSafePassiveEventListener; });
  3122. /* harmony import */ var _array__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(17);
  3123. /**
  3124. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  3125. * @version v23.2.1
  3126. * @link http://www.ag-grid.com/
  3127. * @license MIT
  3128. */
  3129. var AG_GRID_STOP_PROPAGATION = '__ag_Grid_Stop_Propagation';
  3130. var PASSIVE_EVENTS = ['touchstart', 'touchend', 'touchmove', 'touchcancel'];
  3131. var OUTSIDE_ANGULAR_EVENTS = ['mouseover', 'mouseout', 'mouseenter', 'mouseleave'];
  3132. var supports = {};
  3133. /**
  3134. * a user once raised an issue - they said that when you opened a popup (eg context menu)
  3135. * and then clicked on a selection checkbox, the popup wasn't closed. this is because the
  3136. * popup listens for clicks on the body, however ag-grid WAS stopping propagation on the
  3137. * checkbox clicks (so the rows didn't pick them up as row selection selection clicks).
  3138. * to get around this, we have a pattern to stop propagation for the purposes of ag-Grid,
  3139. * but we still let the event pass back to the body.
  3140. * @param {Event} event
  3141. */
  3142. function stopPropagationForAgGrid(event) {
  3143. event[AG_GRID_STOP_PROPAGATION] = true;
  3144. }
  3145. function isStopPropagationForAgGrid(event) {
  3146. return event[AG_GRID_STOP_PROPAGATION] === true;
  3147. }
  3148. var isEventSupported = (function () {
  3149. var tags = {
  3150. select: 'input',
  3151. change: 'input',
  3152. submit: 'form',
  3153. reset: 'form',
  3154. error: 'img',
  3155. load: 'img',
  3156. abort: 'img'
  3157. };
  3158. var isEventSupported = function (eventName) {
  3159. if (typeof supports[eventName] === 'boolean') {
  3160. return supports[eventName];
  3161. }
  3162. var el = document.createElement(tags[eventName] || 'div');
  3163. eventName = 'on' + eventName;
  3164. var isSupported = (eventName in el);
  3165. if (!isSupported) {
  3166. el.setAttribute(eventName, 'return;');
  3167. isSupported = typeof el[eventName] == 'function';
  3168. }
  3169. el = null;
  3170. return supports[eventName] = isSupported;
  3171. };
  3172. return isEventSupported;
  3173. })();
  3174. function getCellCompForEvent(gridOptionsWrapper, event) {
  3175. var sourceElement = getTarget(event);
  3176. while (sourceElement) {
  3177. var renderedCell = gridOptionsWrapper.getDomData(sourceElement, 'cellComp');
  3178. if (renderedCell) {
  3179. return renderedCell;
  3180. }
  3181. sourceElement = sourceElement.parentElement;
  3182. }
  3183. return null;
  3184. }
  3185. /**
  3186. * @deprecated
  3187. * Adds all type of change listeners to an element, intended to be a text field
  3188. * @param {HTMLElement} element
  3189. * @param {EventListener} listener
  3190. */
  3191. function addChangeListener(element, listener) {
  3192. element.addEventListener('changed', listener);
  3193. element.addEventListener('paste', listener);
  3194. element.addEventListener('input', listener);
  3195. // IE doesn't fire changed for special keys (eg delete, backspace), so need to
  3196. // listen for this further ones
  3197. element.addEventListener('keydown', listener);
  3198. element.addEventListener('keyup', listener);
  3199. }
  3200. /**
  3201. * srcElement is only available in IE. In all other browsers it is target
  3202. * http://stackoverflow.com/questions/5301643/how-can-i-make-event-srcelement-work-in-firefox-and-what-does-it-mean
  3203. * @param {Event} event
  3204. * @returns {Element}
  3205. */
  3206. function getTarget(event) {
  3207. var eventNoType = event;
  3208. return eventNoType.target || eventNoType.srcElement;
  3209. }
  3210. function isElementInEventPath(element, event) {
  3211. if (!event || !element) {
  3212. return false;
  3213. }
  3214. return getEventPath(event).indexOf(element) >= 0;
  3215. }
  3216. function createEventPath(event) {
  3217. var res = [];
  3218. var pointer = getTarget(event);
  3219. while (pointer) {
  3220. res.push(pointer);
  3221. pointer = pointer.parentElement;
  3222. }
  3223. return res;
  3224. }
  3225. /**
  3226. * firefox doesn't have event.path set, or any alternative to it, so we hack
  3227. * it in. this is needed as it's to late to work out the path when the item is
  3228. * removed from the dom. used by MouseEventService, where it works out if a click
  3229. * was from the current grid, or a detail grid (master / detail).
  3230. * @param {Event} event
  3231. */
  3232. function addAgGridEventPath(event) {
  3233. event.__agGridEventPath = getEventPath(event);
  3234. }
  3235. /**
  3236. * Gets the path for an Event.
  3237. * https://stackoverflow.com/questions/39245488/event-path-undefined-with-firefox-and-vue-js
  3238. * https://developer.mozilla.org/en-US/docs/Web/API/Event
  3239. * @param {Event} event
  3240. * @returns {EventTarget[]}
  3241. */
  3242. function getEventPath(event) {
  3243. var eventNoType = event;
  3244. if (eventNoType.deepPath) {
  3245. // IE supports deep path
  3246. return eventNoType.deepPath();
  3247. }
  3248. if (eventNoType.path) {
  3249. // Chrome supports path
  3250. return eventNoType.path;
  3251. }
  3252. if (eventNoType.composedPath) {
  3253. // Firefox supports composePath
  3254. return eventNoType.composedPath();
  3255. }
  3256. if (eventNoType.__agGridEventPath) {
  3257. // Firefox supports composePath
  3258. return eventNoType.__agGridEventPath;
  3259. }
  3260. // and finally, if none of the above worked,
  3261. // we create the path ourselves
  3262. return createEventPath(event);
  3263. }
  3264. function addSafePassiveEventListener(frameworkOverrides, eElement, event, listener) {
  3265. var isPassive = Object(_array__WEBPACK_IMPORTED_MODULE_0__["includes"])(PASSIVE_EVENTS, event);
  3266. var isOutsideAngular = Object(_array__WEBPACK_IMPORTED_MODULE_0__["includes"])(OUTSIDE_ANGULAR_EVENTS, event);
  3267. var options = isPassive ? { passive: true } : undefined;
  3268. if (isOutsideAngular) {
  3269. // this happens in certain scenarios where I believe the user must be destroying the grid somehow but continuing
  3270. // for it to be used
  3271. // don't fall through to the else part either - just don't add the listener
  3272. if (frameworkOverrides && frameworkOverrides.addEventListenerOutsideAngular) {
  3273. frameworkOverrides.addEventListenerOutsideAngular(eElement, event, listener, options);
  3274. }
  3275. }
  3276. else {
  3277. eElement.addEventListener(event, listener, options);
  3278. }
  3279. }
  3280. /***/ }),
  3281. /* 21 */
  3282. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  3283. "use strict";
  3284. __webpack_require__.r(__webpack_exports__);
  3285. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "doOnce", function() { return doOnce; });
  3286. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getFunctionParameters", function() { return getFunctionParameters; });
  3287. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isFunction", function() { return isFunction; });
  3288. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "executeInAWhile", function() { return executeInAWhile; });
  3289. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "executeNextVMTurn", function() { return executeNextVMTurn; });
  3290. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "executeAfter", function() { return executeAfter; });
  3291. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "debounce", function() { return debounce; });
  3292. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "compose", function() { return compose; });
  3293. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "callIfPresent", function() { return callIfPresent; });
  3294. /**
  3295. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  3296. * @version v23.2.1
  3297. * @link http://www.ag-grid.com/
  3298. * @license MIT
  3299. */
  3300. var FUNCTION_STRIP_COMMENTS = /((\/\/.*$)|(\/\*[\s\S]*?\*\/))/mg;
  3301. var FUNCTION_ARGUMENT_NAMES = /([^\s,]+)/g;
  3302. var doOnceFlags = {};
  3303. /**
  3304. * If the key was passed before, then doesn't execute the func
  3305. * @param {Function} func
  3306. * @param {string} key
  3307. */
  3308. function doOnce(func, key) {
  3309. if (doOnceFlags[key]) {
  3310. return;
  3311. }
  3312. func();
  3313. doOnceFlags[key] = true;
  3314. }
  3315. /** @deprecated */
  3316. function getFunctionParameters(func) {
  3317. var fnStr = func.toString().replace(FUNCTION_STRIP_COMMENTS, '');
  3318. return fnStr.slice(fnStr.indexOf('(') + 1, fnStr.indexOf(')')).match(FUNCTION_ARGUMENT_NAMES) || [];
  3319. }
  3320. function isFunction(val) {
  3321. return !!(val && val.constructor && val.call && val.apply);
  3322. }
  3323. function executeInAWhile(funcs) {
  3324. executeAfter(funcs, 400);
  3325. }
  3326. function executeNextVMTurn(funcs) {
  3327. executeAfter(funcs, 0);
  3328. }
  3329. function executeAfter(funcs, milliseconds) {
  3330. if (milliseconds === void 0) { milliseconds = 0; }
  3331. if (funcs.length > 0) {
  3332. window.setTimeout(function () { return funcs.forEach(function (func) { return func(); }); }, milliseconds);
  3333. }
  3334. }
  3335. /**
  3336. * from https://stackoverflow.com/questions/24004791/can-someone-explain-the-debounce-function-in-javascript
  3337. * @param {Function} func The function to be debounced
  3338. * @param {number} wait The time in ms to debounce
  3339. * @param {boolean} immediate If it should run immediately or wait for the initial debounce delay
  3340. * @return {Function} The debounced function
  3341. */
  3342. function debounce(func, wait, immediate) {
  3343. if (immediate === void 0) { immediate = false; }
  3344. // 'private' variable for instance
  3345. // The returned function will be able to reference this due to closure.
  3346. // Each call to the returned function will share this common timer.
  3347. var timeout;
  3348. // Calling debounce returns a new anonymous function
  3349. return function () {
  3350. var args = [];
  3351. for (var _i = 0; _i < arguments.length; _i++) {
  3352. args[_i] = arguments[_i];
  3353. }
  3354. // reference the context and args for the setTimeout function
  3355. var context = this;
  3356. // Should the function be called now? If immediate is true
  3357. // and not already in a timeout then the answer is: Yes
  3358. var callNow = immediate && !timeout;
  3359. // This is the basic debounce behaviour where you can call this
  3360. // function several times, but it will only execute once
  3361. // [before or after imposing a delay].
  3362. // Each time the returned function is called, the timer starts over.
  3363. window.clearTimeout(timeout);
  3364. // Set the new timeout
  3365. timeout = window.setTimeout(function () {
  3366. // Inside the timeout function, clear the timeout variable
  3367. // which will let the next execution run when in 'immediate' mode
  3368. timeout = null;
  3369. // Check if the function already ran with the immediate flag
  3370. if (!immediate) {
  3371. // Call the original function with apply
  3372. // apply lets you define the 'this' object as well as the arguments
  3373. // (both captured before setTimeout)
  3374. func.apply(context, args);
  3375. }
  3376. }, wait);
  3377. // Immediate mode and no wait timer? Execute the function..
  3378. if (callNow) {
  3379. func.apply(context, args);
  3380. }
  3381. };
  3382. }
  3383. function compose() {
  3384. var fns = [];
  3385. for (var _i = 0; _i < arguments.length; _i++) {
  3386. fns[_i] = arguments[_i];
  3387. }
  3388. return function (arg) { return fns.reduce(function (composed, f) { return f(composed); }, arg); };
  3389. }
  3390. function callIfPresent(func) {
  3391. if (func) {
  3392. func();
  3393. }
  3394. }
  3395. /***/ }),
  3396. /* 22 */
  3397. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  3398. "use strict";
  3399. __webpack_require__.r(__webpack_exports__);
  3400. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "fuzzyCheckStrings", function() { return fuzzyCheckStrings; });
  3401. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "fuzzySuggestions", function() { return fuzzySuggestions; });
  3402. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "get_bigrams", function() { return get_bigrams; });
  3403. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "string_distances", function() { return string_distances; });
  3404. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "string_weighted_distances", function() { return string_weighted_distances; });
  3405. /**
  3406. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  3407. * @version v23.2.1
  3408. * @link http://www.ag-grid.com/
  3409. * @license MIT
  3410. */
  3411. function fuzzyCheckStrings(inputValues, validValues, allSuggestions) {
  3412. var fuzzyMatches = {};
  3413. var invalidInputs = inputValues.filter(function (inputValue) {
  3414. return !validValues.some(function (validValue) { return validValue === inputValue; });
  3415. });
  3416. if (invalidInputs.length > 0) {
  3417. invalidInputs.forEach(function (invalidInput) {
  3418. return fuzzyMatches[invalidInput] = fuzzySuggestions(invalidInput, allSuggestions);
  3419. });
  3420. }
  3421. return fuzzyMatches;
  3422. }
  3423. /**
  3424. *
  3425. * @param {String} inputValue The value to be compared against a list of strings
  3426. * @param allSuggestions The list of strings to be compared against
  3427. * @param hideIrrelevant By default, fuzzy suggestions will just sort the allSuggestions list, set this to true
  3428. * to filter out the irrelevant values
  3429. * @param weighted Set this to true, to make letters matched in the order they were typed have priority in the results.
  3430. */
  3431. function fuzzySuggestions(inputValue, allSuggestions, hideIrrelevant, weighted) {
  3432. var search = weighted ? string_weighted_distances : string_distances;
  3433. var thisSuggestions = allSuggestions.map(function (text) { return ({
  3434. value: text,
  3435. relevance: search(inputValue.toLowerCase(), text.toLocaleLowerCase())
  3436. }); });
  3437. thisSuggestions.sort(function (a, b) { return b.relevance - a.relevance; });
  3438. if (hideIrrelevant) {
  3439. thisSuggestions = thisSuggestions.filter(function (suggestion) { return suggestion.relevance !== 0; });
  3440. }
  3441. return thisSuggestions.map(function (suggestion) { return suggestion.value; });
  3442. }
  3443. /**
  3444. * Algorithm to do fuzzy search
  3445. * from https://stackoverflow.com/questions/23305000/javascript-fuzzy-search-that-makes-sense
  3446. * @param {string} from
  3447. * @return {[]}
  3448. */
  3449. function get_bigrams(from) {
  3450. var s = from.toLowerCase();
  3451. var v = new Array(s.length - 1);
  3452. var i;
  3453. var j;
  3454. var ref;
  3455. for (i = j = 0, ref = v.length; j <= ref; i = j += 1) {
  3456. v[i] = s.slice(i, i + 2);
  3457. }
  3458. return v;
  3459. }
  3460. function string_distances(str1, str2) {
  3461. if (str1.length === 0 && str2.length === 0) {
  3462. return 0;
  3463. }
  3464. var pairs1 = get_bigrams(str1);
  3465. var pairs2 = get_bigrams(str2);
  3466. var union = pairs1.length + pairs2.length;
  3467. var hit_count = 0;
  3468. var j;
  3469. var len;
  3470. for (j = 0, len = pairs1.length; j < len; j++) {
  3471. var x = pairs1[j];
  3472. var k = void 0;
  3473. var len1 = void 0;
  3474. for (k = 0, len1 = pairs2.length; k < len1; k++) {
  3475. var y = pairs2[k];
  3476. if (x === y) {
  3477. hit_count++;
  3478. }
  3479. }
  3480. }
  3481. return hit_count > 0 ? (2 * hit_count) / union : 0;
  3482. }
  3483. function string_weighted_distances(str1, str2) {
  3484. var a = str1.replace(/\s/g, '');
  3485. var b = str2.replace(/\s/g, '');
  3486. var weight = 0;
  3487. var lastIndex = 0;
  3488. for (var i = 0; i < a.length; i++) {
  3489. var idx = b.indexOf(a[i]);
  3490. if (idx === -1) {
  3491. continue;
  3492. }
  3493. lastIndex = idx;
  3494. weight += ((b.length - lastIndex) * 100) / b.length;
  3495. weight *= weight;
  3496. }
  3497. return weight;
  3498. }
  3499. /***/ }),
  3500. /* 23 */
  3501. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  3502. "use strict";
  3503. __webpack_require__.r(__webpack_exports__);
  3504. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "iconNameClassMap", function() { return iconNameClassMap; });
  3505. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "createIcon", function() { return createIcon; });
  3506. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "createIconNoSpan", function() { return createIconNoSpan; });
  3507. /* harmony import */ var _dom__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(12);
  3508. /**
  3509. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  3510. * @version v23.2.1
  3511. * @link http://www.ag-grid.com/
  3512. * @license MIT
  3513. */
  3514. //
  3515. // IMPORTANT NOTE!
  3516. //
  3517. // If you change the list below, copy/paste the new content into the docs page javascript-grid-icons
  3518. //
  3519. var iconNameClassMap = {
  3520. // header column group shown when expanded (click to contract)
  3521. columnGroupOpened: 'expanded',
  3522. // header column group shown when contracted (click to expand)
  3523. columnGroupClosed: 'contracted',
  3524. // tool panel column group contracted (click to expand)
  3525. columnSelectClosed: 'tree-closed',
  3526. // tool panel column group expanded (click to contract)
  3527. columnSelectOpen: 'tree-open',
  3528. // column tool panel header expand/collapse all button, shown when some children are expanded and
  3529. // others are collapsed
  3530. columnSelectIndeterminate: 'tree-indeterminate',
  3531. // shown on ghost icon while dragging column to the side of the grid to pin
  3532. columnMovePin: 'pin',
  3533. // shown on ghost icon while dragging over part of the page that is not a drop zone
  3534. columnMoveHide: 'eye-slash',
  3535. // shown on ghost icon while dragging columns to reorder
  3536. columnMoveMove: 'arrows',
  3537. // animating icon shown when dragging a column to the right of the grid causes horizontal scrolling
  3538. columnMoveLeft: 'left',
  3539. // animating icon shown when dragging a column to the left of the grid causes horizontal scrolling
  3540. columnMoveRight: 'right',
  3541. // shown on ghost icon while dragging over Row Groups drop zone
  3542. columnMoveGroup: 'group',
  3543. // shown on ghost icon while dragging over Values drop zone
  3544. columnMoveValue: 'aggregation',
  3545. // shown on ghost icon while dragging over pivot drop zone
  3546. columnMovePivot: 'pivot',
  3547. // shown on ghost icon while dragging over drop zone that doesn't support it, e.g.
  3548. // string column over aggregation drop zone
  3549. dropNotAllowed: 'not-allowed',
  3550. // shown on row group when contracted (click to expand)
  3551. groupContracted: 'tree-closed',
  3552. // shown on row group when expanded (click to contract)
  3553. groupExpanded: 'tree-open',
  3554. // context menu chart item
  3555. chart: 'chart',
  3556. // chart window title bar
  3557. close: 'cross',
  3558. // X (remove) on column 'pill' after adding it to a drop zone list
  3559. cancel: 'cancel',
  3560. // indicates the currently active pin state in the "Pin column" sub-menu of the column menu
  3561. check: 'tick',
  3562. // "go to first" button in pagination controls
  3563. first: 'first',
  3564. // "go to previous" button in pagination controls
  3565. previous: 'previous',
  3566. // "go to next" button in pagination controls
  3567. next: 'next',
  3568. // "go to last" button in pagination controls
  3569. last: 'last',
  3570. // shown on top right of chart when chart is linked to range data (click to unlink)
  3571. linked: 'linked',
  3572. // shown on top right of chart when chart is not linked to range data (click to link)
  3573. unlinked: 'unlinked',
  3574. // "Choose colour" button on chart settings tab
  3575. colorPicker: 'color-picker',
  3576. // rotating spinner shown by the loading cell renderer
  3577. groupLoading: 'loading',
  3578. // button to launch enterprise column menu
  3579. menu: 'menu',
  3580. // filter tool panel tab
  3581. filter: 'filter',
  3582. // column tool panel tab
  3583. columns: 'columns',
  3584. // button in chart regular size window title bar (click to maximise)
  3585. maximize: 'maximize',
  3586. // button in chart maximised window title bar (click to make regular size)
  3587. minimize: 'minimize',
  3588. // "Pin column" item in column header menu
  3589. menuPin: 'pin',
  3590. // "Value aggregation" column menu item (shown on numeric columns when grouping is active)"
  3591. menuValue: 'aggregation',
  3592. // "Group by {column-name}" item in column header menu
  3593. menuAddRowGroup: 'group',
  3594. // "Un-Group by {column-name}" item in column header menu
  3595. menuRemoveRowGroup: 'group',
  3596. // context menu copy item
  3597. clipboardCopy: 'copy',
  3598. // context menu paste item
  3599. clipboardPaste: 'paste',
  3600. // identifies the pivot drop zone
  3601. pivotPanel: 'pivot',
  3602. // "Row groups" drop zone in column tool panel
  3603. rowGroupPanel: 'group',
  3604. // columns tool panel Values drop zone
  3605. valuePanel: 'aggregation',
  3606. // drag handle used to pick up draggable columns
  3607. columnDrag: 'grip',
  3608. // drag handle used to pick up draggable rows
  3609. rowDrag: 'grip',
  3610. // context menu export item
  3611. save: 'save',
  3612. // icon on dropdown editors
  3613. smallDown: 'small-down',
  3614. // version of small-right used in RTL mode
  3615. smallLeft: 'small-left',
  3616. // separater between column 'pills' when you add multiple columns to the header drop zone
  3617. smallRight: 'small-right',
  3618. smallUp: 'small-up',
  3619. // show on column header when column is sorted ascending
  3620. sortAscending: 'asc',
  3621. // show on column header when column is sorted descending
  3622. sortDescending: 'desc',
  3623. // show on column header when column has no sort, only when enabled with gridOptions.unSortIcon=true
  3624. sortUnSort: 'none'
  3625. };
  3626. /**
  3627. * If icon provided, use this (either a string, or a function callback).
  3628. * if not, then use the default icon from the theme
  3629. * @param {string} iconName
  3630. * @param {GridOptionsWrapper} gridOptionsWrapper
  3631. * @param {Column | null} [column]
  3632. * @returns {HTMLElement}
  3633. */
  3634. function createIcon(iconName, gridOptionsWrapper, column) {
  3635. var iconContents = createIconNoSpan(iconName, gridOptionsWrapper, column);
  3636. if (iconContents.className.indexOf('ag-icon') > -1) {
  3637. return iconContents;
  3638. }
  3639. var eResult = document.createElement('span');
  3640. eResult.appendChild(iconContents);
  3641. return eResult;
  3642. }
  3643. function createIconNoSpan(iconName, gridOptionsWrapper, column, forceCreate) {
  3644. var userProvidedIcon = null;
  3645. // check col for icon first
  3646. var icons = column && column.getColDef().icons;
  3647. if (icons) {
  3648. userProvidedIcon = icons[iconName];
  3649. }
  3650. // if not in col, try grid options
  3651. if (gridOptionsWrapper && !userProvidedIcon) {
  3652. var optionsIcons = gridOptionsWrapper.getIcons();
  3653. if (optionsIcons) {
  3654. userProvidedIcon = optionsIcons[iconName];
  3655. }
  3656. }
  3657. // now if user provided, use it
  3658. if (userProvidedIcon) {
  3659. var rendererResult = void 0;
  3660. if (typeof userProvidedIcon === 'function') {
  3661. rendererResult = userProvidedIcon();
  3662. }
  3663. else if (typeof userProvidedIcon === 'string') {
  3664. rendererResult = userProvidedIcon;
  3665. }
  3666. else {
  3667. throw new Error('icon from grid options needs to be a string or a function');
  3668. }
  3669. if (typeof rendererResult === 'string') {
  3670. return Object(_dom__WEBPACK_IMPORTED_MODULE_0__["loadTemplate"])(rendererResult);
  3671. }
  3672. else if (Object(_dom__WEBPACK_IMPORTED_MODULE_0__["isNodeOrElement"])(rendererResult)) {
  3673. return rendererResult;
  3674. }
  3675. else {
  3676. console.warn('ag-Grid: iconRenderer should return back a string or a dom object');
  3677. }
  3678. }
  3679. else {
  3680. var span = document.createElement('span');
  3681. var cssClass = iconNameClassMap[iconName];
  3682. if (!cssClass) {
  3683. if (!forceCreate) {
  3684. console.warn("ag-Grid: Did not find icon " + iconName);
  3685. cssClass = '';
  3686. }
  3687. else {
  3688. cssClass = iconName;
  3689. }
  3690. }
  3691. span.setAttribute('class', "ag-icon ag-icon-" + cssClass);
  3692. span.setAttribute("unselectable", "on");
  3693. return span;
  3694. }
  3695. }
  3696. /***/ }),
  3697. /* 24 */
  3698. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  3699. "use strict";
  3700. __webpack_require__.r(__webpack_exports__);
  3701. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isKeyPressed", function() { return isKeyPressed; });
  3702. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isCharacterKey", function() { return isCharacterKey; });
  3703. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isEventFromPrintableCharacter", function() { return isEventFromPrintableCharacter; });
  3704. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isUserSuppressingKeyboardEvent", function() { return isUserSuppressingKeyboardEvent; });
  3705. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(25);
  3706. /* harmony import */ var _generic__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(14);
  3707. /* harmony import */ var _browser__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(13);
  3708. /**
  3709. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  3710. * @version v23.2.1
  3711. * @link http://www.ag-grid.com/
  3712. * @license MIT
  3713. */
  3714. var PRINTABLE_CHARACTERS = 'qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM1234567890!"£$%^&*()_+-=[];\'#,./\\|<>?:@~{}';
  3715. var NUMPAD_DEL_NUMLOCK_ON_KEY = 'Del';
  3716. var NUMPAD_DEL_NUMLOCK_ON_CHARCODE = 46;
  3717. function isKeyPressed(event, keyToCheck) {
  3718. return (event.which || event.keyCode) === keyToCheck;
  3719. }
  3720. function isCharacterKey(event) {
  3721. // from: https://stackoverflow.com/questions/4179708/how-to-detect-if-the-pressed-key-will-produce-a-character-inside-an-input-text
  3722. var which = event.which;
  3723. if (typeof which === 'number' && which) {
  3724. return !event.ctrlKey && !event.metaKey && !event.altKey && event.which !== 8 && event.which !== 16;
  3725. }
  3726. return which === undefined;
  3727. }
  3728. function isEventFromPrintableCharacter(event) {
  3729. var pressedChar = String.fromCharCode(event.charCode);
  3730. // newline is an exception, as it counts as a printable character, but we don't
  3731. // want to start editing when it is pressed. without this check, if user is in chrome
  3732. // and editing a cell, and they press ctrl+enter, the cell stops editing, and then
  3733. // starts editing again with a blank value (two 'key down' events are fired). to
  3734. // test this, remove the line below, edit a cell in chrome and hit ctrl+enter while editing.
  3735. // https://ag-grid.atlassian.net/browse/AG-605
  3736. if (isKeyPressed(event, _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_NEW_LINE)) {
  3737. return false;
  3738. }
  3739. // no allowed printable chars have alt or ctrl key combinations
  3740. if (event.altKey || event.ctrlKey) {
  3741. return false;
  3742. }
  3743. if (Object(_generic__WEBPACK_IMPORTED_MODULE_1__["exists"])(event.key)) {
  3744. // modern browser will implement key, so we return if key is length 1, eg if it is 'a' for the
  3745. // a key, or '2' for the '2' key. non-printable characters have names, eg 'Enter' or 'Backspace'.
  3746. var printableCharacter = event.key.length === 1;
  3747. // IE11 & Edge treat the numpad del key differently - with numlock on we get "Del" for key,
  3748. // so this addition checks if its IE11/Edge and handles that specific case the same was as all other browsers
  3749. var numpadDelWithNumlockOnForEdgeOrIe = isNumpadDelWithNumlockOnForEdgeOrIe(event);
  3750. return printableCharacter || numpadDelWithNumlockOnForEdgeOrIe;
  3751. }
  3752. // otherwise, for older browsers, we test against a list of characters, which doesn't include
  3753. // accents for non-English, but don't care much, as most users are on modern browsers
  3754. return PRINTABLE_CHARACTERS.indexOf(pressedChar) >= 0;
  3755. }
  3756. /**
  3757. * Allows user to tell the grid to skip specific keyboard events
  3758. * @param {GridOptionsWrapper} gridOptionsWrapper
  3759. * @param {KeyboardEvent} keyboardEvent
  3760. * @param {RowNode} rowNode
  3761. * @param {Column} column
  3762. * @param {boolean} editing
  3763. * @returns {boolean}
  3764. */
  3765. function isUserSuppressingKeyboardEvent(gridOptionsWrapper, keyboardEvent, rowNode, column, editing) {
  3766. var gridOptionsFunc = gridOptionsWrapper.getSuppressKeyboardEventFunc();
  3767. var colDefFunc = column.getColDef().suppressKeyboardEvent;
  3768. // if no callbacks provided by user, then do nothing
  3769. if (!gridOptionsFunc && !colDefFunc) {
  3770. return false;
  3771. }
  3772. var params = {
  3773. event: keyboardEvent,
  3774. editing: editing,
  3775. column: column,
  3776. api: gridOptionsWrapper.getApi(),
  3777. node: rowNode,
  3778. data: rowNode.data,
  3779. colDef: column.getColDef(),
  3780. context: gridOptionsWrapper.getContext(),
  3781. columnApi: gridOptionsWrapper.getColumnApi()
  3782. };
  3783. // colDef get first preference on suppressing events
  3784. if (colDefFunc) {
  3785. var colDefFuncResult = colDefFunc(params);
  3786. // if colDef func suppressed, then return now, no need to call gridOption func
  3787. if (colDefFuncResult) {
  3788. return true;
  3789. }
  3790. }
  3791. if (gridOptionsFunc) {
  3792. // if gridOption func, return the result
  3793. return gridOptionsFunc(params);
  3794. }
  3795. // otherwise return false, don't suppress, as colDef didn't suppress and no func on gridOptions
  3796. return false;
  3797. }
  3798. function isNumpadDelWithNumlockOnForEdgeOrIe(event) {
  3799. return (Object(_browser__WEBPACK_IMPORTED_MODULE_2__["isBrowserEdge"])() || Object(_browser__WEBPACK_IMPORTED_MODULE_2__["isBrowserIE"])()) &&
  3800. event.key === NUMPAD_DEL_NUMLOCK_ON_KEY &&
  3801. event.charCode === NUMPAD_DEL_NUMLOCK_ON_CHARCODE;
  3802. }
  3803. /***/ }),
  3804. /* 25 */
  3805. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  3806. "use strict";
  3807. __webpack_require__.r(__webpack_exports__);
  3808. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Constants", function() { return Constants; });
  3809. /**
  3810. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  3811. * @version v23.2.1
  3812. * @link http://www.ag-grid.com/
  3813. * @license MIT
  3814. */
  3815. var Constants = /** @class */ (function () {
  3816. function Constants() {
  3817. }
  3818. Constants.STEP_EVERYTHING = 0;
  3819. Constants.STEP_FILTER = 1;
  3820. Constants.STEP_SORT = 2;
  3821. Constants.STEP_MAP = 3;
  3822. Constants.STEP_AGGREGATE = 4;
  3823. Constants.STEP_PIVOT = 5;
  3824. Constants.ROW_BUFFER_SIZE = 10;
  3825. Constants.LAYOUT_INTERVAL = 500;
  3826. Constants.BATCH_WAIT_MILLIS = 50;
  3827. Constants.EXPORT_TYPE_DRAG_COPY = 'dragCopy';
  3828. Constants.EXPORT_TYPE_CLIPBOARD = 'clipboard';
  3829. Constants.EXPORT_TYPE_EXCEL = 'excel';
  3830. Constants.EXPORT_TYPE_CSV = 'csv';
  3831. Constants.KEY_BACKSPACE = 8;
  3832. Constants.KEY_TAB = 9;
  3833. Constants.KEY_NEW_LINE = 10;
  3834. Constants.KEY_ENTER = 13;
  3835. Constants.KEY_SHIFT = 16;
  3836. Constants.KEY_ESCAPE = 27;
  3837. Constants.KEY_SPACE = 32;
  3838. Constants.KEY_LEFT = 37;
  3839. Constants.KEY_UP = 38;
  3840. Constants.KEY_RIGHT = 39;
  3841. Constants.KEY_DOWN = 40;
  3842. Constants.KEY_DELETE = 46;
  3843. Constants.KEY_A = 65;
  3844. Constants.KEY_C = 67;
  3845. Constants.KEY_V = 86;
  3846. Constants.KEY_D = 68;
  3847. Constants.KEY_Z = 90;
  3848. Constants.KEY_Y = 89;
  3849. Constants.KEY_F2 = 113;
  3850. Constants.KEY_PAGE_UP = 33;
  3851. Constants.KEY_PAGE_DOWN = 34;
  3852. Constants.KEY_PAGE_HOME = 36;
  3853. Constants.KEY_PAGE_END = 35;
  3854. Constants.ROW_MODEL_TYPE_INFINITE = 'infinite';
  3855. Constants.ROW_MODEL_TYPE_VIEWPORT = 'viewport';
  3856. Constants.ROW_MODEL_TYPE_CLIENT_SIDE = 'clientSide';
  3857. Constants.ROW_MODEL_TYPE_SERVER_SIDE = 'serverSide';
  3858. Constants.DEPRECATED_ROW_MODEL_TYPE_NORMAL = 'normal';
  3859. Constants.ALWAYS = 'always';
  3860. Constants.ONLY_WHEN_GROUPING = 'onlyWhenGrouping';
  3861. Constants.PINNED_TOP = 'top';
  3862. Constants.PINNED_BOTTOM = 'bottom';
  3863. Constants.DOM_LAYOUT_NORMAL = 'normal';
  3864. Constants.DOM_LAYOUT_PRINT = 'print';
  3865. Constants.DOM_LAYOUT_AUTO_HEIGHT = 'autoHeight';
  3866. Constants.GROUP_AUTO_COLUMN_ID = 'ag-Grid-AutoColumn';
  3867. Constants.SOURCE_PASTE = 'paste';
  3868. Constants.PINNED_RIGHT = 'right';
  3869. Constants.PINNED_LEFT = 'left';
  3870. Constants.SORT_ASC = 'asc';
  3871. Constants.SORT_DESC = 'desc';
  3872. return Constants;
  3873. }());
  3874. /***/ }),
  3875. /* 26 */
  3876. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  3877. "use strict";
  3878. __webpack_require__.r(__webpack_exports__);
  3879. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "keys", function() { return keys; });
  3880. /**
  3881. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  3882. * @version v23.2.1
  3883. * @link http://www.ag-grid.com/
  3884. * @license MIT
  3885. */
  3886. function keys(map) {
  3887. var keys = [];
  3888. map.forEach(function (_, key) { return keys.push(key); });
  3889. return keys;
  3890. }
  3891. /***/ }),
  3892. /* 27 */
  3893. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  3894. "use strict";
  3895. __webpack_require__.r(__webpack_exports__);
  3896. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "normalizeWheel", function() { return normalizeWheel; });
  3897. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isLeftClick", function() { return isLeftClick; });
  3898. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "areEventsNear", function() { return areEventsNear; });
  3899. /**
  3900. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  3901. * @version v23.2.1
  3902. * @link http://www.ag-grid.com/
  3903. * @license MIT
  3904. */
  3905. /**
  3906. * @deprecated
  3907. * Mouse wheel (and 2-finger trackpad) support on the web sucks. It is
  3908. * complicated, thus this doc is long and (hopefully) detailed enough to answer
  3909. * your questions.
  3910. *
  3911. * If you need to react to the mouse wheel in a predictable way, this code is
  3912. * like your bestest friend. * hugs *
  3913. *
  3914. * As of today, there are 4 DOM event types you can listen to:
  3915. *
  3916. * 'wheel' -- Chrome(31+), FF(17+), IE(9+)
  3917. * 'mousewheel' -- Chrome, IE(6+), Opera, Safari
  3918. * 'MozMousePixelScroll' -- FF(3.5 only!) (2010-2013) -- don't bother!
  3919. * 'DOMMouseScroll' -- FF(0.9.7+) since 2003
  3920. *
  3921. * So what to do? The is the best:
  3922. *
  3923. * normalizeWheel.getEventType();
  3924. *
  3925. * In your event callback, use this code to get sane interpretation of the
  3926. * deltas. This code will return an object with properties:
  3927. *
  3928. * spinX -- normalized spin speed (use for zoom) - x plane
  3929. * spinY -- " - y plane
  3930. * pixelX -- normalized distance (to pixels) - x plane
  3931. * pixelY -- " - y plane
  3932. *
  3933. * Wheel values are provided by the browser assuming you are using the wheel to
  3934. * scroll a web page by a number of lines or pixels (or pages). Values can vary
  3935. * significantly on different platforms and browsers, forgetting that you can
  3936. * scroll at different speeds. Some devices (like trackpads) emit more events
  3937. * at smaller increments with fine granularity, and some emit massive jumps with
  3938. * linear speed or acceleration.
  3939. *
  3940. * This code does its best to normalize the deltas for you:
  3941. *
  3942. * - spin is trying to normalize how far the wheel was spun (or trackpad
  3943. * dragged). This is super useful for zoom support where you want to
  3944. * throw away the chunky scroll steps on the PC and make those equal to
  3945. * the slow and smooth tiny steps on the Mac. Key data: This code tries to
  3946. * resolve a single slow step on a wheel to 1.
  3947. *
  3948. * - pixel is normalizing the desired scroll delta in pixel units. You'll
  3949. * get the crazy differences between browsers, but at least it'll be in
  3950. * pixels!
  3951. *
  3952. * - positive value indicates scrolling DOWN/RIGHT, negative UP/LEFT. This
  3953. * should translate to positive value zooming IN, negative zooming OUT.
  3954. * This matches the newer 'wheel' event.
  3955. *
  3956. * Why are there spinX, spinY (or pixels)?
  3957. *
  3958. * - spinX is a 2-finger side drag on the trackpad, and a shift + wheel turn
  3959. * with a mouse. It results in side-scrolling in the browser by default.
  3960. *
  3961. * - spinY is what you expect -- it's the classic axis of a mouse wheel.
  3962. *
  3963. * - I dropped spinZ/pixelZ. It is supported by the DOM 3 'wheel' event and
  3964. * probably is by browsers in conjunction with fancy 3D controllers .. but
  3965. * you know.
  3966. *
  3967. * Implementation info:
  3968. *
  3969. * Examples of 'wheel' event if you scroll slowly (down) by one step with an
  3970. * average mouse:
  3971. *
  3972. * OS X + Chrome (mouse) - 4 pixel delta (wheelDelta -120)
  3973. * OS X + Safari (mouse) - N/A pixel delta (wheelDelta -12)
  3974. * OS X + Firefox (mouse) - 0.1 line delta (wheelDelta N/A)
  3975. * Win8 + Chrome (mouse) - 100 pixel delta (wheelDelta -120)
  3976. * Win8 + Firefox (mouse) - 3 line delta (wheelDelta -120)
  3977. *
  3978. * On the trackpad:
  3979. *
  3980. * OS X + Chrome (trackpad) - 2 pixel delta (wheelDelta -6)
  3981. * OS X + Firefox (trackpad) - 1 pixel delta (wheelDelta N/A)
  3982. *
  3983. * On other/older browsers.. it's more complicated as there can be multiple and
  3984. * also missing delta values.
  3985. *
  3986. * The 'wheel' event is more standard:
  3987. *
  3988. * http://www.w3.org/TR/DOM-Level-3-Events/#events-wheelevents
  3989. *
  3990. * The basics is that it includes a unit, deltaMode (pixels, lines, pages), and
  3991. * deltaX, deltaY and deltaZ. Some browsers provide other values to maintain
  3992. * backward compatibility with older events. Those other values help us
  3993. * better normalize spin speed. Example of what the browsers provide:
  3994. *
  3995. * | event.wheelDelta | event.detail
  3996. * ------------------+------------------+--------------
  3997. * Safari v5/OS X | -120 | 0
  3998. * Safari v5/Win7 | -120 | 0
  3999. * Chrome v17/OS X | -120 | 0
  4000. * Chrome v17/Win7 | -120 | 0
  4001. * IE9/Win7 | -120 | undefined
  4002. * Firefox v4/OS X | undefined | 1
  4003. * Firefox v4/Win7 | undefined | 3
  4004. *
  4005. * from: https://github.com/facebook/fixed-data-table/blob/master/src/vendor_upstream/dom/normalizeWheel.js
  4006. * @param {any} event
  4007. * @return {any}
  4008. */
  4009. function normalizeWheel(event) {
  4010. var PIXEL_STEP = 10;
  4011. var LINE_HEIGHT = 40;
  4012. var PAGE_HEIGHT = 800;
  4013. // spinX, spinY
  4014. var sX = 0;
  4015. var sY = 0;
  4016. // pixelX, pixelY
  4017. var pX = 0;
  4018. var pY = 0;
  4019. // Legacy
  4020. if ('detail' in event) {
  4021. sY = event.detail;
  4022. }
  4023. if ('wheelDelta' in event) {
  4024. sY = -event.wheelDelta / 120;
  4025. }
  4026. if ('wheelDeltaY' in event) {
  4027. sY = -event.wheelDeltaY / 120;
  4028. }
  4029. if ('wheelDeltaX' in event) {
  4030. sX = -event.wheelDeltaX / 120;
  4031. }
  4032. // side scrolling on FF with DOMMouseScroll
  4033. if ('axis' in event && event.axis === event.HORIZONTAL_AXIS) {
  4034. sX = sY;
  4035. sY = 0;
  4036. }
  4037. pX = sX * PIXEL_STEP;
  4038. pY = sY * PIXEL_STEP;
  4039. if ('deltaY' in event) {
  4040. pY = event.deltaY;
  4041. }
  4042. if ('deltaX' in event) {
  4043. pX = event.deltaX;
  4044. }
  4045. if ((pX || pY) && event.deltaMode) {
  4046. if (event.deltaMode == 1) { // delta in LINE units
  4047. pX *= LINE_HEIGHT;
  4048. pY *= LINE_HEIGHT;
  4049. }
  4050. else { // delta in PAGE units
  4051. pX *= PAGE_HEIGHT;
  4052. pY *= PAGE_HEIGHT;
  4053. }
  4054. }
  4055. // Fall-back if spin cannot be determined
  4056. if (pX && !sX) {
  4057. sX = (pX < 1) ? -1 : 1;
  4058. }
  4059. if (pY && !sY) {
  4060. sY = (pY < 1) ? -1 : 1;
  4061. }
  4062. return {
  4063. spinX: sX,
  4064. spinY: sY,
  4065. pixelX: pX,
  4066. pixelY: pY
  4067. };
  4068. }
  4069. /**
  4070. * @deprecated
  4071. * Checks if event was issued by a left click
  4072. * from https://stackoverflow.com/questions/3944122/detect-left-mouse-button-press
  4073. * @param {MouseEvent} mouseEvent
  4074. * @returns {boolean}
  4075. */
  4076. function isLeftClick(mouseEvent) {
  4077. if ('buttons' in mouseEvent) {
  4078. return mouseEvent.buttons == 1;
  4079. }
  4080. var button = mouseEvent.which || mouseEvent.button;
  4081. return button == 1;
  4082. }
  4083. /**
  4084. * `True` if the event is close to the original event by X pixels either vertically or horizontally.
  4085. * we only start dragging after X pixels so this allows us to know if we should start dragging yet.
  4086. * @param {MouseEvent | TouchEvent} e1
  4087. * @param {MouseEvent | TouchEvent} e2
  4088. * @param {number} pixelCount
  4089. * @returns {boolean}
  4090. */
  4091. function areEventsNear(e1, e2, pixelCount) {
  4092. // by default, we wait 4 pixels before starting the drag
  4093. if (pixelCount === 0) {
  4094. return false;
  4095. }
  4096. var diffX = Math.abs(e1.clientX - e2.clientX);
  4097. var diffY = Math.abs(e1.clientY - e2.clientY);
  4098. return Math.max(diffX, diffY) <= pixelCount;
  4099. }
  4100. /***/ }),
  4101. /* 28 */
  4102. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  4103. "use strict";
  4104. __webpack_require__.r(__webpack_exports__);
  4105. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "sortRowNodesByOrder", function() { return sortRowNodesByOrder; });
  4106. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "traverseNodesWithKey", function() { return traverseNodesWithKey; });
  4107. /**
  4108. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  4109. * @version v23.2.1
  4110. * @link http://www.ag-grid.com/
  4111. * @license MIT
  4112. */
  4113. /**
  4114. * Gets called by: a) ClientSideNodeManager and b) GroupStage to do sorting.
  4115. * when in ClientSideNodeManager we always have indexes (as this sorts the items the
  4116. * user provided) but when in GroupStage, the nodes can contain filler nodes that
  4117. * don't have order id's
  4118. * @param {RowNode[]} rowNodes
  4119. * @param {Object} rowNodeOrder
  4120. */
  4121. function sortRowNodesByOrder(rowNodes, rowNodeOrder) {
  4122. if (!rowNodes) {
  4123. return;
  4124. }
  4125. var comparator = function (nodeA, nodeB) {
  4126. var positionA = rowNodeOrder[nodeA.id];
  4127. var positionB = rowNodeOrder[nodeB.id];
  4128. var aHasIndex = positionA !== undefined;
  4129. var bHasIndex = positionB !== undefined;
  4130. var bothNodesAreUserNodes = aHasIndex && bHasIndex;
  4131. var bothNodesAreFillerNodes = !aHasIndex && !bHasIndex;
  4132. if (bothNodesAreUserNodes) {
  4133. // when comparing two nodes the user has provided, they always
  4134. // have indexes
  4135. return positionA - positionB;
  4136. }
  4137. if (bothNodesAreFillerNodes) {
  4138. // when comparing two filler nodes, we have no index to compare them
  4139. // against, however we want this sorting to be deterministic, so that
  4140. // the rows don't jump around as the user does delta updates. so we
  4141. // want the same sort result. so we use the __objectId - which doesn't make sense
  4142. // from a sorting point of view, but does give consistent behaviour between
  4143. // calls. otherwise groups jump around as delta updates are done.
  4144. // note: previously here we used nodeId, however this gave a strange order
  4145. // as string ordering of numbers is wrong, so using id based on creation order
  4146. // as least gives better looking order.
  4147. return nodeA.__objectId - nodeB.__objectId;
  4148. }
  4149. if (aHasIndex) {
  4150. return 1;
  4151. }
  4152. return -1;
  4153. };
  4154. // check if the list first needs sorting
  4155. var rowNodeA;
  4156. var rowNodeB;
  4157. var atLeastOneOutOfOrder = false;
  4158. for (var i = 0; i < rowNodes.length - 1; i++) {
  4159. rowNodeA = rowNodes[i];
  4160. rowNodeB = rowNodes[i + 1];
  4161. if (comparator(rowNodeA, rowNodeB) > 0) {
  4162. atLeastOneOutOfOrder = true;
  4163. break;
  4164. }
  4165. }
  4166. if (atLeastOneOutOfOrder) {
  4167. rowNodes.sort(comparator);
  4168. }
  4169. }
  4170. function traverseNodesWithKey(nodes, callback) {
  4171. var keyParts = [];
  4172. recursiveSearchNodes(nodes);
  4173. function recursiveSearchNodes(currentNodes) {
  4174. currentNodes.forEach(function (node) {
  4175. // also checking for children for tree data
  4176. if (node.group || node.hasChildren()) {
  4177. keyParts.push(node.key);
  4178. var key = keyParts.join('|');
  4179. callback(node, key);
  4180. recursiveSearchNodes(node.childrenAfterGroup);
  4181. keyParts.pop();
  4182. }
  4183. });
  4184. }
  4185. }
  4186. /***/ }),
  4187. /* 29 */
  4188. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  4189. "use strict";
  4190. __webpack_require__.r(__webpack_exports__);
  4191. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "convertToSet", function() { return convertToSet; });
  4192. /**
  4193. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  4194. * @version v23.2.1
  4195. * @link http://www.ag-grid.com/
  4196. * @license MIT
  4197. */
  4198. function convertToSet(list) {
  4199. var set = new Set();
  4200. list.forEach(function (x) { return set.add(x); });
  4201. return set;
  4202. }
  4203. /***/ }),
  4204. /* 30 */
  4205. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  4206. "use strict";
  4207. __webpack_require__.r(__webpack_exports__);
  4208. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "NumberSequence", function() { return NumberSequence; });
  4209. /**
  4210. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  4211. * @version v23.2.1
  4212. * @link http://www.ag-grid.com/
  4213. * @license MIT
  4214. */
  4215. var NumberSequence = /** @class */ (function () {
  4216. function NumberSequence(initValue, step) {
  4217. if (initValue === void 0) { initValue = 0; }
  4218. if (step === void 0) { step = 1; }
  4219. this.nextValue = initValue;
  4220. this.step = step;
  4221. }
  4222. NumberSequence.prototype.next = function () {
  4223. var valToReturn = this.nextValue;
  4224. this.nextValue += this.step;
  4225. return valToReturn;
  4226. };
  4227. NumberSequence.prototype.peek = function () {
  4228. return this.nextValue;
  4229. };
  4230. NumberSequence.prototype.skip = function (count) {
  4231. this.nextValue += count;
  4232. };
  4233. return NumberSequence;
  4234. }());
  4235. /***/ }),
  4236. /* 31 */
  4237. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  4238. "use strict";
  4239. __webpack_require__.r(__webpack_exports__);
  4240. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PromiseStatus", function() { return PromiseStatus; });
  4241. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Promise", function() { return Promise; });
  4242. /* harmony import */ var _array__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(17);
  4243. /**
  4244. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  4245. * @version v23.2.1
  4246. * @link http://www.ag-grid.com/
  4247. * @license MIT
  4248. */
  4249. var PromiseStatus;
  4250. (function (PromiseStatus) {
  4251. PromiseStatus[PromiseStatus["IN_PROGRESS"] = 0] = "IN_PROGRESS";
  4252. PromiseStatus[PromiseStatus["RESOLVED"] = 1] = "RESOLVED";
  4253. })(PromiseStatus || (PromiseStatus = {}));
  4254. var Promise = /** @class */ (function () {
  4255. function Promise(callback) {
  4256. var _this = this;
  4257. this.status = PromiseStatus.IN_PROGRESS;
  4258. this.resolution = null;
  4259. this.waiters = [];
  4260. callback(function (value) { return _this.onDone(value); }, function (params) { return _this.onReject(params); });
  4261. }
  4262. Promise.all = function (promises) {
  4263. return new Promise(function (resolve) {
  4264. var remainingToResolve = promises.length;
  4265. var combinedValues = new Array(remainingToResolve);
  4266. Object(_array__WEBPACK_IMPORTED_MODULE_0__["forEach"])(promises, function (promise, index) {
  4267. promise.then(function (value) {
  4268. combinedValues[index] = value;
  4269. remainingToResolve--;
  4270. if (remainingToResolve === 0) {
  4271. resolve(combinedValues);
  4272. }
  4273. });
  4274. });
  4275. });
  4276. };
  4277. Promise.resolve = function (value) {
  4278. if (value === void 0) { value = null; }
  4279. return new Promise(function (resolve) { return resolve(value); });
  4280. };
  4281. Promise.prototype.then = function (func) {
  4282. var _this = this;
  4283. return new Promise(function (resolve) {
  4284. if (_this.status === PromiseStatus.RESOLVED) {
  4285. resolve(func(_this.resolution));
  4286. }
  4287. else {
  4288. _this.waiters.push(function (value) { return resolve(func(value)); });
  4289. }
  4290. });
  4291. };
  4292. Promise.prototype.resolveNow = function (ifNotResolvedValue, ifResolved) {
  4293. return this.status === PromiseStatus.RESOLVED ? ifResolved(this.resolution) : ifNotResolvedValue;
  4294. };
  4295. Promise.prototype.onDone = function (value) {
  4296. this.status = PromiseStatus.RESOLVED;
  4297. this.resolution = value;
  4298. Object(_array__WEBPACK_IMPORTED_MODULE_0__["forEach"])(this.waiters, function (waiter) { return waiter(value); });
  4299. };
  4300. Promise.prototype.onReject = function (params) {
  4301. console.warn('TBI');
  4302. };
  4303. return Promise;
  4304. }());
  4305. /***/ }),
  4306. /* 32 */
  4307. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  4308. "use strict";
  4309. __webpack_require__.r(__webpack_exports__);
  4310. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Timer", function() { return Timer; });
  4311. /**
  4312. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  4313. * @version v23.2.1
  4314. * @link http://www.ag-grid.com/
  4315. * @license MIT
  4316. */
  4317. /**
  4318. * A Util Class only used when debugging for printing time to console
  4319. */
  4320. var Timer = /** @class */ (function () {
  4321. function Timer() {
  4322. this.timestamp = new Date().getTime();
  4323. }
  4324. Timer.prototype.print = function (msg) {
  4325. var duration = (new Date().getTime()) - this.timestamp;
  4326. console.info(msg + " = " + duration);
  4327. this.timestamp = new Date().getTime();
  4328. };
  4329. return Timer;
  4330. }());
  4331. /***/ }),
  4332. /* 33 */
  4333. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  4334. "use strict";
  4335. __webpack_require__.r(__webpack_exports__);
  4336. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "OriginalColumnGroup", function() { return OriginalColumnGroup; });
  4337. /* harmony import */ var _columnGroup__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(34);
  4338. /* harmony import */ var _column__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(35);
  4339. /* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(36);
  4340. /**
  4341. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  4342. * @version v23.2.1
  4343. * @link http://www.ag-grid.com/
  4344. * @license MIT
  4345. */
  4346. var OriginalColumnGroup = /** @class */ (function () {
  4347. function OriginalColumnGroup(colGroupDef, groupId, padding, level) {
  4348. this.localEventService = new _eventService__WEBPACK_IMPORTED_MODULE_2__["EventService"]();
  4349. this.expandable = false;
  4350. this.colGroupDef = colGroupDef;
  4351. this.groupId = groupId;
  4352. this.expanded = colGroupDef && !!colGroupDef.openByDefault;
  4353. this.padding = padding;
  4354. this.level = level;
  4355. }
  4356. OriginalColumnGroup.prototype.setOriginalParent = function (originalParent) {
  4357. this.originalParent = originalParent;
  4358. };
  4359. OriginalColumnGroup.prototype.getOriginalParent = function () {
  4360. return this.originalParent;
  4361. };
  4362. OriginalColumnGroup.prototype.getLevel = function () {
  4363. return this.level;
  4364. };
  4365. OriginalColumnGroup.prototype.isVisible = function () {
  4366. // return true if at least one child is visible
  4367. if (this.children) {
  4368. return this.children.some(function (child) { return child.isVisible(); });
  4369. }
  4370. return false;
  4371. };
  4372. OriginalColumnGroup.prototype.isPadding = function () {
  4373. return this.padding;
  4374. };
  4375. OriginalColumnGroup.prototype.setExpanded = function (expanded) {
  4376. this.expanded = expanded === undefined ? false : expanded;
  4377. var event = {
  4378. type: OriginalColumnGroup.EVENT_EXPANDED_CHANGED
  4379. };
  4380. this.localEventService.dispatchEvent(event);
  4381. };
  4382. OriginalColumnGroup.prototype.isExpandable = function () {
  4383. return this.expandable;
  4384. };
  4385. OriginalColumnGroup.prototype.isExpanded = function () {
  4386. return this.expanded;
  4387. };
  4388. OriginalColumnGroup.prototype.getGroupId = function () {
  4389. return this.groupId;
  4390. };
  4391. OriginalColumnGroup.prototype.getId = function () {
  4392. return this.getGroupId();
  4393. };
  4394. OriginalColumnGroup.prototype.setChildren = function (children) {
  4395. this.children = children;
  4396. };
  4397. OriginalColumnGroup.prototype.getChildren = function () {
  4398. return this.children;
  4399. };
  4400. OriginalColumnGroup.prototype.getColGroupDef = function () {
  4401. return this.colGroupDef;
  4402. };
  4403. OriginalColumnGroup.prototype.getLeafColumns = function () {
  4404. var result = [];
  4405. this.addLeafColumns(result);
  4406. return result;
  4407. };
  4408. OriginalColumnGroup.prototype.addLeafColumns = function (leafColumns) {
  4409. if (!this.children) {
  4410. return;
  4411. }
  4412. this.children.forEach(function (child) {
  4413. if (child instanceof _column__WEBPACK_IMPORTED_MODULE_1__["Column"]) {
  4414. leafColumns.push(child);
  4415. }
  4416. else if (child instanceof OriginalColumnGroup) {
  4417. child.addLeafColumns(leafColumns);
  4418. }
  4419. });
  4420. };
  4421. OriginalColumnGroup.prototype.getColumnGroupShow = function () {
  4422. return this.padding ? _columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"].HEADER_GROUP_PADDING : this.colGroupDef.columnGroupShow;
  4423. };
  4424. // need to check that this group has at least one col showing when both expanded and contracted.
  4425. // if not, then we don't allow expanding and contracting on this group
  4426. OriginalColumnGroup.prototype.setupExpandable = function () {
  4427. var _this = this;
  4428. this.setExpandable();
  4429. // note - we should be removing this event listener
  4430. this.getLeafColumns().forEach(function (col) { return col.addEventListener(_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_VISIBLE_CHANGED, _this.onColumnVisibilityChanged.bind(_this)); });
  4431. };
  4432. OriginalColumnGroup.prototype.setExpandable = function () {
  4433. if (this.isPadding()) {
  4434. return;
  4435. }
  4436. // want to make sure the group doesn't disappear when it's open
  4437. var atLeastOneShowingWhenOpen = false;
  4438. // want to make sure the group doesn't disappear when it's closed
  4439. var atLeastOneShowingWhenClosed = false;
  4440. // want to make sure the group has something to show / hide
  4441. var atLeastOneChangeable = false;
  4442. var children = this.findChildren();
  4443. for (var i = 0, j = children.length; i < j; i++) {
  4444. var abstractColumn = children[i];
  4445. if (!abstractColumn.isVisible()) {
  4446. continue;
  4447. }
  4448. // if the abstractColumn is a grid generated group, there will be no colDef
  4449. var headerGroupShow = abstractColumn.getColumnGroupShow();
  4450. if (headerGroupShow === _columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"].HEADER_GROUP_SHOW_OPEN) {
  4451. atLeastOneShowingWhenOpen = true;
  4452. atLeastOneChangeable = true;
  4453. }
  4454. else if (headerGroupShow === _columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"].HEADER_GROUP_SHOW_CLOSED) {
  4455. atLeastOneShowingWhenClosed = true;
  4456. atLeastOneChangeable = true;
  4457. }
  4458. else {
  4459. atLeastOneShowingWhenOpen = true;
  4460. atLeastOneShowingWhenClosed = true;
  4461. if (headerGroupShow === _columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"].HEADER_GROUP_PADDING) {
  4462. var column = abstractColumn;
  4463. atLeastOneChangeable = atLeastOneChangeable || column.children.some(function (child) { return child.getColumnGroupShow() !== undefined; });
  4464. }
  4465. }
  4466. }
  4467. var expandable = atLeastOneShowingWhenOpen && atLeastOneShowingWhenClosed && atLeastOneChangeable;
  4468. if (this.expandable !== expandable) {
  4469. this.expandable = expandable;
  4470. var event_1 = {
  4471. type: OriginalColumnGroup.EVENT_EXPANDABLE_CHANGED
  4472. };
  4473. this.localEventService.dispatchEvent(event_1);
  4474. }
  4475. };
  4476. OriginalColumnGroup.prototype.findChildren = function () {
  4477. var children = this.children;
  4478. var firstChild = children[0];
  4479. if (firstChild && (!firstChild.isPadding || !firstChild.isPadding())) {
  4480. return children;
  4481. }
  4482. while (children.length === 1 && children[0] instanceof OriginalColumnGroup) {
  4483. children = children[0].children;
  4484. }
  4485. return children;
  4486. };
  4487. OriginalColumnGroup.prototype.onColumnVisibilityChanged = function () {
  4488. this.setExpandable();
  4489. };
  4490. OriginalColumnGroup.prototype.addEventListener = function (eventType, listener) {
  4491. this.localEventService.addEventListener(eventType, listener);
  4492. };
  4493. OriginalColumnGroup.prototype.removeEventListener = function (eventType, listener) {
  4494. this.localEventService.removeEventListener(eventType, listener);
  4495. };
  4496. OriginalColumnGroup.EVENT_EXPANDED_CHANGED = 'expandedChanged';
  4497. OriginalColumnGroup.EVENT_EXPANDABLE_CHANGED = 'expandableChanged';
  4498. return OriginalColumnGroup;
  4499. }());
  4500. /***/ }),
  4501. /* 34 */
  4502. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  4503. "use strict";
  4504. __webpack_require__.r(__webpack_exports__);
  4505. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnGroup", function() { return ColumnGroup; });
  4506. /* harmony import */ var _column__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(35);
  4507. /* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(36);
  4508. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37);
  4509. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  4510. /**
  4511. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  4512. * @version v23.2.1
  4513. * @link http://www.ag-grid.com/
  4514. * @license MIT
  4515. */
  4516. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  4517. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  4518. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  4519. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  4520. return c > 3 && r && Object.defineProperty(target, key, r), r;
  4521. };
  4522. var ColumnGroup = /** @class */ (function () {
  4523. function ColumnGroup(originalColumnGroup, groupId, instanceId, pinned) {
  4524. // depends on the open/closed state of the group, only displaying columns are stored here
  4525. this.displayedChildren = [];
  4526. this.localEventService = new _eventService__WEBPACK_IMPORTED_MODULE_1__["EventService"]();
  4527. this.groupId = groupId;
  4528. this.instanceId = instanceId;
  4529. this.originalColumnGroup = originalColumnGroup;
  4530. this.pinned = pinned;
  4531. }
  4532. // this is static, a it is used outside of this class
  4533. ColumnGroup.createUniqueId = function (groupId, instanceId) {
  4534. return groupId + '_' + instanceId;
  4535. };
  4536. // as the user is adding and removing columns, the groups are recalculated.
  4537. // this reset clears out all children, ready for children to be added again
  4538. ColumnGroup.prototype.reset = function () {
  4539. this.parent = null;
  4540. this.children = null;
  4541. this.displayedChildren = null;
  4542. };
  4543. ColumnGroup.prototype.getParent = function () {
  4544. return this.parent;
  4545. };
  4546. ColumnGroup.prototype.setParent = function (parent) {
  4547. this.parent = parent;
  4548. };
  4549. ColumnGroup.prototype.getUniqueId = function () {
  4550. return ColumnGroup.createUniqueId(this.groupId, this.instanceId);
  4551. };
  4552. ColumnGroup.prototype.isEmptyGroup = function () {
  4553. return this.displayedChildren.length === 0;
  4554. };
  4555. ColumnGroup.prototype.isMoving = function () {
  4556. var allLeafColumns = this.getOriginalColumnGroup().getLeafColumns();
  4557. if (!allLeafColumns || allLeafColumns.length === 0) {
  4558. return false;
  4559. }
  4560. return allLeafColumns.every(function (col) { return col.isMoving(); });
  4561. };
  4562. ColumnGroup.prototype.checkLeft = function () {
  4563. // first get all children to setLeft, as it impacts our decision below
  4564. this.displayedChildren.forEach(function (child) {
  4565. if (child instanceof ColumnGroup) {
  4566. child.checkLeft();
  4567. }
  4568. });
  4569. // set our left based on first displayed column
  4570. if (this.displayedChildren.length > 0) {
  4571. if (this.gridOptionsWrapper.isEnableRtl()) {
  4572. var lastChild = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].last(this.displayedChildren);
  4573. var lastChildLeft = lastChild.getLeft();
  4574. this.setLeft(lastChildLeft);
  4575. }
  4576. else {
  4577. var firstChildLeft = this.displayedChildren[0].getLeft();
  4578. this.setLeft(firstChildLeft);
  4579. }
  4580. }
  4581. else {
  4582. // this should never happen, as if we have no displayed columns, then
  4583. // this groups should not even exist.
  4584. this.setLeft(null);
  4585. }
  4586. };
  4587. ColumnGroup.prototype.getLeft = function () {
  4588. return this.left;
  4589. };
  4590. ColumnGroup.prototype.getOldLeft = function () {
  4591. return this.oldLeft;
  4592. };
  4593. ColumnGroup.prototype.setLeft = function (left) {
  4594. this.oldLeft = left;
  4595. if (this.left !== left) {
  4596. this.left = left;
  4597. this.localEventService.dispatchEvent(this.createAgEvent(ColumnGroup.EVENT_LEFT_CHANGED));
  4598. }
  4599. };
  4600. ColumnGroup.prototype.getPinned = function () {
  4601. return this.pinned;
  4602. };
  4603. ColumnGroup.prototype.createAgEvent = function (type) {
  4604. return { type: type };
  4605. };
  4606. ColumnGroup.prototype.addEventListener = function (eventType, listener) {
  4607. this.localEventService.addEventListener(eventType, listener);
  4608. };
  4609. ColumnGroup.prototype.removeEventListener = function (eventType, listener) {
  4610. this.localEventService.removeEventListener(eventType, listener);
  4611. };
  4612. ColumnGroup.prototype.getGroupId = function () {
  4613. return this.groupId;
  4614. };
  4615. ColumnGroup.prototype.getInstanceId = function () {
  4616. return this.instanceId;
  4617. };
  4618. ColumnGroup.prototype.isChildInThisGroupDeepSearch = function (wantedChild) {
  4619. var result = false;
  4620. this.children.forEach(function (foundChild) {
  4621. if (wantedChild === foundChild) {
  4622. result = true;
  4623. }
  4624. if (foundChild instanceof ColumnGroup) {
  4625. if (foundChild.isChildInThisGroupDeepSearch(wantedChild)) {
  4626. result = true;
  4627. }
  4628. }
  4629. });
  4630. return result;
  4631. };
  4632. ColumnGroup.prototype.getActualWidth = function () {
  4633. var groupActualWidth = 0;
  4634. if (this.displayedChildren) {
  4635. this.displayedChildren.forEach(function (child) {
  4636. groupActualWidth += child.getActualWidth();
  4637. });
  4638. }
  4639. return groupActualWidth;
  4640. };
  4641. ColumnGroup.prototype.isResizable = function () {
  4642. if (!this.displayedChildren) {
  4643. return false;
  4644. }
  4645. // if at least one child is resizable, then the group is resizable
  4646. var result = false;
  4647. this.displayedChildren.forEach(function (child) {
  4648. if (child.isResizable()) {
  4649. result = true;
  4650. }
  4651. });
  4652. return result;
  4653. };
  4654. ColumnGroup.prototype.getMinWidth = function () {
  4655. var result = 0;
  4656. this.displayedChildren.forEach(function (groupChild) {
  4657. result += groupChild.getMinWidth();
  4658. });
  4659. return result;
  4660. };
  4661. ColumnGroup.prototype.addChild = function (child) {
  4662. if (!this.children) {
  4663. this.children = [];
  4664. }
  4665. this.children.push(child);
  4666. };
  4667. ColumnGroup.prototype.getDisplayedChildren = function () {
  4668. return this.displayedChildren;
  4669. };
  4670. ColumnGroup.prototype.getLeafColumns = function () {
  4671. var result = [];
  4672. this.addLeafColumns(result);
  4673. return result;
  4674. };
  4675. ColumnGroup.prototype.getDisplayedLeafColumns = function () {
  4676. var result = [];
  4677. this.addDisplayedLeafColumns(result);
  4678. return result;
  4679. };
  4680. // why two methods here doing the same thing?
  4681. ColumnGroup.prototype.getDefinition = function () {
  4682. return this.originalColumnGroup.getColGroupDef();
  4683. };
  4684. ColumnGroup.prototype.getColGroupDef = function () {
  4685. return this.originalColumnGroup.getColGroupDef();
  4686. };
  4687. ColumnGroup.prototype.isPadding = function () {
  4688. return this.originalColumnGroup.isPadding();
  4689. };
  4690. ColumnGroup.prototype.isExpandable = function () {
  4691. return this.originalColumnGroup.isExpandable();
  4692. };
  4693. ColumnGroup.prototype.isExpanded = function () {
  4694. return this.originalColumnGroup.isExpanded();
  4695. };
  4696. ColumnGroup.prototype.setExpanded = function (expanded) {
  4697. this.originalColumnGroup.setExpanded(expanded);
  4698. };
  4699. ColumnGroup.prototype.addDisplayedLeafColumns = function (leafColumns) {
  4700. this.displayedChildren.forEach(function (child) {
  4701. if (child instanceof _column__WEBPACK_IMPORTED_MODULE_0__["Column"]) {
  4702. leafColumns.push(child);
  4703. }
  4704. else if (child instanceof ColumnGroup) {
  4705. child.addDisplayedLeafColumns(leafColumns);
  4706. }
  4707. });
  4708. };
  4709. ColumnGroup.prototype.addLeafColumns = function (leafColumns) {
  4710. this.children.forEach(function (child) {
  4711. if (child instanceof _column__WEBPACK_IMPORTED_MODULE_0__["Column"]) {
  4712. leafColumns.push(child);
  4713. }
  4714. else if (child instanceof ColumnGroup) {
  4715. child.addLeafColumns(leafColumns);
  4716. }
  4717. });
  4718. };
  4719. ColumnGroup.prototype.getChildren = function () {
  4720. return this.children;
  4721. };
  4722. ColumnGroup.prototype.getColumnGroupShow = function () {
  4723. return this.originalColumnGroup.getColumnGroupShow();
  4724. };
  4725. ColumnGroup.prototype.getOriginalColumnGroup = function () {
  4726. return this.originalColumnGroup;
  4727. };
  4728. ColumnGroup.prototype.getPaddingLevel = function () {
  4729. var parent = this.getParent();
  4730. if (!this.isPadding() || !parent || !parent.isPadding()) {
  4731. return 0;
  4732. }
  4733. return 1 + parent.getPaddingLevel();
  4734. };
  4735. ColumnGroup.prototype.calculateDisplayedColumns = function () {
  4736. var _this = this;
  4737. // clear out last time we calculated
  4738. this.displayedChildren = [];
  4739. var topLevelGroup = this;
  4740. // find the column group that is controlling expandable. this is relevant when we have padding (empty)
  4741. // groups, where the expandable is actually the first parent that is not a padding group.
  4742. if (this.isPadding()) {
  4743. while (topLevelGroup.getParent() && topLevelGroup.isPadding()) {
  4744. topLevelGroup = topLevelGroup.getParent();
  4745. }
  4746. }
  4747. var isExpandable = topLevelGroup.originalColumnGroup.isExpandable();
  4748. // it not expandable, everything is visible
  4749. if (!isExpandable) {
  4750. this.displayedChildren = this.children;
  4751. }
  4752. else {
  4753. // Add cols based on columnGroupShow
  4754. // Note - the below also adds padding groups, these are always added because they never have
  4755. // colDef.columnGroupShow set.
  4756. this.children.forEach(function (abstractColumn) {
  4757. var headerGroupShow = abstractColumn.getColumnGroupShow();
  4758. switch (headerGroupShow) {
  4759. case ColumnGroup.HEADER_GROUP_SHOW_OPEN:
  4760. // when set to open, only show col if group is open
  4761. if (topLevelGroup.originalColumnGroup.isExpanded()) {
  4762. _this.displayedChildren.push(abstractColumn);
  4763. }
  4764. break;
  4765. case ColumnGroup.HEADER_GROUP_SHOW_CLOSED:
  4766. // when set to open, only show col if group is open
  4767. if (!topLevelGroup.originalColumnGroup.isExpanded()) {
  4768. _this.displayedChildren.push(abstractColumn);
  4769. }
  4770. break;
  4771. default:
  4772. // if this abstractColumn is padding, we just want to add it
  4773. // to the displayedChildren list if it has displayedChildren itself.
  4774. if (!(abstractColumn instanceof ColumnGroup &&
  4775. abstractColumn.isPadding() &&
  4776. !abstractColumn.displayedChildren.length)) {
  4777. _this.displayedChildren.push(abstractColumn);
  4778. }
  4779. break;
  4780. }
  4781. });
  4782. }
  4783. this.localEventService.dispatchEvent(this.createAgEvent(ColumnGroup.EVENT_DISPLAYED_CHILDREN_CHANGED));
  4784. };
  4785. ColumnGroup.HEADER_GROUP_SHOW_OPEN = 'open';
  4786. ColumnGroup.HEADER_GROUP_SHOW_CLOSED = 'closed';
  4787. ColumnGroup.HEADER_GROUP_PADDING = 'padding';
  4788. ColumnGroup.EVENT_LEFT_CHANGED = 'leftChanged';
  4789. ColumnGroup.EVENT_DISPLAYED_CHILDREN_CHANGED = 'displayedChildrenChanged';
  4790. __decorate([
  4791. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper')
  4792. ], ColumnGroup.prototype, "gridOptionsWrapper", void 0);
  4793. return ColumnGroup;
  4794. }());
  4795. /***/ }),
  4796. /* 35 */
  4797. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  4798. "use strict";
  4799. __webpack_require__.r(__webpack_exports__);
  4800. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Column", function() { return Column; });
  4801. /* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36);
  4802. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7);
  4803. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37);
  4804. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25);
  4805. /* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(38);
  4806. /* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(39);
  4807. /**
  4808. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  4809. * @version v23.2.1
  4810. * @link http://www.ag-grid.com/
  4811. * @license MIT
  4812. */
  4813. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  4814. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  4815. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  4816. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  4817. return c > 3 && r && Object.defineProperty(target, key, r), r;
  4818. };
  4819. // Wrapper around a user provide column definition. The grid treats the column definition as ready only.
  4820. // This class contains all the runtime information about a column, plus some logic (the definition has no logic).
  4821. // This class implements both interfaces ColumnGroupChild and OriginalColumnGroupChild as the class can
  4822. // appear as a child of either the original tree or the displayed tree. However the relevant group classes
  4823. // for each type only implements one, as each group can only appear in it's associated tree (eg OriginalColumnGroup
  4824. // can only appear in OriginalColumn tree).
  4825. var Column = /** @class */ (function () {
  4826. function Column(colDef, userProvidedColDef, colId, primary) {
  4827. this.moving = false;
  4828. this.menuVisible = false;
  4829. this.filterActive = false;
  4830. this.eventService = new _eventService__WEBPACK_IMPORTED_MODULE_0__["EventService"]();
  4831. this.rowGroupActive = false;
  4832. this.pivotActive = false;
  4833. this.aggregationActive = false;
  4834. this.colDef = colDef;
  4835. this.userProvidedColDef = userProvidedColDef;
  4836. this.visible = !colDef.hide;
  4837. this.sort = colDef.sort;
  4838. this.sortedAt = colDef.sortedAt;
  4839. this.colId = colId;
  4840. this.primary = primary;
  4841. }
  4842. // gets called when user provides an alternative colDef, eg
  4843. Column.prototype.setColDef = function (colDef, userProvidedColDef) {
  4844. this.colDef = colDef;
  4845. this.userProvidedColDef = userProvidedColDef;
  4846. };
  4847. Column.prototype.getUserProvidedColDef = function () {
  4848. return this.userProvidedColDef;
  4849. };
  4850. Column.prototype.setParent = function (parent) {
  4851. this.parent = parent;
  4852. };
  4853. Column.prototype.getParent = function () {
  4854. return this.parent;
  4855. };
  4856. Column.prototype.setOriginalParent = function (originalParent) {
  4857. this.originalParent = originalParent;
  4858. };
  4859. Column.prototype.getOriginalParent = function () {
  4860. return this.originalParent;
  4861. };
  4862. // this is done after constructor as it uses gridOptionsWrapper
  4863. Column.prototype.initialise = function () {
  4864. this.setPinned(this.colDef.pinned);
  4865. var minColWidth = this.gridOptionsWrapper.getMinColWidth();
  4866. var maxColWidth = this.gridOptionsWrapper.getMaxColWidth();
  4867. if (this.colDef.minWidth) {
  4868. this.minWidth = this.colDef.minWidth;
  4869. }
  4870. else {
  4871. this.minWidth = minColWidth;
  4872. }
  4873. if (this.colDef.maxWidth) {
  4874. this.maxWidth = this.colDef.maxWidth;
  4875. }
  4876. else {
  4877. this.maxWidth = maxColWidth;
  4878. }
  4879. if (this.colDef.flex) {
  4880. this.flex = this.colDef.flex;
  4881. }
  4882. this.resetActualWidth();
  4883. var suppressDotNotation = this.gridOptionsWrapper.isSuppressFieldDotNotation();
  4884. this.fieldContainsDots = _utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(this.colDef.field) && this.colDef.field.indexOf('.') >= 0 && !suppressDotNotation;
  4885. this.tooltipFieldContainsDots = _utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(this.colDef.tooltipField) && this.colDef.tooltipField.indexOf('.') >= 0 && !suppressDotNotation;
  4886. this.validate();
  4887. };
  4888. Column.prototype.resetActualWidth = function () {
  4889. this.actualWidth = this.columnUtils.calculateColInitialWidth(this.colDef);
  4890. };
  4891. Column.prototype.isEmptyGroup = function () {
  4892. return false;
  4893. };
  4894. Column.prototype.isRowGroupDisplayed = function (colId) {
  4895. if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].missing(this.colDef) || _utils__WEBPACK_IMPORTED_MODULE_1__["_"].missing(this.colDef.showRowGroup)) {
  4896. return false;
  4897. }
  4898. var showingAllGroups = this.colDef.showRowGroup === true;
  4899. var showingThisGroup = this.colDef.showRowGroup === colId;
  4900. return showingAllGroups || showingThisGroup;
  4901. };
  4902. Column.prototype.getUniqueId = function () {
  4903. return this.getId();
  4904. };
  4905. Column.prototype.isPrimary = function () {
  4906. return this.primary;
  4907. };
  4908. Column.prototype.isFilterAllowed = function () {
  4909. // filter defined means it's a string, class or true.
  4910. // if its false, null or undefined then it's false.
  4911. var filterDefined = !!this.colDef.filter || !!this.colDef.filterFramework;
  4912. return this.primary && filterDefined;
  4913. };
  4914. Column.prototype.isFieldContainsDots = function () {
  4915. return this.fieldContainsDots;
  4916. };
  4917. Column.prototype.isTooltipFieldContainsDots = function () {
  4918. return this.tooltipFieldContainsDots;
  4919. };
  4920. Column.prototype.validate = function () {
  4921. var colDefAny = this.colDef;
  4922. function warnOnce(msg, key, obj) {
  4923. _utils__WEBPACK_IMPORTED_MODULE_1__["_"].doOnce(function () {
  4924. if (obj) {
  4925. console.warn(msg, obj);
  4926. }
  4927. else {
  4928. _utils__WEBPACK_IMPORTED_MODULE_1__["_"].doOnce(function () { return console.warn(msg); }, key);
  4929. }
  4930. }, key);
  4931. }
  4932. if (!_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].RowGroupingModule)) {
  4933. var rowGroupingItems = ['enableRowGroup', 'rowGroup', 'rowGroupIndex', 'enablePivot', 'enableValue', 'pivot', 'pivotIndex', 'aggFunc'];
  4934. rowGroupingItems.forEach(function (item) {
  4935. if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(colDefAny[item])) {
  4936. if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isPackageBased()) {
  4937. warnOnce("ag-Grid: " + item + " is only valid in ag-grid-enterprise, your column definition should not have " + item, 'ColumnRowGroupingMissing' + item);
  4938. }
  4939. else {
  4940. warnOnce("ag-Grid: " + item + " is only valid with ag-Grid Enterprise Module " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].RowGroupingModule + " - your column definition should not have " + item, 'ColumnRowGroupingMissing' + item);
  4941. }
  4942. }
  4943. });
  4944. }
  4945. if (!_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].RichSelectModule)) {
  4946. if (this.colDef.cellEditor === 'agRichSelect' || this.colDef.cellEditor === 'agRichSelectCellEditor') {
  4947. if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isPackageBased()) {
  4948. warnOnce("ag-Grid: " + this.colDef.cellEditor + " can only be used with ag-grid-enterprise", 'ColumnRichSelectMissing');
  4949. }
  4950. else {
  4951. warnOnce("ag-Grid: " + this.colDef.cellEditor + " can only be used with ag-Grid Enterprise Module " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].RichSelectModule, 'ColumnRichSelectMissing');
  4952. }
  4953. }
  4954. }
  4955. if (!_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].DateTimeCellEditorModule)) {
  4956. if (this.colDef.cellEditor === 'agRichSelect' || this.colDef.cellEditor === 'agDateTimeCellEditor') {
  4957. if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isPackageBased()) {
  4958. warnOnce("ag-Grid: " + this.colDef.cellEditor + " can only be used with ag-grid-enterprise", 'ColumnDateTimeMissing');
  4959. }
  4960. else {
  4961. warnOnce("ag-Grid: " + this.colDef.cellEditor + " can only be used with ag-Grid Enterprise Module " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].DateTimeCellEditorModule, 'ColumnDateTimeMissing');
  4962. }
  4963. }
  4964. }
  4965. if (this.gridOptionsWrapper.isTreeData()) {
  4966. var itemsNotAllowedWithTreeData = ['rowGroup', 'rowGroupIndex', 'pivot', 'pivotIndex'];
  4967. itemsNotAllowedWithTreeData.forEach(function (item) {
  4968. if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(colDefAny[item])) {
  4969. warnOnce("ag-Grid: " + item + " is not possible when doing tree data, your column definition should not have " + item, 'TreeDataCannotRowGroup');
  4970. }
  4971. });
  4972. }
  4973. if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(this.colDef.width) && typeof this.colDef.width !== 'number') {
  4974. warnOnce('ag-Grid: colDef.width should be a number, not ' + typeof this.colDef.width, 'ColumnCheck_asdfawef');
  4975. }
  4976. if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].get(this, 'colDef.cellRendererParams.restrictToOneGroup', null)) {
  4977. warnOnce('ag-Grid: Since ag-grid 11.0.0 cellRendererParams.restrictToOneGroup is deprecated. You should use showRowGroup', 'ColumnCheck_sksldjf');
  4978. }
  4979. if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].get(this, 'colDef.cellRendererParams.keyMap', null)) {
  4980. warnOnce('ag-Grid: Since ag-grid 11.0.0 cellRendererParams.keyMap is deprecated. You should use colDef.keyCreator', 'ColumnCheck_ieiruhgdf');
  4981. }
  4982. if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].get(this, 'colDef.cellRendererParams.keyMap', null)) {
  4983. warnOnce('ag-Grid: Since ag-grid 11.0.0 cellRendererParams.keyMap is deprecated. You should use colDef.keyCreator', 'ColumnCheck_uitolghj');
  4984. }
  4985. if (colDefAny.floatingCellRenderer) {
  4986. warnOnce('ag-Grid: since v11, floatingCellRenderer is now pinnedRowCellRenderer', 'ColumnCheck_soihwewe');
  4987. this.colDef.pinnedRowCellRenderer = colDefAny.floatingCellRenderer;
  4988. }
  4989. if (colDefAny.floatingRendererFramework) {
  4990. warnOnce('ag-Grid: since v11, floatingRendererFramework is now pinnedRowCellRendererFramework', 'ColumnCheck_zdkiouhwer');
  4991. this.colDef.pinnedRowCellRendererFramework = colDefAny.floatingRendererFramework;
  4992. }
  4993. if (colDefAny.floatingRendererParams) {
  4994. console.warn('ag-Grid: since v11, floatingRendererParams is now pinnedRowCellRendererParams', 'ColumnCheck_retiuhjs');
  4995. this.colDef.pinnedRowCellRendererParams = colDefAny.floatingRendererParams;
  4996. }
  4997. if (colDefAny.floatingValueFormatter) {
  4998. warnOnce('ag-Grid: since v11, floatingValueFormatter is now pinnedRowValueFormatter', 'ColumnCheck_qwroeihjdf');
  4999. this.colDef.pinnedRowValueFormatter = colDefAny.floatingValueFormatter;
  5000. }
  5001. if (colDefAny.cellFormatter) {
  5002. warnOnce('ag-Grid: since v12, cellFormatter is now valueFormatter', 'ColumnCheck_eoireknml');
  5003. if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].missing(this.colDef.valueFormatter)) {
  5004. this.colDef.valueFormatter = colDefAny.cellFormatter;
  5005. }
  5006. }
  5007. if (colDefAny.headerCellTemplate) {
  5008. warnOnce('ag-Grid: since v15, headerCellTemplate is gone, use header component instead.', 'ColumnCheck_eroihxcm');
  5009. }
  5010. if (colDefAny.headerCellRenderer) {
  5011. warnOnce('ag-Grid: since v15, headerCellRenderer is gone, use header component instead.', 'ColumnCheck_terteuh');
  5012. }
  5013. if (colDefAny.volatile) {
  5014. warnOnce('ag-Grid: since v16, colDef.volatile is gone, please check refresh docs on how to refresh specific cells.', 'ColumnCheck_weoihjxcv');
  5015. }
  5016. if (colDefAny.suppressSorting) {
  5017. warnOnce("ag-Grid: since v20, colDef.suppressSorting is gone, instead use colDef.sortable=false.", 'ColumnCheck_43ljrer', this.colDef);
  5018. this.colDef.sortable = false;
  5019. }
  5020. if (colDefAny.suppressFilter) {
  5021. warnOnce("ag-Grid: since v20, colDef.suppressFilter is gone, instead use colDef.filter=false.", 'ColumnCheck_erlkhfdm', this.colDef);
  5022. this.colDef.filter = false;
  5023. }
  5024. if (colDefAny.suppressResize) {
  5025. warnOnce("ag-Grid: since v20, colDef.suppressResize is gone, instead use colDef.resizable=false.", 'ColumnCheck_weoihjxcv', this.colDef);
  5026. this.colDef.resizable = false;
  5027. }
  5028. if (colDefAny.tooltip) {
  5029. warnOnce("ag-Grid: since v20.1, colDef.tooltip is gone, instead use colDef.tooltipValueGetter.", 'ColumnCheck_adslknjwef', this.colDef);
  5030. this.colDef.tooltipValueGetter = colDefAny.tooltip;
  5031. }
  5032. if (colDefAny.suppressToolPanel) {
  5033. warnOnce("ag-Grid: since v22, colDef.suppressToolPanel is gone, instead use suppressColumnsToolPanel / suppressFiltersToolPanel.", 'ColumnCheck_weihjlsjkdf', this.colDef);
  5034. this.colDef.suppressColumnsToolPanel = true;
  5035. }
  5036. };
  5037. Column.prototype.addEventListener = function (eventType, listener) {
  5038. this.eventService.addEventListener(eventType, listener);
  5039. };
  5040. Column.prototype.removeEventListener = function (eventType, listener) {
  5041. this.eventService.removeEventListener(eventType, listener);
  5042. };
  5043. Column.prototype.createIsColumnFuncParams = function (rowNode) {
  5044. return {
  5045. node: rowNode,
  5046. data: rowNode.data,
  5047. column: this,
  5048. colDef: this.colDef,
  5049. context: this.gridOptionsWrapper.getContext(),
  5050. api: this.gridOptionsWrapper.getApi(),
  5051. columnApi: this.gridOptionsWrapper.getColumnApi()
  5052. };
  5053. };
  5054. Column.prototype.isSuppressNavigable = function (rowNode) {
  5055. // if boolean set, then just use it
  5056. if (typeof this.colDef.suppressNavigable === 'boolean') {
  5057. return this.colDef.suppressNavigable;
  5058. }
  5059. // if function, then call the function to find out
  5060. if (typeof this.colDef.suppressNavigable === 'function') {
  5061. var params = this.createIsColumnFuncParams(rowNode);
  5062. var userFunc = this.colDef.suppressNavigable;
  5063. return userFunc(params);
  5064. }
  5065. return false;
  5066. };
  5067. Column.prototype.isCellEditable = function (rowNode) {
  5068. // only allow editing of groups if the user has this option enabled
  5069. if (rowNode.group && !this.gridOptionsWrapper.isEnableGroupEdit()) {
  5070. return false;
  5071. }
  5072. return this.isColumnFunc(rowNode, this.colDef.editable);
  5073. };
  5074. Column.prototype.isRowDrag = function (rowNode) {
  5075. return this.isColumnFunc(rowNode, this.colDef.rowDrag);
  5076. };
  5077. Column.prototype.isDndSource = function (rowNode) {
  5078. return this.isColumnFunc(rowNode, this.colDef.dndSource);
  5079. };
  5080. Column.prototype.isCellCheckboxSelection = function (rowNode) {
  5081. return this.isColumnFunc(rowNode, this.colDef.checkboxSelection);
  5082. };
  5083. Column.prototype.isSuppressPaste = function (rowNode) {
  5084. return this.isColumnFunc(rowNode, this.colDef ? this.colDef.suppressPaste : null);
  5085. };
  5086. Column.prototype.isResizable = function () {
  5087. return this.colDef.resizable === true;
  5088. };
  5089. Column.prototype.isColumnFunc = function (rowNode, value) {
  5090. // if boolean set, then just use it
  5091. if (typeof value === 'boolean') {
  5092. return value;
  5093. }
  5094. // if function, then call the function to find out
  5095. if (typeof value === 'function') {
  5096. var params = this.createIsColumnFuncParams(rowNode);
  5097. var editableFunc = value;
  5098. return editableFunc(params);
  5099. }
  5100. return false;
  5101. };
  5102. Column.prototype.setMoving = function (moving, source) {
  5103. if (source === void 0) { source = "api"; }
  5104. this.moving = moving;
  5105. this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_MOVING_CHANGED, source));
  5106. };
  5107. Column.prototype.createColumnEvent = function (type, source) {
  5108. return {
  5109. api: this.gridApi,
  5110. columnApi: this.columnApi,
  5111. type: type,
  5112. column: this,
  5113. columns: [this],
  5114. source: source
  5115. };
  5116. };
  5117. Column.prototype.isMoving = function () {
  5118. return this.moving;
  5119. };
  5120. Column.prototype.getSort = function () {
  5121. return this.sort;
  5122. };
  5123. Column.prototype.setSort = function (sort, source) {
  5124. if (source === void 0) { source = "api"; }
  5125. if (this.sort !== sort) {
  5126. this.sort = sort;
  5127. this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_SORT_CHANGED, source));
  5128. }
  5129. };
  5130. Column.prototype.setMenuVisible = function (visible, source) {
  5131. if (source === void 0) { source = "api"; }
  5132. if (this.menuVisible !== visible) {
  5133. this.menuVisible = visible;
  5134. this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_MENU_VISIBLE_CHANGED, source));
  5135. }
  5136. };
  5137. Column.prototype.isMenuVisible = function () {
  5138. return this.menuVisible;
  5139. };
  5140. Column.prototype.isSortAscending = function () {
  5141. return this.sort === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].SORT_ASC;
  5142. };
  5143. Column.prototype.isSortDescending = function () {
  5144. return this.sort === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].SORT_DESC;
  5145. };
  5146. Column.prototype.isSortNone = function () {
  5147. return _utils__WEBPACK_IMPORTED_MODULE_1__["_"].missing(this.sort);
  5148. };
  5149. Column.prototype.isSorting = function () {
  5150. return _utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(this.sort);
  5151. };
  5152. Column.prototype.getSortedAt = function () {
  5153. return this.sortedAt;
  5154. };
  5155. Column.prototype.setSortedAt = function (sortedAt) {
  5156. this.sortedAt = sortedAt;
  5157. };
  5158. Column.prototype.setAggFunc = function (aggFunc) {
  5159. this.aggFunc = aggFunc;
  5160. };
  5161. Column.prototype.getAggFunc = function () {
  5162. return this.aggFunc;
  5163. };
  5164. Column.prototype.getLeft = function () {
  5165. return this.left;
  5166. };
  5167. Column.prototype.getOldLeft = function () {
  5168. return this.oldLeft;
  5169. };
  5170. Column.prototype.getRight = function () {
  5171. return this.left + this.actualWidth;
  5172. };
  5173. Column.prototype.setLeft = function (left, source) {
  5174. if (source === void 0) { source = "api"; }
  5175. this.oldLeft = this.left;
  5176. if (this.left !== left) {
  5177. this.left = left;
  5178. this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_LEFT_CHANGED, source));
  5179. }
  5180. };
  5181. Column.prototype.isFilterActive = function () {
  5182. return this.filterActive;
  5183. };
  5184. // additionalEventAttributes is used by provided simple floating filter, so it can add 'floatingFilter=true' to the event
  5185. Column.prototype.setFilterActive = function (active, source, additionalEventAttributes) {
  5186. if (source === void 0) { source = "api"; }
  5187. if (this.filterActive !== active) {
  5188. this.filterActive = active;
  5189. this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_FILTER_ACTIVE_CHANGED, source));
  5190. }
  5191. var filterChangedEvent = this.createColumnEvent(Column.EVENT_FILTER_CHANGED, source);
  5192. if (additionalEventAttributes) {
  5193. _utils__WEBPACK_IMPORTED_MODULE_1__["_"].mergeDeep(filterChangedEvent, additionalEventAttributes);
  5194. }
  5195. this.eventService.dispatchEvent(filterChangedEvent);
  5196. };
  5197. Column.prototype.setPinned = function (pinned) {
  5198. if (pinned === true || pinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_LEFT) {
  5199. this.pinned = _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_LEFT;
  5200. }
  5201. else if (pinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_RIGHT) {
  5202. this.pinned = _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_RIGHT;
  5203. }
  5204. else {
  5205. this.pinned = null;
  5206. }
  5207. };
  5208. Column.prototype.setFirstRightPinned = function (firstRightPinned, source) {
  5209. if (source === void 0) { source = "api"; }
  5210. if (this.firstRightPinned !== firstRightPinned) {
  5211. this.firstRightPinned = firstRightPinned;
  5212. this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_FIRST_RIGHT_PINNED_CHANGED, source));
  5213. }
  5214. };
  5215. Column.prototype.setLastLeftPinned = function (lastLeftPinned, source) {
  5216. if (source === void 0) { source = "api"; }
  5217. if (this.lastLeftPinned !== lastLeftPinned) {
  5218. this.lastLeftPinned = lastLeftPinned;
  5219. this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_LAST_LEFT_PINNED_CHANGED, source));
  5220. }
  5221. };
  5222. Column.prototype.isFirstRightPinned = function () {
  5223. return this.firstRightPinned;
  5224. };
  5225. Column.prototype.isLastLeftPinned = function () {
  5226. return this.lastLeftPinned;
  5227. };
  5228. Column.prototype.isPinned = function () {
  5229. return this.pinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_LEFT || this.pinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_RIGHT;
  5230. };
  5231. Column.prototype.isPinnedLeft = function () {
  5232. return this.pinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_LEFT;
  5233. };
  5234. Column.prototype.isPinnedRight = function () {
  5235. return this.pinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_RIGHT;
  5236. };
  5237. Column.prototype.getPinned = function () {
  5238. return this.pinned;
  5239. };
  5240. Column.prototype.setVisible = function (visible, source) {
  5241. if (source === void 0) { source = "api"; }
  5242. var newValue = visible === true;
  5243. if (this.visible !== newValue) {
  5244. this.visible = newValue;
  5245. this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_VISIBLE_CHANGED, source));
  5246. }
  5247. };
  5248. Column.prototype.isVisible = function () {
  5249. return this.visible;
  5250. };
  5251. Column.prototype.getColDef = function () {
  5252. return this.colDef;
  5253. };
  5254. Column.prototype.getColumnGroupShow = function () {
  5255. return this.colDef.columnGroupShow;
  5256. };
  5257. Column.prototype.getColId = function () {
  5258. return this.colId;
  5259. };
  5260. Column.prototype.getId = function () {
  5261. return this.getColId();
  5262. };
  5263. Column.prototype.getDefinition = function () {
  5264. return this.colDef;
  5265. };
  5266. Column.prototype.getActualWidth = function () {
  5267. return this.actualWidth;
  5268. };
  5269. Column.prototype.createBaseColDefParams = function (rowNode) {
  5270. var params = {
  5271. node: rowNode,
  5272. data: rowNode.data,
  5273. colDef: this.colDef,
  5274. column: this,
  5275. api: this.gridOptionsWrapper.getApi(),
  5276. columnApi: this.gridOptionsWrapper.getColumnApi(),
  5277. context: this.gridOptionsWrapper.getContext()
  5278. };
  5279. return params;
  5280. };
  5281. Column.prototype.getColSpan = function (rowNode) {
  5282. if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].missing(this.colDef.colSpan)) {
  5283. return 1;
  5284. }
  5285. var params = this.createBaseColDefParams(rowNode);
  5286. var colSpan = this.colDef.colSpan(params);
  5287. // colSpan must be number equal to or greater than 1
  5288. return Math.max(colSpan, 1);
  5289. };
  5290. Column.prototype.getRowSpan = function (rowNode) {
  5291. if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].missing(this.colDef.rowSpan)) {
  5292. return 1;
  5293. }
  5294. var params = this.createBaseColDefParams(rowNode);
  5295. var rowSpan = this.colDef.rowSpan(params);
  5296. // rowSpan must be number equal to or greater than 1
  5297. return Math.max(rowSpan, 1);
  5298. };
  5299. Column.prototype.setActualWidth = function (actualWidth, source) {
  5300. if (source === void 0) { source = "api"; }
  5301. if (this.minWidth != null) {
  5302. actualWidth = Math.max(actualWidth, this.minWidth);
  5303. }
  5304. if (this.maxWidth != null) {
  5305. actualWidth = Math.min(actualWidth, this.maxWidth);
  5306. }
  5307. if (this.actualWidth !== actualWidth) {
  5308. // disable flex for this column if it was manually resized.
  5309. if (this.flex && source !== 'flex') {
  5310. this.flex = 0;
  5311. }
  5312. this.actualWidth = actualWidth;
  5313. this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_WIDTH_CHANGED, source));
  5314. }
  5315. };
  5316. Column.prototype.isGreaterThanMax = function (width) {
  5317. if (this.maxWidth != null) {
  5318. return width > this.maxWidth;
  5319. }
  5320. return false;
  5321. };
  5322. Column.prototype.getMinWidth = function () {
  5323. return this.minWidth;
  5324. };
  5325. Column.prototype.getMaxWidth = function () {
  5326. return this.maxWidth;
  5327. };
  5328. Column.prototype.getFlex = function () {
  5329. return this.flex || 0;
  5330. };
  5331. // this method should only be used by the columnController to
  5332. // change flex when required by the setColumnState method.
  5333. Column.prototype.setFlex = function (flex) {
  5334. if (this.flex !== flex) {
  5335. this.flex = flex;
  5336. }
  5337. };
  5338. Column.prototype.setMinimum = function (source) {
  5339. if (source === void 0) { source = "api"; }
  5340. this.setActualWidth(this.minWidth, source);
  5341. };
  5342. Column.prototype.setRowGroupActive = function (rowGroup, source) {
  5343. if (source === void 0) { source = "api"; }
  5344. if (this.rowGroupActive !== rowGroup) {
  5345. this.rowGroupActive = rowGroup;
  5346. this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_ROW_GROUP_CHANGED, source));
  5347. }
  5348. };
  5349. Column.prototype.isRowGroupActive = function () {
  5350. return this.rowGroupActive;
  5351. };
  5352. Column.prototype.setPivotActive = function (pivot, source) {
  5353. if (source === void 0) { source = "api"; }
  5354. if (this.pivotActive !== pivot) {
  5355. this.pivotActive = pivot;
  5356. this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_PIVOT_CHANGED, source));
  5357. }
  5358. };
  5359. Column.prototype.isPivotActive = function () {
  5360. return this.pivotActive;
  5361. };
  5362. Column.prototype.isAnyFunctionActive = function () {
  5363. return this.isPivotActive() || this.isRowGroupActive() || this.isValueActive();
  5364. };
  5365. Column.prototype.isAnyFunctionAllowed = function () {
  5366. return this.isAllowPivot() || this.isAllowRowGroup() || this.isAllowValue();
  5367. };
  5368. Column.prototype.setValueActive = function (value, source) {
  5369. if (source === void 0) { source = "api"; }
  5370. if (this.aggregationActive !== value) {
  5371. this.aggregationActive = value;
  5372. this.eventService.dispatchEvent(this.createColumnEvent(Column.EVENT_VALUE_CHANGED, source));
  5373. }
  5374. };
  5375. Column.prototype.isValueActive = function () {
  5376. return this.aggregationActive;
  5377. };
  5378. Column.prototype.isAllowPivot = function () {
  5379. return this.colDef.enablePivot === true;
  5380. };
  5381. Column.prototype.isAllowValue = function () {
  5382. return this.colDef.enableValue === true;
  5383. };
  5384. Column.prototype.isAllowRowGroup = function () {
  5385. return this.colDef.enableRowGroup === true;
  5386. };
  5387. Column.prototype.getMenuTabs = function (defaultValues) {
  5388. var menuTabs = this.getColDef().menuTabs;
  5389. if (menuTabs == null) {
  5390. menuTabs = defaultValues;
  5391. }
  5392. return menuTabs;
  5393. };
  5394. // this used to be needed, as previous version of ag-grid had lockPosition as column state,
  5395. // so couldn't depend on colDef version.
  5396. Column.prototype.isLockPosition = function () {
  5397. console.warn('ag-Grid: since v21, col.isLockPosition() should not be used, please use col.getColDef().lockPosition instead.');
  5398. return this.colDef ? !!this.colDef.lockPosition : false;
  5399. };
  5400. // this used to be needed, as previous version of ag-grid had lockVisible as column state,
  5401. // so couldn't depend on colDef version.
  5402. Column.prototype.isLockVisible = function () {
  5403. console.warn('ag-Grid: since v21, col.isLockVisible() should not be used, please use col.getColDef().lockVisible instead.');
  5404. return this.colDef ? !!this.colDef.lockVisible : false;
  5405. };
  5406. // this used to be needed, as previous version of ag-grid had lockPinned as column state,
  5407. // so couldn't depend on colDef version.
  5408. Column.prototype.isLockPinned = function () {
  5409. console.warn('ag-Grid: since v21, col.isLockPinned() should not be used, please use col.getColDef().lockPinned instead.');
  5410. return this.colDef ? !!this.colDef.lockPinned : false;
  5411. };
  5412. // + renderedHeaderCell - for making header cell transparent when moving
  5413. Column.EVENT_MOVING_CHANGED = 'movingChanged';
  5414. // + renderedCell - changing left position
  5415. Column.EVENT_LEFT_CHANGED = 'leftChanged';
  5416. // + renderedCell - changing width
  5417. Column.EVENT_WIDTH_CHANGED = 'widthChanged';
  5418. // + renderedCell - for changing pinned classes
  5419. Column.EVENT_LAST_LEFT_PINNED_CHANGED = 'lastLeftPinnedChanged';
  5420. Column.EVENT_FIRST_RIGHT_PINNED_CHANGED = 'firstRightPinnedChanged';
  5421. // + renderedColumn - for changing visibility icon
  5422. Column.EVENT_VISIBLE_CHANGED = 'visibleChanged';
  5423. // + every time the filter changes, used in the floating filters
  5424. Column.EVENT_FILTER_CHANGED = 'filterChanged';
  5425. // + renderedHeaderCell - marks the header with filter icon
  5426. Column.EVENT_FILTER_ACTIVE_CHANGED = 'filterActiveChanged';
  5427. // + renderedHeaderCell - marks the header with sort icon
  5428. Column.EVENT_SORT_CHANGED = 'sortChanged';
  5429. Column.EVENT_MENU_VISIBLE_CHANGED = 'menuVisibleChanged';
  5430. // + toolpanel, for gui updates
  5431. Column.EVENT_ROW_GROUP_CHANGED = 'columnRowGroupChanged';
  5432. // + toolpanel, for gui updates
  5433. Column.EVENT_PIVOT_CHANGED = 'columnPivotChanged';
  5434. // + toolpanel, for gui updates
  5435. Column.EVENT_VALUE_CHANGED = 'columnValueChanged';
  5436. __decorate([
  5437. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper')
  5438. ], Column.prototype, "gridOptionsWrapper", void 0);
  5439. __decorate([
  5440. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnUtils')
  5441. ], Column.prototype, "columnUtils", void 0);
  5442. __decorate([
  5443. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnApi')
  5444. ], Column.prototype, "columnApi", void 0);
  5445. __decorate([
  5446. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridApi')
  5447. ], Column.prototype, "gridApi", void 0);
  5448. __decorate([
  5449. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('context')
  5450. ], Column.prototype, "context", void 0);
  5451. __decorate([
  5452. _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"]
  5453. ], Column.prototype, "initialise", null);
  5454. return Column;
  5455. }());
  5456. /***/ }),
  5457. /* 36 */
  5458. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  5459. "use strict";
  5460. __webpack_require__.r(__webpack_exports__);
  5461. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "EventService", function() { return EventService; });
  5462. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  5463. /**
  5464. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  5465. * @version v23.2.1
  5466. * @link http://www.ag-grid.com/
  5467. * @license MIT
  5468. */
  5469. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  5470. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  5471. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  5472. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  5473. return c > 3 && r && Object.defineProperty(target, key, r), r;
  5474. };
  5475. var __param = (undefined && undefined.__param) || function (paramIndex, decorator) {
  5476. return function (target, key) { decorator(target, key, paramIndex); }
  5477. };
  5478. var EventService = /** @class */ (function () {
  5479. function EventService() {
  5480. this.allSyncListeners = new Map();
  5481. this.allAsyncListeners = new Map();
  5482. this.globalSyncListeners = new Set();
  5483. this.globalAsyncListeners = new Set();
  5484. this.asyncFunctionsQueue = [];
  5485. this.scheduled = false;
  5486. // using an object performs better than a Set for the number of different events we have
  5487. this.firedEvents = {};
  5488. }
  5489. // because this class is used both inside the context and outside the context, we do not
  5490. // use autowired attributes, as that would be confusing, as sometimes the attributes
  5491. // would be wired, and sometimes not.
  5492. //
  5493. // the global event servers used by ag-Grid is autowired by the context once, and this
  5494. // setBeans method gets called once.
  5495. //
  5496. // the times when this class is used outside of the context (eg RowNode has an instance of this
  5497. // class) then it is not a bean, and this setBeans method is not called.
  5498. EventService.prototype.setBeans = function (loggerFactory, gridOptionsWrapper, globalEventListener) {
  5499. if (globalEventListener === void 0) { globalEventListener = null; }
  5500. this.logger = loggerFactory.create('EventService');
  5501. if (globalEventListener) {
  5502. var async = gridOptionsWrapper.useAsyncEvents();
  5503. this.addGlobalListener(globalEventListener, async);
  5504. }
  5505. };
  5506. EventService.prototype.getListeners = function (eventType, async) {
  5507. var listenerMap = async ? this.allAsyncListeners : this.allSyncListeners;
  5508. var listeners = listenerMap.get(eventType);
  5509. if (!listeners) {
  5510. listeners = new Set();
  5511. listenerMap.set(eventType, listeners);
  5512. }
  5513. return listeners;
  5514. };
  5515. EventService.prototype.addEventListener = function (eventType, listener, async) {
  5516. if (async === void 0) { async = false; }
  5517. this.getListeners(eventType, async).add(listener);
  5518. };
  5519. EventService.prototype.removeEventListener = function (eventType, listener, async) {
  5520. if (async === void 0) { async = false; }
  5521. this.getListeners(eventType, async).delete(listener);
  5522. };
  5523. EventService.prototype.addGlobalListener = function (listener, async) {
  5524. if (async === void 0) { async = false; }
  5525. (async ? this.globalAsyncListeners : this.globalSyncListeners).add(listener);
  5526. };
  5527. EventService.prototype.removeGlobalListener = function (listener, async) {
  5528. if (async === void 0) { async = false; }
  5529. (async ? this.globalAsyncListeners : this.globalSyncListeners).delete(listener);
  5530. };
  5531. EventService.prototype.dispatchEvent = function (event) {
  5532. this.dispatchToListeners(event, true);
  5533. this.dispatchToListeners(event, false);
  5534. this.firedEvents[event.type] = true;
  5535. };
  5536. EventService.prototype.dispatchEventOnce = function (event) {
  5537. if (!this.firedEvents[event.type]) {
  5538. this.dispatchEvent(event);
  5539. }
  5540. };
  5541. EventService.prototype.dispatchToListeners = function (event, async) {
  5542. var _this = this;
  5543. var eventType = event.type;
  5544. var processEventListeners = function (listeners) { return listeners.forEach(function (listener) {
  5545. if (async) {
  5546. _this.dispatchAsync(function () { return listener(event); });
  5547. }
  5548. else {
  5549. listener(event);
  5550. }
  5551. }); };
  5552. processEventListeners(this.getListeners(eventType, async));
  5553. var globalListeners = async ? this.globalAsyncListeners : this.globalSyncListeners;
  5554. globalListeners.forEach(function (listener) {
  5555. if (async) {
  5556. _this.dispatchAsync(function () { return listener(eventType, event); });
  5557. }
  5558. else {
  5559. listener(eventType, event);
  5560. }
  5561. });
  5562. };
  5563. // this gets called inside the grid's thread, for each event that it
  5564. // wants to set async. the grid then batches the events into one setTimeout()
  5565. // because setTimeout() is an expensive operation. ideally we would have
  5566. // each event in it's own setTimeout(), but we batch for performance.
  5567. EventService.prototype.dispatchAsync = function (func) {
  5568. // add to the queue for executing later in the next VM turn
  5569. this.asyncFunctionsQueue.push(func);
  5570. // check if timeout is already scheduled. the first time the grid calls
  5571. // this within it's thread turn, this should be false, so it will schedule
  5572. // the 'flush queue' method the first time it comes here. then the flag is
  5573. // set to 'true' so it will know it's already scheduled for subsequent calls.
  5574. if (!this.scheduled) {
  5575. // if not scheduled, schedule one
  5576. window.setTimeout(this.flushAsyncQueue.bind(this), 0);
  5577. // mark that it is scheduled
  5578. this.scheduled = true;
  5579. }
  5580. };
  5581. // this happens in the next VM turn only, and empties the queue of events
  5582. EventService.prototype.flushAsyncQueue = function () {
  5583. this.scheduled = false;
  5584. // we take a copy, because the event listener could be using
  5585. // the grid, which would cause more events, which would be potentially
  5586. // added to the queue, so safe to take a copy, the new events will
  5587. // get executed in a later VM turn rather than risk updating the
  5588. // queue as we are flushing it.
  5589. var queueCopy = this.asyncFunctionsQueue.slice();
  5590. this.asyncFunctionsQueue = [];
  5591. // execute the queue
  5592. queueCopy.forEach(function (func) { return func(); });
  5593. };
  5594. __decorate([
  5595. __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('loggerFactory')),
  5596. __param(1, Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('gridOptionsWrapper')),
  5597. __param(2, Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('globalEventListener'))
  5598. ], EventService.prototype, "setBeans", null);
  5599. EventService = __decorate([
  5600. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('eventService')
  5601. ], EventService);
  5602. return EventService;
  5603. }());
  5604. /***/ }),
  5605. /* 37 */
  5606. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  5607. "use strict";
  5608. __webpack_require__.r(__webpack_exports__);
  5609. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Context", function() { return Context; });
  5610. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PreConstruct", function() { return PreConstruct; });
  5611. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PostConstruct", function() { return PostConstruct; });
  5612. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PreDestroy", function() { return PreDestroy; });
  5613. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Bean", function() { return Bean; });
  5614. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Autowired", function() { return Autowired; });
  5615. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Optional", function() { return Optional; });
  5616. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Qualifier", function() { return Qualifier; });
  5617. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7);
  5618. /**
  5619. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  5620. * @version v23.2.1
  5621. * @link http://www.ag-grid.com/
  5622. * @license MIT
  5623. */
  5624. var Context = /** @class */ (function () {
  5625. function Context(params, logger) {
  5626. this.beanWrappers = {};
  5627. this.destroyed = false;
  5628. if (!params || !params.beanClasses) {
  5629. return;
  5630. }
  5631. this.contextParams = params;
  5632. this.logger = logger;
  5633. this.logger.log(">> creating ag-Application Context");
  5634. this.createBeans();
  5635. var beanInstances = this.getBeanInstances();
  5636. this.wireBeans(beanInstances);
  5637. this.logger.log(">> ag-Application Context ready - component is alive");
  5638. }
  5639. Context.prototype.getBeanInstances = function () {
  5640. return _utils__WEBPACK_IMPORTED_MODULE_0__["_"].values(this.beanWrappers).map(function (beanEntry) { return beanEntry.beanInstance; });
  5641. };
  5642. Context.prototype.createBean = function (bean, afterPreCreateCallback) {
  5643. if (!bean) {
  5644. throw Error("Can't wire to bean since it is null");
  5645. }
  5646. this.wireBeans([bean], afterPreCreateCallback);
  5647. return bean;
  5648. };
  5649. Context.prototype.wireBeans = function (beanInstances, afterPreCreateCallback) {
  5650. this.autoWireBeans(beanInstances);
  5651. this.methodWireBeans(beanInstances);
  5652. this.callLifeCycleMethods(beanInstances, 'preConstructMethods');
  5653. // the callback sets the attributes, so the component has access to attributes
  5654. // before postConstruct methods in the component are executed
  5655. if (_utils__WEBPACK_IMPORTED_MODULE_0__["_"].exists(afterPreCreateCallback)) {
  5656. beanInstances.forEach(afterPreCreateCallback);
  5657. }
  5658. this.callLifeCycleMethods(beanInstances, 'postConstructMethods');
  5659. };
  5660. Context.prototype.createBeans = function () {
  5661. var _this = this;
  5662. // register all normal beans
  5663. this.contextParams.beanClasses.forEach(this.createBeanWrapper.bind(this));
  5664. // register override beans, these will overwrite beans above of same name
  5665. // instantiate all beans - overridden beans will be left out
  5666. _utils__WEBPACK_IMPORTED_MODULE_0__["_"].iterateObject(this.beanWrappers, function (key, beanEntry) {
  5667. var constructorParamsMeta;
  5668. if (beanEntry.bean.__agBeanMetaData && beanEntry.bean.__agBeanMetaData.autowireMethods && beanEntry.bean.__agBeanMetaData.autowireMethods.agConstructor) {
  5669. constructorParamsMeta = beanEntry.bean.__agBeanMetaData.autowireMethods.agConstructor;
  5670. }
  5671. var constructorParams = _this.getBeansForParameters(constructorParamsMeta, beanEntry.bean.name);
  5672. var newInstance = applyToConstructor(beanEntry.bean, constructorParams);
  5673. beanEntry.beanInstance = newInstance;
  5674. });
  5675. var createdBeanNames = Object.keys(this.beanWrappers).join(', ');
  5676. this.logger.log("created beans: " + createdBeanNames);
  5677. };
  5678. // tslint:disable-next-line
  5679. Context.prototype.createBeanWrapper = function (Bean) {
  5680. var metaData = Bean.__agBeanMetaData;
  5681. if (!metaData) {
  5682. var beanName = void 0;
  5683. if (Bean.prototype.constructor) {
  5684. beanName = Bean.prototype.constructor.name;
  5685. }
  5686. else {
  5687. beanName = "" + Bean;
  5688. }
  5689. console.error("context item " + beanName + " is not a bean");
  5690. return;
  5691. }
  5692. var beanEntry = {
  5693. bean: Bean,
  5694. beanInstance: null,
  5695. beanName: metaData.beanName
  5696. };
  5697. this.beanWrappers[metaData.beanName] = beanEntry;
  5698. };
  5699. Context.prototype.autoWireBeans = function (beanInstances) {
  5700. var _this = this;
  5701. beanInstances.forEach(function (beanInstance) {
  5702. _this.forEachMetaDataInHierarchy(beanInstance, function (metaData, beanName) {
  5703. var attributes = metaData.agClassAttributes;
  5704. if (!attributes) {
  5705. return;
  5706. }
  5707. attributes.forEach(function (attribute) {
  5708. var otherBean = _this.lookupBeanInstance(beanName, attribute.beanName, attribute.optional);
  5709. beanInstance[attribute.attributeName] = otherBean;
  5710. });
  5711. });
  5712. });
  5713. };
  5714. Context.prototype.methodWireBeans = function (beanInstances) {
  5715. var _this = this;
  5716. beanInstances.forEach(function (beanInstance) {
  5717. _this.forEachMetaDataInHierarchy(beanInstance, function (metaData, beanName) {
  5718. _utils__WEBPACK_IMPORTED_MODULE_0__["_"].iterateObject(metaData.autowireMethods, function (methodName, wireParams) {
  5719. // skip constructor, as this is dealt with elsewhere
  5720. if (methodName === "agConstructor") {
  5721. return;
  5722. }
  5723. var initParams = _this.getBeansForParameters(wireParams, beanName);
  5724. beanInstance[methodName].apply(beanInstance, initParams);
  5725. });
  5726. });
  5727. });
  5728. };
  5729. Context.prototype.forEachMetaDataInHierarchy = function (beanInstance, callback) {
  5730. var prototype = Object.getPrototypeOf(beanInstance);
  5731. while (prototype != null) {
  5732. var constructor = prototype.constructor;
  5733. if (constructor.hasOwnProperty('__agBeanMetaData')) {
  5734. var metaData = constructor.__agBeanMetaData;
  5735. var beanName = this.getBeanName(constructor);
  5736. callback(metaData, beanName);
  5737. }
  5738. prototype = Object.getPrototypeOf(prototype);
  5739. }
  5740. };
  5741. Context.prototype.getBeanName = function (constructor) {
  5742. if (constructor.__agBeanMetaData && constructor.__agBeanMetaData.beanName) {
  5743. return constructor.__agBeanMetaData.beanName;
  5744. }
  5745. var constructorString = constructor.toString();
  5746. var beanName = constructorString.substring(9, constructorString.indexOf("("));
  5747. return beanName;
  5748. };
  5749. Context.prototype.getBeansForParameters = function (parameters, beanName) {
  5750. var _this = this;
  5751. var beansList = [];
  5752. if (parameters) {
  5753. _utils__WEBPACK_IMPORTED_MODULE_0__["_"].iterateObject(parameters, function (paramIndex, otherBeanName) {
  5754. var otherBean = _this.lookupBeanInstance(beanName, otherBeanName);
  5755. beansList[Number(paramIndex)] = otherBean;
  5756. });
  5757. }
  5758. return beansList;
  5759. };
  5760. Context.prototype.lookupBeanInstance = function (wiringBean, beanName, optional) {
  5761. if (optional === void 0) { optional = false; }
  5762. if (beanName === "context") {
  5763. return this;
  5764. }
  5765. else if (this.contextParams.providedBeanInstances && this.contextParams.providedBeanInstances.hasOwnProperty(beanName)) {
  5766. return this.contextParams.providedBeanInstances[beanName];
  5767. }
  5768. else {
  5769. var beanEntry = this.beanWrappers[beanName];
  5770. if (beanEntry) {
  5771. return beanEntry.beanInstance;
  5772. }
  5773. if (!optional) {
  5774. console.error("ag-Grid: unable to find bean reference " + beanName + " while initialising " + wiringBean);
  5775. }
  5776. return null;
  5777. }
  5778. };
  5779. Context.prototype.callLifeCycleMethods = function (beanInstances, lifeCycleMethod) {
  5780. var _this = this;
  5781. beanInstances.forEach(function (beanInstance) {
  5782. _this.callLifeCycleMethodsOneBean(beanInstance, lifeCycleMethod);
  5783. });
  5784. };
  5785. Context.prototype.callLifeCycleMethodsOneBean = function (beanInstance, lifeCycleMethod, methodToIgnore) {
  5786. // putting all methods into a map removes duplicates
  5787. var allMethods = {};
  5788. // dump methods from each level of the metadata hierarchy
  5789. this.forEachMetaDataInHierarchy(beanInstance, function (metaData) {
  5790. var methods = metaData[lifeCycleMethod];
  5791. if (methods) {
  5792. methods.forEach(function (methodName) {
  5793. if (methodName != methodToIgnore) {
  5794. allMethods[methodName] = true;
  5795. }
  5796. });
  5797. }
  5798. });
  5799. var allMethodsList = Object.keys(allMethods);
  5800. allMethodsList.forEach(function (methodName) { return beanInstance[methodName](); });
  5801. };
  5802. Context.prototype.getBean = function (name) {
  5803. return this.lookupBeanInstance("getBean", name, true);
  5804. };
  5805. Context.prototype.destroy = function () {
  5806. // should only be able to destroy once
  5807. if (this.destroyed) {
  5808. return;
  5809. }
  5810. this.logger.log(">> Shutting down ag-Application Context");
  5811. var beanInstances = this.getBeanInstances();
  5812. this.destroyBeans(beanInstances);
  5813. this.contextParams.providedBeanInstances = null;
  5814. this.destroyed = true;
  5815. this.logger.log(">> ag-Application Context shut down - component is dead");
  5816. };
  5817. Context.prototype.destroyBean = function (bean) {
  5818. if (!bean) {
  5819. return undefined;
  5820. }
  5821. this.destroyBeans([bean]);
  5822. return undefined;
  5823. };
  5824. Context.prototype.destroyBeans = function (beans) {
  5825. var _this = this;
  5826. if (!beans) {
  5827. return [];
  5828. }
  5829. beans.forEach(function (bean) {
  5830. _this.callLifeCycleMethodsOneBean(bean, 'preDestroyMethods', 'destroy');
  5831. // call destroy() explicitly if it exists
  5832. if (bean.destroy) {
  5833. bean.destroy();
  5834. }
  5835. });
  5836. return [];
  5837. };
  5838. return Context;
  5839. }());
  5840. // taken from: http://stackoverflow.com/questions/3362471/how-can-i-call-a-javascript-constructor-using-call-or-apply
  5841. // allows calling 'apply' on a constructor
  5842. function applyToConstructor(constructor, argArray) {
  5843. var args = [null].concat(argArray);
  5844. var factoryFunction = constructor.bind.apply(constructor, args);
  5845. return new factoryFunction();
  5846. }
  5847. function PreConstruct(target, methodName, descriptor) {
  5848. var props = getOrCreateProps(target.constructor);
  5849. if (!props.preConstructMethods) {
  5850. props.preConstructMethods = [];
  5851. }
  5852. props.preConstructMethods.push(methodName);
  5853. }
  5854. function PostConstruct(target, methodName, descriptor) {
  5855. var props = getOrCreateProps(target.constructor);
  5856. if (!props.postConstructMethods) {
  5857. props.postConstructMethods = [];
  5858. }
  5859. props.postConstructMethods.push(methodName);
  5860. }
  5861. function PreDestroy(target, methodName, descriptor) {
  5862. var props = getOrCreateProps(target.constructor);
  5863. if (!props.preDestroyMethods) {
  5864. props.preDestroyMethods = [];
  5865. }
  5866. props.preDestroyMethods.push(methodName);
  5867. }
  5868. function Bean(beanName) {
  5869. return function (classConstructor) {
  5870. var props = getOrCreateProps(classConstructor);
  5871. props.beanName = beanName;
  5872. };
  5873. }
  5874. function Autowired(name) {
  5875. return function (target, propertyKey, descriptor) {
  5876. autowiredFunc(target, name, false, target, propertyKey, null);
  5877. };
  5878. }
  5879. function Optional(name) {
  5880. return function (target, propertyKey, descriptor) {
  5881. autowiredFunc(target, name, true, target, propertyKey, null);
  5882. };
  5883. }
  5884. function autowiredFunc(target, name, optional, classPrototype, methodOrAttributeName, index) {
  5885. if (name === null) {
  5886. console.error("ag-Grid: Autowired name should not be null");
  5887. return;
  5888. }
  5889. if (typeof index === "number") {
  5890. console.error("ag-Grid: Autowired should be on an attribute");
  5891. return;
  5892. }
  5893. // it's an attribute on the class
  5894. var props = getOrCreateProps(target.constructor);
  5895. if (!props.agClassAttributes) {
  5896. props.agClassAttributes = [];
  5897. }
  5898. props.agClassAttributes.push({
  5899. attributeName: methodOrAttributeName,
  5900. beanName: name,
  5901. optional: optional
  5902. });
  5903. }
  5904. function Qualifier(name) {
  5905. return function (classPrototype, methodOrAttributeName, index) {
  5906. var constructor = typeof classPrototype == "function" ? classPrototype : classPrototype.constructor;
  5907. var props;
  5908. if (typeof index === "number") {
  5909. // it's a parameter on a method
  5910. var methodName = void 0;
  5911. if (methodOrAttributeName) {
  5912. props = getOrCreateProps(constructor);
  5913. methodName = methodOrAttributeName;
  5914. }
  5915. else {
  5916. props = getOrCreateProps(constructor);
  5917. methodName = "agConstructor";
  5918. }
  5919. if (!props.autowireMethods) {
  5920. props.autowireMethods = {};
  5921. }
  5922. if (!props.autowireMethods[methodName]) {
  5923. props.autowireMethods[methodName] = {};
  5924. }
  5925. props.autowireMethods[methodName][index] = name;
  5926. }
  5927. };
  5928. }
  5929. function getOrCreateProps(target) {
  5930. if (!target.hasOwnProperty("__agBeanMetaData")) {
  5931. target.__agBeanMetaData = {};
  5932. }
  5933. return target.__agBeanMetaData;
  5934. }
  5935. /***/ }),
  5936. /* 38 */
  5937. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  5938. "use strict";
  5939. __webpack_require__.r(__webpack_exports__);
  5940. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ModuleNames", function() { return ModuleNames; });
  5941. /**
  5942. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  5943. * @version v23.2.1
  5944. * @link http://www.ag-grid.com/
  5945. * @license MIT
  5946. */
  5947. var ModuleNames;
  5948. (function (ModuleNames) {
  5949. // when using modules, user references this
  5950. ModuleNames["CommunityCoreModule"] = "@ag-grid-community/core";
  5951. // when not using modules, user references this
  5952. ModuleNames["CommunityAllModules"] = "@ag-grid-community/all";
  5953. // community modules
  5954. ModuleNames["InfiniteRowModelModule"] = "@ag-grid-community/infinite-row-model";
  5955. ModuleNames["ClientSideRowModelModule"] = "@ag-grid-community/client-side-row-model";
  5956. ModuleNames["CsvExportModule"] = "@ag-grid-community/csv-export";
  5957. ModuleNames["RowNodeCache"] = "@ag-grid-community/row-node-cache";
  5958. // enterprise core - users never import on this, but other enterprise modules do
  5959. ModuleNames["EnterpriseCoreModule"] = "@ag-grid-enterprise/core";
  5960. // when not using modules, user references this
  5961. ModuleNames["EnterpriseAllModules"] = "@ag-grid-enterprise/all";
  5962. // enterprise modules
  5963. ModuleNames["RowGroupingModule"] = "@ag-grid-enterprise/row-grouping";
  5964. ModuleNames["ColumnToolPanelModule"] = "@ag-grid-enterprise/column-tool-panel";
  5965. ModuleNames["FiltersToolPanelModule"] = "@ag-grid-enterprise/filters-tool-panel";
  5966. ModuleNames["MenuModule"] = "@ag-grid-enterprise/menu";
  5967. ModuleNames["SetFilterModule"] = "@ag-grid-enterprise/set-filter";
  5968. ModuleNames["StatusBarModule"] = "@ag-grid-enterprise/status-bar";
  5969. ModuleNames["SideBarModule"] = "@ag-grid-enterprise/side-bar";
  5970. ModuleNames["RangeSelectionModule"] = "@ag-grid-enterprise/range-selection";
  5971. ModuleNames["MasterDetailModule"] = "@ag-grid-enterprise/master-detail";
  5972. ModuleNames["RichSelectModule"] = "@ag-grid-enterprise/rich-select";
  5973. ModuleNames["GridChartsModule"] = "@ag-grid-enterprise/charts";
  5974. ModuleNames["ViewportRowModelModule"] = "@ag-grid-enterprise/viewport-row-model";
  5975. ModuleNames["ServerSideRowModelModule"] = "@ag-grid-enterprise/server-side-row-model";
  5976. ModuleNames["ExcelExportModule"] = "@ag-grid-enterprise/excel-export";
  5977. ModuleNames["ClipboardModule"] = "@ag-grid-enterprise/clipboard";
  5978. ModuleNames["DateTimeCellEditorModule"] = "@ag-grid-enterprise/date-time-cell-editor";
  5979. // framework wrappers currently don't provide beans, comps etc, so no need to be modules,
  5980. // however i argue they should be as in theory they 'could' provide beans etc
  5981. ModuleNames["AngularModule"] = "@ag-grid-community/angular";
  5982. ModuleNames["ReactModule"] = "@ag-grid-community/react";
  5983. ModuleNames["VueModule"] = "@ag-grid-community/vue";
  5984. ModuleNames["PolymerModule"] = "@ag-grid-community/polymer";
  5985. // and then this, which is definitely not a grid module, as it should not have any dependency
  5986. // on the grid (ie shouldn't even reference the Module interface)
  5987. // ChartsModule = "@ag-grid-community/charts-core",
  5988. })(ModuleNames || (ModuleNames = {}));
  5989. /***/ }),
  5990. /* 39 */
  5991. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  5992. "use strict";
  5993. __webpack_require__.r(__webpack_exports__);
  5994. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ModuleRegistry", function() { return ModuleRegistry; });
  5995. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7);
  5996. /**
  5997. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  5998. * @version v23.2.1
  5999. * @link http://www.ag-grid.com/
  6000. * @license MIT
  6001. */
  6002. var ModuleRegistry = /** @class */ (function () {
  6003. function ModuleRegistry() {
  6004. }
  6005. ModuleRegistry.register = function (module, moduleBased) {
  6006. if (moduleBased === void 0) { moduleBased = true; }
  6007. ModuleRegistry.modulesMap[module.moduleName] = module;
  6008. if (ModuleRegistry.moduleBased === undefined) {
  6009. ModuleRegistry.moduleBased = moduleBased;
  6010. }
  6011. else {
  6012. if (ModuleRegistry.moduleBased !== moduleBased) {
  6013. _utils__WEBPACK_IMPORTED_MODULE_0__["_"].doOnce(function () {
  6014. console.warn("ag-Grid: You are mixing modules (i.e. @ag-grid-community/core) and packages (ag-grid-community) - you can only use one or the other of these mechanisms.");
  6015. console.warn('Please see https://www.ag-grid.com/javascript-grid-packages-modules/ for more information.');
  6016. }, 'ModulePackageCheck');
  6017. }
  6018. }
  6019. };
  6020. // noinspection JSUnusedGlobalSymbols
  6021. ModuleRegistry.registerModules = function (modules, moduleBased) {
  6022. if (moduleBased === void 0) { moduleBased = true; }
  6023. if (!modules) {
  6024. return;
  6025. }
  6026. modules.forEach(function (module) { return ModuleRegistry.register(module, moduleBased); });
  6027. };
  6028. ModuleRegistry.assertRegistered = function (moduleName, reason) {
  6029. if (this.isRegistered(moduleName)) {
  6030. return true;
  6031. }
  6032. var warningKey = reason + moduleName;
  6033. var warningMessage = "ag-Grid: unable to use " + reason + " as module " + moduleName + " is not present. Please see: https://www.ag-grid.com/javascript-grid-modules/";
  6034. _utils__WEBPACK_IMPORTED_MODULE_0__["_"].doOnce(function () {
  6035. console.warn(warningMessage);
  6036. }, warningKey);
  6037. return false;
  6038. };
  6039. ModuleRegistry.isRegistered = function (moduleName) {
  6040. return !!ModuleRegistry.modulesMap[moduleName];
  6041. };
  6042. ModuleRegistry.getRegisteredModules = function () {
  6043. return _utils__WEBPACK_IMPORTED_MODULE_0__["_"].values(ModuleRegistry.modulesMap);
  6044. };
  6045. ModuleRegistry.isPackageBased = function () {
  6046. return !ModuleRegistry.moduleBased;
  6047. };
  6048. // having in a map a) removes duplicates and b) allows fast lookup
  6049. ModuleRegistry.modulesMap = {};
  6050. return ModuleRegistry;
  6051. }());
  6052. /***/ }),
  6053. /* 40 */
  6054. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  6055. "use strict";
  6056. __webpack_require__.r(__webpack_exports__);
  6057. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DefaultColumnTypes", function() { return DefaultColumnTypes; });
  6058. /**
  6059. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  6060. * @version v23.2.1
  6061. * @link http://www.ag-grid.com/
  6062. * @license MIT
  6063. */
  6064. var DefaultColumnTypes = {
  6065. numericColumn: {
  6066. headerClass: 'ag-right-aligned-header',
  6067. cellClass: 'ag-right-aligned-cell'
  6068. },
  6069. rightAligned: {
  6070. headerClass: 'ag-right-aligned-header',
  6071. cellClass: 'ag-right-aligned-cell'
  6072. }
  6073. };
  6074. /***/ }),
  6075. /* 41 */
  6076. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  6077. "use strict";
  6078. __webpack_require__.r(__webpack_exports__);
  6079. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BeanStub", function() { return BeanStub; });
  6080. /* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36);
  6081. /* harmony import */ var _context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  6082. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
  6083. /**
  6084. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  6085. * @version v23.2.1
  6086. * @link http://www.ag-grid.com/
  6087. * @license MIT
  6088. */
  6089. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  6090. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  6091. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  6092. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  6093. return c > 3 && r && Object.defineProperty(target, key, r), r;
  6094. };
  6095. var BeanStub = /** @class */ (function () {
  6096. function BeanStub() {
  6097. var _this = this;
  6098. this.destroyFunctions = [];
  6099. this.destroyed = false;
  6100. this.getContext = function () { return _this.context; };
  6101. this.isAlive = function () { return !_this.destroyed; };
  6102. }
  6103. // this was a test constructor niall built, when active, it prints after 5 seconds all beans/components that are
  6104. // not destroyed. to use, create a new grid, then api.destroy() before 5 seconds. then anything that gets printed
  6105. // points to a bean or component that was not properly disposed of.
  6106. // constructor() {
  6107. // setTimeout(()=> {
  6108. // if (this.isAlive()) {
  6109. // let prototype: any = Object.getPrototypeOf(this);
  6110. // const constructor: any = prototype.constructor;
  6111. // const constructorString = constructor.toString();
  6112. // const beanName = constructorString.substring(9, constructorString.indexOf("("));
  6113. // console.log('is alive ' + beanName);
  6114. // }
  6115. // }, 5000);
  6116. // }
  6117. // CellComp and GridComp and override this because they get the FrameworkOverrides from the Beans bean
  6118. BeanStub.prototype.getFrameworkOverrides = function () {
  6119. return this.frameworkOverrides;
  6120. };
  6121. BeanStub.prototype.destroy = function () {
  6122. // let prototype: any = Object.getPrototypeOf(this);
  6123. // const constructor: any = prototype.constructor;
  6124. // const constructorString = constructor.toString();
  6125. // const beanName = constructorString.substring(9, constructorString.indexOf("("));
  6126. this.destroyFunctions.forEach(function (func) { return func(); });
  6127. this.destroyFunctions.length = 0;
  6128. this.destroyed = true;
  6129. this.dispatchEvent({ type: BeanStub.EVENT_DESTROYED });
  6130. };
  6131. BeanStub.prototype.addEventListener = function (eventType, listener) {
  6132. if (!this.localEventService) {
  6133. this.localEventService = new _eventService__WEBPACK_IMPORTED_MODULE_0__["EventService"]();
  6134. }
  6135. this.localEventService.addEventListener(eventType, listener);
  6136. };
  6137. BeanStub.prototype.removeEventListener = function (eventType, listener) {
  6138. if (this.localEventService) {
  6139. this.localEventService.removeEventListener(eventType, listener);
  6140. }
  6141. };
  6142. BeanStub.prototype.dispatchEventAsync = function (event) {
  6143. var _this = this;
  6144. window.setTimeout(function () { return _this.dispatchEvent(event); }, 0);
  6145. };
  6146. BeanStub.prototype.dispatchEvent = function (event) {
  6147. if (this.localEventService) {
  6148. this.localEventService.dispatchEvent(event);
  6149. }
  6150. };
  6151. BeanStub.prototype.addManagedListener = function (object, event, listener) {
  6152. var _this = this;
  6153. if (this.destroyed) {
  6154. return;
  6155. }
  6156. if (object instanceof HTMLElement) {
  6157. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addSafePassiveEventListener(this.getFrameworkOverrides(), object, event, listener);
  6158. }
  6159. else {
  6160. object.addEventListener(event, listener);
  6161. }
  6162. var destroyFunc = function () {
  6163. object.removeEventListener(event, listener);
  6164. _this.destroyFunctions = _this.destroyFunctions.filter(function (fn) { return fn !== destroyFunc; });
  6165. return null;
  6166. };
  6167. this.destroyFunctions.push(destroyFunc);
  6168. return destroyFunc;
  6169. };
  6170. BeanStub.prototype.addDestroyFunc = function (func) {
  6171. // if we are already destroyed, we execute the func now
  6172. if (this.isAlive()) {
  6173. this.destroyFunctions.push(func);
  6174. }
  6175. else {
  6176. func();
  6177. }
  6178. };
  6179. BeanStub.prototype.createManagedBean = function (bean, context) {
  6180. var res = this.createBean(bean, context);
  6181. this.addDestroyFunc(this.destroyBean.bind(this, bean, context));
  6182. return res;
  6183. };
  6184. BeanStub.prototype.createBean = function (bean, context, afterPreCreateCallback) {
  6185. return (context || this.getContext()).createBean(bean, afterPreCreateCallback);
  6186. };
  6187. BeanStub.prototype.destroyBean = function (bean, context) {
  6188. return (context || this.getContext()).destroyBean(bean);
  6189. };
  6190. BeanStub.prototype.destroyBeans = function (beans, context) {
  6191. var _this = this;
  6192. if (beans) {
  6193. beans.forEach(function (bean) { return _this.destroyBean(bean, context); });
  6194. }
  6195. return [];
  6196. };
  6197. BeanStub.EVENT_DESTROYED = 'destroyed';
  6198. __decorate([
  6199. Object(_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('frameworkOverrides')
  6200. ], BeanStub.prototype, "frameworkOverrides", void 0);
  6201. __decorate([
  6202. Object(_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('context')
  6203. ], BeanStub.prototype, "context", void 0);
  6204. __decorate([
  6205. Object(_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('eventService')
  6206. ], BeanStub.prototype, "eventService", void 0);
  6207. __decorate([
  6208. _context__WEBPACK_IMPORTED_MODULE_1__["PreDestroy"]
  6209. ], BeanStub.prototype, "destroy", null);
  6210. return BeanStub;
  6211. }());
  6212. /***/ }),
  6213. /* 42 */
  6214. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  6215. "use strict";
  6216. __webpack_require__.r(__webpack_exports__);
  6217. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnController", function() { return ColumnController; });
  6218. /* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(34);
  6219. /* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(35);
  6220. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43);
  6221. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(41);
  6222. /* harmony import */ var _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(33);
  6223. /* harmony import */ var _groupInstanceIdCreator__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(45);
  6224. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(37);
  6225. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(25);
  6226. /* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(17);
  6227. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(7);
  6228. /**
  6229. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  6230. * @version v23.2.1
  6231. * @link http://www.ag-grid.com/
  6232. * @license MIT
  6233. */
  6234. var __extends = (undefined && undefined.__extends) || (function () {
  6235. var extendStatics = function (d, b) {
  6236. extendStatics = Object.setPrototypeOf ||
  6237. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  6238. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  6239. return extendStatics(d, b);
  6240. };
  6241. return function (d, b) {
  6242. extendStatics(d, b);
  6243. function __() { this.constructor = d; }
  6244. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  6245. };
  6246. })();
  6247. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  6248. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  6249. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  6250. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  6251. return c > 3 && r && Object.defineProperty(target, key, r), r;
  6252. };
  6253. var __param = (undefined && undefined.__param) || function (paramIndex, decorator) {
  6254. return function (target, key) { decorator(target, key, paramIndex); }
  6255. };
  6256. var ColumnController = /** @class */ (function (_super) {
  6257. __extends(ColumnController, _super);
  6258. function ColumnController() {
  6259. var _this = _super !== null && _super.apply(this, arguments) || this;
  6260. // header row count, based on user provided columns
  6261. _this.primaryHeaderRowCount = 0;
  6262. _this.secondaryHeaderRowCount = 0;
  6263. _this.secondaryColumnsPresent = false;
  6264. // header row count, either above, or based on pivoting if we are pivoting
  6265. _this.gridHeaderRowCount = 0;
  6266. // these are the lists used by the rowRenderer to render nodes. almost the leaf nodes of the above
  6267. // displayed trees, however it also takes into account if the groups are open or not.
  6268. _this.displayedLeftColumns = [];
  6269. _this.displayedRightColumns = [];
  6270. _this.displayedCenterColumns = [];
  6271. // all three lists above combined
  6272. _this.allDisplayedColumns = [];
  6273. // same as above, except trimmed down to only columns within the viewport
  6274. _this.allDisplayedVirtualColumns = [];
  6275. _this.allDisplayedCenterVirtualColumns = [];
  6276. _this.rowGroupColumns = [];
  6277. _this.valueColumns = [];
  6278. _this.pivotColumns = [];
  6279. _this.ready = false;
  6280. _this.autoGroupsNeedBuilding = false;
  6281. _this.forceRecreateAutoGroups = false;
  6282. _this.pivotMode = false;
  6283. _this.bodyWidth = 0;
  6284. _this.leftWidth = 0;
  6285. _this.rightWidth = 0;
  6286. _this.bodyWidthDirty = true;
  6287. _this.flexActive = false;
  6288. return _this;
  6289. }
  6290. ColumnController.prototype.init = function () {
  6291. this.suppressColumnVirtualisation = this.gridOptionsWrapper.isSuppressColumnVirtualisation();
  6292. var pivotMode = this.gridOptionsWrapper.isPivotMode();
  6293. if (this.isPivotSettingAllowed(pivotMode)) {
  6294. this.pivotMode = pivotMode;
  6295. }
  6296. this.usingTreeData = this.gridOptionsWrapper.isTreeData();
  6297. this.addManagedListener(this.gridOptionsWrapper, 'autoGroupColumnDef', this.onAutoGroupColumnDefChanged.bind(this));
  6298. };
  6299. ColumnController.prototype.onAutoGroupColumnDefChanged = function () {
  6300. this.autoGroupsNeedBuilding = true;
  6301. this.forceRecreateAutoGroups = true;
  6302. this.updateGridColumns();
  6303. this.updateDisplayedColumns('gridOptionsChanged');
  6304. };
  6305. ColumnController.prototype.setColumnDefs = function (columnDefs, source) {
  6306. if (source === void 0) { source = 'api'; }
  6307. var colsPreviouslyExisted = !!this.columnDefs;
  6308. this.columnDefs = columnDefs;
  6309. // always invalidate cache on changing columns, as the column id's for the new columns
  6310. // could overlap with the old id's, so the cache would return old values for new columns.
  6311. this.valueCache.expire();
  6312. // NOTE ==================
  6313. // we should be destroying the existing columns and groups if they exist, for example, the original column
  6314. // group adds a listener to the columns, it should be also removing the listeners
  6315. this.autoGroupsNeedBuilding = true;
  6316. var oldPrimaryColumns = this.primaryColumns;
  6317. var balancedTreeResult = this.columnFactory.createColumnTree(columnDefs, true, oldPrimaryColumns);
  6318. this.primaryColumnTree = balancedTreeResult.columnTree;
  6319. this.primaryHeaderRowCount = balancedTreeResult.treeDept + 1;
  6320. this.primaryColumns = this.getColumnsFromTree(this.primaryColumnTree);
  6321. this.extractRowGroupColumns(source, oldPrimaryColumns);
  6322. this.extractPivotColumns(source, oldPrimaryColumns);
  6323. this.createValueColumns(source, oldPrimaryColumns);
  6324. this.ready = true;
  6325. this.updateGridColumns();
  6326. this.updateDisplayedColumns(source);
  6327. this.checkDisplayedVirtualColumns();
  6328. if (this.gridOptionsWrapper.isImmutableColumns() && colsPreviouslyExisted) {
  6329. this.resetColumnState(true, source);
  6330. }
  6331. var eventEverythingChanged = {
  6332. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_EVERYTHING_CHANGED,
  6333. api: this.gridApi,
  6334. columnApi: this.columnApi,
  6335. source: source
  6336. };
  6337. this.eventService.dispatchEvent(eventEverythingChanged);
  6338. var newColumnsLoadedEvent = {
  6339. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_NEW_COLUMNS_LOADED,
  6340. api: this.gridApi,
  6341. columnApi: this.columnApi
  6342. };
  6343. this.eventService.dispatchEvent(newColumnsLoadedEvent);
  6344. this.flexActive = this.getDisplayedCenterColumns().some(function (col) { return !!col.getFlex(); });
  6345. };
  6346. ColumnController.prototype.isAutoRowHeightActive = function () {
  6347. return this.autoRowHeightColumns && this.autoRowHeightColumns.length > 0;
  6348. };
  6349. ColumnController.prototype.getAllAutoRowHeightCols = function () {
  6350. return this.autoRowHeightColumns;
  6351. };
  6352. ColumnController.prototype.setVirtualViewportLeftAndRight = function () {
  6353. if (this.gridOptionsWrapper.isEnableRtl()) {
  6354. this.viewportLeft = this.bodyWidth - this.scrollPosition - this.scrollWidth;
  6355. this.viewportRight = this.bodyWidth - this.scrollPosition;
  6356. }
  6357. else {
  6358. this.viewportLeft = this.scrollPosition;
  6359. this.viewportRight = this.scrollWidth + this.scrollPosition;
  6360. }
  6361. };
  6362. // used by clipboard service, to know what columns to paste into
  6363. ColumnController.prototype.getDisplayedColumnsStartingAt = function (column) {
  6364. var currentColumn = column;
  6365. var columns = [];
  6366. while (currentColumn != null) {
  6367. columns.push(currentColumn);
  6368. currentColumn = this.getDisplayedColAfter(currentColumn);
  6369. }
  6370. return columns;
  6371. };
  6372. // checks what columns are currently displayed due to column virtualisation. fires an event
  6373. // if the list of columns has changed.
  6374. // + setColumnWidth(), setVirtualViewportPosition(), setColumnDefs(), sizeColumnsToFit()
  6375. ColumnController.prototype.checkDisplayedVirtualColumns = function () {
  6376. // check displayCenterColumnTree exists first, as it won't exist when grid is initialising
  6377. if (this.displayedCenterColumns == null) {
  6378. return;
  6379. }
  6380. var hashBefore = this.allDisplayedVirtualColumns.map(function (column) { return column.getId(); }).join('#');
  6381. this.updateVirtualSets();
  6382. var hashAfter = this.allDisplayedVirtualColumns.map(function (column) { return column.getId(); }).join('#');
  6383. if (hashBefore !== hashAfter) {
  6384. var event_1 = {
  6385. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_VIRTUAL_COLUMNS_CHANGED,
  6386. api: this.gridApi,
  6387. columnApi: this.columnApi
  6388. };
  6389. this.eventService.dispatchEvent(event_1);
  6390. }
  6391. };
  6392. ColumnController.prototype.setVirtualViewportPosition = function (scrollWidth, scrollPosition) {
  6393. if (scrollWidth !== this.scrollWidth || scrollPosition !== this.scrollPosition || this.bodyWidthDirty) {
  6394. this.scrollWidth = scrollWidth;
  6395. this.scrollPosition = scrollPosition;
  6396. // we need to call setVirtualViewportLeftAndRight() at least once after the body width changes,
  6397. // as the viewport can stay the same, but in RTL, if body width changes, we need to work out the
  6398. // virtual columns again
  6399. this.bodyWidthDirty = true;
  6400. this.setVirtualViewportLeftAndRight();
  6401. if (this.ready) {
  6402. this.checkDisplayedVirtualColumns();
  6403. }
  6404. }
  6405. };
  6406. ColumnController.prototype.isPivotMode = function () {
  6407. return this.pivotMode;
  6408. };
  6409. ColumnController.prototype.isPivotSettingAllowed = function (pivot) {
  6410. if (pivot && this.gridOptionsWrapper.isTreeData()) {
  6411. console.warn("ag-Grid: Pivot mode not available in conjunction Tree Data i.e. 'gridOptions.treeData: true'");
  6412. return false;
  6413. }
  6414. return true;
  6415. };
  6416. ColumnController.prototype.setPivotMode = function (pivotMode, source) {
  6417. if (source === void 0) { source = 'api'; }
  6418. if (pivotMode === this.pivotMode || !this.isPivotSettingAllowed(this.pivotMode)) {
  6419. return;
  6420. }
  6421. this.pivotMode = pivotMode;
  6422. // we need to update grid columns to cover the scenario where user has groupSuppressAutoColumn=true, as
  6423. // this means we don't use auto group column UNLESS we are in pivot mode (it's mandatory in pivot mode),
  6424. // so need to updateGridColumn() to check it autoGroupCol needs to be added / removed
  6425. this.autoGroupsNeedBuilding = true;
  6426. this.updateGridColumns();
  6427. this.updateDisplayedColumns(source);
  6428. var event = {
  6429. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PIVOT_MODE_CHANGED,
  6430. api: this.gridApi,
  6431. columnApi: this.columnApi
  6432. };
  6433. this.eventService.dispatchEvent(event);
  6434. };
  6435. ColumnController.prototype.getSecondaryPivotColumn = function (pivotKeys, valueColKey) {
  6436. if (!this.secondaryColumnsPresent || !this.secondaryColumns) {
  6437. return null;
  6438. }
  6439. var valueColumnToFind = this.getPrimaryColumn(valueColKey);
  6440. var foundColumn = null;
  6441. this.secondaryColumns.forEach(function (column) {
  6442. var thisPivotKeys = column.getColDef().pivotKeys;
  6443. var pivotValueColumn = column.getColDef().pivotValueColumn;
  6444. var pivotKeyMatches = Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["areEqual"])(thisPivotKeys, pivotKeys);
  6445. var pivotValueMatches = pivotValueColumn === valueColumnToFind;
  6446. if (pivotKeyMatches && pivotValueMatches) {
  6447. foundColumn = column;
  6448. }
  6449. });
  6450. return foundColumn;
  6451. };
  6452. ColumnController.prototype.setBeans = function (loggerFactory) {
  6453. this.logger = loggerFactory.create('ColumnController');
  6454. };
  6455. ColumnController.prototype.setFirstRightAndLastLeftPinned = function (source) {
  6456. var lastLeft;
  6457. var firstRight;
  6458. if (this.gridOptionsWrapper.isEnableRtl()) {
  6459. lastLeft = this.displayedLeftColumns ? this.displayedLeftColumns[0] : null;
  6460. firstRight = this.displayedRightColumns ? _utils__WEBPACK_IMPORTED_MODULE_9__["_"].last(this.displayedRightColumns) : null;
  6461. }
  6462. else {
  6463. lastLeft = this.displayedLeftColumns ? _utils__WEBPACK_IMPORTED_MODULE_9__["_"].last(this.displayedLeftColumns) : null;
  6464. firstRight = this.displayedRightColumns ? this.displayedRightColumns[0] : null;
  6465. }
  6466. this.gridColumns.forEach(function (column) {
  6467. column.setLastLeftPinned(column === lastLeft, source);
  6468. column.setFirstRightPinned(column === firstRight, source);
  6469. });
  6470. };
  6471. ColumnController.prototype.autoSizeColumns = function (keys, skipHeader, source) {
  6472. // because of column virtualisation, we can only do this function on columns that are
  6473. // actually rendered, as non-rendered columns (outside the viewport and not rendered
  6474. // due to column virtualisation) are not present. this can result in all rendered columns
  6475. // getting narrowed, which in turn introduces more rendered columns on the RHS which
  6476. // did not get autosized in the original run, leaving the visible grid with columns on
  6477. // the LHS sized, but RHS no. so we keep looping through the visible columns until
  6478. // no more cols are available (rendered) to be resized
  6479. var _this = this;
  6480. if (source === void 0) { source = "api"; }
  6481. // we autosize after animation frames finish in case any cell renderers need to complete first. this can
  6482. // happen eg if client code is calling api.autoSizeAllColumns() straight after grid is initialised, but grid
  6483. // hasn't fully drawn out all the cells yet (due to cell renderers in animation frames).
  6484. this.animationFrameService.flushAllFrames();
  6485. // keep track of which cols we have resized in here
  6486. var columnsAutosized = [];
  6487. // initialise with anything except 0 so that while loop executes at least once
  6488. var changesThisTimeAround = -1;
  6489. if (skipHeader == null) {
  6490. skipHeader = this.gridOptionsWrapper.isSkipHeaderOnAutoSize();
  6491. }
  6492. while (changesThisTimeAround !== 0) {
  6493. changesThisTimeAround = 0;
  6494. this.actionOnGridColumns(keys, function (column) {
  6495. // if already autosized, skip it
  6496. if (columnsAutosized.indexOf(column) >= 0) {
  6497. return false;
  6498. }
  6499. // get how wide this col should be
  6500. var preferredWidth = _this.autoWidthCalculator.getPreferredWidthForColumn(column, skipHeader);
  6501. // preferredWidth = -1 if this col is not on the screen
  6502. if (preferredWidth > 0) {
  6503. var newWidth = _this.normaliseColumnWidth(column, preferredWidth);
  6504. column.setActualWidth(newWidth, source);
  6505. columnsAutosized.push(column);
  6506. changesThisTimeAround++;
  6507. }
  6508. return true;
  6509. }, source);
  6510. }
  6511. if (columnsAutosized.length) {
  6512. var event_2 = {
  6513. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_RESIZED,
  6514. columns: columnsAutosized,
  6515. column: columnsAutosized.length === 1 ? columnsAutosized[0] : null,
  6516. finished: true,
  6517. api: this.gridApi,
  6518. columnApi: this.columnApi,
  6519. source: "autosizeColumns"
  6520. };
  6521. this.eventService.dispatchEvent(event_2);
  6522. }
  6523. };
  6524. ColumnController.prototype.autoSizeColumn = function (key, skipHeader, source) {
  6525. if (source === void 0) { source = "api"; }
  6526. if (key) {
  6527. this.autoSizeColumns([key], skipHeader, source);
  6528. }
  6529. };
  6530. ColumnController.prototype.autoSizeAllColumns = function (skipHeader, source) {
  6531. if (source === void 0) { source = "api"; }
  6532. var allDisplayedColumns = this.getAllDisplayedColumns();
  6533. this.autoSizeColumns(allDisplayedColumns, skipHeader, source);
  6534. };
  6535. ColumnController.prototype.getColumnsFromTree = function (rootColumns) {
  6536. var result = [];
  6537. var recursiveFindColumns = function (childColumns) {
  6538. for (var i = 0; i < childColumns.length; i++) {
  6539. var child = childColumns[i];
  6540. if (child instanceof _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"]) {
  6541. result.push(child);
  6542. }
  6543. else if (child instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__["OriginalColumnGroup"]) {
  6544. recursiveFindColumns(child.getChildren());
  6545. }
  6546. }
  6547. };
  6548. recursiveFindColumns(rootColumns);
  6549. return result;
  6550. };
  6551. ColumnController.prototype.getAllDisplayedColumnGroups = function () {
  6552. if (this.displayedLeftColumnTree && this.displayedRightColumnTree && this.displayedCentreColumnTree) {
  6553. return this.displayedLeftColumnTree
  6554. .concat(this.displayedCentreColumnTree)
  6555. .concat(this.displayedRightColumnTree);
  6556. }
  6557. return null;
  6558. };
  6559. // + columnSelectPanel
  6560. ColumnController.prototype.getPrimaryColumnTree = function () {
  6561. return this.primaryColumnTree;
  6562. };
  6563. // + gridPanel -> for resizing the body and setting top margin
  6564. ColumnController.prototype.getHeaderRowCount = function () {
  6565. return this.gridHeaderRowCount;
  6566. };
  6567. // + headerRenderer -> setting pinned body width
  6568. ColumnController.prototype.getLeftDisplayedColumnGroups = function () {
  6569. return this.displayedLeftColumnTree;
  6570. };
  6571. // + headerRenderer -> setting pinned body width
  6572. ColumnController.prototype.getRightDisplayedColumnGroups = function () {
  6573. return this.displayedRightColumnTree;
  6574. };
  6575. // + headerRenderer -> setting pinned body width
  6576. ColumnController.prototype.getCenterDisplayedColumnGroups = function () {
  6577. return this.displayedCentreColumnTree;
  6578. };
  6579. ColumnController.prototype.getDisplayedColumnGroups = function (type) {
  6580. switch (type) {
  6581. case _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT:
  6582. return this.getLeftDisplayedColumnGroups();
  6583. case _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT:
  6584. return this.getRightDisplayedColumnGroups();
  6585. default:
  6586. return this.getCenterDisplayedColumnGroups();
  6587. }
  6588. };
  6589. // gridPanel -> ensureColumnVisible
  6590. ColumnController.prototype.isColumnDisplayed = function (column) {
  6591. return this.getAllDisplayedColumns().indexOf(column) >= 0;
  6592. };
  6593. // + csvCreator
  6594. ColumnController.prototype.getAllDisplayedColumns = function () {
  6595. return this.allDisplayedColumns;
  6596. };
  6597. ColumnController.prototype.getAllDisplayedVirtualColumns = function () {
  6598. return this.allDisplayedVirtualColumns;
  6599. };
  6600. ColumnController.prototype.getDisplayedLeftColumnsForRow = function (rowNode) {
  6601. if (!this.colSpanActive) {
  6602. return this.displayedLeftColumns;
  6603. }
  6604. return this.getDisplayedColumnsForRow(rowNode, this.displayedLeftColumns);
  6605. };
  6606. ColumnController.prototype.getDisplayedRightColumnsForRow = function (rowNode) {
  6607. if (!this.colSpanActive) {
  6608. return this.displayedRightColumns;
  6609. }
  6610. return this.getDisplayedColumnsForRow(rowNode, this.displayedRightColumns);
  6611. };
  6612. ColumnController.prototype.getDisplayedColumnsForRow = function (rowNode, displayedColumns, filterCallback, emptySpaceBeforeColumn) {
  6613. var result = [];
  6614. var lastConsideredCol = null;
  6615. var _loop_1 = function (i) {
  6616. var col = displayedColumns[i];
  6617. var maxAllowedColSpan = displayedColumns.length - i;
  6618. var colSpan = Math.min(col.getColSpan(rowNode), maxAllowedColSpan);
  6619. var columnsToCheckFilter = [col];
  6620. if (colSpan > 1) {
  6621. var colsToRemove = colSpan - 1;
  6622. for (var j = 1; j <= colsToRemove; j++) {
  6623. columnsToCheckFilter.push(displayedColumns[i + j]);
  6624. }
  6625. i += colsToRemove;
  6626. }
  6627. // see which cols we should take out for column virtualisation
  6628. var filterPasses;
  6629. if (filterCallback) {
  6630. // if user provided a callback, means some columns may not be in the viewport.
  6631. // the user will NOT provide a callback if we are talking about pinned areas,
  6632. // as pinned areas have no horizontal scroll and do not virtualise the columns.
  6633. // if lots of columns, that means column spanning, and we set filterPasses = true
  6634. // if one or more of the columns spanned pass the filter.
  6635. filterPasses = false;
  6636. columnsToCheckFilter.forEach(function (colForFilter) {
  6637. if (filterCallback(colForFilter)) {
  6638. filterPasses = true;
  6639. }
  6640. });
  6641. }
  6642. else {
  6643. filterPasses = true;
  6644. }
  6645. if (filterPasses) {
  6646. if (result.length === 0 && lastConsideredCol) {
  6647. var gapBeforeColumn = emptySpaceBeforeColumn ? emptySpaceBeforeColumn(col) : false;
  6648. if (gapBeforeColumn) {
  6649. result.push(lastConsideredCol);
  6650. }
  6651. }
  6652. result.push(col);
  6653. }
  6654. lastConsideredCol = col;
  6655. out_i_1 = i;
  6656. };
  6657. var out_i_1;
  6658. for (var i = 0; i < displayedColumns.length; i++) {
  6659. _loop_1(i);
  6660. i = out_i_1;
  6661. }
  6662. return result;
  6663. };
  6664. // + rowRenderer
  6665. // if we are not column spanning, this just returns back the virtual centre columns,
  6666. // however if we are column spanning, then different rows can have different virtual
  6667. // columns, so we have to work out the list for each individual row.
  6668. ColumnController.prototype.getAllDisplayedCenterVirtualColumnsForRow = function (rowNode) {
  6669. var _this = this;
  6670. if (!this.colSpanActive) {
  6671. return this.allDisplayedCenterVirtualColumns;
  6672. }
  6673. var emptySpaceBeforeColumn = function (col) { return col.getLeft() > _this.viewportLeft; };
  6674. // if doing column virtualisation, then we filter based on the viewport.
  6675. var filterCallback = this.suppressColumnVirtualisation ? null : this.isColumnInViewport.bind(this);
  6676. return this.getDisplayedColumnsForRow(rowNode, this.displayedCenterColumns, filterCallback, emptySpaceBeforeColumn);
  6677. };
  6678. ColumnController.prototype.isColumnInViewport = function (col) {
  6679. var columnLeft = col.getLeft();
  6680. var columnRight = col.getLeft() + col.getActualWidth();
  6681. // adding 200 for buffer size, so some cols off viewport are rendered.
  6682. // this helps horizontal scrolling so user rarely sees white space (unless
  6683. // they scroll horizontally fast). however we are conservative, as the more
  6684. // buffer the slower the vertical redraw speed
  6685. var leftBounds = this.viewportLeft - 200;
  6686. var rightBounds = this.viewportRight + 200;
  6687. var columnToMuchLeft = columnLeft < leftBounds && columnRight < leftBounds;
  6688. var columnToMuchRight = columnLeft > rightBounds && columnRight > rightBounds;
  6689. return !columnToMuchLeft && !columnToMuchRight;
  6690. };
  6691. // used by:
  6692. // + angularGrid -> setting pinned body width
  6693. // note: this should be cached
  6694. ColumnController.prototype.getPinnedLeftContainerWidth = function () {
  6695. return this.getWidthOfColsInList(this.displayedLeftColumns);
  6696. };
  6697. // note: this should be cached
  6698. ColumnController.prototype.getPinnedRightContainerWidth = function () {
  6699. return this.getWidthOfColsInList(this.displayedRightColumns);
  6700. };
  6701. ColumnController.prototype.updatePrimaryColumnList = function (keys, masterList, actionIsAdd, columnCallback, eventType, source) {
  6702. var _this = this;
  6703. if (source === void 0) { source = "api"; }
  6704. if (!keys || _utils__WEBPACK_IMPORTED_MODULE_9__["_"].missingOrEmpty(keys)) {
  6705. return;
  6706. }
  6707. var atLeastOne = false;
  6708. keys.forEach(function (key) {
  6709. var columnToAdd = _this.getPrimaryColumn(key);
  6710. if (!columnToAdd) {
  6711. return;
  6712. }
  6713. if (actionIsAdd) {
  6714. if (masterList.indexOf(columnToAdd) >= 0) {
  6715. return;
  6716. }
  6717. masterList.push(columnToAdd);
  6718. }
  6719. else {
  6720. if (masterList.indexOf(columnToAdd) < 0) {
  6721. return;
  6722. }
  6723. _utils__WEBPACK_IMPORTED_MODULE_9__["_"].removeFromArray(masterList, columnToAdd);
  6724. }
  6725. columnCallback(columnToAdd);
  6726. atLeastOne = true;
  6727. });
  6728. if (!atLeastOne) {
  6729. return;
  6730. }
  6731. if (this.autoGroupsNeedBuilding) {
  6732. this.updateGridColumns();
  6733. }
  6734. this.updateDisplayedColumns(source);
  6735. var event = {
  6736. type: eventType,
  6737. columns: masterList,
  6738. column: masterList.length === 1 ? masterList[0] : null,
  6739. api: this.gridApi,
  6740. columnApi: this.columnApi,
  6741. source: source
  6742. };
  6743. this.eventService.dispatchEvent(event);
  6744. };
  6745. ColumnController.prototype.setRowGroupColumns = function (colKeys, source) {
  6746. if (source === void 0) { source = "api"; }
  6747. this.autoGroupsNeedBuilding = true;
  6748. this.setPrimaryColumnList(colKeys, this.rowGroupColumns, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, this.setRowGroupActive.bind(this), source);
  6749. };
  6750. ColumnController.prototype.setRowGroupActive = function (active, column, source) {
  6751. if (active === column.isRowGroupActive()) {
  6752. return;
  6753. }
  6754. column.setRowGroupActive(active, source);
  6755. if (!active && !this.gridOptionsWrapper.isSuppressMakeColumnVisibleAfterUnGroup()) {
  6756. column.setVisible(true, source);
  6757. }
  6758. };
  6759. ColumnController.prototype.addRowGroupColumn = function (key, source) {
  6760. if (source === void 0) { source = "api"; }
  6761. if (key) {
  6762. this.addRowGroupColumns([key], source);
  6763. }
  6764. };
  6765. ColumnController.prototype.addRowGroupColumns = function (keys, source) {
  6766. if (source === void 0) { source = "api"; }
  6767. this.autoGroupsNeedBuilding = true;
  6768. this.updatePrimaryColumnList(keys, this.rowGroupColumns, true, this.setRowGroupActive.bind(this, true), _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, source);
  6769. };
  6770. ColumnController.prototype.removeRowGroupColumns = function (keys, source) {
  6771. if (source === void 0) { source = "api"; }
  6772. this.autoGroupsNeedBuilding = true;
  6773. this.updatePrimaryColumnList(keys, this.rowGroupColumns, false, this.setRowGroupActive.bind(this, false), _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, source);
  6774. };
  6775. ColumnController.prototype.removeRowGroupColumn = function (key, source) {
  6776. if (source === void 0) { source = "api"; }
  6777. if (key) {
  6778. this.removeRowGroupColumns([key], source);
  6779. }
  6780. };
  6781. ColumnController.prototype.addPivotColumns = function (keys, source) {
  6782. if (source === void 0) { source = "api"; }
  6783. this.updatePrimaryColumnList(keys, this.pivotColumns, true, function (column) { return column.setPivotActive(true, source); }, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PIVOT_CHANGED, source);
  6784. };
  6785. ColumnController.prototype.setPivotColumns = function (colKeys, source) {
  6786. if (source === void 0) { source = "api"; }
  6787. this.setPrimaryColumnList(colKeys, this.pivotColumns, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PIVOT_CHANGED, function (added, column) {
  6788. column.setPivotActive(added, source);
  6789. }, source);
  6790. };
  6791. ColumnController.prototype.addPivotColumn = function (key, source) {
  6792. if (source === void 0) { source = "api"; }
  6793. this.addPivotColumns([key], source);
  6794. };
  6795. ColumnController.prototype.removePivotColumns = function (keys, source) {
  6796. if (source === void 0) { source = "api"; }
  6797. this.updatePrimaryColumnList(keys, this.pivotColumns, false, function (column) { return column.setPivotActive(false, source); }, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PIVOT_CHANGED, source);
  6798. };
  6799. ColumnController.prototype.removePivotColumn = function (key, source) {
  6800. if (source === void 0) { source = "api"; }
  6801. this.removePivotColumns([key], source);
  6802. };
  6803. ColumnController.prototype.setPrimaryColumnList = function (colKeys, masterList, eventName, columnCallback, source) {
  6804. var _this = this;
  6805. masterList.length = 0;
  6806. if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(colKeys)) {
  6807. colKeys.forEach(function (key) {
  6808. var column = _this.getPrimaryColumn(key);
  6809. if (column) {
  6810. masterList.push(column);
  6811. }
  6812. });
  6813. }
  6814. this.primaryColumns.forEach(function (column) {
  6815. var added = masterList.indexOf(column) >= 0;
  6816. columnCallback(added, column);
  6817. });
  6818. if (this.autoGroupsNeedBuilding) {
  6819. this.updateGridColumns();
  6820. }
  6821. this.updateDisplayedColumns(source);
  6822. var event = {
  6823. type: eventName,
  6824. columns: masterList,
  6825. column: masterList.length === 1 ? masterList[0] : null,
  6826. api: this.gridApi,
  6827. columnApi: this.columnApi,
  6828. source: source
  6829. };
  6830. this.eventService.dispatchEvent(event);
  6831. };
  6832. ColumnController.prototype.setValueColumns = function (colKeys, source) {
  6833. if (source === void 0) { source = "api"; }
  6834. this.setPrimaryColumnList(colKeys, this.valueColumns, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VALUE_CHANGED, this.setValueActive.bind(this), source);
  6835. };
  6836. ColumnController.prototype.setValueActive = function (active, column, source) {
  6837. if (active === column.isValueActive()) {
  6838. return;
  6839. }
  6840. column.setValueActive(active, source);
  6841. if (active && !column.getAggFunc()) {
  6842. var defaultAggFunc = this.aggFuncService.getDefaultAggFunc(column);
  6843. column.setAggFunc(defaultAggFunc);
  6844. }
  6845. };
  6846. ColumnController.prototype.addValueColumns = function (keys, source) {
  6847. if (source === void 0) { source = "api"; }
  6848. this.updatePrimaryColumnList(keys, this.valueColumns, true, this.setValueActive.bind(this, true), _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VALUE_CHANGED, source);
  6849. };
  6850. ColumnController.prototype.addValueColumn = function (colKey, source) {
  6851. if (source === void 0) { source = "api"; }
  6852. if (colKey) {
  6853. this.addValueColumns([colKey], source);
  6854. }
  6855. };
  6856. ColumnController.prototype.removeValueColumn = function (colKey, source) {
  6857. if (source === void 0) { source = "api"; }
  6858. this.removeValueColumns([colKey], source);
  6859. };
  6860. ColumnController.prototype.removeValueColumns = function (keys, source) {
  6861. if (source === void 0) { source = "api"; }
  6862. this.updatePrimaryColumnList(keys, this.valueColumns, false, this.setValueActive.bind(this, false), _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VALUE_CHANGED, source);
  6863. };
  6864. // returns the width we can set to this col, taking into consideration min and max widths
  6865. ColumnController.prototype.normaliseColumnWidth = function (column, newWidth) {
  6866. if (newWidth < column.getMinWidth()) {
  6867. newWidth = column.getMinWidth();
  6868. }
  6869. if (column.isGreaterThanMax(newWidth)) {
  6870. newWidth = column.getMaxWidth();
  6871. }
  6872. return newWidth;
  6873. };
  6874. ColumnController.prototype.getPrimaryOrGridColumn = function (key) {
  6875. var column = this.getPrimaryColumn(key);
  6876. return column || this.getGridColumn(key);
  6877. };
  6878. ColumnController.prototype.setColumnWidths = function (columnWidths, shiftKey, // @takeFromAdjacent - if user has 'shift' pressed, then pixels are taken from adjacent column
  6879. finished, // @finished - ends up in the event, tells the user if more events are to come
  6880. source) {
  6881. var _this = this;
  6882. if (source === void 0) { source = "api"; }
  6883. var sets = [];
  6884. columnWidths.forEach(function (columnWidth) {
  6885. var col = _this.getPrimaryOrGridColumn(columnWidth.key);
  6886. if (!col) {
  6887. return;
  6888. }
  6889. sets.push({
  6890. width: columnWidth.newWidth,
  6891. ratios: [1],
  6892. columns: [col]
  6893. });
  6894. // if user wants to do shift resize by default, then we invert the shift operation
  6895. var defaultIsShift = _this.gridOptionsWrapper.getColResizeDefault() === 'shift';
  6896. if (defaultIsShift) {
  6897. shiftKey = !shiftKey;
  6898. }
  6899. if (shiftKey) {
  6900. var otherCol = _this.getDisplayedColAfter(col);
  6901. if (!otherCol) {
  6902. return;
  6903. }
  6904. var widthDiff = col.getActualWidth() - columnWidth.newWidth;
  6905. var otherColWidth = otherCol.getActualWidth() + widthDiff;
  6906. sets.push({
  6907. width: otherColWidth,
  6908. ratios: [1],
  6909. columns: [otherCol]
  6910. });
  6911. }
  6912. });
  6913. if (sets.length === 0) {
  6914. return;
  6915. }
  6916. this.resizeColumnSets(sets, finished, source);
  6917. if (this.flexActive) {
  6918. this.refreshFlexedColumns();
  6919. }
  6920. };
  6921. ColumnController.prototype.checkMinAndMaxWidthsForSet = function (columnResizeSet) {
  6922. var columns = columnResizeSet.columns, width = columnResizeSet.width;
  6923. // every col has a min width, so sum them all up and see if we have enough room
  6924. // for all the min widths
  6925. var minWidthAccumulated = 0;
  6926. var maxWidthAccumulated = 0;
  6927. var maxWidthActive = true;
  6928. columns.forEach(function (col) {
  6929. minWidthAccumulated += col.getMinWidth();
  6930. if (col.getMaxWidth() > 0) {
  6931. maxWidthAccumulated += col.getMaxWidth();
  6932. }
  6933. else {
  6934. // if at least one columns has no max width, it means the group of columns
  6935. // then has no max width, as at least one column can take as much width as possible
  6936. maxWidthActive = false;
  6937. }
  6938. });
  6939. var minWidthPasses = width >= minWidthAccumulated;
  6940. var maxWidthPasses = !maxWidthActive || (width <= maxWidthAccumulated);
  6941. return minWidthPasses && maxWidthPasses;
  6942. };
  6943. // method takes sets of columns and resizes them. either all sets will be resized, or nothing
  6944. // be resized. this is used for example when user tries to resize a group and holds shift key,
  6945. // then both the current group (grows), and the adjacent group (shrinks), will get resized,
  6946. // so that's two sets for this method.
  6947. ColumnController.prototype.resizeColumnSets = function (resizeSets, finished, source) {
  6948. var passMinMaxCheck = !resizeSets || resizeSets.every(this.checkMinAndMaxWidthsForSet.bind(this));
  6949. if (!passMinMaxCheck) {
  6950. // even though we are not going to resize beyond min/max size, we still need to raise event when finished
  6951. if (finished) {
  6952. var columns = resizeSets && resizeSets.length > 0 ? resizeSets[0].columns : null;
  6953. var event_3 = {
  6954. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_RESIZED,
  6955. columns: columns,
  6956. column: columns && columns.length === 1 ? columns[0] : null,
  6957. finished: finished,
  6958. api: this.gridApi,
  6959. columnApi: this.columnApi,
  6960. source: source
  6961. };
  6962. this.eventService.dispatchEvent(event_3);
  6963. }
  6964. return; // don't resize!
  6965. }
  6966. var changedCols = [];
  6967. var allCols = [];
  6968. resizeSets.forEach(function (set) {
  6969. var width = set.width, columns = set.columns, ratios = set.ratios;
  6970. // keep track of pixels used, and last column gets the remaining,
  6971. // to cater for rounding errors, and min width adjustments
  6972. var newWidths = {};
  6973. var finishedCols = {};
  6974. columns.forEach(function (col) { return allCols.push(col); });
  6975. // the loop below goes through each col. if a col exceeds it's min/max width,
  6976. // it then gets set to its min/max width and the column is removed marked as 'finished'
  6977. // and the calculation is done again leaving this column out. take for example columns
  6978. // {A, width: 50, maxWidth: 100}
  6979. // {B, width: 50}
  6980. // {C, width: 50}
  6981. // and then the set is set to width 600 - on the first pass the grid tries to set each column
  6982. // to 200. it checks A and sees 200 > 100 and so sets the width to 100. col A is then marked
  6983. // as 'finished' and the calculation is done again with the remaining cols B and C, which end up
  6984. // splitting the remaining 500 pixels.
  6985. var finishedColsGrew = true;
  6986. var loopCount = 0;
  6987. var _loop_2 = function () {
  6988. loopCount++;
  6989. if (loopCount > 1000) {
  6990. // this should never happen, but in the future, someone might introduce a bug here,
  6991. // so we stop the browser from hanging and report bug properly
  6992. console.error('ag-Grid: infinite loop in resizeColumnSets');
  6993. return "break";
  6994. }
  6995. finishedColsGrew = false;
  6996. var subsetCols = [];
  6997. var subsetRatios = [];
  6998. var subsetRatioTotal = 0;
  6999. var pixelsToDistribute = width;
  7000. columns.forEach(function (col, index) {
  7001. var thisColFinished = finishedCols[col.getId()];
  7002. if (thisColFinished) {
  7003. pixelsToDistribute -= newWidths[col.getId()];
  7004. }
  7005. else {
  7006. subsetCols.push(col);
  7007. var ratioThisCol = ratios[index];
  7008. subsetRatioTotal += ratioThisCol;
  7009. subsetRatios.push(ratioThisCol);
  7010. }
  7011. });
  7012. // because we are not using all of the ratios (cols can be missing),
  7013. // we scale the ratio. if all columns are included, then subsetRatioTotal=1,
  7014. // and so the ratioScale will be 1.
  7015. var ratioScale = 1 / subsetRatioTotal;
  7016. subsetCols.forEach(function (col, index) {
  7017. var lastCol = index === (subsetCols.length - 1);
  7018. var colNewWidth;
  7019. if (lastCol) {
  7020. colNewWidth = pixelsToDistribute;
  7021. }
  7022. else {
  7023. colNewWidth = Math.round(ratios[index] * width * ratioScale);
  7024. pixelsToDistribute -= colNewWidth;
  7025. }
  7026. if (colNewWidth < col.getMinWidth()) {
  7027. colNewWidth = col.getMinWidth();
  7028. finishedCols[col.getId()] = true;
  7029. finishedColsGrew = true;
  7030. }
  7031. else if (col.getMaxWidth() > 0 && colNewWidth > col.getMaxWidth()) {
  7032. colNewWidth = col.getMaxWidth();
  7033. finishedCols[col.getId()] = true;
  7034. finishedColsGrew = true;
  7035. }
  7036. newWidths[col.getId()] = colNewWidth;
  7037. });
  7038. };
  7039. while (finishedColsGrew) {
  7040. var state_1 = _loop_2();
  7041. if (state_1 === "break")
  7042. break;
  7043. }
  7044. columns.forEach(function (col) {
  7045. var newWidth = newWidths[col.getId()];
  7046. if (col.getActualWidth() !== newWidth) {
  7047. col.setActualWidth(newWidth, source);
  7048. changedCols.push(col);
  7049. }
  7050. });
  7051. });
  7052. // if no cols changed, then no need to update more or send event.
  7053. var atLeastOneColChanged = changedCols.length > 0;
  7054. if (atLeastOneColChanged) {
  7055. this.setLeftValues(source);
  7056. this.updateBodyWidths();
  7057. this.checkDisplayedVirtualColumns();
  7058. }
  7059. // check for change first, to avoid unnecessary firing of events
  7060. // however we always fire 'finished' events. this is important
  7061. // when groups are resized, as if the group is changing slowly,
  7062. // eg 1 pixel at a time, then each change will fire change events
  7063. // in all the columns in the group, but only one with get the pixel.
  7064. if (atLeastOneColChanged || finished) {
  7065. var event_4 = {
  7066. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_RESIZED,
  7067. columns: allCols,
  7068. column: allCols.length === 1 ? allCols[0] : null,
  7069. finished: finished,
  7070. api: this.gridApi,
  7071. columnApi: this.columnApi,
  7072. source: source
  7073. };
  7074. this.eventService.dispatchEvent(event_4);
  7075. }
  7076. };
  7077. ColumnController.prototype.setColumnAggFunc = function (column, aggFunc, source) {
  7078. if (source === void 0) { source = "api"; }
  7079. if (!column) {
  7080. return;
  7081. }
  7082. column.setAggFunc(aggFunc);
  7083. var event = {
  7084. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VALUE_CHANGED,
  7085. columns: [column],
  7086. column: column,
  7087. api: this.gridApi,
  7088. columnApi: this.columnApi,
  7089. source: source
  7090. };
  7091. this.eventService.dispatchEvent(event);
  7092. };
  7093. ColumnController.prototype.moveRowGroupColumn = function (fromIndex, toIndex, source) {
  7094. if (source === void 0) { source = "api"; }
  7095. var column = this.rowGroupColumns[fromIndex];
  7096. this.rowGroupColumns.splice(fromIndex, 1);
  7097. this.rowGroupColumns.splice(toIndex, 0, column);
  7098. var event = {
  7099. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED,
  7100. columns: this.rowGroupColumns,
  7101. column: this.rowGroupColumns.length === 1 ? this.rowGroupColumns[0] : null,
  7102. api: this.gridApi,
  7103. columnApi: this.columnApi,
  7104. source: source
  7105. };
  7106. this.eventService.dispatchEvent(event);
  7107. };
  7108. ColumnController.prototype.moveColumns = function (columnsToMoveKeys, toIndex, source) {
  7109. if (source === void 0) { source = "api"; }
  7110. this.columnAnimationService.start();
  7111. if (toIndex > this.gridColumns.length - columnsToMoveKeys.length) {
  7112. console.warn('ag-Grid: tried to insert columns in invalid location, toIndex = ' + toIndex);
  7113. console.warn('ag-Grid: remember that you should not count the moving columns when calculating the new index');
  7114. return;
  7115. }
  7116. // we want to pull all the columns out first and put them into an ordered list
  7117. var columnsToMove = this.getGridColumns(columnsToMoveKeys);
  7118. var failedRules = !this.doesMovePassRules(columnsToMove, toIndex);
  7119. if (failedRules) {
  7120. return;
  7121. }
  7122. _utils__WEBPACK_IMPORTED_MODULE_9__["_"].moveInArray(this.gridColumns, columnsToMove, toIndex);
  7123. this.updateDisplayedColumns(source);
  7124. var event = {
  7125. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_MOVED,
  7126. columns: columnsToMove,
  7127. column: columnsToMove.length === 1 ? columnsToMove[0] : null,
  7128. toIndex: toIndex,
  7129. api: this.gridApi,
  7130. columnApi: this.columnApi,
  7131. source: source
  7132. };
  7133. this.eventService.dispatchEvent(event);
  7134. this.columnAnimationService.finish();
  7135. };
  7136. ColumnController.prototype.doesMovePassRules = function (columnsToMove, toIndex) {
  7137. // make a copy of what the grid columns would look like after the move
  7138. var proposedColumnOrder = this.gridColumns.slice();
  7139. _utils__WEBPACK_IMPORTED_MODULE_9__["_"].moveInArray(proposedColumnOrder, columnsToMove, toIndex);
  7140. // then check that the new proposed order of the columns passes all rules
  7141. if (!this.doesMovePassMarryChildren(proposedColumnOrder)) {
  7142. return false;
  7143. }
  7144. if (!this.doesMovePassLockedPositions(proposedColumnOrder)) {
  7145. return false;
  7146. }
  7147. return true;
  7148. };
  7149. ColumnController.prototype.doesMovePassLockedPositions = function (proposedColumnOrder) {
  7150. var foundNonLocked = false;
  7151. var rulePassed = true;
  7152. // go though the cols, see if any non-locked appear before any locked
  7153. proposedColumnOrder.forEach(function (col) {
  7154. if (col.getColDef().lockPosition) {
  7155. if (foundNonLocked) {
  7156. rulePassed = false;
  7157. }
  7158. }
  7159. else {
  7160. foundNonLocked = true;
  7161. }
  7162. });
  7163. return rulePassed;
  7164. };
  7165. ColumnController.prototype.doesMovePassMarryChildren = function (allColumnsCopy) {
  7166. var rulePassed = true;
  7167. this.columnUtils.depthFirstOriginalTreeSearch(null, this.gridBalancedTree, function (child) {
  7168. if (!(child instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__["OriginalColumnGroup"])) {
  7169. return;
  7170. }
  7171. var columnGroup = child;
  7172. var marryChildren = columnGroup.getColGroupDef() && columnGroup.getColGroupDef().marryChildren;
  7173. if (!marryChildren) {
  7174. return;
  7175. }
  7176. var newIndexes = [];
  7177. columnGroup.getLeafColumns().forEach(function (col) {
  7178. var newColIndex = allColumnsCopy.indexOf(col);
  7179. newIndexes.push(newColIndex);
  7180. });
  7181. var maxIndex = Math.max.apply(Math, newIndexes);
  7182. var minIndex = Math.min.apply(Math, newIndexes);
  7183. // spread is how far the first column in this group is away from the last column
  7184. var spread = maxIndex - minIndex;
  7185. var maxSpread = columnGroup.getLeafColumns().length - 1;
  7186. // if the columns
  7187. if (spread > maxSpread) {
  7188. rulePassed = false;
  7189. }
  7190. // console.log(`maxIndex = ${maxIndex}, minIndex = ${minIndex}, spread = ${spread}, maxSpread = ${maxSpread}, fail = ${spread > (count-1)}`)
  7191. // console.log(allColumnsCopy.map( col => col.getColDef().field).join(','));
  7192. });
  7193. return rulePassed;
  7194. };
  7195. ColumnController.prototype.moveColumn = function (key, toIndex, source) {
  7196. if (source === void 0) { source = "api"; }
  7197. this.moveColumns([key], toIndex, source);
  7198. };
  7199. ColumnController.prototype.moveColumnByIndex = function (fromIndex, toIndex, source) {
  7200. if (source === void 0) { source = "api"; }
  7201. var column = this.gridColumns[fromIndex];
  7202. this.moveColumn(column, toIndex, source);
  7203. };
  7204. // used by:
  7205. // + angularGrid -> for setting body width
  7206. // + rowController -> setting main row widths (when inserting and resizing)
  7207. // need to cache this
  7208. ColumnController.prototype.getBodyContainerWidth = function () {
  7209. return this.bodyWidth;
  7210. };
  7211. ColumnController.prototype.getContainerWidth = function (pinned) {
  7212. switch (pinned) {
  7213. case _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT:
  7214. return this.leftWidth;
  7215. case _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT:
  7216. return this.rightWidth;
  7217. default:
  7218. return this.bodyWidth;
  7219. }
  7220. };
  7221. // after setColumnWidth or updateGroupsAndDisplayedColumns
  7222. ColumnController.prototype.updateBodyWidths = function () {
  7223. var newBodyWidth = this.getWidthOfColsInList(this.displayedCenterColumns);
  7224. var newLeftWidth = this.getWidthOfColsInList(this.displayedLeftColumns);
  7225. var newRightWidth = this.getWidthOfColsInList(this.displayedRightColumns);
  7226. // this is used by virtual col calculation, for RTL only, as a change to body width can impact displayed
  7227. // columns, due to RTL inverting the y coordinates
  7228. this.bodyWidthDirty = this.bodyWidth !== newBodyWidth;
  7229. var atLeastOneChanged = this.bodyWidth !== newBodyWidth || this.leftWidth !== newLeftWidth || this.rightWidth !== newRightWidth;
  7230. if (atLeastOneChanged) {
  7231. this.bodyWidth = newBodyWidth;
  7232. this.leftWidth = newLeftWidth;
  7233. this.rightWidth = newRightWidth;
  7234. // when this fires, it is picked up by the gridPanel, which ends up in
  7235. // gridPanel calling setWidthAndScrollPosition(), which in turn calls setVirtualViewportPosition()
  7236. var event_5 = {
  7237. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED,
  7238. api: this.gridApi,
  7239. columnApi: this.columnApi
  7240. };
  7241. this.eventService.dispatchEvent(event_5);
  7242. }
  7243. };
  7244. // + rowController
  7245. ColumnController.prototype.getValueColumns = function () {
  7246. return this.valueColumns ? this.valueColumns : [];
  7247. };
  7248. // + rowController
  7249. ColumnController.prototype.getPivotColumns = function () {
  7250. return this.pivotColumns ? this.pivotColumns : [];
  7251. };
  7252. // + clientSideRowModel
  7253. ColumnController.prototype.isPivotActive = function () {
  7254. return this.pivotColumns && this.pivotColumns.length > 0 && this.pivotMode;
  7255. };
  7256. // + toolPanel
  7257. ColumnController.prototype.getRowGroupColumns = function () {
  7258. return this.rowGroupColumns ? this.rowGroupColumns : [];
  7259. };
  7260. // + rowController -> while inserting rows
  7261. ColumnController.prototype.getDisplayedCenterColumns = function () {
  7262. return this.displayedCenterColumns;
  7263. };
  7264. // + rowController -> while inserting rows
  7265. ColumnController.prototype.getDisplayedLeftColumns = function () {
  7266. return this.displayedLeftColumns;
  7267. };
  7268. ColumnController.prototype.getDisplayedRightColumns = function () {
  7269. return this.displayedRightColumns;
  7270. };
  7271. ColumnController.prototype.getDisplayedColumns = function (type) {
  7272. switch (type) {
  7273. case _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT:
  7274. return this.getDisplayedLeftColumns();
  7275. case _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT:
  7276. return this.getDisplayedRightColumns();
  7277. default:
  7278. return this.getDisplayedCenterColumns();
  7279. }
  7280. };
  7281. // used by:
  7282. // + clientSideRowController -> sorting, building quick filter text
  7283. // + headerRenderer -> sorting (clearing icon)
  7284. ColumnController.prototype.getAllPrimaryColumns = function () {
  7285. return this.primaryColumns ? this.primaryColumns.slice() : null;
  7286. };
  7287. ColumnController.prototype.getSecondaryColumns = function () {
  7288. return this.secondaryColumns ? this.secondaryColumns.slice() : null;
  7289. };
  7290. ColumnController.prototype.getAllColumnsForQuickFilter = function () {
  7291. return this.columnsForQuickFilter;
  7292. };
  7293. // + moveColumnController
  7294. ColumnController.prototype.getAllGridColumns = function () {
  7295. return this.gridColumns;
  7296. };
  7297. ColumnController.prototype.isEmpty = function () {
  7298. return _utils__WEBPACK_IMPORTED_MODULE_9__["_"].missingOrEmpty(this.gridColumns);
  7299. };
  7300. ColumnController.prototype.isRowGroupEmpty = function () {
  7301. return _utils__WEBPACK_IMPORTED_MODULE_9__["_"].missingOrEmpty(this.rowGroupColumns);
  7302. };
  7303. ColumnController.prototype.setColumnVisible = function (key, visible, source) {
  7304. if (source === void 0) { source = "api"; }
  7305. this.setColumnsVisible([key], visible, source);
  7306. };
  7307. ColumnController.prototype.setColumnsVisible = function (keys, visible, source) {
  7308. var _this = this;
  7309. if (source === void 0) { source = "api"; }
  7310. this.columnAnimationService.start();
  7311. this.actionOnGridColumns(keys, function (column) {
  7312. if (column.isVisible() !== visible) {
  7313. column.setVisible(visible, source);
  7314. return true;
  7315. }
  7316. return false;
  7317. }, source, function () {
  7318. var event = {
  7319. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VISIBLE,
  7320. visible: visible,
  7321. column: null,
  7322. columns: null,
  7323. api: _this.gridApi,
  7324. columnApi: _this.columnApi,
  7325. source: source
  7326. };
  7327. return event;
  7328. });
  7329. this.columnAnimationService.finish();
  7330. };
  7331. ColumnController.prototype.setColumnPinned = function (key, pinned, source) {
  7332. if (source === void 0) { source = "api"; }
  7333. if (key) {
  7334. this.setColumnsPinned([key], pinned, source);
  7335. }
  7336. };
  7337. ColumnController.prototype.setColumnsPinned = function (keys, pinned, source) {
  7338. var _this = this;
  7339. if (source === void 0) { source = "api"; }
  7340. if (this.gridOptionsWrapper.getDomLayout() === 'print') {
  7341. console.warn("Changing the column pinning status is not allowed with domLayout='print'");
  7342. return;
  7343. }
  7344. this.columnAnimationService.start();
  7345. var actualPinned;
  7346. if (pinned === true || pinned === _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT) {
  7347. actualPinned = _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT;
  7348. }
  7349. else if (pinned === _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT) {
  7350. actualPinned = _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT;
  7351. }
  7352. else {
  7353. actualPinned = null;
  7354. }
  7355. this.actionOnGridColumns(keys, function (col) {
  7356. if (col.getPinned() !== actualPinned) {
  7357. col.setPinned(actualPinned);
  7358. return true;
  7359. }
  7360. return false;
  7361. }, source, function () {
  7362. var event = {
  7363. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PINNED,
  7364. pinned: actualPinned,
  7365. column: null,
  7366. columns: null,
  7367. api: _this.gridApi,
  7368. columnApi: _this.columnApi,
  7369. source: source
  7370. };
  7371. return event;
  7372. });
  7373. this.columnAnimationService.finish();
  7374. };
  7375. // does an action on a set of columns. provides common functionality for looking up the
  7376. // columns based on key, getting a list of effected columns, and then updated the event
  7377. // with either one column (if it was just one col) or a list of columns
  7378. // used by: autoResize, setVisible, setPinned
  7379. ColumnController.prototype.actionOnGridColumns = function (// the column keys this action will be on
  7380. keys,
  7381. // the action to do - if this returns false, the column was skipped
  7382. // and won't be included in the event
  7383. action,
  7384. // should return back a column event of the right type
  7385. source, createEvent) {
  7386. var _this = this;
  7387. if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].missingOrEmpty(keys)) {
  7388. return;
  7389. }
  7390. var updatedColumns = [];
  7391. keys.forEach(function (key) {
  7392. var column = _this.getGridColumn(key);
  7393. if (!column) {
  7394. return;
  7395. }
  7396. // need to check for false with type (ie !== instead of !=)
  7397. // as not returning anything (undefined) would also be false
  7398. var resultOfAction = action(column);
  7399. if (resultOfAction !== false) {
  7400. updatedColumns.push(column);
  7401. }
  7402. });
  7403. if (!updatedColumns.length) {
  7404. return;
  7405. }
  7406. this.updateDisplayedColumns(source);
  7407. if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(createEvent) && createEvent) {
  7408. var event_6 = createEvent();
  7409. event_6.columns = updatedColumns;
  7410. event_6.column = updatedColumns.length === 1 ? updatedColumns[0] : null;
  7411. this.eventService.dispatchEvent(event_6);
  7412. }
  7413. };
  7414. ColumnController.prototype.getDisplayedColBefore = function (col) {
  7415. var allDisplayedColumns = this.getAllDisplayedColumns();
  7416. var oldIndex = allDisplayedColumns.indexOf(col);
  7417. if (oldIndex > 0) {
  7418. return allDisplayedColumns[oldIndex - 1];
  7419. }
  7420. return null;
  7421. };
  7422. // used by:
  7423. // + rowRenderer -> for navigation
  7424. ColumnController.prototype.getDisplayedColAfter = function (col) {
  7425. var allDisplayedColumns = this.getAllDisplayedColumns();
  7426. var oldIndex = allDisplayedColumns.indexOf(col);
  7427. if (oldIndex < (allDisplayedColumns.length - 1)) {
  7428. return allDisplayedColumns[oldIndex + 1];
  7429. }
  7430. return null;
  7431. };
  7432. ColumnController.prototype.getDisplayedGroupAfter = function (columnGroup) {
  7433. return this.getDisplayedGroupAtDirection(columnGroup, 'After');
  7434. };
  7435. ColumnController.prototype.getDisplayedGroupBefore = function (columnGroup) {
  7436. return this.getDisplayedGroupAtDirection(columnGroup, 'Before');
  7437. };
  7438. ColumnController.prototype.getDisplayedGroupAtDirection = function (columnGroup, direction) {
  7439. // pick the last displayed column in this group
  7440. var requiredLevel = columnGroup.getOriginalColumnGroup().getLevel() + columnGroup.getPaddingLevel();
  7441. var colGroupLeafColumns = columnGroup.getDisplayedLeafColumns();
  7442. var col = direction === 'After' ? _utils__WEBPACK_IMPORTED_MODULE_9__["_"].last(colGroupLeafColumns) : colGroupLeafColumns[0];
  7443. var getDisplayColMethod = "getDisplayedCol" + direction;
  7444. while (true) {
  7445. // keep moving to the next col, until we get to another group
  7446. var column = this[getDisplayColMethod](col);
  7447. if (!column) {
  7448. return null;
  7449. }
  7450. var groupPointer = this.getColumnGroupAtLevel(column, requiredLevel);
  7451. if (groupPointer !== columnGroup) {
  7452. return groupPointer;
  7453. }
  7454. }
  7455. };
  7456. ColumnController.prototype.getColumnGroupAtLevel = function (column, level) {
  7457. // get group at same level as the one we are looking for
  7458. var groupPointer = column.getParent();
  7459. var originalGroupLevel;
  7460. var groupPointerLevel;
  7461. while (true) {
  7462. var groupPointerOriginalColumnGroup = groupPointer.getOriginalColumnGroup();
  7463. originalGroupLevel = groupPointerOriginalColumnGroup.getLevel();
  7464. groupPointerLevel = groupPointer.getPaddingLevel();
  7465. if (originalGroupLevel + groupPointerLevel <= level) {
  7466. break;
  7467. }
  7468. groupPointer = groupPointer.getParent();
  7469. }
  7470. return groupPointer;
  7471. };
  7472. ColumnController.prototype.isPinningLeft = function () {
  7473. return this.displayedLeftColumns.length > 0;
  7474. };
  7475. ColumnController.prototype.isPinningRight = function () {
  7476. return this.displayedRightColumns.length > 0;
  7477. };
  7478. ColumnController.prototype.getPrimaryAndSecondaryAndAutoColumns = function () {
  7479. var result = this.primaryColumns ? this.primaryColumns.slice(0) : [];
  7480. if (this.groupAutoColumns && _utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(this.groupAutoColumns)) {
  7481. this.groupAutoColumns.forEach(function (col) { return result.push(col); });
  7482. }
  7483. if (this.secondaryColumnsPresent && this.secondaryColumns) {
  7484. this.secondaryColumns.forEach(function (column) { return result.push(column); });
  7485. }
  7486. return result;
  7487. };
  7488. ColumnController.prototype.createStateItemFromColumn = function (column) {
  7489. var rowGroupIndex = column.isRowGroupActive() ? this.rowGroupColumns.indexOf(column) : null;
  7490. var pivotIndex = column.isPivotActive() ? this.pivotColumns.indexOf(column) : null;
  7491. var aggFunc = column.isValueActive() ? column.getAggFunc() : null;
  7492. return {
  7493. colId: column.getColId(),
  7494. hide: !column.isVisible(),
  7495. aggFunc: aggFunc,
  7496. width: column.getActualWidth(),
  7497. pivotIndex: pivotIndex,
  7498. pinned: column.getPinned(),
  7499. rowGroupIndex: rowGroupIndex,
  7500. flex: column.getFlex()
  7501. };
  7502. };
  7503. ColumnController.prototype.getColumnState = function () {
  7504. if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].missing(this.primaryColumns)) {
  7505. return [];
  7506. }
  7507. var primaryColumnState = this.primaryColumns.map(this.createStateItemFromColumn.bind(this));
  7508. var groupAutoColumnState = this.groupAutoColumns
  7509. // if groupAutoCols, then include them
  7510. ? this.groupAutoColumns.map(this.createStateItemFromColumn.bind(this))
  7511. // otherwise no
  7512. : [];
  7513. var columnStateList = groupAutoColumnState.concat(primaryColumnState);
  7514. if (!this.pivotMode) {
  7515. this.orderColumnStateList(columnStateList);
  7516. }
  7517. return columnStateList;
  7518. };
  7519. ColumnController.prototype.orderColumnStateList = function (columnStateList) {
  7520. var gridColumnIds = this.gridColumns.map(function (column) { return column.getColId(); });
  7521. columnStateList.sort(function (itemA, itemB) {
  7522. var posA = gridColumnIds.indexOf(itemA.colId);
  7523. var posB = gridColumnIds.indexOf(itemB.colId);
  7524. return posA - posB;
  7525. });
  7526. };
  7527. ColumnController.prototype.resetColumnState = function (suppressEverythingEvent, source) {
  7528. // NOTE = there is one bug here that no customer has noticed - if a column has colDef.lockPosition,
  7529. // this is ignored below when ordering the cols. to work, we should always put lockPosition cols first.
  7530. // As a work around, developers should just put lockPosition columns first in their colDef list.
  7531. if (suppressEverythingEvent === void 0) { suppressEverythingEvent = false; }
  7532. if (source === void 0) { source = "api"; }
  7533. // we can't use 'allColumns' as the order might of messed up, so get the primary ordered list
  7534. var primaryColumns = this.getColumnsFromTree(this.primaryColumnTree);
  7535. var columnStates = [];
  7536. // we start at 1000, so if user has mix of rowGroup and group specified, it will work with both.
  7537. // eg IF user has ColA.rowGroupIndex=0, ColB.rowGroupIndex=1, ColC.rowGroup=true,
  7538. // THEN result will be ColA.rowGroupIndex=0, ColB.rowGroupIndex=1, ColC.rowGroup=1000
  7539. var letRowGroupIndex = 1000;
  7540. var letPivotIndex = 1000;
  7541. if (primaryColumns) {
  7542. primaryColumns.forEach(function (column) {
  7543. var rowGroupIndex = column.getColDef().rowGroupIndex;
  7544. var rowGroup = column.getColDef().rowGroup;
  7545. var pivotIndex = column.getColDef().pivotIndex;
  7546. var pivot = column.getColDef().pivot;
  7547. var stateItem = {
  7548. colId: column.getColId(),
  7549. aggFunc: column.getColDef().aggFunc,
  7550. hide: column.getColDef().hide,
  7551. pinned: column.getColDef().pinned,
  7552. rowGroupIndex: rowGroupIndex,
  7553. pivotIndex: column.getColDef().pivotIndex,
  7554. width: column.getColDef().width
  7555. };
  7556. if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].missing(rowGroupIndex) && rowGroup) {
  7557. stateItem.rowGroupIndex = letRowGroupIndex++;
  7558. }
  7559. if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].missing(pivotIndex) && pivot) {
  7560. stateItem.pivotIndex = letPivotIndex++;
  7561. }
  7562. columnStates.push(stateItem);
  7563. });
  7564. }
  7565. this.setColumnState(columnStates, suppressEverythingEvent, source);
  7566. };
  7567. ColumnController.prototype.setColumnState = function (columnStates, suppressEverythingEvent, source) {
  7568. var _this = this;
  7569. if (suppressEverythingEvent === void 0) { suppressEverythingEvent = false; }
  7570. if (source === void 0) { source = "api"; }
  7571. if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].missingOrEmpty(this.primaryColumns)) {
  7572. return false;
  7573. }
  7574. var columnStateBefore = this.getColumnState();
  7575. this.autoGroupsNeedBuilding = true;
  7576. // at the end below, this list will have all columns we got no state for
  7577. var columnsWithNoState = this.primaryColumns.slice();
  7578. this.rowGroupColumns = [];
  7579. this.valueColumns = [];
  7580. this.pivotColumns = [];
  7581. var success = true;
  7582. var rowGroupIndexes = {};
  7583. var pivotIndexes = {};
  7584. var autoGroupColumnStates = [];
  7585. if (columnStates) {
  7586. columnStates.forEach(function (state) {
  7587. // auto group columns are re-created so deferring syncing with ColumnState
  7588. if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(_this.getAutoColumn(state.colId))) {
  7589. autoGroupColumnStates.push(state);
  7590. return;
  7591. }
  7592. var column = _this.getPrimaryColumn(state.colId);
  7593. if (!column) {
  7594. console.warn('ag-grid: column ' + state.colId + ' not found');
  7595. success = false;
  7596. }
  7597. else {
  7598. _this.syncColumnWithStateItem(column, state, rowGroupIndexes, pivotIndexes, source);
  7599. _utils__WEBPACK_IMPORTED_MODULE_9__["_"].removeFromArray(columnsWithNoState, column);
  7600. }
  7601. });
  7602. if (this.flexActive) {
  7603. this.refreshFlexedColumns(undefined, undefined, true);
  7604. }
  7605. }
  7606. // anything left over, we got no data for, so add in the column as non-value, non-rowGroup and hidden
  7607. columnsWithNoState.forEach(this.syncColumnWithNoState.bind(this));
  7608. // sort the lists according to the indexes that were provided
  7609. this.rowGroupColumns.sort(this.sortColumnListUsingIndexes.bind(this, rowGroupIndexes));
  7610. this.pivotColumns.sort(this.sortColumnListUsingIndexes.bind(this, pivotIndexes));
  7611. this.updateGridColumns();
  7612. // sync newly created auto group columns with ColumnState
  7613. autoGroupColumnStates.forEach(function (stateItem) {
  7614. var autoCol = _this.getAutoColumn(stateItem.colId);
  7615. _this.syncColumnWithStateItem(autoCol, stateItem, rowGroupIndexes, pivotIndexes, source);
  7616. });
  7617. if (columnStates) {
  7618. var orderOfColIds_1 = columnStates.map(function (stateItem) { return stateItem.colId; });
  7619. this.gridColumns.sort(function (colA, colB) {
  7620. var indexA = orderOfColIds_1.indexOf(colA.getId());
  7621. var indexB = orderOfColIds_1.indexOf(colB.getId());
  7622. return indexA - indexB;
  7623. });
  7624. }
  7625. // this is already done in updateGridColumns, however we changed the order above (to match the order of the state
  7626. // columns) so we need to do it again. we could of put logic into the order above to take into account fixed
  7627. // columns, however if we did then we would have logic for updating fixed columns twice. reusing the logic here
  7628. // is less sexy for the code here, but it keeps consistency.
  7629. this.putFixedColumnsFirst();
  7630. this.updateDisplayedColumns(source);
  7631. if (!suppressEverythingEvent) {
  7632. var event_7 = {
  7633. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_EVERYTHING_CHANGED,
  7634. api: this.gridApi,
  7635. columnApi: this.columnApi,
  7636. source: source
  7637. };
  7638. this.eventService.dispatchEvent(event_7);
  7639. }
  7640. this.raiseColumnEvents(columnStateBefore, source);
  7641. return success;
  7642. };
  7643. ColumnController.prototype.raiseColumnEvents = function (columnStateBefore, source) {
  7644. var _this = this;
  7645. if (this.gridOptionsWrapper.isSuppressSetColumnStateEvents()) {
  7646. return;
  7647. }
  7648. var columnStateAfter = this.getColumnState();
  7649. // raises generic ColumnEvents where all columns are returned rather than what has changed
  7650. var raiseEventWithAllColumns = function (eventType, idMapper, columns) {
  7651. var unchanged = Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["areEqual"])(columnStateBefore.map(idMapper).sort(), columnStateAfter.map(idMapper).sort());
  7652. if (unchanged) {
  7653. return;
  7654. }
  7655. // returning all columns rather than what has changed!
  7656. var event = {
  7657. type: eventType,
  7658. columns: columns,
  7659. column: columns.length === 1 ? columns[0] : null,
  7660. api: _this.gridApi,
  7661. columnApi: _this.columnApi,
  7662. source: source
  7663. };
  7664. _this.eventService.dispatchEvent(event);
  7665. };
  7666. // determines which columns have changed according to supplied predicate
  7667. var getChangedColumns = function (changedPredicate) {
  7668. var changedColumns = [];
  7669. var columnStateBeforeMap = {};
  7670. columnStateBefore.forEach(function (col) {
  7671. columnStateBeforeMap[col.colId] = col;
  7672. });
  7673. _this.gridColumns.forEach(function (column) {
  7674. var colStateBefore = columnStateBeforeMap[column.getColId()];
  7675. if (!colStateBefore || changedPredicate(colStateBefore, column)) {
  7676. changedColumns.push(column);
  7677. }
  7678. });
  7679. return changedColumns;
  7680. };
  7681. // generic ColumnEvents which return current column list
  7682. var valueColumnIdMapper = function (cs) { return cs.colId + '-' + cs.aggFunc; };
  7683. raiseEventWithAllColumns(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VALUE_CHANGED, valueColumnIdMapper, this.valueColumns);
  7684. var pivotColumnIdMapper = function (cs) { return cs.colId + '-' + cs.pivotIndex; };
  7685. raiseEventWithAllColumns(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PIVOT_CHANGED, pivotColumnIdMapper, this.pivotColumns);
  7686. var rowGroupColumnIdMapper = function (cs) { return cs.colId + '-' + cs.rowGroupIndex; };
  7687. raiseEventWithAllColumns(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, rowGroupColumnIdMapper, this.rowGroupColumns);
  7688. // specific ColumnEvents which return what's changed
  7689. var pinnedChangePredicate = function (cs, c) { return cs.pinned !== c.getPinned(); };
  7690. this.raiseColumnPinnedEvent(getChangedColumns(pinnedChangePredicate), source);
  7691. var visibilityChangePredicate = function (cs, c) { return cs.hide === c.isVisible(); };
  7692. var cols = getChangedColumns(visibilityChangePredicate);
  7693. this.raiseColumnVisibleEvent(cols, source);
  7694. var resizeChangePredicate = function (cs, c) { return cs.width !== c.getActualWidth(); };
  7695. this.raiseColumnResizeEvent(getChangedColumns(resizeChangePredicate), source);
  7696. // special handling for moved column events
  7697. this.raiseColumnMovedEvent(columnStateBefore, source);
  7698. };
  7699. ColumnController.prototype.raiseColumnPinnedEvent = function (changedColumns, source) {
  7700. if (!changedColumns.length) {
  7701. return;
  7702. }
  7703. var event = {
  7704. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PINNED,
  7705. pinned: null,
  7706. columns: changedColumns,
  7707. column: null,
  7708. api: this.gridApi,
  7709. columnApi: this.columnApi,
  7710. source: source
  7711. };
  7712. this.eventService.dispatchEvent(event);
  7713. };
  7714. ColumnController.prototype.raiseColumnVisibleEvent = function (changedColumns, source) {
  7715. if (!changedColumns.length) {
  7716. return;
  7717. }
  7718. var event = {
  7719. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_VISIBLE,
  7720. visible: undefined,
  7721. columns: changedColumns,
  7722. column: null,
  7723. api: this.gridApi,
  7724. columnApi: this.columnApi,
  7725. source: source
  7726. };
  7727. this.eventService.dispatchEvent(event);
  7728. };
  7729. ColumnController.prototype.raiseColumnResizeEvent = function (changedColumns, source) {
  7730. if (!changedColumns.length) {
  7731. return;
  7732. }
  7733. var event = {
  7734. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_RESIZED,
  7735. columns: changedColumns,
  7736. column: null,
  7737. finished: true,
  7738. api: this.gridApi,
  7739. columnApi: this.columnApi,
  7740. source: source
  7741. };
  7742. this.eventService.dispatchEvent(event);
  7743. };
  7744. ColumnController.prototype.raiseColumnMovedEvent = function (columnStateBefore, source) {
  7745. var movedColumns = [];
  7746. var columnStateAfter = this.getColumnState();
  7747. var _loop_3 = function (i) {
  7748. var before = columnStateBefore[i];
  7749. var after = columnStateAfter[i];
  7750. // don't consider column if reintroduced or hidden
  7751. if (!before || after.hide) {
  7752. return "continue";
  7753. }
  7754. if (before.colId !== after.colId) {
  7755. var predicate = function (column) { return column.getColId() === after.colId; };
  7756. var movedColumn = _utils__WEBPACK_IMPORTED_MODULE_9__["_"].find(this_1.allDisplayedColumns, predicate);
  7757. movedColumns.push(movedColumn);
  7758. }
  7759. };
  7760. var this_1 = this;
  7761. for (var i = 0; i < columnStateAfter.length; i++) {
  7762. _loop_3(i);
  7763. }
  7764. if (!movedColumns.length) {
  7765. return;
  7766. }
  7767. var event = {
  7768. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_MOVED,
  7769. columns: movedColumns,
  7770. column: null,
  7771. toIndex: undefined,
  7772. api: this.gridApi,
  7773. columnApi: this.columnApi,
  7774. source: source
  7775. };
  7776. this.eventService.dispatchEvent(event);
  7777. };
  7778. ColumnController.prototype.sortColumnListUsingIndexes = function (indexes, colA, colB) {
  7779. var indexA = indexes[colA.getId()];
  7780. var indexB = indexes[colB.getId()];
  7781. return indexA - indexB;
  7782. };
  7783. ColumnController.prototype.syncColumnWithNoState = function (column, source) {
  7784. column.setVisible(false, source);
  7785. column.setAggFunc(null);
  7786. column.setPinned(null);
  7787. column.setRowGroupActive(false, source);
  7788. column.setPivotActive(false, source);
  7789. column.setValueActive(false, source);
  7790. };
  7791. ColumnController.prototype.syncColumnWithStateItem = function (column, stateItem, rowGroupIndexes, pivotIndexes, source) {
  7792. if (!column) {
  7793. return;
  7794. }
  7795. // following ensures we are left with boolean true or false, eg converts (null, undefined, 0) all to true
  7796. column.setVisible(!stateItem.hide, source);
  7797. // sets pinned to 'left' or 'right'
  7798. column.setPinned(stateItem.pinned);
  7799. // if width provided and valid, use it, otherwise stick with the old width
  7800. var minColWidth = this.gridOptionsWrapper.getMinColWidth();
  7801. if (stateItem.flex != null) {
  7802. column.setFlex(stateItem.flex);
  7803. if (!this.flexActive && stateItem.flex) {
  7804. this.flexActive = true;
  7805. }
  7806. }
  7807. if (stateItem.width && minColWidth &&
  7808. (stateItem.width >= minColWidth)) {
  7809. column.setActualWidth(stateItem.width, source);
  7810. }
  7811. if (typeof stateItem.aggFunc === 'string') {
  7812. column.setAggFunc(stateItem.aggFunc);
  7813. column.setValueActive(true, source);
  7814. this.valueColumns.push(column);
  7815. }
  7816. else {
  7817. if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(stateItem.aggFunc)) {
  7818. console.warn('ag-Grid: stateItem.aggFunc must be a string. if using your own aggregation ' +
  7819. 'functions, register the functions first before using them in get/set state. This is because it is ' +
  7820. 'intended for the column state to be stored and retrieved as simple JSON.');
  7821. }
  7822. column.setAggFunc(null);
  7823. column.setValueActive(false, source);
  7824. }
  7825. if (typeof stateItem.rowGroupIndex === 'number') {
  7826. this.rowGroupColumns.push(column);
  7827. column.setRowGroupActive(true, source);
  7828. rowGroupIndexes[column.getId()] = stateItem.rowGroupIndex;
  7829. }
  7830. else {
  7831. column.setRowGroupActive(false, source);
  7832. }
  7833. if (typeof stateItem.pivotIndex === 'number') {
  7834. this.pivotColumns.push(column);
  7835. column.setPivotActive(true, source);
  7836. pivotIndexes[column.getId()] = stateItem.pivotIndex;
  7837. }
  7838. else {
  7839. column.setPivotActive(false, source);
  7840. }
  7841. };
  7842. ColumnController.prototype.getGridColumns = function (keys) {
  7843. return this.getColumns(keys, this.getGridColumn.bind(this));
  7844. };
  7845. ColumnController.prototype.getColumns = function (keys, columnLookupCallback) {
  7846. var foundColumns = [];
  7847. if (keys) {
  7848. keys.forEach(function (key) {
  7849. var column = columnLookupCallback(key);
  7850. if (column) {
  7851. foundColumns.push(column);
  7852. }
  7853. });
  7854. }
  7855. return foundColumns;
  7856. };
  7857. // used by growGroupPanel
  7858. ColumnController.prototype.getColumnWithValidation = function (key) {
  7859. if (key == null) {
  7860. return null;
  7861. }
  7862. var column = this.getGridColumn(key);
  7863. if (!column) {
  7864. console.warn('ag-Grid: could not find column ' + key);
  7865. }
  7866. return column;
  7867. };
  7868. ColumnController.prototype.getPrimaryColumn = function (key) {
  7869. return this.getColumn(key, this.primaryColumns);
  7870. };
  7871. ColumnController.prototype.getGridColumn = function (key) {
  7872. return this.getColumn(key, this.gridColumns);
  7873. };
  7874. ColumnController.prototype.getColumn = function (key, columnList) {
  7875. if (!key) {
  7876. return null;
  7877. }
  7878. for (var i = 0; i < columnList.length; i++) {
  7879. if (this.columnsMatch(columnList[i], key)) {
  7880. return columnList[i];
  7881. }
  7882. }
  7883. return this.getAutoColumn(key);
  7884. };
  7885. ColumnController.prototype.getAutoColumn = function (key) {
  7886. var _this = this;
  7887. if (!this.groupAutoColumns ||
  7888. !_utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(this.groupAutoColumns) ||
  7889. _utils__WEBPACK_IMPORTED_MODULE_9__["_"].missing(this.groupAutoColumns)) {
  7890. return null;
  7891. }
  7892. return _utils__WEBPACK_IMPORTED_MODULE_9__["_"].find(this.groupAutoColumns, function (groupCol) { return _this.columnsMatch(groupCol, key); });
  7893. };
  7894. ColumnController.prototype.columnsMatch = function (column, key) {
  7895. var columnMatches = column === key;
  7896. var colDefMatches = column.getColDef() === key;
  7897. var idMatches = column.getColId() == key;
  7898. return columnMatches || colDefMatches || idMatches;
  7899. };
  7900. ColumnController.prototype.getDisplayNameForColumn = function (column, location, includeAggFunc) {
  7901. if (includeAggFunc === void 0) { includeAggFunc = false; }
  7902. if (!column) {
  7903. return null;
  7904. }
  7905. var headerName = this.getHeaderName(column.getColDef(), column, null, null, location);
  7906. if (includeAggFunc) {
  7907. return this.wrapHeaderNameWithAggFunc(column, headerName);
  7908. }
  7909. return headerName;
  7910. };
  7911. ColumnController.prototype.getDisplayNameForOriginalColumnGroup = function (columnGroup, originalColumnGroup, location) {
  7912. var colGroupDef = originalColumnGroup ? originalColumnGroup.getColGroupDef() : null;
  7913. if (colGroupDef) {
  7914. return this.getHeaderName(colGroupDef, null, columnGroup, originalColumnGroup, location);
  7915. }
  7916. return null;
  7917. };
  7918. ColumnController.prototype.getDisplayNameForColumnGroup = function (columnGroup, location) {
  7919. return this.getDisplayNameForOriginalColumnGroup(columnGroup, columnGroup.getOriginalColumnGroup(), location);
  7920. };
  7921. // location is where the column is going to appear, ie who is calling us
  7922. ColumnController.prototype.getHeaderName = function (colDef, column, columnGroup, originalColumnGroup, location) {
  7923. var headerValueGetter = colDef.headerValueGetter;
  7924. if (headerValueGetter) {
  7925. var params = {
  7926. colDef: colDef,
  7927. column: column,
  7928. columnGroup: columnGroup,
  7929. originalColumnGroup: originalColumnGroup,
  7930. location: location,
  7931. api: this.gridOptionsWrapper.getApi(),
  7932. context: this.gridOptionsWrapper.getContext()
  7933. };
  7934. if (typeof headerValueGetter === 'function') {
  7935. // valueGetter is a function, so just call it
  7936. return headerValueGetter(params);
  7937. }
  7938. else if (typeof headerValueGetter === 'string') {
  7939. // valueGetter is an expression, so execute the expression
  7940. return this.expressionService.evaluate(headerValueGetter, params);
  7941. }
  7942. console.warn('ag-grid: headerValueGetter must be a function or a string');
  7943. return '';
  7944. }
  7945. else if (colDef.headerName != null) {
  7946. return colDef.headerName;
  7947. }
  7948. else if (colDef.field) {
  7949. return _utils__WEBPACK_IMPORTED_MODULE_9__["_"].camelCaseToHumanText(colDef.field);
  7950. }
  7951. return '';
  7952. };
  7953. /*
  7954. private getHeaderGroupName(columnGroup: ColumnGroup): string {
  7955. let colGroupDef = columnGroup.getOriginalColumnGroup().getColGroupDef();
  7956. let headerValueGetter = colGroupDef.headerValueGetter;
  7957. if (headerValueGetter) {
  7958. let params = {
  7959. columnGroup: columnGroup,
  7960. colDef: colGroupDef,
  7961. api: this.gridOptionsWrapper.getApi(),
  7962. context: this.gridOptionsWrapper.getContext()
  7963. };
  7964. if (typeof headerValueGetter === 'function') {
  7965. // valueGetter is a function, so just call it
  7966. return headerValueGetter(params);
  7967. } else if (typeof headerValueGetter === 'string') {
  7968. // valueGetter is an expression, so execute the expression
  7969. return this.expressionService.evaluate(headerValueGetter, params);
  7970. } else {
  7971. console.warn('ag-grid: headerValueGetter must be a function or a string');
  7972. return '';
  7973. }
  7974. } else {
  7975. return colGroupDef.headerName;
  7976. }
  7977. }
  7978. */
  7979. ColumnController.prototype.wrapHeaderNameWithAggFunc = function (column, headerName) {
  7980. if (this.gridOptionsWrapper.isSuppressAggFuncInHeader()) {
  7981. return headerName;
  7982. }
  7983. // only columns with aggregation active can have aggregations
  7984. var pivotValueColumn = column.getColDef().pivotValueColumn;
  7985. var pivotActiveOnThisColumn = _utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(pivotValueColumn);
  7986. var aggFunc = null;
  7987. var aggFuncFound;
  7988. // otherwise we have a measure that is active, and we are doing aggregation on it
  7989. if (pivotActiveOnThisColumn) {
  7990. aggFunc = pivotValueColumn ? pivotValueColumn.getAggFunc() : null;
  7991. aggFuncFound = true;
  7992. }
  7993. else {
  7994. var measureActive = column.isValueActive();
  7995. var aggregationPresent = this.pivotMode || !this.isRowGroupEmpty();
  7996. if (measureActive && aggregationPresent) {
  7997. aggFunc = column.getAggFunc();
  7998. aggFuncFound = true;
  7999. }
  8000. else {
  8001. aggFuncFound = false;
  8002. }
  8003. }
  8004. if (aggFuncFound) {
  8005. var aggFuncString = (typeof aggFunc === 'string') ? aggFunc : 'func';
  8006. var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();
  8007. var aggFuncStringTranslated = localeTextFunc(aggFuncString, aggFuncString);
  8008. return aggFuncStringTranslated + "(" + headerName + ")";
  8009. }
  8010. return headerName;
  8011. };
  8012. // returns the group with matching colId and instanceId. If instanceId is missing,
  8013. // matches only on the colId.
  8014. ColumnController.prototype.getColumnGroup = function (colId, instanceId) {
  8015. if (!colId) {
  8016. return null;
  8017. }
  8018. if (colId instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) {
  8019. return colId;
  8020. }
  8021. var allColumnGroups = this.getAllDisplayedColumnGroups();
  8022. var checkInstanceId = typeof instanceId === 'number';
  8023. var result = null;
  8024. this.columnUtils.depthFirstAllColumnTreeSearch(allColumnGroups, function (child) {
  8025. if (child instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) {
  8026. var columnGroup = child;
  8027. var matched = void 0;
  8028. if (checkInstanceId) {
  8029. matched = colId === columnGroup.getGroupId() && instanceId === columnGroup.getInstanceId();
  8030. }
  8031. else {
  8032. matched = colId === columnGroup.getGroupId();
  8033. }
  8034. if (matched) {
  8035. result = columnGroup;
  8036. }
  8037. }
  8038. });
  8039. return result;
  8040. };
  8041. ColumnController.prototype.isReady = function () {
  8042. return this.ready;
  8043. };
  8044. ColumnController.prototype.createValueColumns = function (source, oldPrimaryColumns) {
  8045. this.valueColumns = this.extractColumns(oldPrimaryColumns, this.valueColumns, function (col, flag) { return col.setValueActive(flag, source); },
  8046. // aggFunc doesn't have index variant, cos order of value cols doesn't matter, so always return null
  8047. function () { return null; },
  8048. // aggFunc is a string, so return it's existence
  8049. function (colDef) { return !!colDef.aggFunc; });
  8050. // all new columns added will have aggFunc missing, so set it to what is in the colDef
  8051. this.valueColumns.forEach(function (col) {
  8052. if (!col.getAggFunc()) {
  8053. col.setAggFunc(col.getColDef().aggFunc);
  8054. }
  8055. });
  8056. };
  8057. ColumnController.prototype.extractRowGroupColumns = function (source, oldPrimaryColumns) {
  8058. this.rowGroupColumns = this.extractColumns(oldPrimaryColumns, this.rowGroupColumns, function (col, flag) { return col.setRowGroupActive(flag, source); }, function (colDef) { return colDef.rowGroupIndex; }, function (colDef) { return colDef.rowGroup; });
  8059. };
  8060. ColumnController.prototype.extractColumns = function (oldPrimaryColumns, previousCols, setFlagFunc, getIndexFunc, getValueFunc) {
  8061. var _this = this;
  8062. if (!previousCols) {
  8063. previousCols = [];
  8064. }
  8065. // remove cols that no longer exist
  8066. var colPresentInPrimaryFunc = function (col) { return _this.primaryColumns.indexOf(col) >= 0; };
  8067. var colMissingFromPrimaryFunc = function (col) { return _this.primaryColumns.indexOf(col) < 0; };
  8068. var colNewFunc = function (col) { return !oldPrimaryColumns || oldPrimaryColumns.indexOf(col) < 0; };
  8069. var removedCols = previousCols.filter(colMissingFromPrimaryFunc);
  8070. var existingCols = previousCols.filter(colPresentInPrimaryFunc);
  8071. var newPrimaryCols = this.primaryColumns.filter(colNewFunc);
  8072. removedCols.forEach(function (col) { return setFlagFunc(col, false); });
  8073. var newCols = [];
  8074. // we only want to work on new columns, as old columns already got processed first time around
  8075. // pull out items with xxxIndex
  8076. newPrimaryCols.forEach(function (col) {
  8077. var index = getIndexFunc(col.getColDef());
  8078. if (typeof index === 'number') {
  8079. newCols.push(col);
  8080. }
  8081. });
  8082. // then sort them
  8083. newCols.sort(function (colA, colB) {
  8084. var indexA = getIndexFunc(colA.getColDef());
  8085. var indexB = getIndexFunc(colB.getColDef());
  8086. if (indexA === indexB) {
  8087. return 0;
  8088. }
  8089. else if (indexA < indexB) {
  8090. return -1;
  8091. }
  8092. return 1;
  8093. });
  8094. // now just pull out items xxx (boolean value), they will be added at the end
  8095. // after the indexed ones, but in the order the columns appear
  8096. newPrimaryCols.forEach(function (col) {
  8097. var booleanValue = getValueFunc(col.getColDef());
  8098. if (booleanValue) {
  8099. // if user already specified xxxIndex then we skip it as this col already included
  8100. if (newCols.indexOf(col) >= 0) {
  8101. return;
  8102. }
  8103. newCols.push(col);
  8104. }
  8105. });
  8106. newCols.forEach(function (col) { return setFlagFunc(col, true); });
  8107. var res = existingCols.concat(newCols);
  8108. return res;
  8109. };
  8110. ColumnController.prototype.extractPivotColumns = function (source, oldPrimaryColumns) {
  8111. this.pivotColumns = this.extractColumns(oldPrimaryColumns, this.pivotColumns, function (col, flag) { return col.setPivotActive(flag, source); }, function (colDef) { return colDef.pivotIndex; }, function (colDef) { return colDef.pivot; });
  8112. };
  8113. ColumnController.prototype.resetColumnGroupState = function (source) {
  8114. if (source === void 0) { source = "api"; }
  8115. var stateItems = [];
  8116. this.columnUtils.depthFirstOriginalTreeSearch(null, this.primaryColumnTree, function (child) {
  8117. if (child instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__["OriginalColumnGroup"]) {
  8118. var groupState = {
  8119. groupId: child.getGroupId(),
  8120. open: child.getColGroupDef().openByDefault
  8121. };
  8122. stateItems.push(groupState);
  8123. }
  8124. });
  8125. this.setColumnGroupState(stateItems, source);
  8126. };
  8127. ColumnController.prototype.getColumnGroupState = function () {
  8128. var columnGroupState = [];
  8129. this.columnUtils.depthFirstOriginalTreeSearch(null, this.gridBalancedTree, function (node) {
  8130. if (node instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__["OriginalColumnGroup"]) {
  8131. var originalColumnGroup = node;
  8132. columnGroupState.push({
  8133. groupId: originalColumnGroup.getGroupId(),
  8134. open: originalColumnGroup.isExpanded()
  8135. });
  8136. }
  8137. });
  8138. return columnGroupState;
  8139. };
  8140. ColumnController.prototype.setColumnGroupState = function (stateItems, source) {
  8141. var _this = this;
  8142. if (source === void 0) { source = "api"; }
  8143. this.columnAnimationService.start();
  8144. var impactedGroups = [];
  8145. stateItems.forEach(function (stateItem) {
  8146. var groupKey = stateItem.groupId;
  8147. var newValue = stateItem.open;
  8148. var originalColumnGroup = _this.getOriginalColumnGroup(groupKey);
  8149. if (!originalColumnGroup) {
  8150. return;
  8151. }
  8152. if (originalColumnGroup.isExpanded() === newValue) {
  8153. return;
  8154. }
  8155. _this.logger.log('columnGroupOpened(' + originalColumnGroup.getGroupId() + ',' + newValue + ')');
  8156. originalColumnGroup.setExpanded(newValue);
  8157. impactedGroups.push(originalColumnGroup);
  8158. });
  8159. this.updateGroupsAndDisplayedColumns(source);
  8160. this.setFirstRightAndLastLeftPinned(source);
  8161. impactedGroups.forEach(function (originalColumnGroup) {
  8162. var event = {
  8163. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_GROUP_OPENED,
  8164. columnGroup: originalColumnGroup,
  8165. api: _this.gridApi,
  8166. columnApi: _this.columnApi
  8167. };
  8168. _this.eventService.dispatchEvent(event);
  8169. });
  8170. this.columnAnimationService.finish();
  8171. };
  8172. // called by headerRenderer - when a header is opened or closed
  8173. ColumnController.prototype.setColumnGroupOpened = function (key, newValue, source) {
  8174. if (source === void 0) { source = "api"; }
  8175. var keyAsString;
  8176. if (key instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__["OriginalColumnGroup"]) {
  8177. keyAsString = key.getId();
  8178. }
  8179. else {
  8180. keyAsString = key;
  8181. }
  8182. this.setColumnGroupState([{ groupId: keyAsString, open: newValue }], source);
  8183. };
  8184. ColumnController.prototype.getOriginalColumnGroup = function (key) {
  8185. if (key instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__["OriginalColumnGroup"]) {
  8186. return key;
  8187. }
  8188. if (typeof key !== 'string') {
  8189. console.error('ag-Grid: group key must be a string');
  8190. }
  8191. // otherwise, search for the column group by id
  8192. var res = null;
  8193. this.columnUtils.depthFirstOriginalTreeSearch(null, this.gridBalancedTree, function (node) {
  8194. if (node instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__["OriginalColumnGroup"]) {
  8195. var originalColumnGroup = node;
  8196. if (originalColumnGroup.getId() === key) {
  8197. res = originalColumnGroup;
  8198. }
  8199. }
  8200. });
  8201. return res;
  8202. };
  8203. ColumnController.prototype.calculateColumnsForDisplay = function () {
  8204. var _this = this;
  8205. var columnsForDisplay;
  8206. if (this.pivotMode && !this.secondaryColumnsPresent) {
  8207. // pivot mode is on, but we are not pivoting, so we only
  8208. // show columns we are aggregating on
  8209. columnsForDisplay = this.gridColumns.filter(function (column) {
  8210. var isAutoGroupCol = _this.groupAutoColumns && _utils__WEBPACK_IMPORTED_MODULE_9__["_"].includes(_this.groupAutoColumns, column);
  8211. var isValueCol = _this.valueColumns && _utils__WEBPACK_IMPORTED_MODULE_9__["_"].includes(_this.valueColumns, column);
  8212. return isAutoGroupCol || isValueCol;
  8213. });
  8214. }
  8215. else {
  8216. // otherwise continue as normal. this can be working on the primary
  8217. // or secondary columns, whatever the gridColumns are set to
  8218. columnsForDisplay = this.gridColumns.filter(function (column) {
  8219. // keep col if a) it's auto-group or b) it's visible
  8220. var isAutoGroupCol = _this.groupAutoColumns && _utils__WEBPACK_IMPORTED_MODULE_9__["_"].includes(_this.groupAutoColumns, column);
  8221. return isAutoGroupCol || column.isVisible();
  8222. });
  8223. }
  8224. return columnsForDisplay;
  8225. };
  8226. ColumnController.prototype.checkColSpanActiveInCols = function (columns) {
  8227. var result = false;
  8228. columns.forEach(function (col) {
  8229. if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(col.getColDef().colSpan)) {
  8230. result = true;
  8231. }
  8232. });
  8233. return result;
  8234. };
  8235. ColumnController.prototype.calculateColumnsForGroupDisplay = function () {
  8236. var _this = this;
  8237. this.groupDisplayColumns = [];
  8238. var checkFunc = function (col) {
  8239. var colDef = col.getColDef();
  8240. if (colDef && _utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(colDef.showRowGroup)) {
  8241. _this.groupDisplayColumns.push(col);
  8242. }
  8243. };
  8244. this.gridColumns.forEach(checkFunc);
  8245. if (this.groupAutoColumns) {
  8246. this.groupAutoColumns.forEach(checkFunc);
  8247. }
  8248. };
  8249. ColumnController.prototype.getGroupDisplayColumns = function () {
  8250. return this.groupDisplayColumns;
  8251. };
  8252. ColumnController.prototype.updateDisplayedColumns = function (source) {
  8253. var columnsForDisplay = this.calculateColumnsForDisplay();
  8254. this.buildDisplayedTrees(columnsForDisplay);
  8255. this.calculateColumnsForGroupDisplay();
  8256. // also called when group opened/closed
  8257. this.updateGroupsAndDisplayedColumns(source);
  8258. // also called when group opened/closed
  8259. this.setFirstRightAndLastLeftPinned(source);
  8260. };
  8261. ColumnController.prototype.isSecondaryColumnsPresent = function () {
  8262. return this.secondaryColumnsPresent;
  8263. };
  8264. ColumnController.prototype.setSecondaryColumns = function (colDefs, source) {
  8265. if (source === void 0) { source = "api"; }
  8266. var newColsPresent = colDefs && colDefs.length > 0;
  8267. // if not cols passed, and we had to cols anyway, then do nothing
  8268. if (!newColsPresent && !this.secondaryColumnsPresent) {
  8269. return;
  8270. }
  8271. if (newColsPresent) {
  8272. this.processSecondaryColumnDefinitions(colDefs);
  8273. var balancedTreeResult = this.columnFactory.createColumnTree(colDefs, false);
  8274. this.secondaryBalancedTree = balancedTreeResult.columnTree;
  8275. this.secondaryHeaderRowCount = balancedTreeResult.treeDept + 1;
  8276. this.secondaryColumns = this.getColumnsFromTree(this.secondaryBalancedTree);
  8277. this.secondaryColumnsPresent = true;
  8278. }
  8279. else {
  8280. this.secondaryBalancedTree = null;
  8281. this.secondaryHeaderRowCount = -1;
  8282. this.secondaryColumns = null;
  8283. this.secondaryColumnsPresent = false;
  8284. }
  8285. this.updateGridColumns();
  8286. this.updateDisplayedColumns(source);
  8287. };
  8288. ColumnController.prototype.processSecondaryColumnDefinitions = function (colDefs) {
  8289. var columnCallback = this.gridOptionsWrapper.getProcessSecondaryColDefFunc();
  8290. var groupCallback = this.gridOptionsWrapper.getProcessSecondaryColGroupDefFunc();
  8291. if (!columnCallback && !groupCallback) {
  8292. return undefined;
  8293. }
  8294. var searchForColDefs = function (colDefs2) {
  8295. colDefs2.forEach(function (abstractColDef) {
  8296. var isGroup = _utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(abstractColDef.children);
  8297. if (isGroup) {
  8298. var colGroupDef = abstractColDef;
  8299. if (groupCallback) {
  8300. groupCallback(colGroupDef);
  8301. }
  8302. searchForColDefs(colGroupDef.children);
  8303. }
  8304. else {
  8305. var colDef = abstractColDef;
  8306. if (columnCallback) {
  8307. columnCallback(colDef);
  8308. }
  8309. }
  8310. });
  8311. };
  8312. if (colDefs) {
  8313. searchForColDefs(colDefs);
  8314. }
  8315. };
  8316. // called from: setColumnState, setColumnDefs, setSecondaryColumns
  8317. ColumnController.prototype.updateGridColumns = function () {
  8318. if (this.gridColsArePrimary) {
  8319. this.lastPrimaryOrder = this.gridColumns;
  8320. }
  8321. if (this.secondaryColumns && this.secondaryBalancedTree) {
  8322. this.gridBalancedTree = this.secondaryBalancedTree.slice();
  8323. this.gridHeaderRowCount = this.secondaryHeaderRowCount;
  8324. this.gridColumns = this.secondaryColumns.slice();
  8325. this.gridColsArePrimary = false;
  8326. }
  8327. else {
  8328. this.gridBalancedTree = this.primaryColumnTree.slice();
  8329. this.gridHeaderRowCount = this.primaryHeaderRowCount;
  8330. this.gridColumns = this.primaryColumns.slice();
  8331. this.gridColsArePrimary = true;
  8332. // updateGridColumns gets called after user adds a row group. we want to maintain the order of the columns
  8333. // when this happens (eg if user moved a column) rather than revert back to the original column order.
  8334. // likewise if changing in/out of pivot mode, we want to maintain the order of the primary cols
  8335. this.orderGridColsLikeLastPrimary();
  8336. }
  8337. this.addAutoGroupToGridColumns();
  8338. this.autoRowHeightColumns = this.gridColumns.filter(function (col) { return col.getColDef().autoHeight; });
  8339. this.putFixedColumnsFirst();
  8340. this.setupQuickFilterColumns();
  8341. this.clearDisplayedColumns();
  8342. this.colSpanActive = this.checkColSpanActiveInCols(this.gridColumns);
  8343. var event = {
  8344. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_GRID_COLUMNS_CHANGED,
  8345. api: this.gridApi,
  8346. columnApi: this.columnApi
  8347. };
  8348. this.eventService.dispatchEvent(event);
  8349. };
  8350. ColumnController.prototype.orderGridColsLikeLastPrimary = function () {
  8351. var _this = this;
  8352. if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].missing(this.lastPrimaryOrder)) {
  8353. return;
  8354. }
  8355. // only do the sort if at least one column is accounted for. columns will be not accounted for
  8356. // if changing from secondary to primary columns
  8357. var noColsFound = true;
  8358. this.gridColumns.forEach(function (col) {
  8359. if (_this.lastPrimaryOrder.indexOf(col) >= 0) {
  8360. noColsFound = false;
  8361. }
  8362. });
  8363. if (noColsFound) {
  8364. return;
  8365. }
  8366. // order cols in the same order as before. we need to make sure that all
  8367. // cols still exists, so filter out any that no longer exist.
  8368. var oldColsOrdered = this.lastPrimaryOrder.filter(function (col) { return _this.gridColumns.indexOf(col) >= 0; });
  8369. var newColsOrdered = this.gridColumns.filter(function (col) { return oldColsOrdered.indexOf(col) < 0; });
  8370. // add in the new columns, at the end (if no group), or at the end of the group (if a group)
  8371. var newGridColumns = oldColsOrdered.slice();
  8372. newColsOrdered.forEach(function (newCol) {
  8373. var parent = newCol.getOriginalParent();
  8374. // if no parent, means we are not grouping, so just add the column to the end
  8375. if (!parent) {
  8376. newGridColumns.push(newCol);
  8377. return;
  8378. }
  8379. // find the group the column belongs to. if no siblings at the current level (eg col in group on it's
  8380. // own) then go up one level and look for siblings there.
  8381. var siblings = [];
  8382. while (!siblings.length && parent) {
  8383. var leafCols = parent.getLeafColumns();
  8384. leafCols.forEach(function (leafCol) {
  8385. var presentInNewGriColumns = newGridColumns.indexOf(leafCol) >= 0;
  8386. var noYetInSiblings = siblings.indexOf(leafCol) < 0;
  8387. if (presentInNewGriColumns && noYetInSiblings) {
  8388. siblings.push(leafCol);
  8389. }
  8390. });
  8391. parent = parent.getOriginalParent();
  8392. }
  8393. // if no siblings exist at any level, this means the col is in a group (or parent groups) on it's own
  8394. if (!siblings.length) {
  8395. newGridColumns.push(newCol);
  8396. return;
  8397. }
  8398. // find index of last column in the group
  8399. var indexes = siblings.map(function (col) { return newGridColumns.indexOf(col); });
  8400. var lastIndex = Math.max.apply(Math, indexes);
  8401. _utils__WEBPACK_IMPORTED_MODULE_9__["_"].insertIntoArray(newGridColumns, newCol, lastIndex + 1);
  8402. });
  8403. this.gridColumns = newGridColumns;
  8404. };
  8405. ColumnController.prototype.isPrimaryColumnGroupsPresent = function () {
  8406. return this.primaryHeaderRowCount > 1;
  8407. };
  8408. // if we are using autoGroupCols, then they should be included for quick filter. this covers the
  8409. // following scenarios:
  8410. // a) user provides 'field' into autoGroupCol of normal grid, so now because a valid col to filter leafs on
  8411. // b) using tree data and user depends on autoGroupCol for first col, and we also want to filter on this
  8412. // (tree data is a bit different, as parent rows can be filtered on, unlike row grouping)
  8413. ColumnController.prototype.setupQuickFilterColumns = function () {
  8414. if (this.groupAutoColumns) {
  8415. this.columnsForQuickFilter = this.primaryColumns.concat(this.groupAutoColumns);
  8416. }
  8417. else {
  8418. this.columnsForQuickFilter = this.primaryColumns;
  8419. }
  8420. };
  8421. ColumnController.prototype.putFixedColumnsFirst = function () {
  8422. var locked = this.gridColumns.filter(function (c) { return c.getColDef().lockPosition; });
  8423. var unlocked = this.gridColumns.filter(function (c) { return !c.getColDef().lockPosition; });
  8424. this.gridColumns = locked.concat(unlocked);
  8425. };
  8426. ColumnController.prototype.addAutoGroupToGridColumns = function () {
  8427. // add in auto-group here
  8428. this.createGroupAutoColumnsIfNeeded();
  8429. if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].missing(this.groupAutoColumns)) {
  8430. return;
  8431. }
  8432. this.gridColumns = this.groupAutoColumns ? this.groupAutoColumns.concat(this.gridColumns) : this.gridColumns;
  8433. var autoColBalancedTree = this.columnFactory.createForAutoGroups(this.groupAutoColumns, this.gridBalancedTree);
  8434. this.gridBalancedTree = autoColBalancedTree.concat(this.gridBalancedTree);
  8435. };
  8436. // gets called after we copy down grid columns, to make sure any part of the gui
  8437. // that tries to draw, eg the header, it will get empty lists of columns rather
  8438. // than stale columns. for example, the header will received gridColumnsChanged
  8439. // event, so will try and draw, but it will draw successfully when it acts on the
  8440. // virtualColumnsChanged event
  8441. ColumnController.prototype.clearDisplayedColumns = function () {
  8442. this.displayedLeftColumnTree = [];
  8443. this.displayedRightColumnTree = [];
  8444. this.displayedCentreColumnTree = [];
  8445. this.displayedLeftHeaderRows = {};
  8446. this.displayedRightHeaderRows = {};
  8447. this.displayedCentreHeaderRows = {};
  8448. this.displayedLeftColumns = [];
  8449. this.displayedRightColumns = [];
  8450. this.displayedCenterColumns = [];
  8451. this.allDisplayedColumns = [];
  8452. this.allDisplayedVirtualColumns = [];
  8453. };
  8454. ColumnController.prototype.updateGroupsAndDisplayedColumns = function (source) {
  8455. this.updateOpenClosedVisibilityInColumnGroups();
  8456. this.updateDisplayedColumnsFromTrees(source);
  8457. this.updateVirtualSets();
  8458. this.refreshFlexedColumns(undefined, undefined, true);
  8459. this.updateBodyWidths();
  8460. // this event is picked up by the gui, headerRenderer and rowRenderer, to recalculate what columns to display
  8461. var event = {
  8462. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED,
  8463. api: this.gridApi,
  8464. columnApi: this.columnApi
  8465. };
  8466. this.eventService.dispatchEvent(event);
  8467. };
  8468. ColumnController.prototype.updateDisplayedColumnsFromTrees = function (source) {
  8469. this.addToDisplayedColumns(this.displayedLeftColumnTree, this.displayedLeftColumns);
  8470. this.addToDisplayedColumns(this.displayedCentreColumnTree, this.displayedCenterColumns);
  8471. this.addToDisplayedColumns(this.displayedRightColumnTree, this.displayedRightColumns);
  8472. this.setupAllDisplayedColumns();
  8473. this.setLeftValues(source);
  8474. };
  8475. ColumnController.prototype.setupAllDisplayedColumns = function () {
  8476. if (this.gridOptionsWrapper.isEnableRtl()) {
  8477. this.allDisplayedColumns = this.displayedRightColumns
  8478. .concat(this.displayedCenterColumns)
  8479. .concat(this.displayedLeftColumns);
  8480. }
  8481. else {
  8482. this.allDisplayedColumns = this.displayedLeftColumns
  8483. .concat(this.displayedCenterColumns)
  8484. .concat(this.displayedRightColumns);
  8485. }
  8486. };
  8487. // sets the left pixel position of each column
  8488. ColumnController.prototype.setLeftValues = function (source) {
  8489. this.setLeftValuesOfColumns(source);
  8490. this.setLeftValuesOfGroups();
  8491. };
  8492. ColumnController.prototype.setLeftValuesOfColumns = function (source) {
  8493. var _this = this;
  8494. // go through each list of displayed columns
  8495. var allColumns = this.primaryColumns.slice(0);
  8496. // let totalColumnWidth = this.getWidthOfColsInList()
  8497. var doingRtl = this.gridOptionsWrapper.isEnableRtl();
  8498. [
  8499. this.displayedLeftColumns,
  8500. this.displayedRightColumns,
  8501. this.displayedCenterColumns
  8502. ].forEach(function (columns) {
  8503. if (doingRtl) {
  8504. // when doing RTL, we start at the top most pixel (ie RHS) and work backwards
  8505. var left_1 = _this.getWidthOfColsInList(columns);
  8506. columns.forEach(function (column) {
  8507. left_1 -= column.getActualWidth();
  8508. column.setLeft(left_1, source);
  8509. });
  8510. }
  8511. else {
  8512. // otherwise normal LTR, we start at zero
  8513. var left_2 = 0;
  8514. columns.forEach(function (column) {
  8515. column.setLeft(left_2, source);
  8516. left_2 += column.getActualWidth();
  8517. });
  8518. }
  8519. _utils__WEBPACK_IMPORTED_MODULE_9__["_"].removeAllFromArray(allColumns, columns);
  8520. });
  8521. // items left in allColumns are columns not displayed, so remove the left position. this is
  8522. // important for the rows, as if a col is made visible, then taken out, then made visible again,
  8523. // we don't want the animation of the cell floating in from the old position, whatever that was.
  8524. allColumns.forEach(function (column) {
  8525. column.setLeft(null, source);
  8526. });
  8527. };
  8528. ColumnController.prototype.setLeftValuesOfGroups = function () {
  8529. // a groups left value is the lest left value of it's children
  8530. [
  8531. this.displayedLeftColumnTree,
  8532. this.displayedRightColumnTree,
  8533. this.displayedCentreColumnTree
  8534. ].forEach(function (columns) {
  8535. columns.forEach(function (column) {
  8536. if (column instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) {
  8537. var columnGroup = column;
  8538. columnGroup.checkLeft();
  8539. }
  8540. });
  8541. });
  8542. };
  8543. ColumnController.prototype.addToDisplayedColumns = function (displayedColumnTree, displayedColumns) {
  8544. displayedColumns.length = 0;
  8545. this.columnUtils.depthFirstDisplayedColumnTreeSearch(displayedColumnTree, function (child) {
  8546. if (child instanceof _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"]) {
  8547. displayedColumns.push(child);
  8548. }
  8549. });
  8550. };
  8551. ColumnController.prototype.updateDisplayedCenterVirtualColumns = function () {
  8552. if (this.suppressColumnVirtualisation) {
  8553. // no virtualisation, so don't filter
  8554. this.allDisplayedCenterVirtualColumns = this.displayedCenterColumns;
  8555. }
  8556. else {
  8557. // filter out what should be visible
  8558. this.allDisplayedCenterVirtualColumns = this.filterOutColumnsWithinViewport();
  8559. }
  8560. this.allDisplayedVirtualColumns = this.allDisplayedCenterVirtualColumns
  8561. .concat(this.displayedLeftColumns)
  8562. .concat(this.displayedRightColumns);
  8563. // return map of virtual col id's, for easy lookup when building the groups.
  8564. // the map will be colId=>true, ie col id's mapping to 'true'.
  8565. var result = {};
  8566. this.allDisplayedVirtualColumns.forEach(function (col) {
  8567. result[col.getId()] = true;
  8568. });
  8569. return result;
  8570. };
  8571. ColumnController.prototype.getVirtualHeaderGroupRow = function (type, dept) {
  8572. var result;
  8573. switch (type) {
  8574. case _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT:
  8575. result = this.displayedLeftHeaderRows[dept];
  8576. break;
  8577. case _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT:
  8578. result = this.displayedRightHeaderRows[dept];
  8579. break;
  8580. default:
  8581. result = this.displayedCentreHeaderRows[dept];
  8582. break;
  8583. }
  8584. if (_utils__WEBPACK_IMPORTED_MODULE_9__["_"].missing(result)) {
  8585. result = [];
  8586. }
  8587. return result;
  8588. };
  8589. ColumnController.prototype.updateDisplayedVirtualGroups = function (virtualColIds) {
  8590. // go through each group, see if any of it's cols are displayed, and if yes,
  8591. // then this group is included
  8592. this.displayedLeftHeaderRows = {};
  8593. this.displayedRightHeaderRows = {};
  8594. this.displayedCentreHeaderRows = {};
  8595. var testGroup = function (children, result, dept) {
  8596. var returnValue = false;
  8597. for (var i = 0; i < children.length; i++) {
  8598. // see if this item is within viewport
  8599. var child = children[i];
  8600. var addThisItem = void 0;
  8601. if (child instanceof _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"]) {
  8602. // for column, test if column is included
  8603. addThisItem = virtualColIds[child.getId()] === true;
  8604. }
  8605. else {
  8606. // if group, base decision on children
  8607. var columnGroup = child;
  8608. addThisItem = testGroup(columnGroup.getDisplayedChildren(), result, dept + 1);
  8609. }
  8610. if (addThisItem) {
  8611. returnValue = true;
  8612. if (!result[dept]) {
  8613. result[dept] = [];
  8614. }
  8615. result[dept].push(child);
  8616. }
  8617. }
  8618. return returnValue;
  8619. };
  8620. testGroup(this.displayedLeftColumnTree, this.displayedLeftHeaderRows, 0);
  8621. testGroup(this.displayedRightColumnTree, this.displayedRightHeaderRows, 0);
  8622. testGroup(this.displayedCentreColumnTree, this.displayedCentreHeaderRows, 0);
  8623. };
  8624. ColumnController.prototype.updateVirtualSets = function () {
  8625. var virtualColIds = this.updateDisplayedCenterVirtualColumns();
  8626. this.updateDisplayedVirtualGroups(virtualColIds);
  8627. };
  8628. ColumnController.prototype.filterOutColumnsWithinViewport = function () {
  8629. return this.displayedCenterColumns.filter(this.isColumnInViewport.bind(this));
  8630. };
  8631. ColumnController.prototype.refreshFlexedColumns = function (updatedFlexViewportWidth, source, silent) {
  8632. if (source === void 0) { source = 'flex'; }
  8633. if (!this.flexActive) {
  8634. return;
  8635. }
  8636. this.flexViewportWidth = updatedFlexViewportWidth || this.flexViewportWidth;
  8637. if (!this.flexViewportWidth) {
  8638. return;
  8639. }
  8640. // If the grid has left-over space, divide it between flexing columns in proportion to their flex value.
  8641. // A "flexing column" is one that has a 'flex' value set and is not currently being constrained by its
  8642. // minWidth or maxWidth rules.
  8643. var knownWidthColumns = this.displayedCenterColumns.filter(function (col) { return !col.getFlex(); });
  8644. var flexingColumns = this.displayedCenterColumns.filter(function (col) { return col.getFlex(); });
  8645. if (!flexingColumns.length) {
  8646. this.flexActive = false;
  8647. return;
  8648. }
  8649. var flexingColumnSizes = [];
  8650. var spaceForFlexingColumns;
  8651. outer: while (true) {
  8652. var totalFlex = flexingColumns.reduce(function (count, col) { return count + col.getFlex(); }, 0);
  8653. spaceForFlexingColumns = this.flexViewportWidth - this.getWidthOfColsInList(knownWidthColumns);
  8654. for (var i = 0; i < flexingColumns.length; i++) {
  8655. var col = flexingColumns[i];
  8656. var widthByFlexRule = spaceForFlexingColumns * col.getFlex() / totalFlex;
  8657. var constrainedWidth = void 0;
  8658. if (widthByFlexRule < col.getMinWidth()) {
  8659. constrainedWidth = col.getMinWidth();
  8660. }
  8661. else if (col.getMaxWidth() != null && widthByFlexRule > col.getMaxWidth()) {
  8662. constrainedWidth = col.getMaxWidth();
  8663. }
  8664. if (constrainedWidth) {
  8665. // This column is not in fact flexing as it is being constrained to a specific size
  8666. // so remove it from the list of flexing columns and start again
  8667. col.setActualWidth(constrainedWidth, source);
  8668. _utils__WEBPACK_IMPORTED_MODULE_9__["_"].removeFromArray(flexingColumns, col);
  8669. knownWidthColumns.push(col);
  8670. continue outer;
  8671. }
  8672. flexingColumnSizes[i] = Math.round(widthByFlexRule);
  8673. }
  8674. break;
  8675. }
  8676. var remainingSpace = spaceForFlexingColumns;
  8677. flexingColumns.forEach(function (col, i) {
  8678. col.setActualWidth(Math.min(flexingColumnSizes[i], remainingSpace), source);
  8679. remainingSpace -= flexingColumnSizes[i];
  8680. });
  8681. this.setLeftValues(source);
  8682. if (!silent) {
  8683. this.updateBodyWidths();
  8684. this.fireResizedEventForColumns(flexingColumns, source);
  8685. }
  8686. };
  8687. // called from api
  8688. ColumnController.prototype.sizeColumnsToFit = function (gridWidth, source, silent) {
  8689. if (source === void 0) { source = "sizeColumnsToFit"; }
  8690. // avoid divide by zero
  8691. var allDisplayedColumns = this.getAllDisplayedColumns();
  8692. if (gridWidth <= 0 || !allDisplayedColumns.length) {
  8693. return;
  8694. }
  8695. var colsToSpread = [];
  8696. var colsToNotSpread = [];
  8697. allDisplayedColumns.forEach(function (column) {
  8698. if (column.getColDef().suppressSizeToFit === true) {
  8699. colsToNotSpread.push(column);
  8700. }
  8701. else {
  8702. colsToSpread.push(column);
  8703. }
  8704. });
  8705. // make a copy of the cols that are going to be resized
  8706. var colsToFireEventFor = colsToSpread.slice(0);
  8707. var finishedResizing = false;
  8708. var moveToNotSpread = function (column) {
  8709. _utils__WEBPACK_IMPORTED_MODULE_9__["_"].removeFromArray(colsToSpread, column);
  8710. colsToNotSpread.push(column);
  8711. };
  8712. // resetting cols to their original width makes the sizeColumnsToFit more deterministic,
  8713. // rather than depending on the current size of the columns. most users call sizeColumnsToFit
  8714. // immediately after grid is created, so will make no difference. however if application is calling
  8715. // sizeColumnsToFit repeatedly (eg after column group is opened / closed repeatedly) we don't want
  8716. // the columns to start shrinking / growing over time.
  8717. colsToSpread.forEach(function (column) { return column.resetActualWidth(); });
  8718. while (!finishedResizing) {
  8719. finishedResizing = true;
  8720. var availablePixels = gridWidth - this.getWidthOfColsInList(colsToNotSpread);
  8721. if (availablePixels <= 0) {
  8722. // no width, set everything to minimum
  8723. colsToSpread.forEach(function (column) {
  8724. column.setMinimum(source);
  8725. });
  8726. }
  8727. else {
  8728. var scale = availablePixels / this.getWidthOfColsInList(colsToSpread);
  8729. // we set the pixels for the last col based on what's left, as otherwise
  8730. // we could be a pixel or two short or extra because of rounding errors.
  8731. var pixelsForLastCol = availablePixels;
  8732. // backwards through loop, as we are removing items as we go
  8733. for (var i = colsToSpread.length - 1; i >= 0; i--) {
  8734. var column = colsToSpread[i];
  8735. var newWidth = Math.round(column.getActualWidth() * scale);
  8736. if (newWidth < column.getMinWidth()) {
  8737. column.setMinimum(source);
  8738. moveToNotSpread(column);
  8739. finishedResizing = false;
  8740. }
  8741. else if (column.isGreaterThanMax(newWidth)) {
  8742. column.setActualWidth(column.getMaxWidth(), source);
  8743. moveToNotSpread(column);
  8744. finishedResizing = false;
  8745. }
  8746. else {
  8747. var onLastCol = i === 0;
  8748. if (onLastCol) {
  8749. column.setActualWidth(pixelsForLastCol, source);
  8750. }
  8751. else {
  8752. column.setActualWidth(newWidth, source);
  8753. }
  8754. }
  8755. pixelsForLastCol -= newWidth;
  8756. }
  8757. }
  8758. }
  8759. this.setLeftValues(source);
  8760. this.updateBodyWidths();
  8761. if (silent) {
  8762. return;
  8763. }
  8764. this.fireResizedEventForColumns(colsToFireEventFor, source);
  8765. };
  8766. ColumnController.prototype.fireResizedEventForColumns = function (columns, source) {
  8767. var _this = this;
  8768. columns.forEach(function (column) {
  8769. var event = {
  8770. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_RESIZED,
  8771. column: column,
  8772. columns: [column],
  8773. finished: true,
  8774. api: _this.gridApi,
  8775. columnApi: _this.columnApi,
  8776. source: source
  8777. };
  8778. _this.eventService.dispatchEvent(event);
  8779. });
  8780. };
  8781. ColumnController.prototype.buildDisplayedTrees = function (visibleColumns) {
  8782. var leftVisibleColumns = [];
  8783. var rightVisibleColumns = [];
  8784. var centerVisibleColumns = [];
  8785. visibleColumns.forEach(function (column) {
  8786. switch (column.getPinned()) {
  8787. case "left":
  8788. leftVisibleColumns.push(column);
  8789. break;
  8790. case "right":
  8791. rightVisibleColumns.push(column);
  8792. break;
  8793. default:
  8794. centerVisibleColumns.push(column);
  8795. break;
  8796. }
  8797. });
  8798. var groupInstanceIdCreator = new _groupInstanceIdCreator__WEBPACK_IMPORTED_MODULE_5__["GroupInstanceIdCreator"]();
  8799. this.displayedLeftColumnTree = this.displayedGroupCreator.createDisplayedGroups(leftVisibleColumns, this.gridBalancedTree, groupInstanceIdCreator, _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_LEFT, this.displayedLeftColumnTree);
  8800. this.displayedRightColumnTree = this.displayedGroupCreator.createDisplayedGroups(rightVisibleColumns, this.gridBalancedTree, groupInstanceIdCreator, _constants__WEBPACK_IMPORTED_MODULE_7__["Constants"].PINNED_RIGHT, this.displayedRightColumnTree);
  8801. this.displayedCentreColumnTree = this.displayedGroupCreator.createDisplayedGroups(centerVisibleColumns, this.gridBalancedTree, groupInstanceIdCreator, null, this.displayedCentreColumnTree);
  8802. };
  8803. ColumnController.prototype.updateOpenClosedVisibilityInColumnGroups = function () {
  8804. var allColumnGroups = this.getAllDisplayedColumnGroups();
  8805. this.columnUtils.depthFirstAllColumnTreeSearch(allColumnGroups, function (child) {
  8806. if (child instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) {
  8807. var columnGroup = child;
  8808. columnGroup.calculateDisplayedColumns();
  8809. }
  8810. });
  8811. };
  8812. ColumnController.prototype.getGroupAutoColumns = function () {
  8813. return this.groupAutoColumns;
  8814. };
  8815. ColumnController.prototype.createGroupAutoColumnsIfNeeded = function () {
  8816. if (!this.autoGroupsNeedBuilding) {
  8817. return;
  8818. }
  8819. this.autoGroupsNeedBuilding = false;
  8820. var groupFullWidthRow = this.gridOptionsWrapper.isGroupUseEntireRow(this.pivotMode);
  8821. // we need to allow suppressing auto-column separately for group and pivot as the normal situation
  8822. // is CSRM and user provides group column themselves for normal view, but when they go into pivot the
  8823. // columns are generated by the grid so no opportunity for user to provide group column. so need a way
  8824. // to suppress auto-col for grouping only, and not pivot.
  8825. // however if using Viewport RM or SSRM and user is providing the columns, the user may wish full control
  8826. // of the group column in this instance.
  8827. var suppressAutoColumn = this.pivotMode ?
  8828. this.gridOptionsWrapper.isPivotSuppressAutoColumn() : this.gridOptionsWrapper.isGroupSuppressAutoColumn();
  8829. // const groupSuppressAutoColumn = this.gridOptionsWrapper.isGroupSuppressAutoColumn() && !this.pivotMode;
  8830. var groupSuppressRow = this.gridOptionsWrapper.isGroupSuppressRow();
  8831. var groupingActive = this.rowGroupColumns.length > 0 || this.usingTreeData;
  8832. var needAutoColumns = groupingActive && !suppressAutoColumn && !groupFullWidthRow && !groupSuppressRow;
  8833. if (needAutoColumns) {
  8834. var newAutoGroupCols = this.autoGroupColService.createAutoGroupColumns(this.rowGroupColumns);
  8835. var autoColsDifferent = !this.autoColsEqual(newAutoGroupCols, this.groupAutoColumns);
  8836. // we force recreate when suppressSetColumnStateEvents changes, so new group cols pick up the new
  8837. // definitions. otherwise we could ignore the new cols becasue they appear to be the same.
  8838. if (autoColsDifferent || this.forceRecreateAutoGroups) {
  8839. this.groupAutoColumns = newAutoGroupCols;
  8840. }
  8841. }
  8842. else {
  8843. this.groupAutoColumns = null;
  8844. }
  8845. };
  8846. ColumnController.prototype.autoColsEqual = function (colsA, colsB) {
  8847. return Object(_utils_array__WEBPACK_IMPORTED_MODULE_8__["areEqual"])(colsA, colsB, function (a, b) { return a.getColId() === b.getColId(); });
  8848. };
  8849. ColumnController.prototype.getWidthOfColsInList = function (columnList) {
  8850. return columnList.reduce(function (width, col) { return width + col.getActualWidth(); }, 0);
  8851. };
  8852. ColumnController.prototype.getGridBalancedTree = function () {
  8853. return this.gridBalancedTree;
  8854. };
  8855. ColumnController.prototype.hasFloatingFilters = function () {
  8856. var defaultColDef = this.gridOptionsWrapper.getDefaultColDef();
  8857. return (defaultColDef != null && defaultColDef.floatingFilter === true) ||
  8858. (this.columnDefs != null && this.columnDefs.some(function (c) { return c.floatingFilter === true; }));
  8859. };
  8860. ColumnController.prototype.getFirstDisplayedColumn = function () {
  8861. var isRtl = this.gridOptionsWrapper.isEnableRtl();
  8862. var queryOrder = [
  8863. 'getDisplayedLeftColumns',
  8864. 'getDisplayedCenterColumns',
  8865. 'getDisplayedRightColumns'
  8866. ];
  8867. if (isRtl) {
  8868. queryOrder.reverse();
  8869. }
  8870. for (var i = 0; i < queryOrder.length; i++) {
  8871. var container = this[queryOrder[i]]();
  8872. if (container.length) {
  8873. return isRtl ? _utils__WEBPACK_IMPORTED_MODULE_9__["_"].last(container) : container[0];
  8874. }
  8875. }
  8876. return null;
  8877. };
  8878. __decorate([
  8879. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('gridOptionsWrapper')
  8880. ], ColumnController.prototype, "gridOptionsWrapper", void 0);
  8881. __decorate([
  8882. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('expressionService')
  8883. ], ColumnController.prototype, "expressionService", void 0);
  8884. __decorate([
  8885. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('columnFactory')
  8886. ], ColumnController.prototype, "columnFactory", void 0);
  8887. __decorate([
  8888. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('displayedGroupCreator')
  8889. ], ColumnController.prototype, "displayedGroupCreator", void 0);
  8890. __decorate([
  8891. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('autoWidthCalculator')
  8892. ], ColumnController.prototype, "autoWidthCalculator", void 0);
  8893. __decorate([
  8894. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('columnUtils')
  8895. ], ColumnController.prototype, "columnUtils", void 0);
  8896. __decorate([
  8897. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('columnAnimationService')
  8898. ], ColumnController.prototype, "columnAnimationService", void 0);
  8899. __decorate([
  8900. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('autoGroupColService')
  8901. ], ColumnController.prototype, "autoGroupColService", void 0);
  8902. __decorate([
  8903. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Optional"])('aggFuncService')
  8904. ], ColumnController.prototype, "aggFuncService", void 0);
  8905. __decorate([
  8906. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Optional"])('valueCache')
  8907. ], ColumnController.prototype, "valueCache", void 0);
  8908. __decorate([
  8909. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Optional"])('animationFrameService')
  8910. ], ColumnController.prototype, "animationFrameService", void 0);
  8911. __decorate([
  8912. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('columnApi')
  8913. ], ColumnController.prototype, "columnApi", void 0);
  8914. __decorate([
  8915. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])('gridApi')
  8916. ], ColumnController.prototype, "gridApi", void 0);
  8917. __decorate([
  8918. _context_context__WEBPACK_IMPORTED_MODULE_6__["PostConstruct"]
  8919. ], ColumnController.prototype, "init", null);
  8920. __decorate([
  8921. __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Qualifier"])('loggerFactory'))
  8922. ], ColumnController.prototype, "setBeans", null);
  8923. ColumnController = __decorate([
  8924. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Bean"])('columnController')
  8925. ], ColumnController);
  8926. return ColumnController;
  8927. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"]));
  8928. /***/ }),
  8929. /* 43 */
  8930. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  8931. "use strict";
  8932. __webpack_require__.r(__webpack_exports__);
  8933. /* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(44);
  8934. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Events", function() { return _eventKeys__WEBPACK_IMPORTED_MODULE_0__["Events"]; });
  8935. /**
  8936. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  8937. * @version v23.2.1
  8938. * @link http://www.ag-grid.com/
  8939. * @license MIT
  8940. */
  8941. /***/ }),
  8942. /* 44 */
  8943. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  8944. "use strict";
  8945. __webpack_require__.r(__webpack_exports__);
  8946. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Events", function() { return Events; });
  8947. /**
  8948. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  8949. * @version v23.2.1
  8950. * @link http://www.ag-grid.com/
  8951. * @license MIT
  8952. */
  8953. var Events = /** @class */ (function () {
  8954. function Events() {
  8955. }
  8956. /** Everything has changed with the columns. Either complete new set of columns set, or user called setState()*/
  8957. Events.EVENT_COLUMN_EVERYTHING_CHANGED = 'columnEverythingChanged';
  8958. /** User has set in new columns. */
  8959. Events.EVENT_NEW_COLUMNS_LOADED = 'newColumnsLoaded';
  8960. /** The pivot mode flag was changed */
  8961. Events.EVENT_COLUMN_PIVOT_MODE_CHANGED = 'columnPivotModeChanged';
  8962. /** A row group column was added, removed or order changed. */
  8963. Events.EVENT_COLUMN_ROW_GROUP_CHANGED = 'columnRowGroupChanged';
  8964. /** expandAll / collapseAll was called from the api. */
  8965. Events.EVENT_EXPAND_COLLAPSE_ALL = 'expandOrCollapseAll';
  8966. /** A pivot column was added, removed or order changed. */
  8967. Events.EVENT_COLUMN_PIVOT_CHANGED = 'columnPivotChanged';
  8968. /** The list of grid columns has changed. */
  8969. Events.EVENT_GRID_COLUMNS_CHANGED = 'gridColumnsChanged';
  8970. /** A value column was added, removed or agg function was changed. */
  8971. Events.EVENT_COLUMN_VALUE_CHANGED = 'columnValueChanged';
  8972. /** A column was moved */
  8973. Events.EVENT_COLUMN_MOVED = 'columnMoved';
  8974. /** One or more columns was shown / hidden */
  8975. Events.EVENT_COLUMN_VISIBLE = 'columnVisible';
  8976. /** One or more columns was pinned / unpinned*/
  8977. Events.EVENT_COLUMN_PINNED = 'columnPinned';
  8978. /** A column group was opened / closed */
  8979. Events.EVENT_COLUMN_GROUP_OPENED = 'columnGroupOpened';
  8980. /** One or more columns was resized. If just one, the column in the event is set. */
  8981. Events.EVENT_COLUMN_RESIZED = 'columnResized';
  8982. /** The list of displayed columns has changed, can result from columns open / close, column move, pivot, group, etc */
  8983. Events.EVENT_DISPLAYED_COLUMNS_CHANGED = 'displayedColumnsChanged';
  8984. /** The list of virtual columns has changed, results from viewport changing */
  8985. Events.EVENT_VIRTUAL_COLUMNS_CHANGED = 'virtualColumnsChanged';
  8986. /** A row group was opened / closed */
  8987. Events.EVENT_ROW_GROUP_OPENED = 'rowGroupOpened';
  8988. /** The client has set new data into the grid */
  8989. Events.EVENT_ROW_DATA_CHANGED = 'rowDataChanged';
  8990. /** The client has updated data for the grid */
  8991. Events.EVENT_ROW_DATA_UPDATED = 'rowDataUpdated';
  8992. /** The client has set new floating data into the grid */
  8993. Events.EVENT_PINNED_ROW_DATA_CHANGED = 'pinnedRowDataChanged';
  8994. /** Range selection has changed */
  8995. Events.EVENT_RANGE_SELECTION_CHANGED = 'rangeSelectionChanged';
  8996. /** Chart was created */
  8997. Events.EVENT_CHART_CREATED = 'chartCreated';
  8998. /** Chart Range selection has changed */
  8999. Events.EVENT_CHART_RANGE_SELECTION_CHANGED = 'chartRangeSelectionChanged';
  9000. /** Chart Options have changed */
  9001. Events.EVENT_CHART_OPTIONS_CHANGED = 'chartOptionsChanged';
  9002. /** Chart was destroyed */
  9003. Events.EVENT_CHART_DESTROYED = 'chartDestroyed';
  9004. /** For when the tool panel is shown / hidden */
  9005. Events.EVENT_TOOL_PANEL_VISIBLE_CHANGED = 'toolPanelVisibleChanged';
  9006. /** Model was updated - grid updates the drawn rows when this happens */
  9007. Events.EVENT_MODEL_UPDATED = 'modelUpdated';
  9008. Events.EVENT_PASTE_START = 'pasteStart';
  9009. Events.EVENT_PASTE_END = 'pasteEnd';
  9010. Events.EVENT_FILL_START = 'fillStart';
  9011. Events.EVENT_FILL_END = 'fillEnd';
  9012. Events.EVENT_CELL_CLICKED = 'cellClicked';
  9013. Events.EVENT_CELL_DOUBLE_CLICKED = 'cellDoubleClicked';
  9014. Events.EVENT_CELL_MOUSE_DOWN = 'cellMouseDown';
  9015. Events.EVENT_CELL_CONTEXT_MENU = 'cellContextMenu';
  9016. Events.EVENT_CELL_VALUE_CHANGED = 'cellValueChanged';
  9017. Events.EVENT_ROW_VALUE_CHANGED = 'rowValueChanged';
  9018. Events.EVENT_CELL_FOCUSED = 'cellFocused';
  9019. Events.EVENT_ROW_SELECTED = 'rowSelected';
  9020. Events.EVENT_SELECTION_CHANGED = 'selectionChanged';
  9021. Events.EVENT_CELL_KEY_DOWN = 'cellKeyDown';
  9022. Events.EVENT_CELL_KEY_PRESS = 'cellKeyPress';
  9023. Events.EVENT_CELL_MOUSE_OVER = 'cellMouseOver';
  9024. Events.EVENT_CELL_MOUSE_OUT = 'cellMouseOut';
  9025. /** 2 events for filtering. The grid LISTENS for filterChanged and afterFilterChanged */
  9026. Events.EVENT_FILTER_CHANGED = 'filterChanged';
  9027. /** Filter was change but not applied. Only useful if apply buttons are used in filters. */
  9028. Events.EVENT_FILTER_MODIFIED = 'filterModified';
  9029. Events.EVENT_FILTER_OPENED = 'filterOpened';
  9030. Events.EVENT_SORT_CHANGED = 'sortChanged';
  9031. /** A row was removed from the dom, for any reason. Use to clean up resources (if any) used by the row. */
  9032. Events.EVENT_VIRTUAL_ROW_REMOVED = 'virtualRowRemoved';
  9033. Events.EVENT_ROW_CLICKED = 'rowClicked';
  9034. Events.EVENT_ROW_DOUBLE_CLICKED = 'rowDoubleClicked';
  9035. /** Gets called once after the grid has finished initialising. */
  9036. Events.EVENT_GRID_READY = 'gridReady';
  9037. /** Width of height of the main grid div has changed. Grid listens for this and does layout of grid if it's
  9038. * changed, so always filling the space it was given. */
  9039. Events.EVENT_GRID_SIZE_CHANGED = 'gridSizeChanged';
  9040. /** The indexes of the rows rendered has changed, eg user has scrolled to a new vertical position. */
  9041. Events.EVENT_VIEWPORT_CHANGED = 'viewportChanged';
  9042. /** Rows were rendered for the first time (ie on async data load). */
  9043. Events.EVENT_FIRST_DATA_RENDERED = 'firstDataRendered';
  9044. /** A column drag has started, either resizing a column or moving a column. */
  9045. Events.EVENT_DRAG_STARTED = 'dragStarted';
  9046. /** A column drag has stopped */
  9047. Events.EVENT_DRAG_STOPPED = 'dragStopped';
  9048. Events.EVENT_CHECKBOX_CHANGED = 'checkboxChanged';
  9049. Events.EVENT_ROW_EDITING_STARTED = 'rowEditingStarted';
  9050. Events.EVENT_ROW_EDITING_STOPPED = 'rowEditingStopped';
  9051. Events.EVENT_CELL_EDITING_STARTED = 'cellEditingStarted';
  9052. Events.EVENT_CELL_EDITING_STOPPED = 'cellEditingStopped';
  9053. /** Main body of grid has scrolled, either horizontally or vertically */
  9054. Events.EVENT_BODY_SCROLL = 'bodyScroll';
  9055. Events.EVENT_ANIMATION_QUEUE_EMPTY = 'animationQueueEmpty';
  9056. Events.EVENT_HEIGHT_SCALE_CHANGED = 'heightScaleChanged';
  9057. /** The displayed page for pagination has changed. For example the data was filtered or sorted,
  9058. * or the user has moved to a different page. */
  9059. Events.EVENT_PAGINATION_CHANGED = 'paginationChanged';
  9060. /** Only used by React, Angular 2+, Web Components and VueJS ag-Grid components
  9061. * (not used if doing plain JavaScript or Angular 1.x). If the grid receives changes due
  9062. * to bound properties, this event fires after the grid has finished processing the change. */
  9063. Events.EVENT_COMPONENT_STATE_CHANGED = 'componentStateChanged';
  9064. /** All items from here down are used internally by the grid, not intended for external use. */
  9065. // not documented, either experimental, or we just don't want users using an depending on them
  9066. Events.EVENT_BODY_HEIGHT_CHANGED = 'bodyHeightChanged';
  9067. Events.EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED = 'displayedColumnsWidthChanged';
  9068. Events.EVENT_SCROLL_VISIBILITY_CHANGED = 'scrollVisibilityChanged';
  9069. Events.EVENT_COLUMN_HOVER_CHANGED = 'columnHoverChanged';
  9070. Events.EVENT_FLASH_CELLS = 'flashCells';
  9071. Events.EVENT_ROW_DRAG_ENTER = 'rowDragEnter';
  9072. Events.EVENT_ROW_DRAG_MOVE = 'rowDragMove';
  9073. Events.EVENT_ROW_DRAG_LEAVE = 'rowDragLeave';
  9074. Events.EVENT_ROW_DRAG_END = 'rowDragEnd';
  9075. // primarily for charts
  9076. Events.EVENT_POPUP_TO_FRONT = 'popupToFront';
  9077. // these are used for server side group and agg - only used by CS with Viewport Row Model - intention is
  9078. // to design these better around server side functions and then release to general public when fully working with
  9079. // all the row models.
  9080. Events.EVENT_COLUMN_ROW_GROUP_CHANGE_REQUEST = 'columnRowGroupChangeRequest';
  9081. Events.EVENT_COLUMN_PIVOT_CHANGE_REQUEST = 'columnPivotChangeRequest';
  9082. Events.EVENT_COLUMN_VALUE_CHANGE_REQUEST = 'columnValueChangeRequest';
  9083. Events.EVENT_COLUMN_AGG_FUNC_CHANGE_REQUEST = 'columnAggFuncChangeRequest';
  9084. Events.EVENT_KEYBOARD_FOCUS = 'keyboardFocus';
  9085. Events.EVENT_MOUSE_FOCUS = 'mouseFocus';
  9086. return Events;
  9087. }());
  9088. /***/ }),
  9089. /* 45 */
  9090. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  9091. "use strict";
  9092. __webpack_require__.r(__webpack_exports__);
  9093. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GroupInstanceIdCreator", function() { return GroupInstanceIdCreator; });
  9094. /**
  9095. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  9096. * @version v23.2.1
  9097. * @link http://www.ag-grid.com/
  9098. * @license MIT
  9099. */
  9100. // class returns unique instance id's for columns.
  9101. // eg, the following calls (in this order) will result in:
  9102. //
  9103. // getInstanceIdForKey('country') => 0
  9104. // getInstanceIdForKey('country') => 1
  9105. // getInstanceIdForKey('country') => 2
  9106. // getInstanceIdForKey('country') => 3
  9107. // getInstanceIdForKey('age') => 0
  9108. // getInstanceIdForKey('age') => 1
  9109. // getInstanceIdForKey('country') => 4
  9110. var GroupInstanceIdCreator = /** @class */ (function () {
  9111. function GroupInstanceIdCreator() {
  9112. // this map contains keys to numbers, so we remember what the last call was
  9113. this.existingIds = {};
  9114. }
  9115. GroupInstanceIdCreator.prototype.getInstanceIdForKey = function (key) {
  9116. var lastResult = this.existingIds[key];
  9117. var result;
  9118. if (typeof lastResult !== 'number') {
  9119. // first time this key
  9120. result = 0;
  9121. }
  9122. else {
  9123. result = lastResult + 1;
  9124. }
  9125. this.existingIds[key] = result;
  9126. return result;
  9127. };
  9128. return GroupInstanceIdCreator;
  9129. }());
  9130. /***/ }),
  9131. /* 46 */
  9132. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  9133. "use strict";
  9134. __webpack_require__.r(__webpack_exports__);
  9135. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnUtils", function() { return ColumnUtils; });
  9136. /* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(34);
  9137. /* harmony import */ var _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(33);
  9138. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37);
  9139. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  9140. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(41);
  9141. /**
  9142. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  9143. * @version v23.2.1
  9144. * @link http://www.ag-grid.com/
  9145. * @license MIT
  9146. */
  9147. var __extends = (undefined && undefined.__extends) || (function () {
  9148. var extendStatics = function (d, b) {
  9149. extendStatics = Object.setPrototypeOf ||
  9150. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  9151. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  9152. return extendStatics(d, b);
  9153. };
  9154. return function (d, b) {
  9155. extendStatics(d, b);
  9156. function __() { this.constructor = d; }
  9157. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  9158. };
  9159. })();
  9160. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  9161. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  9162. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  9163. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  9164. return c > 3 && r && Object.defineProperty(target, key, r), r;
  9165. };
  9166. // takes in a list of columns, as specified by the column definitions, and returns column groups
  9167. var ColumnUtils = /** @class */ (function (_super) {
  9168. __extends(ColumnUtils, _super);
  9169. function ColumnUtils() {
  9170. return _super !== null && _super.apply(this, arguments) || this;
  9171. }
  9172. ColumnUtils.prototype.calculateColInitialWidth = function (colDef) {
  9173. var optionsWrapper = this.gridOptionsWrapper;
  9174. var minColWidth = colDef.minWidth != null ? colDef.minWidth : optionsWrapper.getMinColWidth();
  9175. var maxColWidth = colDef.maxWidth != null ? colDef.maxWidth : (optionsWrapper.getMaxColWidth() || _utils__WEBPACK_IMPORTED_MODULE_3__["_"].getMaxSafeInteger());
  9176. var width = colDef.width != null ? colDef.width : optionsWrapper.getColWidth();
  9177. return Math.max(Math.min(width, maxColWidth), minColWidth);
  9178. };
  9179. ColumnUtils.prototype.getOriginalPathForColumn = function (column, originalBalancedTree) {
  9180. var result = [];
  9181. var found = false;
  9182. var recursePath = function (balancedColumnTree, dept) {
  9183. for (var i = 0; i < balancedColumnTree.length; i++) {
  9184. if (found) {
  9185. return;
  9186. }
  9187. // quit the search, so 'result' is kept with the found result
  9188. var node = balancedColumnTree[i];
  9189. if (node instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"]) {
  9190. var nextNode = node;
  9191. recursePath(nextNode.getChildren(), dept + 1);
  9192. result[dept] = node;
  9193. }
  9194. else if (node === column) {
  9195. found = true;
  9196. }
  9197. }
  9198. };
  9199. recursePath(originalBalancedTree, 0);
  9200. // we should always find the path, but in case there is a bug somewhere, returning null
  9201. // will make it fail rather than provide a 'hard to track down' bug
  9202. return found ? result : null;
  9203. };
  9204. /* public getPathForColumn(column: Column, allDisplayedColumnGroups: ColumnGroupChild[]): ColumnGroup[] {
  9205. let result: ColumnGroup[] = [];
  9206. let found = false;
  9207. recursePath(allDisplayedColumnGroups, 0);
  9208. // we should always find the path, but in case there is a bug somewhere, returning null
  9209. // will make it fail rather than provide a 'hard to track down' bug
  9210. if (found) {
  9211. return result;
  9212. } else {
  9213. return null;
  9214. }
  9215. function recursePath(balancedColumnTree: ColumnGroupChild[], dept: number): void {
  9216. for (let i = 0; i<balancedColumnTree.length; i++) {
  9217. if (found) {
  9218. // quit the search, so 'result' is kept with the found result
  9219. return;
  9220. }
  9221. let node = balancedColumnTree[i];
  9222. if (node instanceof ColumnGroup) {
  9223. let nextNode = <ColumnGroup> node;
  9224. recursePath(nextNode.getChildren(), dept+1);
  9225. result[dept] = node;
  9226. } else {
  9227. if (node === column) {
  9228. found = true;
  9229. }
  9230. }
  9231. }
  9232. }
  9233. }*/
  9234. ColumnUtils.prototype.depthFirstOriginalTreeSearch = function (parent, tree, callback) {
  9235. var _this = this;
  9236. if (!tree) {
  9237. return;
  9238. }
  9239. tree.forEach(function (child) {
  9240. if (child instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_1__["OriginalColumnGroup"]) {
  9241. _this.depthFirstOriginalTreeSearch(child, child.getChildren(), callback);
  9242. }
  9243. callback(child, parent);
  9244. });
  9245. };
  9246. ColumnUtils.prototype.depthFirstAllColumnTreeSearch = function (tree, callback) {
  9247. var _this = this;
  9248. if (!tree) {
  9249. return;
  9250. }
  9251. tree.forEach(function (child) {
  9252. if (child instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) {
  9253. _this.depthFirstAllColumnTreeSearch(child.getChildren(), callback);
  9254. }
  9255. callback(child);
  9256. });
  9257. };
  9258. ColumnUtils.prototype.depthFirstDisplayedColumnTreeSearch = function (tree, callback) {
  9259. var _this = this;
  9260. if (!tree) {
  9261. return;
  9262. }
  9263. tree.forEach(function (child) {
  9264. if (child instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) {
  9265. _this.depthFirstDisplayedColumnTreeSearch(child.getDisplayedChildren(), callback);
  9266. }
  9267. callback(child);
  9268. });
  9269. };
  9270. __decorate([
  9271. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper')
  9272. ], ColumnUtils.prototype, "gridOptionsWrapper", void 0);
  9273. ColumnUtils = __decorate([
  9274. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Bean"])('columnUtils')
  9275. ], ColumnUtils);
  9276. return ColumnUtils;
  9277. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_4__["BeanStub"]));
  9278. /***/ }),
  9279. /* 47 */
  9280. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  9281. "use strict";
  9282. __webpack_require__.r(__webpack_exports__);
  9283. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DisplayedGroupCreator", function() { return DisplayedGroupCreator; });
  9284. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  9285. /* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(34);
  9286. /* harmony import */ var _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(33);
  9287. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  9288. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(41);
  9289. /**
  9290. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  9291. * @version v23.2.1
  9292. * @link http://www.ag-grid.com/
  9293. * @license MIT
  9294. */
  9295. var __extends = (undefined && undefined.__extends) || (function () {
  9296. var extendStatics = function (d, b) {
  9297. extendStatics = Object.setPrototypeOf ||
  9298. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  9299. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  9300. return extendStatics(d, b);
  9301. };
  9302. return function (d, b) {
  9303. extendStatics(d, b);
  9304. function __() { this.constructor = d; }
  9305. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  9306. };
  9307. })();
  9308. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  9309. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  9310. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  9311. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  9312. return c > 3 && r && Object.defineProperty(target, key, r), r;
  9313. };
  9314. // takes in a list of columns, as specified by the column definitions, and returns column groups
  9315. var DisplayedGroupCreator = /** @class */ (function (_super) {
  9316. __extends(DisplayedGroupCreator, _super);
  9317. function DisplayedGroupCreator() {
  9318. return _super !== null && _super.apply(this, arguments) || this;
  9319. }
  9320. DisplayedGroupCreator.prototype.createDisplayedGroups = function (
  9321. // all displayed columns sorted - this is the columns the grid should show
  9322. sortedVisibleColumns,
  9323. // the tree of columns, as provided by the users, used to know what groups columns roll up into
  9324. balancedColumnTree,
  9325. // creates unique id's for the group
  9326. groupInstanceIdCreator,
  9327. // whether it's left, right or center col
  9328. pinned,
  9329. // we try to reuse old groups if we can, to allow gui to do animation
  9330. oldDisplayedGroups) {
  9331. var _this = this;
  9332. var result = [];
  9333. var previousRealPath;
  9334. var previousOriginalPath;
  9335. var oldColumnsMapped = this.mapOldGroupsById(oldDisplayedGroups);
  9336. // go through each column, then do a bottom up comparison to the previous column, and start
  9337. // to share groups if they converge at any point.
  9338. sortedVisibleColumns.forEach(function (currentColumn) {
  9339. var currentOriginalPath = _this.getOriginalPathForColumn(balancedColumnTree, currentColumn);
  9340. var currentRealPath = [];
  9341. var firstColumn = !previousOriginalPath;
  9342. for (var i = 0; i < currentOriginalPath.length; i++) {
  9343. if (firstColumn || currentOriginalPath[i] !== previousOriginalPath[i]) {
  9344. // new group needed
  9345. var newGroup = _this.createColumnGroup(currentOriginalPath[i], groupInstanceIdCreator, oldColumnsMapped, pinned);
  9346. currentRealPath[i] = newGroup;
  9347. // if top level, add to result, otherwise add to parent
  9348. if (i == 0) {
  9349. result.push(newGroup);
  9350. }
  9351. else {
  9352. currentRealPath[i - 1].addChild(newGroup);
  9353. }
  9354. }
  9355. else {
  9356. // reuse old group
  9357. currentRealPath[i] = previousRealPath[i];
  9358. }
  9359. }
  9360. var noColumnGroups = currentRealPath.length === 0;
  9361. if (noColumnGroups) {
  9362. // if we are not grouping, then the result of the above is an empty
  9363. // path (no groups), and we just add the column to the root list.
  9364. result.push(currentColumn);
  9365. }
  9366. else {
  9367. var leafGroup = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].last(currentRealPath);
  9368. leafGroup.addChild(currentColumn);
  9369. }
  9370. previousRealPath = currentRealPath;
  9371. previousOriginalPath = currentOriginalPath;
  9372. });
  9373. this.setupParentsIntoColumns(result, null);
  9374. return result;
  9375. };
  9376. DisplayedGroupCreator.prototype.createColumnGroup = function (originalGroup, groupInstanceIdCreator, oldColumnsMapped, pinned) {
  9377. var groupId = originalGroup.getGroupId();
  9378. var instanceId = groupInstanceIdCreator.getInstanceIdForKey(groupId);
  9379. var uniqueId = _entities_columnGroup__WEBPACK_IMPORTED_MODULE_1__["ColumnGroup"].createUniqueId(groupId, instanceId);
  9380. var columnGroup = oldColumnsMapped[uniqueId];
  9381. // if the user is setting new colDefs, it is possible that the id's overlap, and we
  9382. // would have a false match from above. so we double check we are talking about the
  9383. // same original column group.
  9384. if (columnGroup && columnGroup.getOriginalColumnGroup() !== originalGroup) {
  9385. columnGroup = null;
  9386. }
  9387. if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(columnGroup)) {
  9388. // clean out the old column group here, as we will be adding children into it again
  9389. columnGroup.reset();
  9390. }
  9391. else {
  9392. columnGroup = new _entities_columnGroup__WEBPACK_IMPORTED_MODULE_1__["ColumnGroup"](originalGroup, groupId, instanceId, pinned);
  9393. this.context.createBean(columnGroup);
  9394. }
  9395. return columnGroup;
  9396. };
  9397. // returns back a 2d map of ColumnGroup as follows: groupId -> instanceId -> ColumnGroup
  9398. DisplayedGroupCreator.prototype.mapOldGroupsById = function (displayedGroups) {
  9399. var result = {};
  9400. var recursive = function (columnsOrGroups) {
  9401. columnsOrGroups.forEach(function (columnOrGroup) {
  9402. if (columnOrGroup instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_1__["ColumnGroup"]) {
  9403. var columnGroup = columnOrGroup;
  9404. result[columnOrGroup.getUniqueId()] = columnGroup;
  9405. recursive(columnGroup.getChildren());
  9406. }
  9407. });
  9408. };
  9409. if (displayedGroups) {
  9410. recursive(displayedGroups);
  9411. }
  9412. return result;
  9413. };
  9414. DisplayedGroupCreator.prototype.setupParentsIntoColumns = function (columnsOrGroups, parent) {
  9415. var _this = this;
  9416. columnsOrGroups.forEach(function (columnsOrGroup) {
  9417. columnsOrGroup.setParent(parent);
  9418. if (columnsOrGroup instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_1__["ColumnGroup"]) {
  9419. var columnGroup = columnsOrGroup;
  9420. _this.setupParentsIntoColumns(columnGroup.getChildren(), columnGroup);
  9421. }
  9422. });
  9423. };
  9424. DisplayedGroupCreator.prototype.getOriginalPathForColumn = function (balancedColumnTree, column) {
  9425. var result = [];
  9426. var found = false;
  9427. var recursePath = function (balancedColumnTree, dept) {
  9428. for (var i = 0; i < balancedColumnTree.length; i++) {
  9429. // quit the search, so 'result' is kept with the found result
  9430. if (found) {
  9431. return;
  9432. }
  9433. var node = balancedColumnTree[i];
  9434. if (node instanceof _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_2__["OriginalColumnGroup"]) {
  9435. var nextNode = node;
  9436. recursePath(nextNode.getChildren(), dept + 1);
  9437. result[dept] = node;
  9438. }
  9439. else if (node === column) {
  9440. found = true;
  9441. }
  9442. }
  9443. };
  9444. recursePath(balancedColumnTree, 0);
  9445. // it's possible we didn't find a path. this happens if the column is generated
  9446. // by the grid (auto-group), in that the definition didn't come from the client. in this case,
  9447. // we create a fake original path.
  9448. if (found) {
  9449. return result;
  9450. }
  9451. console.warn('could not get path');
  9452. return null;
  9453. };
  9454. __decorate([
  9455. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnUtils')
  9456. ], DisplayedGroupCreator.prototype, "columnUtils", void 0);
  9457. DisplayedGroupCreator = __decorate([
  9458. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('displayedGroupCreator')
  9459. ], DisplayedGroupCreator);
  9460. return DisplayedGroupCreator;
  9461. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_4__["BeanStub"]));
  9462. /***/ }),
  9463. /* 48 */
  9464. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  9465. "use strict";
  9466. __webpack_require__.r(__webpack_exports__);
  9467. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ComponentUtil", function() { return ComponentUtil; });
  9468. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(43);
  9469. /* harmony import */ var _propertyKeys__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(49);
  9470. /* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(50);
  9471. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  9472. /**
  9473. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  9474. * @version v23.2.1
  9475. * @link http://www.ag-grid.com/
  9476. * @license MIT
  9477. */
  9478. var __spreadArrays = (undefined && undefined.__spreadArrays) || function () {
  9479. for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;
  9480. for (var r = Array(s), k = 0, i = 0; i < il; i++)
  9481. for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
  9482. r[k] = a[j];
  9483. return r;
  9484. };
  9485. var ComponentUtil = /** @class */ (function () {
  9486. function ComponentUtil() {
  9487. }
  9488. ComponentUtil.getEventCallbacks = function () {
  9489. if (!ComponentUtil.EVENT_CALLBACKS) {
  9490. ComponentUtil.EVENT_CALLBACKS = ComponentUtil.EVENTS.map(function (event) { return ComponentUtil.getCallbackForEvent(event); });
  9491. }
  9492. return ComponentUtil.EVENT_CALLBACKS;
  9493. };
  9494. ComponentUtil.copyAttributesToGridOptions = function (gridOptions, component, skipEventDeprecationCheck) {
  9495. if (skipEventDeprecationCheck === void 0) { skipEventDeprecationCheck = false; }
  9496. checkForDeprecated(component);
  9497. // create empty grid options if none were passed
  9498. if (typeof gridOptions !== 'object') {
  9499. gridOptions = {};
  9500. }
  9501. // to allow array style lookup in TypeScript, take type away from 'this' and 'gridOptions'
  9502. var pGridOptions = gridOptions;
  9503. var keyExists = function (key) { return typeof component[key] !== 'undefined'; };
  9504. // add in all the simple properties
  9505. __spreadArrays(ComponentUtil.ARRAY_PROPERTIES, ComponentUtil.STRING_PROPERTIES, ComponentUtil.OBJECT_PROPERTIES, ComponentUtil.FUNCTION_PROPERTIES, ComponentUtil.getEventCallbacks()).filter(keyExists)
  9506. .forEach(function (key) { return pGridOptions[key] = component[key]; });
  9507. ComponentUtil.BOOLEAN_PROPERTIES
  9508. .filter(keyExists)
  9509. .forEach(function (key) { return pGridOptions[key] = ComponentUtil.toBoolean(component[key]); });
  9510. ComponentUtil.NUMBER_PROPERTIES
  9511. .filter(keyExists)
  9512. .forEach(function (key) { return pGridOptions[key] = ComponentUtil.toNumber(component[key]); });
  9513. // purely for event deprecation checks (for frameworks - wouldn't apply for non-fw versions)
  9514. if (!skipEventDeprecationCheck) {
  9515. ComponentUtil.EVENTS
  9516. // React uses onXXX, not sure why this is different to the other frameworks
  9517. .filter(function (event) { return keyExists(event) || keyExists(ComponentUtil.getCallbackForEvent(event)); })
  9518. .forEach(function (event) { return _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__["GridOptionsWrapper"].checkEventDeprecation(event); });
  9519. }
  9520. return gridOptions;
  9521. };
  9522. ComponentUtil.getCallbackForEvent = function (eventName) {
  9523. if (!eventName || eventName.length < 2) {
  9524. return eventName;
  9525. }
  9526. else {
  9527. return 'on' + eventName[0].toUpperCase() + eventName.substr(1);
  9528. }
  9529. };
  9530. ComponentUtil.processOnChange = function (changes, gridOptions, api, columnApi) {
  9531. if (!changes) {
  9532. return;
  9533. }
  9534. checkForDeprecated(changes);
  9535. // to allow array style lookup in TypeScript, take type away from 'this' and 'gridOptions'
  9536. var pGridOptions = gridOptions;
  9537. var keyExists = function (key) { return changes[key]; };
  9538. // check if any change for the simple types, and if so, then just copy in the new value
  9539. __spreadArrays(ComponentUtil.ARRAY_PROPERTIES, ComponentUtil.OBJECT_PROPERTIES, ComponentUtil.STRING_PROPERTIES, ComponentUtil.getEventCallbacks()).filter(keyExists)
  9540. .forEach(function (key) { return pGridOptions[key] = changes[key].currentValue; });
  9541. ComponentUtil.BOOLEAN_PROPERTIES
  9542. .filter(keyExists)
  9543. .forEach(function (key) { return pGridOptions[key] = ComponentUtil.toBoolean(changes[key].currentValue); });
  9544. ComponentUtil.NUMBER_PROPERTIES
  9545. .filter(keyExists)
  9546. .forEach(function (key) { return pGridOptions[key] = ComponentUtil.toNumber(changes[key].currentValue); });
  9547. if (changes.enableCellTextSelection) {
  9548. api.setEnableCellTextSelection(ComponentUtil.toBoolean(changes.enableCellTextSelection.currentValue));
  9549. }
  9550. if (changes.showToolPanel) {
  9551. api.showToolPanel(ComponentUtil.toBoolean(changes.showToolPanel.currentValue));
  9552. }
  9553. if (changes.quickFilterText) {
  9554. api.setQuickFilter(changes.quickFilterText.currentValue);
  9555. }
  9556. if (changes.rowData) {
  9557. api.setRowData(changes.rowData.currentValue);
  9558. }
  9559. if (changes.pinnedTopRowData) {
  9560. api.setPinnedTopRowData(changes.pinnedTopRowData.currentValue);
  9561. }
  9562. if (changes.pinnedBottomRowData) {
  9563. api.setPinnedBottomRowData(changes.pinnedBottomRowData.currentValue);
  9564. }
  9565. if (changes.autoGroupColumnDef) {
  9566. api.setAutoGroupColumnDef(changes.autoGroupColumnDef.currentValue, "gridOptionsChanged");
  9567. }
  9568. if (changes.columnDefs) {
  9569. api.setColumnDefs(changes.columnDefs.currentValue, "gridOptionsChanged");
  9570. }
  9571. if (changes.datasource) {
  9572. api.setDatasource(changes.datasource.currentValue);
  9573. }
  9574. if (changes.headerHeight) {
  9575. api.setHeaderHeight(ComponentUtil.toNumber(changes.headerHeight.currentValue));
  9576. }
  9577. if (changes.paginationPageSize) {
  9578. api.paginationSetPageSize(ComponentUtil.toNumber(changes.paginationPageSize.currentValue));
  9579. }
  9580. if (changes.pivotMode) {
  9581. columnApi.setPivotMode(ComponentUtil.toBoolean(changes.pivotMode.currentValue));
  9582. }
  9583. if (changes.groupRemoveSingleChildren) {
  9584. api.setGroupRemoveSingleChildren(ComponentUtil.toBoolean(changes.groupRemoveSingleChildren.currentValue));
  9585. }
  9586. if (changes.suppressRowDrag) {
  9587. api.setSuppressRowDrag(ComponentUtil.toBoolean(changes.suppressRowDrag.currentValue));
  9588. }
  9589. if (changes.suppressMoveWhenRowDragging) {
  9590. api.setSuppressMoveWhenRowDragging(ComponentUtil.toBoolean(changes.suppressMoveWhenRowDragging.currentValue));
  9591. }
  9592. if (changes.suppressRowClickSelection) {
  9593. api.setSuppressRowClickSelection(ComponentUtil.toBoolean(changes.suppressRowClickSelection.currentValue));
  9594. }
  9595. if (changes.gridAutoHeight) {
  9596. api.setGridAutoHeight(ComponentUtil.toBoolean(changes.gridAutoHeight.currentValue));
  9597. }
  9598. if (changes.suppressClipboardPaste) {
  9599. api.setSuppressClipboardPaste(ComponentUtil.toBoolean(changes.suppressClipboardPaste.currentValue));
  9600. }
  9601. if (changes.sideBar) {
  9602. api.setSideBar(changes.sideBar.currentValue);
  9603. }
  9604. // copy changes into an event for dispatch
  9605. var event = {
  9606. type: _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COMPONENT_STATE_CHANGED,
  9607. api: gridOptions.api,
  9608. columnApi: gridOptions.columnApi
  9609. };
  9610. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].iterateObject(changes, function (key, value) {
  9611. event[key] = value;
  9612. });
  9613. api.dispatchEvent(event);
  9614. };
  9615. ComponentUtil.toBoolean = function (value) {
  9616. if (typeof value === 'boolean') {
  9617. return value;
  9618. }
  9619. else if (typeof value === 'string') {
  9620. // for boolean, compare to empty String to allow attributes appearing with
  9621. // no value to be treated as 'true'
  9622. return value.toUpperCase() === 'TRUE' || value == '';
  9623. }
  9624. else {
  9625. return false;
  9626. }
  9627. };
  9628. ComponentUtil.toNumber = function (value) {
  9629. if (typeof value === 'number') {
  9630. return value;
  9631. }
  9632. else if (typeof value === 'string') {
  9633. return Number(value);
  9634. }
  9635. else {
  9636. return undefined;
  9637. }
  9638. };
  9639. // all the events are populated in here AFTER this class (at the bottom of the file).
  9640. ComponentUtil.EVENTS = [];
  9641. ComponentUtil.STRING_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].STRING_PROPERTIES;
  9642. ComponentUtil.OBJECT_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].OBJECT_PROPERTIES;
  9643. ComponentUtil.ARRAY_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].ARRAY_PROPERTIES;
  9644. ComponentUtil.NUMBER_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].NUMBER_PROPERTIES;
  9645. ComponentUtil.BOOLEAN_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].BOOLEAN_PROPERTIES;
  9646. ComponentUtil.FUNCTION_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].FUNCTION_PROPERTIES;
  9647. ComponentUtil.ALL_PROPERTIES = _propertyKeys__WEBPACK_IMPORTED_MODULE_1__["PropertyKeys"].ALL_PROPERTIES;
  9648. return ComponentUtil;
  9649. }());
  9650. ComponentUtil.EVENTS = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].values(_events__WEBPACK_IMPORTED_MODULE_0__["Events"]);
  9651. function checkForDeprecated(changes) {
  9652. if (changes.rowDeselected || changes.onRowDeselected) {
  9653. console.warn('ag-grid: as of v3.4 rowDeselected no longer exists. Please check the docs.');
  9654. }
  9655. }
  9656. /***/ }),
  9657. /* 49 */
  9658. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  9659. "use strict";
  9660. __webpack_require__.r(__webpack_exports__);
  9661. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PropertyKeys", function() { return PropertyKeys; });
  9662. /**
  9663. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  9664. * @version v23.2.1
  9665. * @link http://www.ag-grid.com/
  9666. * @license MIT
  9667. */
  9668. var __spreadArrays = (undefined && undefined.__spreadArrays) || function () {
  9669. for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;
  9670. for (var r = Array(s), k = 0, i = 0; i < il; i++)
  9671. for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
  9672. r[k] = a[j];
  9673. return r;
  9674. };
  9675. /**
  9676. * These keys are used for validating properties supplied on a gridOptions object, and for code generation.
  9677. * If you change the properties on the gridOptions interface, you *must* update this file as well to be consistent.
  9678. */
  9679. var PropertyKeys = /** @class */ (function () {
  9680. function PropertyKeys() {
  9681. }
  9682. PropertyKeys.STRING_PROPERTIES = [
  9683. 'sortingOrder', 'rowClass', 'rowSelection', 'overlayLoadingTemplate',
  9684. 'overlayNoRowsTemplate', 'quickFilterText', 'rowModelType',
  9685. 'editType', 'domLayout', 'clipboardDeliminator', 'rowGroupPanelShow',
  9686. 'multiSortKey', 'pivotColumnGroupTotals', 'pivotRowTotals', 'pivotPanelShow'
  9687. ];
  9688. PropertyKeys.OBJECT_PROPERTIES = [
  9689. 'components', 'frameworkComponents', 'rowStyle', 'context', 'autoGroupColumnDef', 'groupColumnDef', 'localeText',
  9690. 'icons', 'datasource', 'serverSideDatasource', 'viewportDatasource', 'groupRowRendererParams', 'aggFuncs',
  9691. 'fullWidthCellRendererParams', 'defaultColGroupDef', 'defaultColDef', 'defaultExportParams', 'columnTypes',
  9692. 'rowClassRules', 'detailGridOptions', 'detailCellRendererParams', 'loadingCellRendererParams', 'loadingOverlayComponentParams',
  9693. 'noRowsOverlayComponentParams', 'popupParent', 'colResizeDefault', 'reduxStore', 'statusBar', 'sideBar'
  9694. ];
  9695. PropertyKeys.ARRAY_PROPERTIES = [
  9696. 'slaveGrids', 'alignedGrids', 'rowData', 'columnDefs', 'excelStyles', 'pinnedTopRowData', 'pinnedBottomRowData'
  9697. ];
  9698. PropertyKeys.NUMBER_PROPERTIES = [
  9699. 'rowHeight', 'detailRowHeight', 'rowBuffer', 'colWidth', 'headerHeight', 'groupHeaderHeight', 'floatingFiltersHeight',
  9700. 'pivotHeaderHeight', 'pivotGroupHeaderHeight', 'groupDefaultExpanded', 'minColWidth', 'maxColWidth', 'viewportRowModelPageSize',
  9701. 'viewportRowModelBufferSize', 'autoSizePadding', 'maxBlocksInCache', 'maxConcurrentDatasourceRequests', 'tooltipShowDelay',
  9702. 'cacheOverflowSize', 'paginationPageSize', 'cacheBlockSize', 'infiniteInitialRowCount', 'scrollbarWidth', 'paginationStartPage',
  9703. 'infiniteBlockSize', 'batchUpdateWaitMillis', 'asyncTransactionWaitMillis', 'blockLoadDebounceMillis', 'keepDetailRowsCount',
  9704. 'undoRedoCellEditingLimit', 'cellFlashDelay', 'cellFadeDelay'
  9705. ];
  9706. PropertyKeys.BOOLEAN_PROPERTIES = [
  9707. 'toolPanelSuppressRowGroups', 'toolPanelSuppressValues', 'toolPanelSuppressPivots', 'toolPanelSuppressPivotMode',
  9708. 'toolPanelSuppressSideButtons', 'toolPanelSuppressColumnFilter', 'toolPanelSuppressColumnSelectAll',
  9709. 'toolPanelSuppressColumnExpandAll', 'suppressMakeColumnVisibleAfterUnGroup', 'suppressRowClickSelection',
  9710. 'suppressCellSelection', 'suppressHorizontalScroll', 'alwaysShowVerticalScroll', 'debug', 'enableBrowserTooltips',
  9711. 'enableColResize', 'enableCellExpressions', 'enableSorting', 'enableServerSideSorting', 'enableFilter', 'enableServerSideFilter',
  9712. 'angularCompileRows', 'angularCompileFilters', 'angularCompileHeaders', 'groupSuppressAutoColumn', 'groupSelectsChildren',
  9713. 'groupIncludeFooter', 'groupIncludeTotalFooter', 'groupUseEntireRow', 'groupSuppressRow', 'groupSuppressBlankHeader',
  9714. 'forPrint', 'suppressMenuHide', 'rowDeselection', 'unSortIcon', 'suppressMultiSort', 'singleClickEdit', 'suppressLoadingOverlay',
  9715. 'suppressNoRowsOverlay', 'suppressAutoSize', 'skipHeaderOnAutoSize', 'suppressParentsInRowNodes', 'showToolPanel',
  9716. 'suppressColumnMoveAnimation', 'suppressMovableColumns', 'suppressFieldDotNotation', 'enableRangeSelection', 'enableRangeHandle',
  9717. 'enableFillHandle', 'suppressClearOnFillReduction', 'deltaSort', 'suppressTouch', 'suppressAsyncEvents', 'allowContextMenuWithControlKey',
  9718. 'suppressContextMenu', 'suppressMenuFilterPanel', 'suppressMenuMainPanel', 'suppressMenuColumnPanel', 'rememberGroupStateWhenNewData',
  9719. 'enableCellChangeFlash', 'suppressDragLeaveHidesColumns', 'suppressMiddleClickScrolls', 'suppressPreventDefaultOnMouseWheel',
  9720. 'suppressUseColIdForGroups', 'suppressCopyRowsToClipboard', 'copyHeadersToClipboard', 'pivotMode', 'suppressAggFuncInHeader',
  9721. 'suppressColumnVirtualisation', 'suppressAggAtRootLevel', 'suppressFocusAfterRefresh', 'functionsPassive', 'functionsReadOnly',
  9722. 'animateRows', 'groupSelectsFiltered', 'groupRemoveSingleChildren', 'groupRemoveLowestSingleChildren', 'enableRtl', 'suppressClickEdit',
  9723. 'rowDragManaged', 'suppressRowDrag', 'suppressMoveWhenRowDragging', 'enableMultiRowDragging', 'enableGroupEdit', 'embedFullWidthRows',
  9724. 'deprecatedEmbedFullWidthRows', 'suppressTabbing', 'suppressPaginationPanel', 'floatingFilter', 'groupHideOpenParents', 'groupMultiAutoColumn',
  9725. 'pagination', 'stopEditingWhenGridLosesFocus', 'paginationAutoPageSize', 'suppressScrollOnNewData', 'purgeClosedRowNodes', 'cacheQuickFilter',
  9726. 'deltaRowDataMode', 'ensureDomOrder', 'accentedSort', 'pivotTotals', 'suppressChangeDetection', 'valueCache', 'valueCacheNeverExpires',
  9727. 'aggregateOnlyChangedColumns', 'suppressAnimationFrame', 'suppressExcelExport', 'suppressCsvExport', 'treeData', 'masterDetail',
  9728. 'suppressMultiRangeSelection', 'enterMovesDownAfterEdit', 'enterMovesDown', 'suppressPropertyNamesCheck', 'rowMultiSelectWithClick',
  9729. 'contractColumnSelection', 'suppressEnterpriseResetOnNewColumns', 'enableOldSetFilterModel', 'suppressRowHoverHighlight', 'gridAutoHeight',
  9730. 'suppressRowTransform', 'suppressClipboardPaste', 'suppressLastEmptyLineOnPaste', 'serverSideSortingAlwaysResets', 'reactNext',
  9731. 'suppressSetColumnStateEvents', 'enableCharts', 'deltaColumnMode', 'suppressMaintainUnsortedOrder', 'enableCellTextSelection',
  9732. 'suppressBrowserResizeObserver', 'suppressMaxRenderedRowRestriction', 'excludeChildrenWhenTreeDataFiltering', 'tooltipMouseTrack',
  9733. 'keepDetailRows', 'paginateChildRows', 'preventDefaultOnContextMenu', 'undoRedoCellEditing', 'allowDragFromColumnsToolPanel',
  9734. 'immutableData', 'immutableColumns', 'pivotSuppressAutoColumn'
  9735. ];
  9736. /** You do not need to include event callbacks in this list, as they are generated automatically. */
  9737. PropertyKeys.FUNCTION_PROPERTIES = [
  9738. 'localeTextFunc', 'groupRowInnerRenderer', 'groupRowInnerRendererFramework', 'dateComponent', 'dateComponentFramework', 'groupRowRenderer',
  9739. 'groupRowRendererFramework', 'isExternalFilterPresent', 'getRowHeight', 'doesExternalFilterPass', 'getRowClass', 'getRowStyle',
  9740. 'getRowClassRules', 'traverseNode', 'getContextMenuItems', 'getMainMenuItems', 'processRowPostCreate', 'processCellForClipboard',
  9741. 'getNodeChildDetails', 'groupRowAggNodes', 'getRowNodeId', 'isFullWidthCell', 'fullWidthCellRenderer', 'fullWidthCellRendererFramework',
  9742. 'doesDataFlower', 'processSecondaryColDef', 'processSecondaryColGroupDef', 'getBusinessKeyForNode', 'sendToClipboard', 'navigateToNextCell',
  9743. 'tabToNextCell', 'getDetailRowData', 'processCellFromClipboard', 'getDocument', 'postProcessPopup', 'getChildCount', 'getDataPath',
  9744. 'loadingCellRenderer', 'loadingCellRendererFramework', 'loadingOverlayComponent', 'loadingOverlayComponentFramework', 'noRowsOverlayComponent',
  9745. 'noRowsOverlayComponentFramework', 'detailCellRenderer', 'detailCellRendererFramework', 'defaultGroupSortComparator', 'isRowMaster',
  9746. 'isRowSelectable', 'postSort', 'processHeaderForClipboard', 'paginationNumberFormatter', 'processDataFromClipboard', 'getServerSideGroupKey',
  9747. 'isServerSideGroup', 'suppressKeyboardEvent', 'createChartContainer', 'processChartOptions', 'getChartToolbarItems', 'fillOperation'
  9748. ];
  9749. PropertyKeys.ALL_PROPERTIES = __spreadArrays(PropertyKeys.ARRAY_PROPERTIES, PropertyKeys.OBJECT_PROPERTIES, PropertyKeys.STRING_PROPERTIES, PropertyKeys.NUMBER_PROPERTIES, PropertyKeys.FUNCTION_PROPERTIES, PropertyKeys.BOOLEAN_PROPERTIES);
  9750. /**
  9751. * Used when performing property checks. This avoids noise caused when using frameworks, which can add their own
  9752. * framework-specific properties to colDefs, gridOptions etc.
  9753. */
  9754. PropertyKeys.FRAMEWORK_PROPERTIES = [
  9755. '__ob__', '__metadata__', 'mappedColumnProperties', 'hasChildColumns', 'toColDef', 'createColDefFromGridColumn'
  9756. ];
  9757. return PropertyKeys;
  9758. }());
  9759. /***/ }),
  9760. /* 50 */
  9761. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  9762. "use strict";
  9763. __webpack_require__.r(__webpack_exports__);
  9764. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridOptionsWrapper", function() { return GridOptionsWrapper; });
  9765. /* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36);
  9766. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(25);
  9767. /* harmony import */ var _components_componentUtil__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(48);
  9768. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(37);
  9769. /* harmony import */ var _propertyKeys__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(49);
  9770. /* harmony import */ var _components_colDefUtil__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(51);
  9771. /* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(44);
  9772. /* harmony import */ var _entities_sideBar__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(52);
  9773. /* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(38);
  9774. /* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(39);
  9775. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(7);
  9776. /**
  9777. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  9778. * @version v23.2.1
  9779. * @link http://www.ag-grid.com/
  9780. * @license MIT
  9781. */
  9782. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  9783. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  9784. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  9785. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  9786. return c > 3 && r && Object.defineProperty(target, key, r), r;
  9787. };
  9788. var __param = (undefined && undefined.__param) || function (paramIndex, decorator) {
  9789. return function (target, key) { decorator(target, key, paramIndex); }
  9790. };
  9791. var __spreadArrays = (undefined && undefined.__spreadArrays) || function () {
  9792. for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;
  9793. for (var r = Array(s), k = 0, i = 0; i < il; i++)
  9794. for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
  9795. r[k] = a[j];
  9796. return r;
  9797. };
  9798. var DEFAULT_ROW_HEIGHT = 25;
  9799. var DEFAULT_DETAIL_ROW_HEIGHT = 300;
  9800. var DEFAULT_VIEWPORT_ROW_MODEL_PAGE_SIZE = 5;
  9801. var DEFAULT_VIEWPORT_ROW_MODEL_BUFFER_SIZE = 5;
  9802. var DEFAULT_KEEP_DETAIL_ROW_COUNT = 10;
  9803. function isTrue(value) {
  9804. return value === true || value === 'true';
  9805. }
  9806. function zeroOrGreater(value, defaultValue) {
  9807. if (value >= 0) {
  9808. return value;
  9809. }
  9810. // zero gets returned if number is missing or the wrong type
  9811. return defaultValue;
  9812. }
  9813. function oneOrGreater(value, defaultValue) {
  9814. if (value > 0) {
  9815. return value;
  9816. }
  9817. // zero gets returned if number is missing or the wrong type
  9818. return defaultValue;
  9819. }
  9820. var GridOptionsWrapper = /** @class */ (function () {
  9821. function GridOptionsWrapper() {
  9822. this.propertyEventService = new _eventService__WEBPACK_IMPORTED_MODULE_0__["EventService"]();
  9823. this.domDataKey = '__AG_' + Math.random().toString();
  9824. this.layoutElements = [];
  9825. }
  9826. GridOptionsWrapper_1 = GridOptionsWrapper;
  9827. GridOptionsWrapper.prototype.agWire = function (gridApi, columnApi) {
  9828. this.gridOptions.api = gridApi;
  9829. this.gridOptions.columnApi = columnApi;
  9830. this.checkForDeprecated();
  9831. this.checkForViolations();
  9832. };
  9833. GridOptionsWrapper.prototype.destroy = function () {
  9834. // need to remove these, as we don't own the lifecycle of the gridOptions, we need to
  9835. // remove the references in case the user keeps the grid options, we want the rest
  9836. // of the grid to be picked up by the garbage collector
  9837. this.gridOptions.api = null;
  9838. this.gridOptions.columnApi = null;
  9839. this.removeEventListener(GridOptionsWrapper_1.PROP_DOM_LAYOUT, this.updateLayoutClassesListener);
  9840. };
  9841. GridOptionsWrapper.prototype.init = function () {
  9842. var _this = this;
  9843. if (!(this.gridOptions.suppressPropertyNamesCheck === true)) {
  9844. this.checkGridOptionsProperties();
  9845. this.checkColumnDefProperties();
  9846. }
  9847. var async = this.useAsyncEvents();
  9848. this.eventService.addGlobalListener(this.globalEventHandler.bind(this), async);
  9849. if (this.isGroupSelectsChildren() && this.isSuppressParentsInRowNodes()) {
  9850. console.warn("ag-Grid: 'groupSelectsChildren' does not work with 'suppressParentsInRowNodes', this selection method needs the part in rowNode to work");
  9851. }
  9852. if (this.isGroupSelectsChildren()) {
  9853. if (!this.isRowSelectionMulti()) {
  9854. console.warn("ag-Grid: rowSelection must be 'multiple' for groupSelectsChildren to make sense");
  9855. }
  9856. if (this.isRowModelServerSide()) {
  9857. console.warn('ag-Grid: group selects children is NOT support for Server Side Row Model. ' +
  9858. 'This is because the rows are lazy loaded, so selecting a group is not possible as' +
  9859. 'the grid has no way of knowing what the children are.');
  9860. }
  9861. }
  9862. if (this.isGroupRemoveSingleChildren() && this.isGroupHideOpenParents()) {
  9863. console.warn("ag-Grid: groupRemoveSingleChildren and groupHideOpenParents do not work with each other, you need to pick one. And don't ask us how to us these together on our support forum either you will get the same answer!");
  9864. }
  9865. if (this.isRowModelServerSide()) {
  9866. var msg = function (prop) { return "ag-Grid: '" + prop + "' is not supported on the Server-Side Row Model"; };
  9867. if (_utils__WEBPACK_IMPORTED_MODULE_10__["_"].exists(this.gridOptions.groupDefaultExpanded)) {
  9868. console.warn(msg('groupDefaultExpanded'));
  9869. }
  9870. if (_utils__WEBPACK_IMPORTED_MODULE_10__["_"].exists(this.gridOptions.groupDefaultExpanded)) {
  9871. console.warn(msg('groupIncludeFooter'));
  9872. }
  9873. if (_utils__WEBPACK_IMPORTED_MODULE_10__["_"].exists(this.gridOptions.groupDefaultExpanded)) {
  9874. console.warn(msg('groupIncludeTotalFooter'));
  9875. }
  9876. }
  9877. if (this.isEnableRangeSelection()) {
  9878. _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_9__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__["ModuleNames"].RangeSelectionModule, 'enableRangeSelection');
  9879. }
  9880. if (!this.isEnableRangeSelection() && (this.isEnableRangeHandle() || this.isEnableFillHandle())) {
  9881. console.warn("ag-Grid: 'enableRangeHandle' and 'enableFillHandle' will not work unless 'enableRangeSelection' is set to true");
  9882. }
  9883. var warnOfDeprecaredIcon = function (name) {
  9884. if (_this.gridOptions.icons && _this.gridOptions.icons[name]) {
  9885. console.warn("gridOptions.icons." + name + " is no longer supported. For information on how to style checkboxes and radio buttons, see https://www.ag-grid.com/javascript-grid-icons/");
  9886. }
  9887. };
  9888. warnOfDeprecaredIcon('radioButtonOff');
  9889. warnOfDeprecaredIcon('radioButtonOn');
  9890. warnOfDeprecaredIcon('checkboxChecked');
  9891. warnOfDeprecaredIcon('checkboxUnchecked');
  9892. warnOfDeprecaredIcon('checkboxIndeterminate');
  9893. this.updateLayoutClassesListener = this.updateLayoutClasses.bind(this);
  9894. this.addEventListener(GridOptionsWrapper_1.PROP_DOM_LAYOUT, this.updateLayoutClassesListener);
  9895. };
  9896. GridOptionsWrapper.prototype.checkColumnDefProperties = function () {
  9897. var _this = this;
  9898. if (this.gridOptions.columnDefs == null) {
  9899. return;
  9900. }
  9901. this.gridOptions.columnDefs.forEach(function (colDef) {
  9902. var userProperties = Object.getOwnPropertyNames(colDef);
  9903. var validProperties = __spreadArrays(_components_colDefUtil__WEBPACK_IMPORTED_MODULE_5__["ColDefUtil"].ALL_PROPERTIES, _components_colDefUtil__WEBPACK_IMPORTED_MODULE_5__["ColDefUtil"].FRAMEWORK_PROPERTIES);
  9904. _this.checkProperties(userProperties, validProperties, validProperties, 'colDef', 'https://www.ag-grid.com/javascript-grid-column-properties/');
  9905. });
  9906. };
  9907. GridOptionsWrapper.prototype.checkGridOptionsProperties = function () {
  9908. var userProperties = Object.getOwnPropertyNames(this.gridOptions);
  9909. var validProperties = __spreadArrays(_propertyKeys__WEBPACK_IMPORTED_MODULE_4__["PropertyKeys"].ALL_PROPERTIES, _propertyKeys__WEBPACK_IMPORTED_MODULE_4__["PropertyKeys"].FRAMEWORK_PROPERTIES, _utils__WEBPACK_IMPORTED_MODULE_10__["_"].values(_eventKeys__WEBPACK_IMPORTED_MODULE_6__["Events"]).map(function (event) { return _components_componentUtil__WEBPACK_IMPORTED_MODULE_2__["ComponentUtil"].getCallbackForEvent(event); }));
  9910. var validPropertiesAndExceptions = __spreadArrays(validProperties, ['api', 'columnApi']);
  9911. this.checkProperties(userProperties, validPropertiesAndExceptions, validProperties, 'gridOptions', 'https://www.ag-grid.com/javascript-grid-properties/');
  9912. };
  9913. GridOptionsWrapper.prototype.checkProperties = function (userProperties, validPropertiesAndExceptions, validProperties, containerName, docsUrl) {
  9914. var invalidProperties = _utils__WEBPACK_IMPORTED_MODULE_10__["_"].fuzzyCheckStrings(userProperties, validPropertiesAndExceptions, validProperties);
  9915. _utils__WEBPACK_IMPORTED_MODULE_10__["_"].iterateObject(invalidProperties, function (key, value) {
  9916. console.warn("ag-grid: invalid " + containerName + " property '" + key + "' did you mean any of these: " + value.slice(0, 8).join(", "));
  9917. });
  9918. if (Object.keys(invalidProperties).length > 0) {
  9919. console.warn("ag-grid: to see all the valid " + containerName + " properties please check: " + docsUrl);
  9920. }
  9921. };
  9922. // returns the dom data, or undefined if not found
  9923. GridOptionsWrapper.prototype.getDomData = function (element, key) {
  9924. var domData = element[this.domDataKey];
  9925. return domData ? domData[key] : undefined;
  9926. };
  9927. GridOptionsWrapper.prototype.setDomData = function (element, key, value) {
  9928. var domData = element[this.domDataKey];
  9929. if (_utils__WEBPACK_IMPORTED_MODULE_10__["_"].missing(domData)) {
  9930. domData = {};
  9931. element[this.domDataKey] = domData;
  9932. }
  9933. domData[key] = value;
  9934. };
  9935. GridOptionsWrapper.prototype.isRowSelection = function () {
  9936. return this.gridOptions.rowSelection === 'single' || this.gridOptions.rowSelection === 'multiple';
  9937. };
  9938. GridOptionsWrapper.prototype.isRowDeselection = function () {
  9939. return isTrue(this.gridOptions.rowDeselection);
  9940. };
  9941. GridOptionsWrapper.prototype.isRowSelectionMulti = function () {
  9942. return this.gridOptions.rowSelection === 'multiple';
  9943. };
  9944. GridOptionsWrapper.prototype.isRowMultiSelectWithClick = function () {
  9945. return isTrue(this.gridOptions.rowMultiSelectWithClick);
  9946. };
  9947. GridOptionsWrapper.prototype.getContext = function () {
  9948. return this.gridOptions.context;
  9949. };
  9950. GridOptionsWrapper.prototype.isPivotMode = function () {
  9951. return isTrue(this.gridOptions.pivotMode);
  9952. };
  9953. GridOptionsWrapper.prototype.isPivotTotals = function () {
  9954. return isTrue(this.gridOptions.pivotTotals);
  9955. };
  9956. GridOptionsWrapper.prototype.getPivotColumnGroupTotals = function () {
  9957. return this.gridOptions.pivotColumnGroupTotals;
  9958. };
  9959. GridOptionsWrapper.prototype.getPivotRowTotals = function () {
  9960. return this.gridOptions.pivotRowTotals;
  9961. };
  9962. GridOptionsWrapper.prototype.isRowModelInfinite = function () {
  9963. return this.gridOptions.rowModelType === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_INFINITE;
  9964. };
  9965. GridOptionsWrapper.prototype.isRowModelViewport = function () {
  9966. return this.gridOptions.rowModelType === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_VIEWPORT;
  9967. };
  9968. GridOptionsWrapper.prototype.isRowModelServerSide = function () {
  9969. return this.gridOptions.rowModelType === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE;
  9970. };
  9971. GridOptionsWrapper.prototype.isRowModelDefault = function () {
  9972. return (_utils__WEBPACK_IMPORTED_MODULE_10__["_"].missing(this.gridOptions.rowModelType) ||
  9973. this.gridOptions.rowModelType === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE ||
  9974. this.gridOptions.rowModelType === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DEPRECATED_ROW_MODEL_TYPE_NORMAL);
  9975. };
  9976. GridOptionsWrapper.prototype.isFullRowEdit = function () {
  9977. return this.gridOptions.editType === 'fullRow';
  9978. };
  9979. GridOptionsWrapper.prototype.isSuppressFocusAfterRefresh = function () {
  9980. return isTrue(this.gridOptions.suppressFocusAfterRefresh);
  9981. };
  9982. GridOptionsWrapper.prototype.isSuppressBrowserResizeObserver = function () {
  9983. return isTrue(this.gridOptions.suppressBrowserResizeObserver);
  9984. };
  9985. GridOptionsWrapper.prototype.isSuppressMaintainUnsortedOrder = function () {
  9986. return isTrue(this.gridOptions.suppressMaintainUnsortedOrder);
  9987. };
  9988. GridOptionsWrapper.prototype.isSuppressClearOnFillReduction = function () {
  9989. return isTrue(this.gridOptions.suppressClearOnFillReduction);
  9990. };
  9991. GridOptionsWrapper.prototype.isShowToolPanel = function () {
  9992. return isTrue(this.gridOptions.sideBar && Array.isArray(this.getSideBar().toolPanels));
  9993. };
  9994. GridOptionsWrapper.prototype.getSideBar = function () {
  9995. return this.gridOptions.sideBar;
  9996. };
  9997. GridOptionsWrapper.prototype.isSuppressTouch = function () {
  9998. return isTrue(this.gridOptions.suppressTouch);
  9999. };
  10000. GridOptionsWrapper.prototype.isSuppressRowTransform = function () {
  10001. return isTrue(this.gridOptions.suppressRowTransform);
  10002. };
  10003. GridOptionsWrapper.prototype.isSuppressSetColumnStateEvents = function () {
  10004. return isTrue(this.gridOptions.suppressSetColumnStateEvents);
  10005. };
  10006. GridOptionsWrapper.prototype.isAllowDragFromColumnsToolPanel = function () {
  10007. return isTrue(this.gridOptions.allowDragFromColumnsToolPanel);
  10008. };
  10009. GridOptionsWrapper.prototype.useAsyncEvents = function () {
  10010. return !isTrue(this.gridOptions.suppressAsyncEvents);
  10011. };
  10012. GridOptionsWrapper.prototype.isEnableCellChangeFlash = function () {
  10013. return isTrue(this.gridOptions.enableCellChangeFlash);
  10014. };
  10015. GridOptionsWrapper.prototype.getCellFlashDelay = function () {
  10016. return this.gridOptions.cellFlashDelay || 500;
  10017. };
  10018. GridOptionsWrapper.prototype.getCellFadeDelay = function () {
  10019. return this.gridOptions.cellFadeDelay || 1000;
  10020. };
  10021. GridOptionsWrapper.prototype.isGroupSelectsChildren = function () {
  10022. var result = isTrue(this.gridOptions.groupSelectsChildren);
  10023. if (result && this.isTreeData()) {
  10024. console.warn('ag-Grid: groupSelectsChildren does not work with tree data');
  10025. return false;
  10026. }
  10027. return result;
  10028. };
  10029. GridOptionsWrapper.prototype.isSuppressRowHoverHighlight = function () {
  10030. return isTrue(this.gridOptions.suppressRowHoverHighlight);
  10031. };
  10032. GridOptionsWrapper.prototype.isGroupSelectsFiltered = function () {
  10033. return isTrue(this.gridOptions.groupSelectsFiltered);
  10034. };
  10035. GridOptionsWrapper.prototype.isGroupHideOpenParents = function () {
  10036. return isTrue(this.gridOptions.groupHideOpenParents);
  10037. };
  10038. // if we are doing hideOpenParents, then we always have groupMultiAutoColumn, otherwise hideOpenParents would not work
  10039. GridOptionsWrapper.prototype.isGroupMultiAutoColumn = function () {
  10040. return isTrue(this.gridOptions.groupMultiAutoColumn) || isTrue(this.gridOptions.groupHideOpenParents);
  10041. };
  10042. GridOptionsWrapper.prototype.isGroupRemoveSingleChildren = function () {
  10043. return isTrue(this.gridOptions.groupRemoveSingleChildren);
  10044. };
  10045. GridOptionsWrapper.prototype.isGroupRemoveLowestSingleChildren = function () {
  10046. return isTrue(this.gridOptions.groupRemoveLowestSingleChildren);
  10047. };
  10048. GridOptionsWrapper.prototype.isGroupIncludeFooter = function () {
  10049. return isTrue(this.gridOptions.groupIncludeFooter);
  10050. };
  10051. GridOptionsWrapper.prototype.isGroupIncludeTotalFooter = function () {
  10052. return isTrue(this.gridOptions.groupIncludeTotalFooter);
  10053. };
  10054. GridOptionsWrapper.prototype.isGroupSuppressBlankHeader = function () {
  10055. return isTrue(this.gridOptions.groupSuppressBlankHeader);
  10056. };
  10057. GridOptionsWrapper.prototype.isSuppressRowClickSelection = function () {
  10058. return isTrue(this.gridOptions.suppressRowClickSelection);
  10059. };
  10060. GridOptionsWrapper.prototype.isSuppressCellSelection = function () {
  10061. return isTrue(this.gridOptions.suppressCellSelection);
  10062. };
  10063. GridOptionsWrapper.prototype.isSuppressMultiSort = function () {
  10064. return isTrue(this.gridOptions.suppressMultiSort);
  10065. };
  10066. GridOptionsWrapper.prototype.isMultiSortKeyCtrl = function () {
  10067. return this.gridOptions.multiSortKey === 'ctrl';
  10068. };
  10069. GridOptionsWrapper.prototype.isGroupSuppressAutoColumn = function () {
  10070. return isTrue(this.gridOptions.groupSuppressAutoColumn);
  10071. };
  10072. GridOptionsWrapper.prototype.isPivotSuppressAutoColumn = function () {
  10073. return isTrue(this.gridOptions.pivotSuppressAutoColumn);
  10074. };
  10075. GridOptionsWrapper.prototype.isSuppressDragLeaveHidesColumns = function () {
  10076. return isTrue(this.gridOptions.suppressDragLeaveHidesColumns);
  10077. };
  10078. GridOptionsWrapper.prototype.isSuppressScrollOnNewData = function () {
  10079. return isTrue(this.gridOptions.suppressScrollOnNewData);
  10080. };
  10081. GridOptionsWrapper.prototype.isRowDragManaged = function () {
  10082. return isTrue(this.gridOptions.rowDragManaged);
  10083. };
  10084. GridOptionsWrapper.prototype.isSuppressRowDrag = function () {
  10085. return isTrue(this.gridOptions.suppressRowDrag);
  10086. };
  10087. GridOptionsWrapper.prototype.isSuppressMoveWhenRowDragging = function () {
  10088. return isTrue(this.gridOptions.suppressMoveWhenRowDragging);
  10089. };
  10090. GridOptionsWrapper.prototype.isEnableMultiRowDragging = function () {
  10091. return isTrue(this.gridOptions.enableMultiRowDragging);
  10092. };
  10093. // returns either 'print', 'autoHeight' or 'normal' (normal is the default)
  10094. GridOptionsWrapper.prototype.getDomLayout = function () {
  10095. var domLayout = this.gridOptions.domLayout || _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_NORMAL;
  10096. var validLayouts = [
  10097. _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_PRINT,
  10098. _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_AUTO_HEIGHT,
  10099. _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_NORMAL
  10100. ];
  10101. if (validLayouts.indexOf(domLayout) === -1) {
  10102. _utils__WEBPACK_IMPORTED_MODULE_10__["_"].doOnce(function () {
  10103. return console.warn("ag-Grid: " + domLayout + " is not valid for DOM Layout, valid values are " + _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_NORMAL + ", " + _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_AUTO_HEIGHT + " and " + _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_PRINT);
  10104. }, 'warn about dom layout values');
  10105. return _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_NORMAL;
  10106. }
  10107. return domLayout;
  10108. };
  10109. GridOptionsWrapper.prototype.isSuppressHorizontalScroll = function () {
  10110. return isTrue(this.gridOptions.suppressHorizontalScroll);
  10111. };
  10112. GridOptionsWrapper.prototype.isSuppressMaxRenderedRowRestriction = function () {
  10113. return isTrue(this.gridOptions.suppressMaxRenderedRowRestriction);
  10114. };
  10115. GridOptionsWrapper.prototype.isExcludeChildrenWhenTreeDataFiltering = function () {
  10116. return isTrue(this.gridOptions.excludeChildrenWhenTreeDataFiltering);
  10117. };
  10118. GridOptionsWrapper.prototype.isAlwaysShowVerticalScroll = function () {
  10119. return isTrue(this.gridOptions.alwaysShowVerticalScroll);
  10120. };
  10121. GridOptionsWrapper.prototype.isSuppressLoadingOverlay = function () {
  10122. return isTrue(this.gridOptions.suppressLoadingOverlay);
  10123. };
  10124. GridOptionsWrapper.prototype.isSuppressNoRowsOverlay = function () {
  10125. return isTrue(this.gridOptions.suppressNoRowsOverlay);
  10126. };
  10127. GridOptionsWrapper.prototype.isSuppressFieldDotNotation = function () {
  10128. return isTrue(this.gridOptions.suppressFieldDotNotation);
  10129. };
  10130. GridOptionsWrapper.prototype.getPinnedTopRowData = function () {
  10131. return this.gridOptions.pinnedTopRowData;
  10132. };
  10133. GridOptionsWrapper.prototype.getPinnedBottomRowData = function () {
  10134. return this.gridOptions.pinnedBottomRowData;
  10135. };
  10136. GridOptionsWrapper.prototype.isFunctionsPassive = function () {
  10137. return isTrue(this.gridOptions.functionsPassive);
  10138. };
  10139. GridOptionsWrapper.prototype.isSuppressTabbing = function () {
  10140. return isTrue(this.gridOptions.suppressTabbing);
  10141. };
  10142. GridOptionsWrapper.prototype.isSuppressChangeDetection = function () {
  10143. return isTrue(this.gridOptions.suppressChangeDetection);
  10144. };
  10145. GridOptionsWrapper.prototype.isSuppressAnimationFrame = function () {
  10146. return isTrue(this.gridOptions.suppressAnimationFrame);
  10147. };
  10148. GridOptionsWrapper.prototype.getQuickFilterText = function () {
  10149. return this.gridOptions.quickFilterText;
  10150. };
  10151. GridOptionsWrapper.prototype.isCacheQuickFilter = function () {
  10152. return isTrue(this.gridOptions.cacheQuickFilter);
  10153. };
  10154. GridOptionsWrapper.prototype.isUnSortIcon = function () {
  10155. return isTrue(this.gridOptions.unSortIcon);
  10156. };
  10157. GridOptionsWrapper.prototype.isSuppressMenuHide = function () {
  10158. return isTrue(this.gridOptions.suppressMenuHide);
  10159. };
  10160. GridOptionsWrapper.prototype.isEnterMovesDownAfterEdit = function () {
  10161. return isTrue(this.gridOptions.enterMovesDownAfterEdit);
  10162. };
  10163. GridOptionsWrapper.prototype.isEnterMovesDown = function () {
  10164. return isTrue(this.gridOptions.enterMovesDown);
  10165. };
  10166. GridOptionsWrapper.prototype.isUndoRedoCellEditing = function () {
  10167. return isTrue(this.gridOptions.undoRedoCellEditing);
  10168. };
  10169. GridOptionsWrapper.prototype.getUndoRedoCellEditingLimit = function () {
  10170. return this.gridOptions.undoRedoCellEditingLimit;
  10171. };
  10172. GridOptionsWrapper.prototype.getRowStyle = function () {
  10173. return this.gridOptions.rowStyle;
  10174. };
  10175. GridOptionsWrapper.prototype.getRowClass = function () {
  10176. return this.gridOptions.rowClass;
  10177. };
  10178. GridOptionsWrapper.prototype.getRowStyleFunc = function () {
  10179. return this.gridOptions.getRowStyle;
  10180. };
  10181. GridOptionsWrapper.prototype.getRowClassFunc = function () {
  10182. return this.gridOptions.getRowClass;
  10183. };
  10184. GridOptionsWrapper.prototype.rowClassRules = function () {
  10185. return this.gridOptions.rowClassRules;
  10186. };
  10187. GridOptionsWrapper.prototype.getCreateChartContainerFunc = function () {
  10188. return this.gridOptions.createChartContainer;
  10189. };
  10190. GridOptionsWrapper.prototype.getPopupParent = function () {
  10191. return this.gridOptions.popupParent;
  10192. };
  10193. GridOptionsWrapper.prototype.getBlockLoadDebounceMillis = function () {
  10194. return this.gridOptions.blockLoadDebounceMillis;
  10195. };
  10196. GridOptionsWrapper.prototype.getPostProcessPopupFunc = function () {
  10197. return this.gridOptions.postProcessPopup;
  10198. };
  10199. GridOptionsWrapper.prototype.getDoesDataFlowerFunc = function () {
  10200. return this.gridOptions.doesDataFlower;
  10201. };
  10202. GridOptionsWrapper.prototype.getPaginationNumberFormatterFunc = function () {
  10203. return this.gridOptions.paginationNumberFormatter;
  10204. };
  10205. GridOptionsWrapper.prototype.getChildCountFunc = function () {
  10206. return this.gridOptions.getChildCount;
  10207. };
  10208. GridOptionsWrapper.prototype.getDefaultGroupSortComparator = function () {
  10209. return this.gridOptions.defaultGroupSortComparator;
  10210. };
  10211. GridOptionsWrapper.prototype.getIsFullWidthCellFunc = function () {
  10212. return this.gridOptions.isFullWidthCell;
  10213. };
  10214. GridOptionsWrapper.prototype.getFullWidthCellRendererParams = function () {
  10215. return this.gridOptions.fullWidthCellRendererParams;
  10216. };
  10217. GridOptionsWrapper.prototype.isEmbedFullWidthRows = function () {
  10218. return isTrue(this.gridOptions.embedFullWidthRows) || isTrue(this.gridOptions.deprecatedEmbedFullWidthRows);
  10219. };
  10220. GridOptionsWrapper.prototype.getSuppressKeyboardEventFunc = function () {
  10221. return this.gridOptions.suppressKeyboardEvent;
  10222. };
  10223. GridOptionsWrapper.prototype.getBusinessKeyForNodeFunc = function () {
  10224. return this.gridOptions.getBusinessKeyForNode;
  10225. };
  10226. GridOptionsWrapper.prototype.getApi = function () {
  10227. return this.gridOptions.api;
  10228. };
  10229. GridOptionsWrapper.prototype.getColumnApi = function () {
  10230. return this.gridOptions.columnApi;
  10231. };
  10232. GridOptionsWrapper.prototype.isImmutableData = function () {
  10233. return isTrue(this.gridOptions.immutableData);
  10234. };
  10235. GridOptionsWrapper.prototype.isImmutableColumns = function () {
  10236. return isTrue(this.gridOptions.immutableColumns);
  10237. };
  10238. GridOptionsWrapper.prototype.isEnsureDomOrder = function () {
  10239. return isTrue(this.gridOptions.ensureDomOrder);
  10240. };
  10241. GridOptionsWrapper.prototype.isEnableCharts = function () {
  10242. if (isTrue(this.gridOptions.enableCharts)) {
  10243. return _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_9__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__["ModuleNames"].GridChartsModule, 'enableCharts');
  10244. }
  10245. return false;
  10246. };
  10247. GridOptionsWrapper.prototype.getColResizeDefault = function () {
  10248. return this.gridOptions.colResizeDefault;
  10249. };
  10250. GridOptionsWrapper.prototype.isSingleClickEdit = function () {
  10251. return isTrue(this.gridOptions.singleClickEdit);
  10252. };
  10253. GridOptionsWrapper.prototype.isSuppressClickEdit = function () {
  10254. return isTrue(this.gridOptions.suppressClickEdit);
  10255. };
  10256. GridOptionsWrapper.prototype.isStopEditingWhenGridLosesFocus = function () {
  10257. return isTrue(this.gridOptions.stopEditingWhenGridLosesFocus);
  10258. };
  10259. GridOptionsWrapper.prototype.getGroupDefaultExpanded = function () {
  10260. return this.gridOptions.groupDefaultExpanded;
  10261. };
  10262. GridOptionsWrapper.prototype.getMaxConcurrentDatasourceRequests = function () {
  10263. return this.gridOptions.maxConcurrentDatasourceRequests;
  10264. };
  10265. GridOptionsWrapper.prototype.getMaxBlocksInCache = function () {
  10266. return this.gridOptions.maxBlocksInCache;
  10267. };
  10268. GridOptionsWrapper.prototype.getCacheOverflowSize = function () {
  10269. return this.gridOptions.cacheOverflowSize;
  10270. };
  10271. GridOptionsWrapper.prototype.getPaginationPageSize = function () {
  10272. return this.gridOptions.paginationPageSize;
  10273. };
  10274. GridOptionsWrapper.prototype.isPaginateChildRows = function () {
  10275. // if using groupSuppressRow, means we are not showing parent rows,
  10276. // so we always paginate on the child rows here as there are no parent rows
  10277. var shouldPaginate = this.isGroupSuppressRow() || this.isGroupRemoveSingleChildren() || this.isGroupRemoveLowestSingleChildren();
  10278. if (shouldPaginate) {
  10279. return true;
  10280. }
  10281. return isTrue(this.gridOptions.paginateChildRows);
  10282. };
  10283. GridOptionsWrapper.prototype.getCacheBlockSize = function () {
  10284. return this.gridOptions.cacheBlockSize;
  10285. };
  10286. GridOptionsWrapper.prototype.getInfiniteInitialRowCount = function () {
  10287. return this.gridOptions.infiniteInitialRowCount;
  10288. };
  10289. GridOptionsWrapper.prototype.isPurgeClosedRowNodes = function () {
  10290. return isTrue(this.gridOptions.purgeClosedRowNodes);
  10291. };
  10292. GridOptionsWrapper.prototype.isSuppressPaginationPanel = function () {
  10293. return isTrue(this.gridOptions.suppressPaginationPanel);
  10294. };
  10295. GridOptionsWrapper.prototype.getRowData = function () {
  10296. return this.gridOptions.rowData;
  10297. };
  10298. // this property is different - we never allow groupUseEntireRow if in pivot mode,
  10299. // as otherwise we don't see the pivot values.
  10300. GridOptionsWrapper.prototype.isGroupUseEntireRow = function (pivotMode) {
  10301. return pivotMode ? false : isTrue(this.gridOptions.groupUseEntireRow);
  10302. };
  10303. GridOptionsWrapper.prototype.isEnableRtl = function () {
  10304. return isTrue(this.gridOptions.enableRtl);
  10305. };
  10306. GridOptionsWrapper.prototype.getAutoGroupColumnDef = function () {
  10307. return this.gridOptions.autoGroupColumnDef;
  10308. };
  10309. GridOptionsWrapper.prototype.isGroupSuppressRow = function () {
  10310. return isTrue(this.gridOptions.groupSuppressRow);
  10311. };
  10312. GridOptionsWrapper.prototype.getRowGroupPanelShow = function () {
  10313. return this.gridOptions.rowGroupPanelShow;
  10314. };
  10315. GridOptionsWrapper.prototype.getPivotPanelShow = function () {
  10316. return this.gridOptions.pivotPanelShow;
  10317. };
  10318. GridOptionsWrapper.prototype.isAngularCompileRows = function () {
  10319. return isTrue(this.gridOptions.angularCompileRows);
  10320. };
  10321. GridOptionsWrapper.prototype.isAngularCompileFilters = function () {
  10322. return isTrue(this.gridOptions.angularCompileFilters);
  10323. };
  10324. GridOptionsWrapper.prototype.isAngularCompileHeaders = function () {
  10325. return isTrue(this.gridOptions.angularCompileHeaders);
  10326. };
  10327. GridOptionsWrapper.prototype.isDebug = function () {
  10328. return isTrue(this.gridOptions.debug);
  10329. };
  10330. GridOptionsWrapper.prototype.getColumnDefs = function () {
  10331. return this.gridOptions.columnDefs;
  10332. };
  10333. GridOptionsWrapper.prototype.getColumnTypes = function () {
  10334. return this.gridOptions.columnTypes;
  10335. };
  10336. GridOptionsWrapper.prototype.getDatasource = function () {
  10337. return this.gridOptions.datasource;
  10338. };
  10339. GridOptionsWrapper.prototype.getViewportDatasource = function () {
  10340. return this.gridOptions.viewportDatasource;
  10341. };
  10342. GridOptionsWrapper.prototype.getServerSideDatasource = function () {
  10343. return this.gridOptions.serverSideDatasource;
  10344. };
  10345. GridOptionsWrapper.prototype.isAccentedSort = function () {
  10346. return isTrue(this.gridOptions.accentedSort);
  10347. };
  10348. GridOptionsWrapper.prototype.isEnableBrowserTooltips = function () {
  10349. return isTrue(this.gridOptions.enableBrowserTooltips);
  10350. };
  10351. GridOptionsWrapper.prototype.isEnableCellExpressions = function () {
  10352. return isTrue(this.gridOptions.enableCellExpressions);
  10353. };
  10354. GridOptionsWrapper.prototype.isEnableGroupEdit = function () {
  10355. return isTrue(this.gridOptions.enableGroupEdit);
  10356. };
  10357. GridOptionsWrapper.prototype.isSuppressMiddleClickScrolls = function () {
  10358. return isTrue(this.gridOptions.suppressMiddleClickScrolls);
  10359. };
  10360. GridOptionsWrapper.prototype.isPreventDefaultOnContextMenu = function () {
  10361. return isTrue(this.gridOptions.preventDefaultOnContextMenu);
  10362. };
  10363. GridOptionsWrapper.prototype.isSuppressPreventDefaultOnMouseWheel = function () {
  10364. return isTrue(this.gridOptions.suppressPreventDefaultOnMouseWheel);
  10365. };
  10366. GridOptionsWrapper.prototype.isSuppressColumnVirtualisation = function () {
  10367. return isTrue(this.gridOptions.suppressColumnVirtualisation);
  10368. };
  10369. GridOptionsWrapper.prototype.isSuppressContextMenu = function () {
  10370. return isTrue(this.gridOptions.suppressContextMenu);
  10371. };
  10372. GridOptionsWrapper.prototype.isAllowContextMenuWithControlKey = function () {
  10373. return isTrue(this.gridOptions.allowContextMenuWithControlKey);
  10374. };
  10375. GridOptionsWrapper.prototype.isSuppressCopyRowsToClipboard = function () {
  10376. return isTrue(this.gridOptions.suppressCopyRowsToClipboard);
  10377. };
  10378. GridOptionsWrapper.prototype.isCopyHeadersToClipboard = function () {
  10379. return isTrue(this.gridOptions.copyHeadersToClipboard);
  10380. };
  10381. GridOptionsWrapper.prototype.isSuppressClipboardPaste = function () {
  10382. return isTrue(this.gridOptions.suppressClipboardPaste);
  10383. };
  10384. GridOptionsWrapper.prototype.isSuppressLastEmptyLineOnPaste = function () {
  10385. return isTrue(this.gridOptions.suppressLastEmptyLineOnPaste);
  10386. };
  10387. GridOptionsWrapper.prototype.isPagination = function () {
  10388. return isTrue(this.gridOptions.pagination);
  10389. };
  10390. GridOptionsWrapper.prototype.isSuppressEnterpriseResetOnNewColumns = function () {
  10391. return isTrue(this.gridOptions.suppressEnterpriseResetOnNewColumns);
  10392. };
  10393. GridOptionsWrapper.prototype.getProcessDataFromClipboardFunc = function () {
  10394. return this.gridOptions.processDataFromClipboard;
  10395. };
  10396. GridOptionsWrapper.prototype.getAsyncTransactionWaitMillis = function () {
  10397. return _utils__WEBPACK_IMPORTED_MODULE_10__["_"].exists(this.gridOptions.asyncTransactionWaitMillis) ? this.gridOptions.asyncTransactionWaitMillis : _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].BATCH_WAIT_MILLIS;
  10398. };
  10399. GridOptionsWrapper.prototype.isSuppressMovableColumns = function () {
  10400. return isTrue(this.gridOptions.suppressMovableColumns);
  10401. };
  10402. GridOptionsWrapper.prototype.isAnimateRows = function () {
  10403. // never allow animating if enforcing the row order
  10404. if (this.isEnsureDomOrder()) {
  10405. return false;
  10406. }
  10407. return isTrue(this.gridOptions.animateRows);
  10408. };
  10409. GridOptionsWrapper.prototype.isSuppressColumnMoveAnimation = function () {
  10410. return isTrue(this.gridOptions.suppressColumnMoveAnimation);
  10411. };
  10412. GridOptionsWrapper.prototype.isSuppressAggFuncInHeader = function () {
  10413. return isTrue(this.gridOptions.suppressAggFuncInHeader);
  10414. };
  10415. GridOptionsWrapper.prototype.isSuppressAggAtRootLevel = function () {
  10416. return isTrue(this.gridOptions.suppressAggAtRootLevel);
  10417. };
  10418. GridOptionsWrapper.prototype.isEnableRangeSelection = function () {
  10419. return _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_9__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__["ModuleNames"].RangeSelectionModule) && isTrue(this.gridOptions.enableRangeSelection);
  10420. };
  10421. GridOptionsWrapper.prototype.isEnableRangeHandle = function () {
  10422. return isTrue(this.gridOptions.enableRangeHandle);
  10423. };
  10424. GridOptionsWrapper.prototype.isEnableFillHandle = function () {
  10425. return isTrue(this.gridOptions.enableFillHandle);
  10426. };
  10427. GridOptionsWrapper.prototype.getFillOperation = function () {
  10428. return this.gridOptions.fillOperation;
  10429. };
  10430. GridOptionsWrapper.prototype.isSuppressMultiRangeSelection = function () {
  10431. return isTrue(this.gridOptions.suppressMultiRangeSelection);
  10432. };
  10433. GridOptionsWrapper.prototype.isPaginationAutoPageSize = function () {
  10434. return isTrue(this.gridOptions.paginationAutoPageSize);
  10435. };
  10436. GridOptionsWrapper.prototype.isRememberGroupStateWhenNewData = function () {
  10437. return isTrue(this.gridOptions.rememberGroupStateWhenNewData);
  10438. };
  10439. GridOptionsWrapper.prototype.getIcons = function () {
  10440. return this.gridOptions.icons;
  10441. };
  10442. GridOptionsWrapper.prototype.getAggFuncs = function () {
  10443. return this.gridOptions.aggFuncs;
  10444. };
  10445. GridOptionsWrapper.prototype.getSortingOrder = function () {
  10446. return this.gridOptions.sortingOrder;
  10447. };
  10448. GridOptionsWrapper.prototype.getAlignedGrids = function () {
  10449. return this.gridOptions.alignedGrids;
  10450. };
  10451. GridOptionsWrapper.prototype.isMasterDetail = function () {
  10452. var masterDetail = isTrue(this.gridOptions.masterDetail);
  10453. if (masterDetail) {
  10454. return _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_9__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__["ModuleNames"].MasterDetailModule, 'masterDetail');
  10455. }
  10456. else {
  10457. return false;
  10458. }
  10459. };
  10460. GridOptionsWrapper.prototype.isKeepDetailRows = function () {
  10461. return isTrue(this.gridOptions.keepDetailRows);
  10462. };
  10463. GridOptionsWrapper.prototype.getKeepDetailRowsCount = function () {
  10464. if (this.gridOptions.keepDetailRowsCount > 0) {
  10465. return this.gridOptions.keepDetailRowsCount;
  10466. }
  10467. return DEFAULT_KEEP_DETAIL_ROW_COUNT;
  10468. };
  10469. GridOptionsWrapper.prototype.getIsRowMasterFunc = function () {
  10470. return this.gridOptions.isRowMaster;
  10471. };
  10472. GridOptionsWrapper.prototype.getIsRowSelectableFunc = function () {
  10473. return this.gridOptions.isRowSelectable;
  10474. };
  10475. GridOptionsWrapper.prototype.getGroupRowRendererParams = function () {
  10476. return this.gridOptions.groupRowRendererParams;
  10477. };
  10478. GridOptionsWrapper.prototype.getOverlayLoadingTemplate = function () {
  10479. return this.gridOptions.overlayLoadingTemplate;
  10480. };
  10481. GridOptionsWrapper.prototype.getOverlayNoRowsTemplate = function () {
  10482. return this.gridOptions.overlayNoRowsTemplate;
  10483. };
  10484. GridOptionsWrapper.prototype.isSuppressAutoSize = function () {
  10485. return isTrue(this.gridOptions.suppressAutoSize);
  10486. };
  10487. GridOptionsWrapper.prototype.isEnableCellTextSelection = function () {
  10488. return isTrue(this.gridOptions.enableCellTextSelection);
  10489. };
  10490. GridOptionsWrapper.prototype.isSuppressParentsInRowNodes = function () {
  10491. return isTrue(this.gridOptions.suppressParentsInRowNodes);
  10492. };
  10493. GridOptionsWrapper.prototype.isFunctionsReadOnly = function () {
  10494. return isTrue(this.gridOptions.functionsReadOnly);
  10495. };
  10496. GridOptionsWrapper.prototype.isFloatingFilter = function () {
  10497. return this.gridOptions.floatingFilter;
  10498. };
  10499. GridOptionsWrapper.prototype.isEnableCellTextSelect = function () {
  10500. return isTrue(this.gridOptions.enableCellTextSelection);
  10501. };
  10502. GridOptionsWrapper.prototype.isEnableOldSetFilterModel = function () {
  10503. return isTrue(this.gridOptions.enableOldSetFilterModel);
  10504. };
  10505. GridOptionsWrapper.prototype.getDefaultColDef = function () {
  10506. return this.gridOptions.defaultColDef;
  10507. };
  10508. GridOptionsWrapper.prototype.getDefaultColGroupDef = function () {
  10509. return this.gridOptions.defaultColGroupDef;
  10510. };
  10511. GridOptionsWrapper.prototype.getDefaultExportParams = function () {
  10512. return this.gridOptions.defaultExportParams;
  10513. };
  10514. GridOptionsWrapper.prototype.isSuppressCsvExport = function () {
  10515. return isTrue(this.gridOptions.suppressCsvExport);
  10516. };
  10517. GridOptionsWrapper.prototype.isAllowShowChangeAfterFilter = function () {
  10518. return isTrue(this.gridOptions.allowShowChangeAfterFilter);
  10519. };
  10520. GridOptionsWrapper.prototype.isSuppressExcelExport = function () {
  10521. return isTrue(this.gridOptions.suppressExcelExport);
  10522. };
  10523. GridOptionsWrapper.prototype.isSuppressMakeColumnVisibleAfterUnGroup = function () {
  10524. return isTrue(this.gridOptions.suppressMakeColumnVisibleAfterUnGroup);
  10525. };
  10526. GridOptionsWrapper.prototype.getNodeChildDetailsFunc = function () {
  10527. return this.gridOptions.getNodeChildDetails;
  10528. };
  10529. GridOptionsWrapper.prototype.getDataPathFunc = function () {
  10530. return this.gridOptions.getDataPath;
  10531. };
  10532. GridOptionsWrapper.prototype.getIsServerSideGroupFunc = function () {
  10533. return this.gridOptions.isServerSideGroup;
  10534. };
  10535. GridOptionsWrapper.prototype.getServerSideGroupKeyFunc = function () {
  10536. return this.gridOptions.getServerSideGroupKey;
  10537. };
  10538. GridOptionsWrapper.prototype.getGroupRowAggNodesFunc = function () {
  10539. return this.gridOptions.groupRowAggNodes;
  10540. };
  10541. GridOptionsWrapper.prototype.getContextMenuItemsFunc = function () {
  10542. return this.gridOptions.getContextMenuItems;
  10543. };
  10544. GridOptionsWrapper.prototype.getMainMenuItemsFunc = function () {
  10545. return this.gridOptions.getMainMenuItems;
  10546. };
  10547. GridOptionsWrapper.prototype.getChartToolbarItemsFunc = function () {
  10548. return this.gridOptions.getChartToolbarItems;
  10549. };
  10550. GridOptionsWrapper.prototype.getRowNodeIdFunc = function () {
  10551. return this.gridOptions.getRowNodeId;
  10552. };
  10553. GridOptionsWrapper.prototype.getNavigateToNextCellFunc = function () {
  10554. return this.gridOptions.navigateToNextCell;
  10555. };
  10556. GridOptionsWrapper.prototype.getTabToNextCellFunc = function () {
  10557. return this.gridOptions.tabToNextCell;
  10558. };
  10559. GridOptionsWrapper.prototype.isTreeData = function () {
  10560. var usingTreeData = isTrue(this.gridOptions.treeData);
  10561. if (usingTreeData) {
  10562. return _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_9__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__["ModuleNames"].RowGroupingModule, 'Tree Data');
  10563. }
  10564. else {
  10565. return false;
  10566. }
  10567. };
  10568. GridOptionsWrapper.prototype.isValueCache = function () {
  10569. return isTrue(this.gridOptions.valueCache);
  10570. };
  10571. GridOptionsWrapper.prototype.isValueCacheNeverExpires = function () {
  10572. return isTrue(this.gridOptions.valueCacheNeverExpires);
  10573. };
  10574. GridOptionsWrapper.prototype.isDeltaSort = function () {
  10575. return isTrue(this.gridOptions.deltaSort);
  10576. };
  10577. GridOptionsWrapper.prototype.isAggregateOnlyChangedColumns = function () {
  10578. return isTrue(this.gridOptions.aggregateOnlyChangedColumns);
  10579. };
  10580. GridOptionsWrapper.prototype.getProcessSecondaryColDefFunc = function () {
  10581. return this.gridOptions.processSecondaryColDef;
  10582. };
  10583. GridOptionsWrapper.prototype.getProcessSecondaryColGroupDefFunc = function () {
  10584. return this.gridOptions.processSecondaryColGroupDef;
  10585. };
  10586. GridOptionsWrapper.prototype.getSendToClipboardFunc = function () {
  10587. return this.gridOptions.sendToClipboard;
  10588. };
  10589. GridOptionsWrapper.prototype.getProcessRowPostCreateFunc = function () {
  10590. return this.gridOptions.processRowPostCreate;
  10591. };
  10592. GridOptionsWrapper.prototype.getProcessCellForClipboardFunc = function () {
  10593. return this.gridOptions.processCellForClipboard;
  10594. };
  10595. GridOptionsWrapper.prototype.getProcessHeaderForClipboardFunc = function () {
  10596. return this.gridOptions.processHeaderForClipboard;
  10597. };
  10598. GridOptionsWrapper.prototype.getProcessCellFromClipboardFunc = function () {
  10599. return this.gridOptions.processCellFromClipboard;
  10600. };
  10601. GridOptionsWrapper.prototype.getViewportRowModelPageSize = function () {
  10602. return oneOrGreater(this.gridOptions.viewportRowModelPageSize, DEFAULT_VIEWPORT_ROW_MODEL_PAGE_SIZE);
  10603. };
  10604. GridOptionsWrapper.prototype.getViewportRowModelBufferSize = function () {
  10605. return zeroOrGreater(this.gridOptions.viewportRowModelBufferSize, DEFAULT_VIEWPORT_ROW_MODEL_BUFFER_SIZE);
  10606. };
  10607. GridOptionsWrapper.prototype.isServerSideSortingAlwaysResets = function () {
  10608. return isTrue(this.gridOptions.serverSideSortingAlwaysResets);
  10609. };
  10610. GridOptionsWrapper.prototype.getPostSortFunc = function () {
  10611. return this.gridOptions.postSort;
  10612. };
  10613. GridOptionsWrapper.prototype.getProcessChartOptionsFunc = function () {
  10614. return this.gridOptions.processChartOptions;
  10615. };
  10616. GridOptionsWrapper.prototype.getClipboardDeliminator = function () {
  10617. return _utils__WEBPACK_IMPORTED_MODULE_10__["_"].exists(this.gridOptions.clipboardDeliminator) ? this.gridOptions.clipboardDeliminator : '\t';
  10618. };
  10619. GridOptionsWrapper.prototype.setProperty = function (key, value, force) {
  10620. if (force === void 0) { force = false; }
  10621. var gridOptionsNoType = this.gridOptions;
  10622. var previousValue = gridOptionsNoType[key];
  10623. if (force || previousValue !== value) {
  10624. gridOptionsNoType[key] = value;
  10625. var event_1 = {
  10626. type: key,
  10627. currentValue: value,
  10628. previousValue: previousValue
  10629. };
  10630. this.propertyEventService.dispatchEvent(event_1);
  10631. }
  10632. };
  10633. // this logic is repeated in lots of places. any element that had different CSS
  10634. // dependent on the layout needs to have the layout class added ot it.
  10635. GridOptionsWrapper.prototype.addLayoutElement = function (element) {
  10636. this.layoutElements.push(element);
  10637. this.updateLayoutClasses();
  10638. };
  10639. GridOptionsWrapper.prototype.updateLayoutClasses = function () {
  10640. var domLayout = this.getDomLayout();
  10641. var domLayoutAutoHeight = domLayout === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_AUTO_HEIGHT;
  10642. var domLayoutPrint = domLayout === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_PRINT;
  10643. var domLayoutNormal = domLayout === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].DOM_LAYOUT_NORMAL;
  10644. this.layoutElements.forEach(function (e) {
  10645. _utils__WEBPACK_IMPORTED_MODULE_10__["_"].addOrRemoveCssClass(e, 'ag-layout-auto-height', domLayoutAutoHeight);
  10646. _utils__WEBPACK_IMPORTED_MODULE_10__["_"].addOrRemoveCssClass(e, 'ag-layout-normal', domLayoutNormal);
  10647. _utils__WEBPACK_IMPORTED_MODULE_10__["_"].addOrRemoveCssClass(e, 'ag-layout-print', domLayoutPrint);
  10648. });
  10649. };
  10650. GridOptionsWrapper.prototype.addEventListener = function (key, listener) {
  10651. GridOptionsWrapper_1.checkEventDeprecation(key);
  10652. this.propertyEventService.addEventListener(key, listener);
  10653. };
  10654. GridOptionsWrapper.checkEventDeprecation = function (eventName) {
  10655. if (eventName === 'floatingRowDataChanged') {
  10656. console.warn('ag-Grid: floatingRowDataChanged is now called pinnedRowDataChanged');
  10657. }
  10658. };
  10659. GridOptionsWrapper.prototype.removeEventListener = function (key, listener) {
  10660. this.propertyEventService.removeEventListener(key, listener);
  10661. };
  10662. GridOptionsWrapper.prototype.isSkipHeaderOnAutoSize = function () {
  10663. return !!this.gridOptions.skipHeaderOnAutoSize;
  10664. };
  10665. GridOptionsWrapper.prototype.getAutoSizePadding = function () {
  10666. return this.gridOptions.autoSizePadding && this.gridOptions.autoSizePadding > 0 ? this.gridOptions.autoSizePadding : 20;
  10667. };
  10668. // properties
  10669. GridOptionsWrapper.prototype.getHeaderHeight = function () {
  10670. if (typeof this.gridOptions.headerHeight === 'number') {
  10671. return this.gridOptions.headerHeight;
  10672. }
  10673. return this.getFromTheme(25, 'headerHeight');
  10674. };
  10675. GridOptionsWrapper.prototype.getFloatingFiltersHeight = function () {
  10676. if (typeof this.gridOptions.floatingFiltersHeight === 'number') {
  10677. return this.gridOptions.floatingFiltersHeight;
  10678. }
  10679. return this.getFromTheme(25, 'headerHeight');
  10680. };
  10681. GridOptionsWrapper.prototype.getGroupHeaderHeight = function () {
  10682. if (typeof this.gridOptions.groupHeaderHeight === 'number') {
  10683. return this.gridOptions.groupHeaderHeight;
  10684. }
  10685. return this.getHeaderHeight();
  10686. };
  10687. GridOptionsWrapper.prototype.getPivotHeaderHeight = function () {
  10688. if (typeof this.gridOptions.pivotHeaderHeight === 'number') {
  10689. return this.gridOptions.pivotHeaderHeight;
  10690. }
  10691. return this.getHeaderHeight();
  10692. };
  10693. GridOptionsWrapper.prototype.getPivotGroupHeaderHeight = function () {
  10694. if (typeof this.gridOptions.pivotGroupHeaderHeight === 'number') {
  10695. return this.gridOptions.pivotGroupHeaderHeight;
  10696. }
  10697. return this.getGroupHeaderHeight();
  10698. };
  10699. GridOptionsWrapper.prototype.isExternalFilterPresent = function () {
  10700. if (typeof this.gridOptions.isExternalFilterPresent === 'function') {
  10701. return this.gridOptions.isExternalFilterPresent();
  10702. }
  10703. return false;
  10704. };
  10705. GridOptionsWrapper.prototype.doesExternalFilterPass = function (node) {
  10706. if (typeof this.gridOptions.doesExternalFilterPass === 'function') {
  10707. return this.gridOptions.doesExternalFilterPass(node);
  10708. }
  10709. return false;
  10710. };
  10711. GridOptionsWrapper.prototype.getTooltipShowDelay = function () {
  10712. var tooltipShowDelay = this.gridOptions.tooltipShowDelay;
  10713. if (_utils__WEBPACK_IMPORTED_MODULE_10__["_"].exists(tooltipShowDelay)) {
  10714. if (tooltipShowDelay < 0) {
  10715. console.warn('ag-grid: tooltipShowDelay should not be lower than 0');
  10716. }
  10717. return Math.max(200, tooltipShowDelay);
  10718. }
  10719. return null;
  10720. };
  10721. GridOptionsWrapper.prototype.isTooltipMouseTrack = function () {
  10722. return isTrue(this.gridOptions.tooltipMouseTrack);
  10723. };
  10724. GridOptionsWrapper.prototype.getDocument = function () {
  10725. // if user is providing document, we use the users one,
  10726. // otherwise we use the document on the global namespace.
  10727. var result = null;
  10728. if (this.gridOptions.getDocument && _utils__WEBPACK_IMPORTED_MODULE_10__["_"].exists(this.gridOptions.getDocument)) {
  10729. result = this.gridOptions.getDocument();
  10730. }
  10731. if (result && _utils__WEBPACK_IMPORTED_MODULE_10__["_"].exists(result)) {
  10732. return result;
  10733. }
  10734. return document;
  10735. };
  10736. GridOptionsWrapper.prototype.getMinColWidth = function () {
  10737. if (this.gridOptions.minColWidth > GridOptionsWrapper_1.MIN_COL_WIDTH) {
  10738. return this.gridOptions.minColWidth;
  10739. }
  10740. var measuredMin = this.getFromTheme(null, 'headerCellMinWidth');
  10741. return Math.max(measuredMin, GridOptionsWrapper_1.MIN_COL_WIDTH);
  10742. };
  10743. GridOptionsWrapper.prototype.getMaxColWidth = function () {
  10744. if (this.gridOptions.maxColWidth && this.gridOptions.maxColWidth > GridOptionsWrapper_1.MIN_COL_WIDTH) {
  10745. return this.gridOptions.maxColWidth;
  10746. }
  10747. return null;
  10748. };
  10749. GridOptionsWrapper.prototype.getColWidth = function () {
  10750. if (typeof this.gridOptions.colWidth !== 'number' || this.gridOptions.colWidth < GridOptionsWrapper_1.MIN_COL_WIDTH) {
  10751. return 200;
  10752. }
  10753. return this.gridOptions.colWidth;
  10754. };
  10755. GridOptionsWrapper.prototype.getRowBuffer = function () {
  10756. var rowBuffer = this.gridOptions.rowBuffer;
  10757. if (typeof rowBuffer === 'number') {
  10758. if (rowBuffer < 0) {
  10759. _utils__WEBPACK_IMPORTED_MODULE_10__["_"].doOnce(function () { return console.warn("ag-Grid: rowBuffer should not be negative"); }, 'warn rowBuffer negative');
  10760. this.gridOptions.rowBuffer = rowBuffer = 0;
  10761. }
  10762. }
  10763. else {
  10764. rowBuffer = _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_BUFFER_SIZE;
  10765. }
  10766. return rowBuffer;
  10767. };
  10768. GridOptionsWrapper.prototype.getRowBufferInPixels = function () {
  10769. var rowsToBuffer = this.getRowBuffer();
  10770. var defaultRowHeight = this.getRowHeightAsNumber();
  10771. return rowsToBuffer * defaultRowHeight;
  10772. };
  10773. // the user might be using some non-standard scrollbar, eg a scrollbar that has zero
  10774. // width and overlays (like the Safari scrollbar, but presented in Chrome). so we
  10775. // allow the user to provide the scroll width before we work it out.
  10776. GridOptionsWrapper.prototype.getScrollbarWidth = function () {
  10777. if (this.scrollWidth == null) {
  10778. var useGridOptions = typeof this.gridOptions.scrollbarWidth === 'number' && this.gridOptions.scrollbarWidth >= 0;
  10779. this.scrollWidth = useGridOptions ? this.gridOptions.scrollbarWidth : _utils__WEBPACK_IMPORTED_MODULE_10__["_"].getScrollbarWidth();
  10780. }
  10781. return this.scrollWidth;
  10782. };
  10783. GridOptionsWrapper.prototype.checkForDeprecated = function () {
  10784. var _this = this;
  10785. // casting to generic object, so typescript compiles even though
  10786. // we are looking for attributes that don't exist
  10787. var options = this.gridOptions;
  10788. if (options.suppressUnSort) {
  10789. console.warn('ag-grid: as of v1.12.4 suppressUnSort is not used. Please use sortingOrder instead.');
  10790. }
  10791. if (options.suppressDescSort) {
  10792. console.warn('ag-grid: as of v1.12.4 suppressDescSort is not used. Please use sortingOrder instead.');
  10793. }
  10794. if (options.groupAggFields) {
  10795. console.warn('ag-grid: as of v3 groupAggFields is not used. Please add appropriate agg fields to your columns.');
  10796. }
  10797. if (options.groupHidePivotColumns) {
  10798. console.warn('ag-grid: as of v3 groupHidePivotColumns is not used as pivot columns are now called rowGroup columns. Please refer to the documentation');
  10799. }
  10800. if (options.groupKeys) {
  10801. console.warn('ag-grid: as of v3 groupKeys is not used. You need to set rowGroupIndex on the columns to group. Please refer to the documentation');
  10802. }
  10803. if (typeof options.groupDefaultExpanded === 'boolean') {
  10804. console.warn('ag-grid: groupDefaultExpanded can no longer be boolean. for groupDefaultExpanded=true, use groupDefaultExpanded=9999 instead, to expand all the groups');
  10805. }
  10806. if (options.onRowDeselected || options.rowDeselected) {
  10807. console.warn('ag-grid: since version 3.4 event rowDeselected no longer exists, please check the docs');
  10808. }
  10809. if (options.rowsAlreadyGrouped) {
  10810. console.warn('ag-grid: since version 3.4 rowsAlreadyGrouped no longer exists, please use getNodeChildDetails() instead');
  10811. }
  10812. if (options.groupAggFunction) {
  10813. console.warn('ag-grid: since version 4.3.x groupAggFunction is now called groupRowAggNodes');
  10814. }
  10815. if (options.checkboxSelection) {
  10816. console.warn('ag-grid: since version 8.0.x checkboxSelection is not supported as a grid option. ' + 'If you want this on all columns, use defaultColDef instead and set it there');
  10817. }
  10818. if (options.paginationInitialRowCount) {
  10819. console.warn('ag-grid: since version 9.0.x paginationInitialRowCount is now called infiniteInitialRowCount');
  10820. }
  10821. if (options.infinitePageSize) {
  10822. console.warn('ag-grid: since version 9.0.x infinitePageSize is now called cacheBlockSize');
  10823. }
  10824. if (options.infiniteBlockSize) {
  10825. console.warn('ag-grid: since version 10.0.x infiniteBlockSize is now called cacheBlockSize');
  10826. }
  10827. if (options.maxPagesInCache) {
  10828. console.warn('ag-grid: since version 10.0.x maxPagesInCache is now called maxBlocksInCache');
  10829. }
  10830. if (options.paginationOverflowSize) {
  10831. console.warn('ag-grid: since version 10.0.x paginationOverflowSize is now called cacheOverflowSize');
  10832. }
  10833. // if (options.forPrint) {
  10834. // console.warn('ag-grid: since version 10.1.x, use property domLayout="forPrint" instead of forPrint=true');
  10835. // }
  10836. if (options.suppressMenuFilterPanel) {
  10837. console.warn("ag-grid: since version 11.0.x, use property colDef.menuTabs=['generalMenuTab','columnsMenuTab'] instead of suppressMenuFilterPanel=true");
  10838. }
  10839. if (options.suppressMenuMainPanel) {
  10840. console.warn("ag-grid: since version 11.0.x, use property colDef.menuTabs=['filterMenuTab','columnsMenuTab'] instead of suppressMenuMainPanel=true");
  10841. }
  10842. if (options.suppressMenuColumnPanel) {
  10843. console.warn("ag-grid: since version 11.0.x, use property colDef.menuTabs=['generalMenuTab','filterMenuTab'] instead of suppressMenuColumnPanel=true");
  10844. }
  10845. if (options.suppressUseColIdForGroups) {
  10846. console.warn("ag-grid: since version 11.0.x, this is not in use anymore. You should be able to remove it from your definition");
  10847. }
  10848. if (options.groupSuppressRow) {
  10849. console.warn("ag-grid: since version 18.2.x, 'groupSuppressRow' should not be used anymore. Instead remove row groups and perform custom sorting.");
  10850. }
  10851. if (options.groupColumnDef) {
  10852. console.warn("ag-grid: since version 11.0.x, groupColumnDef has been renamed, this property is now called autoGroupColumnDef. Please change your configuration accordingly");
  10853. }
  10854. if (options.slaveGrids) {
  10855. console.warn("ag-grid: since version 12.x, slaveGrids has been renamed, this property is now called alignedGrids. Please change your configuration accordingly");
  10856. }
  10857. if (options.floatingTopRowData) {
  10858. console.warn("ag-grid: since version 12.x, floatingTopRowData is now called pinnedTopRowData");
  10859. }
  10860. if (options.floatingBottomRowData) {
  10861. console.warn("ag-grid: since version 12.x, floatingBottomRowData is now called pinnedBottomRowData");
  10862. }
  10863. if (options.paginationStartPage) {
  10864. console.warn("ag-grid: since version 12.x, paginationStartPage is gone, please call api.paginationGoToPage(" + options.paginationStartPage + ") instead.");
  10865. }
  10866. if (options.getHeaderCellTemplate) {
  10867. console.warn("ag-grid: since version 15.x, getHeaderCellTemplate is gone, please check the header documentation on how to set header templates.");
  10868. }
  10869. if (options.headerCellTemplate) {
  10870. console.warn("ag-grid: since version 15.x, headerCellTemplate is gone, please check the header documentation on how to set header templates.");
  10871. }
  10872. if (options.headerCellRenderer) {
  10873. console.warn("ag-grid: since version 15.x, headerCellRenderer is gone, please check the header documentation on how to set header templates.");
  10874. }
  10875. if (options.angularCompileHeaders) {
  10876. console.warn("ag-grid: since version 15.x, angularCompileHeaders is gone, please see the getting started for Angular 1 docs to see how to do headers in Angular 1.x.");
  10877. }
  10878. if (options.pivotTotals) {
  10879. console.warn("ag-grid: since version 18.x, pivotTotals has been removed, instead if using pivotTotals, set pivotColumnGroupTotals='before'|'after'.");
  10880. options.pivotColumnGroupTotals = 'before';
  10881. }
  10882. if (options.rowModelType === 'inMemory') {
  10883. console.warn("ag-grid: since version 18.x, The In Memory Row Model has been renamed to the Client Side Row Model, set rowModelType='clientSide' instead.");
  10884. options.rowModelType = 'clientSide';
  10885. }
  10886. if (options.rowModelType === 'enterprise') {
  10887. console.warn("ag-grid: since version 18.x, The Enterprise Row Model has been renamed to the Server Side Row Model, set rowModelType='serverSide' instead.");
  10888. options.rowModelType = 'serverSide';
  10889. }
  10890. if (options.layoutInterval) {
  10891. console.warn("ag-grid: since version 18.x, layoutInterval is no longer a property. This is because the grid now uses CSS Flex for layout.");
  10892. }
  10893. if (options.gridAutoHeight) {
  10894. console.warn("ag-grid: since version 19.x, gridAutoHeight is gone, please use domLayout=autoHeight instead");
  10895. options.domLayout = 'autoHeight';
  10896. }
  10897. if (options.showToolPanel === true) {
  10898. console.warn("ag-grid: since version 19.x, showToolPanel is gone, please specify toolPanel components. See https://www.ag-grid.com/javascript-grid-tool-panel/");
  10899. options.showToolPanel = undefined;
  10900. options.sideBar = options.sideBar || true;
  10901. }
  10902. if (options.showToolPanel === false) {
  10903. console.warn("ag-grid: since version 19.x, showToolPanel is gone, please specify toolPanel components. See https://www.ag-grid.com/javascript-grid-tool-panel/");
  10904. options.showToolPanel = undefined;
  10905. options.sideBar = options.sideBar || false;
  10906. }
  10907. var oldToolPanelProperties = {
  10908. toolPanelSuppressRowGroups: 'suppressRowGroups',
  10909. toolPanelSuppressValues: 'suppressValues',
  10910. toolPanelSuppressPivots: 'suppressPivots',
  10911. toolPanelSuppressPivotMode: 'suppressPivotMode',
  10912. toolPanelSuppressColumnFilter: 'suppressColumnFilter',
  10913. toolPanelSuppressColumnSelectAll: 'suppressColumnSelectAll',
  10914. toolPanelSuppressSideButtons: 'suppressSideButtons',
  10915. toolPanelSuppressColumnExpandAll: 'suppressColumnExpandAll',
  10916. contractColumnSelection: 'contractColumnSelection'
  10917. };
  10918. var toolPanelColumnsCompProps = {};
  10919. Object.keys(oldToolPanelProperties).forEach(function (key) {
  10920. var translation = oldToolPanelProperties[key];
  10921. var value = _this.gridOptions[key];
  10922. if (value !== undefined) {
  10923. if (key === 'toolPanelSuppressSideButtons') {
  10924. console.warn('ag-grid: since v19.0 toolPanelSuppressSideButtons has been completely removed. See https://www.ag-grid.com/javascript-grid-tool-panel/');
  10925. return;
  10926. }
  10927. console.warn("ag-grid: since v19.0 gridOptions." + key + " is deprecated, please use gridOptions.sideBar.toolPanel[columnsIndex].componentParams." + translation);
  10928. toolPanelColumnsCompProps[translation] = value;
  10929. }
  10930. });
  10931. if (Object.keys(toolPanelColumnsCompProps).length > 0 && !_utils__WEBPACK_IMPORTED_MODULE_10__["_"].exists(options.sideBar)) {
  10932. console.warn("ag-grid: since version 19.x, sideBar is mandatory if using toolPanel related properties. See https://www.ag-grid.com/javascript-grid-tool-panel/");
  10933. options.sideBar = true;
  10934. }
  10935. if (options.sideBar != null) {
  10936. options.sideBar = _entities_sideBar__WEBPACK_IMPORTED_MODULE_7__["SideBarDefParser"].parse(options.sideBar);
  10937. }
  10938. var sideBarDef = this.gridOptions.sideBar;
  10939. if (Object.keys(toolPanelColumnsCompProps).length > 0 && sideBarDef && sideBarDef.toolPanels) {
  10940. var columnsDef = sideBarDef.toolPanels.filter(function (it) { return it.id === 'columns'; });
  10941. if (columnsDef.length === 1) {
  10942. _utils__WEBPACK_IMPORTED_MODULE_10__["_"].mergeDeep(columnsDef[0], {
  10943. componentParams: toolPanelColumnsCompProps
  10944. });
  10945. }
  10946. }
  10947. if (options.enableStatusBar) {
  10948. console.warn("ag-grid: since version 19.x, enableStatusBar is gone, please specify statusBar components");
  10949. options.statusBar = options.statusBar || {
  10950. components: [{ component: 'agAggregationComponent' }]
  10951. };
  10952. }
  10953. if (options.alwaysShowStatusBar) {
  10954. console.warn("ag-grid: since version 19.x, alwaysShowStatusBar is gone. Please specify a min-height on the ag-status-bar css class, eg .ag-status-bar {min-height: 35px; }");
  10955. }
  10956. if (options.enableServerSideSorting || options.enableSorting) {
  10957. console.warn("ag-Grid: since v20, grid options enableSorting and enableServerSideSorting are gone. Instead set sortable=true on the column definition for the columns sorting are allowed on. To migrate from gridOption.enableSorting=true, set gridOptions.defaultColDef.sortable=true");
  10958. if (!options.defaultColDef) {
  10959. options.defaultColDef = {};
  10960. }
  10961. if (!options.defaultColDef.sortable) {
  10962. options.defaultColDef.sortable = true;
  10963. }
  10964. }
  10965. if (options.enableFilter || options.enableServerSideFilter) {
  10966. console.warn("ag-Grid: since v20, grid options enableFilter and enableServerSideFilter are gone. Instead set filter=true (if not already specifying a specific filter) on the column definition for the columns filtering is allowed on. To migrate from gridOptions.enableFilter=true, set gridOptions.defaultColDef.filter=true. If you are explicitly setting specific filters for each column (ie colDef.filter is already set) the you don't need to do anything.");
  10967. if (!options.defaultColDef) {
  10968. options.defaultColDef = {};
  10969. }
  10970. if (!options.defaultColDef.filter) {
  10971. options.defaultColDef.filter = true;
  10972. }
  10973. }
  10974. if (options.enableColResize) {
  10975. console.warn("ag-Grid: since v20, grid options enableColResize is gone. Instead set resizable=true on the column definition for the columns resizing are allowed on. To migrate from gridOption.enableColResize=true, set gridOptions.defaultColDef.resizable=true");
  10976. if (!options.defaultColDef) {
  10977. options.defaultColDef = {};
  10978. }
  10979. if (!options.defaultColDef.resizable) {
  10980. options.defaultColDef.resizable = true;
  10981. }
  10982. }
  10983. if (options.deprecatedEmbedFullWidthRows) {
  10984. console.warn("ag-Grid: since v21.2, deprecatedEmbedFullWidthRows has been replaced with embedFullWidthRows.");
  10985. }
  10986. if (options.suppressTabbing) {
  10987. console.warn("ag-Grid: since v20.1, suppressTabbing is replaced with the more powerful grid callback suppressKeyboardEvent(params) which can suppress any keyboard event including tabbing.");
  10988. }
  10989. if (options.doesDataFlower) {
  10990. console.warn('ag-Grid: since v21.1, doesDataFlower is deprecated. Master/Detail is the new way for showing child data for a row and was introduced over a year ago. Please migrate your code to use master/detail instead.');
  10991. }
  10992. if (options.enableOldSetFilterModel) {
  10993. console.warn('ag-Grid: since v22.x, enableOldSetFilterModel is deprecated. Please move to the new Set Filter Model as the old one may not be supported in v23 onwards.');
  10994. }
  10995. if (options.floatingFilter) {
  10996. console.warn('ag-Grid: since v23.1, floatingFilter on the gridOptions is deprecated. Please use floatingFilter on the colDef instead.');
  10997. if (!options.defaultColDef) {
  10998. options.defaultColDef = {};
  10999. }
  11000. if (options.defaultColDef.floatingFilter == null) {
  11001. options.defaultColDef.floatingFilter = true;
  11002. }
  11003. }
  11004. var checkRenamedProperty = function (oldProp, newProp, version) {
  11005. if (options[oldProp] != null) {
  11006. console.warn("ag-grid: since version " + version + ", '" + oldProp + "' is deprecated / renamed, please use the new property name '" + newProp + "' instead.");
  11007. if (options[newProp] == null) {
  11008. options[newProp] = options[oldProp];
  11009. }
  11010. }
  11011. };
  11012. checkRenamedProperty('batchUpdateWaitMillis', 'asyncTransactionWaitMillis', '23.1.x');
  11013. checkRenamedProperty('deltaRowDataMode', 'immutableData', '23.1.x');
  11014. checkRenamedProperty('deltaColumnMode', 'immutableColumns', '23.1.x');
  11015. };
  11016. GridOptionsWrapper.prototype.checkForViolations = function () {
  11017. if (this.isTreeData()) {
  11018. this.treeDataViolations();
  11019. }
  11020. };
  11021. GridOptionsWrapper.prototype.treeDataViolations = function () {
  11022. if (this.isRowModelDefault()) {
  11023. if (_utils__WEBPACK_IMPORTED_MODULE_10__["_"].missing(this.getDataPathFunc())) {
  11024. console.warn('ag-Grid: property usingTreeData=true with rowModel=clientSide, but you did not ' +
  11025. 'provide getDataPath function, please provide getDataPath function if using tree data.');
  11026. }
  11027. }
  11028. if (this.isRowModelServerSide()) {
  11029. if (_utils__WEBPACK_IMPORTED_MODULE_10__["_"].missing(this.getIsServerSideGroupFunc())) {
  11030. console.warn('ag-Grid: property usingTreeData=true with rowModel=serverSide, but you did not ' +
  11031. 'provide isServerSideGroup function, please provide isServerSideGroup function if using tree data.');
  11032. }
  11033. if (_utils__WEBPACK_IMPORTED_MODULE_10__["_"].missing(this.getServerSideGroupKeyFunc())) {
  11034. console.warn('ag-Grid: property usingTreeData=true with rowModel=serverSide, but you did not ' +
  11035. 'provide getServerSideGroupKey function, please provide getServerSideGroupKey function if using tree data.');
  11036. }
  11037. }
  11038. };
  11039. GridOptionsWrapper.prototype.getLocaleTextFunc = function () {
  11040. if (this.gridOptions.localeTextFunc) {
  11041. return this.gridOptions.localeTextFunc;
  11042. }
  11043. var localeText = this.gridOptions.localeText;
  11044. return function (key, defaultValue) {
  11045. return localeText && localeText[key] ? localeText[key] : defaultValue;
  11046. };
  11047. };
  11048. // responsible for calling the onXXX functions on gridOptions
  11049. GridOptionsWrapper.prototype.globalEventHandler = function (eventName, event) {
  11050. var callbackMethodName = _components_componentUtil__WEBPACK_IMPORTED_MODULE_2__["ComponentUtil"].getCallbackForEvent(eventName);
  11051. if (typeof this.gridOptions[callbackMethodName] === 'function') {
  11052. this.gridOptions[callbackMethodName](event);
  11053. }
  11054. };
  11055. // we don't allow dynamic row height for virtual paging
  11056. GridOptionsWrapper.prototype.getRowHeightAsNumber = function () {
  11057. if (!this.gridOptions.rowHeight || _utils__WEBPACK_IMPORTED_MODULE_10__["_"].missing(this.gridOptions.rowHeight)) {
  11058. return this.getDefaultRowHeight();
  11059. }
  11060. else if (this.gridOptions.rowHeight && this.isNumeric(this.gridOptions.rowHeight)) {
  11061. return this.gridOptions.rowHeight;
  11062. }
  11063. console.warn('ag-Grid row height must be a number if not using standard row model');
  11064. return this.getDefaultRowHeight();
  11065. };
  11066. GridOptionsWrapper.prototype.getRowHeightForNode = function (rowNode, allowEstimate) {
  11067. // check the function first, in case use set both function and
  11068. // number, when using virtual pagination then function can be
  11069. // used for pinned rows and the number for the body rows.
  11070. if (allowEstimate === void 0) { allowEstimate = false; }
  11071. if (typeof this.gridOptions.getRowHeight === 'function') {
  11072. if (allowEstimate) {
  11073. return { height: this.getDefaultRowHeight(), estimated: true };
  11074. }
  11075. var params = {
  11076. node: rowNode,
  11077. data: rowNode.data,
  11078. api: this.gridOptions.api,
  11079. context: this.gridOptions.context
  11080. };
  11081. var height = this.gridOptions.getRowHeight(params);
  11082. if (height != null) {
  11083. return { height: height, estimated: false };
  11084. }
  11085. }
  11086. if (rowNode.detail && this.isMasterDetail()) {
  11087. if (this.isNumeric(this.gridOptions.detailRowHeight)) {
  11088. return { height: this.gridOptions.detailRowHeight, estimated: false };
  11089. }
  11090. return { height: DEFAULT_DETAIL_ROW_HEIGHT, estimated: false };
  11091. }
  11092. var defaultRowHeight = this.getDefaultRowHeight();
  11093. var rowHeight = this.gridOptions.rowHeight && this.isNumeric(this.gridOptions.rowHeight) ? this.gridOptions.rowHeight : defaultRowHeight;
  11094. var minRowHeight = Math.min(defaultRowHeight, rowHeight);
  11095. if (this.columnController.isAutoRowHeightActive()) {
  11096. if (allowEstimate) {
  11097. return { height: rowHeight, estimated: true };
  11098. }
  11099. var autoHeight = this.autoHeightCalculator.getPreferredHeightForRow(rowNode);
  11100. // never return less than the default row height - covers when auto height
  11101. // cells are blank.
  11102. return { height: Math.max(autoHeight, minRowHeight), estimated: false };
  11103. }
  11104. return { height: rowHeight, estimated: false };
  11105. };
  11106. GridOptionsWrapper.prototype.isDynamicRowHeight = function () {
  11107. return typeof this.gridOptions.getRowHeight === 'function';
  11108. };
  11109. GridOptionsWrapper.prototype.getListItemHeight = function () {
  11110. return this.getFromTheme(20, 'listItemHeight');
  11111. };
  11112. GridOptionsWrapper.prototype.chartMenuPanelWidth = function () {
  11113. return this.environment.chartMenuPanelWidth();
  11114. };
  11115. GridOptionsWrapper.prototype.isNumeric = function (value) {
  11116. return !isNaN(value) && typeof value === 'number';
  11117. };
  11118. // Material data table has strict guidelines about whitespace, and these values are different than the ones
  11119. // ag-grid uses by default. We override the default ones for the sake of making it better out of the box
  11120. GridOptionsWrapper.prototype.getFromTheme = function (defaultValue, sassVariableName) {
  11121. var theme = this.environment.getTheme().theme;
  11122. if (theme && theme.indexOf('ag-theme') === 0) {
  11123. return this.environment.getSassVariable(theme, sassVariableName);
  11124. }
  11125. return defaultValue;
  11126. };
  11127. GridOptionsWrapper.prototype.getDefaultRowHeight = function () {
  11128. return this.getFromTheme(DEFAULT_ROW_HEIGHT, 'rowHeight');
  11129. };
  11130. var GridOptionsWrapper_1;
  11131. GridOptionsWrapper.MIN_COL_WIDTH = 10;
  11132. GridOptionsWrapper.PROP_HEADER_HEIGHT = 'headerHeight';
  11133. GridOptionsWrapper.PROP_GROUP_REMOVE_SINGLE_CHILDREN = 'groupRemoveSingleChildren';
  11134. GridOptionsWrapper.PROP_GROUP_REMOVE_LOWEST_SINGLE_CHILDREN = 'groupRemoveLowestSingleChildren';
  11135. GridOptionsWrapper.PROP_PIVOT_HEADER_HEIGHT = 'pivotHeaderHeight';
  11136. GridOptionsWrapper.PROP_SUPPRESS_CLIPBOARD_PASTE = 'suppressClipboardPaste';
  11137. GridOptionsWrapper.PROP_GROUP_HEADER_HEIGHT = 'groupHeaderHeight';
  11138. GridOptionsWrapper.PROP_PIVOT_GROUP_HEADER_HEIGHT = 'pivotGroupHeaderHeight';
  11139. GridOptionsWrapper.PROP_FLOATING_FILTERS_HEIGHT = 'floatingFiltersHeight';
  11140. GridOptionsWrapper.PROP_SUPPRESS_ROW_CLICK_SELECTION = 'suppressRowClickSelection';
  11141. GridOptionsWrapper.PROP_SUPPRESS_ROW_DRAG = 'suppressRowDrag';
  11142. GridOptionsWrapper.PROP_SUPPRESS_MOVE_WHEN_ROW_DRAG = 'suppressMoveWhenRowDragging';
  11143. GridOptionsWrapper.PROP_POPUP_PARENT = 'popupParent';
  11144. GridOptionsWrapper.PROP_DOM_LAYOUT = 'domLayout';
  11145. __decorate([
  11146. Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('gridOptions')
  11147. ], GridOptionsWrapper.prototype, "gridOptions", void 0);
  11148. __decorate([
  11149. Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('columnController')
  11150. ], GridOptionsWrapper.prototype, "columnController", void 0);
  11151. __decorate([
  11152. Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('eventService')
  11153. ], GridOptionsWrapper.prototype, "eventService", void 0);
  11154. __decorate([
  11155. Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('environment')
  11156. ], GridOptionsWrapper.prototype, "environment", void 0);
  11157. __decorate([
  11158. Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('autoHeightCalculator')
  11159. ], GridOptionsWrapper.prototype, "autoHeightCalculator", void 0);
  11160. __decorate([
  11161. __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Qualifier"])('gridApi')), __param(1, Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Qualifier"])('columnApi'))
  11162. ], GridOptionsWrapper.prototype, "agWire", null);
  11163. __decorate([
  11164. _context_context__WEBPACK_IMPORTED_MODULE_3__["PreDestroy"]
  11165. ], GridOptionsWrapper.prototype, "destroy", null);
  11166. __decorate([
  11167. _context_context__WEBPACK_IMPORTED_MODULE_3__["PostConstruct"]
  11168. ], GridOptionsWrapper.prototype, "init", null);
  11169. GridOptionsWrapper = GridOptionsWrapper_1 = __decorate([
  11170. Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Bean"])('gridOptionsWrapper')
  11171. ], GridOptionsWrapper);
  11172. return GridOptionsWrapper;
  11173. }());
  11174. /***/ }),
  11175. /* 51 */
  11176. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  11177. "use strict";
  11178. __webpack_require__.r(__webpack_exports__);
  11179. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColDefUtil", function() { return ColDefUtil; });
  11180. /**
  11181. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  11182. * @version v23.2.1
  11183. * @link http://www.ag-grid.com/
  11184. * @license MIT
  11185. */
  11186. var __spreadArrays = (undefined && undefined.__spreadArrays) || function () {
  11187. for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;
  11188. for (var r = Array(s), k = 0, i = 0; i < il; i++)
  11189. for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
  11190. r[k] = a[j];
  11191. return r;
  11192. };
  11193. var ColDefUtil = /** @class */ (function () {
  11194. function ColDefUtil() {
  11195. }
  11196. ColDefUtil.STRING_PROPERTIES = [
  11197. 'headerName',
  11198. 'columnGroupShow',
  11199. 'headerClass',
  11200. 'toolPanelClass',
  11201. 'headerValueGetter',
  11202. 'pivotKeys',
  11203. 'groupId',
  11204. 'colId',
  11205. 'sort',
  11206. 'field',
  11207. 'type',
  11208. 'tooltipComponent',
  11209. 'tooltipField',
  11210. 'headerTooltip',
  11211. 'cellClass',
  11212. 'showRowGroup',
  11213. 'template',
  11214. 'templateUrl',
  11215. 'filter',
  11216. 'aggFunc',
  11217. 'cellRenderer',
  11218. 'cellEditor',
  11219. 'pinned',
  11220. 'chartDataType'
  11221. ];
  11222. ColDefUtil.OBJECT_PROPERTIES = [
  11223. 'headerGroupComponent',
  11224. 'headerGroupComponentFramework',
  11225. 'headerGroupComponentParams',
  11226. 'cellStyle',
  11227. 'cellRendererParams',
  11228. 'cellEditorFramework',
  11229. 'cellEditorParams',
  11230. 'pinnedRowCellRendererFramework',
  11231. 'pinnedRowCellRendererParams',
  11232. 'filterFramework',
  11233. 'filterParams',
  11234. 'pivotValueColumn',
  11235. 'headerComponent',
  11236. 'headerComponentFramework',
  11237. 'headerComponentParams',
  11238. 'floatingFilterComponent',
  11239. 'floatingFilterComponentParams',
  11240. 'floatingFilterComponentFramework',
  11241. 'tooltipComponent',
  11242. 'tooltipComponentParams',
  11243. 'tooltipComponentFramework',
  11244. 'refData'
  11245. ];
  11246. ColDefUtil.ARRAY_PROPERTIES = [
  11247. 'children',
  11248. 'sortingOrder',
  11249. 'allowedAggFuncs',
  11250. 'menuTabs',
  11251. 'pivotTotalColumnIds',
  11252. 'cellClassRules',
  11253. 'icons'
  11254. ];
  11255. ColDefUtil.NUMBER_PROPERTIES = [
  11256. 'sortedAt',
  11257. 'flex',
  11258. 'width',
  11259. 'minWidth',
  11260. 'maxWidth',
  11261. 'rowGroupIndex',
  11262. 'pivotIndex'
  11263. ];
  11264. ColDefUtil.BOOLEAN_PROPERTIES = [
  11265. 'suppressCellFlash',
  11266. 'suppressColumnsToolPanel',
  11267. 'suppressFiltersToolPanel',
  11268. 'openByDefault',
  11269. 'marryChildren',
  11270. 'hide',
  11271. 'rowGroup',
  11272. 'pivot',
  11273. 'checkboxSelection',
  11274. 'headerCheckboxSelection',
  11275. 'headerCheckboxSelectionFilteredOnly',
  11276. 'suppressMenu',
  11277. 'suppressSorting',
  11278. 'suppressMovable',
  11279. 'suppressFilter',
  11280. 'lockPosition',
  11281. 'lockVisible',
  11282. 'lockPinned',
  11283. 'unSortIcon',
  11284. 'suppressSizeToFit',
  11285. 'suppressResize',
  11286. 'suppressAutoSize',
  11287. 'enableRowGroup',
  11288. 'enablePivot',
  11289. 'enableValue',
  11290. 'editable',
  11291. 'suppressPaste',
  11292. 'suppressNavigable',
  11293. 'enableCellChangeFlash',
  11294. 'rowDrag',
  11295. 'dndSource',
  11296. 'autoHeight',
  11297. 'sortable',
  11298. 'resizable',
  11299. 'singleClickEdit',
  11300. 'floatingFilter',
  11301. ];
  11302. ColDefUtil.FUNCTION_PROPERTIES = [
  11303. 'dndSourceOnRowDrag',
  11304. 'valueGetter',
  11305. 'valueSetter',
  11306. 'filterValueGetter',
  11307. 'keyCreator',
  11308. 'cellRenderer',
  11309. 'cellRendererFramework',
  11310. 'pinnedRowCellRenderer',
  11311. 'valueFormatter',
  11312. 'pinnedRowValueFormatter',
  11313. 'valueParser',
  11314. 'comparator',
  11315. 'equals',
  11316. 'pivotComparator',
  11317. 'suppressKeyboardEvent',
  11318. 'colSpan',
  11319. 'rowSpan',
  11320. 'getQuickFilterText',
  11321. 'newValueHandler',
  11322. 'onCellValueChanged',
  11323. 'onCellClicked',
  11324. 'onCellDoubleClicked',
  11325. 'onCellContextMenu',
  11326. 'rowDragText',
  11327. 'tooltip',
  11328. 'tooltipValueGetter',
  11329. 'tooltipComponent',
  11330. 'tooltipComponentFramework',
  11331. 'cellRendererSelector',
  11332. 'cellEditorSelector'
  11333. ];
  11334. ColDefUtil.ALL_PROPERTIES = __spreadArrays(ColDefUtil.ARRAY_PROPERTIES, ColDefUtil.OBJECT_PROPERTIES, ColDefUtil.STRING_PROPERTIES, ColDefUtil.NUMBER_PROPERTIES, ColDefUtil.FUNCTION_PROPERTIES, ColDefUtil.BOOLEAN_PROPERTIES);
  11335. // used when doing property checks - this causes noise when using frameworks which can add their own fw specific
  11336. // properties to colDefs, gridOptions etc
  11337. ColDefUtil.FRAMEWORK_PROPERTIES = ['__ob__', '__metadata__', 'mappedColumnProperties', 'hasChildColumns',
  11338. 'toColDef', 'createColDefFromGridColumn'];
  11339. return ColDefUtil;
  11340. }());
  11341. /***/ }),
  11342. /* 52 */
  11343. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  11344. "use strict";
  11345. __webpack_require__.r(__webpack_exports__);
  11346. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SideBarDefParser", function() { return SideBarDefParser; });
  11347. /**
  11348. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  11349. * @version v23.2.1
  11350. * @link http://www.ag-grid.com/
  11351. * @license MIT
  11352. */
  11353. var SideBarDefParser = /** @class */ (function () {
  11354. function SideBarDefParser() {
  11355. }
  11356. SideBarDefParser.parse = function (toParse) {
  11357. if (!toParse) {
  11358. return null;
  11359. }
  11360. if (toParse === true) {
  11361. return {
  11362. toolPanels: [
  11363. SideBarDefParser.DEFAULT_COLUMN_COMP,
  11364. SideBarDefParser.DEFAULT_FILTER_COMP,
  11365. ],
  11366. defaultToolPanel: 'columns'
  11367. };
  11368. }
  11369. if (typeof toParse === 'string') {
  11370. return SideBarDefParser.parse([toParse]);
  11371. }
  11372. if (Array.isArray(toParse)) {
  11373. var comps_1 = [];
  11374. toParse.forEach(function (key) {
  11375. var lookupResult = SideBarDefParser.DEFAULT_BY_KEY[key];
  11376. if (!lookupResult) {
  11377. console.warn("ag-grid: the key " + key + " is not a valid key for specifying a tool panel, valid keys are: " + Object.keys(SideBarDefParser.DEFAULT_BY_KEY).join(','));
  11378. return;
  11379. }
  11380. comps_1.push(lookupResult);
  11381. });
  11382. if (comps_1.length === 0) {
  11383. return null;
  11384. }
  11385. return {
  11386. toolPanels: comps_1,
  11387. defaultToolPanel: comps_1[0].id
  11388. };
  11389. }
  11390. var result = {
  11391. toolPanels: SideBarDefParser.parseComponents(toParse.toolPanels),
  11392. defaultToolPanel: toParse.defaultToolPanel,
  11393. hiddenByDefault: toParse.hiddenByDefault,
  11394. position: toParse.position
  11395. };
  11396. return result;
  11397. };
  11398. SideBarDefParser.parseComponents = function (from) {
  11399. var result = [];
  11400. from.forEach(function (it) {
  11401. var toAdd = null;
  11402. if (typeof it === 'string') {
  11403. var lookupResult = SideBarDefParser.DEFAULT_BY_KEY[it];
  11404. if (!lookupResult) {
  11405. console.warn("ag-grid: the key " + it + " is not a valid key for specifying a tool panel, valid keys are: " + Object.keys(SideBarDefParser.DEFAULT_BY_KEY).join(','));
  11406. return;
  11407. }
  11408. toAdd = lookupResult;
  11409. }
  11410. else {
  11411. toAdd = it;
  11412. }
  11413. result.push(toAdd);
  11414. });
  11415. return result;
  11416. };
  11417. SideBarDefParser.DEFAULT_COLUMN_COMP = {
  11418. id: 'columns',
  11419. labelDefault: 'Columns',
  11420. labelKey: 'columns',
  11421. iconKey: 'columns',
  11422. toolPanel: 'agColumnsToolPanel',
  11423. };
  11424. SideBarDefParser.DEFAULT_FILTER_COMP = {
  11425. id: 'filters',
  11426. labelDefault: 'Filters',
  11427. labelKey: 'filters',
  11428. iconKey: 'filter',
  11429. toolPanel: 'agFiltersToolPanel',
  11430. };
  11431. SideBarDefParser.DEFAULT_BY_KEY = {
  11432. columns: SideBarDefParser.DEFAULT_COLUMN_COMP,
  11433. filters: SideBarDefParser.DEFAULT_FILTER_COMP
  11434. };
  11435. return SideBarDefParser;
  11436. }());
  11437. /***/ }),
  11438. /* 53 */
  11439. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  11440. "use strict";
  11441. __webpack_require__.r(__webpack_exports__);
  11442. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RegisteredComponentSource", function() { return RegisteredComponentSource; });
  11443. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "UserComponentRegistry", function() { return UserComponentRegistry; });
  11444. /* harmony import */ var _rendering_cellEditors_textCellEditor__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(54);
  11445. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  11446. /* harmony import */ var _filter_provided_date_dateFilter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(58);
  11447. /* harmony import */ var _headerRendering_header_headerComp__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(64);
  11448. /* harmony import */ var _headerRendering_headerGroup_headerGroupComp__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(66);
  11449. /* harmony import */ var _rendering_cellRenderers_groupCellRenderer__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(67);
  11450. /* harmony import */ var _rendering_cellRenderers_animateShowChangeCellRenderer__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(76);
  11451. /* harmony import */ var _rendering_cellRenderers_animateSlideCellRenderer__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(77);
  11452. /* harmony import */ var _rendering_cellRenderers_loadingCellRenderer__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(78);
  11453. /* harmony import */ var _rendering_cellEditors_selectCellEditor__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(79);
  11454. /* harmony import */ var _rendering_cellEditors_popupTextCellEditor__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(80);
  11455. /* harmony import */ var _rendering_cellEditors_popupSelectCellEditor__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(81);
  11456. /* harmony import */ var _rendering_cellEditors_largeTextCellEditor__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(82);
  11457. /* harmony import */ var _filter_provided_number_numberFilter__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(83);
  11458. /* harmony import */ var _rendering_overlays_loadingOverlayComponent__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(84);
  11459. /* harmony import */ var _rendering_overlays_noRowsOverlayComponent__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(85);
  11460. /* harmony import */ var _rendering_tooltipComponent__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(86);
  11461. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(7);
  11462. /* harmony import */ var _filter_provided_date_defaultDateComponent__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(87);
  11463. /* harmony import */ var _filter_provided_date_dateFloatingFilter__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(88);
  11464. /* harmony import */ var _filter_provided_text_textFilter__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(90);
  11465. /* harmony import */ var _filter_provided_number_numberFloatingFilter__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(91);
  11466. /* harmony import */ var _filter_provided_text_textFloatingFilter__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(93);
  11467. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(41);
  11468. /**
  11469. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  11470. * @version v23.2.1
  11471. * @link http://www.ag-grid.com/
  11472. * @license MIT
  11473. */
  11474. var __extends = (undefined && undefined.__extends) || (function () {
  11475. var extendStatics = function (d, b) {
  11476. extendStatics = Object.setPrototypeOf ||
  11477. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  11478. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  11479. return extendStatics(d, b);
  11480. };
  11481. return function (d, b) {
  11482. extendStatics(d, b);
  11483. function __() { this.constructor = d; }
  11484. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  11485. };
  11486. })();
  11487. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  11488. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  11489. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  11490. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  11491. return c > 3 && r && Object.defineProperty(target, key, r), r;
  11492. };
  11493. var RegisteredComponentSource;
  11494. (function (RegisteredComponentSource) {
  11495. RegisteredComponentSource[RegisteredComponentSource["DEFAULT"] = 0] = "DEFAULT";
  11496. RegisteredComponentSource[RegisteredComponentSource["REGISTERED"] = 1] = "REGISTERED";
  11497. })(RegisteredComponentSource || (RegisteredComponentSource = {}));
  11498. var UserComponentRegistry = /** @class */ (function (_super) {
  11499. __extends(UserComponentRegistry, _super);
  11500. function UserComponentRegistry() {
  11501. var _this = _super !== null && _super.apply(this, arguments) || this;
  11502. _this.agGridDefaults = {
  11503. //date
  11504. agDateInput: _filter_provided_date_defaultDateComponent__WEBPACK_IMPORTED_MODULE_18__["DefaultDateComponent"],
  11505. //header
  11506. agColumnHeader: _headerRendering_header_headerComp__WEBPACK_IMPORTED_MODULE_3__["HeaderComp"],
  11507. agColumnGroupHeader: _headerRendering_headerGroup_headerGroupComp__WEBPACK_IMPORTED_MODULE_4__["HeaderGroupComp"],
  11508. //floating filters
  11509. agTextColumnFloatingFilter: _filter_provided_text_textFloatingFilter__WEBPACK_IMPORTED_MODULE_22__["TextFloatingFilter"],
  11510. agNumberColumnFloatingFilter: _filter_provided_number_numberFloatingFilter__WEBPACK_IMPORTED_MODULE_21__["NumberFloatingFilter"],
  11511. agDateColumnFloatingFilter: _filter_provided_date_dateFloatingFilter__WEBPACK_IMPORTED_MODULE_19__["DateFloatingFilter"],
  11512. // renderers
  11513. agAnimateShowChangeCellRenderer: _rendering_cellRenderers_animateShowChangeCellRenderer__WEBPACK_IMPORTED_MODULE_6__["AnimateShowChangeCellRenderer"],
  11514. agAnimateSlideCellRenderer: _rendering_cellRenderers_animateSlideCellRenderer__WEBPACK_IMPORTED_MODULE_7__["AnimateSlideCellRenderer"],
  11515. agGroupCellRenderer: _rendering_cellRenderers_groupCellRenderer__WEBPACK_IMPORTED_MODULE_5__["GroupCellRenderer"],
  11516. agGroupRowRenderer: _rendering_cellRenderers_groupCellRenderer__WEBPACK_IMPORTED_MODULE_5__["GroupCellRenderer"],
  11517. agLoadingCellRenderer: _rendering_cellRenderers_loadingCellRenderer__WEBPACK_IMPORTED_MODULE_8__["LoadingCellRenderer"],
  11518. //editors
  11519. agCellEditor: _rendering_cellEditors_textCellEditor__WEBPACK_IMPORTED_MODULE_0__["TextCellEditor"],
  11520. agTextCellEditor: _rendering_cellEditors_textCellEditor__WEBPACK_IMPORTED_MODULE_0__["TextCellEditor"],
  11521. agSelectCellEditor: _rendering_cellEditors_selectCellEditor__WEBPACK_IMPORTED_MODULE_9__["SelectCellEditor"],
  11522. agPopupTextCellEditor: _rendering_cellEditors_popupTextCellEditor__WEBPACK_IMPORTED_MODULE_10__["PopupTextCellEditor"],
  11523. agPopupSelectCellEditor: _rendering_cellEditors_popupSelectCellEditor__WEBPACK_IMPORTED_MODULE_11__["PopupSelectCellEditor"],
  11524. agLargeTextCellEditor: _rendering_cellEditors_largeTextCellEditor__WEBPACK_IMPORTED_MODULE_12__["LargeTextCellEditor"],
  11525. //filter
  11526. agTextColumnFilter: _filter_provided_text_textFilter__WEBPACK_IMPORTED_MODULE_20__["TextFilter"],
  11527. agNumberColumnFilter: _filter_provided_number_numberFilter__WEBPACK_IMPORTED_MODULE_13__["NumberFilter"],
  11528. agDateColumnFilter: _filter_provided_date_dateFilter__WEBPACK_IMPORTED_MODULE_2__["DateFilter"],
  11529. //overlays
  11530. agLoadingOverlay: _rendering_overlays_loadingOverlayComponent__WEBPACK_IMPORTED_MODULE_14__["LoadingOverlayComponent"],
  11531. agNoRowsOverlay: _rendering_overlays_noRowsOverlayComponent__WEBPACK_IMPORTED_MODULE_15__["NoRowsOverlayComponent"],
  11532. // tooltips
  11533. agTooltipComponent: _rendering_tooltipComponent__WEBPACK_IMPORTED_MODULE_16__["TooltipComponent"]
  11534. };
  11535. _this.agDeprecatedNames = {
  11536. set: {
  11537. newComponentName: 'agSetColumnFilter',
  11538. propertyHolder: 'filter'
  11539. },
  11540. text: {
  11541. newComponentName: 'agTextColumnFilter',
  11542. propertyHolder: 'filter'
  11543. },
  11544. number: {
  11545. newComponentName: 'agNumberColumnFilter',
  11546. propertyHolder: 'filter'
  11547. },
  11548. date: {
  11549. newComponentName: 'agDateColumnFilter',
  11550. propertyHolder: 'filter'
  11551. },
  11552. group: {
  11553. newComponentName: 'agGroupCellRenderer',
  11554. propertyHolder: 'cellRenderer'
  11555. },
  11556. animateShowChange: {
  11557. newComponentName: 'agAnimateShowChangeCellRenderer',
  11558. propertyHolder: 'cellRenderer'
  11559. },
  11560. animateSlide: {
  11561. newComponentName: 'agAnimateSlideCellRenderer',
  11562. propertyHolder: 'cellRenderer'
  11563. },
  11564. select: {
  11565. newComponentName: 'agSelectCellEditor',
  11566. propertyHolder: 'cellEditor'
  11567. },
  11568. largeText: {
  11569. newComponentName: 'agLargeTextCellEditor',
  11570. propertyHolder: 'cellEditor'
  11571. },
  11572. popupSelect: {
  11573. newComponentName: 'agPopupSelectCellEditor',
  11574. propertyHolder: 'cellEditor'
  11575. },
  11576. popupText: {
  11577. newComponentName: 'agPopupTextCellEditor',
  11578. propertyHolder: 'cellEditor'
  11579. },
  11580. richSelect: {
  11581. newComponentName: 'agRichSelectCellEditor',
  11582. propertyHolder: 'cellEditor'
  11583. },
  11584. headerComponent: {
  11585. newComponentName: 'agColumnHeader',
  11586. propertyHolder: 'headerComponent'
  11587. }
  11588. };
  11589. _this.jsComponents = {};
  11590. _this.frameworkComponents = {};
  11591. return _this;
  11592. }
  11593. UserComponentRegistry.prototype.init = function () {
  11594. var _this = this;
  11595. if (this.gridOptions.components != null) {
  11596. Object.keys(this.gridOptions.components).forEach(function (it) {
  11597. _this.registerComponent(it, _this.gridOptions.components[it]);
  11598. });
  11599. }
  11600. if (this.gridOptions.frameworkComponents != null) {
  11601. Object.keys(this.gridOptions.frameworkComponents).forEach(function (it) {
  11602. _this.registerFwComponent(it, _this.gridOptions.frameworkComponents[it]);
  11603. });
  11604. }
  11605. };
  11606. UserComponentRegistry.prototype.registerDefaultComponent = function (rawName, component) {
  11607. var name = this.translateIfDeprecated(rawName);
  11608. if (this.agGridDefaults[name]) {
  11609. console.error("Trying to overwrite a default component. You should call registerComponent");
  11610. return;
  11611. }
  11612. this.agGridDefaults[name] = component;
  11613. };
  11614. UserComponentRegistry.prototype.registerComponent = function (rawName, component) {
  11615. var name = this.translateIfDeprecated(rawName);
  11616. if (this.frameworkComponents[name]) {
  11617. console.error("Trying to register a component that you have already registered for frameworks: " + name);
  11618. return;
  11619. }
  11620. this.jsComponents[name] = component;
  11621. };
  11622. /**
  11623. * B the business interface (ie IHeader)
  11624. * A the agGridComponent interface (ie IHeaderComp). The final object acceptable by ag-grid
  11625. */
  11626. UserComponentRegistry.prototype.registerFwComponent = function (rawName, component) {
  11627. var name = this.translateIfDeprecated(rawName);
  11628. if (this.jsComponents[name]) {
  11629. console.error("Trying to register a component that you have already registered for plain javascript: " + name);
  11630. return;
  11631. }
  11632. this.frameworkComponents[name] = component;
  11633. };
  11634. /**
  11635. * B the business interface (ie IHeader)
  11636. * A the agGridComponent interface (ie IHeaderComp). The final object acceptable by ag-grid
  11637. */
  11638. UserComponentRegistry.prototype.retrieve = function (rawName) {
  11639. var name = this.translateIfDeprecated(rawName);
  11640. if (this.frameworkComponents[name]) {
  11641. return {
  11642. componentFromFramework: true,
  11643. component: this.frameworkComponents[name],
  11644. source: RegisteredComponentSource.REGISTERED
  11645. };
  11646. }
  11647. if (this.jsComponents[name]) {
  11648. return {
  11649. componentFromFramework: false,
  11650. component: this.jsComponents[name],
  11651. source: RegisteredComponentSource.REGISTERED
  11652. };
  11653. }
  11654. if (this.agGridDefaults[name]) {
  11655. return this.agGridDefaults[name] ?
  11656. {
  11657. componentFromFramework: false,
  11658. component: this.agGridDefaults[name],
  11659. source: RegisteredComponentSource.DEFAULT
  11660. } :
  11661. null;
  11662. }
  11663. if (Object.keys(this.agGridDefaults).indexOf(name) < 0) {
  11664. console.warn("ag-Grid: Looking for component [" + name + "] but it wasn't found.");
  11665. }
  11666. return null;
  11667. };
  11668. UserComponentRegistry.prototype.translateIfDeprecated = function (raw) {
  11669. var deprecatedInfo = this.agDeprecatedNames[raw];
  11670. if (deprecatedInfo != null) {
  11671. _utils__WEBPACK_IMPORTED_MODULE_17__["_"].doOnce(function () {
  11672. console.warn("ag-grid. Since v15.0 component names have been renamed to be namespaced. You should rename " + deprecatedInfo.propertyHolder + ":" + raw + " to " + deprecatedInfo.propertyHolder + ":" + deprecatedInfo.newComponentName);
  11673. }, 'DEPRECATE_COMPONENT_' + raw);
  11674. return deprecatedInfo.newComponentName;
  11675. }
  11676. return raw;
  11677. };
  11678. __decorate([
  11679. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptions')
  11680. ], UserComponentRegistry.prototype, "gridOptions", void 0);
  11681. __decorate([
  11682. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  11683. ], UserComponentRegistry.prototype, "init", null);
  11684. UserComponentRegistry = __decorate([
  11685. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('userComponentRegistry')
  11686. ], UserComponentRegistry);
  11687. return UserComponentRegistry;
  11688. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_23__["BeanStub"]));
  11689. /***/ }),
  11690. /* 54 */
  11691. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  11692. "use strict";
  11693. __webpack_require__.r(__webpack_exports__);
  11694. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TextCellEditor", function() { return TextCellEditor; });
  11695. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(25);
  11696. /* harmony import */ var _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(55);
  11697. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57);
  11698. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  11699. /**
  11700. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  11701. * @version v23.2.1
  11702. * @link http://www.ag-grid.com/
  11703. * @license MIT
  11704. */
  11705. var __extends = (undefined && undefined.__extends) || (function () {
  11706. var extendStatics = function (d, b) {
  11707. extendStatics = Object.setPrototypeOf ||
  11708. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  11709. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  11710. return extendStatics(d, b);
  11711. };
  11712. return function (d, b) {
  11713. extendStatics(d, b);
  11714. function __() { this.constructor = d; }
  11715. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  11716. };
  11717. })();
  11718. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  11719. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  11720. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  11721. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  11722. return c > 3 && r && Object.defineProperty(target, key, r), r;
  11723. };
  11724. var TextCellEditor = /** @class */ (function (_super) {
  11725. __extends(TextCellEditor, _super);
  11726. function TextCellEditor() {
  11727. return _super.call(this, TextCellEditor.TEMPLATE) || this;
  11728. }
  11729. TextCellEditor.prototype.init = function (params) {
  11730. this.params = params;
  11731. var eInput = this.eInput;
  11732. var startValue;
  11733. // cellStartedEdit is only false if we are doing fullRow editing
  11734. if (params.cellStartedEdit) {
  11735. this.focusAfterAttached = true;
  11736. var keyPressBackspaceOrDelete = params.keyPress === _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_BACKSPACE
  11737. || params.keyPress === _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_DELETE;
  11738. if (keyPressBackspaceOrDelete) {
  11739. startValue = '';
  11740. }
  11741. else if (params.charPress) {
  11742. startValue = params.charPress;
  11743. }
  11744. else {
  11745. startValue = this.getStartValue(params);
  11746. if (params.keyPress !== _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_F2) {
  11747. this.highlightAllOnFocus = true;
  11748. }
  11749. }
  11750. }
  11751. else {
  11752. this.focusAfterAttached = false;
  11753. startValue = this.getStartValue(params);
  11754. }
  11755. if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(startValue)) {
  11756. eInput.setValue(startValue, true);
  11757. }
  11758. this.addManagedListener(eInput.getGui(), 'keydown', function (event) {
  11759. var pageUp = event.keyCode === _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_PAGE_UP;
  11760. var pageDown = event.keyCode === _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_PAGE_DOWN;
  11761. if (pageUp || pageDown) {
  11762. event.preventDefault();
  11763. }
  11764. });
  11765. };
  11766. TextCellEditor.prototype.afterGuiAttached = function () {
  11767. if (!this.focusAfterAttached) {
  11768. return;
  11769. }
  11770. var eInput = this.eInput;
  11771. // Added for AG-3238. We can't remove this explicit focus() because Chrome requires an input
  11772. // to be focused before setSelectionRange will work. But it triggers a bug in Safari where
  11773. // explicitly focusing then blurring an empty field will cause the parent container to scroll.
  11774. if (!_utils__WEBPACK_IMPORTED_MODULE_3__["_"].isBrowserSafari()) {
  11775. eInput.getFocusableElement().focus();
  11776. }
  11777. var inputEl = eInput.getInputElement();
  11778. if (this.highlightAllOnFocus) {
  11779. inputEl.select();
  11780. }
  11781. else {
  11782. // when we started editing, we want the caret at the end, not the start.
  11783. // this comes into play in two scenarios: a) when user hits F2 and b)
  11784. // when user hits a printable character, then on IE (and only IE) the caret
  11785. // was placed after the first character, thus 'apply' would end up as 'pplea'
  11786. var value = eInput.getValue();
  11787. var len = (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(value) && value.length) || 0;
  11788. if (len) {
  11789. inputEl.setSelectionRange(len, len);
  11790. }
  11791. }
  11792. };
  11793. // gets called when tabbing trough cells and in full row edit mode
  11794. TextCellEditor.prototype.focusIn = function () {
  11795. var eInput = this.eInput;
  11796. var focusEl = eInput.getFocusableElement();
  11797. var inputEl = eInput.getInputElement();
  11798. focusEl.focus();
  11799. inputEl.select();
  11800. };
  11801. TextCellEditor.prototype.focusOut = function () {
  11802. var inputEl = this.eInput.getInputElement();
  11803. if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].isBrowserIE()) {
  11804. inputEl.setSelectionRange(0, 0);
  11805. }
  11806. };
  11807. TextCellEditor.prototype.getValue = function () {
  11808. var eInput = this.eInput;
  11809. return this.params.parseValue(eInput.getValue());
  11810. };
  11811. TextCellEditor.prototype.getStartValue = function (params) {
  11812. var formatValue = params.useFormatter || params.column.getColDef().refData;
  11813. return formatValue ? params.formatValue(params.value) : params.value;
  11814. };
  11815. TextCellEditor.prototype.isPopup = function () {
  11816. return false;
  11817. };
  11818. TextCellEditor.TEMPLATE = '<div class="ag-cell-edit-wrapper"><ag-input-text-field class="ag-cell-editor" ref="eInput"></ag-input-text-field></div>';
  11819. __decorate([
  11820. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('eInput')
  11821. ], TextCellEditor.prototype, "eInput", void 0);
  11822. return TextCellEditor;
  11823. }(_widgets_popupComponent__WEBPACK_IMPORTED_MODULE_1__["PopupComponent"]));
  11824. /***/ }),
  11825. /* 55 */
  11826. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  11827. "use strict";
  11828. __webpack_require__.r(__webpack_exports__);
  11829. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PopupComponent", function() { return PopupComponent; });
  11830. /* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56);
  11831. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7);
  11832. /**
  11833. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  11834. * @version v23.2.1
  11835. * @link http://www.ag-grid.com/
  11836. * @license MIT
  11837. */
  11838. var __extends = (undefined && undefined.__extends) || (function () {
  11839. var extendStatics = function (d, b) {
  11840. extendStatics = Object.setPrototypeOf ||
  11841. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  11842. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  11843. return extendStatics(d, b);
  11844. };
  11845. return function (d, b) {
  11846. extendStatics(d, b);
  11847. function __() { this.constructor = d; }
  11848. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  11849. };
  11850. })();
  11851. var PopupComponent = /** @class */ (function (_super) {
  11852. __extends(PopupComponent, _super);
  11853. function PopupComponent() {
  11854. return _super !== null && _super.apply(this, arguments) || this;
  11855. }
  11856. PopupComponent.prototype.isPopup = function () {
  11857. return true;
  11858. };
  11859. PopupComponent.prototype.setParentComponent = function (container) {
  11860. _utils__WEBPACK_IMPORTED_MODULE_1__["_"].addCssClass(container.getGui(), 'ag-has-popup');
  11861. _super.prototype.setParentComponent.call(this, container);
  11862. };
  11863. PopupComponent.prototype.destroy = function () {
  11864. var parentComp = this.parentComponent;
  11865. var hasParent = parentComp && parentComp.isAlive();
  11866. if (hasParent) {
  11867. _utils__WEBPACK_IMPORTED_MODULE_1__["_"].removeCssClass(parentComp.getGui(), 'ag-has-popup');
  11868. }
  11869. _super.prototype.destroy.call(this);
  11870. };
  11871. return PopupComponent;
  11872. }(_component__WEBPACK_IMPORTED_MODULE_0__["Component"]));
  11873. /***/ }),
  11874. /* 56 */
  11875. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  11876. "use strict";
  11877. __webpack_require__.r(__webpack_exports__);
  11878. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Component", function() { return Component; });
  11879. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  11880. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  11881. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
  11882. /**
  11883. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  11884. * @version v23.2.1
  11885. * @link http://www.ag-grid.com/
  11886. * @license MIT
  11887. */
  11888. var __extends = (undefined && undefined.__extends) || (function () {
  11889. var extendStatics = function (d, b) {
  11890. extendStatics = Object.setPrototypeOf ||
  11891. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  11892. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  11893. return extendStatics(d, b);
  11894. };
  11895. return function (d, b) {
  11896. extendStatics(d, b);
  11897. function __() { this.constructor = d; }
  11898. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  11899. };
  11900. })();
  11901. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  11902. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  11903. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  11904. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  11905. return c > 3 && r && Object.defineProperty(target, key, r), r;
  11906. };
  11907. var compIdSequence = new _utils__WEBPACK_IMPORTED_MODULE_2__["NumberSequence"]();
  11908. var Component = /** @class */ (function (_super) {
  11909. __extends(Component, _super);
  11910. function Component(template) {
  11911. var _this = _super.call(this) || this;
  11912. _this.annotatedGuiListeners = [];
  11913. // if false, then CSS class "ag-hidden" is applied, which sets "display: none"
  11914. _this.displayed = true;
  11915. // if false, then CSS class "ag-invisible" is applied, which sets "visibility: hidden"
  11916. _this.visible = true;
  11917. // unique id for this row component. this is used for getting a reference to the HTML dom.
  11918. // we cannot use the RowNode id as this is not unique (due to animation, old rows can be lying
  11919. // around as we create a new rowComp instance for the same row node).
  11920. _this.compId = compIdSequence.next();
  11921. if (template) {
  11922. _this.setTemplate(template);
  11923. }
  11924. return _this;
  11925. }
  11926. Component.prototype.getCompId = function () {
  11927. return this.compId;
  11928. };
  11929. // for registered components only, eg creates AgCheckbox instance from ag-checkbox HTML tag
  11930. Component.prototype.createChildComponentsFromTags = function (parentNode, paramsMap) {
  11931. var _this = this;
  11932. // we MUST take a copy of the list first, as the 'swapComponentForNode' adds comments into the DOM
  11933. // which messes up the traversal order of the children.
  11934. var childNodeList = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].copyNodeList(parentNode.childNodes);
  11935. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].forEach(childNodeList, function (childNode) {
  11936. if (!(childNode instanceof HTMLElement)) {
  11937. return;
  11938. }
  11939. var childComp = _this.createComponentFromElement(childNode, function (childComp) {
  11940. // copy over all attributes, including css classes, so any attributes user put on the tag
  11941. // wll be carried across
  11942. _this.copyAttributesFromNode(childNode, childComp.getGui());
  11943. }, paramsMap);
  11944. if (childComp) {
  11945. if (childComp.addItems && childNode.children.length) {
  11946. _this.createChildComponentsFromTags(childNode);
  11947. // converting from HTMLCollection to Array
  11948. var items = Array.prototype.slice.call(childNode.children);
  11949. childComp.addItems(items);
  11950. }
  11951. // replace the tag (eg ag-checkbox) with the proper HTMLElement (eg 'div') in the dom
  11952. _this.swapComponentForNode(childComp, parentNode, childNode);
  11953. }
  11954. else if (childNode.childNodes) {
  11955. _this.createChildComponentsFromTags(childNode);
  11956. }
  11957. });
  11958. };
  11959. Component.prototype.createComponentFromElement = function (element, afterPreCreateCallback, paramsMap) {
  11960. var key = element.nodeName;
  11961. var componentParams = paramsMap ? paramsMap[element.getAttribute('ref')] : undefined;
  11962. var ComponentClass = this.agStackComponentsRegistry.getComponentClass(key);
  11963. if (ComponentClass) {
  11964. var newComponent = new ComponentClass(componentParams);
  11965. this.createBean(newComponent, null, afterPreCreateCallback);
  11966. return newComponent;
  11967. }
  11968. return null;
  11969. };
  11970. Component.prototype.copyAttributesFromNode = function (source, dest) {
  11971. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].iterateNamedNodeMap(source.attributes, function (name, value) { return dest.setAttribute(name, value); });
  11972. };
  11973. Component.prototype.swapComponentForNode = function (newComponent, parentNode, childNode) {
  11974. var eComponent = newComponent.getGui();
  11975. parentNode.replaceChild(eComponent, childNode);
  11976. parentNode.insertBefore(document.createComment(childNode.nodeName), eComponent);
  11977. this.addDestroyFunc(this.destroyBean.bind(this, newComponent));
  11978. this.swapInComponentForQuerySelectors(newComponent, childNode);
  11979. };
  11980. Component.prototype.swapInComponentForQuerySelectors = function (newComponent, childNode) {
  11981. var thisNoType = this;
  11982. this.iterateOverQuerySelectors(function (querySelector) {
  11983. if (thisNoType[querySelector.attributeName] === childNode) {
  11984. thisNoType[querySelector.attributeName] = newComponent;
  11985. }
  11986. });
  11987. };
  11988. Component.prototype.iterateOverQuerySelectors = function (action) {
  11989. var thisPrototype = Object.getPrototypeOf(this);
  11990. while (thisPrototype != null) {
  11991. var metaData = thisPrototype.__agComponentMetaData;
  11992. var currentProtoName = (thisPrototype.constructor).name;
  11993. if (metaData && metaData[currentProtoName] && metaData[currentProtoName].querySelectors) {
  11994. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].forEach(metaData[currentProtoName].querySelectors, function (querySelector) { return action(querySelector); });
  11995. }
  11996. thisPrototype = Object.getPrototypeOf(thisPrototype);
  11997. }
  11998. };
  11999. Component.prototype.setTemplate = function (template, paramsMap) {
  12000. var eGui = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].loadTemplate(template);
  12001. this.setTemplateFromElement(eGui, paramsMap);
  12002. };
  12003. Component.prototype.setTemplateFromElement = function (element, paramsMap) {
  12004. this.eGui = element;
  12005. this.eGui.__agComponent = this;
  12006. this.addAnnotatedGuiEventListeners();
  12007. this.wireQuerySelectors();
  12008. // context will not be available when user sets template in constructor
  12009. if (!!this.getContext()) {
  12010. this.createChildComponentsFromTags(this.getGui(), paramsMap);
  12011. }
  12012. };
  12013. Component.prototype.createChildComponentsPreConstruct = function () {
  12014. // ui exists if user sets template in constructor. when this happens, we have to wait for the context
  12015. // to be autoWired first before we can create child components.
  12016. if (!!this.getGui()) {
  12017. this.createChildComponentsFromTags(this.getGui());
  12018. }
  12019. };
  12020. Component.prototype.wireQuerySelectors = function () {
  12021. var _this = this;
  12022. if (!this.eGui) {
  12023. return;
  12024. }
  12025. var thisNoType = this;
  12026. this.iterateOverQuerySelectors(function (querySelector) {
  12027. var resultOfQuery = _this.eGui.querySelector(querySelector.querySelector);
  12028. if (resultOfQuery) {
  12029. thisNoType[querySelector.attributeName] = resultOfQuery.__agComponent || resultOfQuery;
  12030. }
  12031. else {
  12032. // put debug msg in here if query selector fails???
  12033. }
  12034. });
  12035. };
  12036. Component.prototype.addAnnotatedGuiEventListeners = function () {
  12037. var _this = this;
  12038. this.removeAnnotatedGuiEventListeners();
  12039. if (!this.eGui) {
  12040. return;
  12041. }
  12042. var listenerMethods = this.getAgComponentMetaData('guiListenerMethods');
  12043. if (!listenerMethods) {
  12044. return;
  12045. }
  12046. if (!this.annotatedGuiListeners) {
  12047. this.annotatedGuiListeners = [];
  12048. }
  12049. listenerMethods.forEach(function (meta) {
  12050. var element = _this.getRefElement(meta.ref);
  12051. if (!element) {
  12052. return;
  12053. }
  12054. var listener = _this[meta.methodName].bind(_this);
  12055. element.addEventListener(meta.eventName, listener);
  12056. _this.annotatedGuiListeners.push({ eventName: meta.eventName, listener: listener, element: element });
  12057. });
  12058. };
  12059. Component.prototype.addAnnotatedGridEventListeners = function () {
  12060. var _this = this;
  12061. var listenerMetas = this.getAgComponentMetaData('gridListenerMethods');
  12062. if (!listenerMetas) {
  12063. return;
  12064. }
  12065. listenerMetas.forEach(function (meta) {
  12066. var listener = _this[meta.methodName].bind(_this);
  12067. _this.addManagedListener(_this.eventService, meta.eventName, listener);
  12068. });
  12069. };
  12070. Component.prototype.getAgComponentMetaData = function (key) {
  12071. var res = [];
  12072. var thisProto = Object.getPrototypeOf(this);
  12073. while (thisProto != null) {
  12074. var metaData = thisProto.__agComponentMetaData;
  12075. var currentProtoName = (thisProto.constructor).name;
  12076. // IE does not support Function.prototype.name, so we need to extract
  12077. // the name using a RegEx
  12078. // from: https://matt.scharley.me/2012/03/monkey-patch-name-ie.html
  12079. if (currentProtoName === undefined) {
  12080. var funcNameRegex = /function\s([^(]{1,})\(/;
  12081. var results = funcNameRegex.exec(thisProto.constructor.toString());
  12082. if (results && results.length > 1) {
  12083. currentProtoName = results[1].trim();
  12084. }
  12085. }
  12086. if (metaData && metaData[currentProtoName] && metaData[currentProtoName][key]) {
  12087. res = res.concat(metaData[currentProtoName][key]);
  12088. }
  12089. thisProto = Object.getPrototypeOf(thisProto);
  12090. }
  12091. return res;
  12092. };
  12093. Component.prototype.removeAnnotatedGuiEventListeners = function () {
  12094. if (!this.annotatedGuiListeners) {
  12095. return;
  12096. }
  12097. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].forEach(this.annotatedGuiListeners, function (e) {
  12098. e.element.removeEventListener(e.eventName, e.listener);
  12099. });
  12100. this.annotatedGuiListeners = [];
  12101. };
  12102. Component.prototype.getGui = function () {
  12103. return this.eGui;
  12104. };
  12105. Component.prototype.getFocusableElement = function () {
  12106. return this.eGui;
  12107. };
  12108. Component.prototype.setParentComponent = function (component) {
  12109. this.parentComponent = component;
  12110. };
  12111. Component.prototype.getParentComponent = function () {
  12112. return this.parentComponent;
  12113. };
  12114. // this method is for older code, that wants to provide the gui element,
  12115. // it is not intended for this to be in ag-Stack
  12116. Component.prototype.setGui = function (eGui) {
  12117. this.eGui = eGui;
  12118. };
  12119. Component.prototype.queryForHtmlElement = function (cssSelector) {
  12120. return this.eGui.querySelector(cssSelector);
  12121. };
  12122. Component.prototype.queryForHtmlInputElement = function (cssSelector) {
  12123. return this.eGui.querySelector(cssSelector);
  12124. };
  12125. Component.prototype.appendChild = function (newChild, container) {
  12126. if (!container) {
  12127. container = this.eGui;
  12128. }
  12129. if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].isNodeOrElement(newChild)) {
  12130. container.appendChild(newChild);
  12131. }
  12132. else {
  12133. var childComponent = newChild;
  12134. container.appendChild(childComponent.getGui());
  12135. this.addDestroyFunc(this.destroyBean.bind(this, childComponent));
  12136. }
  12137. };
  12138. Component.prototype.isDisplayed = function () {
  12139. return this.displayed;
  12140. };
  12141. Component.prototype.setVisible = function (visible) {
  12142. if (visible !== this.visible) {
  12143. this.visible = visible;
  12144. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].setVisible(this.eGui, visible);
  12145. }
  12146. };
  12147. Component.prototype.setDisplayed = function (displayed) {
  12148. if (displayed !== this.displayed) {
  12149. this.displayed = displayed;
  12150. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].setDisplayed(this.eGui, displayed);
  12151. var event_1 = {
  12152. type: Component.EVENT_DISPLAYED_CHANGED,
  12153. visible: this.displayed
  12154. };
  12155. this.dispatchEvent(event_1);
  12156. }
  12157. };
  12158. Component.prototype.destroy = function () {
  12159. this.removeAnnotatedGuiEventListeners();
  12160. _super.prototype.destroy.call(this);
  12161. };
  12162. Component.prototype.addGuiEventListener = function (event, listener) {
  12163. var _this = this;
  12164. this.eGui.addEventListener(event, listener);
  12165. this.addDestroyFunc(function () { return _this.eGui.removeEventListener(event, listener); });
  12166. };
  12167. Component.prototype.addCssClass = function (className) {
  12168. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(this.eGui, className);
  12169. };
  12170. Component.prototype.removeCssClass = function (className) {
  12171. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].removeCssClass(this.eGui, className);
  12172. };
  12173. Component.prototype.addOrRemoveCssClass = function (className, addOrRemove) {
  12174. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addOrRemoveCssClass(this.eGui, className, addOrRemove);
  12175. };
  12176. Component.prototype.getAttribute = function (key) {
  12177. var eGui = this.eGui;
  12178. return eGui ? eGui.getAttribute(key) : null;
  12179. };
  12180. Component.prototype.getRefElement = function (refName) {
  12181. return this.queryForHtmlElement("[ref=\"" + refName + "\"]");
  12182. };
  12183. Component.EVENT_DISPLAYED_CHANGED = 'displayedChanged';
  12184. __decorate([
  12185. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('agStackComponentsRegistry')
  12186. ], Component.prototype, "agStackComponentsRegistry", void 0);
  12187. __decorate([
  12188. _context_context__WEBPACK_IMPORTED_MODULE_0__["PreConstruct"]
  12189. ], Component.prototype, "createChildComponentsPreConstruct", null);
  12190. __decorate([
  12191. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  12192. ], Component.prototype, "addAnnotatedGridEventListeners", null);
  12193. return Component;
  12194. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  12195. /***/ }),
  12196. /* 57 */
  12197. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  12198. "use strict";
  12199. __webpack_require__.r(__webpack_exports__);
  12200. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "QuerySelector", function() { return QuerySelector; });
  12201. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RefSelector", function() { return RefSelector; });
  12202. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridListener", function() { return GridListener; });
  12203. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GuiListener", function() { return GuiListener; });
  12204. /**
  12205. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  12206. * @version v23.2.1
  12207. * @link http://www.ag-grid.com/
  12208. * @license MIT
  12209. */
  12210. function QuerySelector(selector) {
  12211. return querySelectorFunc.bind(this, selector);
  12212. }
  12213. function RefSelector(ref) {
  12214. return querySelectorFunc.bind(this, "[ref=" + ref + "]");
  12215. }
  12216. function querySelectorFunc(selector, classPrototype, methodOrAttributeName, index) {
  12217. if (selector === null) {
  12218. console.error("ag-Grid: QuerySelector selector should not be null");
  12219. return;
  12220. }
  12221. if (typeof index === "number") {
  12222. console.error("ag-Grid: QuerySelector should be on an attribute");
  12223. return;
  12224. }
  12225. addToObjectProps(classPrototype, 'querySelectors', {
  12226. attributeName: methodOrAttributeName,
  12227. querySelector: selector
  12228. });
  12229. }
  12230. // think we should take this out, put property bindings on the
  12231. function GridListener(eventName) {
  12232. return gridListenerFunc.bind(this, eventName);
  12233. }
  12234. function gridListenerFunc(eventName, target, methodName) {
  12235. if (eventName == null) {
  12236. console.error("ag-Grid: GridListener eventName is missing");
  12237. return;
  12238. }
  12239. addToObjectProps(target, 'gridListenerMethods', {
  12240. methodName: methodName,
  12241. eventName: eventName
  12242. });
  12243. }
  12244. // think we should take this out, put property bindings on the
  12245. function GuiListener(ref, eventName) {
  12246. return guiListenerFunc.bind(this, ref, eventName);
  12247. }
  12248. function guiListenerFunc(ref, eventName, target, methodName) {
  12249. if (eventName == null) {
  12250. console.error("ag-Grid: GuiListener eventName is missing");
  12251. return;
  12252. }
  12253. addToObjectProps(target, 'guiListenerMethods', {
  12254. methodName: methodName,
  12255. eventName: eventName,
  12256. ref: ref
  12257. });
  12258. }
  12259. // // think we should take this out, put property bindings on the
  12260. // export function Method(eventName?: string): Function {
  12261. // return methodFunc.bind(this, eventName);
  12262. // }
  12263. //
  12264. // function methodFunc(alias: string, target: Object, methodName: string) {
  12265. // if (alias === null) {
  12266. // console.error("ag-Grid: EventListener eventName should not be null");
  12267. // return;
  12268. // }
  12269. //
  12270. // addToObjectProps(target, 'methods', {
  12271. // methodName: methodName,
  12272. // alias: alias
  12273. // });
  12274. // }
  12275. function addToObjectProps(target, key, value) {
  12276. // it's an attribute on the class
  12277. var props = getOrCreateProps(target, target.constructor.name);
  12278. if (!props[key]) {
  12279. props[key] = [];
  12280. }
  12281. props[key].push(value);
  12282. }
  12283. function getOrCreateProps(target, instanceName) {
  12284. if (!target.__agComponentMetaData) {
  12285. target.__agComponentMetaData = {};
  12286. }
  12287. if (!target.__agComponentMetaData[instanceName]) {
  12288. target.__agComponentMetaData[instanceName] = {};
  12289. }
  12290. return target.__agComponentMetaData[instanceName];
  12291. }
  12292. /***/ }),
  12293. /* 58 */
  12294. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  12295. "use strict";
  12296. __webpack_require__.r(__webpack_exports__);
  12297. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DateFilter", function() { return DateFilter; });
  12298. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57);
  12299. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  12300. /* harmony import */ var _dateCompWrapper__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(59);
  12301. /* harmony import */ var _simpleFilter__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(60);
  12302. /* harmony import */ var _scalarFilter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(63);
  12303. /* harmony import */ var _utils_date__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(18);
  12304. /* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(12);
  12305. /**
  12306. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  12307. * @version v23.2.1
  12308. * @link http://www.ag-grid.com/
  12309. * @license MIT
  12310. */
  12311. var __extends = (undefined && undefined.__extends) || (function () {
  12312. var extendStatics = function (d, b) {
  12313. extendStatics = Object.setPrototypeOf ||
  12314. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  12315. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  12316. return extendStatics(d, b);
  12317. };
  12318. return function (d, b) {
  12319. extendStatics(d, b);
  12320. function __() { this.constructor = d; }
  12321. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  12322. };
  12323. })();
  12324. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  12325. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  12326. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  12327. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  12328. return c > 3 && r && Object.defineProperty(target, key, r), r;
  12329. };
  12330. var DateFilter = /** @class */ (function (_super) {
  12331. __extends(DateFilter, _super);
  12332. function DateFilter() {
  12333. return _super !== null && _super.apply(this, arguments) || this;
  12334. }
  12335. DateFilter.prototype.mapRangeFromModel = function (filterModel) {
  12336. // unlike the other filters, we do two things here:
  12337. // 1) allow for different attribute names (same as done for other filters) (eg the 'from' and 'to'
  12338. // are in different locations in Date and Number filter models)
  12339. // 2) convert the type (because Date filter uses Dates, however model is 'string')
  12340. //
  12341. // NOTE: The conversion of string to date also removes the timezone - i.e. when user picks
  12342. // a date from the UI, it will have timezone info in it. This is lost when creating
  12343. // the model. When we recreate the date again here, it's without a timezone.
  12344. return {
  12345. from: Object(_utils_date__WEBPACK_IMPORTED_MODULE_5__["parseDateTimeFromString"])(filterModel.dateFrom),
  12346. to: Object(_utils_date__WEBPACK_IMPORTED_MODULE_5__["parseDateTimeFromString"])(filterModel.dateTo)
  12347. };
  12348. };
  12349. DateFilter.prototype.setValueFromFloatingFilter = function (value) {
  12350. if (value != null) {
  12351. var dateFrom = Object(_utils_date__WEBPACK_IMPORTED_MODULE_5__["parseDateTimeFromString"])(value);
  12352. this.dateCondition1FromComp.setDate(dateFrom);
  12353. }
  12354. else {
  12355. this.dateCondition1FromComp.setDate(null);
  12356. }
  12357. this.dateCondition1ToComp.setDate(null);
  12358. this.dateCondition2FromComp.setDate(null);
  12359. this.dateCondition2ToComp.setDate(null);
  12360. };
  12361. DateFilter.prototype.setConditionIntoUi = function (model, position) {
  12362. var _a = model ?
  12363. [Object(_utils_date__WEBPACK_IMPORTED_MODULE_5__["parseDateTimeFromString"])(model.dateFrom), Object(_utils_date__WEBPACK_IMPORTED_MODULE_5__["parseDateTimeFromString"])(model.dateTo)] :
  12364. [null, null], dateFrom = _a[0], dateTo = _a[1];
  12365. var _b = this.getFromToComponents(position), compFrom = _b[0], compTo = _b[1];
  12366. compFrom.setDate(dateFrom);
  12367. compTo.setDate(dateTo);
  12368. };
  12369. DateFilter.prototype.resetUiToDefaults = function (silent) {
  12370. var _this = this;
  12371. return _super.prototype.resetUiToDefaults.call(this, silent).then(function () {
  12372. _this.dateCondition1FromComp.setDate(null);
  12373. _this.dateCondition1ToComp.setDate(null);
  12374. _this.dateCondition2FromComp.setDate(null);
  12375. _this.dateCondition2ToComp.setDate(null);
  12376. });
  12377. };
  12378. DateFilter.prototype.comparator = function () {
  12379. return this.dateFilterParams.comparator ? this.dateFilterParams.comparator : this.defaultComparator.bind(this);
  12380. };
  12381. DateFilter.prototype.defaultComparator = function (filterDate, cellValue) {
  12382. // The default comparator assumes that the cellValue is a date
  12383. var cellAsDate = cellValue;
  12384. if (cellValue == null || cellAsDate < filterDate) {
  12385. return -1;
  12386. }
  12387. if (cellAsDate > filterDate) {
  12388. return 1;
  12389. }
  12390. return 0;
  12391. };
  12392. DateFilter.prototype.setParams = function (params) {
  12393. _super.prototype.setParams.call(this, params);
  12394. this.dateFilterParams = params;
  12395. this.createDateComponents();
  12396. };
  12397. DateFilter.prototype.createDateComponents = function () {
  12398. var _this = this;
  12399. // params to pass to all four date comps
  12400. var dateComponentParams = {
  12401. onDateChanged: function () { return _this.onUiChanged(); },
  12402. filterParams: this.dateFilterParams
  12403. };
  12404. this.dateCondition1FromComp = new _dateCompWrapper__WEBPACK_IMPORTED_MODULE_2__["DateCompWrapper"](this.getContext(), this.userComponentFactory, dateComponentParams, this.eCondition1PanelFrom);
  12405. this.dateCondition1ToComp = new _dateCompWrapper__WEBPACK_IMPORTED_MODULE_2__["DateCompWrapper"](this.getContext(), this.userComponentFactory, dateComponentParams, this.eCondition1PanelTo);
  12406. this.dateCondition2FromComp = new _dateCompWrapper__WEBPACK_IMPORTED_MODULE_2__["DateCompWrapper"](this.getContext(), this.userComponentFactory, dateComponentParams, this.eCondition2PanelFrom);
  12407. this.dateCondition2ToComp = new _dateCompWrapper__WEBPACK_IMPORTED_MODULE_2__["DateCompWrapper"](this.getContext(), this.userComponentFactory, dateComponentParams, this.eCondition2PanelTo);
  12408. this.addDestroyFunc(function () {
  12409. _this.dateCondition1FromComp.destroy();
  12410. _this.dateCondition1ToComp.destroy();
  12411. _this.dateCondition2FromComp.destroy();
  12412. _this.dateCondition2ToComp.destroy();
  12413. });
  12414. };
  12415. DateFilter.prototype.getDefaultFilterOptions = function () {
  12416. return DateFilter.DEFAULT_FILTER_OPTIONS;
  12417. };
  12418. DateFilter.prototype.createValueTemplate = function (position) {
  12419. var pos = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_3__["ConditionPosition"].One ? '1' : '2';
  12420. return /* html */ "\n <div class=\"ag-filter-body\" ref=\"eCondition" + pos + "Body\">\n <div class=\"ag-filter-from ag-filter-date-from\" ref=\"eCondition" + pos + "PanelFrom\">\n </div>\n <div class=\"ag-filter-to ag-filter-date-to\" ref=\"eCondition" + pos + "PanelTo\">\n </div>\n </div>";
  12421. };
  12422. DateFilter.prototype.isConditionUiComplete = function (position) {
  12423. var positionOne = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_3__["ConditionPosition"].One;
  12424. var option = positionOne ? this.getCondition1Type() : this.getCondition2Type();
  12425. if (option === _simpleFilter__WEBPACK_IMPORTED_MODULE_3__["SimpleFilter"].EMPTY) {
  12426. return false;
  12427. }
  12428. if (this.doesFilterHaveHiddenInput(option)) {
  12429. return true;
  12430. }
  12431. var _a = this.getFromToComponents(position), compFrom = _a[0], compTo = _a[1];
  12432. return compFrom.getDate() != null && (option !== _simpleFilter__WEBPACK_IMPORTED_MODULE_3__["SimpleFilter"].IN_RANGE || compTo.getDate() != null);
  12433. };
  12434. DateFilter.prototype.areSimpleModelsEqual = function (aSimple, bSimple) {
  12435. return aSimple.dateFrom === bSimple.dateFrom
  12436. && aSimple.dateTo === bSimple.dateTo
  12437. && aSimple.type === bSimple.type;
  12438. };
  12439. // needed for creating filter model
  12440. DateFilter.prototype.getFilterType = function () {
  12441. return DateFilter.FILTER_TYPE;
  12442. };
  12443. DateFilter.prototype.createCondition = function (position) {
  12444. var positionOne = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_3__["ConditionPosition"].One;
  12445. var type = positionOne ? this.getCondition1Type() : this.getCondition2Type();
  12446. var _a = this.getFromToComponents(position), compFrom = _a[0], compTo = _a[1];
  12447. return {
  12448. dateFrom: Object(_utils_date__WEBPACK_IMPORTED_MODULE_5__["serialiseDate"])(compFrom.getDate()),
  12449. dateTo: Object(_utils_date__WEBPACK_IMPORTED_MODULE_5__["serialiseDate"])(compTo.getDate()),
  12450. type: type,
  12451. filterType: DateFilter.FILTER_TYPE
  12452. };
  12453. };
  12454. DateFilter.prototype.resetPlaceholder = function () {
  12455. var translate = this.gridOptionsWrapper.getLocaleTextFunc();
  12456. var placeholder = translate('dateFormatOoo', 'yyyy-mm-dd');
  12457. this.dateCondition1FromComp.setInputPlaceholder(placeholder);
  12458. this.dateCondition1ToComp.setInputPlaceholder(placeholder);
  12459. this.dateCondition2FromComp.setInputPlaceholder(placeholder);
  12460. this.dateCondition2ToComp.setInputPlaceholder(placeholder);
  12461. };
  12462. DateFilter.prototype.updateUiVisibility = function () {
  12463. _super.prototype.updateUiVisibility.call(this);
  12464. this.resetPlaceholder();
  12465. var condition1Type = this.getCondition1Type();
  12466. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["setDisplayed"])(this.eCondition1PanelFrom, this.showValueFrom(condition1Type));
  12467. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["setDisplayed"])(this.eCondition1PanelTo, this.showValueTo(condition1Type));
  12468. var condition2Type = this.getCondition2Type();
  12469. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["setDisplayed"])(this.eCondition2PanelFrom, this.showValueFrom(condition2Type));
  12470. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["setDisplayed"])(this.eCondition2PanelTo, this.showValueTo(condition2Type));
  12471. };
  12472. DateFilter.prototype.getFromToComponents = function (position) {
  12473. return position === _simpleFilter__WEBPACK_IMPORTED_MODULE_3__["ConditionPosition"].One ?
  12474. [this.dateCondition1FromComp, this.dateCondition1ToComp] :
  12475. [this.dateCondition2FromComp, this.dateCondition2ToComp];
  12476. };
  12477. DateFilter.FILTER_TYPE = 'date';
  12478. DateFilter.DEFAULT_FILTER_OPTIONS = [
  12479. _scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"].EQUALS,
  12480. _scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"].GREATER_THAN,
  12481. _scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"].LESS_THAN,
  12482. _scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"].NOT_EQUAL,
  12483. _scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"].IN_RANGE
  12484. ];
  12485. __decorate([
  12486. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eCondition1PanelFrom')
  12487. ], DateFilter.prototype, "eCondition1PanelFrom", void 0);
  12488. __decorate([
  12489. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eCondition1PanelTo')
  12490. ], DateFilter.prototype, "eCondition1PanelTo", void 0);
  12491. __decorate([
  12492. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eCondition2PanelFrom')
  12493. ], DateFilter.prototype, "eCondition2PanelFrom", void 0);
  12494. __decorate([
  12495. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eCondition2PanelTo')
  12496. ], DateFilter.prototype, "eCondition2PanelTo", void 0);
  12497. __decorate([
  12498. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('userComponentFactory')
  12499. ], DateFilter.prototype, "userComponentFactory", void 0);
  12500. return DateFilter;
  12501. }(_scalarFilter__WEBPACK_IMPORTED_MODULE_4__["ScalarFilter"]));
  12502. /***/ }),
  12503. /* 59 */
  12504. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  12505. "use strict";
  12506. __webpack_require__.r(__webpack_exports__);
  12507. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DateCompWrapper", function() { return DateCompWrapper; });
  12508. /**
  12509. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  12510. * @version v23.2.1
  12511. * @link http://www.ag-grid.com/
  12512. * @license MIT
  12513. */
  12514. /** Provides sync access to async component. Date component can be lazy created - this class encapsulates
  12515. * this by keeping value locally until DateComp has loaded, then passing DateComp the value. */
  12516. var DateCompWrapper = /** @class */ (function () {
  12517. function DateCompWrapper(context, userComponentFactory, dateComponentParams, eParent) {
  12518. var _this = this;
  12519. this.alive = true;
  12520. this.context = context;
  12521. userComponentFactory.newDateComponent(dateComponentParams).then(function (dateComp) {
  12522. // because async, check the filter still exists after component comes back
  12523. if (!_this.alive) {
  12524. context.destroyBean(dateComp);
  12525. return;
  12526. }
  12527. _this.dateComp = dateComp;
  12528. eParent.appendChild(dateComp.getGui());
  12529. if (dateComp.afterGuiAttached) {
  12530. dateComp.afterGuiAttached();
  12531. }
  12532. if (_this.tempValue) {
  12533. dateComp.setDate(_this.tempValue);
  12534. }
  12535. });
  12536. }
  12537. DateCompWrapper.prototype.destroy = function () {
  12538. this.alive = false;
  12539. this.dateComp = this.context.destroyBean(this.dateComp);
  12540. };
  12541. DateCompWrapper.prototype.getDate = function () {
  12542. return this.dateComp ? this.dateComp.getDate() : this.tempValue;
  12543. };
  12544. DateCompWrapper.prototype.setDate = function (value) {
  12545. if (this.dateComp) {
  12546. this.dateComp.setDate(value);
  12547. }
  12548. else {
  12549. this.tempValue = value;
  12550. }
  12551. };
  12552. DateCompWrapper.prototype.setInputPlaceholder = function (placeholder) {
  12553. if (this.dateComp && this.dateComp.setInputPlaceholder) {
  12554. this.dateComp.setInputPlaceholder(placeholder);
  12555. }
  12556. };
  12557. return DateCompWrapper;
  12558. }());
  12559. /***/ }),
  12560. /* 60 */
  12561. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  12562. "use strict";
  12563. __webpack_require__.r(__webpack_exports__);
  12564. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ConditionPosition", function() { return ConditionPosition; });
  12565. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SimpleFilter", function() { return SimpleFilter; });
  12566. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57);
  12567. /* harmony import */ var _optionsFactory__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(61);
  12568. /* harmony import */ var _providedFilter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(62);
  12569. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  12570. /* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(17);
  12571. /* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(12);
  12572. /**
  12573. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  12574. * @version v23.2.1
  12575. * @link http://www.ag-grid.com/
  12576. * @license MIT
  12577. */
  12578. var __extends = (undefined && undefined.__extends) || (function () {
  12579. var extendStatics = function (d, b) {
  12580. extendStatics = Object.setPrototypeOf ||
  12581. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  12582. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  12583. return extendStatics(d, b);
  12584. };
  12585. return function (d, b) {
  12586. extendStatics(d, b);
  12587. function __() { this.constructor = d; }
  12588. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  12589. };
  12590. })();
  12591. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  12592. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  12593. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  12594. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  12595. return c > 3 && r && Object.defineProperty(target, key, r), r;
  12596. };
  12597. var ConditionPosition;
  12598. (function (ConditionPosition) {
  12599. ConditionPosition[ConditionPosition["One"] = 0] = "One";
  12600. ConditionPosition[ConditionPosition["Two"] = 1] = "Two";
  12601. })(ConditionPosition || (ConditionPosition = {}));
  12602. var DEFAULT_TRANSLATIONS = {
  12603. filterOoo: 'Filter...',
  12604. empty: 'Choose One',
  12605. equals: 'Equals',
  12606. notEqual: 'Not equal',
  12607. lessThan: 'Less than',
  12608. greaterThan: 'Greater than',
  12609. inRange: 'In range',
  12610. inRangeStart: 'From',
  12611. inRangeEnd: 'To',
  12612. lessThanOrEqual: 'Less than or equals',
  12613. greaterThanOrEqual: 'Greater than or equals',
  12614. contains: 'Contains',
  12615. notContains: 'Not contains',
  12616. startsWith: 'Starts with',
  12617. endsWith: 'Ends with',
  12618. andCondition: 'AND',
  12619. orCondition: 'OR',
  12620. };
  12621. /**
  12622. * Every filter with a dropdown where the user can specify a comparing type against the filter values
  12623. */
  12624. var SimpleFilter = /** @class */ (function (_super) {
  12625. __extends(SimpleFilter, _super);
  12626. function SimpleFilter() {
  12627. return _super !== null && _super.apply(this, arguments) || this;
  12628. }
  12629. // returns true if this type requires a 'from' field, eg any filter that requires at least one text value
  12630. SimpleFilter.prototype.showValueFrom = function (type) {
  12631. return !this.doesFilterHaveHiddenInput(type) && type !== SimpleFilter.EMPTY;
  12632. };
  12633. // returns true if this type requires a 'to' field, currently only 'range' returns true
  12634. SimpleFilter.prototype.showValueTo = function (type) {
  12635. return type === SimpleFilter.IN_RANGE;
  12636. };
  12637. // floating filter calls this when user applies filter from floating filter
  12638. SimpleFilter.prototype.onFloatingFilterChanged = function (type, value) {
  12639. this.setTypeFromFloatingFilter(type);
  12640. this.setValueFromFloatingFilter(value);
  12641. this.onUiChanged(true);
  12642. };
  12643. SimpleFilter.prototype.setTypeFromFloatingFilter = function (type) {
  12644. this.eType1.setValue(type);
  12645. this.eType2.setValue(this.optionsFactory.getDefaultOption());
  12646. this.eJoinOperatorAnd.setValue(true);
  12647. };
  12648. SimpleFilter.prototype.getModelFromUi = function () {
  12649. if (!this.isConditionUiComplete(ConditionPosition.One)) {
  12650. return null;
  12651. }
  12652. if (this.isAllowTwoConditions() && this.isConditionUiComplete(ConditionPosition.Two)) {
  12653. return {
  12654. filterType: this.getFilterType(),
  12655. operator: this.getJoinOperator(),
  12656. condition1: this.createCondition(ConditionPosition.One),
  12657. condition2: this.createCondition(ConditionPosition.Two)
  12658. };
  12659. }
  12660. return this.createCondition(ConditionPosition.One);
  12661. };
  12662. SimpleFilter.prototype.getCondition1Type = function () {
  12663. return this.eType1.getValue();
  12664. };
  12665. SimpleFilter.prototype.getCondition2Type = function () {
  12666. return this.eType2.getValue();
  12667. };
  12668. SimpleFilter.prototype.getJoinOperator = function () {
  12669. return this.eJoinOperatorOr.getValue() === true ? 'OR' : 'AND';
  12670. };
  12671. SimpleFilter.prototype.areModelsEqual = function (a, b) {
  12672. // both are missing
  12673. if (!a && !b) {
  12674. return true;
  12675. }
  12676. // one is missing, other present
  12677. if ((!a && b) || (a && !b)) {
  12678. return false;
  12679. }
  12680. // one is combined, the other is not
  12681. var aIsSimple = !a.operator;
  12682. var bIsSimple = !b.operator;
  12683. var oneSimpleOneCombined = (!aIsSimple && bIsSimple) || (aIsSimple && !bIsSimple);
  12684. if (oneSimpleOneCombined) {
  12685. return false;
  12686. }
  12687. var res;
  12688. // otherwise both present, so compare
  12689. if (aIsSimple) {
  12690. var aSimple = a;
  12691. var bSimple = b;
  12692. res = this.areSimpleModelsEqual(aSimple, bSimple);
  12693. }
  12694. else {
  12695. var aCombined = a;
  12696. var bCombined = b;
  12697. res = aCombined.operator === bCombined.operator
  12698. && this.areSimpleModelsEqual(aCombined.condition1, bCombined.condition1)
  12699. && this.areSimpleModelsEqual(aCombined.condition2, bCombined.condition2);
  12700. }
  12701. return res;
  12702. };
  12703. SimpleFilter.prototype.setModelIntoUi = function (model) {
  12704. var isCombined = model.operator;
  12705. if (isCombined) {
  12706. var combinedModel = model;
  12707. var orChecked = combinedModel.operator === 'OR';
  12708. this.eJoinOperatorAnd.setValue(!orChecked);
  12709. this.eJoinOperatorOr.setValue(orChecked);
  12710. this.eType1.setValue(combinedModel.condition1.type);
  12711. this.eType2.setValue(combinedModel.condition2.type);
  12712. this.setConditionIntoUi(combinedModel.condition1, ConditionPosition.One);
  12713. this.setConditionIntoUi(combinedModel.condition2, ConditionPosition.Two);
  12714. }
  12715. else {
  12716. var simpleModel = model;
  12717. this.eJoinOperatorAnd.setValue(true);
  12718. this.eJoinOperatorOr.setValue(false);
  12719. this.eType1.setValue(simpleModel.type);
  12720. this.eType2.setValue(this.optionsFactory.getDefaultOption());
  12721. this.setConditionIntoUi(simpleModel, ConditionPosition.One);
  12722. this.setConditionIntoUi(null, ConditionPosition.Two);
  12723. }
  12724. return _utils__WEBPACK_IMPORTED_MODULE_3__["Promise"].resolve();
  12725. };
  12726. SimpleFilter.prototype.doesFilterPass = function (params) {
  12727. var model = this.getModel();
  12728. var isCombined = model.operator;
  12729. if (isCombined) {
  12730. var combinedModel = model;
  12731. var firstResult = this.individualConditionPasses(params, combinedModel.condition1);
  12732. var secondResult = this.individualConditionPasses(params, combinedModel.condition2);
  12733. if (combinedModel.operator === 'AND') {
  12734. return firstResult && secondResult;
  12735. }
  12736. return firstResult || secondResult;
  12737. }
  12738. var simpleModel = model;
  12739. var result = this.individualConditionPasses(params, simpleModel);
  12740. return result;
  12741. };
  12742. SimpleFilter.prototype.setParams = function (params) {
  12743. _super.prototype.setParams.call(this, params);
  12744. this.optionsFactory = new _optionsFactory__WEBPACK_IMPORTED_MODULE_1__["OptionsFactory"]();
  12745. this.optionsFactory.init(params, this.getDefaultFilterOptions());
  12746. this.allowTwoConditions = !params.suppressAndOrCondition;
  12747. this.putOptionsIntoDropdown();
  12748. this.addChangedListeners();
  12749. };
  12750. SimpleFilter.prototype.putOptionsIntoDropdown = function () {
  12751. var _this = this;
  12752. var filterOptions = this.optionsFactory.getFilterOptions();
  12753. Object(_utils_array__WEBPACK_IMPORTED_MODULE_4__["forEach"])(filterOptions, function (option) {
  12754. var value;
  12755. var text;
  12756. if (typeof option === 'string') {
  12757. value = option;
  12758. text = _this.translate(value);
  12759. }
  12760. else {
  12761. value = option.displayKey;
  12762. var customOption = _this.optionsFactory.getCustomOption(value);
  12763. text = customOption ? customOption.displayName : _this.translate(value);
  12764. }
  12765. var createOption = function () { return ({ value: value, text: text }); };
  12766. _this.eType1.addOption(createOption());
  12767. _this.eType2.addOption(createOption());
  12768. });
  12769. var readOnly = filterOptions.length <= 1;
  12770. this.eType1.setDisabled(readOnly);
  12771. this.eType2.setDisabled(readOnly);
  12772. };
  12773. SimpleFilter.prototype.isAllowTwoConditions = function () {
  12774. return this.allowTwoConditions;
  12775. };
  12776. SimpleFilter.prototype.createBodyTemplate = function () {
  12777. return /* html */ "\n <ag-select class=\"ag-filter-select\" ref=\"eOptions1\"></ag-select>\n " + this.createValueTemplate(ConditionPosition.One) + "\n <div class=\"ag-filter-condition\" ref=\"eJoinOperatorPanel\">\n <ag-radio-button ref=\"eJoinOperatorAnd\" class=\"ag-filter-condition-operator ag-filter-condition-operator-and\"></ag-radio-button>\n <ag-radio-button ref=\"eJoinOperatorOr\" class=\"ag-filter-condition-operator ag-filter-condition-operator-or\"></ag-radio-button>\n </div>\n <ag-select class=\"ag-filter-select\" ref=\"eOptions2\"></ag-select>\n " + this.createValueTemplate(ConditionPosition.Two);
  12778. };
  12779. SimpleFilter.prototype.getCssIdentifier = function () {
  12780. return 'simple-filter';
  12781. };
  12782. SimpleFilter.prototype.updateUiVisibility = function () {
  12783. var firstConditionComplete = this.isConditionUiComplete(ConditionPosition.One);
  12784. var showSecondFilter = this.allowTwoConditions && firstConditionComplete;
  12785. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["setDisplayed"])(this.eCondition2Body, showSecondFilter);
  12786. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["setDisplayed"])(this.eType2.getGui(), showSecondFilter);
  12787. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["setDisplayed"])(this.eJoinOperatorPanel, showSecondFilter);
  12788. };
  12789. SimpleFilter.prototype.resetUiToDefaults = function (silent) {
  12790. var uniqueGroupId = 'ag-simple-filter-and-or-' + this.getCompId();
  12791. var defaultOption = this.optionsFactory.getDefaultOption();
  12792. this.eType1.setValue(defaultOption, silent);
  12793. this.eType2.setValue(defaultOption, silent);
  12794. this.eJoinOperatorAnd
  12795. .setValue(true, silent)
  12796. .setName(uniqueGroupId)
  12797. .setLabel(this.translate('andCondition'));
  12798. this.eJoinOperatorOr
  12799. .setValue(false, silent)
  12800. .setName(uniqueGroupId)
  12801. .setLabel(this.translate('orCondition'));
  12802. return _utils__WEBPACK_IMPORTED_MODULE_3__["Promise"].resolve();
  12803. };
  12804. SimpleFilter.prototype.translate = function (toTranslate) {
  12805. var translate = this.gridOptionsWrapper.getLocaleTextFunc();
  12806. return translate(toTranslate, DEFAULT_TRANSLATIONS[toTranslate]);
  12807. };
  12808. SimpleFilter.prototype.addChangedListeners = function () {
  12809. var _this = this;
  12810. var listener = function () { return _this.onUiChanged(); };
  12811. this.eType1.onValueChange(listener);
  12812. this.eType2.onValueChange(listener);
  12813. this.eJoinOperatorOr.onValueChange(listener);
  12814. this.eJoinOperatorAnd.onValueChange(listener);
  12815. };
  12816. SimpleFilter.prototype.doesFilterHaveHiddenInput = function (filterType) {
  12817. var customFilterOption = this.optionsFactory.getCustomOption(filterType);
  12818. return customFilterOption && customFilterOption.hideFilterInput;
  12819. };
  12820. SimpleFilter.EMPTY = 'empty';
  12821. SimpleFilter.EQUALS = 'equals';
  12822. SimpleFilter.NOT_EQUAL = 'notEqual';
  12823. SimpleFilter.LESS_THAN = 'lessThan';
  12824. SimpleFilter.LESS_THAN_OR_EQUAL = 'lessThanOrEqual';
  12825. SimpleFilter.GREATER_THAN = 'greaterThan';
  12826. SimpleFilter.GREATER_THAN_OR_EQUAL = 'greaterThanOrEqual';
  12827. SimpleFilter.IN_RANGE = 'inRange';
  12828. SimpleFilter.CONTAINS = 'contains';
  12829. SimpleFilter.NOT_CONTAINS = 'notContains';
  12830. SimpleFilter.STARTS_WITH = 'startsWith';
  12831. SimpleFilter.ENDS_WITH = 'endsWith';
  12832. __decorate([
  12833. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eOptions1')
  12834. ], SimpleFilter.prototype, "eType1", void 0);
  12835. __decorate([
  12836. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eOptions2')
  12837. ], SimpleFilter.prototype, "eType2", void 0);
  12838. __decorate([
  12839. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eJoinOperatorAnd')
  12840. ], SimpleFilter.prototype, "eJoinOperatorAnd", void 0);
  12841. __decorate([
  12842. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eJoinOperatorOr')
  12843. ], SimpleFilter.prototype, "eJoinOperatorOr", void 0);
  12844. __decorate([
  12845. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eCondition2Body')
  12846. ], SimpleFilter.prototype, "eCondition2Body", void 0);
  12847. __decorate([
  12848. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eJoinOperatorPanel')
  12849. ], SimpleFilter.prototype, "eJoinOperatorPanel", void 0);
  12850. return SimpleFilter;
  12851. }(_providedFilter__WEBPACK_IMPORTED_MODULE_2__["ProvidedFilter"]));
  12852. /***/ }),
  12853. /* 61 */
  12854. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  12855. "use strict";
  12856. __webpack_require__.r(__webpack_exports__);
  12857. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "OptionsFactory", function() { return OptionsFactory; });
  12858. /* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(17);
  12859. /**
  12860. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  12861. * @version v23.2.1
  12862. * @link http://www.ag-grid.com/
  12863. * @license MIT
  12864. */
  12865. /* Common logic for options, used by both filters and floating filters. */
  12866. var OptionsFactory = /** @class */ (function () {
  12867. function OptionsFactory() {
  12868. this.customFilterOptions = {};
  12869. }
  12870. OptionsFactory.prototype.init = function (params, defaultOptions) {
  12871. this.filterOptions = params.filterOptions || defaultOptions;
  12872. this.mapCustomOptions();
  12873. this.selectDefaultItem(params);
  12874. };
  12875. OptionsFactory.prototype.getFilterOptions = function () {
  12876. return this.filterOptions;
  12877. };
  12878. OptionsFactory.prototype.mapCustomOptions = function () {
  12879. var _this = this;
  12880. if (!this.filterOptions) {
  12881. return;
  12882. }
  12883. this.filterOptions.forEach(function (filterOption) {
  12884. if (typeof filterOption === 'string') {
  12885. return;
  12886. }
  12887. var requiredProperties = ['displayKey', 'displayName', 'test'];
  12888. if (Object(_utils_array__WEBPACK_IMPORTED_MODULE_0__["every"])(requiredProperties, function (key) {
  12889. if (!filterOption[key]) {
  12890. console.warn("ag-Grid: ignoring FilterOptionDef as it doesn't contain a '" + key + "'");
  12891. return false;
  12892. }
  12893. return true;
  12894. })) {
  12895. _this.customFilterOptions[filterOption.displayKey] = filterOption;
  12896. }
  12897. });
  12898. };
  12899. OptionsFactory.prototype.selectDefaultItem = function (params) {
  12900. if (params.defaultOption) {
  12901. this.defaultOption = params.defaultOption;
  12902. }
  12903. else if (this.filterOptions.length >= 1) {
  12904. var firstFilterOption = this.filterOptions[0];
  12905. if (typeof firstFilterOption === 'string') {
  12906. this.defaultOption = firstFilterOption;
  12907. }
  12908. else if (firstFilterOption.displayKey) {
  12909. this.defaultOption = firstFilterOption.displayKey;
  12910. }
  12911. else {
  12912. console.warn("ag-Grid: invalid FilterOptionDef supplied as it doesn't contain a 'displayKey'");
  12913. }
  12914. }
  12915. else {
  12916. console.warn('ag-Grid: no filter options for filter');
  12917. }
  12918. };
  12919. OptionsFactory.prototype.getDefaultOption = function () {
  12920. return this.defaultOption;
  12921. };
  12922. OptionsFactory.prototype.getCustomOption = function (name) {
  12923. return this.customFilterOptions[name];
  12924. };
  12925. return OptionsFactory;
  12926. }());
  12927. /***/ }),
  12928. /* 62 */
  12929. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  12930. "use strict";
  12931. __webpack_require__.r(__webpack_exports__);
  12932. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ProvidedFilter", function() { return ProvidedFilter; });
  12933. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56);
  12934. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  12935. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25);
  12936. /* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(12);
  12937. /* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(21);
  12938. /**
  12939. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  12940. * @version v23.2.1
  12941. * @link http://www.ag-grid.com/
  12942. * @license MIT
  12943. */
  12944. var __extends = (undefined && undefined.__extends) || (function () {
  12945. var extendStatics = function (d, b) {
  12946. extendStatics = Object.setPrototypeOf ||
  12947. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  12948. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  12949. return extendStatics(d, b);
  12950. };
  12951. return function (d, b) {
  12952. extendStatics(d, b);
  12953. function __() { this.constructor = d; }
  12954. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  12955. };
  12956. })();
  12957. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  12958. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  12959. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  12960. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  12961. return c > 3 && r && Object.defineProperty(target, key, r), r;
  12962. };
  12963. /**
  12964. * Contains common logic to all provided filters (apply button, clear button, etc).
  12965. * All the filters that come with ag-Grid extend this class. User filters do not
  12966. * extend this class.
  12967. */
  12968. var ProvidedFilter = /** @class */ (function (_super) {
  12969. __extends(ProvidedFilter, _super);
  12970. function ProvidedFilter() {
  12971. var _this = _super !== null && _super.apply(this, arguments) || this;
  12972. _this.applyActive = false;
  12973. _this.hidePopup = null;
  12974. // after the user hits 'apply' the model gets copied to here. this is then the model that we use for
  12975. // all filtering. so if user changes UI but doesn't hit apply, then the UI will be out of sync with this model.
  12976. // this is what we want, as the UI should only become the 'active' filter once it's applied. when apply is
  12977. // inactive, this model will be in sync (following the debounce ms). if the UI is not a valid filter
  12978. // (eg the value is missing so nothing to filter on, or for set filter all checkboxes are checked so filter
  12979. // not active) then this appliedModel will be null/undefined.
  12980. _this.appliedModel = null;
  12981. return _this;
  12982. }
  12983. /** @deprecated */
  12984. ProvidedFilter.prototype.onFilterChanged = function () {
  12985. console.warn("ag-Grid: you should not call onFilterChanged() directly on the filter, please call\n gridApi.onFilterChanged() instead. onFilterChanged is not part of the exposed filter interface (it was\n a method that existed on an old version of the filters that was not intended for public use.");
  12986. this.providedFilterParams.filterChangedCallback();
  12987. };
  12988. ProvidedFilter.prototype.isFilterActive = function () {
  12989. // filter is active if we have a valid applied model
  12990. return !!this.appliedModel;
  12991. };
  12992. ProvidedFilter.prototype.postConstruct = function () {
  12993. var templateString = /* html */ "\n <div>\n <div class=\"ag-filter-body-wrapper ag-" + this.getCssIdentifier() + "-body-wrapper\">\n " + this.createBodyTemplate() + "\n </div>\n </div>";
  12994. this.setTemplate(templateString);
  12995. };
  12996. ProvidedFilter.prototype.init = function (params) {
  12997. var _this = this;
  12998. this.setParams(params);
  12999. this.resetUiToDefaults(true).then(function () {
  13000. _this.updateUiVisibility();
  13001. _this.setupOnBtApplyDebounce();
  13002. });
  13003. };
  13004. ProvidedFilter.prototype.setParams = function (params) {
  13005. ProvidedFilter.checkForDeprecatedParams(params);
  13006. this.providedFilterParams = params;
  13007. if (params.newRowsAction === 'keep') {
  13008. this.newRowsActionKeep = true;
  13009. }
  13010. else if (params.newRowsAction === 'clear') {
  13011. this.newRowsActionKeep = false;
  13012. }
  13013. else {
  13014. // the default for SSRM and IRM is 'keep', for CSRM and VRM the default is 'clear'
  13015. var modelsForKeep = [_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE, _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].ROW_MODEL_TYPE_INFINITE];
  13016. this.newRowsActionKeep = modelsForKeep.indexOf(this.rowModel.getType()) >= 0;
  13017. }
  13018. this.applyActive = ProvidedFilter.isUseApplyButton(params);
  13019. this.createButtonPanel();
  13020. };
  13021. ProvidedFilter.prototype.createButtonPanel = function () {
  13022. var _this = this;
  13023. var buttons = this.providedFilterParams.buttons;
  13024. if (!buttons || buttons.length < 1) {
  13025. return;
  13026. }
  13027. var translate = this.gridOptionsWrapper.getLocaleTextFunc();
  13028. var eButtonsPanel = document.createElement('div');
  13029. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["addCssClass"])(eButtonsPanel, 'ag-filter-apply-panel');
  13030. var addButton = function (type) {
  13031. var text;
  13032. var clickListener;
  13033. switch (type) {
  13034. case 'apply':
  13035. text = translate('applyFilter', 'Apply Filter');
  13036. clickListener = function (e) { return _this.onBtApply(false, false, e); };
  13037. break;
  13038. case 'clear':
  13039. text = translate('clearFilter', 'Clear Filter');
  13040. clickListener = function () { return _this.onBtClear(); };
  13041. break;
  13042. case 'reset':
  13043. text = translate('resetFilter', 'Reset Filter');
  13044. clickListener = function () { return _this.onBtReset(); };
  13045. break;
  13046. case 'cancel':
  13047. text = translate('cancelFilter', 'Cancel Filter');
  13048. clickListener = function (e) { _this.onBtCancel(e); };
  13049. break;
  13050. default:
  13051. console.warn('Unknown button type specified');
  13052. return;
  13053. }
  13054. var button = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["loadTemplate"])(/* html */ "<button\n type=\"button\"\n ref=\"" + type + "FilterButton\"\n class=\"ag-standard-button ag-filter-apply-panel-button\">" + text + "</button>");
  13055. eButtonsPanel.appendChild(button);
  13056. _this.addManagedListener(button, 'click', clickListener);
  13057. };
  13058. new Set(buttons).forEach(function (type) { return addButton(type); });
  13059. this.getGui().appendChild(eButtonsPanel);
  13060. };
  13061. ProvidedFilter.checkForDeprecatedParams = function (params) {
  13062. var buttons = params.buttons || [];
  13063. if (buttons.length > 0) {
  13064. return;
  13065. }
  13066. var applyButton = params.applyButton, resetButton = params.resetButton, clearButton = params.clearButton;
  13067. if (clearButton) {
  13068. console.warn('ag-Grid: as of ag-Grid v23.2, filterParams.clearButton is deprecated. Please use filterParams.buttons instead');
  13069. buttons.push('clear');
  13070. }
  13071. if (resetButton) {
  13072. console.warn('ag-Grid: as of ag-Grid v23.2, filterParams.resetButton is deprecated. Please use filterParams.buttons instead');
  13073. buttons.push('reset');
  13074. }
  13075. if (applyButton) {
  13076. console.warn('ag-Grid: as of ag-Grid v23.2, filterParams.applyButton is deprecated. Please use filterParams.buttons instead');
  13077. buttons.push('apply');
  13078. }
  13079. if (params.apply) {
  13080. console.warn('ag-Grid: as of ag-Grid v21, filterParams.apply is deprecated. Please use filterParams.buttons instead');
  13081. buttons.push('apply');
  13082. }
  13083. params.buttons = buttons;
  13084. };
  13085. // subclasses can override this to provide alternative debounce defaults
  13086. ProvidedFilter.prototype.getDefaultDebounceMs = function () {
  13087. return 0;
  13088. };
  13089. ProvidedFilter.prototype.setupOnBtApplyDebounce = function () {
  13090. var debounceMs = ProvidedFilter.getDebounceMs(this.providedFilterParams, this.getDefaultDebounceMs());
  13091. this.onBtApplyDebounce = Object(_utils_function__WEBPACK_IMPORTED_MODULE_4__["debounce"])(this.onBtApply.bind(this), debounceMs);
  13092. };
  13093. ProvidedFilter.prototype.getModel = function () {
  13094. return this.appliedModel;
  13095. };
  13096. ProvidedFilter.prototype.setModel = function (model) {
  13097. var _this = this;
  13098. var promise = model ? this.setModelIntoUi(model) : this.resetUiToDefaults();
  13099. return promise.then(function () {
  13100. _this.updateUiVisibility();
  13101. // we set the model from the gui, rather than the provided model,
  13102. // so the model is consistent. eg handling of null/undefined will be the same,
  13103. // of if model is case insensitive, then casing is removed.
  13104. _this.applyModel();
  13105. });
  13106. };
  13107. ProvidedFilter.prototype.onBtCancel = function (e) {
  13108. var _this = this;
  13109. this.setModelIntoUi(this.getModel()).then(function () {
  13110. _this.onUiChanged(false, 'prevent');
  13111. if (_this.providedFilterParams.closeOnApply) {
  13112. _this.close(e);
  13113. }
  13114. });
  13115. };
  13116. ProvidedFilter.prototype.onBtClear = function () {
  13117. var _this = this;
  13118. this.resetUiToDefaults().then(function () { return _this.onUiChanged(); });
  13119. };
  13120. ProvidedFilter.prototype.onBtReset = function () {
  13121. this.onBtClear();
  13122. this.onBtApply();
  13123. };
  13124. /**
  13125. * Applies changes made in the UI to the filter, and returns true if the model has changed.
  13126. */
  13127. ProvidedFilter.prototype.applyModel = function () {
  13128. var newModel = this.getModelFromUi();
  13129. if (!this.isModelValid(newModel)) {
  13130. return false;
  13131. }
  13132. var previousModel = this.appliedModel;
  13133. this.appliedModel = newModel;
  13134. // models can be same if user pasted same content into text field, or maybe just changed the case
  13135. // and it's a case insensitive filter
  13136. return !this.areModelsEqual(previousModel, newModel);
  13137. };
  13138. ProvidedFilter.prototype.isModelValid = function (model) {
  13139. return true;
  13140. };
  13141. ProvidedFilter.prototype.onBtApply = function (afterFloatingFilter, afterDataChange, e) {
  13142. if (afterFloatingFilter === void 0) { afterFloatingFilter = false; }
  13143. if (afterDataChange === void 0) { afterDataChange = false; }
  13144. if (this.applyModel()) {
  13145. // the floating filter uses 'afterFloatingFilter' info, so it doesn't refresh after filter changed if change
  13146. // came from floating filter
  13147. this.providedFilterParams.filterChangedCallback({ afterFloatingFilter: afterFloatingFilter, afterDataChange: afterDataChange });
  13148. }
  13149. var closeOnApply = this.providedFilterParams.closeOnApply;
  13150. // only close if an apply button is visible, otherwise we'd be closing every time a change was made!
  13151. if (closeOnApply && !afterFloatingFilter && this.applyActive) {
  13152. this.close(e);
  13153. }
  13154. };
  13155. ProvidedFilter.prototype.onNewRowsLoaded = function () {
  13156. var _this = this;
  13157. if (!this.newRowsActionKeep) {
  13158. this.resetUiToDefaults().then(function () { return _this.appliedModel = null; });
  13159. }
  13160. };
  13161. ProvidedFilter.prototype.close = function (e) {
  13162. if (!this.hidePopup) {
  13163. return;
  13164. }
  13165. var keyboardEvent = e;
  13166. var key = keyboardEvent && keyboardEvent.key;
  13167. var params;
  13168. if (key === 'Enter' || key === 'Space') {
  13169. params = { keyboardEvent: keyboardEvent };
  13170. }
  13171. this.hidePopup(params);
  13172. this.hidePopup = null;
  13173. };
  13174. // called by set filter
  13175. ProvidedFilter.prototype.isNewRowsActionKeep = function () {
  13176. return this.newRowsActionKeep;
  13177. };
  13178. /**
  13179. * By default, if the change came from a floating filter it will be applied immediately, otherwise if there is no
  13180. * apply button it will be applied after a debounce, otherwise it will not be applied at all. This behaviour can
  13181. * be adjusted by using the apply parameter.
  13182. */
  13183. ProvidedFilter.prototype.onUiChanged = function (fromFloatingFilter, apply) {
  13184. if (fromFloatingFilter === void 0) { fromFloatingFilter = false; }
  13185. this.updateUiVisibility();
  13186. this.providedFilterParams.filterModifiedCallback();
  13187. if (this.applyActive) {
  13188. var isValid = this.isModelValid(this.getModelFromUi());
  13189. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["setDisabled"])(this.getRefElement('applyFilterButton'), !isValid);
  13190. }
  13191. if ((fromFloatingFilter && !apply) || apply === 'immediately') {
  13192. this.onBtApply(fromFloatingFilter);
  13193. }
  13194. else if ((!this.applyActive && !apply) || apply === 'debounce') {
  13195. this.onBtApplyDebounce();
  13196. }
  13197. };
  13198. ProvidedFilter.prototype.afterGuiAttached = function (params) {
  13199. this.hidePopup = params.hidePopup;
  13200. };
  13201. // static, as used by floating filter also
  13202. ProvidedFilter.getDebounceMs = function (params, debounceDefault) {
  13203. if (ProvidedFilter.isUseApplyButton(params)) {
  13204. if (params.debounceMs != null) {
  13205. console.warn('ag-Grid: debounceMs is ignored when apply button is present');
  13206. }
  13207. return 0;
  13208. }
  13209. return params.debounceMs != null ? params.debounceMs : debounceDefault;
  13210. };
  13211. // static, as used by floating filter also
  13212. ProvidedFilter.isUseApplyButton = function (params) {
  13213. ProvidedFilter.checkForDeprecatedParams(params);
  13214. return params.buttons && params.buttons.indexOf('apply') >= 0;
  13215. };
  13216. ProvidedFilter.prototype.destroy = function () {
  13217. this.hidePopup = null;
  13218. _super.prototype.destroy.call(this);
  13219. };
  13220. __decorate([
  13221. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  13222. ], ProvidedFilter.prototype, "gridOptionsWrapper", void 0);
  13223. __decorate([
  13224. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowModel')
  13225. ], ProvidedFilter.prototype, "rowModel", void 0);
  13226. __decorate([
  13227. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  13228. ], ProvidedFilter.prototype, "postConstruct", null);
  13229. return ProvidedFilter;
  13230. }(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"]));
  13231. /***/ }),
  13232. /* 63 */
  13233. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  13234. "use strict";
  13235. __webpack_require__.r(__webpack_exports__);
  13236. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ScalarFilter", function() { return ScalarFilter; });
  13237. /* harmony import */ var _simpleFilter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(60);
  13238. /**
  13239. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  13240. * @version v23.2.1
  13241. * @link http://www.ag-grid.com/
  13242. * @license MIT
  13243. */
  13244. var __extends = (undefined && undefined.__extends) || (function () {
  13245. var extendStatics = function (d, b) {
  13246. extendStatics = Object.setPrototypeOf ||
  13247. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  13248. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  13249. return extendStatics(d, b);
  13250. };
  13251. return function (d, b) {
  13252. extendStatics(d, b);
  13253. function __() { this.constructor = d; }
  13254. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  13255. };
  13256. })();
  13257. var ScalarFilter = /** @class */ (function (_super) {
  13258. __extends(ScalarFilter, _super);
  13259. function ScalarFilter() {
  13260. return _super !== null && _super.apply(this, arguments) || this;
  13261. }
  13262. ScalarFilter.prototype.setParams = function (params) {
  13263. _super.prototype.setParams.call(this, params);
  13264. this.scalarFilterParams = params;
  13265. this.checkDeprecatedParams();
  13266. };
  13267. ScalarFilter.prototype.checkDeprecatedParams = function () {
  13268. if (this.scalarFilterParams.nullComparator) {
  13269. console.warn('ag-Grid: Since v21.0, the property filterParams.nullComparator is deprecated. ' +
  13270. 'Please use filterParams.includeBlanksInEquals, filterParams.includeBlanksInLessThan and ' +
  13271. 'filterParams.includeBlanksInGreaterThan instead.');
  13272. this.scalarFilterParams.includeBlanksInEquals = this.scalarFilterParams.nullComparator.equals;
  13273. this.scalarFilterParams.includeBlanksInLessThan = this.scalarFilterParams.nullComparator.lessThan;
  13274. this.scalarFilterParams.includeBlanksInGreaterThan = this.scalarFilterParams.nullComparator.greaterThan;
  13275. }
  13276. };
  13277. ScalarFilter.prototype.nullComparator = function (selectedOption, filterValue, gridValue) {
  13278. if (gridValue == null) {
  13279. switch (selectedOption) {
  13280. case ScalarFilter.EMPTY:
  13281. return 0;
  13282. case ScalarFilter.EQUALS:
  13283. return this.scalarFilterParams.includeBlanksInEquals ? 0 : 1;
  13284. case ScalarFilter.NOT_EQUAL:
  13285. return this.scalarFilterParams.includeBlanksInEquals ? 1 : 0;
  13286. case ScalarFilter.GREATER_THAN:
  13287. case ScalarFilter.GREATER_THAN_OR_EQUAL:
  13288. return this.scalarFilterParams.includeBlanksInGreaterThan ? 1 : -1;
  13289. case ScalarFilter.LESS_THAN:
  13290. case ScalarFilter.LESS_THAN_OR_EQUAL:
  13291. return this.scalarFilterParams.includeBlanksInLessThan ? -1 : 1;
  13292. }
  13293. }
  13294. return this.comparator()(filterValue, gridValue);
  13295. };
  13296. ScalarFilter.prototype.individualConditionPasses = function (params, filterModel) {
  13297. var cellValue = this.scalarFilterParams.valueGetter(params.node);
  13298. var range = this.mapRangeFromModel(filterModel);
  13299. var filterValue = range.from;
  13300. var filterValueTo = range.to;
  13301. var filterType = filterModel.type;
  13302. var customFilterOption = this.optionsFactory.getCustomOption(filterType);
  13303. if (customFilterOption) {
  13304. // only execute the custom filter if a value exists or a value isn't required, i.e. input is hidden
  13305. if (filterValue != null || customFilterOption.hideFilterInput) {
  13306. return customFilterOption.test(filterValue, cellValue);
  13307. }
  13308. }
  13309. var compareResult = this.nullComparator(filterType, filterValue, cellValue);
  13310. switch (filterType) {
  13311. case ScalarFilter.EQUALS:
  13312. return compareResult === 0;
  13313. case ScalarFilter.NOT_EQUAL:
  13314. return compareResult !== 0;
  13315. case ScalarFilter.GREATER_THAN:
  13316. return compareResult > 0;
  13317. case ScalarFilter.GREATER_THAN_OR_EQUAL:
  13318. return compareResult >= 0;
  13319. case ScalarFilter.LESS_THAN:
  13320. return compareResult < 0;
  13321. case ScalarFilter.LESS_THAN_OR_EQUAL:
  13322. return compareResult <= 0;
  13323. case ScalarFilter.IN_RANGE: {
  13324. var compareToResult = this.nullComparator(filterType, filterValueTo, cellValue);
  13325. return this.scalarFilterParams.inRangeInclusive ?
  13326. compareResult >= 0 && compareToResult <= 0 :
  13327. compareResult > 0 && compareToResult < 0;
  13328. }
  13329. default:
  13330. throw new Error('Unexpected type of filter: ' + filterType);
  13331. }
  13332. };
  13333. return ScalarFilter;
  13334. }(_simpleFilter__WEBPACK_IMPORTED_MODULE_0__["SimpleFilter"]));
  13335. /***/ }),
  13336. /* 64 */
  13337. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  13338. "use strict";
  13339. __webpack_require__.r(__webpack_exports__);
  13340. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderComp", function() { return HeaderComp; });
  13341. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56);
  13342. /* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(35);
  13343. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37);
  13344. /* harmony import */ var _widgets_touchListener__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(65);
  13345. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(57);
  13346. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(43);
  13347. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(7);
  13348. /**
  13349. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  13350. * @version v23.2.1
  13351. * @link http://www.ag-grid.com/
  13352. * @license MIT
  13353. */
  13354. var __extends = (undefined && undefined.__extends) || (function () {
  13355. var extendStatics = function (d, b) {
  13356. extendStatics = Object.setPrototypeOf ||
  13357. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  13358. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  13359. return extendStatics(d, b);
  13360. };
  13361. return function (d, b) {
  13362. extendStatics(d, b);
  13363. function __() { this.constructor = d; }
  13364. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  13365. };
  13366. })();
  13367. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  13368. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  13369. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  13370. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  13371. return c > 3 && r && Object.defineProperty(target, key, r), r;
  13372. };
  13373. var HeaderComp = /** @class */ (function (_super) {
  13374. __extends(HeaderComp, _super);
  13375. function HeaderComp() {
  13376. var _this = _super !== null && _super.apply(this, arguments) || this;
  13377. _this.lastMovingChanged = 0;
  13378. return _this;
  13379. }
  13380. // this is a user component, and IComponent has "public destroy()" as part of the interface.
  13381. // so we need to override destroy() just to make the method public.
  13382. HeaderComp.prototype.destroy = function () {
  13383. _super.prototype.destroy.call(this);
  13384. };
  13385. HeaderComp.prototype.init = function (params) {
  13386. var template = _utils__WEBPACK_IMPORTED_MODULE_6__["_"].firstExistingValue(params.template, HeaderComp.TEMPLATE);
  13387. // take account of any newlines & whitespace before/after the actual template
  13388. template = template && template.trim ? template.trim() : template;
  13389. this.setTemplate(template);
  13390. this.params = params;
  13391. this.setupTap();
  13392. this.setupIcons(params.column);
  13393. this.setupMenu();
  13394. this.setupSort();
  13395. this.setupFilterIcon();
  13396. this.setupText(params.displayName);
  13397. };
  13398. HeaderComp.prototype.setupText = function (displayName) {
  13399. var displayNameSanitised = _utils__WEBPACK_IMPORTED_MODULE_6__["_"].escape(displayName);
  13400. if (this.eText) {
  13401. this.eText.innerHTML = displayNameSanitised;
  13402. }
  13403. };
  13404. HeaderComp.prototype.setupIcons = function (column) {
  13405. this.addInIcon('sortAscending', this.eSortAsc, column);
  13406. this.addInIcon('sortDescending', this.eSortDesc, column);
  13407. this.addInIcon('sortUnSort', this.eSortNone, column);
  13408. this.addInIcon('menu', this.eMenu, column);
  13409. this.addInIcon('filter', this.eFilter, column);
  13410. };
  13411. HeaderComp.prototype.addInIcon = function (iconName, eParent, column) {
  13412. if (eParent == null) {
  13413. return;
  13414. }
  13415. var eIcon = _utils__WEBPACK_IMPORTED_MODULE_6__["_"].createIconNoSpan(iconName, this.gridOptionsWrapper, column);
  13416. eParent.appendChild(eIcon);
  13417. };
  13418. HeaderComp.prototype.setupTap = function () {
  13419. var _this = this;
  13420. var options = this.gridOptionsWrapper;
  13421. if (options.isSuppressTouch()) {
  13422. return;
  13423. }
  13424. var touchListener = new _widgets_touchListener__WEBPACK_IMPORTED_MODULE_3__["TouchListener"](this.getGui(), true);
  13425. var suppressMenuHide = options.isSuppressMenuHide();
  13426. var tapMenuButton = suppressMenuHide && _utils__WEBPACK_IMPORTED_MODULE_6__["_"].exists(this.eMenu);
  13427. var menuTouchListener = tapMenuButton ? new _widgets_touchListener__WEBPACK_IMPORTED_MODULE_3__["TouchListener"](this.eMenu, true) : touchListener;
  13428. if (this.params.enableMenu) {
  13429. var eventType = tapMenuButton ? 'EVENT_TAP' : 'EVENT_LONG_TAP';
  13430. var showMenuFn = function (event) {
  13431. options.getApi().showColumnMenuAfterMouseClick(_this.params.column, event.touchStart);
  13432. };
  13433. this.addManagedListener(menuTouchListener, _widgets_touchListener__WEBPACK_IMPORTED_MODULE_3__["TouchListener"][eventType], showMenuFn);
  13434. }
  13435. if (this.params.enableSorting) {
  13436. var tapListener = function (event) {
  13437. var target = event.touchStart.target;
  13438. // When suppressMenuHide is true, a tap on the menu icon will bubble up
  13439. // to the header container, in that case we should not sort
  13440. if (suppressMenuHide && _this.eMenu.contains(target)) {
  13441. return;
  13442. }
  13443. _this.sortController.progressSort(_this.params.column, false, "uiColumnSorted");
  13444. };
  13445. this.addManagedListener(touchListener, _widgets_touchListener__WEBPACK_IMPORTED_MODULE_3__["TouchListener"].EVENT_TAP, tapListener);
  13446. }
  13447. // if tapMenuButton is true `touchListener` and `menuTouchListener` are different
  13448. // so we need to make sure to destroy both listeners here
  13449. this.addDestroyFunc(function () { return touchListener.destroy(); });
  13450. if (tapMenuButton) {
  13451. this.addDestroyFunc(function () { return menuTouchListener.destroy(); });
  13452. }
  13453. };
  13454. HeaderComp.prototype.setupMenu = function () {
  13455. var _this = this;
  13456. // if no menu provided in template, do nothing
  13457. if (!this.eMenu) {
  13458. return;
  13459. }
  13460. // we don't show the menu if on an iPad/iPhone, as the user cannot have a pointer device
  13461. // Note: If suppressMenuHide is set to true the menu will be displayed, and if suppressMenuHide
  13462. // is false (default) user will need to use longpress to display the menu.
  13463. var suppressMenuHide = this.gridOptionsWrapper.isSuppressMenuHide();
  13464. var hideShowMenu = !this.params.enableMenu || (_utils__WEBPACK_IMPORTED_MODULE_6__["_"].isIOSUserAgent() && !suppressMenuHide);
  13465. if (hideShowMenu) {
  13466. _utils__WEBPACK_IMPORTED_MODULE_6__["_"].removeFromParent(this.eMenu);
  13467. return;
  13468. }
  13469. this.addManagedListener(this.eMenu, 'click', function () { return _this.showMenu(_this.eMenu); });
  13470. if (!suppressMenuHide) {
  13471. this.eMenu.style.opacity = '0';
  13472. }
  13473. var style = this.eMenu.style;
  13474. style.transition = 'opacity 0.2s, border 0.2s';
  13475. style['-webkit-transition'] = 'opacity 0.2s, border 0.2s';
  13476. };
  13477. HeaderComp.prototype.setActiveParent = function (activeParent) {
  13478. if (!this.gridOptionsWrapper.isSuppressMenuHide()) {
  13479. this.eMenu.style.opacity = activeParent ? '1' : '0';
  13480. }
  13481. };
  13482. HeaderComp.prototype.showMenu = function (eventSource) {
  13483. if (!eventSource) {
  13484. eventSource = this.eMenu;
  13485. }
  13486. this.menuFactory.showMenuAfterButtonClick(this.params.column, eventSource);
  13487. };
  13488. HeaderComp.prototype.removeSortIcons = function () {
  13489. _utils__WEBPACK_IMPORTED_MODULE_6__["_"].removeFromParent(this.eSortAsc);
  13490. _utils__WEBPACK_IMPORTED_MODULE_6__["_"].removeFromParent(this.eSortDesc);
  13491. _utils__WEBPACK_IMPORTED_MODULE_6__["_"].removeFromParent(this.eSortNone);
  13492. _utils__WEBPACK_IMPORTED_MODULE_6__["_"].removeFromParent(this.eSortOrder);
  13493. };
  13494. HeaderComp.prototype.setupSort = function () {
  13495. var _this = this;
  13496. var enableSorting = this.params.enableSorting;
  13497. if (!enableSorting) {
  13498. this.removeSortIcons();
  13499. return;
  13500. }
  13501. var sortUsingCtrl = this.gridOptionsWrapper.isMultiSortKeyCtrl();
  13502. // keep track of last time the moving changed flag was set
  13503. this.addManagedListener(this.params.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_MOVING_CHANGED, function () {
  13504. _this.lastMovingChanged = new Date().getTime();
  13505. });
  13506. // add the event on the header, so when clicked, we do sorting
  13507. if (this.eLabel) {
  13508. this.addManagedListener(this.eLabel, 'click', function (event) {
  13509. // sometimes when moving a column via dragging, this was also firing a clicked event.
  13510. // here is issue raised by user: https://ag-grid.zendesk.com/agent/tickets/1076
  13511. // this check stops sort if a) column is moving or b) column moved less than 200ms ago (so caters for race condition)
  13512. var moving = _this.params.column.isMoving();
  13513. var nowTime = new Date().getTime();
  13514. // typically there is <2ms if moving flag was set recently, as it would be done in same VM turn
  13515. var movedRecently = (nowTime - _this.lastMovingChanged) < 50;
  13516. var columnMoving = moving || movedRecently;
  13517. if (!columnMoving) {
  13518. var multiSort = sortUsingCtrl ? (event.ctrlKey || event.metaKey) : event.shiftKey;
  13519. _this.params.progressSort(multiSort);
  13520. }
  13521. });
  13522. }
  13523. this.addManagedListener(this.params.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_SORT_CHANGED, this.onSortChanged.bind(this));
  13524. this.onSortChanged();
  13525. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_5__["Events"].EVENT_SORT_CHANGED, this.setMultiSortOrder.bind(this));
  13526. this.setMultiSortOrder();
  13527. };
  13528. HeaderComp.prototype.onSortChanged = function () {
  13529. _utils__WEBPACK_IMPORTED_MODULE_6__["_"].addOrRemoveCssClass(this.getGui(), 'ag-header-cell-sorted-asc', this.params.column.isSortAscending());
  13530. _utils__WEBPACK_IMPORTED_MODULE_6__["_"].addOrRemoveCssClass(this.getGui(), 'ag-header-cell-sorted-desc', this.params.column.isSortDescending());
  13531. _utils__WEBPACK_IMPORTED_MODULE_6__["_"].addOrRemoveCssClass(this.getGui(), 'ag-header-cell-sorted-none', this.params.column.isSortNone());
  13532. if (this.eSortAsc) {
  13533. _utils__WEBPACK_IMPORTED_MODULE_6__["_"].addOrRemoveCssClass(this.eSortAsc, 'ag-hidden', !this.params.column.isSortAscending());
  13534. }
  13535. if (this.eSortDesc) {
  13536. _utils__WEBPACK_IMPORTED_MODULE_6__["_"].addOrRemoveCssClass(this.eSortDesc, 'ag-hidden', !this.params.column.isSortDescending());
  13537. }
  13538. if (this.eSortNone) {
  13539. var alwaysHideNoSort = !this.params.column.getColDef().unSortIcon && !this.gridOptionsWrapper.isUnSortIcon();
  13540. _utils__WEBPACK_IMPORTED_MODULE_6__["_"].addOrRemoveCssClass(this.eSortNone, 'ag-hidden', alwaysHideNoSort || !this.params.column.isSortNone());
  13541. }
  13542. };
  13543. // we listen here for global sort events, NOT column sort events, as we want to do this
  13544. // when sorting has been set on all column (if we listened just for our col (where we
  13545. // set the asc / desc icons) then it's possible other cols are yet to get their sorting state.
  13546. HeaderComp.prototype.setMultiSortOrder = function () {
  13547. if (!this.eSortOrder) {
  13548. return;
  13549. }
  13550. var col = this.params.column;
  13551. var allColumnsWithSorting = this.sortController.getColumnsWithSortingOrdered();
  13552. var indexThisCol = allColumnsWithSorting.indexOf(col);
  13553. var moreThanOneColSorting = allColumnsWithSorting.length > 1;
  13554. var showIndex = col.isSorting() && moreThanOneColSorting;
  13555. _utils__WEBPACK_IMPORTED_MODULE_6__["_"].setDisplayed(this.eSortOrder, showIndex);
  13556. if (indexThisCol >= 0) {
  13557. this.eSortOrder.innerHTML = (indexThisCol + 1).toString();
  13558. }
  13559. else {
  13560. _utils__WEBPACK_IMPORTED_MODULE_6__["_"].clearElement(this.eSortOrder);
  13561. }
  13562. };
  13563. HeaderComp.prototype.setupFilterIcon = function () {
  13564. if (!this.eFilter) {
  13565. return;
  13566. }
  13567. this.addManagedListener(this.params.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_FILTER_CHANGED, this.onFilterChanged.bind(this));
  13568. this.onFilterChanged();
  13569. };
  13570. HeaderComp.prototype.onFilterChanged = function () {
  13571. var filterPresent = this.params.column.isFilterActive();
  13572. _utils__WEBPACK_IMPORTED_MODULE_6__["_"].addOrRemoveCssClass(this.eFilter, 'ag-hidden', !filterPresent);
  13573. };
  13574. HeaderComp.TEMPLATE = "<div class=\"ag-cell-label-container\">\n <span ref=\"eMenu\" class=\"ag-header-icon ag-header-cell-menu-button\" aria-hidden=\"true\"></span>\n <div ref=\"eLabel\" class=\"ag-header-cell-label\" role=\"presentation\" unselectable=\"on\">\n <span ref=\"eText\" class=\"ag-header-cell-text\" role=\"columnheader\" unselectable=\"on\"></span>\n <span ref=\"eFilter\" class=\"ag-header-icon ag-header-label-icon ag-filter-icon\" aria-hidden=\"true\"></span>\n <span ref=\"eSortOrder\" class=\"ag-header-icon ag-header-label-icon ag-sort-order\" aria-hidden=\"true\"></span>\n <span ref=\"eSortAsc\" class=\"ag-header-icon ag-header-label-icon ag-sort-ascending-icon\" aria-hidden=\"true\"></span>\n <span ref=\"eSortDesc\" class=\"ag-header-icon ag-header-label-icon ag-sort-descending-icon\" aria-hidden=\"true\"></span>\n <span ref=\"eSortNone\" class=\"ag-header-icon ag-header-label-icon ag-sort-none-icon\" aria-hidden=\"true\"></span>\n </div>\n </div>";
  13575. __decorate([
  13576. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper')
  13577. ], HeaderComp.prototype, "gridOptionsWrapper", void 0);
  13578. __decorate([
  13579. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('sortController')
  13580. ], HeaderComp.prototype, "sortController", void 0);
  13581. __decorate([
  13582. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('menuFactory')
  13583. ], HeaderComp.prototype, "menuFactory", void 0);
  13584. __decorate([
  13585. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eFilter')
  13586. ], HeaderComp.prototype, "eFilter", void 0);
  13587. __decorate([
  13588. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eSortAsc')
  13589. ], HeaderComp.prototype, "eSortAsc", void 0);
  13590. __decorate([
  13591. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eSortDesc')
  13592. ], HeaderComp.prototype, "eSortDesc", void 0);
  13593. __decorate([
  13594. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eSortNone')
  13595. ], HeaderComp.prototype, "eSortNone", void 0);
  13596. __decorate([
  13597. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eSortOrder')
  13598. ], HeaderComp.prototype, "eSortOrder", void 0);
  13599. __decorate([
  13600. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eMenu')
  13601. ], HeaderComp.prototype, "eMenu", void 0);
  13602. __decorate([
  13603. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eLabel')
  13604. ], HeaderComp.prototype, "eLabel", void 0);
  13605. __decorate([
  13606. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eText')
  13607. ], HeaderComp.prototype, "eText", void 0);
  13608. return HeaderComp;
  13609. }(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"]));
  13610. /***/ }),
  13611. /* 65 */
  13612. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  13613. "use strict";
  13614. __webpack_require__.r(__webpack_exports__);
  13615. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TouchListener", function() { return TouchListener; });
  13616. /* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36);
  13617. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7);
  13618. /**
  13619. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  13620. * @version v23.2.1
  13621. * @link http://www.ag-grid.com/
  13622. * @license MIT
  13623. */
  13624. var TouchListener = /** @class */ (function () {
  13625. function TouchListener(eElement, preventMouseClick) {
  13626. var _this = this;
  13627. if (preventMouseClick === void 0) { preventMouseClick = false; }
  13628. this.destroyFuncs = [];
  13629. this.touching = false;
  13630. this.eventService = new _eventService__WEBPACK_IMPORTED_MODULE_0__["EventService"]();
  13631. this.eElement = eElement;
  13632. this.preventMouseClick = preventMouseClick;
  13633. var startListener = this.onTouchStart.bind(this);
  13634. var moveListener = this.onTouchMove.bind(this);
  13635. var endListener = this.onTouchEnd.bind(this);
  13636. this.eElement.addEventListener("touchstart", startListener, { passive: true });
  13637. this.eElement.addEventListener("touchmove", moveListener, { passive: true });
  13638. // we set passive=false, as we want to prevent default on this event
  13639. this.eElement.addEventListener("touchend", endListener, { passive: false });
  13640. this.destroyFuncs.push(function () {
  13641. _this.eElement.removeEventListener("touchstart", startListener, { passive: true });
  13642. _this.eElement.removeEventListener("touchmove", moveListener, { passive: true });
  13643. _this.eElement.removeEventListener("touchend", endListener, { passive: false });
  13644. });
  13645. }
  13646. TouchListener.prototype.getActiveTouch = function (touchList) {
  13647. for (var i = 0; i < touchList.length; i++) {
  13648. var matches = touchList[i].identifier === this.touchStart.identifier;
  13649. if (matches) {
  13650. return touchList[i];
  13651. }
  13652. }
  13653. return null;
  13654. };
  13655. TouchListener.prototype.addEventListener = function (eventType, listener) {
  13656. this.eventService.addEventListener(eventType, listener);
  13657. };
  13658. TouchListener.prototype.removeEventListener = function (eventType, listener) {
  13659. this.eventService.removeEventListener(eventType, listener);
  13660. };
  13661. TouchListener.prototype.onTouchStart = function (touchEvent) {
  13662. var _this = this;
  13663. // only looking at one touch point at any time
  13664. if (this.touching) {
  13665. return;
  13666. }
  13667. this.touchStart = touchEvent.touches[0];
  13668. this.touching = true;
  13669. this.moved = false;
  13670. var touchStartCopy = this.touchStart;
  13671. window.setTimeout(function () {
  13672. var touchesMatch = _this.touchStart === touchStartCopy;
  13673. if (_this.touching && touchesMatch && !_this.moved) {
  13674. _this.moved = true;
  13675. var event_1 = {
  13676. type: TouchListener.EVENT_LONG_TAP,
  13677. touchStart: _this.touchStart,
  13678. touchEvent: touchEvent
  13679. };
  13680. _this.eventService.dispatchEvent(event_1);
  13681. }
  13682. }, 500);
  13683. };
  13684. TouchListener.prototype.onTouchMove = function (touchEvent) {
  13685. if (!this.touching) {
  13686. return;
  13687. }
  13688. var touch = this.getActiveTouch(touchEvent.touches);
  13689. if (!touch) {
  13690. return;
  13691. }
  13692. var eventIsFarAway = !_utils__WEBPACK_IMPORTED_MODULE_1__["_"].areEventsNear(touch, this.touchStart, 4);
  13693. if (eventIsFarAway) {
  13694. this.moved = true;
  13695. }
  13696. };
  13697. TouchListener.prototype.onTouchEnd = function (touchEvent) {
  13698. if (!this.touching) {
  13699. return;
  13700. }
  13701. if (!this.moved) {
  13702. var event_2 = {
  13703. type: TouchListener.EVENT_TAP,
  13704. touchStart: this.touchStart
  13705. };
  13706. this.eventService.dispatchEvent(event_2);
  13707. this.checkForDoubleTap();
  13708. }
  13709. // stops the tap from also been processed as a mouse click
  13710. if (this.preventMouseClick) {
  13711. touchEvent.preventDefault();
  13712. }
  13713. this.touching = false;
  13714. };
  13715. TouchListener.prototype.checkForDoubleTap = function () {
  13716. var now = new Date().getTime();
  13717. if (this.lastTapTime && this.lastTapTime > 0) {
  13718. // if previous tap, see if duration is short enough to be considered double tap
  13719. var interval = now - this.lastTapTime;
  13720. if (interval > TouchListener.DOUBLE_TAP_MILLIS) {
  13721. // dispatch double tap event
  13722. var event_3 = {
  13723. type: TouchListener.EVENT_DOUBLE_TAP,
  13724. touchStart: this.touchStart
  13725. };
  13726. this.eventService.dispatchEvent(event_3);
  13727. // this stops a tripple tap ending up as two double taps
  13728. this.lastTapTime = null;
  13729. }
  13730. else {
  13731. this.lastTapTime = now;
  13732. }
  13733. }
  13734. else {
  13735. this.lastTapTime = now;
  13736. }
  13737. };
  13738. TouchListener.prototype.destroy = function () {
  13739. this.destroyFuncs.forEach(function (func) { return func(); });
  13740. };
  13741. TouchListener.EVENT_TAP = "tap";
  13742. TouchListener.EVENT_DOUBLE_TAP = "doubleTap";
  13743. TouchListener.EVENT_LONG_TAP = "longTap";
  13744. TouchListener.DOUBLE_TAP_MILLIS = 500;
  13745. return TouchListener;
  13746. }());
  13747. /***/ }),
  13748. /* 66 */
  13749. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  13750. "use strict";
  13751. __webpack_require__.r(__webpack_exports__);
  13752. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderGroupComp", function() { return HeaderGroupComp; });
  13753. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56);
  13754. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  13755. /* harmony import */ var _widgets_touchListener__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(65);
  13756. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(57);
  13757. /* harmony import */ var _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(33);
  13758. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7);
  13759. /**
  13760. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  13761. * @version v23.2.1
  13762. * @link http://www.ag-grid.com/
  13763. * @license MIT
  13764. */
  13765. var __extends = (undefined && undefined.__extends) || (function () {
  13766. var extendStatics = function (d, b) {
  13767. extendStatics = Object.setPrototypeOf ||
  13768. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  13769. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  13770. return extendStatics(d, b);
  13771. };
  13772. return function (d, b) {
  13773. extendStatics(d, b);
  13774. function __() { this.constructor = d; }
  13775. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  13776. };
  13777. })();
  13778. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  13779. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  13780. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  13781. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  13782. return c > 3 && r && Object.defineProperty(target, key, r), r;
  13783. };
  13784. var HeaderGroupComp = /** @class */ (function (_super) {
  13785. __extends(HeaderGroupComp, _super);
  13786. function HeaderGroupComp() {
  13787. return _super.call(this, HeaderGroupComp.TEMPLATE) || this;
  13788. }
  13789. // this is a user component, and IComponent has "public destroy()" as part of the interface.
  13790. // so we need to override destroy() just to make the method public.
  13791. HeaderGroupComp.prototype.destroy = function () {
  13792. _super.prototype.destroy.call(this);
  13793. };
  13794. HeaderGroupComp.prototype.init = function (params) {
  13795. this.params = params;
  13796. this.setupLabel();
  13797. this.addGroupExpandIcon();
  13798. this.setupExpandIcons();
  13799. };
  13800. HeaderGroupComp.prototype.setupExpandIcons = function () {
  13801. var _this = this;
  13802. this.addInIcon("columnGroupOpened", "agOpened");
  13803. this.addInIcon("columnGroupClosed", "agClosed");
  13804. var expandAction = function (event) {
  13805. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].isStopPropagationForAgGrid(event)) {
  13806. return;
  13807. }
  13808. var newExpandedValue = !_this.params.columnGroup.isExpanded();
  13809. _this.columnController.setColumnGroupOpened(_this.params.columnGroup.getOriginalColumnGroup(), newExpandedValue, "uiColumnExpanded");
  13810. };
  13811. this.addTouchAndClickListeners(this.eCloseIcon, expandAction);
  13812. this.addTouchAndClickListeners(this.eOpenIcon, expandAction);
  13813. var stopPropagationAction = function (event) {
  13814. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].stopPropagationForAgGrid(event);
  13815. };
  13816. // adding stopPropagation to the double click for the icons prevents double click action happening
  13817. // when the icons are clicked. if the icons are double clicked, then the groups should open and
  13818. // then close again straight away. if we also listened to double click, then the group would open,
  13819. // close, then open, which is not what we want. double click should only action if the user double
  13820. // clicks outside of the icons.
  13821. this.addManagedListener(this.eCloseIcon, "dblclick", stopPropagationAction);
  13822. this.addManagedListener(this.eOpenIcon, "dblclick", stopPropagationAction);
  13823. this.addManagedListener(this.getGui(), "dblclick", expandAction);
  13824. this.updateIconVisibility();
  13825. var originalColumnGroup = this.params.columnGroup.getOriginalColumnGroup();
  13826. this.addManagedListener(originalColumnGroup, _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__["OriginalColumnGroup"].EVENT_EXPANDED_CHANGED, this.updateIconVisibility.bind(this));
  13827. this.addManagedListener(originalColumnGroup, _entities_originalColumnGroup__WEBPACK_IMPORTED_MODULE_4__["OriginalColumnGroup"].EVENT_EXPANDABLE_CHANGED, this.updateIconVisibility.bind(this));
  13828. };
  13829. HeaderGroupComp.prototype.addTouchAndClickListeners = function (eElement, action) {
  13830. var touchListener = new _widgets_touchListener__WEBPACK_IMPORTED_MODULE_2__["TouchListener"](eElement);
  13831. this.addManagedListener(touchListener, _widgets_touchListener__WEBPACK_IMPORTED_MODULE_2__["TouchListener"].EVENT_TAP, action);
  13832. this.addDestroyFunc(function () { return touchListener.destroy(); });
  13833. this.addManagedListener(eElement, "click", action);
  13834. };
  13835. HeaderGroupComp.prototype.updateIconVisibility = function () {
  13836. var columnGroup = this.params.columnGroup;
  13837. if (columnGroup.isExpandable()) {
  13838. var expanded = this.params.columnGroup.isExpanded();
  13839. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].setDisplayed(this.eOpenIcon, expanded);
  13840. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].setDisplayed(this.eCloseIcon, !expanded);
  13841. }
  13842. else {
  13843. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].setDisplayed(this.eOpenIcon, false);
  13844. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].setDisplayed(this.eCloseIcon, false);
  13845. }
  13846. };
  13847. HeaderGroupComp.prototype.addInIcon = function (iconName, refName) {
  13848. var eIcon = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].createIconNoSpan(iconName, this.gridOptionsWrapper, null);
  13849. this.getRefElement(refName).appendChild(eIcon);
  13850. };
  13851. HeaderGroupComp.prototype.addGroupExpandIcon = function () {
  13852. if (!this.params.columnGroup.isExpandable()) {
  13853. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].setDisplayed(this.eOpenIcon, false);
  13854. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].setDisplayed(this.eCloseIcon, false);
  13855. return;
  13856. }
  13857. };
  13858. HeaderGroupComp.prototype.setupLabel = function () {
  13859. // no renderer, default text render
  13860. var displayName = this.params.displayName;
  13861. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(displayName)) {
  13862. var displayNameSanitised = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].escape(displayName);
  13863. this.getRefElement("agLabel").innerHTML = displayNameSanitised;
  13864. }
  13865. };
  13866. HeaderGroupComp.TEMPLATE = "<div class=\"ag-header-group-cell-label\" ref=\"agContainer\" role=\"presentation\">\n <span ref=\"agLabel\" class=\"ag-header-group-text\" role=\"columnheader\"></span>\n <span ref=\"agOpened\" class=\"ag-header-icon ag-header-expand-icon ag-header-expand-icon-expanded\"></span>\n <span ref=\"agClosed\" class=\"ag-header-icon ag-header-expand-icon ag-header-expand-icon-collapsed\"></span>\n </div>";
  13867. __decorate([
  13868. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])("columnController")
  13869. ], HeaderGroupComp.prototype, "columnController", void 0);
  13870. __decorate([
  13871. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])("gridOptionsWrapper")
  13872. ], HeaderGroupComp.prototype, "gridOptionsWrapper", void 0);
  13873. __decorate([
  13874. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])("agOpened")
  13875. ], HeaderGroupComp.prototype, "eOpenIcon", void 0);
  13876. __decorate([
  13877. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])("agClosed")
  13878. ], HeaderGroupComp.prototype, "eCloseIcon", void 0);
  13879. return HeaderGroupComp;
  13880. }(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"]));
  13881. /***/ }),
  13882. /* 67 */
  13883. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  13884. "use strict";
  13885. __webpack_require__.r(__webpack_exports__);
  13886. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GroupCellRenderer", function() { return GroupCellRenderer; });
  13887. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(25);
  13888. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  13889. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(56);
  13890. /* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(68);
  13891. /* harmony import */ var _checkboxSelectionComponent__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(69);
  13892. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(57);
  13893. /* harmony import */ var _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(74);
  13894. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(7);
  13895. /**
  13896. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  13897. * @version v23.2.1
  13898. * @link http://www.ag-grid.com/
  13899. * @license MIT
  13900. */
  13901. var __extends = (undefined && undefined.__extends) || (function () {
  13902. var extendStatics = function (d, b) {
  13903. extendStatics = Object.setPrototypeOf ||
  13904. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  13905. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  13906. return extendStatics(d, b);
  13907. };
  13908. return function (d, b) {
  13909. extendStatics(d, b);
  13910. function __() { this.constructor = d; }
  13911. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  13912. };
  13913. })();
  13914. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  13915. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  13916. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  13917. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  13918. return c > 3 && r && Object.defineProperty(target, key, r), r;
  13919. };
  13920. var GroupCellRenderer = /** @class */ (function (_super) {
  13921. __extends(GroupCellRenderer, _super);
  13922. function GroupCellRenderer() {
  13923. return _super.call(this, GroupCellRenderer.TEMPLATE) || this;
  13924. }
  13925. GroupCellRenderer.prototype.init = function (params) {
  13926. this.params = params;
  13927. if (this.gridOptionsWrapper.isGroupIncludeTotalFooter()) {
  13928. this.assignBlankValueToGroupFooterCell(params);
  13929. }
  13930. var embeddedRowMismatch = this.isEmbeddedRowMismatch();
  13931. // This allows for empty strings to appear as groups since
  13932. // it will only return for null or undefined.
  13933. var nullValue = params.value == null;
  13934. var skipCell = false;
  13935. // if the groupCellRenderer is inside of a footer and groupHideOpenParents is true
  13936. // we should only display the groupCellRenderer if the current column is the rowGroupedColumn
  13937. if (this.gridOptionsWrapper.isGroupIncludeFooter() && this.gridOptionsWrapper.isGroupHideOpenParents()) {
  13938. var node = params.node;
  13939. if (node.footer) {
  13940. var showRowGroup = params.colDef && params.colDef.showRowGroup;
  13941. var rowGroupColumnId = node.rowGroupColumn && node.rowGroupColumn.getColId();
  13942. skipCell = showRowGroup !== rowGroupColumnId;
  13943. }
  13944. }
  13945. this.cellIsBlank = embeddedRowMismatch || nullValue || skipCell;
  13946. if (this.cellIsBlank) {
  13947. return;
  13948. }
  13949. this.setupDragOpenParents();
  13950. this.addExpandAndContract();
  13951. this.addCheckboxIfNeeded();
  13952. this.addValueElement();
  13953. this.setupIndent();
  13954. };
  13955. GroupCellRenderer.prototype.assignBlankValueToGroupFooterCell = function (params) {
  13956. // this is not ideal, but it was the only way we could get footer working for the root node
  13957. if (!params.value && params.node.level == -1) {
  13958. params.value = '';
  13959. }
  13960. };
  13961. // if we are doing embedded full width rows, we only show the renderer when
  13962. // in the body, or if pinning in the pinned section, or if pinning and RTL,
  13963. // in the right section. otherwise we would have the cell repeated in each section.
  13964. GroupCellRenderer.prototype.isEmbeddedRowMismatch = function () {
  13965. if (!this.params.fullWidth || !this.gridOptionsWrapper.isEmbedFullWidthRows()) {
  13966. return false;
  13967. }
  13968. var pinnedLeftCell = this.params.pinned === _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_LEFT;
  13969. var pinnedRightCell = this.params.pinned === _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_RIGHT;
  13970. var bodyCell = !pinnedLeftCell && !pinnedRightCell;
  13971. if (this.gridOptionsWrapper.isEnableRtl()) {
  13972. if (this.columnController.isPinningLeft()) {
  13973. return !pinnedRightCell;
  13974. }
  13975. return !bodyCell;
  13976. }
  13977. if (this.columnController.isPinningLeft()) {
  13978. return !pinnedLeftCell;
  13979. }
  13980. return !bodyCell;
  13981. };
  13982. GroupCellRenderer.prototype.setIndent = function () {
  13983. if (this.gridOptionsWrapper.isGroupHideOpenParents()) {
  13984. return;
  13985. }
  13986. var params = this.params;
  13987. var rowNode = params.node;
  13988. var paddingCount = rowNode.uiLevel;
  13989. var userProvidedPaddingPixelsTheDeprecatedWay = params.padding >= 0;
  13990. if (userProvidedPaddingPixelsTheDeprecatedWay) {
  13991. this.setPaddingDeprecatedWay(paddingCount, params.padding);
  13992. return;
  13993. }
  13994. if (this.indentClass) {
  13995. this.removeCssClass(this.indentClass);
  13996. }
  13997. this.indentClass = 'ag-row-group-indent-' + paddingCount;
  13998. this.addCssClass(this.indentClass);
  13999. };
  14000. GroupCellRenderer.prototype.setPaddingDeprecatedWay = function (paddingCount, padding) {
  14001. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].doOnce(function () { return console.warn('ag-Grid: since v14.2, configuring padding for groupCellRenderer should be done with Sass variables and themes. Please see the ag-Grid documentation page for Themes, in particular the property $row-group-indent-size.'); }, 'groupCellRenderer->doDeprecatedWay');
  14002. var paddingPx = paddingCount * padding;
  14003. var eGui = this.getGui();
  14004. var paddingSide = this.gridOptionsWrapper.isEnableRtl() ? 'paddingRight' : 'paddingLeft';
  14005. eGui.style[paddingSide] = paddingPx + "px";
  14006. };
  14007. GroupCellRenderer.prototype.setupIndent = function () {
  14008. // only do this if an indent - as this overwrites the padding that
  14009. // the theme set, which will make things look 'not aligned' for the
  14010. // first group level.
  14011. var node = this.params.node;
  14012. var suppressPadding = this.params.suppressPadding;
  14013. if (!suppressPadding) {
  14014. this.addManagedListener(node, _entities_rowNode__WEBPACK_IMPORTED_MODULE_3__["RowNode"].EVENT_UI_LEVEL_CHANGED, this.setIndent.bind(this));
  14015. this.setIndent();
  14016. }
  14017. };
  14018. GroupCellRenderer.prototype.addValueElement = function () {
  14019. var params = this.params;
  14020. var rowNode = this.displayedGroup;
  14021. if (rowNode.footer) {
  14022. this.createFooterCell();
  14023. }
  14024. else if (rowNode.hasChildren() ||
  14025. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].get(params.colDef, 'cellRendererParams.innerRenderer', null) ||
  14026. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].get(params.colDef, 'cellRendererParams.innerRendererFramework', null)) {
  14027. this.createGroupCell();
  14028. if (rowNode.hasChildren()) {
  14029. this.addChildCount();
  14030. }
  14031. }
  14032. else {
  14033. this.createLeafCell();
  14034. }
  14035. };
  14036. GroupCellRenderer.prototype.createFooterCell = function () {
  14037. var footerValueGetter = this.params.footerValueGetter;
  14038. var footerValue;
  14039. if (footerValueGetter) {
  14040. // params is same as we were given, except we set the value as the item to display
  14041. var paramsClone = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].cloneObject(this.params);
  14042. paramsClone.value = this.params.value;
  14043. if (typeof footerValueGetter === 'function') {
  14044. footerValue = footerValueGetter(paramsClone);
  14045. }
  14046. else if (typeof footerValueGetter === 'string') {
  14047. footerValue = this.expressionService.evaluate(footerValueGetter, paramsClone);
  14048. }
  14049. else {
  14050. console.warn('ag-Grid: footerValueGetter should be either a function or a string (expression)');
  14051. }
  14052. }
  14053. else {
  14054. footerValue = 'Total ' + this.params.value;
  14055. }
  14056. this.eValue.innerHTML = footerValue;
  14057. };
  14058. GroupCellRenderer.prototype.createGroupCell = function () {
  14059. var _this = this;
  14060. var params = this.params;
  14061. var rowGroupColumn = this.displayedGroup.rowGroupColumn;
  14062. // we try and use the cellRenderer of the column used for the grouping if we can
  14063. var columnToUse = rowGroupColumn ? rowGroupColumn : params.column;
  14064. var groupName = this.params.value;
  14065. var valueFormatted = columnToUse ?
  14066. this.valueFormatterService.formatValue(columnToUse, params.node, params.scope, groupName) : null;
  14067. params.valueFormatted = valueFormatted;
  14068. var rendererPromise;
  14069. rendererPromise = params.fullWidth
  14070. ? this.useFullWidth(params)
  14071. : this.useInnerRenderer(this.params.colDef.cellRendererParams, columnToUse.getColDef(), params);
  14072. // retain a reference to the created renderer - we'll use this later for cleanup (in destroy)
  14073. if (rendererPromise) {
  14074. rendererPromise.then(function (value) {
  14075. _this.innerCellRenderer = value;
  14076. });
  14077. }
  14078. };
  14079. GroupCellRenderer.prototype.useInnerRenderer = function (groupCellRendererParams, groupedColumnDef, // the column this group row is for, eg 'Country'
  14080. params) {
  14081. var _this = this;
  14082. // when grouping, the normal case is we use the cell renderer of the grouped column. eg if grouping by country
  14083. // and then rating, we will use the country cell renderer for each country group row and likewise the rating
  14084. // cell renderer for each rating group row.
  14085. //
  14086. // however if the user has innerCellRenderer defined, this gets preference and we don't use cell renderers
  14087. // of the grouped columns.
  14088. //
  14089. // so we check and use in the following order:
  14090. //
  14091. // 1) thisColDef.cellRendererParams.innerRenderer of the column showing the groups (eg auto group column)
  14092. // 2) groupedColDef.cellRenderer of the grouped column
  14093. // 3) groupedColDef.cellRendererParams.innerRenderer
  14094. var cellRendererPromise = null;
  14095. // we check if cell renderer provided for the group cell renderer, eg colDef.cellRendererParams.innerRenderer
  14096. var groupInnerRendererClass = this.userComponentFactory
  14097. .lookupComponentClassDef(groupCellRendererParams, "innerRenderer");
  14098. if (groupInnerRendererClass && groupInnerRendererClass.component != null
  14099. && groupInnerRendererClass.source != _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_6__["ComponentSource"].DEFAULT) {
  14100. // use the renderer defined in cellRendererParams.innerRenderer
  14101. cellRendererPromise = this.userComponentFactory.newInnerCellRenderer(groupCellRendererParams, params);
  14102. }
  14103. else {
  14104. // otherwise see if we can use the cellRenderer of the column we are grouping by
  14105. var groupColumnRendererClass = this.userComponentFactory
  14106. .lookupComponentClassDef(groupedColumnDef, "cellRenderer");
  14107. if (groupColumnRendererClass &&
  14108. groupColumnRendererClass.source != _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_6__["ComponentSource"].DEFAULT) {
  14109. // Only if the original column is using a specific renderer, it it is a using a DEFAULT one ignore it
  14110. cellRendererPromise = this.userComponentFactory.newCellRenderer(groupedColumnDef, params);
  14111. }
  14112. else if (groupColumnRendererClass &&
  14113. groupColumnRendererClass.source == _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_6__["ComponentSource"].DEFAULT &&
  14114. (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].get(groupedColumnDef, 'cellRendererParams.innerRenderer', null))) {
  14115. // EDGE CASE - THIS COMES FROM A COLUMN WHICH HAS BEEN GROUPED DYNAMICALLY, THAT HAS AS RENDERER 'group'
  14116. // AND HAS A INNER CELL RENDERER
  14117. cellRendererPromise = this.userComponentFactory.newInnerCellRenderer(groupedColumnDef.cellRendererParams, params);
  14118. }
  14119. else {
  14120. // This forces the retrieval of the default plain cellRenderer that just renders the values.
  14121. cellRendererPromise = this.userComponentFactory.newCellRenderer({}, params);
  14122. }
  14123. }
  14124. if (cellRendererPromise != null) {
  14125. cellRendererPromise.then(function (rendererToUse) {
  14126. if (rendererToUse == null) {
  14127. _this.eValue.innerText = params.valueFormatted != null ? params.valueFormatted : params.value;
  14128. return;
  14129. }
  14130. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].bindCellRendererToHtmlElement(cellRendererPromise, _this.eValue);
  14131. });
  14132. }
  14133. else {
  14134. this.eValue.innerText = params.valueFormatted != null ? params.valueFormatted : params.value;
  14135. }
  14136. return cellRendererPromise;
  14137. };
  14138. GroupCellRenderer.prototype.useFullWidth = function (params) {
  14139. var cellRendererPromise = this.userComponentFactory.newFullWidthGroupRowInnerCellRenderer(params);
  14140. if (cellRendererPromise != null) {
  14141. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].bindCellRendererToHtmlElement(cellRendererPromise, this.eValue);
  14142. }
  14143. else {
  14144. this.eValue.innerText = params.valueFormatted != null ? params.valueFormatted : params.value;
  14145. }
  14146. return cellRendererPromise;
  14147. };
  14148. GroupCellRenderer.prototype.addChildCount = function () {
  14149. // only include the child count if it's included, eg if user doing custom aggregation,
  14150. // then this could be left out, or set to -1, ie no child count
  14151. if (this.params.suppressCount) {
  14152. return;
  14153. }
  14154. this.addManagedListener(this.displayedGroup, _entities_rowNode__WEBPACK_IMPORTED_MODULE_3__["RowNode"].EVENT_ALL_CHILDREN_COUNT_CHANGED, this.updateChildCount.bind(this));
  14155. // filtering changes the child count, so need to cater for it
  14156. this.updateChildCount();
  14157. };
  14158. GroupCellRenderer.prototype.updateChildCount = function () {
  14159. var allChildrenCount = this.displayedGroup.allChildrenCount;
  14160. this.eChildCount.innerHTML = allChildrenCount >= 0 ? "(" + allChildrenCount + ")" : "";
  14161. };
  14162. GroupCellRenderer.prototype.createLeafCell = function () {
  14163. if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(this.params.value)) {
  14164. this.eValue.innerText = this.params.valueFormatted ? this.params.valueFormatted : this.params.value;
  14165. }
  14166. };
  14167. GroupCellRenderer.prototype.isUserWantsSelected = function () {
  14168. var paramsCheckbox = this.params.checkbox;
  14169. if (typeof paramsCheckbox === 'function') {
  14170. return paramsCheckbox(this.params);
  14171. }
  14172. return paramsCheckbox === true;
  14173. };
  14174. GroupCellRenderer.prototype.addCheckboxIfNeeded = function () {
  14175. var _this = this;
  14176. var rowNode = this.displayedGroup;
  14177. var checkboxNeeded = this.isUserWantsSelected() &&
  14178. // footers cannot be selected
  14179. !rowNode.footer &&
  14180. // pinned rows cannot be selected
  14181. !rowNode.rowPinned &&
  14182. // details cannot be selected
  14183. !rowNode.detail;
  14184. if (checkboxNeeded) {
  14185. var cbSelectionComponent_1 = new _checkboxSelectionComponent__WEBPACK_IMPORTED_MODULE_4__["CheckboxSelectionComponent"]();
  14186. this.getContext().createBean(cbSelectionComponent_1);
  14187. cbSelectionComponent_1.init({ rowNode: rowNode, column: this.params.column });
  14188. this.eCheckbox.appendChild(cbSelectionComponent_1.getGui());
  14189. this.addDestroyFunc(function () { return _this.getContext().destroyBean(cbSelectionComponent_1); });
  14190. }
  14191. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.eCheckbox, 'ag-invisible', !checkboxNeeded);
  14192. };
  14193. GroupCellRenderer.prototype.addExpandAndContract = function () {
  14194. var params = this.params;
  14195. var eGroupCell = params.eGridCell;
  14196. var eExpandedIcon = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].createIconNoSpan('groupExpanded', this.gridOptionsWrapper, null);
  14197. var eContractedIcon = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].createIconNoSpan('groupContracted', this.gridOptionsWrapper, null);
  14198. this.eExpanded.appendChild(eExpandedIcon);
  14199. this.eContracted.appendChild(eContractedIcon);
  14200. this.addManagedListener(this.eExpanded, 'click', this.onExpandClicked.bind(this));
  14201. this.addManagedListener(this.eContracted, 'click', this.onExpandClicked.bind(this));
  14202. // expand / contract as the user hits enter
  14203. this.addManagedListener(eGroupCell, 'keydown', this.onKeyDown.bind(this));
  14204. this.addManagedListener(params.node, _entities_rowNode__WEBPACK_IMPORTED_MODULE_3__["RowNode"].EVENT_EXPANDED_CHANGED, this.showExpandAndContractIcons.bind(this));
  14205. this.showExpandAndContractIcons();
  14206. // because we don't show the expand / contract when there are no children, we need to check every time
  14207. // the number of children change.
  14208. this.addManagedListener(this.displayedGroup, _entities_rowNode__WEBPACK_IMPORTED_MODULE_3__["RowNode"].EVENT_ALL_CHILDREN_COUNT_CHANGED, this.onRowNodeIsExpandableChanged.bind(this));
  14209. this.addManagedListener(this.displayedGroup, _entities_rowNode__WEBPACK_IMPORTED_MODULE_3__["RowNode"].EVENT_MASTER_CHANGED, this.onRowNodeIsExpandableChanged.bind(this));
  14210. // if editing groups, then double click is to start editing
  14211. if (!this.gridOptionsWrapper.isEnableGroupEdit() && this.isExpandable() && !params.suppressDoubleClickExpand) {
  14212. this.addManagedListener(eGroupCell, 'dblclick', this.onCellDblClicked.bind(this));
  14213. }
  14214. };
  14215. GroupCellRenderer.prototype.onRowNodeIsExpandableChanged = function () {
  14216. // maybe if no children now, we should hide the expand / contract icons
  14217. this.showExpandAndContractIcons();
  14218. // if we have no children, this impacts the indent
  14219. this.setIndent();
  14220. };
  14221. GroupCellRenderer.prototype.onKeyDown = function (event) {
  14222. var enterKeyPressed = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].isKeyPressed(event, _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_ENTER);
  14223. if (!enterKeyPressed || this.params.suppressEnterExpand) {
  14224. return;
  14225. }
  14226. var cellEditable = this.params.column && this.params.column.isCellEditable(this.params.node);
  14227. if (cellEditable) {
  14228. return;
  14229. }
  14230. event.preventDefault();
  14231. this.onExpandOrContract();
  14232. };
  14233. GroupCellRenderer.prototype.setupDragOpenParents = function () {
  14234. var column = this.params.column;
  14235. var rowNode = this.params.node;
  14236. if (!this.gridOptionsWrapper.isGroupHideOpenParents()) {
  14237. this.draggedFromHideOpenParents = false;
  14238. }
  14239. else if (!rowNode.hasChildren()) {
  14240. // if we are here, and we are not a group, then we must of been dragged down,
  14241. // as otherwise the cell would be blank, and if cell is blank, this method is never called.
  14242. this.draggedFromHideOpenParents = true;
  14243. }
  14244. else {
  14245. var rowGroupColumn = rowNode.rowGroupColumn;
  14246. if (rowGroupColumn) {
  14247. // if the displayGroup column for this col matches the rowGroupColumn we grouped by for this node,
  14248. // then nothing was dragged down
  14249. this.draggedFromHideOpenParents = !column.isRowGroupDisplayed(rowGroupColumn.getId());
  14250. }
  14251. else {
  14252. // the only way we can end up here (no column, but a group) is if we are at the root node,
  14253. // which only happens when 'groupIncludeTotalFooter' is true. here, we are never dragging
  14254. this.draggedFromHideOpenParents = false;
  14255. }
  14256. }
  14257. if (this.draggedFromHideOpenParents) {
  14258. var pointer = rowNode.parent;
  14259. while (true) {
  14260. if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(pointer)) {
  14261. break;
  14262. }
  14263. if (pointer.rowGroupColumn && column.isRowGroupDisplayed(pointer.rowGroupColumn.getId())) {
  14264. this.displayedGroup = pointer;
  14265. break;
  14266. }
  14267. pointer = pointer.parent;
  14268. }
  14269. }
  14270. // if we didn't find a displayed group, set it to the row node
  14271. if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(this.displayedGroup)) {
  14272. this.displayedGroup = rowNode;
  14273. }
  14274. };
  14275. GroupCellRenderer.prototype.onExpandClicked = function (mouseEvent) {
  14276. if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].isStopPropagationForAgGrid(mouseEvent)) {
  14277. return;
  14278. }
  14279. // so if we expand a node, it does not also get selected.
  14280. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].stopPropagationForAgGrid(mouseEvent);
  14281. this.onExpandOrContract();
  14282. };
  14283. GroupCellRenderer.prototype.onCellDblClicked = function (mouseEvent) {
  14284. if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].isStopPropagationForAgGrid(mouseEvent)) {
  14285. return;
  14286. }
  14287. // we want to avoid acting on double click events on the expand / contract icon,
  14288. // as that icons already has expand / collapse functionality on it. otherwise if
  14289. // the icon was double clicked, we would get 'click', 'click', 'dblclick' which
  14290. // is open->close->open, however double click should be open->close only.
  14291. var targetIsExpandIcon = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].isElementInEventPath(this.eExpanded, mouseEvent)
  14292. || _utils__WEBPACK_IMPORTED_MODULE_7__["_"].isElementInEventPath(this.eContracted, mouseEvent);
  14293. if (!targetIsExpandIcon) {
  14294. this.onExpandOrContract();
  14295. }
  14296. };
  14297. GroupCellRenderer.prototype.onExpandOrContract = function () {
  14298. // must use the displayedGroup, so if data was dragged down, we expand the parent, not this row
  14299. var rowNode = this.displayedGroup;
  14300. rowNode.setExpanded(!rowNode.expanded);
  14301. };
  14302. GroupCellRenderer.prototype.isExpandable = function () {
  14303. var rowNode = this.params.node;
  14304. var reducedLeafNode = this.columnController.isPivotMode() && rowNode.leafGroup;
  14305. return this.draggedFromHideOpenParents ||
  14306. (rowNode.isExpandable() && !rowNode.footer && !reducedLeafNode);
  14307. };
  14308. GroupCellRenderer.prototype.showExpandAndContractIcons = function () {
  14309. var rowNode = this.params.node;
  14310. if (this.isExpandable()) {
  14311. // if expandable, show one based on expand state.
  14312. // if we were dragged down, means our parent is always expanded
  14313. var expanded = this.draggedFromHideOpenParents ? true : rowNode.expanded;
  14314. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].setDisplayed(this.eContracted, !expanded);
  14315. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].setDisplayed(this.eExpanded, expanded);
  14316. }
  14317. else {
  14318. // it not expandable, show neither
  14319. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].setDisplayed(this.eExpanded, false);
  14320. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].setDisplayed(this.eContracted, false);
  14321. }
  14322. var displayedGroup = this.displayedGroup;
  14323. // compensation padding for leaf nodes, so there is blank space instead of the expand icon
  14324. var pivotModeAndLeafGroup = this.columnController.isPivotMode() && displayedGroup.leafGroup;
  14325. var notExpandable = !displayedGroup.isExpandable();
  14326. var addLeafIndentClass = displayedGroup.footer || notExpandable || pivotModeAndLeafGroup;
  14327. this.addOrRemoveCssClass('ag-row-group', !addLeafIndentClass);
  14328. this.addOrRemoveCssClass('ag-row-group-leaf-indent', addLeafIndentClass);
  14329. };
  14330. // this is a user component, and IComponent has "public destroy()" as part of the interface.
  14331. // so we need to have public here instead of private or protected
  14332. GroupCellRenderer.prototype.destroy = function () {
  14333. this.getContext().destroyBean(this.innerCellRenderer);
  14334. _super.prototype.destroy.call(this);
  14335. };
  14336. GroupCellRenderer.prototype.refresh = function () {
  14337. return false;
  14338. };
  14339. GroupCellRenderer.TEMPLATE = '<span class="ag-cell-wrapper">' +
  14340. '<span class="ag-group-expanded" ref="eExpanded"></span>' +
  14341. '<span class="ag-group-contracted" ref="eContracted"></span>' +
  14342. '<span class="ag-group-checkbox ag-invisible" ref="eCheckbox"></span>' +
  14343. '<span class="ag-group-value" ref="eValue"></span>' +
  14344. '<span class="ag-group-child-count" ref="eChildCount"></span>' +
  14345. '</span>';
  14346. __decorate([
  14347. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  14348. ], GroupCellRenderer.prototype, "gridOptionsWrapper", void 0);
  14349. __decorate([
  14350. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('expressionService')
  14351. ], GroupCellRenderer.prototype, "expressionService", void 0);
  14352. __decorate([
  14353. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('valueFormatterService')
  14354. ], GroupCellRenderer.prototype, "valueFormatterService", void 0);
  14355. __decorate([
  14356. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController')
  14357. ], GroupCellRenderer.prototype, "columnController", void 0);
  14358. __decorate([
  14359. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('userComponentFactory')
  14360. ], GroupCellRenderer.prototype, "userComponentFactory", void 0);
  14361. __decorate([
  14362. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_5__["RefSelector"])('eExpanded')
  14363. ], GroupCellRenderer.prototype, "eExpanded", void 0);
  14364. __decorate([
  14365. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_5__["RefSelector"])('eContracted')
  14366. ], GroupCellRenderer.prototype, "eContracted", void 0);
  14367. __decorate([
  14368. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_5__["RefSelector"])('eCheckbox')
  14369. ], GroupCellRenderer.prototype, "eCheckbox", void 0);
  14370. __decorate([
  14371. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_5__["RefSelector"])('eValue')
  14372. ], GroupCellRenderer.prototype, "eValue", void 0);
  14373. __decorate([
  14374. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_5__["RefSelector"])('eChildCount')
  14375. ], GroupCellRenderer.prototype, "eChildCount", void 0);
  14376. return GroupCellRenderer;
  14377. }(_widgets_component__WEBPACK_IMPORTED_MODULE_2__["Component"]));
  14378. /***/ }),
  14379. /* 68 */
  14380. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  14381. "use strict";
  14382. __webpack_require__.r(__webpack_exports__);
  14383. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowNode", function() { return RowNode; });
  14384. /* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(36);
  14385. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43);
  14386. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37);
  14387. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25);
  14388. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7);
  14389. /**
  14390. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  14391. * @version v23.2.1
  14392. * @link http://www.ag-grid.com/
  14393. * @license MIT
  14394. */
  14395. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  14396. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  14397. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  14398. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  14399. return c > 3 && r && Object.defineProperty(target, key, r), r;
  14400. };
  14401. var RowNode = /** @class */ (function () {
  14402. function RowNode() {
  14403. /** Children mapped by the pivot columns */
  14404. this.childrenMapped = {};
  14405. /** True by default - can be overridden via gridOptions.isRowSelectable(rowNode) */
  14406. this.selectable = true;
  14407. /** Used by sorting service - to give deterministic sort to groups. Previously we
  14408. * just id for this, however id is a string and had slower sorting compared to numbers. */
  14409. this.__objectId = RowNode.OBJECT_ID_SEQUENCE++;
  14410. /** True when nodes with the same id are being removed and added as part of the same batch transaction */
  14411. this.alreadyRendered = false;
  14412. this.highlighted = null;
  14413. this.selected = false;
  14414. }
  14415. RowNode.prototype.setData = function (data) {
  14416. var oldData = this.data;
  14417. this.data = data;
  14418. this.valueCache.onDataChanged();
  14419. this.updateDataOnDetailNode();
  14420. this.checkRowSelectable();
  14421. var event = this.createDataChangedEvent(data, oldData, false);
  14422. this.dispatchLocalEvent(event);
  14423. };
  14424. // when we are doing master / detail, the detail node is lazy created, but then kept around.
  14425. // so if we show / hide the detail, the same detail rowNode is used. so we need to keep the data
  14426. // in sync, otherwise expand/collapse of the detail would still show the old values.
  14427. RowNode.prototype.updateDataOnDetailNode = function () {
  14428. if (this.detailNode) {
  14429. this.detailNode.data = this.data;
  14430. }
  14431. };
  14432. RowNode.prototype.createDataChangedEvent = function (newData, oldData, update) {
  14433. return {
  14434. type: RowNode.EVENT_DATA_CHANGED,
  14435. node: this,
  14436. oldData: oldData,
  14437. newData: newData,
  14438. update: update
  14439. };
  14440. };
  14441. RowNode.prototype.createLocalRowEvent = function (type) {
  14442. return {
  14443. type: type,
  14444. node: this
  14445. };
  14446. };
  14447. // similar to setRowData, however it is expected that the data is the same data item. this
  14448. // is intended to be used with Redux type stores, where the whole data can be changed. we are
  14449. // guaranteed that the data is the same entity (so grid doesn't need to worry about the id of the
  14450. // underlying data changing, hence doesn't need to worry about selection). the grid, upon receiving
  14451. // dataChanged event, will refresh the cells rather than rip them all out (so user can show transitions).
  14452. RowNode.prototype.updateData = function (data) {
  14453. var oldData = this.data;
  14454. this.data = data;
  14455. this.updateDataOnDetailNode();
  14456. this.checkRowSelectable();
  14457. this.updateDataOnDetailNode();
  14458. var event = this.createDataChangedEvent(data, oldData, true);
  14459. this.dispatchLocalEvent(event);
  14460. };
  14461. RowNode.prototype.getRowIndexString = function () {
  14462. if (this.rowPinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_TOP) {
  14463. return 't-' + this.rowIndex;
  14464. }
  14465. else if (this.rowPinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_BOTTOM) {
  14466. return 'b-' + this.rowIndex;
  14467. }
  14468. return this.rowIndex.toString();
  14469. };
  14470. RowNode.prototype.createDaemonNode = function () {
  14471. var oldNode = new RowNode();
  14472. this.context.createBean(oldNode);
  14473. // just copy the id and data, this is enough for the node to be used
  14474. // in the selection controller (the selection controller is the only
  14475. // place where daemon nodes can live).
  14476. oldNode.id = this.id;
  14477. oldNode.data = this.data;
  14478. oldNode.daemon = true;
  14479. oldNode.selected = this.selected;
  14480. oldNode.level = this.level;
  14481. return oldNode;
  14482. };
  14483. RowNode.prototype.setDataAndId = function (data, id) {
  14484. var oldNode = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].exists(this.id) ? this.createDaemonNode() : null;
  14485. var oldData = this.data;
  14486. this.data = data;
  14487. this.updateDataOnDetailNode();
  14488. this.setId(id);
  14489. this.selectionController.syncInRowNode(this, oldNode);
  14490. this.checkRowSelectable();
  14491. var event = this.createDataChangedEvent(data, oldData, false);
  14492. this.dispatchLocalEvent(event);
  14493. };
  14494. RowNode.prototype.checkRowSelectable = function () {
  14495. var isRowSelectableFunc = this.gridOptionsWrapper.getIsRowSelectableFunc();
  14496. var shouldInvokeIsRowSelectable = isRowSelectableFunc && _utils__WEBPACK_IMPORTED_MODULE_4__["_"].exists(this);
  14497. this.setRowSelectable(shouldInvokeIsRowSelectable ? isRowSelectableFunc(this) : true);
  14498. };
  14499. RowNode.prototype.setRowSelectable = function (newVal) {
  14500. if (this.selectable !== newVal) {
  14501. this.selectable = newVal;
  14502. if (this.eventService) {
  14503. this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_SELECTABLE_CHANGED));
  14504. }
  14505. }
  14506. };
  14507. RowNode.prototype.setId = function (id) {
  14508. // see if user is providing the id's
  14509. var getRowNodeId = this.gridOptionsWrapper.getRowNodeIdFunc();
  14510. if (getRowNodeId) {
  14511. // if user is providing the id's, then we set the id only after the data has been set.
  14512. // this is important for virtual pagination and viewport, where empty rows exist.
  14513. if (this.data) {
  14514. this.id = getRowNodeId(this.data);
  14515. // make sure id provided doesn't start with 'row-group-' as this is reserved. also check that
  14516. // it has 'startsWith' in case the user provided a number.
  14517. if (this.id && this.id.startsWith && this.id.startsWith(RowNode.ID_PREFIX_ROW_GROUP)) {
  14518. console.error("ag-Grid: Row ID's cannot start with " + RowNode.ID_PREFIX_ROW_GROUP + ", this is a reserved prefix for ag-Grid's row grouping feature.");
  14519. }
  14520. }
  14521. else {
  14522. // this can happen if user has set blank into the rowNode after the row previously
  14523. // having data. this happens in virtual page row model, when data is delete and
  14524. // the page is refreshed.
  14525. this.id = undefined;
  14526. }
  14527. }
  14528. else {
  14529. this.id = id;
  14530. }
  14531. };
  14532. RowNode.prototype.isPixelInRange = function (pixel) {
  14533. return pixel >= this.rowTop && pixel < (this.rowTop + this.rowHeight);
  14534. };
  14535. RowNode.prototype.clearRowTop = function () {
  14536. this.oldRowTop = this.rowTop;
  14537. this.setRowTop(null);
  14538. };
  14539. RowNode.prototype.setFirstChild = function (firstChild) {
  14540. if (this.firstChild === firstChild) {
  14541. return;
  14542. }
  14543. this.firstChild = firstChild;
  14544. if (this.eventService) {
  14545. this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_FIRST_CHILD_CHANGED));
  14546. }
  14547. };
  14548. RowNode.prototype.setLastChild = function (lastChild) {
  14549. if (this.lastChild === lastChild) {
  14550. return;
  14551. }
  14552. this.lastChild = lastChild;
  14553. if (this.eventService) {
  14554. this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_LAST_CHILD_CHANGED));
  14555. }
  14556. };
  14557. RowNode.prototype.setChildIndex = function (childIndex) {
  14558. if (this.childIndex === childIndex) {
  14559. return;
  14560. }
  14561. this.childIndex = childIndex;
  14562. if (this.eventService) {
  14563. this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_CHILD_INDEX_CHANGED));
  14564. }
  14565. };
  14566. RowNode.prototype.setRowTop = function (rowTop) {
  14567. if (this.rowTop === rowTop) {
  14568. return;
  14569. }
  14570. this.rowTop = rowTop;
  14571. if (this.eventService) {
  14572. this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_TOP_CHANGED));
  14573. }
  14574. };
  14575. RowNode.prototype.setDragging = function (dragging) {
  14576. if (this.dragging === dragging) {
  14577. return;
  14578. }
  14579. this.dragging = dragging;
  14580. if (this.eventService) {
  14581. this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_DRAGGING_CHANGED));
  14582. }
  14583. };
  14584. RowNode.prototype.setHighlighted = function (highlighted) {
  14585. if (highlighted === this.highlighted) {
  14586. return;
  14587. }
  14588. this.highlighted = highlighted;
  14589. if (this.eventService) {
  14590. this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_HIGHLIGHT_CHANGED));
  14591. }
  14592. };
  14593. RowNode.prototype.setAllChildrenCount = function (allChildrenCount) {
  14594. if (this.allChildrenCount === allChildrenCount) {
  14595. return;
  14596. }
  14597. this.allChildrenCount = allChildrenCount;
  14598. if (this.eventService) {
  14599. this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_ALL_CHILDREN_COUNT_CHANGED));
  14600. }
  14601. };
  14602. RowNode.prototype.setMaster = function (master) {
  14603. if (this.master === master) {
  14604. return;
  14605. }
  14606. // if changing AWAY from master, then unexpand, otherwise
  14607. // next time it's shown it is expanded again
  14608. if (this.master && !master) {
  14609. this.expanded = false;
  14610. }
  14611. this.master = master;
  14612. if (this.eventService) {
  14613. this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_MASTER_CHANGED));
  14614. }
  14615. };
  14616. RowNode.prototype.setRowHeight = function (rowHeight, estimated) {
  14617. if (estimated === void 0) { estimated = false; }
  14618. this.rowHeight = rowHeight;
  14619. this.rowHeightEstimated = estimated;
  14620. if (this.eventService) {
  14621. this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_HEIGHT_CHANGED));
  14622. }
  14623. };
  14624. RowNode.prototype.setRowIndex = function (rowIndex) {
  14625. this.rowIndex = rowIndex;
  14626. if (this.eventService) {
  14627. this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_ROW_INDEX_CHANGED));
  14628. }
  14629. };
  14630. RowNode.prototype.setUiLevel = function (uiLevel) {
  14631. if (this.uiLevel === uiLevel) {
  14632. return;
  14633. }
  14634. this.uiLevel = uiLevel;
  14635. if (this.eventService) {
  14636. this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_UI_LEVEL_CHANGED));
  14637. }
  14638. };
  14639. RowNode.prototype.setExpanded = function (expanded) {
  14640. if (this.expanded === expanded) {
  14641. return;
  14642. }
  14643. this.expanded = expanded;
  14644. if (this.eventService) {
  14645. this.eventService.dispatchEvent(this.createLocalRowEvent(RowNode.EVENT_EXPANDED_CHANGED));
  14646. }
  14647. var event = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].assign({}, this.createGlobalRowEvent(_events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_ROW_GROUP_OPENED), {
  14648. expanded: expanded
  14649. });
  14650. this.mainEventService.dispatchEvent(event);
  14651. if (this.gridOptionsWrapper.isGroupIncludeFooter()) {
  14652. this.gridApi.redrawRows({ rowNodes: [this] });
  14653. }
  14654. };
  14655. RowNode.prototype.createGlobalRowEvent = function (type) {
  14656. return {
  14657. type: type,
  14658. node: this,
  14659. data: this.data,
  14660. rowIndex: this.rowIndex,
  14661. rowPinned: this.rowPinned,
  14662. context: this.gridOptionsWrapper.getContext(),
  14663. api: this.gridOptionsWrapper.getApi(),
  14664. columnApi: this.gridOptionsWrapper.getColumnApi()
  14665. };
  14666. };
  14667. RowNode.prototype.dispatchLocalEvent = function (event) {
  14668. if (this.eventService) {
  14669. this.eventService.dispatchEvent(event);
  14670. }
  14671. };
  14672. // we also allow editing the value via the editors. when it is done via
  14673. // the editors, no 'cell changed' event gets fired, as it's assumed that
  14674. // the cell knows about the change given it's in charge of the editing.
  14675. // this method is for the client to call, so the cell listens for the change
  14676. // event, and also flashes the cell when the change occurs.
  14677. RowNode.prototype.setDataValue = function (colKey, newValue) {
  14678. var column = this.columnController.getPrimaryColumn(colKey);
  14679. var oldValue = this.valueService.getValue(column, this);
  14680. this.valueService.setValue(this, column, newValue);
  14681. this.dispatchCellChangedEvent(column, newValue, oldValue);
  14682. };
  14683. RowNode.prototype.setGroupValue = function (colKey, newValue) {
  14684. var column = this.columnController.getGridColumn(colKey);
  14685. if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].missing(this.groupData)) {
  14686. this.groupData = {};
  14687. }
  14688. var columnId = column.getColId();
  14689. var oldValue = this.groupData[columnId];
  14690. if (oldValue === newValue) {
  14691. return;
  14692. }
  14693. this.groupData[columnId] = newValue;
  14694. this.dispatchCellChangedEvent(column, newValue, oldValue);
  14695. };
  14696. // sets the data for an aggregation
  14697. RowNode.prototype.setAggData = function (newAggData) {
  14698. var _this = this;
  14699. // find out all keys that could potentially change
  14700. var colIds = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].getAllKeysInObjects([this.aggData, newAggData]);
  14701. var oldAggData = this.aggData;
  14702. this.aggData = newAggData;
  14703. // if no event service, nobody has registered for events, so no need fire event
  14704. if (this.eventService) {
  14705. colIds.forEach(function (colId) {
  14706. var column = _this.columnController.getGridColumn(colId);
  14707. var value = _this.aggData ? _this.aggData[colId] : undefined;
  14708. var oldValue = oldAggData ? oldAggData[colId] : undefined;
  14709. _this.dispatchCellChangedEvent(column, value, oldValue);
  14710. });
  14711. }
  14712. };
  14713. RowNode.prototype.hasChildren = function () {
  14714. // we need to return true when this.group=true, as this is used by server side row model
  14715. // (as children are lazy loaded and stored in a cache anyway). otherwise we return true
  14716. // if children exist.
  14717. return this.group || (this.childrenAfterGroup && this.childrenAfterGroup.length > 0);
  14718. };
  14719. RowNode.prototype.isEmptyRowGroupNode = function () {
  14720. return this.group && _utils__WEBPACK_IMPORTED_MODULE_4__["_"].missingOrEmpty(this.childrenAfterGroup);
  14721. };
  14722. RowNode.prototype.dispatchCellChangedEvent = function (column, newValue, oldValue) {
  14723. var cellChangedEvent = {
  14724. type: RowNode.EVENT_CELL_CHANGED,
  14725. node: this,
  14726. column: column,
  14727. newValue: newValue,
  14728. oldValue: oldValue
  14729. };
  14730. this.dispatchLocalEvent(cellChangedEvent);
  14731. };
  14732. RowNode.prototype.resetQuickFilterAggregateText = function () {
  14733. this.quickFilterAggregateText = null;
  14734. };
  14735. RowNode.prototype.isExpandable = function () {
  14736. return this.hasChildren() || this.master;
  14737. };
  14738. RowNode.prototype.isSelected = function () {
  14739. // for footers, we just return what our sibling selected state is, as cannot select a footer
  14740. if (this.footer) {
  14741. return this.sibling.isSelected();
  14742. }
  14743. return this.selected;
  14744. };
  14745. RowNode.prototype.depthFirstSearch = function (callback) {
  14746. if (this.childrenAfterGroup) {
  14747. this.childrenAfterGroup.forEach(function (child) { return child.depthFirstSearch(callback); });
  14748. }
  14749. callback(this);
  14750. };
  14751. // + rowController.updateGroupsInSelection()
  14752. // + selectionController.calculatedSelectedForAllGroupNodes()
  14753. RowNode.prototype.calculateSelectedFromChildren = function () {
  14754. var atLeastOneSelected = false;
  14755. var atLeastOneDeSelected = false;
  14756. var atLeastOneMixed = false;
  14757. var newSelectedValue;
  14758. if (this.childrenAfterGroup) {
  14759. for (var i = 0; i < this.childrenAfterGroup.length; i++) {
  14760. var child = this.childrenAfterGroup[i];
  14761. // skip non-selectable nodes to prevent inconsistent selection values
  14762. if (!child.selectable) {
  14763. continue;
  14764. }
  14765. var childState = child.isSelected();
  14766. switch (childState) {
  14767. case true:
  14768. atLeastOneSelected = true;
  14769. break;
  14770. case false:
  14771. atLeastOneDeSelected = true;
  14772. break;
  14773. default:
  14774. atLeastOneMixed = true;
  14775. break;
  14776. }
  14777. }
  14778. }
  14779. if (atLeastOneMixed) {
  14780. newSelectedValue = undefined;
  14781. }
  14782. else if (atLeastOneSelected && !atLeastOneDeSelected) {
  14783. newSelectedValue = true;
  14784. }
  14785. else if (!atLeastOneSelected && atLeastOneDeSelected) {
  14786. newSelectedValue = false;
  14787. }
  14788. else {
  14789. newSelectedValue = undefined;
  14790. }
  14791. this.selectThisNode(newSelectedValue);
  14792. };
  14793. RowNode.prototype.setSelectedInitialValue = function (selected) {
  14794. this.selected = selected;
  14795. };
  14796. RowNode.prototype.setSelected = function (newValue, clearSelection, suppressFinishActions) {
  14797. if (clearSelection === void 0) { clearSelection = false; }
  14798. if (suppressFinishActions === void 0) { suppressFinishActions = false; }
  14799. this.setSelectedParams({
  14800. newValue: newValue,
  14801. clearSelection: clearSelection,
  14802. suppressFinishActions: suppressFinishActions,
  14803. rangeSelect: false
  14804. });
  14805. };
  14806. RowNode.prototype.isRowPinned = function () {
  14807. return this.rowPinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_TOP || this.rowPinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_BOTTOM;
  14808. };
  14809. // to make calling code more readable, this is the same method as setSelected except it takes names parameters
  14810. RowNode.prototype.setSelectedParams = function (params) {
  14811. var groupSelectsChildren = this.gridOptionsWrapper.isGroupSelectsChildren();
  14812. var newValue = params.newValue === true;
  14813. var clearSelection = params.clearSelection === true;
  14814. var suppressFinishActions = params.suppressFinishActions === true;
  14815. var rangeSelect = params.rangeSelect === true;
  14816. // groupSelectsFiltered only makes sense when group selects children
  14817. var groupSelectsFiltered = groupSelectsChildren && (params.groupSelectsFiltered === true);
  14818. if (this.id === undefined) {
  14819. console.warn('ag-Grid: cannot select node until id for node is known');
  14820. return 0;
  14821. }
  14822. if (this.rowPinned) {
  14823. console.warn('ag-Grid: cannot select pinned rows');
  14824. return 0;
  14825. }
  14826. // if we are a footer, we don't do selection, just pass the info
  14827. // to the sibling (the parent of the group)
  14828. if (this.footer) {
  14829. var count = this.sibling.setSelectedParams(params);
  14830. return count;
  14831. }
  14832. if (rangeSelect) {
  14833. var newRowClicked = this.selectionController.getLastSelectedNode() !== this;
  14834. var allowMultiSelect = this.gridOptionsWrapper.isRowSelectionMulti();
  14835. if (newRowClicked && allowMultiSelect) {
  14836. return this.doRowRangeSelection();
  14837. }
  14838. }
  14839. var updatedCount = 0;
  14840. // when groupSelectsFiltered, then this node may end up intermediate despite
  14841. // trying to set it to true / false. this group will be calculated further on
  14842. // down when we call calculatedSelectedForAllGroupNodes(). we need to skip it
  14843. // here, otherwise the updatedCount would include it.
  14844. var skipThisNode = groupSelectsFiltered && this.group;
  14845. if (!skipThisNode) {
  14846. var thisNodeWasSelected = this.selectThisNode(newValue);
  14847. if (thisNodeWasSelected) {
  14848. updatedCount++;
  14849. }
  14850. }
  14851. if (groupSelectsChildren && this.group) {
  14852. updatedCount += this.selectChildNodes(newValue, groupSelectsFiltered);
  14853. }
  14854. // clear other nodes if not doing multi select
  14855. if (!suppressFinishActions) {
  14856. var clearOtherNodes = newValue && (clearSelection || !this.gridOptionsWrapper.isRowSelectionMulti());
  14857. if (clearOtherNodes) {
  14858. updatedCount += this.selectionController.clearOtherNodes(this);
  14859. }
  14860. // only if we selected something, then update groups and fire events
  14861. if (updatedCount > 0) {
  14862. this.selectionController.updateGroupsFromChildrenSelections();
  14863. // this is the very end of the 'action node', so we are finished all the updates,
  14864. // include any parent / child changes that this method caused
  14865. var event_1 = {
  14866. type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_SELECTION_CHANGED,
  14867. api: this.gridApi,
  14868. columnApi: this.columnApi
  14869. };
  14870. this.mainEventService.dispatchEvent(event_1);
  14871. }
  14872. // so if user next does shift-select, we know where to start the selection from
  14873. if (newValue) {
  14874. this.selectionController.setLastSelectedNode(this);
  14875. }
  14876. }
  14877. return updatedCount;
  14878. };
  14879. // selects all rows between this node and the last selected node (or the top if this is the first selection).
  14880. // not to be mixed up with 'cell range selection' where you drag the mouse, this is row range selection, by
  14881. // holding down 'shift'.
  14882. RowNode.prototype.doRowRangeSelection = function () {
  14883. var groupsSelectChildren = this.gridOptionsWrapper.isGroupSelectsChildren();
  14884. var lastSelectedNode = this.selectionController.getLastSelectedNode();
  14885. var nodesToSelect = this.rowModel.getNodesInRangeForSelection(this, lastSelectedNode);
  14886. var updatedCount = 0;
  14887. nodesToSelect.forEach(function (rowNode) {
  14888. if (rowNode.group && groupsSelectChildren) {
  14889. return;
  14890. }
  14891. var nodeWasSelected = rowNode.selectThisNode(true);
  14892. if (nodeWasSelected) {
  14893. updatedCount++;
  14894. }
  14895. });
  14896. this.selectionController.updateGroupsFromChildrenSelections();
  14897. var event = {
  14898. type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_SELECTION_CHANGED,
  14899. api: this.gridApi,
  14900. columnApi: this.columnApi
  14901. };
  14902. this.mainEventService.dispatchEvent(event);
  14903. return updatedCount;
  14904. };
  14905. RowNode.prototype.isParentOfNode = function (potentialParent) {
  14906. var parentNode = this.parent;
  14907. while (parentNode) {
  14908. if (parentNode === potentialParent) {
  14909. return true;
  14910. }
  14911. parentNode = parentNode.parent;
  14912. }
  14913. return false;
  14914. };
  14915. RowNode.prototype.selectThisNode = function (newValue) {
  14916. // we only check selectable when newValue=true (ie selecting) to allow unselecting values,
  14917. // as selectable is dynamic, need a way to unselect rows when selectable becomes false.
  14918. var selectionNotAllowed = !this.selectable && newValue;
  14919. var selectionNotChanged = this.selected === newValue;
  14920. if (selectionNotAllowed || selectionNotChanged) {
  14921. return false;
  14922. }
  14923. this.selected = newValue;
  14924. if (this.eventService) {
  14925. this.dispatchLocalEvent(this.createLocalRowEvent(RowNode.EVENT_ROW_SELECTED));
  14926. }
  14927. var event = this.createGlobalRowEvent(_events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_ROW_SELECTED);
  14928. this.mainEventService.dispatchEvent(event);
  14929. return true;
  14930. };
  14931. RowNode.prototype.selectChildNodes = function (newValue, groupSelectsFiltered) {
  14932. var children = groupSelectsFiltered ? this.childrenAfterFilter : this.childrenAfterGroup;
  14933. if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].missing(children)) {
  14934. return;
  14935. }
  14936. var updatedCount = 0;
  14937. for (var i = 0; i < children.length; i++) {
  14938. updatedCount += children[i].setSelectedParams({
  14939. newValue: newValue,
  14940. clearSelection: false,
  14941. suppressFinishActions: true,
  14942. groupSelectsFiltered: groupSelectsFiltered
  14943. });
  14944. }
  14945. return updatedCount;
  14946. };
  14947. RowNode.prototype.addEventListener = function (eventType, listener) {
  14948. if (!this.eventService) {
  14949. this.eventService = new _eventService__WEBPACK_IMPORTED_MODULE_0__["EventService"]();
  14950. }
  14951. this.eventService.addEventListener(eventType, listener);
  14952. };
  14953. RowNode.prototype.removeEventListener = function (eventType, listener) {
  14954. this.eventService.removeEventListener(eventType, listener);
  14955. };
  14956. RowNode.prototype.onMouseEnter = function () {
  14957. this.dispatchLocalEvent(this.createLocalRowEvent(RowNode.EVENT_MOUSE_ENTER));
  14958. };
  14959. RowNode.prototype.onMouseLeave = function () {
  14960. this.dispatchLocalEvent(this.createLocalRowEvent(RowNode.EVENT_MOUSE_LEAVE));
  14961. };
  14962. RowNode.prototype.getFirstChildOfFirstChild = function (rowGroupColumn) {
  14963. var currentRowNode = this;
  14964. var isCandidate = true;
  14965. var foundFirstChildPath = false;
  14966. var nodeToSwapIn;
  14967. // if we are hiding groups, then if we are the first child, of the first child,
  14968. // all the way up to the column we are interested in, then we show the group cell.
  14969. while (isCandidate && !foundFirstChildPath) {
  14970. var parentRowNode = currentRowNode.parent;
  14971. var firstChild = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].exists(parentRowNode) && currentRowNode.firstChild;
  14972. if (firstChild) {
  14973. if (parentRowNode.rowGroupColumn === rowGroupColumn) {
  14974. foundFirstChildPath = true;
  14975. nodeToSwapIn = parentRowNode;
  14976. }
  14977. }
  14978. else {
  14979. isCandidate = false;
  14980. }
  14981. currentRowNode = parentRowNode;
  14982. }
  14983. return foundFirstChildPath ? nodeToSwapIn : null;
  14984. };
  14985. RowNode.prototype.isFullWidthCell = function () {
  14986. var isFullWidthCellFunc = this.gridOptionsWrapper.getIsFullWidthCellFunc();
  14987. return isFullWidthCellFunc ? isFullWidthCellFunc(this) : false;
  14988. };
  14989. RowNode.ID_PREFIX_ROW_GROUP = 'row-group-';
  14990. RowNode.ID_PREFIX_TOP_PINNED = 't-';
  14991. RowNode.ID_PREFIX_BOTTOM_PINNED = 'b-';
  14992. RowNode.OBJECT_ID_SEQUENCE = 0;
  14993. RowNode.EVENT_ROW_SELECTED = 'rowSelected';
  14994. RowNode.EVENT_DATA_CHANGED = 'dataChanged';
  14995. RowNode.EVENT_CELL_CHANGED = 'cellChanged';
  14996. RowNode.EVENT_ALL_CHILDREN_COUNT_CHANGED = 'allChildrenCountChanged';
  14997. RowNode.EVENT_MASTER_CHANGED = 'masterChanged';
  14998. RowNode.EVENT_MOUSE_ENTER = 'mouseEnter';
  14999. RowNode.EVENT_MOUSE_LEAVE = 'mouseLeave';
  15000. RowNode.EVENT_HEIGHT_CHANGED = 'heightChanged';
  15001. RowNode.EVENT_TOP_CHANGED = 'topChanged';
  15002. RowNode.EVENT_FIRST_CHILD_CHANGED = 'firstChildChanged';
  15003. RowNode.EVENT_LAST_CHILD_CHANGED = 'lastChildChanged';
  15004. RowNode.EVENT_CHILD_INDEX_CHANGED = 'childIndexChanged';
  15005. RowNode.EVENT_ROW_INDEX_CHANGED = 'rowIndexChanged';
  15006. RowNode.EVENT_EXPANDED_CHANGED = 'expandedChanged';
  15007. RowNode.EVENT_SELECTABLE_CHANGED = 'selectableChanged';
  15008. RowNode.EVENT_UI_LEVEL_CHANGED = 'uiLevelChanged';
  15009. RowNode.EVENT_HIGHLIGHT_CHANGED = 'rowHighlightChanged';
  15010. RowNode.EVENT_DRAGGING_CHANGED = 'draggingChanged';
  15011. __decorate([
  15012. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('eventService')
  15013. ], RowNode.prototype, "mainEventService", void 0);
  15014. __decorate([
  15015. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper')
  15016. ], RowNode.prototype, "gridOptionsWrapper", void 0);
  15017. __decorate([
  15018. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('selectionController')
  15019. ], RowNode.prototype, "selectionController", void 0);
  15020. __decorate([
  15021. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnController')
  15022. ], RowNode.prototype, "columnController", void 0);
  15023. __decorate([
  15024. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('valueService')
  15025. ], RowNode.prototype, "valueService", void 0);
  15026. __decorate([
  15027. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('rowModel')
  15028. ], RowNode.prototype, "rowModel", void 0);
  15029. __decorate([
  15030. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('context')
  15031. ], RowNode.prototype, "context", void 0);
  15032. __decorate([
  15033. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('valueCache')
  15034. ], RowNode.prototype, "valueCache", void 0);
  15035. __decorate([
  15036. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnApi')
  15037. ], RowNode.prototype, "columnApi", void 0);
  15038. __decorate([
  15039. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridApi')
  15040. ], RowNode.prototype, "gridApi", void 0);
  15041. return RowNode;
  15042. }());
  15043. /***/ }),
  15044. /* 69 */
  15045. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  15046. "use strict";
  15047. __webpack_require__.r(__webpack_exports__);
  15048. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CheckboxSelectionComponent", function() { return CheckboxSelectionComponent; });
  15049. /* harmony import */ var _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(70);
  15050. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  15051. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(56);
  15052. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(43);
  15053. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(57);
  15054. /* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(68);
  15055. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(7);
  15056. /**
  15057. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  15058. * @version v23.2.1
  15059. * @link http://www.ag-grid.com/
  15060. * @license MIT
  15061. */
  15062. var __extends = (undefined && undefined.__extends) || (function () {
  15063. var extendStatics = function (d, b) {
  15064. extendStatics = Object.setPrototypeOf ||
  15065. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  15066. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  15067. return extendStatics(d, b);
  15068. };
  15069. return function (d, b) {
  15070. extendStatics(d, b);
  15071. function __() { this.constructor = d; }
  15072. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  15073. };
  15074. })();
  15075. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  15076. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  15077. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  15078. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  15079. return c > 3 && r && Object.defineProperty(target, key, r), r;
  15080. };
  15081. var CheckboxSelectionComponent = /** @class */ (function (_super) {
  15082. __extends(CheckboxSelectionComponent, _super);
  15083. function CheckboxSelectionComponent() {
  15084. return _super.call(this, /* html*/ "\n <div class=\"ag-selection-checkbox\">\n <ag-checkbox role=\"presentation\" ref=\"eCheckbox\"></ag-checkbox>\n </div>") || this;
  15085. }
  15086. CheckboxSelectionComponent.prototype.onDataChanged = function () {
  15087. // when rows are loaded for the second time, this can impact the selection, as a row
  15088. // could be loaded as already selected (if user scrolls down, and then up again).
  15089. this.onSelectionChanged();
  15090. };
  15091. CheckboxSelectionComponent.prototype.onSelectableChanged = function () {
  15092. this.showOrHideSelect();
  15093. };
  15094. CheckboxSelectionComponent.prototype.onSelectionChanged = function () {
  15095. var state = this.rowNode.isSelected();
  15096. this.eCheckbox.setValue(state, true);
  15097. };
  15098. CheckboxSelectionComponent.prototype.onCheckedClicked = function () {
  15099. var groupSelectsFiltered = this.gridOptionsWrapper.isGroupSelectsFiltered();
  15100. var updatedCount = this.rowNode.setSelectedParams({ newValue: false, groupSelectsFiltered: groupSelectsFiltered });
  15101. return updatedCount;
  15102. };
  15103. CheckboxSelectionComponent.prototype.onUncheckedClicked = function (event) {
  15104. var groupSelectsFiltered = this.gridOptionsWrapper.isGroupSelectsFiltered();
  15105. var updatedCount = this.rowNode.setSelectedParams({ newValue: true, rangeSelect: event.shiftKey, groupSelectsFiltered: groupSelectsFiltered });
  15106. return updatedCount;
  15107. };
  15108. CheckboxSelectionComponent.prototype.init = function (params) {
  15109. var _this = this;
  15110. this.rowNode = params.rowNode;
  15111. this.column = params.column;
  15112. this.onSelectionChanged();
  15113. // we don't want the row clicked event to fire when selecting the checkbox, otherwise the row
  15114. // would possibly get selected twice
  15115. this.addGuiEventListener('click', function (event) { return _utils__WEBPACK_IMPORTED_MODULE_6__["_"].stopPropagationForAgGrid(event); });
  15116. // likewise we don't want double click on this icon to open a group
  15117. this.addGuiEventListener('dblclick', function (event) { return _utils__WEBPACK_IMPORTED_MODULE_6__["_"].stopPropagationForAgGrid(event); });
  15118. this.addManagedListener(this.eCheckbox, _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_0__["AgCheckbox"].EVENT_CHANGED, function (params) {
  15119. if (params.selected) {
  15120. _this.onUncheckedClicked(params.event || {});
  15121. }
  15122. else {
  15123. _this.onCheckedClicked();
  15124. }
  15125. });
  15126. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_5__["RowNode"].EVENT_ROW_SELECTED, this.onSelectionChanged.bind(this));
  15127. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_5__["RowNode"].EVENT_DATA_CHANGED, this.onDataChanged.bind(this));
  15128. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_5__["RowNode"].EVENT_SELECTABLE_CHANGED, this.onSelectableChanged.bind(this));
  15129. this.isRowSelectableFunc = this.gridOptionsWrapper.getIsRowSelectableFunc();
  15130. var checkboxVisibleIsDynamic = this.isRowSelectableFunc || this.checkboxCallbackExists();
  15131. if (checkboxVisibleIsDynamic) {
  15132. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.showOrHideSelect.bind(this));
  15133. this.showOrHideSelect();
  15134. }
  15135. this.eCheckbox.setInputAriaLabel('Toggle Row Selection');
  15136. };
  15137. CheckboxSelectionComponent.prototype.showOrHideSelect = function () {
  15138. // if the isRowSelectable() is not provided the row node is selectable by default
  15139. var selectable = this.rowNode.selectable;
  15140. // checkboxSelection callback is deemed a legacy solution however we will still consider it's result.
  15141. // If selectable, then also check the colDef callback. if not selectable, this it short circuits - no need
  15142. // to call the colDef callback.
  15143. if (selectable && this.checkboxCallbackExists()) {
  15144. selectable = this.column.isCellCheckboxSelection(this.rowNode);
  15145. }
  15146. // show checkbox if both conditions are true
  15147. this.setDisplayed(selectable);
  15148. };
  15149. CheckboxSelectionComponent.prototype.checkboxCallbackExists = function () {
  15150. // column will be missing if groupUseEntireRow=true
  15151. var colDef = this.column ? this.column.getColDef() : null;
  15152. return colDef && typeof colDef.checkboxSelection === 'function';
  15153. };
  15154. __decorate([
  15155. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  15156. ], CheckboxSelectionComponent.prototype, "gridOptionsWrapper", void 0);
  15157. __decorate([
  15158. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eCheckbox')
  15159. ], CheckboxSelectionComponent.prototype, "eCheckbox", void 0);
  15160. return CheckboxSelectionComponent;
  15161. }(_widgets_component__WEBPACK_IMPORTED_MODULE_2__["Component"]));
  15162. /***/ }),
  15163. /* 70 */
  15164. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  15165. "use strict";
  15166. __webpack_require__.r(__webpack_exports__);
  15167. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgCheckbox", function() { return AgCheckbox; });
  15168. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  15169. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43);
  15170. /* harmony import */ var _agAbstractInputField__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(71);
  15171. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  15172. /**
  15173. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  15174. * @version v23.2.1
  15175. * @link http://www.ag-grid.com/
  15176. * @license MIT
  15177. */
  15178. var __extends = (undefined && undefined.__extends) || (function () {
  15179. var extendStatics = function (d, b) {
  15180. extendStatics = Object.setPrototypeOf ||
  15181. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  15182. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  15183. return extendStatics(d, b);
  15184. };
  15185. return function (d, b) {
  15186. extendStatics(d, b);
  15187. function __() { this.constructor = d; }
  15188. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  15189. };
  15190. })();
  15191. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  15192. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  15193. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  15194. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  15195. return c > 3 && r && Object.defineProperty(target, key, r), r;
  15196. };
  15197. var AgCheckbox = /** @class */ (function (_super) {
  15198. __extends(AgCheckbox, _super);
  15199. function AgCheckbox() {
  15200. var _this = _super.call(this) || this;
  15201. _this.className = 'ag-checkbox';
  15202. _this.displayTag = 'input';
  15203. _this.inputType = 'checkbox';
  15204. _this.labelAlignment = 'right';
  15205. _this.selected = false;
  15206. _this.readOnly = false;
  15207. _this.passive = false;
  15208. _this.setTemplate(_this.TEMPLATE.replace(/%displayField%/g, _this.displayTag));
  15209. return _this;
  15210. }
  15211. AgCheckbox.prototype.addInputListeners = function () {
  15212. this.addManagedListener(this.eInput, 'click', this.onCheckboxClick.bind(this));
  15213. };
  15214. AgCheckbox.prototype.getNextValue = function () {
  15215. return this.selected === undefined ? true : !this.selected;
  15216. };
  15217. AgCheckbox.prototype.setPassive = function (passive) {
  15218. this.passive = passive;
  15219. };
  15220. AgCheckbox.prototype.isReadOnly = function () {
  15221. return this.readOnly;
  15222. };
  15223. AgCheckbox.prototype.setReadOnly = function (readOnly) {
  15224. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addOrRemoveCssClass(this.eWrapper, 'ag-disabled', readOnly);
  15225. this.eInput.disabled = readOnly;
  15226. this.readOnly = readOnly;
  15227. };
  15228. AgCheckbox.prototype.setDisabled = function (disabled) {
  15229. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addOrRemoveCssClass(this.eWrapper, 'ag-disabled', disabled);
  15230. return _super.prototype.setDisabled.call(this, disabled);
  15231. };
  15232. AgCheckbox.prototype.toggle = function () {
  15233. var nextValue = this.getNextValue();
  15234. if (this.passive) {
  15235. this.dispatchChange(nextValue);
  15236. }
  15237. else {
  15238. this.setValue(nextValue);
  15239. }
  15240. };
  15241. AgCheckbox.prototype.getValue = function () {
  15242. return this.isSelected();
  15243. };
  15244. AgCheckbox.prototype.setValue = function (value, silent) {
  15245. this.refreshSelectedClass(value);
  15246. this.setSelected(value, silent);
  15247. return this;
  15248. };
  15249. AgCheckbox.prototype.setName = function (name) {
  15250. var input = this.getInputElement();
  15251. input.name = name;
  15252. return this;
  15253. };
  15254. AgCheckbox.prototype.isSelected = function () {
  15255. return this.selected;
  15256. };
  15257. AgCheckbox.prototype.setSelected = function (selected, silent) {
  15258. if (this.isSelected() === selected) {
  15259. return;
  15260. }
  15261. this.selected = typeof selected === 'boolean' ? selected : undefined;
  15262. this.eInput.checked = this.selected;
  15263. this.eInput.indeterminate = this.selected === undefined;
  15264. if (!silent) {
  15265. this.dispatchChange(this.selected);
  15266. }
  15267. };
  15268. AgCheckbox.prototype.dispatchChange = function (selected, event) {
  15269. this.dispatchEvent({ type: AgCheckbox.EVENT_CHANGED, selected: selected, event: event });
  15270. var input = this.getInputElement();
  15271. var checkboxChangedEvent = {
  15272. type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CHECKBOX_CHANGED,
  15273. id: input.id,
  15274. name: input.name,
  15275. selected: selected
  15276. };
  15277. this.eventService.dispatchEvent(checkboxChangedEvent);
  15278. };
  15279. AgCheckbox.prototype.onCheckboxClick = function (e) {
  15280. this.selected = e.target.checked;
  15281. this.refreshSelectedClass(this.selected);
  15282. this.dispatchChange(this.selected, e);
  15283. };
  15284. AgCheckbox.prototype.refreshSelectedClass = function (value) {
  15285. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addOrRemoveCssClass(this.eWrapper, 'ag-checked', value === true);
  15286. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addOrRemoveCssClass(this.eWrapper, 'ag-indeterminate', value == null);
  15287. };
  15288. __decorate([
  15289. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  15290. ], AgCheckbox.prototype, "gridOptionsWrapper", void 0);
  15291. return AgCheckbox;
  15292. }(_agAbstractInputField__WEBPACK_IMPORTED_MODULE_2__["AgAbstractInputField"]));
  15293. /***/ }),
  15294. /* 71 */
  15295. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  15296. "use strict";
  15297. __webpack_require__.r(__webpack_exports__);
  15298. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgAbstractInputField", function() { return AgAbstractInputField; });
  15299. /* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57);
  15300. /* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(72);
  15301. /* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(12);
  15302. /**
  15303. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  15304. * @version v23.2.1
  15305. * @link http://www.ag-grid.com/
  15306. * @license MIT
  15307. */
  15308. var __extends = (undefined && undefined.__extends) || (function () {
  15309. var extendStatics = function (d, b) {
  15310. extendStatics = Object.setPrototypeOf ||
  15311. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  15312. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  15313. return extendStatics(d, b);
  15314. };
  15315. return function (d, b) {
  15316. extendStatics(d, b);
  15317. function __() { this.constructor = d; }
  15318. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  15319. };
  15320. })();
  15321. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  15322. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  15323. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  15324. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  15325. return c > 3 && r && Object.defineProperty(target, key, r), r;
  15326. };
  15327. var AgAbstractInputField = /** @class */ (function (_super) {
  15328. __extends(AgAbstractInputField, _super);
  15329. function AgAbstractInputField() {
  15330. var _this = _super !== null && _super.apply(this, arguments) || this;
  15331. _this.config = {};
  15332. _this.TEMPLATE = "\n <div role=\"presentation\">\n <label ref=\"eLabel\" class=\"ag-input-field-label\"></label>\n <div ref=\"eWrapper\" class=\"ag-wrapper ag-input-wrapper\" role=\"presentation\">\n <%displayField% ref=\"eInput\" class=\"ag-input-field-input\"></%displayField%>\n </div>\n </div>";
  15333. return _this;
  15334. }
  15335. AgAbstractInputField.prototype.postConstruct = function () {
  15336. _super.prototype.postConstruct.call(this);
  15337. this.setInputType();
  15338. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["addCssClass"])(this.eLabel, this.className + "-label");
  15339. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["addCssClass"])(this.eWrapper, this.className + "-input-wrapper");
  15340. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["addCssClass"])(this.eInput, this.className + "-input");
  15341. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["addCssClass"])(this.getGui(), 'ag-input-field');
  15342. var inputId = this.eInput.id ? this.eInput.id : "ag-input-id-" + this.getCompId();
  15343. this.eLabel.htmlFor = inputId;
  15344. this.eInput.id = inputId;
  15345. var _a = this.config, width = _a.width, value = _a.value;
  15346. if (width != null) {
  15347. this.setWidth(width);
  15348. }
  15349. if (value != null) {
  15350. this.setValue(value);
  15351. }
  15352. this.addInputListeners();
  15353. };
  15354. AgAbstractInputField.prototype.addInputListeners = function () {
  15355. var _this = this;
  15356. this.addManagedListener(this.eInput, 'input', function (e) {
  15357. var value = e.target.value;
  15358. _this.setValue(value);
  15359. });
  15360. };
  15361. AgAbstractInputField.prototype.setInputType = function () {
  15362. if (this.inputType) {
  15363. this.eInput.setAttribute('type', this.inputType);
  15364. }
  15365. };
  15366. AgAbstractInputField.prototype.getInputElement = function () {
  15367. return this.eInput;
  15368. };
  15369. AgAbstractInputField.prototype.setInputWidth = function (width) {
  15370. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["setElementWidth"])(this.eWrapper, width);
  15371. return this;
  15372. };
  15373. AgAbstractInputField.prototype.setInputName = function (name) {
  15374. this.getInputElement().setAttribute('name', name);
  15375. return this;
  15376. };
  15377. AgAbstractInputField.prototype.getFocusableElement = function () {
  15378. return this.eInput;
  15379. };
  15380. AgAbstractInputField.prototype.setMaxLength = function (length) {
  15381. var eInput = this.eInput;
  15382. eInput.maxLength = length;
  15383. return this;
  15384. };
  15385. AgAbstractInputField.prototype.setInputPlaceholder = function (placeholder) {
  15386. var eInput = this.eInput;
  15387. var attributeName = 'placeholder';
  15388. if (placeholder) {
  15389. eInput.setAttribute(attributeName, placeholder);
  15390. }
  15391. else {
  15392. eInput.removeAttribute(attributeName);
  15393. }
  15394. return this;
  15395. };
  15396. AgAbstractInputField.prototype.setDisabled = function (disabled) {
  15397. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_2__["setDisabled"])(this.eInput, disabled);
  15398. return _super.prototype.setDisabled.call(this, disabled);
  15399. };
  15400. AgAbstractInputField.prototype.setInputAriaLabel = function (label) {
  15401. this.eInput.setAttribute('aria-label', label);
  15402. return this;
  15403. };
  15404. __decorate([
  15405. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eLabel')
  15406. ], AgAbstractInputField.prototype, "eLabel", void 0);
  15407. __decorate([
  15408. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eWrapper')
  15409. ], AgAbstractInputField.prototype, "eWrapper", void 0);
  15410. __decorate([
  15411. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eInput')
  15412. ], AgAbstractInputField.prototype, "eInput", void 0);
  15413. return AgAbstractInputField;
  15414. }(_agAbstractField__WEBPACK_IMPORTED_MODULE_1__["AgAbstractField"]));
  15415. /***/ }),
  15416. /* 72 */
  15417. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  15418. "use strict";
  15419. __webpack_require__.r(__webpack_exports__);
  15420. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgAbstractField", function() { return AgAbstractField; });
  15421. /* harmony import */ var _agAbstractLabel__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(73);
  15422. /* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(12);
  15423. /**
  15424. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  15425. * @version v23.2.1
  15426. * @link http://www.ag-grid.com/
  15427. * @license MIT
  15428. */
  15429. var __extends = (undefined && undefined.__extends) || (function () {
  15430. var extendStatics = function (d, b) {
  15431. extendStatics = Object.setPrototypeOf ||
  15432. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  15433. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  15434. return extendStatics(d, b);
  15435. };
  15436. return function (d, b) {
  15437. extendStatics(d, b);
  15438. function __() { this.constructor = d; }
  15439. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  15440. };
  15441. })();
  15442. var AgAbstractField = /** @class */ (function (_super) {
  15443. __extends(AgAbstractField, _super);
  15444. function AgAbstractField() {
  15445. var _this = _super !== null && _super.apply(this, arguments) || this;
  15446. _this.disabled = false;
  15447. return _this;
  15448. }
  15449. AgAbstractField.prototype.postConstruct = function () {
  15450. _super.prototype.postConstruct.call(this);
  15451. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["addCssClass"])(this.getGui(), this.className);
  15452. };
  15453. AgAbstractField.prototype.onValueChange = function (callbackFn) {
  15454. var _this = this;
  15455. this.addManagedListener(this, AgAbstractField.EVENT_CHANGED, function () { return callbackFn(_this.getValue()); });
  15456. return this;
  15457. };
  15458. AgAbstractField.prototype.getWidth = function () {
  15459. return this.getGui().clientWidth;
  15460. };
  15461. AgAbstractField.prototype.setWidth = function (width) {
  15462. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["setFixedWidth"])(this.getGui(), width);
  15463. return this;
  15464. };
  15465. AgAbstractField.prototype.getValue = function () {
  15466. return this.value;
  15467. };
  15468. AgAbstractField.prototype.setValue = function (value, silent) {
  15469. if (this.value === value) {
  15470. return this;
  15471. }
  15472. this.value = value;
  15473. if (!silent) {
  15474. this.dispatchEvent({ type: AgAbstractField.EVENT_CHANGED });
  15475. }
  15476. return this;
  15477. };
  15478. AgAbstractField.prototype.setDisabled = function (disabled) {
  15479. disabled = !!disabled;
  15480. var element = this.getGui();
  15481. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["setDisabled"])(element, disabled);
  15482. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_1__["addOrRemoveCssClass"])(element, 'ag-disabled', disabled);
  15483. this.disabled = disabled;
  15484. return this;
  15485. };
  15486. AgAbstractField.prototype.isDisabled = function () {
  15487. return !!this.disabled;
  15488. };
  15489. AgAbstractField.EVENT_CHANGED = 'valueChange';
  15490. return AgAbstractField;
  15491. }(_agAbstractLabel__WEBPACK_IMPORTED_MODULE_0__["AgAbstractLabel"]));
  15492. /***/ }),
  15493. /* 73 */
  15494. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  15495. "use strict";
  15496. __webpack_require__.r(__webpack_exports__);
  15497. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgAbstractLabel", function() { return AgAbstractLabel; });
  15498. /* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56);
  15499. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  15500. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
  15501. /**
  15502. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  15503. * @version v23.2.1
  15504. * @link http://www.ag-grid.com/
  15505. * @license MIT
  15506. */
  15507. var __extends = (undefined && undefined.__extends) || (function () {
  15508. var extendStatics = function (d, b) {
  15509. extendStatics = Object.setPrototypeOf ||
  15510. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  15511. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  15512. return extendStatics(d, b);
  15513. };
  15514. return function (d, b) {
  15515. extendStatics(d, b);
  15516. function __() { this.constructor = d; }
  15517. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  15518. };
  15519. })();
  15520. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  15521. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  15522. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  15523. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  15524. return c > 3 && r && Object.defineProperty(target, key, r), r;
  15525. };
  15526. var AgAbstractLabel = /** @class */ (function (_super) {
  15527. __extends(AgAbstractLabel, _super);
  15528. function AgAbstractLabel() {
  15529. var _this = _super !== null && _super.apply(this, arguments) || this;
  15530. _this.labelSeparator = '';
  15531. _this.labelAlignment = 'left';
  15532. _this.config = {};
  15533. _this.label = '';
  15534. return _this;
  15535. }
  15536. AgAbstractLabel.prototype.postConstruct = function () {
  15537. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(this.getGui(), 'ag-labeled');
  15538. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(this.eLabel, 'ag-label');
  15539. var _a = this.config, labelSeparator = _a.labelSeparator, label = _a.label, labelWidth = _a.labelWidth, labelAlignment = _a.labelAlignment;
  15540. if (labelSeparator != null) {
  15541. this.setLabelSeparator(labelSeparator);
  15542. }
  15543. if (label != null) {
  15544. this.setLabel(label);
  15545. }
  15546. if (labelWidth != null) {
  15547. this.setLabelWidth(labelWidth);
  15548. }
  15549. this.setLabelAlignment(labelAlignment || this.labelAlignment);
  15550. this.refreshLabel();
  15551. };
  15552. AgAbstractLabel.prototype.refreshLabel = function () {
  15553. this.eLabel.innerText = this.label + this.labelSeparator;
  15554. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addOrRemoveCssClass(this.eLabel, 'ag-hidden', this.label === '');
  15555. };
  15556. AgAbstractLabel.prototype.setLabelSeparator = function (labelSeparator) {
  15557. if (this.labelSeparator === labelSeparator) {
  15558. return this;
  15559. }
  15560. this.labelSeparator = labelSeparator;
  15561. if (this.label != null) {
  15562. this.refreshLabel();
  15563. }
  15564. return this;
  15565. };
  15566. AgAbstractLabel.prototype.setLabel = function (label) {
  15567. if (this.label === label) {
  15568. return this;
  15569. }
  15570. this.label = label;
  15571. this.refreshLabel();
  15572. return this;
  15573. };
  15574. AgAbstractLabel.prototype.setLabelAlignment = function (alignment) {
  15575. var eGui = this.getGui();
  15576. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addOrRemoveCssClass(eGui, 'ag-label-align-left', alignment === 'left');
  15577. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addOrRemoveCssClass(eGui, 'ag-label-align-right', alignment === 'right');
  15578. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addOrRemoveCssClass(eGui, 'ag-label-align-top', alignment === 'top');
  15579. return this;
  15580. };
  15581. AgAbstractLabel.prototype.setLabelWidth = function (width) {
  15582. if (this.label == null) {
  15583. return this;
  15584. }
  15585. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].setElementWidth(this.eLabel, width);
  15586. return this;
  15587. };
  15588. __decorate([
  15589. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  15590. ], AgAbstractLabel.prototype, "postConstruct", null);
  15591. return AgAbstractLabel;
  15592. }(_component__WEBPACK_IMPORTED_MODULE_0__["Component"]));
  15593. /***/ }),
  15594. /* 74 */
  15595. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  15596. "use strict";
  15597. __webpack_require__.r(__webpack_exports__);
  15598. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ComponentSource", function() { return ComponentSource; });
  15599. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "UserComponentFactory", function() { return UserComponentFactory; });
  15600. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  15601. /* harmony import */ var _userComponentRegistry__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(53);
  15602. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
  15603. /* harmony import */ var _componentTypes__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(75);
  15604. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(41);
  15605. /* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(16);
  15606. /**
  15607. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  15608. * @version v23.2.1
  15609. * @link http://www.ag-grid.com/
  15610. * @license MIT
  15611. */
  15612. var __extends = (undefined && undefined.__extends) || (function () {
  15613. var extendStatics = function (d, b) {
  15614. extendStatics = Object.setPrototypeOf ||
  15615. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  15616. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  15617. return extendStatics(d, b);
  15618. };
  15619. return function (d, b) {
  15620. extendStatics(d, b);
  15621. function __() { this.constructor = d; }
  15622. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  15623. };
  15624. })();
  15625. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  15626. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  15627. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  15628. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  15629. return c > 3 && r && Object.defineProperty(target, key, r), r;
  15630. };
  15631. var ComponentSource;
  15632. (function (ComponentSource) {
  15633. ComponentSource[ComponentSource["DEFAULT"] = 0] = "DEFAULT";
  15634. ComponentSource[ComponentSource["REGISTERED_BY_NAME"] = 1] = "REGISTERED_BY_NAME";
  15635. ComponentSource[ComponentSource["HARDCODED"] = 2] = "HARDCODED";
  15636. })(ComponentSource || (ComponentSource = {}));
  15637. var UserComponentFactory = /** @class */ (function (_super) {
  15638. __extends(UserComponentFactory, _super);
  15639. function UserComponentFactory() {
  15640. return _super !== null && _super.apply(this, arguments) || this;
  15641. }
  15642. UserComponentFactory.prototype.newDateComponent = function (params) {
  15643. return this.createAndInitUserComponent(this.gridOptions, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["DateComponent"], 'agDateInput');
  15644. };
  15645. UserComponentFactory.prototype.newHeaderComponent = function (params) {
  15646. return this.createAndInitUserComponent(params.column.getColDef(), params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["HeaderComponent"], 'agColumnHeader');
  15647. };
  15648. UserComponentFactory.prototype.newHeaderGroupComponent = function (params) {
  15649. return this.createAndInitUserComponent(params.columnGroup.getColGroupDef(), params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["HeaderGroupComponent"], 'agColumnGroupHeader');
  15650. };
  15651. UserComponentFactory.prototype.newFullWidthGroupRowInnerCellRenderer = function (params) {
  15652. return this.createAndInitUserComponent(this.gridOptions, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["GroupRowInnerRendererComponent"], null, true);
  15653. };
  15654. // this one is unusual, as it can be LoadingCellRenderer, DetailCellRenderer, FullWidthCellRenderer or GroupRowRenderer.
  15655. // so we have to pass the type in.
  15656. UserComponentFactory.prototype.newFullWidthCellRenderer = function (params, cellRendererType, cellRendererName) {
  15657. return this.createAndInitUserComponent(null, params, {
  15658. propertyName: cellRendererType,
  15659. isCellRenderer: function () { return true; }
  15660. }, cellRendererName);
  15661. };
  15662. UserComponentFactory.prototype.newCellRenderer = function (target, params, isPinned) {
  15663. if (isPinned === void 0) { isPinned = false; }
  15664. return this.createAndInitUserComponent(target, params, isPinned ? _componentTypes__WEBPACK_IMPORTED_MODULE_3__["PinnedRowCellRendererComponent"] : _componentTypes__WEBPACK_IMPORTED_MODULE_3__["CellRendererComponent"], null, true);
  15665. };
  15666. UserComponentFactory.prototype.newCellEditor = function (colDef, params) {
  15667. return this.createAndInitUserComponent(colDef, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["CellEditorComponent"], 'agCellEditor');
  15668. };
  15669. UserComponentFactory.prototype.newInnerCellRenderer = function (target, params) {
  15670. return this.createAndInitUserComponent(target, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["InnerRendererComponent"], null);
  15671. };
  15672. UserComponentFactory.prototype.newLoadingOverlayComponent = function (params) {
  15673. return this.createAndInitUserComponent(this.gridOptions, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["LoadingOverlayComponent"], 'agLoadingOverlay');
  15674. };
  15675. UserComponentFactory.prototype.newNoRowsOverlayComponent = function (params) {
  15676. return this.createAndInitUserComponent(this.gridOptions, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["NoRowsOverlayComponent"], 'agNoRowsOverlay');
  15677. };
  15678. UserComponentFactory.prototype.newTooltipComponent = function (params) {
  15679. return this.createAndInitUserComponent(params.colDef, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["TooltipComponent"], 'agTooltipComponent');
  15680. };
  15681. UserComponentFactory.prototype.newFilterComponent = function (colDef, params, defaultFilter, modifyParamsCallback) {
  15682. return this.createAndInitUserComponent(colDef, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["FilterComponent"], defaultFilter, false, modifyParamsCallback);
  15683. };
  15684. UserComponentFactory.prototype.newSetFilterCellRenderer = function (target, params) {
  15685. return this.createAndInitUserComponent(target, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["CellRendererComponent"], null, true);
  15686. };
  15687. UserComponentFactory.prototype.newFloatingFilterComponent = function (colDef, params, defaultFloatingFilter) {
  15688. return this.createAndInitUserComponent(colDef, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["FloatingFilterComponent"], defaultFloatingFilter, true);
  15689. };
  15690. UserComponentFactory.prototype.newToolPanelComponent = function (toolPanelDef, params) {
  15691. return this.createAndInitUserComponent(toolPanelDef, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["ToolPanelComponent"]);
  15692. };
  15693. UserComponentFactory.prototype.newStatusPanelComponent = function (def, params) {
  15694. return this.createAndInitUserComponent(def, params, _componentTypes__WEBPACK_IMPORTED_MODULE_3__["StatusPanelComponent"]);
  15695. };
  15696. /**
  15697. * This method creates a component given everything needed to guess what sort of component needs to be instantiated
  15698. * It takes
  15699. * @param definitionObject: This is the context for which this component needs to be created, it can be gridOptions
  15700. * (global) or columnDef mostly.
  15701. * @param paramsFromGrid: Params to be passed to the component and passed by ag-Grid. This will get merged with any params
  15702. * specified by the user in the configuration
  15703. * @param propertyName: The name of the property used in ag-grid as a convention to refer to the component, it can be:
  15704. * 'floatingFilter', 'cellRenderer', is used to find if the user is specifying a custom component
  15705. * @param defaultComponentName: The actual name of the component to instantiate, this is usually the same as propertyName, but in
  15706. * some cases is not, like floatingFilter, if it is the same is not necessary to specify
  15707. * @param optional: Handy method to tell if this should return a component ALWAYS. if that is the case, but there is no
  15708. * component found, it throws an error, by default all components are MANDATORY
  15709. * @param modifyParamsCallback: A chance to customise the params passed to the init method. It receives what the current
  15710. * params are and the component that init is about to get called for
  15711. */
  15712. UserComponentFactory.prototype.createAndInitUserComponent = function (definitionObject, paramsFromGrid, componentType, defaultComponentName,
  15713. // optional items are: FloatingFilter, CellComp (for cellRenderer)
  15714. optional,
  15715. // used by FilterManager only
  15716. modifyParamsCallback) {
  15717. if (optional === void 0) { optional = false; }
  15718. if (!definitionObject) {
  15719. definitionObject = this.gridOptions;
  15720. }
  15721. // Create the component instance
  15722. var componentAndParams = this.createComponentInstance(definitionObject, componentType, paramsFromGrid, defaultComponentName, optional);
  15723. if (!componentAndParams) {
  15724. return null;
  15725. }
  15726. var componentInstance = componentAndParams.componentInstance;
  15727. // Wire the component and call the init method with the correct params
  15728. var params = this.createFinalParams(definitionObject, componentType.propertyName, paramsFromGrid, componentAndParams.paramsFromSelector);
  15729. this.addReactHacks(params);
  15730. // give caller chance to set any params that depend on the componentInstance (need here as the
  15731. // componentInstance was not available when createUserComponent was called)
  15732. var paramsAfterCallback = modifyParamsCallback ? modifyParamsCallback(params, componentInstance) : params;
  15733. var deferredInit = this.initComponent(componentInstance, paramsAfterCallback);
  15734. if (deferredInit == null) {
  15735. return _utils__WEBPACK_IMPORTED_MODULE_2__["Promise"].resolve(componentInstance);
  15736. }
  15737. else {
  15738. return deferredInit.then(function () { return componentInstance; });
  15739. }
  15740. };
  15741. UserComponentFactory.prototype.addReactHacks = function (params) {
  15742. // a temporary fix for AG-1574
  15743. // AG-1715 raised to do a wider ranging refactor to improve this
  15744. var agGridReact = this.context.getBean('agGridReact');
  15745. if (agGridReact) {
  15746. params.agGridReact = Object(_utils_object__WEBPACK_IMPORTED_MODULE_5__["cloneObject"])(agGridReact);
  15747. }
  15748. // AG-1716 - directly related to AG-1574 and AG-1715
  15749. var frameworkComponentWrapper = this.context.getBean('frameworkComponentWrapper');
  15750. if (frameworkComponentWrapper) {
  15751. params.frameworkComponentWrapper = frameworkComponentWrapper;
  15752. }
  15753. };
  15754. /**
  15755. * This method creates a component given everything needed to guess what sort of component needs to be instantiated
  15756. * It takes
  15757. * @param clazz: The class to instantiate,
  15758. * @param agGridParams: Params to be passed to the component and passed by ag-Grid. This will get merged with any params
  15759. * specified by the user in the configuration
  15760. * @param modifyParamsCallback: A chance to customise the params passed to the init method. It receives what the current
  15761. * params are and the component that init is about to get called for
  15762. */
  15763. UserComponentFactory.prototype.createUserComponentFromConcreteClass = function (clazz, agGridParams) {
  15764. var internalComponent = new clazz();
  15765. this.initComponent(internalComponent, agGridParams);
  15766. return internalComponent;
  15767. };
  15768. /**
  15769. * This method returns the underlying representation of the component to be created. ie for Javascript the
  15770. * underlying function where we should be calling new into. In case of the frameworks, the framework class
  15771. * object that represents the component to be created.
  15772. *
  15773. * This method is handy for different reasons, for example if you want to check if a component has a particular
  15774. * method implemented without having to create the component, just by inspecting the source component
  15775. *
  15776. * It takes
  15777. * @param definitionObject: This is the context for which this component needs to be created, it can be gridOptions
  15778. * (global) or columnDef mostly.
  15779. * @param propertyName: The name of the property used in ag-grid as a convention to refer to the component, it can be:
  15780. * 'floatingFilter', 'cellRenderer', is used to find if the user is specifying a custom component
  15781. * @param params: Params to be passed to the dynamic component function in case it needs to be
  15782. * invoked
  15783. * @param defaultComponentName: The name of the component to load if there is no component specified
  15784. */
  15785. UserComponentFactory.prototype.lookupComponentClassDef = function (definitionObject, propertyName, params, defaultComponentName) {
  15786. if (params === void 0) { params = null; }
  15787. /**
  15788. * There are five things that can happen when resolving a component.
  15789. * a) HardcodedFwComponent: That holder[propertyName]Framework has associated a Framework native component
  15790. * b) HardcodedJsComponent: That holder[propertyName] has associate a JS component
  15791. * c) hardcodedJsFunction: That holder[propertyName] has associate a JS function
  15792. * d) hardcodedNameComponent: That holder[propertyName] has associate a string that represents a component to load
  15793. * e) That none of the three previous are specified, then we need to use the DefaultRegisteredComponent
  15794. */
  15795. var hardcodedNameComponent = null;
  15796. var HardcodedJsComponent = null;
  15797. var hardcodedJsFunction = null;
  15798. var HardcodedFwComponent = null;
  15799. var componentSelectorFunc;
  15800. if (definitionObject != null) {
  15801. var componentPropertyValue = definitionObject[propertyName];
  15802. // for filters only, we allow 'true' for the component, which means default filter to be used
  15803. var usingDefaultComponent = componentPropertyValue === true;
  15804. if (componentPropertyValue != null && !usingDefaultComponent) {
  15805. if (typeof componentPropertyValue === 'string') {
  15806. hardcodedNameComponent = componentPropertyValue;
  15807. }
  15808. else if (typeof componentPropertyValue === 'boolean') {
  15809. // never happens, as we test for usingDefaultComponent above,
  15810. // however it's needed for the next block to compile
  15811. }
  15812. else if (this.agComponentUtils.doesImplementIComponent(componentPropertyValue)) {
  15813. HardcodedJsComponent = componentPropertyValue;
  15814. }
  15815. else {
  15816. hardcodedJsFunction = componentPropertyValue;
  15817. }
  15818. }
  15819. HardcodedFwComponent = definitionObject[propertyName + "Framework"];
  15820. componentSelectorFunc = definitionObject[propertyName + "Selector"];
  15821. }
  15822. /**
  15823. * Since we allow many types of flavors for specifying the components, let's make sure this is not an illegal
  15824. * combination
  15825. */
  15826. if ((HardcodedJsComponent && HardcodedFwComponent) ||
  15827. (hardcodedNameComponent && HardcodedFwComponent) ||
  15828. (hardcodedJsFunction && HardcodedFwComponent)) {
  15829. throw Error("ag-grid: you are trying to specify: " + propertyName + " twice as a component.");
  15830. }
  15831. if (HardcodedFwComponent && !this.frameworkComponentWrapper) {
  15832. throw Error("ag-grid: you are specifying a framework component but you are not using a framework version of ag-grid for : " + propertyName);
  15833. }
  15834. if (componentSelectorFunc && (hardcodedNameComponent || HardcodedJsComponent || hardcodedJsFunction || HardcodedFwComponent)) {
  15835. throw Error("ag-grid: you can't specify both, the selector and the component of ag-grid for : " + propertyName);
  15836. }
  15837. /**
  15838. * At this stage we are guaranteed to either have,
  15839. * DEPRECATED
  15840. * - A unique HardcodedFwComponent
  15841. * - A unique HardcodedJsComponent
  15842. * - A unique hardcodedJsFunction
  15843. * BY NAME- FAVOURED APPROACH
  15844. * - A unique hardcodedNameComponent
  15845. * - None of the previous, hence we revert to: RegisteredComponent
  15846. */
  15847. if (HardcodedFwComponent) {
  15848. // console.warn(`ag-grid: Since version 12.1.0 specifying a component directly is deprecated, you should register the component by name`);
  15849. // console.warn(`${HardcodedFwComponent}`);
  15850. return {
  15851. componentFromFramework: true,
  15852. component: HardcodedFwComponent,
  15853. source: ComponentSource.HARDCODED,
  15854. paramsFromSelector: null
  15855. };
  15856. }
  15857. if (HardcodedJsComponent) {
  15858. // console.warn(`ag-grid: Since version 12.1.0 specifying a component directly is deprecated, you should register the component by name`);
  15859. // console.warn(`${HardcodedJsComponent}`);
  15860. return {
  15861. componentFromFramework: false,
  15862. component: HardcodedJsComponent,
  15863. source: ComponentSource.HARDCODED,
  15864. paramsFromSelector: null
  15865. };
  15866. }
  15867. if (hardcodedJsFunction) {
  15868. // console.warn(`ag-grid: Since version 12.1.0 specifying a function directly is deprecated, you should register the component by name`);
  15869. // console.warn(`${hardcodedJsFunction}`);
  15870. return this.agComponentUtils.adaptFunction(propertyName, hardcodedJsFunction, false, ComponentSource.HARDCODED);
  15871. }
  15872. var selectorResult = componentSelectorFunc ? componentSelectorFunc(params) : null;
  15873. var componentNameToUse;
  15874. if (selectorResult && selectorResult.component) {
  15875. componentNameToUse = selectorResult.component;
  15876. }
  15877. else if (hardcodedNameComponent) {
  15878. componentNameToUse = hardcodedNameComponent;
  15879. }
  15880. else {
  15881. componentNameToUse = defaultComponentName;
  15882. }
  15883. if (!componentNameToUse) {
  15884. return null;
  15885. }
  15886. var registeredCompClassDef = this.lookupFromRegisteredComponents(propertyName, componentNameToUse);
  15887. if (!registeredCompClassDef) {
  15888. return null;
  15889. }
  15890. return {
  15891. componentFromFramework: registeredCompClassDef.componentFromFramework,
  15892. component: registeredCompClassDef.component,
  15893. source: registeredCompClassDef.source,
  15894. paramsFromSelector: selectorResult ? selectorResult.params : null
  15895. };
  15896. };
  15897. UserComponentFactory.prototype.lookupFromRegisteredComponents = function (propertyName, componentNameOpt) {
  15898. var componentName = componentNameOpt != null ? componentNameOpt : propertyName;
  15899. var registeredComponent = this.userComponentRegistry.retrieve(componentName);
  15900. if (registeredComponent == null) {
  15901. return null;
  15902. }
  15903. //If it is a FW it has to be registered as a component
  15904. if (registeredComponent.componentFromFramework) {
  15905. return {
  15906. component: registeredComponent.component,
  15907. componentFromFramework: true,
  15908. source: ComponentSource.REGISTERED_BY_NAME,
  15909. paramsFromSelector: null
  15910. };
  15911. }
  15912. //If it is JS it may be a function or a component
  15913. if (this.agComponentUtils.doesImplementIComponent(registeredComponent.component)) {
  15914. return {
  15915. component: registeredComponent.component,
  15916. componentFromFramework: false,
  15917. source: (registeredComponent.source == _userComponentRegistry__WEBPACK_IMPORTED_MODULE_1__["RegisteredComponentSource"].REGISTERED) ? ComponentSource.REGISTERED_BY_NAME : ComponentSource.DEFAULT,
  15918. paramsFromSelector: null
  15919. };
  15920. }
  15921. // This is a function
  15922. return this.agComponentUtils.adaptFunction(propertyName, registeredComponent.component, registeredComponent.componentFromFramework, (registeredComponent.source == _userComponentRegistry__WEBPACK_IMPORTED_MODULE_1__["RegisteredComponentSource"].REGISTERED) ? ComponentSource.REGISTERED_BY_NAME : ComponentSource.DEFAULT);
  15923. };
  15924. /**
  15925. * Useful to check what would be the resultant params for a given object
  15926. * @param definitionObject: This is the context for which this component needs to be created, it can be gridOptions
  15927. * (global) or columnDef mostly.
  15928. * @param propertyName: The name of the property used in ag-grid as a convention to refer to the component, it can be:
  15929. * 'floatingFilter', 'cellRenderer', is used to find if the user is specifying a custom component
  15930. * @param paramsFromGrid: Params to be passed to the component and passed by ag-Grid. This will get merged with any params
  15931. * specified by the user in the configuration
  15932. * @returns {TParams} It merges the user agGridParams with the actual params specified by the user.
  15933. */
  15934. UserComponentFactory.prototype.createFinalParams = function (definitionObject, propertyName, paramsFromGrid, paramsFromSelector) {
  15935. if (paramsFromSelector === void 0) { paramsFromSelector = null; }
  15936. var params = {};
  15937. Object(_utils_object__WEBPACK_IMPORTED_MODULE_5__["mergeDeep"])(params, paramsFromGrid);
  15938. var userParams = definitionObject ? definitionObject[propertyName + "Params"] : null;
  15939. if (userParams != null) {
  15940. if (typeof userParams === 'function') {
  15941. Object(_utils_object__WEBPACK_IMPORTED_MODULE_5__["mergeDeep"])(params, userParams(paramsFromGrid));
  15942. }
  15943. else if (typeof userParams === 'object') {
  15944. Object(_utils_object__WEBPACK_IMPORTED_MODULE_5__["mergeDeep"])(params, userParams);
  15945. }
  15946. }
  15947. Object(_utils_object__WEBPACK_IMPORTED_MODULE_5__["mergeDeep"])(params, paramsFromSelector);
  15948. return params;
  15949. };
  15950. UserComponentFactory.prototype.createComponentInstance = function (holder, componentType, paramsForSelector, defaultComponentName, optional) {
  15951. var propertyName = componentType.propertyName;
  15952. var componentToUse = this.lookupComponentClassDef(holder, propertyName, paramsForSelector, defaultComponentName);
  15953. var missing = !componentToUse || !componentToUse.component;
  15954. if (missing) {
  15955. // to help the user, we print out the name they are looking for, rather than the default name.
  15956. // i don't know why the default name was originally printed out (that doesn't help the user)
  15957. var overrideName = holder ? holder[propertyName] : defaultComponentName;
  15958. var nameToReport = overrideName ? overrideName : defaultComponentName;
  15959. if (!optional) {
  15960. console.error("Could not find component " + nameToReport + ", did you forget to configure this component?");
  15961. }
  15962. return null;
  15963. }
  15964. var componentInstance;
  15965. if (componentToUse.componentFromFramework) {
  15966. // Using framework component
  15967. var FrameworkComponentRaw = componentToUse.component;
  15968. var thisComponentConfig = this.componentMetadataProvider.retrieve(propertyName);
  15969. componentInstance = this.frameworkComponentWrapper.wrap(FrameworkComponentRaw, thisComponentConfig.mandatoryMethodList, thisComponentConfig.optionalMethodList, componentType, defaultComponentName);
  15970. }
  15971. else {
  15972. // Using plain JavaScript component
  15973. componentInstance = new componentToUse.component();
  15974. }
  15975. return { componentInstance: componentInstance, paramsFromSelector: componentToUse.paramsFromSelector };
  15976. };
  15977. UserComponentFactory.prototype.initComponent = function (component, params) {
  15978. this.context.createBean(component);
  15979. if (component.init == null) {
  15980. return;
  15981. }
  15982. return component.init(params);
  15983. };
  15984. __decorate([
  15985. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("gridOptions")
  15986. ], UserComponentFactory.prototype, "gridOptions", void 0);
  15987. __decorate([
  15988. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("agComponentUtils")
  15989. ], UserComponentFactory.prototype, "agComponentUtils", void 0);
  15990. __decorate([
  15991. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("componentMetadataProvider")
  15992. ], UserComponentFactory.prototype, "componentMetadataProvider", void 0);
  15993. __decorate([
  15994. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("userComponentRegistry")
  15995. ], UserComponentFactory.prototype, "userComponentRegistry", void 0);
  15996. __decorate([
  15997. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])("frameworkComponentWrapper")
  15998. ], UserComponentFactory.prototype, "frameworkComponentWrapper", void 0);
  15999. UserComponentFactory = __decorate([
  16000. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('userComponentFactory')
  16001. ], UserComponentFactory);
  16002. return UserComponentFactory;
  16003. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_4__["BeanStub"]));
  16004. /***/ }),
  16005. /* 75 */
  16006. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  16007. "use strict";
  16008. __webpack_require__.r(__webpack_exports__);
  16009. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DateComponent", function() { return DateComponent; });
  16010. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderComponent", function() { return HeaderComponent; });
  16011. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderGroupComponent", function() { return HeaderGroupComponent; });
  16012. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GroupRowInnerRendererComponent", function() { return GroupRowInnerRendererComponent; });
  16013. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellRendererComponent", function() { return CellRendererComponent; });
  16014. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PinnedRowCellRendererComponent", function() { return PinnedRowCellRendererComponent; });
  16015. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellEditorComponent", function() { return CellEditorComponent; });
  16016. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "InnerRendererComponent", function() { return InnerRendererComponent; });
  16017. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LoadingOverlayComponent", function() { return LoadingOverlayComponent; });
  16018. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "NoRowsOverlayComponent", function() { return NoRowsOverlayComponent; });
  16019. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TooltipComponent", function() { return TooltipComponent; });
  16020. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FilterComponent", function() { return FilterComponent; });
  16021. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FloatingFilterComponent", function() { return FloatingFilterComponent; });
  16022. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ToolPanelComponent", function() { return ToolPanelComponent; });
  16023. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "StatusPanelComponent", function() { return StatusPanelComponent; });
  16024. /**
  16025. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  16026. * @version v23.2.1
  16027. * @link http://www.ag-grid.com/
  16028. * @license MIT
  16029. */
  16030. var DateComponent = {
  16031. propertyName: 'dateComponent',
  16032. isCellRenderer: function () { return false; }
  16033. };
  16034. var HeaderComponent = {
  16035. propertyName: 'headerComponent',
  16036. isCellRenderer: function () { return false; },
  16037. };
  16038. var HeaderGroupComponent = {
  16039. propertyName: 'headerGroupComponent',
  16040. isCellRenderer: function () { return false; },
  16041. };
  16042. var GroupRowInnerRendererComponent = {
  16043. propertyName: 'groupRowInnerRenderer',
  16044. isCellRenderer: function () { return true; },
  16045. };
  16046. var CellRendererComponent = {
  16047. propertyName: 'cellRenderer',
  16048. isCellRenderer: function () { return true; },
  16049. };
  16050. var PinnedRowCellRendererComponent = {
  16051. propertyName: 'pinnedRowCellRenderer',
  16052. isCellRenderer: function () { return true; },
  16053. };
  16054. var CellEditorComponent = {
  16055. propertyName: 'cellEditor',
  16056. isCellRenderer: function () { return false; },
  16057. };
  16058. var InnerRendererComponent = {
  16059. propertyName: 'innerRenderer',
  16060. isCellRenderer: function () { return true; },
  16061. };
  16062. var LoadingOverlayComponent = {
  16063. propertyName: 'loadingOverlayComponent',
  16064. isCellRenderer: function () { return false; },
  16065. };
  16066. var NoRowsOverlayComponent = {
  16067. propertyName: 'noRowsOverlayComponent',
  16068. isCellRenderer: function () { return false; },
  16069. };
  16070. var TooltipComponent = {
  16071. propertyName: 'tooltipComponent',
  16072. isCellRenderer: function () { return false; },
  16073. };
  16074. var FilterComponent = {
  16075. propertyName: 'filter',
  16076. isCellRenderer: function () { return false; },
  16077. };
  16078. var FloatingFilterComponent = {
  16079. propertyName: 'floatingFilterComponent',
  16080. isCellRenderer: function () { return false; },
  16081. };
  16082. var ToolPanelComponent = {
  16083. propertyName: 'toolPanel',
  16084. isCellRenderer: function () { return false; },
  16085. };
  16086. var StatusPanelComponent = {
  16087. propertyName: 'statusPanel',
  16088. isCellRenderer: function () { return false; },
  16089. };
  16090. /***/ }),
  16091. /* 76 */
  16092. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  16093. "use strict";
  16094. __webpack_require__.r(__webpack_exports__);
  16095. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AnimateShowChangeCellRenderer", function() { return AnimateShowChangeCellRenderer; });
  16096. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  16097. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(56);
  16098. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
  16099. /**
  16100. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  16101. * @version v23.2.1
  16102. * @link http://www.ag-grid.com/
  16103. * @license MIT
  16104. */
  16105. var __extends = (undefined && undefined.__extends) || (function () {
  16106. var extendStatics = function (d, b) {
  16107. extendStatics = Object.setPrototypeOf ||
  16108. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  16109. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  16110. return extendStatics(d, b);
  16111. };
  16112. return function (d, b) {
  16113. extendStatics(d, b);
  16114. function __() { this.constructor = d; }
  16115. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  16116. };
  16117. })();
  16118. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  16119. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  16120. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  16121. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  16122. return c > 3 && r && Object.defineProperty(target, key, r), r;
  16123. };
  16124. var ARROW_UP = '\u2191';
  16125. var ARROW_DOWN = '\u2193';
  16126. var AnimateShowChangeCellRenderer = /** @class */ (function (_super) {
  16127. __extends(AnimateShowChangeCellRenderer, _super);
  16128. function AnimateShowChangeCellRenderer() {
  16129. var _this = _super.call(this, AnimateShowChangeCellRenderer.TEMPLATE) || this;
  16130. _this.refreshCount = 0;
  16131. return _this;
  16132. }
  16133. AnimateShowChangeCellRenderer.prototype.init = function (params) {
  16134. // this.params = params;
  16135. this.eValue = this.queryForHtmlElement('.ag-value-change-value');
  16136. this.eDelta = this.queryForHtmlElement('.ag-value-change-delta');
  16137. this.refresh(params);
  16138. };
  16139. AnimateShowChangeCellRenderer.prototype.showDelta = function (params, delta) {
  16140. var absDelta = Math.abs(delta);
  16141. var valueFormatted = params.formatValue(absDelta);
  16142. var valueToUse = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(valueFormatted) ? valueFormatted : absDelta;
  16143. var deltaUp = (delta >= 0);
  16144. if (deltaUp) {
  16145. this.eDelta.innerHTML = ARROW_UP + valueToUse;
  16146. }
  16147. else {
  16148. // because negative, use ABS to remove sign
  16149. this.eDelta.innerHTML = ARROW_DOWN + valueToUse;
  16150. }
  16151. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addOrRemoveCssClass(this.eDelta, 'ag-value-change-delta-up', deltaUp);
  16152. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addOrRemoveCssClass(this.eDelta, 'ag-value-change-delta-down', !deltaUp);
  16153. };
  16154. AnimateShowChangeCellRenderer.prototype.setTimerToRemoveDelta = function () {
  16155. var _this = this;
  16156. // the refreshCount makes sure that if the value updates again while
  16157. // the below timer is waiting, then the below timer will realise it
  16158. // is not the most recent and will not try to remove the delta value.
  16159. this.refreshCount++;
  16160. var refreshCountCopy = this.refreshCount;
  16161. window.setTimeout(function () {
  16162. if (refreshCountCopy === _this.refreshCount) {
  16163. _this.hideDeltaValue();
  16164. }
  16165. }, 2000);
  16166. };
  16167. AnimateShowChangeCellRenderer.prototype.hideDeltaValue = function () {
  16168. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].removeCssClass(this.eValue, 'ag-value-change-value-highlight');
  16169. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].clearElement(this.eDelta);
  16170. };
  16171. AnimateShowChangeCellRenderer.prototype.refresh = function (params) {
  16172. var value = params.value;
  16173. if (value === this.lastValue) {
  16174. return;
  16175. }
  16176. if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(params.valueFormatted)) {
  16177. this.eValue.innerHTML = params.valueFormatted;
  16178. }
  16179. else if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(params.value)) {
  16180. this.eValue.innerHTML = value;
  16181. }
  16182. else {
  16183. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].clearElement(this.eValue);
  16184. }
  16185. // we don't show the delta if we are in the middle of a filter. see comment on FilterManager
  16186. // with regards processingFilterChange
  16187. if (this.filterManager.isSuppressFlashingCellsBecauseFiltering()) {
  16188. return;
  16189. }
  16190. if (typeof value === 'number' && typeof this.lastValue === 'number') {
  16191. var delta = value - this.lastValue;
  16192. this.showDelta(params, delta);
  16193. }
  16194. // highlight the current value, but only if it's not new, otherwise it
  16195. // would get highlighted first time the value is shown
  16196. if (this.lastValue) {
  16197. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(this.eValue, 'ag-value-change-value-highlight');
  16198. }
  16199. this.setTimerToRemoveDelta();
  16200. this.lastValue = value;
  16201. return true;
  16202. };
  16203. AnimateShowChangeCellRenderer.TEMPLATE = '<span>' +
  16204. '<span class="ag-value-change-delta"></span>' +
  16205. '<span class="ag-value-change-value"></span>' +
  16206. '</span>';
  16207. __decorate([
  16208. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager')
  16209. ], AnimateShowChangeCellRenderer.prototype, "filterManager", void 0);
  16210. return AnimateShowChangeCellRenderer;
  16211. }(_widgets_component__WEBPACK_IMPORTED_MODULE_1__["Component"]));
  16212. /***/ }),
  16213. /* 77 */
  16214. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  16215. "use strict";
  16216. __webpack_require__.r(__webpack_exports__);
  16217. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AnimateSlideCellRenderer", function() { return AnimateSlideCellRenderer; });
  16218. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  16219. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(56);
  16220. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
  16221. /**
  16222. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  16223. * @version v23.2.1
  16224. * @link http://www.ag-grid.com/
  16225. * @license MIT
  16226. */
  16227. var __extends = (undefined && undefined.__extends) || (function () {
  16228. var extendStatics = function (d, b) {
  16229. extendStatics = Object.setPrototypeOf ||
  16230. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  16231. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  16232. return extendStatics(d, b);
  16233. };
  16234. return function (d, b) {
  16235. extendStatics(d, b);
  16236. function __() { this.constructor = d; }
  16237. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  16238. };
  16239. })();
  16240. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  16241. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  16242. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  16243. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  16244. return c > 3 && r && Object.defineProperty(target, key, r), r;
  16245. };
  16246. var AnimateSlideCellRenderer = /** @class */ (function (_super) {
  16247. __extends(AnimateSlideCellRenderer, _super);
  16248. function AnimateSlideCellRenderer() {
  16249. var _this = _super.call(this, AnimateSlideCellRenderer.TEMPLATE) || this;
  16250. _this.refreshCount = 0;
  16251. _this.eCurrent = _this.queryForHtmlElement('.ag-value-slide-current');
  16252. return _this;
  16253. }
  16254. AnimateSlideCellRenderer.prototype.init = function (params) {
  16255. this.params = params;
  16256. this.refresh(params);
  16257. };
  16258. AnimateSlideCellRenderer.prototype.addSlideAnimation = function () {
  16259. var _this = this;
  16260. this.refreshCount++;
  16261. // below we keep checking this, and stop working on the animation
  16262. // if it no longer matches - this means another animation has started
  16263. // and this one is stale.
  16264. var refreshCountCopy = this.refreshCount;
  16265. // if old animation, remove it
  16266. if (this.ePrevious) {
  16267. this.getGui().removeChild(this.ePrevious);
  16268. }
  16269. this.ePrevious = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].loadTemplate('<span class="ag-value-slide-previous ag-value-slide-out"></span>');
  16270. this.ePrevious.innerHTML = this.eCurrent.innerHTML;
  16271. this.getGui().insertBefore(this.ePrevious, this.eCurrent);
  16272. // having timeout of 0 allows use to skip to the next css turn,
  16273. // so we know the previous css classes have been applied. so the
  16274. // complex set of setTimeout below creates the animation
  16275. window.setTimeout(function () {
  16276. if (refreshCountCopy !== _this.refreshCount) {
  16277. return;
  16278. }
  16279. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(_this.ePrevious, 'ag-value-slide-out-end');
  16280. }, 50);
  16281. window.setTimeout(function () {
  16282. if (refreshCountCopy !== _this.refreshCount) {
  16283. return;
  16284. }
  16285. _this.getGui().removeChild(_this.ePrevious);
  16286. _this.ePrevious = null;
  16287. }, 3000);
  16288. };
  16289. AnimateSlideCellRenderer.prototype.refresh = function (params) {
  16290. var value = params.value;
  16291. if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].missing(value)) {
  16292. value = '';
  16293. }
  16294. if (value === this.lastValue) {
  16295. return;
  16296. }
  16297. // we don't show the delta if we are in the middle of a filter. see comment on FilterManager
  16298. // with regards processingFilterChange
  16299. if (this.filterManager.isSuppressFlashingCellsBecauseFiltering()) {
  16300. return;
  16301. }
  16302. this.addSlideAnimation();
  16303. this.lastValue = value;
  16304. if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(params.valueFormatted)) {
  16305. this.eCurrent.innerHTML = params.valueFormatted;
  16306. }
  16307. else if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(params.value)) {
  16308. this.eCurrent.innerHTML = value;
  16309. }
  16310. else {
  16311. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].clearElement(this.eCurrent);
  16312. }
  16313. return true;
  16314. };
  16315. AnimateSlideCellRenderer.TEMPLATE = '<span>' +
  16316. '<span class="ag-value-slide-current"></span>' +
  16317. '</span>';
  16318. __decorate([
  16319. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager')
  16320. ], AnimateSlideCellRenderer.prototype, "filterManager", void 0);
  16321. return AnimateSlideCellRenderer;
  16322. }(_widgets_component__WEBPACK_IMPORTED_MODULE_1__["Component"]));
  16323. /***/ }),
  16324. /* 78 */
  16325. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  16326. "use strict";
  16327. __webpack_require__.r(__webpack_exports__);
  16328. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LoadingCellRenderer", function() { return LoadingCellRenderer; });
  16329. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  16330. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(56);
  16331. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57);
  16332. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  16333. /**
  16334. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  16335. * @version v23.2.1
  16336. * @link http://www.ag-grid.com/
  16337. * @license MIT
  16338. */
  16339. var __extends = (undefined && undefined.__extends) || (function () {
  16340. var extendStatics = function (d, b) {
  16341. extendStatics = Object.setPrototypeOf ||
  16342. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  16343. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  16344. return extendStatics(d, b);
  16345. };
  16346. return function (d, b) {
  16347. extendStatics(d, b);
  16348. function __() { this.constructor = d; }
  16349. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  16350. };
  16351. })();
  16352. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  16353. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  16354. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  16355. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  16356. return c > 3 && r && Object.defineProperty(target, key, r), r;
  16357. };
  16358. var LoadingCellRenderer = /** @class */ (function (_super) {
  16359. __extends(LoadingCellRenderer, _super);
  16360. function LoadingCellRenderer() {
  16361. return _super.call(this, LoadingCellRenderer.TEMPLATE) || this;
  16362. }
  16363. LoadingCellRenderer.prototype.init = function (params) {
  16364. var eLoadingIcon = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].createIconNoSpan('groupLoading', this.gridOptionsWrapper, null);
  16365. this.eLoadingIcon.appendChild(eLoadingIcon);
  16366. var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();
  16367. this.eLoadingText.innerText = localeTextFunc('loadingOoo', 'Loading');
  16368. };
  16369. LoadingCellRenderer.prototype.refresh = function (params) {
  16370. return false;
  16371. };
  16372. LoadingCellRenderer.TEMPLATE = "<div class=\"ag-loading\">\n <span class=\"ag-loading-icon\" ref=\"eLoadingIcon\"></span>\n <span class=\"ag-loading-text\" ref=\"eLoadingText\"></span>\n </div>";
  16373. __decorate([
  16374. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  16375. ], LoadingCellRenderer.prototype, "gridOptionsWrapper", void 0);
  16376. __decorate([
  16377. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('eLoadingIcon')
  16378. ], LoadingCellRenderer.prototype, "eLoadingIcon", void 0);
  16379. __decorate([
  16380. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('eLoadingText')
  16381. ], LoadingCellRenderer.prototype, "eLoadingText", void 0);
  16382. return LoadingCellRenderer;
  16383. }(_widgets_component__WEBPACK_IMPORTED_MODULE_1__["Component"]));
  16384. /***/ }),
  16385. /* 79 */
  16386. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  16387. "use strict";
  16388. __webpack_require__.r(__webpack_exports__);
  16389. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SelectCellEditor", function() { return SelectCellEditor; });
  16390. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  16391. /* harmony import */ var _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(55);
  16392. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57);
  16393. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  16394. /**
  16395. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  16396. * @version v23.2.1
  16397. * @link http://www.ag-grid.com/
  16398. * @license MIT
  16399. */
  16400. var __extends = (undefined && undefined.__extends) || (function () {
  16401. var extendStatics = function (d, b) {
  16402. extendStatics = Object.setPrototypeOf ||
  16403. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  16404. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  16405. return extendStatics(d, b);
  16406. };
  16407. return function (d, b) {
  16408. extendStatics(d, b);
  16409. function __() { this.constructor = d; }
  16410. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  16411. };
  16412. })();
  16413. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  16414. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  16415. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  16416. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  16417. return c > 3 && r && Object.defineProperty(target, key, r), r;
  16418. };
  16419. var SelectCellEditor = /** @class */ (function (_super) {
  16420. __extends(SelectCellEditor, _super);
  16421. function SelectCellEditor() {
  16422. return _super.call(this, '<div class="ag-cell-edit-wrapper"><ag-select class="ag-cell-editor" ref="eSelect"></ag-select></div>') || this;
  16423. }
  16424. SelectCellEditor.prototype.init = function (params) {
  16425. var _this = this;
  16426. this.focusAfterAttached = params.cellStartedEdit;
  16427. if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].missing(params.values)) {
  16428. console.warn('ag-Grid: no values found for select cellEditor');
  16429. return;
  16430. }
  16431. params.values.forEach(function (value) {
  16432. var option = { value: value };
  16433. var valueFormatted = _this.valueFormatterService.formatValue(params.column, null, null, value);
  16434. var valueFormattedExits = valueFormatted !== null && valueFormatted !== undefined;
  16435. option.text = valueFormattedExits ? valueFormatted : value;
  16436. _this.eSelect.addOption(option);
  16437. });
  16438. this.eSelect.setValue(params.value, true);
  16439. // we don't want to add this if full row editing, otherwise selecting will stop the
  16440. // full row editing.
  16441. if (!this.gridOptionsWrapper.isFullRowEdit()) {
  16442. this.eSelect.onValueChange(function () { return params.stopEditing(); });
  16443. }
  16444. };
  16445. SelectCellEditor.prototype.afterGuiAttached = function () {
  16446. if (this.focusAfterAttached) {
  16447. this.eSelect.getFocusableElement().focus();
  16448. }
  16449. };
  16450. SelectCellEditor.prototype.focusIn = function () {
  16451. this.eSelect.getFocusableElement().focus();
  16452. };
  16453. SelectCellEditor.prototype.getValue = function () {
  16454. return this.eSelect.getValue();
  16455. };
  16456. SelectCellEditor.prototype.isPopup = function () {
  16457. return false;
  16458. };
  16459. __decorate([
  16460. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  16461. ], SelectCellEditor.prototype, "gridOptionsWrapper", void 0);
  16462. __decorate([
  16463. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueFormatterService')
  16464. ], SelectCellEditor.prototype, "valueFormatterService", void 0);
  16465. __decorate([
  16466. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('eSelect')
  16467. ], SelectCellEditor.prototype, "eSelect", void 0);
  16468. return SelectCellEditor;
  16469. }(_widgets_popupComponent__WEBPACK_IMPORTED_MODULE_1__["PopupComponent"]));
  16470. /***/ }),
  16471. /* 80 */
  16472. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  16473. "use strict";
  16474. __webpack_require__.r(__webpack_exports__);
  16475. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PopupTextCellEditor", function() { return PopupTextCellEditor; });
  16476. /* harmony import */ var _textCellEditor__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(54);
  16477. /**
  16478. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  16479. * @version v23.2.1
  16480. * @link http://www.ag-grid.com/
  16481. * @license MIT
  16482. */
  16483. var __extends = (undefined && undefined.__extends) || (function () {
  16484. var extendStatics = function (d, b) {
  16485. extendStatics = Object.setPrototypeOf ||
  16486. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  16487. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  16488. return extendStatics(d, b);
  16489. };
  16490. return function (d, b) {
  16491. extendStatics(d, b);
  16492. function __() { this.constructor = d; }
  16493. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  16494. };
  16495. })();
  16496. var PopupTextCellEditor = /** @class */ (function (_super) {
  16497. __extends(PopupTextCellEditor, _super);
  16498. function PopupTextCellEditor() {
  16499. return _super !== null && _super.apply(this, arguments) || this;
  16500. }
  16501. PopupTextCellEditor.prototype.isPopup = function () {
  16502. return true;
  16503. };
  16504. return PopupTextCellEditor;
  16505. }(_textCellEditor__WEBPACK_IMPORTED_MODULE_0__["TextCellEditor"]));
  16506. /***/ }),
  16507. /* 81 */
  16508. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  16509. "use strict";
  16510. __webpack_require__.r(__webpack_exports__);
  16511. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PopupSelectCellEditor", function() { return PopupSelectCellEditor; });
  16512. /* harmony import */ var _selectCellEditor__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(79);
  16513. /**
  16514. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  16515. * @version v23.2.1
  16516. * @link http://www.ag-grid.com/
  16517. * @license MIT
  16518. */
  16519. var __extends = (undefined && undefined.__extends) || (function () {
  16520. var extendStatics = function (d, b) {
  16521. extendStatics = Object.setPrototypeOf ||
  16522. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  16523. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  16524. return extendStatics(d, b);
  16525. };
  16526. return function (d, b) {
  16527. extendStatics(d, b);
  16528. function __() { this.constructor = d; }
  16529. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  16530. };
  16531. })();
  16532. var PopupSelectCellEditor = /** @class */ (function (_super) {
  16533. __extends(PopupSelectCellEditor, _super);
  16534. function PopupSelectCellEditor() {
  16535. return _super !== null && _super.apply(this, arguments) || this;
  16536. }
  16537. PopupSelectCellEditor.prototype.isPopup = function () {
  16538. return true;
  16539. };
  16540. return PopupSelectCellEditor;
  16541. }(_selectCellEditor__WEBPACK_IMPORTED_MODULE_0__["SelectCellEditor"]));
  16542. /***/ }),
  16543. /* 82 */
  16544. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  16545. "use strict";
  16546. __webpack_require__.r(__webpack_exports__);
  16547. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LargeTextCellEditor", function() { return LargeTextCellEditor; });
  16548. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(25);
  16549. /* harmony import */ var _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(55);
  16550. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57);
  16551. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  16552. /**
  16553. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  16554. * @version v23.2.1
  16555. * @link http://www.ag-grid.com/
  16556. * @license MIT
  16557. */
  16558. var __extends = (undefined && undefined.__extends) || (function () {
  16559. var extendStatics = function (d, b) {
  16560. extendStatics = Object.setPrototypeOf ||
  16561. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  16562. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  16563. return extendStatics(d, b);
  16564. };
  16565. return function (d, b) {
  16566. extendStatics(d, b);
  16567. function __() { this.constructor = d; }
  16568. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  16569. };
  16570. })();
  16571. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  16572. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  16573. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  16574. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  16575. return c > 3 && r && Object.defineProperty(target, key, r), r;
  16576. };
  16577. var LargeTextCellEditor = /** @class */ (function (_super) {
  16578. __extends(LargeTextCellEditor, _super);
  16579. function LargeTextCellEditor() {
  16580. return _super.call(this, LargeTextCellEditor.TEMPLATE) || this;
  16581. }
  16582. LargeTextCellEditor.prototype.init = function (params) {
  16583. this.params = params;
  16584. this.focusAfterAttached = params.cellStartedEdit;
  16585. this.eTextArea
  16586. .setMaxLength(params.maxLength || 200)
  16587. .setCols(params.cols || 60)
  16588. .setRows(params.rows || 10);
  16589. if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(params.value)) {
  16590. this.eTextArea.setValue(params.value.toString(), true);
  16591. }
  16592. this.addGuiEventListener('keydown', this.onKeyDown.bind(this));
  16593. };
  16594. LargeTextCellEditor.prototype.onKeyDown = function (event) {
  16595. var key = event.which || event.keyCode;
  16596. if (key == _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_LEFT ||
  16597. key == _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_UP ||
  16598. key == _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_RIGHT ||
  16599. key == _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_DOWN ||
  16600. (event.shiftKey && key == _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_ENTER)) { // shift+enter allows for newlines
  16601. event.stopPropagation();
  16602. }
  16603. };
  16604. LargeTextCellEditor.prototype.afterGuiAttached = function () {
  16605. if (this.focusAfterAttached) {
  16606. this.eTextArea.getFocusableElement().focus();
  16607. }
  16608. };
  16609. LargeTextCellEditor.prototype.getValue = function () {
  16610. return this.params.parseValue(this.eTextArea.getValue());
  16611. };
  16612. LargeTextCellEditor.TEMPLATE = "<div class=\"ag-large-text\" tabindex=\"0\">\n <ag-input-text-area ref=\"eTextArea\" class=\"ag-large-text-input\"></ag-input-text-area>\n </div>";
  16613. __decorate([
  16614. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])("eTextArea")
  16615. ], LargeTextCellEditor.prototype, "eTextArea", void 0);
  16616. return LargeTextCellEditor;
  16617. }(_widgets_popupComponent__WEBPACK_IMPORTED_MODULE_1__["PopupComponent"]));
  16618. /***/ }),
  16619. /* 83 */
  16620. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  16621. "use strict";
  16622. __webpack_require__.r(__webpack_exports__);
  16623. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "NumberFilter", function() { return NumberFilter; });
  16624. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57);
  16625. /* harmony import */ var _simpleFilter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(60);
  16626. /* harmony import */ var _scalarFilter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(63);
  16627. /* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(14);
  16628. /* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(12);
  16629. /**
  16630. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  16631. * @version v23.2.1
  16632. * @link http://www.ag-grid.com/
  16633. * @license MIT
  16634. */
  16635. var __extends = (undefined && undefined.__extends) || (function () {
  16636. var extendStatics = function (d, b) {
  16637. extendStatics = Object.setPrototypeOf ||
  16638. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  16639. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  16640. return extendStatics(d, b);
  16641. };
  16642. return function (d, b) {
  16643. extendStatics(d, b);
  16644. function __() { this.constructor = d; }
  16645. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  16646. };
  16647. })();
  16648. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  16649. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  16650. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  16651. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  16652. return c > 3 && r && Object.defineProperty(target, key, r), r;
  16653. };
  16654. var NumberFilter = /** @class */ (function (_super) {
  16655. __extends(NumberFilter, _super);
  16656. function NumberFilter() {
  16657. return _super !== null && _super.apply(this, arguments) || this;
  16658. }
  16659. NumberFilter.prototype.mapRangeFromModel = function (filterModel) {
  16660. return {
  16661. from: filterModel.filter,
  16662. to: filterModel.filterTo
  16663. };
  16664. };
  16665. NumberFilter.prototype.getDefaultDebounceMs = function () {
  16666. return 500;
  16667. };
  16668. NumberFilter.prototype.resetUiToDefaults = function (silent) {
  16669. var _this = this;
  16670. return _super.prototype.resetUiToDefaults.call(this, silent).then(function () {
  16671. var fields = [_this.eValueFrom1, _this.eValueFrom2, _this.eValueTo1, _this.eValueTo2];
  16672. fields.forEach(function (field) { return field.setValue(null, silent); });
  16673. _this.resetPlaceholder();
  16674. });
  16675. };
  16676. NumberFilter.prototype.setConditionIntoUi = function (model, position) {
  16677. var positionOne = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["ConditionPosition"].One;
  16678. var eValueFrom = positionOne ? this.eValueFrom1 : this.eValueFrom2;
  16679. var eValueTo = positionOne ? this.eValueTo1 : this.eValueTo2;
  16680. eValueFrom.setValue(model ? ('' + model.filter) : null);
  16681. eValueTo.setValue(model ? ('' + model.filterTo) : null);
  16682. };
  16683. NumberFilter.prototype.setValueFromFloatingFilter = function (value) {
  16684. this.eValueFrom1.setValue(value);
  16685. this.eValueFrom2.setValue(null);
  16686. this.eValueTo1.setValue(null);
  16687. this.eValueTo2.setValue(null);
  16688. };
  16689. NumberFilter.prototype.comparator = function () {
  16690. return function (left, right) {
  16691. if (left === right) {
  16692. return 0;
  16693. }
  16694. if (left < right) {
  16695. return 1;
  16696. }
  16697. return -1;
  16698. };
  16699. };
  16700. NumberFilter.prototype.setParams = function (params) {
  16701. _super.prototype.setParams.call(this, params);
  16702. this.addValueChangedListeners();
  16703. };
  16704. NumberFilter.prototype.addValueChangedListeners = function () {
  16705. var _this = this;
  16706. var listener = function () { return _this.onUiChanged(); };
  16707. this.eValueFrom1.onValueChange(listener);
  16708. this.eValueFrom2.onValueChange(listener);
  16709. this.eValueTo1.onValueChange(listener);
  16710. this.eValueTo2.onValueChange(listener);
  16711. };
  16712. NumberFilter.prototype.resetPlaceholder = function () {
  16713. var isRange1 = this.getCondition1Type() === _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].IN_RANGE;
  16714. var isRange2 = this.getCondition2Type() === _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].IN_RANGE;
  16715. this.eValueFrom1.setInputPlaceholder(this.translate(isRange1 ? 'inRangeStart' : 'filterOoo'));
  16716. this.eValueTo1.setInputPlaceholder(this.translate(isRange1 ? 'inRangeEnd' : 'filterOoo'));
  16717. this.eValueFrom2.setInputPlaceholder(this.translate(isRange2 ? 'inRangeStart' : 'filterOoo'));
  16718. this.eValueTo2.setInputPlaceholder(this.translate(isRange2 ? 'inRangeEnd' : 'filterOoo'));
  16719. };
  16720. NumberFilter.prototype.afterGuiAttached = function (params) {
  16721. _super.prototype.afterGuiAttached.call(this, params);
  16722. this.resetPlaceholder();
  16723. this.eValueFrom1.getInputElement().focus();
  16724. };
  16725. NumberFilter.prototype.getDefaultFilterOptions = function () {
  16726. return NumberFilter.DEFAULT_FILTER_OPTIONS;
  16727. };
  16728. NumberFilter.prototype.createValueTemplate = function (position) {
  16729. var positionOne = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["ConditionPosition"].One;
  16730. var pos = positionOne ? '1' : '2';
  16731. return "<div class=\"ag-filter-body\" ref=\"eCondition" + pos + "Body\" role=\"presentation\">\n <ag-input-number-field class=\"ag-filter-from ag-filter-filter\" ref=\"eValueFrom" + pos + "\"></ag-input-number-field>\n <ag-input-number-field class=\"ag-filter-to ag-filter-filter\" ref=\"eValueTo" + pos + "\"></ag-input-number-field>\n </div>";
  16732. };
  16733. NumberFilter.prototype.isConditionUiComplete = function (position) {
  16734. var positionOne = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["ConditionPosition"].One;
  16735. var option = positionOne ? this.getCondition1Type() : this.getCondition2Type();
  16736. var eValue = positionOne ? this.eValueFrom1 : this.eValueFrom2;
  16737. var eValueTo = positionOne ? this.eValueTo1 : this.eValueTo2;
  16738. var value = this.stringToFloat(eValue.getValue());
  16739. var valueTo = this.stringToFloat(eValueTo.getValue());
  16740. if (option === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].EMPTY) {
  16741. return false;
  16742. }
  16743. if (this.doesFilterHaveHiddenInput(option)) {
  16744. return true;
  16745. }
  16746. if (option === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].IN_RANGE) {
  16747. return value != null && valueTo != null;
  16748. }
  16749. return value != null;
  16750. };
  16751. NumberFilter.prototype.areSimpleModelsEqual = function (aSimple, bSimple) {
  16752. return aSimple.filter === bSimple.filter
  16753. && aSimple.filterTo === bSimple.filterTo
  16754. && aSimple.type === bSimple.type;
  16755. };
  16756. // needed for creating filter model
  16757. NumberFilter.prototype.getFilterType = function () {
  16758. return NumberFilter.FILTER_TYPE;
  16759. };
  16760. NumberFilter.prototype.stringToFloat = function (value) {
  16761. if (typeof value === 'number') {
  16762. return value;
  16763. }
  16764. var filterText = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_3__["makeNull"])(value);
  16765. if (filterText && filterText.trim() === '') {
  16766. filterText = null;
  16767. }
  16768. var newFilter;
  16769. if (filterText !== null && filterText !== undefined) {
  16770. newFilter = parseFloat(filterText);
  16771. }
  16772. else {
  16773. newFilter = null;
  16774. }
  16775. return newFilter;
  16776. };
  16777. NumberFilter.prototype.createCondition = function (position) {
  16778. var positionOne = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["ConditionPosition"].One;
  16779. var type = positionOne ? this.getCondition1Type() : this.getCondition2Type();
  16780. var eValue = positionOne ? this.eValueFrom1 : this.eValueFrom2;
  16781. var value = this.stringToFloat(eValue.getValue());
  16782. var eValueTo = positionOne ? this.eValueTo1 : this.eValueTo2;
  16783. var valueTo = this.stringToFloat(eValueTo.getValue());
  16784. var model = {
  16785. filterType: NumberFilter.FILTER_TYPE,
  16786. type: type
  16787. };
  16788. if (!this.doesFilterHaveHiddenInput(type)) {
  16789. model.filter = value;
  16790. model.filterTo = valueTo; // FIX - should only populate this when filter choice has 'to' option
  16791. }
  16792. return model;
  16793. };
  16794. NumberFilter.prototype.updateUiVisibility = function () {
  16795. _super.prototype.updateUiVisibility.call(this);
  16796. this.resetPlaceholder();
  16797. var showFrom1 = this.showValueFrom(this.getCondition1Type());
  16798. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setDisplayed"])(this.eValueFrom1.getGui(), showFrom1);
  16799. var showTo1 = this.showValueTo(this.getCondition1Type());
  16800. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setDisplayed"])(this.eValueTo1.getGui(), showTo1);
  16801. var showFrom2 = this.showValueFrom(this.getCondition2Type());
  16802. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setDisplayed"])(this.eValueFrom2.getGui(), showFrom2);
  16803. var showTo2 = this.showValueTo(this.getCondition2Type());
  16804. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_4__["setDisplayed"])(this.eValueTo2.getGui(), showTo2);
  16805. };
  16806. NumberFilter.FILTER_TYPE = 'number';
  16807. NumberFilter.DEFAULT_FILTER_OPTIONS = [
  16808. _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].EQUALS,
  16809. _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].NOT_EQUAL,
  16810. _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].LESS_THAN,
  16811. _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].LESS_THAN_OR_EQUAL,
  16812. _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].GREATER_THAN,
  16813. _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].GREATER_THAN_OR_EQUAL,
  16814. _scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"].IN_RANGE
  16815. ];
  16816. __decorate([
  16817. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValueFrom1')
  16818. ], NumberFilter.prototype, "eValueFrom1", void 0);
  16819. __decorate([
  16820. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValueFrom2')
  16821. ], NumberFilter.prototype, "eValueFrom2", void 0);
  16822. __decorate([
  16823. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValueTo1')
  16824. ], NumberFilter.prototype, "eValueTo1", void 0);
  16825. __decorate([
  16826. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValueTo2')
  16827. ], NumberFilter.prototype, "eValueTo2", void 0);
  16828. return NumberFilter;
  16829. }(_scalarFilter__WEBPACK_IMPORTED_MODULE_2__["ScalarFilter"]));
  16830. /***/ }),
  16831. /* 84 */
  16832. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  16833. "use strict";
  16834. __webpack_require__.r(__webpack_exports__);
  16835. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LoadingOverlayComponent", function() { return LoadingOverlayComponent; });
  16836. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  16837. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(56);
  16838. /**
  16839. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  16840. * @version v23.2.1
  16841. * @link http://www.ag-grid.com/
  16842. * @license MIT
  16843. */
  16844. var __extends = (undefined && undefined.__extends) || (function () {
  16845. var extendStatics = function (d, b) {
  16846. extendStatics = Object.setPrototypeOf ||
  16847. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  16848. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  16849. return extendStatics(d, b);
  16850. };
  16851. return function (d, b) {
  16852. extendStatics(d, b);
  16853. function __() { this.constructor = d; }
  16854. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  16855. };
  16856. })();
  16857. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  16858. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  16859. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  16860. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  16861. return c > 3 && r && Object.defineProperty(target, key, r), r;
  16862. };
  16863. var LoadingOverlayComponent = /** @class */ (function (_super) {
  16864. __extends(LoadingOverlayComponent, _super);
  16865. function LoadingOverlayComponent() {
  16866. return _super.call(this) || this;
  16867. }
  16868. // this is a user component, and IComponent has "public destroy()" as part of the interface.
  16869. // so we need to override destroy() just to make the method public.
  16870. LoadingOverlayComponent.prototype.destroy = function () {
  16871. _super.prototype.destroy.call(this);
  16872. };
  16873. LoadingOverlayComponent.prototype.init = function (params) {
  16874. var template = this.gridOptionsWrapper.getOverlayLoadingTemplate() ?
  16875. this.gridOptionsWrapper.getOverlayLoadingTemplate() : LoadingOverlayComponent.DEFAULT_LOADING_OVERLAY_TEMPLATE;
  16876. var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();
  16877. var localisedTemplate = template.replace('[LOADING...]', localeTextFunc('loadingOoo', 'Loading...'));
  16878. this.setTemplate(localisedTemplate);
  16879. };
  16880. LoadingOverlayComponent.DEFAULT_LOADING_OVERLAY_TEMPLATE = '<span class="ag-overlay-loading-center">[LOADING...]</span>';
  16881. __decorate([
  16882. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  16883. ], LoadingOverlayComponent.prototype, "gridOptionsWrapper", void 0);
  16884. return LoadingOverlayComponent;
  16885. }(_widgets_component__WEBPACK_IMPORTED_MODULE_1__["Component"]));
  16886. /***/ }),
  16887. /* 85 */
  16888. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  16889. "use strict";
  16890. __webpack_require__.r(__webpack_exports__);
  16891. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "NoRowsOverlayComponent", function() { return NoRowsOverlayComponent; });
  16892. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  16893. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(56);
  16894. /**
  16895. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  16896. * @version v23.2.1
  16897. * @link http://www.ag-grid.com/
  16898. * @license MIT
  16899. */
  16900. var __extends = (undefined && undefined.__extends) || (function () {
  16901. var extendStatics = function (d, b) {
  16902. extendStatics = Object.setPrototypeOf ||
  16903. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  16904. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  16905. return extendStatics(d, b);
  16906. };
  16907. return function (d, b) {
  16908. extendStatics(d, b);
  16909. function __() { this.constructor = d; }
  16910. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  16911. };
  16912. })();
  16913. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  16914. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  16915. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  16916. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  16917. return c > 3 && r && Object.defineProperty(target, key, r), r;
  16918. };
  16919. var NoRowsOverlayComponent = /** @class */ (function (_super) {
  16920. __extends(NoRowsOverlayComponent, _super);
  16921. function NoRowsOverlayComponent() {
  16922. return _super.call(this) || this;
  16923. }
  16924. // this is a user component, and IComponent has "public destroy()" as part of the interface.
  16925. // so we need to override destroy() just to make the method public.
  16926. NoRowsOverlayComponent.prototype.destroy = function () {
  16927. _super.prototype.destroy.call(this);
  16928. };
  16929. NoRowsOverlayComponent.prototype.init = function (params) {
  16930. var template = this.gridOptionsWrapper.getOverlayNoRowsTemplate() ?
  16931. this.gridOptionsWrapper.getOverlayNoRowsTemplate() : NoRowsOverlayComponent.DEFAULT_NO_ROWS_TEMPLATE;
  16932. var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();
  16933. var localisedTemplate = template.replace('[NO_ROWS_TO_SHOW]', localeTextFunc('noRowsToShow', 'No Rows To Show'));
  16934. this.setTemplate(localisedTemplate);
  16935. };
  16936. NoRowsOverlayComponent.DEFAULT_NO_ROWS_TEMPLATE = '<span class="ag-overlay-no-rows-center">[NO_ROWS_TO_SHOW]</span>';
  16937. __decorate([
  16938. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  16939. ], NoRowsOverlayComponent.prototype, "gridOptionsWrapper", void 0);
  16940. return NoRowsOverlayComponent;
  16941. }(_widgets_component__WEBPACK_IMPORTED_MODULE_1__["Component"]));
  16942. /***/ }),
  16943. /* 86 */
  16944. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  16945. "use strict";
  16946. __webpack_require__.r(__webpack_exports__);
  16947. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TooltipComponent", function() { return TooltipComponent; });
  16948. /* harmony import */ var _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(55);
  16949. /**
  16950. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  16951. * @version v23.2.1
  16952. * @link http://www.ag-grid.com/
  16953. * @license MIT
  16954. */
  16955. var __extends = (undefined && undefined.__extends) || (function () {
  16956. var extendStatics = function (d, b) {
  16957. extendStatics = Object.setPrototypeOf ||
  16958. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  16959. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  16960. return extendStatics(d, b);
  16961. };
  16962. return function (d, b) {
  16963. extendStatics(d, b);
  16964. function __() { this.constructor = d; }
  16965. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  16966. };
  16967. })();
  16968. var TooltipComponent = /** @class */ (function (_super) {
  16969. __extends(TooltipComponent, _super);
  16970. function TooltipComponent() {
  16971. return _super.call(this, /* html */ "<div class=\"ag-tooltip\"></div>") || this;
  16972. }
  16973. // will need to type params
  16974. TooltipComponent.prototype.init = function (params) {
  16975. var value = params.value;
  16976. this.getGui().innerHTML = value;
  16977. };
  16978. return TooltipComponent;
  16979. }(_widgets_popupComponent__WEBPACK_IMPORTED_MODULE_0__["PopupComponent"]));
  16980. /***/ }),
  16981. /* 87 */
  16982. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  16983. "use strict";
  16984. __webpack_require__.r(__webpack_exports__);
  16985. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DefaultDateComponent", function() { return DefaultDateComponent; });
  16986. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56);
  16987. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57);
  16988. /* harmony import */ var _utils_date__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(18);
  16989. /* harmony import */ var _utils_browser__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(13);
  16990. /**
  16991. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  16992. * @version v23.2.1
  16993. * @link http://www.ag-grid.com/
  16994. * @license MIT
  16995. */
  16996. var __extends = (undefined && undefined.__extends) || (function () {
  16997. var extendStatics = function (d, b) {
  16998. extendStatics = Object.setPrototypeOf ||
  16999. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  17000. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  17001. return extendStatics(d, b);
  17002. };
  17003. return function (d, b) {
  17004. extendStatics(d, b);
  17005. function __() { this.constructor = d; }
  17006. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  17007. };
  17008. })();
  17009. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  17010. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  17011. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  17012. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  17013. return c > 3 && r && Object.defineProperty(target, key, r), r;
  17014. };
  17015. var DefaultDateComponent = /** @class */ (function (_super) {
  17016. __extends(DefaultDateComponent, _super);
  17017. function DefaultDateComponent() {
  17018. return _super.call(this, /* html */ "\n <div class=\"ag-filter-filter\">\n <ag-input-text-field class=\"ag-date-filter\" ref=\"eDateInput\"></ag-input-text-field>\n </div>") || this;
  17019. }
  17020. // this is a user component, and IComponent has "public destroy()" as part of the interface.
  17021. // so we need to override destroy() just to make the method public.
  17022. DefaultDateComponent.prototype.destroy = function () {
  17023. _super.prototype.destroy.call(this);
  17024. };
  17025. DefaultDateComponent.prototype.init = function (params) {
  17026. var _this = this;
  17027. if (this.shouldUseBrowserDatePicker(params)) {
  17028. if (Object(_utils_browser__WEBPACK_IMPORTED_MODULE_3__["isBrowserIE"])()) {
  17029. console.warn('ag-grid: browserDatePicker is specified to true, but it is not supported in IE 11, reverting to plain text date picker');
  17030. }
  17031. else {
  17032. this.eDateInput.getInputElement().type = 'date';
  17033. }
  17034. }
  17035. this.listener = params.onDateChanged;
  17036. this.addManagedListener(this.eDateInput.getInputElement(), 'input', function (e) {
  17037. if (e.target !== document.activeElement) {
  17038. return;
  17039. }
  17040. _this.listener();
  17041. });
  17042. };
  17043. DefaultDateComponent.prototype.getDate = function () {
  17044. return Object(_utils_date__WEBPACK_IMPORTED_MODULE_2__["parseDateTimeFromString"])(this.eDateInput.getValue());
  17045. };
  17046. DefaultDateComponent.prototype.setDate = function (date) {
  17047. this.eDateInput.setValue(Object(_utils_date__WEBPACK_IMPORTED_MODULE_2__["serialiseDate"])(date, false));
  17048. };
  17049. DefaultDateComponent.prototype.setInputPlaceholder = function (placeholder) {
  17050. this.eDateInput.setInputPlaceholder(placeholder);
  17051. };
  17052. DefaultDateComponent.prototype.shouldUseBrowserDatePicker = function (params) {
  17053. if (params.filterParams && params.filterParams.browserDatePicker != null) {
  17054. return params.filterParams.browserDatePicker;
  17055. }
  17056. else {
  17057. return Object(_utils_browser__WEBPACK_IMPORTED_MODULE_3__["isBrowserChrome"])() || Object(_utils_browser__WEBPACK_IMPORTED_MODULE_3__["isBrowserFirefox"])();
  17058. }
  17059. };
  17060. __decorate([
  17061. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eDateInput')
  17062. ], DefaultDateComponent.prototype, "eDateInput", void 0);
  17063. return DefaultDateComponent;
  17064. }(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"]));
  17065. /***/ }),
  17066. /* 88 */
  17067. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  17068. "use strict";
  17069. __webpack_require__.r(__webpack_exports__);
  17070. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DateFloatingFilter", function() { return DateFloatingFilter; });
  17071. /* harmony import */ var _dateFilter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(58);
  17072. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  17073. /* harmony import */ var _dateCompWrapper__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(59);
  17074. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(57);
  17075. /* harmony import */ var _simpleFilter__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(60);
  17076. /* harmony import */ var _floating_provided_simpleFloatingFilter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(89);
  17077. /* harmony import */ var _providedFilter__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(62);
  17078. /* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(12);
  17079. /* harmony import */ var _utils_date__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(18);
  17080. /* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(21);
  17081. /**
  17082. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  17083. * @version v23.2.1
  17084. * @link http://www.ag-grid.com/
  17085. * @license MIT
  17086. */
  17087. var __extends = (undefined && undefined.__extends) || (function () {
  17088. var extendStatics = function (d, b) {
  17089. extendStatics = Object.setPrototypeOf ||
  17090. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  17091. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  17092. return extendStatics(d, b);
  17093. };
  17094. return function (d, b) {
  17095. extendStatics(d, b);
  17096. function __() { this.constructor = d; }
  17097. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  17098. };
  17099. })();
  17100. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  17101. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  17102. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  17103. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  17104. return c > 3 && r && Object.defineProperty(target, key, r), r;
  17105. };
  17106. var DateFloatingFilter = /** @class */ (function (_super) {
  17107. __extends(DateFloatingFilter, _super);
  17108. function DateFloatingFilter() {
  17109. return _super.call(this, /* html */ "\n <div class=\"ag-floating-filter-input\" role=\"presentation\">\n <ag-input-text-field ref=\"eReadOnlyText\"></ag-input-text-field>\n <div ref=\"eDateWrapper\" style=\"display: flex; overflow: hidden;\"></div>\n </div>") || this;
  17110. }
  17111. DateFloatingFilter.prototype.getDefaultFilterOptions = function () {
  17112. return _dateFilter__WEBPACK_IMPORTED_MODULE_0__["DateFilter"].DEFAULT_FILTER_OPTIONS;
  17113. };
  17114. DateFloatingFilter.prototype.conditionToString = function (condition) {
  17115. if (condition.type === _simpleFilter__WEBPACK_IMPORTED_MODULE_4__["SimpleFilter"].IN_RANGE) {
  17116. return condition.dateFrom + "-" + condition.dateTo;
  17117. }
  17118. // cater for when the type doesn't need a value
  17119. if (condition.dateFrom != null) {
  17120. return "" + condition.dateFrom;
  17121. }
  17122. return "" + condition.type;
  17123. };
  17124. DateFloatingFilter.prototype.init = function (params) {
  17125. _super.prototype.init.call(this, params);
  17126. this.params = params;
  17127. this.createDateComponent();
  17128. this.eReadOnlyText
  17129. .setDisabled(true)
  17130. .setInputAriaLabel('Date Filter Input');
  17131. };
  17132. DateFloatingFilter.prototype.setEditable = function (editable) {
  17133. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_7__["setDisplayed"])(this.eDateWrapper, editable);
  17134. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_7__["setDisplayed"])(this.eReadOnlyText.getGui(), !editable);
  17135. };
  17136. DateFloatingFilter.prototype.onParentModelChanged = function (model, event) {
  17137. // We don't want to update the floating filter if the floating filter caused the change,
  17138. // because the UI is already in sync. if we didn't do this, the UI would behave strangely
  17139. // as it would be updating as the user is typing
  17140. if (this.isEventFromFloatingFilter(event)) {
  17141. return;
  17142. }
  17143. _super.prototype.setLastTypeFromModel.call(this, model);
  17144. var allowEditing = this.canWeEditAfterModelFromParentFilter(model);
  17145. this.setEditable(allowEditing);
  17146. if (allowEditing) {
  17147. if (model) {
  17148. var dateModel = model;
  17149. this.dateComp.setDate(Object(_utils_date__WEBPACK_IMPORTED_MODULE_8__["parseDateTimeFromString"])(dateModel.dateFrom));
  17150. }
  17151. else {
  17152. this.dateComp.setDate(null);
  17153. }
  17154. this.eReadOnlyText.setValue('');
  17155. }
  17156. else {
  17157. this.eReadOnlyText.setValue(this.getTextFromModel(model));
  17158. this.dateComp.setDate(null);
  17159. }
  17160. };
  17161. DateFloatingFilter.prototype.onDateChanged = function () {
  17162. var _this = this;
  17163. var filterValueDate = this.dateComp.getDate();
  17164. var filterValueText = Object(_utils_date__WEBPACK_IMPORTED_MODULE_8__["serialiseDate"])(filterValueDate);
  17165. this.params.parentFilterInstance(function (filterInstance) {
  17166. if (filterInstance) {
  17167. var simpleFilter = filterInstance;
  17168. simpleFilter.onFloatingFilterChanged(_this.getLastType(), filterValueText);
  17169. }
  17170. });
  17171. };
  17172. DateFloatingFilter.prototype.createDateComponent = function () {
  17173. var _this = this;
  17174. var debounceMs = _providedFilter__WEBPACK_IMPORTED_MODULE_6__["ProvidedFilter"].getDebounceMs(this.params.filterParams, this.getDefaultDebounceMs());
  17175. var dateComponentParams = {
  17176. onDateChanged: Object(_utils_function__WEBPACK_IMPORTED_MODULE_9__["debounce"])(this.onDateChanged.bind(this), debounceMs),
  17177. filterParams: this.params.column.getColDef().filterParams
  17178. };
  17179. this.dateComp = new _dateCompWrapper__WEBPACK_IMPORTED_MODULE_2__["DateCompWrapper"](this.getContext(), this.userComponentFactory, dateComponentParams, this.eDateWrapper);
  17180. this.addDestroyFunc(function () { return _this.dateComp.destroy(); });
  17181. };
  17182. __decorate([
  17183. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('userComponentFactory')
  17184. ], DateFloatingFilter.prototype, "userComponentFactory", void 0);
  17185. __decorate([
  17186. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eReadOnlyText')
  17187. ], DateFloatingFilter.prototype, "eReadOnlyText", void 0);
  17188. __decorate([
  17189. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eDateWrapper')
  17190. ], DateFloatingFilter.prototype, "eDateWrapper", void 0);
  17191. return DateFloatingFilter;
  17192. }(_floating_provided_simpleFloatingFilter__WEBPACK_IMPORTED_MODULE_5__["SimpleFloatingFilter"]));
  17193. /***/ }),
  17194. /* 89 */
  17195. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  17196. "use strict";
  17197. __webpack_require__.r(__webpack_exports__);
  17198. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SimpleFloatingFilter", function() { return SimpleFloatingFilter; });
  17199. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56);
  17200. /* harmony import */ var _provided_simpleFilter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(60);
  17201. /* harmony import */ var _provided_optionsFactory__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(61);
  17202. /**
  17203. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  17204. * @version v23.2.1
  17205. * @link http://www.ag-grid.com/
  17206. * @license MIT
  17207. */
  17208. var __extends = (undefined && undefined.__extends) || (function () {
  17209. var extendStatics = function (d, b) {
  17210. extendStatics = Object.setPrototypeOf ||
  17211. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  17212. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  17213. return extendStatics(d, b);
  17214. };
  17215. return function (d, b) {
  17216. extendStatics(d, b);
  17217. function __() { this.constructor = d; }
  17218. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  17219. };
  17220. })();
  17221. var SimpleFloatingFilter = /** @class */ (function (_super) {
  17222. __extends(SimpleFloatingFilter, _super);
  17223. function SimpleFloatingFilter() {
  17224. return _super !== null && _super.apply(this, arguments) || this;
  17225. }
  17226. SimpleFloatingFilter.prototype.getDefaultDebounceMs = function () {
  17227. return 0;
  17228. };
  17229. // this is a user component, and IComponent has "public destroy()" as part of the interface.
  17230. // so we need to override destroy() just to make the method public.
  17231. SimpleFloatingFilter.prototype.destroy = function () {
  17232. _super.prototype.destroy.call(this);
  17233. };
  17234. // used by:
  17235. // 1) NumberFloatingFilter & TextFloatingFilter: Always, for both when editable and read only.
  17236. // 2) DateFloatingFilter: Only when read only (as we show text rather than a date picker when read only)
  17237. SimpleFloatingFilter.prototype.getTextFromModel = function (model) {
  17238. if (!model) {
  17239. return null;
  17240. }
  17241. var isCombined = model.operator;
  17242. if (isCombined) {
  17243. var combinedModel = model;
  17244. var con1Str = this.conditionToString(combinedModel.condition1);
  17245. var con2Str = this.conditionToString(combinedModel.condition2);
  17246. return con1Str + " " + combinedModel.operator + " " + con2Str;
  17247. }
  17248. else {
  17249. var condition = model;
  17250. return this.conditionToString(condition);
  17251. }
  17252. };
  17253. SimpleFloatingFilter.prototype.isEventFromFloatingFilter = function (event) {
  17254. return event && event.afterFloatingFilter;
  17255. };
  17256. SimpleFloatingFilter.prototype.getLastType = function () {
  17257. return this.lastType;
  17258. };
  17259. SimpleFloatingFilter.prototype.setLastTypeFromModel = function (model) {
  17260. // if no model provided by the parent filter use default
  17261. if (!model) {
  17262. this.lastType = this.optionsFactory.getDefaultOption();
  17263. return;
  17264. }
  17265. var isCombined = model.operator;
  17266. var condition;
  17267. if (isCombined) {
  17268. var combinedModel = model;
  17269. condition = combinedModel.condition1;
  17270. }
  17271. else {
  17272. condition = model;
  17273. }
  17274. this.lastType = condition.type;
  17275. };
  17276. SimpleFloatingFilter.prototype.canWeEditAfterModelFromParentFilter = function (model) {
  17277. if (!model) {
  17278. // if no model, then we can edit as long as the lastType is something we can edit, as this
  17279. // is the type we will provide to the parent filter if the user decides to use the floating filter.
  17280. return this.isTypeEditable(this.lastType);
  17281. }
  17282. // never allow editing if the filter is combined (ie has two parts)
  17283. var isCombined = model.operator;
  17284. if (isCombined) {
  17285. return false;
  17286. }
  17287. var simpleModel = model;
  17288. return this.isTypeEditable(simpleModel.type);
  17289. };
  17290. SimpleFloatingFilter.prototype.init = function (params) {
  17291. this.optionsFactory = new _provided_optionsFactory__WEBPACK_IMPORTED_MODULE_2__["OptionsFactory"]();
  17292. this.optionsFactory.init(params.filterParams, this.getDefaultFilterOptions());
  17293. this.lastType = this.optionsFactory.getDefaultOption();
  17294. // we are editable if:
  17295. // 1) there is a type (user has configured filter wrong if not type)
  17296. // AND
  17297. // 2) the default type is not 'in range'
  17298. var editable = this.isTypeEditable(this.lastType);
  17299. this.setEditable(editable);
  17300. };
  17301. SimpleFloatingFilter.prototype.doesFilterHaveHiddenInput = function (filterType) {
  17302. var customFilterOption = this.optionsFactory.getCustomOption(filterType);
  17303. return customFilterOption && customFilterOption.hideFilterInput;
  17304. };
  17305. SimpleFloatingFilter.prototype.isTypeEditable = function (type) {
  17306. return !this.doesFilterHaveHiddenInput(type) &&
  17307. type
  17308. && type !== _provided_simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].IN_RANGE
  17309. && type !== _provided_simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].EMPTY;
  17310. };
  17311. return SimpleFloatingFilter;
  17312. }(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"]));
  17313. /***/ }),
  17314. /* 90 */
  17315. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  17316. "use strict";
  17317. __webpack_require__.r(__webpack_exports__);
  17318. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TextFilter", function() { return TextFilter; });
  17319. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57);
  17320. /* harmony import */ var _simpleFilter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(60);
  17321. /* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(14);
  17322. /* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(12);
  17323. /* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(17);
  17324. /**
  17325. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  17326. * @version v23.2.1
  17327. * @link http://www.ag-grid.com/
  17328. * @license MIT
  17329. */
  17330. var __extends = (undefined && undefined.__extends) || (function () {
  17331. var extendStatics = function (d, b) {
  17332. extendStatics = Object.setPrototypeOf ||
  17333. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  17334. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  17335. return extendStatics(d, b);
  17336. };
  17337. return function (d, b) {
  17338. extendStatics(d, b);
  17339. function __() { this.constructor = d; }
  17340. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  17341. };
  17342. })();
  17343. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  17344. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  17345. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  17346. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  17347. return c > 3 && r && Object.defineProperty(target, key, r), r;
  17348. };
  17349. var TextFilter = /** @class */ (function (_super) {
  17350. __extends(TextFilter, _super);
  17351. function TextFilter() {
  17352. return _super !== null && _super.apply(this, arguments) || this;
  17353. }
  17354. TextFilter.prototype.getDefaultDebounceMs = function () {
  17355. return 500;
  17356. };
  17357. TextFilter.prototype.getValue = function (inputField) {
  17358. var val = inputField.getValue();
  17359. val = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_2__["makeNull"])(val);
  17360. if (val && val.trim() === '') {
  17361. val = null;
  17362. }
  17363. return val;
  17364. };
  17365. TextFilter.prototype.addValueChangedListeners = function () {
  17366. var _this = this;
  17367. var listener = function () { return _this.onUiChanged(); };
  17368. this.eValue1.onValueChange(listener);
  17369. this.eValue2.onValueChange(listener);
  17370. };
  17371. TextFilter.prototype.setParams = function (params) {
  17372. _super.prototype.setParams.call(this, params);
  17373. this.textFilterParams = params;
  17374. this.comparator = this.textFilterParams.textCustomComparator || TextFilter.DEFAULT_COMPARATOR;
  17375. this.formatter = this.textFilterParams.textFormatter ||
  17376. (this.textFilterParams.caseSensitive == true
  17377. ? TextFilter.DEFAULT_FORMATTER
  17378. : TextFilter.DEFAULT_LOWERCASE_FORMATTER);
  17379. this.addValueChangedListeners();
  17380. };
  17381. TextFilter.prototype.setConditionIntoUi = function (model, position) {
  17382. var positionOne = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["ConditionPosition"].One;
  17383. var eValue = positionOne ? this.eValue1 : this.eValue2;
  17384. eValue.setValue(model ? model.filter : null);
  17385. };
  17386. TextFilter.prototype.createCondition = function (position) {
  17387. var positionOne = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["ConditionPosition"].One;
  17388. var type = positionOne ? this.getCondition1Type() : this.getCondition2Type();
  17389. var eValue = positionOne ? this.eValue1 : this.eValue2;
  17390. var value = this.getValue(eValue);
  17391. var model = {
  17392. filterType: TextFilter.FILTER_TYPE,
  17393. type: type
  17394. };
  17395. if (!this.doesFilterHaveHiddenInput(type)) {
  17396. model.filter = value;
  17397. }
  17398. return model;
  17399. };
  17400. TextFilter.prototype.getFilterType = function () {
  17401. return TextFilter.FILTER_TYPE;
  17402. };
  17403. TextFilter.prototype.areSimpleModelsEqual = function (aSimple, bSimple) {
  17404. return aSimple.filter === bSimple.filter && aSimple.type === bSimple.type;
  17405. };
  17406. TextFilter.prototype.resetUiToDefaults = function (silent) {
  17407. var _this = this;
  17408. return _super.prototype.resetUiToDefaults.call(this, silent).then(function () {
  17409. _this.forEachInput(function (field) { return field.setValue(null, silent); });
  17410. _this.resetPlaceholder();
  17411. });
  17412. };
  17413. TextFilter.prototype.resetPlaceholder = function () {
  17414. var placeholder = this.translate('filterOoo');
  17415. this.forEachInput(function (field) { return field.setInputPlaceholder(placeholder); });
  17416. };
  17417. TextFilter.prototype.forEachInput = function (action) {
  17418. Object(_utils_array__WEBPACK_IMPORTED_MODULE_4__["forEach"])([this.eValue1, this.eValue2], action);
  17419. };
  17420. TextFilter.prototype.setValueFromFloatingFilter = function (value) {
  17421. this.eValue1.setValue(value);
  17422. this.eValue2.setValue(null);
  17423. };
  17424. TextFilter.prototype.getDefaultFilterOptions = function () {
  17425. return TextFilter.DEFAULT_FILTER_OPTIONS;
  17426. };
  17427. TextFilter.prototype.createValueTemplate = function (position) {
  17428. var pos = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["ConditionPosition"].One ? '1' : '2';
  17429. return /* html */ "\n <div class=\"ag-filter-body\" ref=\"eCondition" + pos + "Body\" role=\"presentation\">\n <ag-input-text-field class=\"ag-filter-filter\" ref=\"eValue" + pos + "\"></ag-input-text-field>\n </div>";
  17430. };
  17431. TextFilter.prototype.updateUiVisibility = function () {
  17432. _super.prototype.updateUiVisibility.call(this);
  17433. var showValue1 = this.showValueFrom(this.getCondition1Type());
  17434. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["setDisplayed"])(this.eValue1.getGui(), showValue1);
  17435. var showValue2 = this.showValueFrom(this.getCondition2Type());
  17436. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_3__["setDisplayed"])(this.eValue2.getGui(), showValue2);
  17437. };
  17438. TextFilter.prototype.afterGuiAttached = function (params) {
  17439. _super.prototype.afterGuiAttached.call(this, params);
  17440. this.resetPlaceholder();
  17441. this.eValue1.getInputElement().focus();
  17442. };
  17443. TextFilter.prototype.isConditionUiComplete = function (position) {
  17444. var positionOne = position === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["ConditionPosition"].One;
  17445. var option = positionOne ? this.getCondition1Type() : this.getCondition2Type();
  17446. if (option === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].EMPTY) {
  17447. return false;
  17448. }
  17449. if (this.doesFilterHaveHiddenInput(option)) {
  17450. return true;
  17451. }
  17452. return this.getValue(positionOne ? this.eValue1 : this.eValue2) != null;
  17453. };
  17454. TextFilter.prototype.individualConditionPasses = function (params, filterModel) {
  17455. var filterText = filterModel.filter;
  17456. var filterOption = filterModel.type;
  17457. var cellValue = this.textFilterParams.valueGetter(params.node);
  17458. var cellValueFormatted = this.formatter(cellValue);
  17459. var customFilterOption = this.optionsFactory.getCustomOption(filterOption);
  17460. if (customFilterOption) {
  17461. // only execute the custom filter if a value exists or a value isn't required, i.e. input is hidden
  17462. if (filterText != null || customFilterOption.hideFilterInput) {
  17463. return customFilterOption.test(filterText, cellValueFormatted);
  17464. }
  17465. }
  17466. if (cellValue == null) {
  17467. return filterOption === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].NOT_EQUAL || filterOption === _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].NOT_CONTAINS;
  17468. }
  17469. var filterTextFormatted = this.formatter(filterText);
  17470. return this.comparator(filterOption, cellValueFormatted, filterTextFormatted);
  17471. };
  17472. TextFilter.FILTER_TYPE = 'text';
  17473. TextFilter.DEFAULT_FILTER_OPTIONS = [
  17474. _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].CONTAINS,
  17475. _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].NOT_CONTAINS,
  17476. _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].EQUALS,
  17477. _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].NOT_EQUAL,
  17478. _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].STARTS_WITH,
  17479. _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].ENDS_WITH
  17480. ];
  17481. TextFilter.DEFAULT_FORMATTER = function (from) { return from; };
  17482. TextFilter.DEFAULT_LOWERCASE_FORMATTER = function (from) {
  17483. return from == null ? null : from.toString().toLowerCase();
  17484. };
  17485. TextFilter.DEFAULT_COMPARATOR = function (filter, value, filterText) {
  17486. switch (filter) {
  17487. case TextFilter.CONTAINS:
  17488. return value.indexOf(filterText) >= 0;
  17489. case TextFilter.NOT_CONTAINS:
  17490. return value.indexOf(filterText) === -1;
  17491. case TextFilter.EQUALS:
  17492. return value === filterText;
  17493. case TextFilter.NOT_EQUAL:
  17494. return value != filterText;
  17495. case TextFilter.STARTS_WITH:
  17496. return value.indexOf(filterText) === 0;
  17497. case TextFilter.ENDS_WITH:
  17498. var index = value.lastIndexOf(filterText);
  17499. return index >= 0 && index === (value.length - filterText.length);
  17500. default:
  17501. // should never happen
  17502. console.warn('invalid filter type ' + filter);
  17503. return false;
  17504. }
  17505. };
  17506. __decorate([
  17507. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValue1')
  17508. ], TextFilter.prototype, "eValue1", void 0);
  17509. __decorate([
  17510. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eValue2')
  17511. ], TextFilter.prototype, "eValue2", void 0);
  17512. return TextFilter;
  17513. }(_simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"]));
  17514. /***/ }),
  17515. /* 91 */
  17516. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  17517. "use strict";
  17518. __webpack_require__.r(__webpack_exports__);
  17519. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "NumberFloatingFilter", function() { return NumberFloatingFilter; });
  17520. /* harmony import */ var _numberFilter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(83);
  17521. /* harmony import */ var _simpleFilter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(60);
  17522. /* harmony import */ var _floating_provided_textInputFloatingFilter__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(92);
  17523. /**
  17524. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  17525. * @version v23.2.1
  17526. * @link http://www.ag-grid.com/
  17527. * @license MIT
  17528. */
  17529. var __extends = (undefined && undefined.__extends) || (function () {
  17530. var extendStatics = function (d, b) {
  17531. extendStatics = Object.setPrototypeOf ||
  17532. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  17533. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  17534. return extendStatics(d, b);
  17535. };
  17536. return function (d, b) {
  17537. extendStatics(d, b);
  17538. function __() { this.constructor = d; }
  17539. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  17540. };
  17541. })();
  17542. var NumberFloatingFilter = /** @class */ (function (_super) {
  17543. __extends(NumberFloatingFilter, _super);
  17544. function NumberFloatingFilter() {
  17545. return _super !== null && _super.apply(this, arguments) || this;
  17546. }
  17547. NumberFloatingFilter.prototype.getDefaultFilterOptions = function () {
  17548. return _numberFilter__WEBPACK_IMPORTED_MODULE_0__["NumberFilter"].DEFAULT_FILTER_OPTIONS;
  17549. };
  17550. NumberFloatingFilter.prototype.conditionToString = function (condition) {
  17551. var isRange = condition.type == _simpleFilter__WEBPACK_IMPORTED_MODULE_1__["SimpleFilter"].IN_RANGE;
  17552. if (isRange) {
  17553. return condition.filter + "-" + condition.filterTo;
  17554. }
  17555. // cater for when the type doesn't need a value
  17556. if (condition.filter != null) {
  17557. return "" + condition.filter;
  17558. }
  17559. return "" + condition.type;
  17560. };
  17561. return NumberFloatingFilter;
  17562. }(_floating_provided_textInputFloatingFilter__WEBPACK_IMPORTED_MODULE_2__["TextInputFloatingFilter"]));
  17563. /***/ }),
  17564. /* 92 */
  17565. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  17566. "use strict";
  17567. __webpack_require__.r(__webpack_exports__);
  17568. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TextInputFloatingFilter", function() { return TextInputFloatingFilter; });
  17569. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57);
  17570. /* harmony import */ var _utils_function__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(21);
  17571. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25);
  17572. /* harmony import */ var _provided_providedFilter__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(62);
  17573. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(37);
  17574. /* harmony import */ var _simpleFloatingFilter__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(89);
  17575. /* harmony import */ var _utils_keyboard__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(24);
  17576. /**
  17577. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  17578. * @version v23.2.1
  17579. * @link http://www.ag-grid.com/
  17580. * @license MIT
  17581. */
  17582. var __extends = (undefined && undefined.__extends) || (function () {
  17583. var extendStatics = function (d, b) {
  17584. extendStatics = Object.setPrototypeOf ||
  17585. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  17586. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  17587. return extendStatics(d, b);
  17588. };
  17589. return function (d, b) {
  17590. extendStatics(d, b);
  17591. function __() { this.constructor = d; }
  17592. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  17593. };
  17594. })();
  17595. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  17596. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  17597. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  17598. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  17599. return c > 3 && r && Object.defineProperty(target, key, r), r;
  17600. };
  17601. var TextInputFloatingFilter = /** @class */ (function (_super) {
  17602. __extends(TextInputFloatingFilter, _super);
  17603. function TextInputFloatingFilter() {
  17604. return _super !== null && _super.apply(this, arguments) || this;
  17605. }
  17606. TextInputFloatingFilter.prototype.postConstruct = function () {
  17607. this.setTemplate(/* html */ "\n <div class=\"ag-floating-filter-input\" role=\"presentation\">\n <ag-input-text-field ref=\"eFloatingFilterInput\"></ag-input-text-field>\n </div>");
  17608. };
  17609. TextInputFloatingFilter.prototype.getDefaultDebounceMs = function () {
  17610. return 500;
  17611. };
  17612. TextInputFloatingFilter.prototype.onParentModelChanged = function (model, event) {
  17613. // we don't want to update the floating filter if the floating filter caused the change.
  17614. // as if it caused the change, the ui is already in sync. if we didn't do this, the UI
  17615. // would behave strange as it would be updating as the user is typing
  17616. if (this.isEventFromFloatingFilter(event)) {
  17617. return;
  17618. }
  17619. this.setLastTypeFromModel(model);
  17620. var modelString = this.getTextFromModel(model);
  17621. this.eFloatingFilterInput.setValue(modelString);
  17622. var editable = this.canWeEditAfterModelFromParentFilter(model);
  17623. this.setEditable(editable);
  17624. };
  17625. TextInputFloatingFilter.prototype.init = function (params) {
  17626. _super.prototype.init.call(this, params);
  17627. this.params = params;
  17628. this.applyActive = _provided_providedFilter__WEBPACK_IMPORTED_MODULE_3__["ProvidedFilter"].isUseApplyButton(this.params.filterParams);
  17629. var debounceMs = _provided_providedFilter__WEBPACK_IMPORTED_MODULE_3__["ProvidedFilter"].getDebounceMs(this.params.filterParams, this.getDefaultDebounceMs());
  17630. var toDebounce = Object(_utils_function__WEBPACK_IMPORTED_MODULE_1__["debounce"])(this.syncUpWithParentFilter.bind(this), debounceMs);
  17631. var filterGui = this.eFloatingFilterInput.getGui();
  17632. this.addManagedListener(filterGui, 'input', toDebounce);
  17633. this.addManagedListener(filterGui, 'keypress', toDebounce);
  17634. this.addManagedListener(filterGui, 'keydown', toDebounce);
  17635. var columnDef = params.column.getDefinition();
  17636. if (columnDef.filterParams &&
  17637. columnDef.filterParams.filterOptions &&
  17638. columnDef.filterParams.filterOptions.length === 1 &&
  17639. columnDef.filterParams.filterOptions[0] === 'inRange') {
  17640. this.eFloatingFilterInput.setDisabled(true);
  17641. }
  17642. var displayName = this.columnController.getDisplayNameForColumn(params.column, 'header', true);
  17643. this.eFloatingFilterInput.setInputAriaLabel(displayName + " Filter Input");
  17644. };
  17645. TextInputFloatingFilter.prototype.syncUpWithParentFilter = function (e) {
  17646. var _this = this;
  17647. var value = this.eFloatingFilterInput.getValue();
  17648. var enterKeyPressed = Object(_utils_keyboard__WEBPACK_IMPORTED_MODULE_6__["isKeyPressed"])(e, _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_ENTER);
  17649. if (this.applyActive && !enterKeyPressed) {
  17650. return;
  17651. }
  17652. this.params.parentFilterInstance(function (filterInstance) {
  17653. if (filterInstance) {
  17654. var simpleFilter = filterInstance;
  17655. simpleFilter.onFloatingFilterChanged(_this.getLastType(), value);
  17656. }
  17657. });
  17658. };
  17659. TextInputFloatingFilter.prototype.setEditable = function (editable) {
  17660. this.eFloatingFilterInput.setDisabled(!editable);
  17661. };
  17662. __decorate([
  17663. Object(_context_context__WEBPACK_IMPORTED_MODULE_4__["Autowired"])('columnController')
  17664. ], TextInputFloatingFilter.prototype, "columnController", void 0);
  17665. __decorate([
  17666. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eFloatingFilterInput')
  17667. ], TextInputFloatingFilter.prototype, "eFloatingFilterInput", void 0);
  17668. __decorate([
  17669. _context_context__WEBPACK_IMPORTED_MODULE_4__["PostConstruct"]
  17670. ], TextInputFloatingFilter.prototype, "postConstruct", null);
  17671. return TextInputFloatingFilter;
  17672. }(_simpleFloatingFilter__WEBPACK_IMPORTED_MODULE_5__["SimpleFloatingFilter"]));
  17673. /***/ }),
  17674. /* 93 */
  17675. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  17676. "use strict";
  17677. __webpack_require__.r(__webpack_exports__);
  17678. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TextFloatingFilter", function() { return TextFloatingFilter; });
  17679. /* harmony import */ var _textFilter__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(90);
  17680. /* harmony import */ var _floating_provided_textInputFloatingFilter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(92);
  17681. /**
  17682. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  17683. * @version v23.2.1
  17684. * @link http://www.ag-grid.com/
  17685. * @license MIT
  17686. */
  17687. var __extends = (undefined && undefined.__extends) || (function () {
  17688. var extendStatics = function (d, b) {
  17689. extendStatics = Object.setPrototypeOf ||
  17690. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  17691. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  17692. return extendStatics(d, b);
  17693. };
  17694. return function (d, b) {
  17695. extendStatics(d, b);
  17696. function __() { this.constructor = d; }
  17697. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  17698. };
  17699. })();
  17700. var TextFloatingFilter = /** @class */ (function (_super) {
  17701. __extends(TextFloatingFilter, _super);
  17702. function TextFloatingFilter() {
  17703. return _super !== null && _super.apply(this, arguments) || this;
  17704. }
  17705. TextFloatingFilter.prototype.conditionToString = function (condition) {
  17706. // it's not possible to have 'in range' for string, so no need to check for it.
  17707. // also cater for when the type doesn't need a value
  17708. if (condition.filter != null) {
  17709. return "" + condition.filter;
  17710. }
  17711. else {
  17712. return "" + condition.type;
  17713. }
  17714. };
  17715. TextFloatingFilter.prototype.getDefaultFilterOptions = function () {
  17716. return _textFilter__WEBPACK_IMPORTED_MODULE_0__["TextFilter"].DEFAULT_FILTER_OPTIONS;
  17717. };
  17718. return TextFloatingFilter;
  17719. }(_floating_provided_textInputFloatingFilter__WEBPACK_IMPORTED_MODULE_1__["TextInputFloatingFilter"]));
  17720. /***/ }),
  17721. /* 94 */
  17722. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  17723. "use strict";
  17724. __webpack_require__.r(__webpack_exports__);
  17725. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "initialiseAgGridWithAngular1", function() { return initialiseAgGridWithAngular1; });
  17726. /* harmony import */ var _grid__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(95);
  17727. /**
  17728. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  17729. * @version v23.2.1
  17730. * @link http://www.ag-grid.com/
  17731. * @license MIT
  17732. */
  17733. function initialiseAgGridWithAngular1(angular) {
  17734. var angularModule = angular.module("agGrid", []);
  17735. angularModule.directive("agGrid", function () {
  17736. return {
  17737. restrict: "A",
  17738. controller: ['$element', '$scope', '$compile', '$attrs', AngularDirectiveController],
  17739. scope: true
  17740. };
  17741. });
  17742. }
  17743. function AngularDirectiveController($element, $scope, $compile, $attrs) {
  17744. var gridOptions;
  17745. var quickFilterOnScope;
  17746. var keyOfGridInScope = $attrs.agGrid;
  17747. quickFilterOnScope = keyOfGridInScope + '.quickFilterText';
  17748. gridOptions = $scope.$eval(keyOfGridInScope);
  17749. if (!gridOptions) {
  17750. console.warn("WARNING - grid options for ag-Grid not found. Please ensure the attribute ag-grid points to a valid object on the scope");
  17751. return;
  17752. }
  17753. var eGridDiv = $element[0];
  17754. var gridParams = {
  17755. $scope: $scope,
  17756. $compile: $compile,
  17757. quickFilterOnScope: quickFilterOnScope
  17758. };
  17759. var grid = new _grid__WEBPACK_IMPORTED_MODULE_0__["Grid"](eGridDiv, gridOptions, gridParams);
  17760. $scope.$on("$destroy", function () {
  17761. grid.destroy();
  17762. grid = null;
  17763. });
  17764. }
  17765. /***/ }),
  17766. /* 95 */
  17767. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  17768. "use strict";
  17769. __webpack_require__.r(__webpack_exports__);
  17770. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Grid", function() { return Grid; });
  17771. /* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(50);
  17772. /* harmony import */ var _selectionController__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(96);
  17773. /* harmony import */ var _columnController_columnApi__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(98);
  17774. /* harmony import */ var _columnController_columnController__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(42);
  17775. /* harmony import */ var _rendering_rowRenderer__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(99);
  17776. /* harmony import */ var _headerRendering_headerRootComp__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(108);
  17777. /* harmony import */ var _filter_filterManager__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(125);
  17778. /* harmony import */ var _valueService_valueService__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(126);
  17779. /* harmony import */ var _eventService__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(36);
  17780. /* harmony import */ var _gridPanel_gridPanel__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(127);
  17781. /* harmony import */ var _gridApi__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(130);
  17782. /* harmony import */ var _columnController_columnFactory__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(5);
  17783. /* harmony import */ var _columnController_displayedGroupCreator__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(47);
  17784. /* harmony import */ var _valueService_expressionService__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(131);
  17785. /* harmony import */ var _templateService__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(132);
  17786. /* harmony import */ var _widgets_popupService__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(133);
  17787. /* harmony import */ var _logger__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(134);
  17788. /* harmony import */ var _columnController_columnUtils__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(46);
  17789. /* harmony import */ var _rendering_autoWidthCalculator__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(135);
  17790. /* harmony import */ var _headerRendering_horizontalResizeService__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(136);
  17791. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(37);
  17792. /* harmony import */ var _gridCore__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(137);
  17793. /* harmony import */ var _headerRendering_standardMenu__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(138);
  17794. /* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(104);
  17795. /* harmony import */ var _dragAndDrop_dragService__WEBPACK_IMPORTED_MODULE_24__ = __webpack_require__(139);
  17796. /* harmony import */ var _sortController__WEBPACK_IMPORTED_MODULE_25__ = __webpack_require__(140);
  17797. /* harmony import */ var _focusController__WEBPACK_IMPORTED_MODULE_26__ = __webpack_require__(141);
  17798. /* harmony import */ var _gridPanel_mouseEventService__WEBPACK_IMPORTED_MODULE_27__ = __webpack_require__(142);
  17799. /* harmony import */ var _cellNavigationService__WEBPACK_IMPORTED_MODULE_28__ = __webpack_require__(143);
  17800. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_29__ = __webpack_require__(43);
  17801. /* harmony import */ var _rendering_cellRendererFactory__WEBPACK_IMPORTED_MODULE_30__ = __webpack_require__(144);
  17802. /* harmony import */ var _rendering_valueFormatterService__WEBPACK_IMPORTED_MODULE_31__ = __webpack_require__(145);
  17803. /* harmony import */ var _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_32__ = __webpack_require__(70);
  17804. /* harmony import */ var _widgets_agRadioButton__WEBPACK_IMPORTED_MODULE_33__ = __webpack_require__(146);
  17805. /* harmony import */ var _vanillaFrameworkOverrides__WEBPACK_IMPORTED_MODULE_34__ = __webpack_require__(147);
  17806. /* harmony import */ var _gridPanel_scrollVisibleService__WEBPACK_IMPORTED_MODULE_35__ = __webpack_require__(148);
  17807. /* harmony import */ var _styling_stylingService__WEBPACK_IMPORTED_MODULE_36__ = __webpack_require__(149);
  17808. /* harmony import */ var _rendering_columnHoverService__WEBPACK_IMPORTED_MODULE_37__ = __webpack_require__(150);
  17809. /* harmony import */ var _rendering_columnAnimationService__WEBPACK_IMPORTED_MODULE_38__ = __webpack_require__(151);
  17810. /* harmony import */ var _columnController_autoGroupColService__WEBPACK_IMPORTED_MODULE_39__ = __webpack_require__(152);
  17811. /* harmony import */ var _pagination_paginationProxy__WEBPACK_IMPORTED_MODULE_40__ = __webpack_require__(153);
  17812. /* harmony import */ var _pagination_paginationAutoPageSizeService__WEBPACK_IMPORTED_MODULE_41__ = __webpack_require__(154);
  17813. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_42__ = __webpack_require__(25);
  17814. /* harmony import */ var _valueService_valueCache__WEBPACK_IMPORTED_MODULE_43__ = __webpack_require__(155);
  17815. /* harmony import */ var _valueService_changeDetectionService__WEBPACK_IMPORTED_MODULE_44__ = __webpack_require__(156);
  17816. /* harmony import */ var _alignedGridsService__WEBPACK_IMPORTED_MODULE_45__ = __webpack_require__(157);
  17817. /* harmony import */ var _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_46__ = __webpack_require__(74);
  17818. /* harmony import */ var _components_framework_userComponentRegistry__WEBPACK_IMPORTED_MODULE_47__ = __webpack_require__(53);
  17819. /* harmony import */ var _components_framework_agComponentUtils__WEBPACK_IMPORTED_MODULE_48__ = __webpack_require__(158);
  17820. /* harmony import */ var _components_framework_componentMetadataProvider__WEBPACK_IMPORTED_MODULE_49__ = __webpack_require__(159);
  17821. /* harmony import */ var _rendering_beans__WEBPACK_IMPORTED_MODULE_50__ = __webpack_require__(160);
  17822. /* harmony import */ var _environment__WEBPACK_IMPORTED_MODULE_51__ = __webpack_require__(161);
  17823. /* harmony import */ var _misc_animationFrameService__WEBPACK_IMPORTED_MODULE_52__ = __webpack_require__(162);
  17824. /* harmony import */ var _gridPanel_navigationService__WEBPACK_IMPORTED_MODULE_53__ = __webpack_require__(163);
  17825. /* harmony import */ var _rendering_maxDivHeightScaler__WEBPACK_IMPORTED_MODULE_54__ = __webpack_require__(164);
  17826. /* harmony import */ var _rowNodes_selectableService__WEBPACK_IMPORTED_MODULE_55__ = __webpack_require__(165);
  17827. /* harmony import */ var _rendering_autoHeightCalculator__WEBPACK_IMPORTED_MODULE_56__ = __webpack_require__(166);
  17828. /* harmony import */ var _pagination_paginationComp__WEBPACK_IMPORTED_MODULE_57__ = __webpack_require__(167);
  17829. /* harmony import */ var _misc_resizeObserverService__WEBPACK_IMPORTED_MODULE_58__ = __webpack_require__(168);
  17830. /* harmony import */ var _rendering_overlays_overlayWrapperComponent__WEBPACK_IMPORTED_MODULE_59__ = __webpack_require__(169);
  17831. /* harmony import */ var _widgets_agGroupComponent__WEBPACK_IMPORTED_MODULE_60__ = __webpack_require__(170);
  17832. /* harmony import */ var _widgets_agDialog__WEBPACK_IMPORTED_MODULE_61__ = __webpack_require__(171);
  17833. /* harmony import */ var _widgets_agPanel__WEBPACK_IMPORTED_MODULE_62__ = __webpack_require__(172);
  17834. /* harmony import */ var _widgets_agInputTextField__WEBPACK_IMPORTED_MODULE_63__ = __webpack_require__(173);
  17835. /* harmony import */ var _widgets_agInputTextArea__WEBPACK_IMPORTED_MODULE_64__ = __webpack_require__(174);
  17836. /* harmony import */ var _widgets_agSlider__WEBPACK_IMPORTED_MODULE_65__ = __webpack_require__(175);
  17837. /* harmony import */ var _widgets_agColorPicker__WEBPACK_IMPORTED_MODULE_66__ = __webpack_require__(176);
  17838. /* harmony import */ var _widgets_agInputNumberField__WEBPACK_IMPORTED_MODULE_67__ = __webpack_require__(179);
  17839. /* harmony import */ var _widgets_agInputRange__WEBPACK_IMPORTED_MODULE_68__ = __webpack_require__(180);
  17840. /* harmony import */ var _widgets_agSelect__WEBPACK_IMPORTED_MODULE_69__ = __webpack_require__(181);
  17841. /* harmony import */ var _widgets_agAngleSelect__WEBPACK_IMPORTED_MODULE_70__ = __webpack_require__(183);
  17842. /* harmony import */ var _widgets_agToggleButton__WEBPACK_IMPORTED_MODULE_71__ = __webpack_require__(184);
  17843. /* harmony import */ var _rendering_detailRowCompCache__WEBPACK_IMPORTED_MODULE_72__ = __webpack_require__(185);
  17844. /* harmony import */ var _entities_rowPosition__WEBPACK_IMPORTED_MODULE_73__ = __webpack_require__(186);
  17845. /* harmony import */ var _entities_cellPosition__WEBPACK_IMPORTED_MODULE_74__ = __webpack_require__(187);
  17846. /* harmony import */ var _pinnedRowModel_pinnedRowModel__WEBPACK_IMPORTED_MODULE_75__ = __webpack_require__(188);
  17847. /* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_76__ = __webpack_require__(39);
  17848. /* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_77__ = __webpack_require__(38);
  17849. /* harmony import */ var _undoRedo_undoRedoService__WEBPACK_IMPORTED_MODULE_78__ = __webpack_require__(189);
  17850. /* harmony import */ var _components_agStackComponentsRegistry__WEBPACK_IMPORTED_MODULE_79__ = __webpack_require__(191);
  17851. /* harmony import */ var _headerRendering_header_headerPosition__WEBPACK_IMPORTED_MODULE_80__ = __webpack_require__(192);
  17852. /* harmony import */ var _headerRendering_header_headerNavigationService__WEBPACK_IMPORTED_MODULE_81__ = __webpack_require__(124);
  17853. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_82__ = __webpack_require__(7);
  17854. /**
  17855. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  17856. * @version v23.2.1
  17857. * @link http://www.ag-grid.com/
  17858. * @license MIT
  17859. */
  17860. var Grid = /** @class */ (function () {
  17861. function Grid(eGridDiv, gridOptions, params) {
  17862. if (!eGridDiv) {
  17863. console.error('ag-Grid: no div element provided to the grid');
  17864. return;
  17865. }
  17866. if (!gridOptions) {
  17867. console.error('ag-Grid: no gridOptions provided to the grid');
  17868. return;
  17869. }
  17870. var debug = !!gridOptions.debug;
  17871. this.gridOptions = gridOptions;
  17872. var registeredModules = this.getRegisteredModules(params);
  17873. var beanClasses = this.createBeansList(registeredModules);
  17874. var providedBeanInstances = this.createProvidedBeans(eGridDiv, params);
  17875. if (!beanClasses) {
  17876. return;
  17877. } // happens when no row model found
  17878. var contextParams = {
  17879. providedBeanInstances: providedBeanInstances,
  17880. beanClasses: beanClasses,
  17881. debug: debug
  17882. };
  17883. this.logger = new _logger__WEBPACK_IMPORTED_MODULE_16__["Logger"]('ag-Grid', function () { return gridOptions.debug; });
  17884. var contextLogger = new _logger__WEBPACK_IMPORTED_MODULE_16__["Logger"]('Context', function () { return contextParams.debug; });
  17885. this.context = new _context_context__WEBPACK_IMPORTED_MODULE_20__["Context"](contextParams, contextLogger);
  17886. this.registerModuleUserComponents(registeredModules);
  17887. this.registerStackComponents(registeredModules);
  17888. var gridCoreClass = (params && params.rootComponent) || _gridCore__WEBPACK_IMPORTED_MODULE_21__["GridCore"];
  17889. var gridCore = new gridCoreClass();
  17890. this.context.createBean(gridCore);
  17891. this.setColumnsAndData();
  17892. this.dispatchGridReadyEvent(gridOptions);
  17893. var isEnterprise = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_76__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_77__["ModuleNames"].EnterpriseCoreModule);
  17894. this.logger.log("initialised successfully, enterprise = " + isEnterprise);
  17895. }
  17896. Grid.prototype.registerStackComponents = function (registeredModules) {
  17897. var agStackComponents = this.createAgStackComponentsList(registeredModules);
  17898. var agStackComponentsRegistry = this.context.getBean('agStackComponentsRegistry');
  17899. agStackComponentsRegistry.setupComponents(agStackComponents);
  17900. };
  17901. Grid.prototype.getRegisteredModules = function (params) {
  17902. var passedViaConstructor = params ? params.modules : null;
  17903. var registered = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_76__["ModuleRegistry"].getRegisteredModules();
  17904. var allModules = [];
  17905. var mapNames = {};
  17906. // adds to list and removes duplicates
  17907. function addModule(moduleBased, module) {
  17908. function addIndividualModule(module) {
  17909. if (!mapNames[module.moduleName]) {
  17910. mapNames[module.moduleName] = true;
  17911. allModules.push(module);
  17912. _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_76__["ModuleRegistry"].register(module, moduleBased);
  17913. }
  17914. }
  17915. addIndividualModule(module);
  17916. if (module.dependantModules) {
  17917. module.dependantModules.forEach(addModule.bind(null, moduleBased));
  17918. }
  17919. }
  17920. if (passedViaConstructor) {
  17921. passedViaConstructor.forEach(addModule.bind(null, true));
  17922. }
  17923. if (registered) {
  17924. registered.forEach(addModule.bind(null, !_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_76__["ModuleRegistry"].isPackageBased()));
  17925. }
  17926. return allModules;
  17927. };
  17928. Grid.prototype.registerModuleUserComponents = function (registeredModules) {
  17929. var userComponentRegistry = this.context.getBean('userComponentRegistry');
  17930. var moduleUserComps = this.extractModuleEntity(registeredModules, function (module) { return module.userComponents ? module.userComponents : []; });
  17931. moduleUserComps.forEach(function (compMeta) {
  17932. userComponentRegistry.registerDefaultComponent(compMeta.componentName, compMeta.componentClass);
  17933. });
  17934. };
  17935. Grid.prototype.createProvidedBeans = function (eGridDiv, params) {
  17936. var frameworkOverrides = params ? params.frameworkOverrides : null;
  17937. if (_utils__WEBPACK_IMPORTED_MODULE_82__["_"].missing(frameworkOverrides)) {
  17938. frameworkOverrides = new _vanillaFrameworkOverrides__WEBPACK_IMPORTED_MODULE_34__["VanillaFrameworkOverrides"]();
  17939. }
  17940. var seed = {
  17941. gridOptions: this.gridOptions,
  17942. eGridDiv: eGridDiv,
  17943. $scope: params ? params.$scope : null,
  17944. $compile: params ? params.$compile : null,
  17945. quickFilterOnScope: params ? params.quickFilterOnScope : null,
  17946. globalEventListener: params ? params.globalEventListener : null,
  17947. frameworkOverrides: frameworkOverrides
  17948. };
  17949. if (params && params.providedBeanInstances) {
  17950. _utils__WEBPACK_IMPORTED_MODULE_82__["_"].assign(seed, params.providedBeanInstances);
  17951. }
  17952. return seed;
  17953. };
  17954. Grid.prototype.createAgStackComponentsList = function (registeredModules) {
  17955. var components = [
  17956. { componentName: 'AgCheckbox', componentClass: _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_32__["AgCheckbox"] },
  17957. { componentName: 'AgRadioButton', componentClass: _widgets_agRadioButton__WEBPACK_IMPORTED_MODULE_33__["AgRadioButton"] },
  17958. { componentName: 'AgToggleButton', componentClass: _widgets_agToggleButton__WEBPACK_IMPORTED_MODULE_71__["AgToggleButton"] },
  17959. { componentName: 'AgInputTextField', componentClass: _widgets_agInputTextField__WEBPACK_IMPORTED_MODULE_63__["AgInputTextField"] },
  17960. { componentName: 'AgInputTextArea', componentClass: _widgets_agInputTextArea__WEBPACK_IMPORTED_MODULE_64__["AgInputTextArea"] },
  17961. { componentName: 'AgInputNumberField', componentClass: _widgets_agInputNumberField__WEBPACK_IMPORTED_MODULE_67__["AgInputNumberField"] },
  17962. { componentName: 'AgInputRange', componentClass: _widgets_agInputRange__WEBPACK_IMPORTED_MODULE_68__["AgInputRange"] },
  17963. { componentName: 'AgSelect', componentClass: _widgets_agSelect__WEBPACK_IMPORTED_MODULE_69__["AgSelect"] },
  17964. { componentName: 'AgSlider', componentClass: _widgets_agSlider__WEBPACK_IMPORTED_MODULE_65__["AgSlider"] },
  17965. { componentName: 'AgAngleSelect', componentClass: _widgets_agAngleSelect__WEBPACK_IMPORTED_MODULE_70__["AgAngleSelect"] },
  17966. { componentName: 'AgColorPicker', componentClass: _widgets_agColorPicker__WEBPACK_IMPORTED_MODULE_66__["AgColorPicker"] },
  17967. { componentName: 'AgGridComp', componentClass: _gridPanel_gridPanel__WEBPACK_IMPORTED_MODULE_9__["GridPanel"] },
  17968. { componentName: 'AgHeaderRoot', componentClass: _headerRendering_headerRootComp__WEBPACK_IMPORTED_MODULE_5__["HeaderRootComp"] },
  17969. { componentName: 'AgPagination', componentClass: _pagination_paginationComp__WEBPACK_IMPORTED_MODULE_57__["PaginationComp"] },
  17970. { componentName: 'AgOverlayWrapper', componentClass: _rendering_overlays_overlayWrapperComponent__WEBPACK_IMPORTED_MODULE_59__["OverlayWrapperComponent"] },
  17971. { componentName: 'AgGroupComponent', componentClass: _widgets_agGroupComponent__WEBPACK_IMPORTED_MODULE_60__["AgGroupComponent"] },
  17972. { componentName: 'AgPanel', componentClass: _widgets_agPanel__WEBPACK_IMPORTED_MODULE_62__["AgPanel"] },
  17973. { componentName: 'AgDialog', componentClass: _widgets_agDialog__WEBPACK_IMPORTED_MODULE_61__["AgDialog"] }
  17974. ];
  17975. var moduleAgStackComps = this.extractModuleEntity(registeredModules, function (module) { return module.agStackComponents ? module.agStackComponents : []; });
  17976. components = components.concat(moduleAgStackComps);
  17977. return components;
  17978. };
  17979. Grid.prototype.createBeansList = function (registeredModules) {
  17980. var rowModelClass = this.getRowModelClass(registeredModules);
  17981. if (!rowModelClass) {
  17982. return undefined;
  17983. }
  17984. // beans should only contain SERVICES, it should NEVER contain COMPONENTS
  17985. var beans = [
  17986. rowModelClass, _rendering_beans__WEBPACK_IMPORTED_MODULE_50__["Beans"], _entities_rowPosition__WEBPACK_IMPORTED_MODULE_73__["RowPositionUtils"], _entities_cellPosition__WEBPACK_IMPORTED_MODULE_74__["CellPositionUtils"], _headerRendering_header_headerPosition__WEBPACK_IMPORTED_MODULE_80__["HeaderPositionUtils"],
  17987. _pagination_paginationAutoPageSizeService__WEBPACK_IMPORTED_MODULE_41__["PaginationAutoPageSizeService"], _gridApi__WEBPACK_IMPORTED_MODULE_10__["GridApi"], _components_framework_userComponentRegistry__WEBPACK_IMPORTED_MODULE_47__["UserComponentRegistry"], _components_framework_agComponentUtils__WEBPACK_IMPORTED_MODULE_48__["AgComponentUtils"],
  17988. _components_framework_componentMetadataProvider__WEBPACK_IMPORTED_MODULE_49__["ComponentMetadataProvider"], _misc_resizeObserverService__WEBPACK_IMPORTED_MODULE_58__["ResizeObserverService"], _components_framework_userComponentFactory__WEBPACK_IMPORTED_MODULE_46__["UserComponentFactory"],
  17989. _rendering_maxDivHeightScaler__WEBPACK_IMPORTED_MODULE_54__["MaxDivHeightScaler"], _rendering_autoHeightCalculator__WEBPACK_IMPORTED_MODULE_56__["AutoHeightCalculator"], _rendering_cellRendererFactory__WEBPACK_IMPORTED_MODULE_30__["CellRendererFactory"], _headerRendering_horizontalResizeService__WEBPACK_IMPORTED_MODULE_19__["HorizontalResizeService"],
  17990. _pinnedRowModel_pinnedRowModel__WEBPACK_IMPORTED_MODULE_75__["PinnedRowModel"], _dragAndDrop_dragService__WEBPACK_IMPORTED_MODULE_24__["DragService"], _columnController_displayedGroupCreator__WEBPACK_IMPORTED_MODULE_12__["DisplayedGroupCreator"], _eventService__WEBPACK_IMPORTED_MODULE_8__["EventService"], _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"],
  17991. _widgets_popupService__WEBPACK_IMPORTED_MODULE_15__["PopupService"], _selectionController__WEBPACK_IMPORTED_MODULE_1__["SelectionController"], _filter_filterManager__WEBPACK_IMPORTED_MODULE_6__["FilterManager"], _columnController_columnController__WEBPACK_IMPORTED_MODULE_3__["ColumnController"], _headerRendering_header_headerNavigationService__WEBPACK_IMPORTED_MODULE_81__["HeaderNavigationService"],
  17992. _pagination_paginationProxy__WEBPACK_IMPORTED_MODULE_40__["PaginationProxy"], _rendering_rowRenderer__WEBPACK_IMPORTED_MODULE_4__["RowRenderer"], _valueService_expressionService__WEBPACK_IMPORTED_MODULE_13__["ExpressionService"], _columnController_columnFactory__WEBPACK_IMPORTED_MODULE_11__["ColumnFactory"], _templateService__WEBPACK_IMPORTED_MODULE_14__["TemplateService"],
  17993. _alignedGridsService__WEBPACK_IMPORTED_MODULE_45__["AlignedGridsService"], _gridPanel_navigationService__WEBPACK_IMPORTED_MODULE_53__["NavigationService"], _valueService_valueCache__WEBPACK_IMPORTED_MODULE_43__["ValueCache"], _valueService_valueService__WEBPACK_IMPORTED_MODULE_7__["ValueService"], _logger__WEBPACK_IMPORTED_MODULE_16__["LoggerFactory"],
  17994. _columnController_columnUtils__WEBPACK_IMPORTED_MODULE_17__["ColumnUtils"], _rendering_autoWidthCalculator__WEBPACK_IMPORTED_MODULE_18__["AutoWidthCalculator"], _headerRendering_standardMenu__WEBPACK_IMPORTED_MODULE_22__["StandardMenuFactory"], _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_23__["DragAndDropService"], _columnController_columnApi__WEBPACK_IMPORTED_MODULE_2__["ColumnApi"],
  17995. _focusController__WEBPACK_IMPORTED_MODULE_26__["FocusController"], _gridPanel_mouseEventService__WEBPACK_IMPORTED_MODULE_27__["MouseEventService"], _environment__WEBPACK_IMPORTED_MODULE_51__["Environment"], _cellNavigationService__WEBPACK_IMPORTED_MODULE_28__["CellNavigationService"], _rendering_valueFormatterService__WEBPACK_IMPORTED_MODULE_31__["ValueFormatterService"],
  17996. _styling_stylingService__WEBPACK_IMPORTED_MODULE_36__["StylingService"], _gridPanel_scrollVisibleService__WEBPACK_IMPORTED_MODULE_35__["ScrollVisibleService"], _sortController__WEBPACK_IMPORTED_MODULE_25__["SortController"], _rendering_columnHoverService__WEBPACK_IMPORTED_MODULE_37__["ColumnHoverService"], _rendering_columnAnimationService__WEBPACK_IMPORTED_MODULE_38__["ColumnAnimationService"],
  17997. _rowNodes_selectableService__WEBPACK_IMPORTED_MODULE_55__["SelectableService"], _columnController_autoGroupColService__WEBPACK_IMPORTED_MODULE_39__["AutoGroupColService"], _valueService_changeDetectionService__WEBPACK_IMPORTED_MODULE_44__["ChangeDetectionService"], _misc_animationFrameService__WEBPACK_IMPORTED_MODULE_52__["AnimationFrameService"],
  17998. _rendering_detailRowCompCache__WEBPACK_IMPORTED_MODULE_72__["DetailRowCompCache"], _undoRedo_undoRedoService__WEBPACK_IMPORTED_MODULE_78__["UndoRedoService"], _components_agStackComponentsRegistry__WEBPACK_IMPORTED_MODULE_79__["AgStackComponentsRegistry"]
  17999. ];
  18000. var moduleBeans = this.extractModuleEntity(registeredModules, function (module) { return module.beans ? module.beans : []; });
  18001. beans.push.apply(beans, moduleBeans);
  18002. // check for duplicates, as different modules could include the same beans that
  18003. // they depend on, eg ClientSideRowModel in enterprise, and ClientSideRowModel in community
  18004. var beansNoDuplicates = [];
  18005. beans.forEach(function (bean) {
  18006. if (beansNoDuplicates.indexOf(bean) < 0) {
  18007. beansNoDuplicates.push(bean);
  18008. }
  18009. });
  18010. return beansNoDuplicates;
  18011. };
  18012. Grid.prototype.extractModuleEntity = function (moduleEntities, extractor) {
  18013. return [].concat.apply([], moduleEntities.map(extractor));
  18014. };
  18015. Grid.prototype.setColumnsAndData = function () {
  18016. var gridOptionsWrapper = this.context.getBean('gridOptionsWrapper');
  18017. var columnController = this.context.getBean('columnController');
  18018. var columnDefs = gridOptionsWrapper.getColumnDefs();
  18019. if (_utils__WEBPACK_IMPORTED_MODULE_82__["_"].exists(columnDefs)) {
  18020. columnController.setColumnDefs(columnDefs, "gridInitializing");
  18021. }
  18022. var rowModel = this.context.getBean('rowModel');
  18023. rowModel.start();
  18024. };
  18025. Grid.prototype.dispatchGridReadyEvent = function (gridOptions) {
  18026. var eventService = this.context.getBean('eventService');
  18027. var readyEvent = {
  18028. type: _events__WEBPACK_IMPORTED_MODULE_29__["Events"].EVENT_GRID_READY,
  18029. api: gridOptions.api,
  18030. columnApi: gridOptions.columnApi
  18031. };
  18032. eventService.dispatchEvent(readyEvent);
  18033. };
  18034. Grid.prototype.getRowModelClass = function (registeredModules) {
  18035. var rowModelType = this.gridOptions.rowModelType;
  18036. //TODO: temporary measure before 'enterprise' is completely removed (similar handling in gridOptionsWrapper is also required)
  18037. if (rowModelType === 'enterprise') {
  18038. console.warn("ag-Grid: enterprise rowModel deprecated. Should now be called server side row model instead.");
  18039. rowModelType = _constants__WEBPACK_IMPORTED_MODULE_42__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE;
  18040. }
  18041. if (rowModelType === 'normal') {
  18042. console.warn("ag-Grid: normal rowModel deprecated. Should now be called client side row model instead.");
  18043. rowModelType = _constants__WEBPACK_IMPORTED_MODULE_42__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE;
  18044. }
  18045. // default to client side
  18046. if (!rowModelType) {
  18047. rowModelType = _constants__WEBPACK_IMPORTED_MODULE_42__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE;
  18048. }
  18049. var rowModelClasses = {};
  18050. registeredModules.forEach(function (module) {
  18051. _utils__WEBPACK_IMPORTED_MODULE_82__["_"].iterateObject(module.rowModels, function (key, value) {
  18052. rowModelClasses[key] = value;
  18053. });
  18054. });
  18055. var rowModelClass = rowModelClasses[rowModelType];
  18056. if (_utils__WEBPACK_IMPORTED_MODULE_82__["_"].exists(rowModelClass)) {
  18057. return rowModelClass;
  18058. }
  18059. else {
  18060. if (rowModelType === _constants__WEBPACK_IMPORTED_MODULE_42__["Constants"].ROW_MODEL_TYPE_INFINITE) {
  18061. console.error("ag-Grid: Row Model \"Infinite\" not found. Please ensure the " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_77__["ModuleNames"].InfiniteRowModelModule + " is registered.';");
  18062. }
  18063. console.error('ag-Grid: could not find matching row model for rowModelType ' + rowModelType);
  18064. if (rowModelType === _constants__WEBPACK_IMPORTED_MODULE_42__["Constants"].ROW_MODEL_TYPE_VIEWPORT) {
  18065. console.error("ag-Grid: Row Model \"Viewport\" not found. Please ensure the ag-Grid Enterprise Module " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_77__["ModuleNames"].ViewportRowModelModule + " is registered.';");
  18066. }
  18067. if (rowModelType === _constants__WEBPACK_IMPORTED_MODULE_42__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE) {
  18068. console.error("ag-Grid: Row Model \"Server Side\" not found. Please ensure the ag-Grid Enterprise Module " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_77__["ModuleNames"].ServerSideRowModelModule + " is registered.';");
  18069. }
  18070. if (rowModelType === _constants__WEBPACK_IMPORTED_MODULE_42__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE) {
  18071. console.error("ag-Grid: Row Model \"Client Side\" not found. Please ensure the " + _modules_moduleNames__WEBPACK_IMPORTED_MODULE_77__["ModuleNames"].ClientSideRowModelModule + " is registered.';");
  18072. }
  18073. return undefined;
  18074. }
  18075. };
  18076. Grid.prototype.destroy = function () {
  18077. this.gridOptions.api.destroy();
  18078. };
  18079. return Grid;
  18080. }());
  18081. /***/ }),
  18082. /* 96 */
  18083. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  18084. "use strict";
  18085. __webpack_require__.r(__webpack_exports__);
  18086. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SelectionController", function() { return SelectionController; });
  18087. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  18088. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  18089. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43);
  18090. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25);
  18091. /* harmony import */ var _utils_changedPath__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(97);
  18092. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7);
  18093. /**
  18094. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  18095. * @version v23.2.1
  18096. * @link http://www.ag-grid.com/
  18097. * @license MIT
  18098. */
  18099. var __extends = (undefined && undefined.__extends) || (function () {
  18100. var extendStatics = function (d, b) {
  18101. extendStatics = Object.setPrototypeOf ||
  18102. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  18103. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  18104. return extendStatics(d, b);
  18105. };
  18106. return function (d, b) {
  18107. extendStatics(d, b);
  18108. function __() { this.constructor = d; }
  18109. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  18110. };
  18111. })();
  18112. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  18113. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  18114. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  18115. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  18116. return c > 3 && r && Object.defineProperty(target, key, r), r;
  18117. };
  18118. var __param = (undefined && undefined.__param) || function (paramIndex, decorator) {
  18119. return function (target, key) { decorator(target, key, paramIndex); }
  18120. };
  18121. var SelectionController = /** @class */ (function (_super) {
  18122. __extends(SelectionController, _super);
  18123. function SelectionController() {
  18124. return _super !== null && _super.apply(this, arguments) || this;
  18125. }
  18126. SelectionController.prototype.setBeans = function (loggerFactory) {
  18127. this.logger = loggerFactory.create('SelectionController');
  18128. this.reset();
  18129. if (this.gridOptionsWrapper.isRowModelDefault()) {
  18130. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DATA_CHANGED, this.reset.bind(this));
  18131. }
  18132. };
  18133. SelectionController.prototype.init = function () {
  18134. this.groupSelectsChildren = this.gridOptionsWrapper.isGroupSelectsChildren();
  18135. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_SELECTED, this.onRowSelected.bind(this));
  18136. };
  18137. SelectionController.prototype.setLastSelectedNode = function (rowNode) {
  18138. this.lastSelectedNode = rowNode;
  18139. };
  18140. SelectionController.prototype.getLastSelectedNode = function () {
  18141. return this.lastSelectedNode;
  18142. };
  18143. SelectionController.prototype.getSelectedNodes = function () {
  18144. var selectedNodes = [];
  18145. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].iterateObject(this.selectedNodes, function (key, rowNode) {
  18146. if (rowNode) {
  18147. selectedNodes.push(rowNode);
  18148. }
  18149. });
  18150. return selectedNodes;
  18151. };
  18152. SelectionController.prototype.getSelectedRows = function () {
  18153. var selectedRows = [];
  18154. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].iterateObject(this.selectedNodes, function (key, rowNode) {
  18155. if (rowNode && rowNode.data) {
  18156. selectedRows.push(rowNode.data);
  18157. }
  18158. });
  18159. return selectedRows;
  18160. };
  18161. SelectionController.prototype.removeGroupsFromSelection = function () {
  18162. var _this = this;
  18163. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].iterateObject(this.selectedNodes, function (key, rowNode) {
  18164. if (rowNode && rowNode.group) {
  18165. _this.selectedNodes[rowNode.id] = undefined;
  18166. }
  18167. });
  18168. };
  18169. // should only be called if groupSelectsChildren=true
  18170. SelectionController.prototype.updateGroupsFromChildrenSelections = function (changedPath) {
  18171. // we only do this when group selection state depends on selected children
  18172. if (!this.gridOptionsWrapper.isGroupSelectsChildren()) {
  18173. return;
  18174. }
  18175. // also only do it if CSRM (code should never allow this anyway)
  18176. if (this.rowModel.getType() !== _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE) {
  18177. return;
  18178. }
  18179. var clientSideRowModel = this.rowModel;
  18180. var rootNode = clientSideRowModel.getRootNode();
  18181. if (!changedPath) {
  18182. changedPath = new _utils_changedPath__WEBPACK_IMPORTED_MODULE_4__["ChangedPath"](true, rootNode);
  18183. changedPath.setInactive();
  18184. }
  18185. changedPath.forEachChangedNodeDepthFirst(function (rowNode) {
  18186. if (rowNode !== rootNode) {
  18187. rowNode.calculateSelectedFromChildren();
  18188. }
  18189. });
  18190. // clientSideRowModel.getTopLevelNodes()!.forEach((rowNode: RowNode) => {
  18191. // rowNode.depthFirstSearch((node) => {
  18192. // if (node.group) {
  18193. // }
  18194. // });
  18195. // });
  18196. };
  18197. SelectionController.prototype.getNodeForIdIfSelected = function (id) {
  18198. return this.selectedNodes[id];
  18199. };
  18200. SelectionController.prototype.clearOtherNodes = function (rowNodeToKeepSelected) {
  18201. var _this = this;
  18202. var groupsToRefresh = {};
  18203. var updatedCount = 0;
  18204. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].iterateObject(this.selectedNodes, function (key, otherRowNode) {
  18205. if (otherRowNode && otherRowNode.id !== rowNodeToKeepSelected.id) {
  18206. var rowNode = _this.selectedNodes[otherRowNode.id];
  18207. updatedCount += rowNode.setSelectedParams({
  18208. newValue: false,
  18209. clearSelection: false,
  18210. suppressFinishActions: true
  18211. });
  18212. if (_this.groupSelectsChildren && otherRowNode.parent) {
  18213. groupsToRefresh[otherRowNode.parent.id] = otherRowNode.parent;
  18214. }
  18215. }
  18216. });
  18217. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].iterateObject(groupsToRefresh, function (key, group) {
  18218. group.calculateSelectedFromChildren();
  18219. });
  18220. return updatedCount;
  18221. };
  18222. SelectionController.prototype.onRowSelected = function (event) {
  18223. var rowNode = event.node;
  18224. // we do not store the group rows when the groups select children
  18225. if (this.groupSelectsChildren && rowNode.group) {
  18226. return;
  18227. }
  18228. if (rowNode.isSelected()) {
  18229. this.selectedNodes[rowNode.id] = rowNode;
  18230. }
  18231. else {
  18232. this.selectedNodes[rowNode.id] = undefined;
  18233. }
  18234. };
  18235. SelectionController.prototype.syncInRowNode = function (rowNode, oldNode) {
  18236. this.syncInOldRowNode(rowNode, oldNode);
  18237. this.syncInNewRowNode(rowNode);
  18238. };
  18239. // if the id has changed for the node, then this means the rowNode
  18240. // is getting used for a different data item, which breaks
  18241. // our selectedNodes, as the node now is mapped by the old id
  18242. // which is inconsistent. so to keep the old node as selected,
  18243. // we swap in the clone (with the old id and old data). this means
  18244. // the oldNode is effectively a daemon we keep a reference to,
  18245. // so if client calls api.getSelectedNodes(), it gets the daemon
  18246. // in the result. when the client un-selects, the reference to the
  18247. // daemon is removed. the daemon, because it's an oldNode, is not
  18248. // used by the grid for rendering, it's a copy of what the node used
  18249. // to be like before the id was changed.
  18250. SelectionController.prototype.syncInOldRowNode = function (rowNode, oldNode) {
  18251. var oldNodeHasDifferentId = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(oldNode) && (rowNode.id !== oldNode.id);
  18252. if (oldNodeHasDifferentId) {
  18253. var oldNodeSelected = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(this.selectedNodes[oldNode.id]);
  18254. if (oldNodeSelected) {
  18255. this.selectedNodes[oldNode.id] = oldNode;
  18256. }
  18257. }
  18258. };
  18259. SelectionController.prototype.syncInNewRowNode = function (rowNode) {
  18260. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(this.selectedNodes[rowNode.id])) {
  18261. rowNode.setSelectedInitialValue(true);
  18262. this.selectedNodes[rowNode.id] = rowNode;
  18263. }
  18264. else {
  18265. rowNode.setSelectedInitialValue(false);
  18266. }
  18267. };
  18268. SelectionController.prototype.reset = function () {
  18269. this.logger.log('reset');
  18270. this.selectedNodes = {};
  18271. this.lastSelectedNode = null;
  18272. };
  18273. // returns a list of all nodes at 'best cost' - a feature to be used
  18274. // with groups / trees. if a group has all it's children selected,
  18275. // then the group appears in the result, but not the children.
  18276. // Designed for use with 'children' as the group selection type,
  18277. // where groups don't actually appear in the selection normally.
  18278. SelectionController.prototype.getBestCostNodeSelection = function () {
  18279. if (this.rowModel.getType() !== _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE) {
  18280. console.warn('getBestCostNodeSelection is only available when using normal row model');
  18281. return;
  18282. }
  18283. var clientSideRowModel = this.rowModel;
  18284. var topLevelNodes = clientSideRowModel.getTopLevelNodes();
  18285. if (topLevelNodes === null) {
  18286. console.warn('selectAll not available doing rowModel=virtual');
  18287. return;
  18288. }
  18289. var result = [];
  18290. // recursive function, to find the selected nodes
  18291. function traverse(nodes) {
  18292. for (var i = 0, l = nodes.length; i < l; i++) {
  18293. var node = nodes[i];
  18294. if (node.isSelected()) {
  18295. result.push(node);
  18296. }
  18297. else {
  18298. // if not selected, then if it's a group, and the group
  18299. // has children, continue to search for selections
  18300. if (node.group && node.children) {
  18301. traverse(node.children);
  18302. }
  18303. }
  18304. }
  18305. }
  18306. traverse(topLevelNodes);
  18307. return result;
  18308. };
  18309. SelectionController.prototype.setRowModel = function (rowModel) {
  18310. this.rowModel = rowModel;
  18311. };
  18312. SelectionController.prototype.isEmpty = function () {
  18313. var count = 0;
  18314. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].iterateObject(this.selectedNodes, function (nodeId, rowNode) {
  18315. if (rowNode) {
  18316. count++;
  18317. }
  18318. });
  18319. return count === 0;
  18320. };
  18321. SelectionController.prototype.deselectAllRowNodes = function (justFiltered) {
  18322. if (justFiltered === void 0) { justFiltered = false; }
  18323. var callback = function (rowNode) { return rowNode.selectThisNode(false); };
  18324. var rowModelClientSide = this.rowModel.getType() === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE;
  18325. if (justFiltered) {
  18326. if (!rowModelClientSide) {
  18327. console.error('ag-Grid: selecting just filtered only works with In Memory Row Model');
  18328. return;
  18329. }
  18330. var clientSideRowModel = this.rowModel;
  18331. clientSideRowModel.forEachNodeAfterFilter(callback);
  18332. }
  18333. else {
  18334. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].iterateObject(this.selectedNodes, function (id, rowNode) {
  18335. // remember the reference can be to null, as we never 'delete' from the map
  18336. if (rowNode) {
  18337. callback(rowNode);
  18338. }
  18339. });
  18340. // this clears down the map (whereas above only sets the items in map to 'undefined')
  18341. this.reset();
  18342. }
  18343. // the above does not clean up the parent rows if they are selected
  18344. if (rowModelClientSide && this.groupSelectsChildren) {
  18345. this.updateGroupsFromChildrenSelections();
  18346. }
  18347. var event = {
  18348. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_SELECTION_CHANGED,
  18349. api: this.gridApi,
  18350. columnApi: this.columnApi
  18351. };
  18352. this.eventService.dispatchEvent(event);
  18353. };
  18354. SelectionController.prototype.selectAllRowNodes = function (justFiltered) {
  18355. if (justFiltered === void 0) { justFiltered = false; }
  18356. if (this.rowModel.getType() !== _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE) {
  18357. throw new Error("selectAll only available with normal row model, ie not " + this.rowModel.getType());
  18358. }
  18359. var clientSideRowModel = this.rowModel;
  18360. var callback = function (rowNode) { return rowNode.selectThisNode(true); };
  18361. if (justFiltered) {
  18362. clientSideRowModel.forEachNodeAfterFilter(callback);
  18363. }
  18364. else {
  18365. clientSideRowModel.forEachNode(callback);
  18366. }
  18367. // the above does not clean up the parent rows if they are selected
  18368. if (this.rowModel.getType() === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE && this.groupSelectsChildren) {
  18369. this.updateGroupsFromChildrenSelections();
  18370. }
  18371. var event = {
  18372. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_SELECTION_CHANGED,
  18373. api: this.gridApi,
  18374. columnApi: this.columnApi
  18375. };
  18376. this.eventService.dispatchEvent(event);
  18377. };
  18378. /**
  18379. * @method
  18380. * @deprecated
  18381. */
  18382. SelectionController.prototype.selectNode = function (rowNode, tryMulti) {
  18383. if (rowNode) {
  18384. rowNode.setSelectedParams({ newValue: true, clearSelection: !tryMulti });
  18385. }
  18386. };
  18387. /**
  18388. * @method
  18389. * @deprecated
  18390. */
  18391. SelectionController.prototype.deselectIndex = function (rowIndex) {
  18392. var node = this.rowModel.getRow(rowIndex);
  18393. this.deselectNode(node);
  18394. };
  18395. /**
  18396. * @method
  18397. * @deprecated
  18398. */
  18399. SelectionController.prototype.deselectNode = function (rowNode) {
  18400. if (rowNode) {
  18401. rowNode.setSelectedParams({ newValue: false, clearSelection: false });
  18402. }
  18403. };
  18404. /**
  18405. * @method
  18406. * @deprecated
  18407. */
  18408. SelectionController.prototype.selectIndex = function (index, tryMulti) {
  18409. var node = this.rowModel.getRow(index);
  18410. this.selectNode(node, tryMulti);
  18411. };
  18412. __decorate([
  18413. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel')
  18414. ], SelectionController.prototype, "rowModel", void 0);
  18415. __decorate([
  18416. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  18417. ], SelectionController.prototype, "gridOptionsWrapper", void 0);
  18418. __decorate([
  18419. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi')
  18420. ], SelectionController.prototype, "columnApi", void 0);
  18421. __decorate([
  18422. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi')
  18423. ], SelectionController.prototype, "gridApi", void 0);
  18424. __decorate([
  18425. __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('loggerFactory'))
  18426. ], SelectionController.prototype, "setBeans", null);
  18427. __decorate([
  18428. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  18429. ], SelectionController.prototype, "init", null);
  18430. SelectionController = __decorate([
  18431. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('selectionController')
  18432. ], SelectionController);
  18433. return SelectionController;
  18434. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  18435. /***/ }),
  18436. /* 97 */
  18437. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  18438. "use strict";
  18439. __webpack_require__.r(__webpack_exports__);
  18440. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ChangedPath", function() { return ChangedPath; });
  18441. /**
  18442. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  18443. * @version v23.2.1
  18444. * @link http://www.ag-grid.com/
  18445. * @license MIT
  18446. */
  18447. // when doing transactions, or change detection, and grouping is present
  18448. // in the data, there is no need for the ClientSideRowModel to update each
  18449. // group after an update, ony parts that were impacted by the change.
  18450. // this class keeps track of all groups that were impacted by a transaction.
  18451. // the the different CSRM operations (filter, sort etc) use the forEach method
  18452. // to visit each group that was changed.
  18453. var ChangedPath = /** @class */ (function () {
  18454. function ChangedPath(keepingColumns, rootNode) {
  18455. // whether changed path is active of not. it is active when a) doing
  18456. // a transaction update or b) doing change detection. if we are doing
  18457. // a CSRM refresh for other reasons (after sort or filter, or user calling
  18458. // setRowData() without delta mode) then we are not active. we are also
  18459. // marked as not active if secondary columns change in pivot (as this impacts
  18460. // aggregations)
  18461. this.active = true;
  18462. // for each node in the change path, we also store which columns need
  18463. // to be re-aggregated.
  18464. this.nodeIdsToColumns = {};
  18465. // for quick lookup, all items in the change path are mapped by nodeId
  18466. this.mapToItems = {};
  18467. this.keepingColumns = keepingColumns;
  18468. this.pathRoot = {
  18469. rowNode: rootNode,
  18470. children: null
  18471. };
  18472. this.mapToItems[rootNode.id] = this.pathRoot;
  18473. }
  18474. // can be set inactive by:
  18475. // a) ClientSideRowModel, if no transactions or
  18476. // b) PivotService, if secondary columns changed
  18477. ChangedPath.prototype.setInactive = function () {
  18478. this.active = false;
  18479. };
  18480. ChangedPath.prototype.isActive = function () {
  18481. return this.active;
  18482. };
  18483. ChangedPath.prototype.depthFirstSearchChangedPath = function (pathItem, callback) {
  18484. if (pathItem.children) {
  18485. for (var i = 0; i < pathItem.children.length; i++) {
  18486. this.depthFirstSearchChangedPath(pathItem.children[i], callback);
  18487. }
  18488. }
  18489. callback(pathItem.rowNode);
  18490. };
  18491. ChangedPath.prototype.depthFirstSearchEverything = function (rowNode, callback, traverseEverything) {
  18492. if (rowNode.childrenAfterGroup) {
  18493. for (var i = 0; i < rowNode.childrenAfterGroup.length; i++) {
  18494. var childNode = rowNode.childrenAfterGroup[i];
  18495. if (childNode.childrenAfterGroup) {
  18496. this.depthFirstSearchEverything(rowNode.childrenAfterGroup[i], callback, traverseEverything);
  18497. }
  18498. else if (traverseEverything) {
  18499. callback(childNode);
  18500. }
  18501. }
  18502. }
  18503. callback(rowNode);
  18504. };
  18505. // traverseLeafNodes -> used when NOT doing changed path, ie traversing everything. the callback
  18506. // will be called for child nodes in addition to parent nodes.
  18507. ChangedPath.prototype.forEachChangedNodeDepthFirst = function (callback, traverseLeafNodes) {
  18508. if (traverseLeafNodes === void 0) { traverseLeafNodes = false; }
  18509. if (this.active) {
  18510. // if we are active, then use the change path to callback
  18511. // only for updated groups
  18512. this.depthFirstSearchChangedPath(this.pathRoot, callback);
  18513. }
  18514. else {
  18515. // we are not active, so callback for everything, walk the entire path
  18516. this.depthFirstSearchEverything(this.pathRoot.rowNode, callback, traverseLeafNodes);
  18517. }
  18518. };
  18519. ChangedPath.prototype.executeFromRootNode = function (callback) {
  18520. callback(this.pathRoot.rowNode);
  18521. };
  18522. ChangedPath.prototype.createPathItems = function (rowNode) {
  18523. var pointer = rowNode;
  18524. var newEntryCount = 0;
  18525. while (!this.mapToItems[pointer.id]) {
  18526. var newEntry = {
  18527. rowNode: pointer,
  18528. children: null
  18529. };
  18530. this.mapToItems[pointer.id] = newEntry;
  18531. newEntryCount++;
  18532. pointer = pointer.parent;
  18533. }
  18534. return newEntryCount;
  18535. };
  18536. ChangedPath.prototype.populateColumnsMap = function (rowNode, columns) {
  18537. var _this = this;
  18538. if (!this.keepingColumns || !columns) {
  18539. return;
  18540. }
  18541. var pointer = rowNode;
  18542. while (pointer) {
  18543. // if columns, add the columns in all the way to parent, merging
  18544. // in any other columns that might be there already
  18545. if (!this.nodeIdsToColumns[pointer.id]) {
  18546. this.nodeIdsToColumns[pointer.id] = {};
  18547. }
  18548. columns.forEach(function (col) { return _this.nodeIdsToColumns[pointer.id][col.getId()] = true; });
  18549. pointer = pointer.parent;
  18550. }
  18551. };
  18552. ChangedPath.prototype.linkPathItems = function (rowNode, newEntryCount) {
  18553. var pointer = rowNode;
  18554. for (var i = 0; i < newEntryCount; i++) {
  18555. var thisItem = this.mapToItems[pointer.id];
  18556. var parentItem = this.mapToItems[pointer.parent.id];
  18557. if (!parentItem.children) {
  18558. parentItem.children = [];
  18559. }
  18560. parentItem.children.push(thisItem);
  18561. pointer = pointer.parent;
  18562. }
  18563. };
  18564. // called by
  18565. // 1) change detection (provides cols) and
  18566. // 2) groupStage if doing transaction update (doesn't provide cols)
  18567. ChangedPath.prototype.addParentNode = function (rowNode, columns) {
  18568. if (!rowNode || rowNode.isRowPinned()) {
  18569. return;
  18570. }
  18571. // we cannot do both steps below in the same loop as
  18572. // the second loop has a dependency on the first loop.
  18573. // ie the hierarchy cannot be stitched up yet because
  18574. // we don't have it built yet
  18575. // create the new PathItem objects.
  18576. var newEntryCount = this.createPathItems(rowNode);
  18577. // link in the node items
  18578. this.linkPathItems(rowNode, newEntryCount);
  18579. // update columns
  18580. this.populateColumnsMap(rowNode, columns);
  18581. };
  18582. ChangedPath.prototype.canSkip = function (rowNode) {
  18583. return this.active && !this.mapToItems[rowNode.id];
  18584. };
  18585. ChangedPath.prototype.getValueColumnsForNode = function (rowNode, valueColumns) {
  18586. if (!this.keepingColumns) {
  18587. return valueColumns;
  18588. }
  18589. var colsForThisNode = this.nodeIdsToColumns[rowNode.id];
  18590. var result = valueColumns.filter(function (col) { return colsForThisNode[col.getId()]; });
  18591. return result;
  18592. };
  18593. ChangedPath.prototype.getNotValueColumnsForNode = function (rowNode, valueColumns) {
  18594. if (!this.keepingColumns) {
  18595. return null;
  18596. }
  18597. var colsForThisNode = this.nodeIdsToColumns[rowNode.id];
  18598. var result = valueColumns.filter(function (col) { return !colsForThisNode[col.getId()]; });
  18599. return result;
  18600. };
  18601. return ChangedPath;
  18602. }());
  18603. /***/ }),
  18604. /* 98 */
  18605. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  18606. "use strict";
  18607. __webpack_require__.r(__webpack_exports__);
  18608. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnApi", function() { return ColumnApi; });
  18609. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  18610. /**
  18611. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  18612. * @version v23.2.1
  18613. * @link http://www.ag-grid.com/
  18614. * @license MIT
  18615. */
  18616. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  18617. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  18618. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  18619. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  18620. return c > 3 && r && Object.defineProperty(target, key, r), r;
  18621. };
  18622. var ColumnApi = /** @class */ (function () {
  18623. function ColumnApi() {
  18624. }
  18625. ColumnApi.prototype.sizeColumnsToFit = function (gridWidth) {
  18626. // AG-3403 validate that gridWidth is provided because this method has the same name as
  18627. // a method on the grid API that takes no arguments, and it's easy to confuse the two
  18628. if (typeof gridWidth === "undefined") {
  18629. console.error('ag-Grid: missing parameter to columnApi.sizeColumnsToFit(gridWidth)');
  18630. }
  18631. this.columnController.sizeColumnsToFit(gridWidth, 'api');
  18632. };
  18633. ColumnApi.prototype.setColumnGroupOpened = function (group, newValue) { this.columnController.setColumnGroupOpened(group, newValue, 'api'); };
  18634. ColumnApi.prototype.getColumnGroup = function (name, instanceId) { return this.columnController.getColumnGroup(name, instanceId); };
  18635. ColumnApi.prototype.getOriginalColumnGroup = function (name) { return this.columnController.getOriginalColumnGroup(name); };
  18636. ColumnApi.prototype.getDisplayNameForColumn = function (column, location) { return this.columnController.getDisplayNameForColumn(column, location) || ''; };
  18637. ColumnApi.prototype.getDisplayNameForColumnGroup = function (columnGroup, location) { return this.columnController.getDisplayNameForColumnGroup(columnGroup, location) || ''; };
  18638. ColumnApi.prototype.getColumn = function (key) { return this.columnController.getPrimaryColumn(key); };
  18639. ColumnApi.prototype.setColumnState = function (columnState) { return this.columnController.setColumnState(columnState, false, 'api'); };
  18640. ColumnApi.prototype.getColumnState = function () { return this.columnController.getColumnState(); };
  18641. ColumnApi.prototype.resetColumnState = function () { this.columnController.resetColumnState(false, 'api'); };
  18642. ColumnApi.prototype.getColumnGroupState = function () { return this.columnController.getColumnGroupState(); };
  18643. ColumnApi.prototype.setColumnGroupState = function (stateItems) { this.columnController.setColumnGroupState(stateItems, 'api'); };
  18644. ColumnApi.prototype.resetColumnGroupState = function () { this.columnController.resetColumnGroupState('api'); };
  18645. ColumnApi.prototype.isPinning = function () { return this.columnController.isPinningLeft() || this.columnController.isPinningRight(); };
  18646. ColumnApi.prototype.isPinningLeft = function () { return this.columnController.isPinningLeft(); };
  18647. ColumnApi.prototype.isPinningRight = function () { return this.columnController.isPinningRight(); };
  18648. ColumnApi.prototype.getDisplayedColAfter = function (col) { return this.columnController.getDisplayedColAfter(col); };
  18649. ColumnApi.prototype.getDisplayedColBefore = function (col) { return this.columnController.getDisplayedColBefore(col); };
  18650. ColumnApi.prototype.setColumnVisible = function (key, visible) { this.columnController.setColumnVisible(key, visible, 'api'); };
  18651. ColumnApi.prototype.setColumnsVisible = function (keys, visible) { this.columnController.setColumnsVisible(keys, visible, 'api'); };
  18652. ColumnApi.prototype.setColumnPinned = function (key, pinned) { this.columnController.setColumnPinned(key, pinned, 'api'); };
  18653. ColumnApi.prototype.setColumnsPinned = function (keys, pinned) { this.columnController.setColumnsPinned(keys, pinned, 'api'); };
  18654. ColumnApi.prototype.getAllColumns = function () { return this.columnController.getAllPrimaryColumns(); };
  18655. ColumnApi.prototype.getAllGridColumns = function () { return this.columnController.getAllGridColumns(); };
  18656. ColumnApi.prototype.getDisplayedLeftColumns = function () { return this.columnController.getDisplayedLeftColumns(); };
  18657. ColumnApi.prototype.getDisplayedCenterColumns = function () { return this.columnController.getDisplayedCenterColumns(); };
  18658. ColumnApi.prototype.getDisplayedRightColumns = function () { return this.columnController.getDisplayedRightColumns(); };
  18659. ColumnApi.prototype.getAllDisplayedColumns = function () { return this.columnController.getAllDisplayedColumns(); };
  18660. ColumnApi.prototype.getAllDisplayedVirtualColumns = function () { return this.columnController.getAllDisplayedVirtualColumns(); };
  18661. ColumnApi.prototype.moveColumn = function (key, toIndex) {
  18662. if (typeof key === 'number') {
  18663. // moveColumn used to take indexes, so this is advising user who hasn't moved to new method name
  18664. console.warn('ag-Grid: you are using moveColumn(fromIndex, toIndex) - moveColumn takes a column key and a destination index, not two indexes, to move with indexes use moveColumnByIndex(from,to) instead');
  18665. this.columnController.moveColumnByIndex(key, toIndex, 'api');
  18666. }
  18667. else {
  18668. this.columnController.moveColumn(key, toIndex, 'api');
  18669. }
  18670. };
  18671. ColumnApi.prototype.moveColumnByIndex = function (fromIndex, toIndex) { this.columnController.moveColumnByIndex(fromIndex, toIndex, 'api'); };
  18672. ColumnApi.prototype.moveColumns = function (columnsToMoveKeys, toIndex) { this.columnController.moveColumns(columnsToMoveKeys, toIndex, 'api'); };
  18673. ColumnApi.prototype.moveRowGroupColumn = function (fromIndex, toIndex) { this.columnController.moveRowGroupColumn(fromIndex, toIndex); };
  18674. ColumnApi.prototype.setColumnAggFunc = function (column, aggFunc) { this.columnController.setColumnAggFunc(column, aggFunc); };
  18675. ColumnApi.prototype.setColumnWidth = function (key, newWidth, finished) {
  18676. if (finished === void 0) { finished = true; }
  18677. this.columnController.setColumnWidths([{ key: key, newWidth: newWidth }], false, finished);
  18678. };
  18679. ColumnApi.prototype.setColumnWidths = function (columnWidths, finished) {
  18680. if (finished === void 0) { finished = true; }
  18681. this.columnController.setColumnWidths(columnWidths, false, finished);
  18682. };
  18683. ColumnApi.prototype.setPivotMode = function (pivotMode) { this.columnController.setPivotMode(pivotMode); };
  18684. ColumnApi.prototype.isPivotMode = function () { return this.columnController.isPivotMode(); };
  18685. ColumnApi.prototype.getSecondaryPivotColumn = function (pivotKeys, valueColKey) { return this.columnController.getSecondaryPivotColumn(pivotKeys, valueColKey); };
  18686. ColumnApi.prototype.setValueColumns = function (colKeys) { this.columnController.setValueColumns(colKeys, 'api'); };
  18687. ColumnApi.prototype.getValueColumns = function () { return this.columnController.getValueColumns(); };
  18688. ColumnApi.prototype.removeValueColumn = function (colKey) { this.columnController.removeValueColumn(colKey, 'api'); };
  18689. ColumnApi.prototype.removeValueColumns = function (colKeys) { this.columnController.removeValueColumns(colKeys, 'api'); };
  18690. ColumnApi.prototype.addValueColumn = function (colKey) { this.columnController.addValueColumn(colKey, 'api'); };
  18691. ColumnApi.prototype.addValueColumns = function (colKeys) { this.columnController.addValueColumns(colKeys, 'api'); };
  18692. ColumnApi.prototype.setRowGroupColumns = function (colKeys) { this.columnController.setRowGroupColumns(colKeys, 'api'); };
  18693. ColumnApi.prototype.removeRowGroupColumn = function (colKey) { this.columnController.removeRowGroupColumn(colKey, 'api'); };
  18694. ColumnApi.prototype.removeRowGroupColumns = function (colKeys) { this.columnController.removeRowGroupColumns(colKeys, 'api'); };
  18695. ColumnApi.prototype.addRowGroupColumn = function (colKey) { this.columnController.addRowGroupColumn(colKey, 'api'); };
  18696. ColumnApi.prototype.addRowGroupColumns = function (colKeys) { this.columnController.addRowGroupColumns(colKeys, 'api'); };
  18697. ColumnApi.prototype.getRowGroupColumns = function () { return this.columnController.getRowGroupColumns(); };
  18698. ColumnApi.prototype.setPivotColumns = function (colKeys) { this.columnController.setPivotColumns(colKeys, 'api'); };
  18699. ColumnApi.prototype.removePivotColumn = function (colKey) { this.columnController.removePivotColumn(colKey, 'api'); };
  18700. ColumnApi.prototype.removePivotColumns = function (colKeys) { this.columnController.removePivotColumns(colKeys, 'api'); };
  18701. ColumnApi.prototype.addPivotColumn = function (colKey) { this.columnController.addPivotColumn(colKey, 'api'); };
  18702. ColumnApi.prototype.addPivotColumns = function (colKeys) { this.columnController.addPivotColumns(colKeys, 'api'); };
  18703. ColumnApi.prototype.getPivotColumns = function () { return this.columnController.getPivotColumns(); };
  18704. ColumnApi.prototype.getLeftDisplayedColumnGroups = function () { return this.columnController.getLeftDisplayedColumnGroups(); };
  18705. ColumnApi.prototype.getCenterDisplayedColumnGroups = function () { return this.columnController.getCenterDisplayedColumnGroups(); };
  18706. ColumnApi.prototype.getRightDisplayedColumnGroups = function () { return this.columnController.getRightDisplayedColumnGroups(); };
  18707. ColumnApi.prototype.getAllDisplayedColumnGroups = function () { return this.columnController.getAllDisplayedColumnGroups(); };
  18708. ColumnApi.prototype.autoSizeColumn = function (key, skipHeader) { return this.columnController.autoSizeColumn(key, skipHeader, 'api'); };
  18709. ColumnApi.prototype.autoSizeColumns = function (keys, skipHeader) { return this.columnController.autoSizeColumns(keys, skipHeader, 'api'); };
  18710. ColumnApi.prototype.autoSizeAllColumns = function (skipHeader) { this.columnController.autoSizeAllColumns(skipHeader, 'api'); };
  18711. ColumnApi.prototype.setSecondaryColumns = function (colDefs) { this.columnController.setSecondaryColumns(colDefs, 'api'); };
  18712. ColumnApi.prototype.getSecondaryColumns = function () { return this.columnController.getSecondaryColumns(); };
  18713. ColumnApi.prototype.getPrimaryColumns = function () { return this.columnController.getAllPrimaryColumns(); };
  18714. // below goes through deprecated items, prints message to user, then calls the new version of the same method
  18715. ColumnApi.prototype.columnGroupOpened = function (group, newValue) {
  18716. console.error('ag-Grid: columnGroupOpened no longer exists, use setColumnGroupOpened');
  18717. this.setColumnGroupOpened(group, newValue);
  18718. };
  18719. ColumnApi.prototype.hideColumns = function (colIds, hide) {
  18720. console.error('ag-Grid: hideColumns is deprecated, use setColumnsVisible');
  18721. this.columnController.setColumnsVisible(colIds, !hide, 'api');
  18722. };
  18723. ColumnApi.prototype.hideColumn = function (colId, hide) {
  18724. console.error('ag-Grid: hideColumn is deprecated, use setColumnVisible');
  18725. this.columnController.setColumnVisible(colId, !hide, 'api');
  18726. };
  18727. ColumnApi.prototype.setState = function (columnState) {
  18728. console.error('ag-Grid: setState is deprecated, use setColumnState');
  18729. return this.setColumnState(columnState);
  18730. };
  18731. ColumnApi.prototype.getState = function () {
  18732. console.error('ag-Grid: getState is deprecated, use getColumnState');
  18733. return this.getColumnState();
  18734. };
  18735. ColumnApi.prototype.resetState = function () {
  18736. console.error('ag-Grid: resetState is deprecated, use resetColumnState');
  18737. this.resetColumnState();
  18738. };
  18739. ColumnApi.prototype.getAggregationColumns = function () {
  18740. console.error('ag-Grid: getAggregationColumns is deprecated, use getValueColumns');
  18741. return this.columnController.getValueColumns();
  18742. };
  18743. ColumnApi.prototype.removeAggregationColumn = function (colKey) {
  18744. console.error('ag-Grid: removeAggregationColumn is deprecated, use removeValueColumn');
  18745. this.columnController.removeValueColumn(colKey, 'api');
  18746. };
  18747. ColumnApi.prototype.removeAggregationColumns = function (colKeys) {
  18748. console.error('ag-Grid: removeAggregationColumns is deprecated, use removeValueColumns');
  18749. this.columnController.removeValueColumns(colKeys, 'api');
  18750. };
  18751. ColumnApi.prototype.addAggregationColumn = function (colKey) {
  18752. console.error('ag-Grid: addAggregationColumn is deprecated, use addValueColumn');
  18753. this.columnController.addValueColumn(colKey, 'api');
  18754. };
  18755. ColumnApi.prototype.addAggregationColumns = function (colKeys) {
  18756. console.error('ag-Grid: addAggregationColumns is deprecated, use addValueColumns');
  18757. this.columnController.addValueColumns(colKeys, 'api');
  18758. };
  18759. ColumnApi.prototype.setColumnAggFunction = function (column, aggFunc) {
  18760. console.error('ag-Grid: setColumnAggFunction is deprecated, use setColumnAggFunc');
  18761. this.columnController.setColumnAggFunc(column, aggFunc, 'api');
  18762. };
  18763. ColumnApi.prototype.getDisplayNameForCol = function (column) {
  18764. console.error('ag-Grid: getDisplayNameForCol is deprecated, use getDisplayNameForColumn');
  18765. return this.getDisplayNameForColumn(column, null);
  18766. };
  18767. __decorate([
  18768. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController')
  18769. ], ColumnApi.prototype, "columnController", void 0);
  18770. ColumnApi = __decorate([
  18771. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('columnApi')
  18772. ], ColumnApi);
  18773. return ColumnApi;
  18774. }());
  18775. /***/ }),
  18776. /* 99 */
  18777. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  18778. "use strict";
  18779. __webpack_require__.r(__webpack_exports__);
  18780. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowRenderer", function() { return RowRenderer; });
  18781. /* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(50);
  18782. /* harmony import */ var _rowComp__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(100);
  18783. /* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(35);
  18784. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(43);
  18785. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(25);
  18786. /* harmony import */ var _cellComp__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(101);
  18787. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(37);
  18788. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(41);
  18789. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(7);
  18790. /**
  18791. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  18792. * @version v23.2.1
  18793. * @link http://www.ag-grid.com/
  18794. * @license MIT
  18795. */
  18796. var __extends = (undefined && undefined.__extends) || (function () {
  18797. var extendStatics = function (d, b) {
  18798. extendStatics = Object.setPrototypeOf ||
  18799. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  18800. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  18801. return extendStatics(d, b);
  18802. };
  18803. return function (d, b) {
  18804. extendStatics(d, b);
  18805. function __() { this.constructor = d; }
  18806. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  18807. };
  18808. })();
  18809. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  18810. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  18811. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  18812. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  18813. return c > 3 && r && Object.defineProperty(target, key, r), r;
  18814. };
  18815. var __param = (undefined && undefined.__param) || function (paramIndex, decorator) {
  18816. return function (target, key) { decorator(target, key, paramIndex); }
  18817. };
  18818. var RowRenderer = /** @class */ (function (_super) {
  18819. __extends(RowRenderer, _super);
  18820. function RowRenderer() {
  18821. var _this = _super !== null && _super.apply(this, arguments) || this;
  18822. _this.destroyFuncsForColumnListeners = [];
  18823. // map of row ids to row objects. keeps track of which elements
  18824. // are rendered for which rows in the dom.
  18825. _this.rowCompsByIndex = {};
  18826. _this.floatingTopRowComps = [];
  18827. _this.floatingBottomRowComps = [];
  18828. // we only allow one refresh at a time, otherwise the internal memory structure here
  18829. // will get messed up. this can happen if the user has a cellRenderer, and inside the
  18830. // renderer they call an API method that results in another pass of the refresh,
  18831. // then it will be trying to draw rows in the middle of a refresh.
  18832. _this.refreshInProgress = false;
  18833. return _this;
  18834. }
  18835. RowRenderer.prototype.registerGridCore = function (gridCore) {
  18836. this.gridCore = gridCore;
  18837. };
  18838. RowRenderer.prototype.getGridCore = function () {
  18839. return this.gridCore;
  18840. };
  18841. RowRenderer.prototype.agWire = function (loggerFactory) {
  18842. this.logger = loggerFactory.create("RowRenderer");
  18843. };
  18844. RowRenderer.prototype.registerGridComp = function (gridPanel) {
  18845. this.gridPanel = gridPanel;
  18846. this.rowContainers = this.gridPanel.getRowContainers();
  18847. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_PAGINATION_CHANGED, this.onPageLoaded.bind(this));
  18848. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_PINNED_ROW_DATA_CHANGED, this.onPinnedRowDataChanged.bind(this));
  18849. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this));
  18850. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_BODY_SCROLL, this.redrawAfterScroll.bind(this));
  18851. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_BODY_HEIGHT_CHANGED, this.redrawAfterScroll.bind(this));
  18852. this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_DOM_LAYOUT, this.onDomLayoutChanged.bind(this));
  18853. this.registerCellEventListeners();
  18854. this.printLayout = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].DOM_LAYOUT_PRINT;
  18855. this.embedFullWidthRows = this.printLayout || this.gridOptionsWrapper.isEmbedFullWidthRows();
  18856. this.redrawAfterModelUpdate();
  18857. };
  18858. // in a clean design, each cell would register for each of these events. however when scrolling, all the cells
  18859. // registering and de-registering for events is a performance bottleneck. so we register here once and inform
  18860. // all active cells.
  18861. RowRenderer.prototype.registerCellEventListeners = function () {
  18862. var _this = this;
  18863. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_CELL_FOCUSED, function (event) {
  18864. _this.forEachCellComp(function (cellComp) { return cellComp.onCellFocused(event); });
  18865. });
  18866. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_FLASH_CELLS, function (event) {
  18867. _this.forEachCellComp(function (cellComp) { return cellComp.onFlashCells(event); });
  18868. });
  18869. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_HOVER_CHANGED, function () {
  18870. _this.forEachCellComp(function (cellComp) { return cellComp.onColumnHover(); });
  18871. });
  18872. // only for printLayout - because we are rendering all the cells in the same row, regardless of pinned state,
  18873. // then changing the width of the containers will impact left position. eg the center cols all have their
  18874. // left position adjusted by the width of the left pinned column, so if the pinned left column width changes,
  18875. // all the center cols need to be shifted to accommodate this. when in normal layout, the pinned cols are
  18876. // in different containers so doesn't impact.
  18877. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, function () {
  18878. if (_this.printLayout) {
  18879. _this.forEachCellComp(function (cellComp) { return cellComp.onLeftChanged(); });
  18880. }
  18881. });
  18882. var rangeSelectionEnabled = this.gridOptionsWrapper.isEnableRangeSelection();
  18883. if (rangeSelectionEnabled) {
  18884. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_RANGE_SELECTION_CHANGED, function () {
  18885. _this.forEachCellComp(function (cellComp) { return cellComp.onRangeSelectionChanged(); });
  18886. });
  18887. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_MOVED, function () {
  18888. _this.forEachCellComp(function (cellComp) { return cellComp.updateRangeBordersIfRangeCount(); });
  18889. });
  18890. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_PINNED, function () {
  18891. _this.forEachCellComp(function (cellComp) { return cellComp.updateRangeBordersIfRangeCount(); });
  18892. });
  18893. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_VISIBLE, function () {
  18894. _this.forEachCellComp(function (cellComp) { return cellComp.updateRangeBordersIfRangeCount(); });
  18895. });
  18896. }
  18897. // add listeners to the grid columns
  18898. this.refreshListenersToColumnsForCellComps();
  18899. // if the grid columns change, then refresh the listeners again
  18900. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_GRID_COLUMNS_CHANGED, this.refreshListenersToColumnsForCellComps.bind(this));
  18901. this.addDestroyFunc(this.removeGridColumnListeners.bind(this));
  18902. };
  18903. // executes all functions in destroyFuncsForColumnListeners and then clears the list
  18904. RowRenderer.prototype.removeGridColumnListeners = function () {
  18905. this.destroyFuncsForColumnListeners.forEach(function (func) { return func(); });
  18906. this.destroyFuncsForColumnListeners.length = 0;
  18907. };
  18908. // this function adds listeners onto all the grid columns, which are the column that we could have cellComps for.
  18909. // when the grid columns change, we add listeners again. in an ideal design, each CellComp would just register to
  18910. // the column it belongs to on creation, however this was a bottleneck with the number of cells, so do it here
  18911. // once instead.
  18912. RowRenderer.prototype.refreshListenersToColumnsForCellComps = function () {
  18913. var _this = this;
  18914. this.removeGridColumnListeners();
  18915. var cols = this.columnController.getAllGridColumns();
  18916. if (!cols) {
  18917. return;
  18918. }
  18919. cols.forEach(function (col) {
  18920. var forEachCellWithThisCol = function (callback) {
  18921. _this.forEachCellComp(function (cellComp) {
  18922. if (cellComp.getColumn() === col) {
  18923. callback(cellComp);
  18924. }
  18925. });
  18926. };
  18927. var leftChangedListener = function () {
  18928. forEachCellWithThisCol(function (cellComp) { return cellComp.onLeftChanged(); });
  18929. };
  18930. var widthChangedListener = function () {
  18931. forEachCellWithThisCol(function (cellComp) { return cellComp.onWidthChanged(); });
  18932. };
  18933. var firstRightPinnedChangedListener = function () {
  18934. forEachCellWithThisCol(function (cellComp) { return cellComp.onFirstRightPinnedChanged(); });
  18935. };
  18936. var lastLeftPinnedChangedListener = function () {
  18937. forEachCellWithThisCol(function (cellComp) { return cellComp.onLastLeftPinnedChanged(); });
  18938. };
  18939. col.addEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_LEFT_CHANGED, leftChangedListener);
  18940. col.addEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_WIDTH_CHANGED, widthChangedListener);
  18941. col.addEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_FIRST_RIGHT_PINNED_CHANGED, firstRightPinnedChangedListener);
  18942. col.addEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_LAST_LEFT_PINNED_CHANGED, lastLeftPinnedChangedListener);
  18943. _this.destroyFuncsForColumnListeners.push(function () {
  18944. col.removeEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_LEFT_CHANGED, leftChangedListener);
  18945. col.removeEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_WIDTH_CHANGED, widthChangedListener);
  18946. col.removeEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_FIRST_RIGHT_PINNED_CHANGED, firstRightPinnedChangedListener);
  18947. col.removeEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_2__["Column"].EVENT_LAST_LEFT_PINNED_CHANGED, lastLeftPinnedChangedListener);
  18948. });
  18949. });
  18950. };
  18951. RowRenderer.prototype.onDomLayoutChanged = function () {
  18952. var printLayout = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].DOM_LAYOUT_PRINT;
  18953. var embedFullWidthRows = printLayout || this.gridOptionsWrapper.isEmbedFullWidthRows();
  18954. // if moving towards or away from print layout, means we need to destroy all rows, as rows are not laid
  18955. // out using absolute positioning when doing print layout
  18956. var destroyRows = embedFullWidthRows !== this.embedFullWidthRows || this.printLayout !== printLayout;
  18957. this.printLayout = printLayout;
  18958. this.embedFullWidthRows = embedFullWidthRows;
  18959. if (destroyRows) {
  18960. this.redrawAfterModelUpdate();
  18961. }
  18962. };
  18963. // for row models that have datasources, when we update the datasource, we need to force the rowRenderer
  18964. // to redraw all rows. otherwise the old rows from the old datasource will stay displayed.
  18965. RowRenderer.prototype.datasourceChanged = function () {
  18966. this.firstRenderedRow = 0;
  18967. this.lastRenderedRow = -1;
  18968. var rowIndexesToRemove = Object.keys(this.rowCompsByIndex);
  18969. this.removeRowComps(rowIndexesToRemove);
  18970. };
  18971. RowRenderer.prototype.onPageLoaded = function (refreshEvent) {
  18972. if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(refreshEvent)) {
  18973. refreshEvent = {
  18974. type: _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_MODEL_UPDATED,
  18975. api: this.gridApi,
  18976. columnApi: this.columnApi,
  18977. animate: false,
  18978. keepRenderedRows: false,
  18979. newData: false,
  18980. newPage: false
  18981. };
  18982. }
  18983. this.onModelUpdated(refreshEvent);
  18984. };
  18985. RowRenderer.prototype.getAllCellsForColumn = function (column) {
  18986. var eCells = [];
  18987. function callback(key, rowComp) {
  18988. var eCell = rowComp.getCellForCol(column);
  18989. if (eCell) {
  18990. eCells.push(eCell);
  18991. }
  18992. }
  18993. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.rowCompsByIndex, callback);
  18994. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.floatingBottomRowComps, callback);
  18995. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.floatingTopRowComps, callback);
  18996. return eCells;
  18997. };
  18998. RowRenderer.prototype.refreshFloatingRowComps = function () {
  18999. this.refreshFloatingRows(this.floatingTopRowComps, this.pinnedRowModel.getPinnedTopRowData(), this.rowContainers.floatingTopPinnedLeft, this.rowContainers.floatingTopPinnedRight, this.rowContainers.floatingTop, this.rowContainers.floatingTopFullWidth);
  19000. this.refreshFloatingRows(this.floatingBottomRowComps, this.pinnedRowModel.getPinnedBottomRowData(), this.rowContainers.floatingBottomPinnedLeft, this.rowContainers.floatingBottomPinnedRight, this.rowContainers.floatingBottom, this.rowContainers.floatingBottomFullWidth);
  19001. };
  19002. RowRenderer.prototype.refreshFloatingRows = function (rowComps, rowNodes, pinnedLeftContainerComp, pinnedRightContainerComp, bodyContainerComp, fullWidthContainerComp) {
  19003. var _this = this;
  19004. rowComps.forEach(function (row) {
  19005. row.destroy();
  19006. });
  19007. rowComps.length = 0;
  19008. if (rowNodes) {
  19009. rowNodes.forEach(function (node) {
  19010. var rowComp = new _rowComp__WEBPACK_IMPORTED_MODULE_1__["RowComp"](_this.$scope, bodyContainerComp, pinnedLeftContainerComp, pinnedRightContainerComp, fullWidthContainerComp, node, _this.beans, false, false, _this.printLayout, _this.embedFullWidthRows);
  19011. rowComp.init();
  19012. rowComps.push(rowComp);
  19013. });
  19014. }
  19015. this.flushContainers(rowComps);
  19016. };
  19017. RowRenderer.prototype.onPinnedRowDataChanged = function () {
  19018. // recycling rows in order to ensure cell editing is not cancelled
  19019. var params = {
  19020. recycleRows: true
  19021. };
  19022. this.redrawAfterModelUpdate(params);
  19023. };
  19024. RowRenderer.prototype.onModelUpdated = function (refreshEvent) {
  19025. var params = {
  19026. recycleRows: refreshEvent.keepRenderedRows,
  19027. animate: refreshEvent.animate,
  19028. newData: refreshEvent.newData,
  19029. newPage: refreshEvent.newPage,
  19030. // because this is a model updated event (not pinned rows), we
  19031. // can skip updating the pinned rows. this is needed so that if user
  19032. // is doing transaction updates, the pinned rows are not getting constantly
  19033. // trashed - or editing cells in pinned rows are not refreshed and put into read mode
  19034. onlyBody: true
  19035. };
  19036. this.redrawAfterModelUpdate(params);
  19037. };
  19038. // if the row nodes are not rendered, no index is returned
  19039. RowRenderer.prototype.getRenderedIndexesForRowNodes = function (rowNodes) {
  19040. var result = [];
  19041. if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(rowNodes)) {
  19042. return result;
  19043. }
  19044. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.rowCompsByIndex, function (index, renderedRow) {
  19045. var rowNode = renderedRow.getRowNode();
  19046. if (rowNodes.indexOf(rowNode) >= 0) {
  19047. result.push(index);
  19048. }
  19049. });
  19050. return result;
  19051. };
  19052. RowRenderer.prototype.redrawRows = function (rowNodes) {
  19053. if (!rowNodes || rowNodes.length == 0) {
  19054. return;
  19055. }
  19056. // we only need to be worried about rendered rows, as this method is
  19057. // called to what's rendered. if the row isn't rendered, we don't care
  19058. var indexesToRemove = this.getRenderedIndexesForRowNodes(rowNodes);
  19059. // remove the rows
  19060. this.removeRowComps(indexesToRemove);
  19061. // add draw them again
  19062. this.redrawAfterModelUpdate({
  19063. recycleRows: true
  19064. });
  19065. };
  19066. RowRenderer.prototype.getCellToRestoreFocusToAfterRefresh = function (params) {
  19067. var focusedCell = params.suppressKeepFocus ? null : this.focusController.getFocusCellToUseAfterRefresh();
  19068. if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(focusedCell)) {
  19069. return null;
  19070. }
  19071. // if the dom is not actually focused on a cell, then we don't try to refocus. the problem this
  19072. // solves is with editing - if the user is editing, eg focus is on a text field, and not on the
  19073. // cell itself, then the cell can be registered as having focus, however it's the text field that
  19074. // has the focus and not the cell div. therefore, when the refresh is finished, the grid will focus
  19075. // the cell, and not the textfield. that means if the user is in a text field, and the grid refreshes,
  19076. // the focus is lost from the text field. we do not want this.
  19077. var activeElement = document.activeElement;
  19078. var domData = this.gridOptionsWrapper.getDomData(activeElement, _cellComp__WEBPACK_IMPORTED_MODULE_5__["CellComp"].DOM_DATA_KEY_CELL_COMP);
  19079. var elementIsNotACellDev = _utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(domData);
  19080. return elementIsNotACellDev ? null : focusedCell;
  19081. };
  19082. // gets called after changes to the model.
  19083. RowRenderer.prototype.redrawAfterModelUpdate = function (params) {
  19084. if (params === void 0) { params = {}; }
  19085. this.getLockOnRefresh();
  19086. var focusedCell = this.getCellToRestoreFocusToAfterRefresh(params);
  19087. this.sizeContainerToPageHeight();
  19088. this.scrollToTopIfNewData(params);
  19089. // never recycle rows when print layout, we draw each row again from scratch. this is because print layout
  19090. // uses normal dom layout to put cells into dom - it doesn't allow reordering rows.
  19091. var recycleRows = !this.printLayout && params.recycleRows;
  19092. var animate = params.animate && this.gridOptionsWrapper.isAnimateRows();
  19093. var rowsToRecycle = this.binRowComps(recycleRows);
  19094. this.redraw(rowsToRecycle, animate);
  19095. if (!params.onlyBody) {
  19096. this.refreshFloatingRowComps();
  19097. }
  19098. this.restoreFocusedCell(focusedCell);
  19099. this.releaseLockOnRefresh();
  19100. };
  19101. RowRenderer.prototype.scrollToTopIfNewData = function (params) {
  19102. var scrollToTop = params.newData || params.newPage;
  19103. var suppressScrollToTop = this.gridOptionsWrapper.isSuppressScrollOnNewData();
  19104. if (scrollToTop && !suppressScrollToTop) {
  19105. this.gridPanel.scrollToTop();
  19106. }
  19107. };
  19108. RowRenderer.prototype.sizeContainerToPageHeight = function () {
  19109. var containers = [
  19110. this.rowContainers.body,
  19111. this.rowContainers.fullWidth,
  19112. this.rowContainers.pinnedLeft,
  19113. this.rowContainers.pinnedRight
  19114. ];
  19115. if (this.printLayout) {
  19116. containers.forEach(function (container) { return container.setHeight(null); });
  19117. return;
  19118. }
  19119. var containerHeight = this.paginationProxy.getCurrentPageHeight();
  19120. // we need at least 1 pixel for the horizontal scroll to work. so if there are now rows,
  19121. // we still want the scroll to be present, otherwise there would be no way to scroll the header
  19122. // which might be needed us user wants to access columns
  19123. // on the RHS - and if that was where the filter was that cause no rows to be presented, there
  19124. // is no way to remove the filter.
  19125. if (containerHeight === 0) {
  19126. containerHeight = 1;
  19127. }
  19128. this.maxDivHeightScaler.setModelHeight(containerHeight);
  19129. var realHeight = this.maxDivHeightScaler.getUiContainerHeight();
  19130. containers.forEach(function (container) { return container.setHeight(realHeight); });
  19131. };
  19132. RowRenderer.prototype.getLockOnRefresh = function () {
  19133. if (this.refreshInProgress) {
  19134. throw new Error("ag-Grid: cannot get grid to draw rows when it is in the middle of drawing rows. " +
  19135. "Your code probably called a grid API method while the grid was in the render stage. To overcome " +
  19136. "this, put the API call into a timeout, eg instead of api.refreshView(), " +
  19137. "call setTimeout(function(){api.refreshView(),0}). To see what part of your code " +
  19138. "that caused the refresh check this stacktrace.");
  19139. }
  19140. this.refreshInProgress = true;
  19141. };
  19142. RowRenderer.prototype.releaseLockOnRefresh = function () {
  19143. this.refreshInProgress = false;
  19144. };
  19145. // sets the focus to the provided cell, if the cell is provided. this way, the user can call refresh without
  19146. // worry about the focus been lost. this is important when the user is using keyboard navigation to do edits
  19147. // and the cellEditor is calling 'refresh' to get other cells to update (as other cells might depend on the
  19148. // edited cell).
  19149. RowRenderer.prototype.restoreFocusedCell = function (cellPosition) {
  19150. if (cellPosition) {
  19151. this.focusController.setFocusedCell(cellPosition.rowIndex, cellPosition.column, cellPosition.rowPinned, true);
  19152. }
  19153. };
  19154. RowRenderer.prototype.stopEditing = function (cancel) {
  19155. if (cancel === void 0) { cancel = false; }
  19156. this.forEachRowComp(function (key, rowComp) {
  19157. rowComp.stopEditing(cancel);
  19158. });
  19159. };
  19160. RowRenderer.prototype.forEachCellComp = function (callback) {
  19161. this.forEachRowComp(function (key, rowComp) { return rowComp.forEachCellComp(callback); });
  19162. };
  19163. RowRenderer.prototype.forEachRowComp = function (callback) {
  19164. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.rowCompsByIndex, callback);
  19165. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.floatingTopRowComps, callback);
  19166. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.floatingBottomRowComps, callback);
  19167. };
  19168. RowRenderer.prototype.addRenderedRowListener = function (eventName, rowIndex, callback) {
  19169. var rowComp = this.rowCompsByIndex[rowIndex];
  19170. if (rowComp) {
  19171. rowComp.addEventListener(eventName, callback);
  19172. }
  19173. };
  19174. RowRenderer.prototype.flashCells = function (params) {
  19175. if (params === void 0) { params = {}; }
  19176. var flashDelay = params.flashDelay, fadeDelay = params.fadeDelay;
  19177. this.forEachCellCompFiltered(params.rowNodes, params.columns, function (cellComp) { return cellComp.flashCell({ flashDelay: flashDelay, fadeDelay: fadeDelay }); });
  19178. };
  19179. RowRenderer.prototype.refreshCells = function (params) {
  19180. if (params === void 0) { params = {}; }
  19181. var refreshCellParams = {
  19182. forceRefresh: params.force,
  19183. newData: false,
  19184. suppressFlash: params.suppressFlash
  19185. };
  19186. this.forEachCellCompFiltered(params.rowNodes, params.columns, function (cellComp) { return cellComp.refreshCell(refreshCellParams); });
  19187. };
  19188. RowRenderer.prototype.getCellRendererInstances = function (params) {
  19189. var res = [];
  19190. this.forEachCellCompFiltered(params.rowNodes, params.columns, function (cellComp) {
  19191. var cellRenderer = cellComp.getCellRenderer();
  19192. if (cellRenderer) {
  19193. res.push(cellRenderer);
  19194. }
  19195. });
  19196. return res;
  19197. };
  19198. RowRenderer.prototype.getCellEditorInstances = function (params) {
  19199. var res = [];
  19200. this.forEachCellCompFiltered(params.rowNodes, params.columns, function (cellComp) {
  19201. var cellEditor = cellComp.getCellEditor();
  19202. if (cellEditor) {
  19203. res.push(cellEditor);
  19204. }
  19205. });
  19206. return res;
  19207. };
  19208. RowRenderer.prototype.getEditingCells = function () {
  19209. var res = [];
  19210. this.forEachCellComp(function (cellComp) {
  19211. if (cellComp.isEditing()) {
  19212. var cellPosition = cellComp.getCellPosition();
  19213. res.push(cellPosition);
  19214. }
  19215. });
  19216. return res;
  19217. };
  19218. // calls the callback for each cellComp that match the provided rowNodes and columns. eg if one row node
  19219. // and two columns provided, that identifies 4 cells, so callback gets called 4 times, once for each cell.
  19220. RowRenderer.prototype.forEachCellCompFiltered = function (rowNodes, columns, callback) {
  19221. var _this = this;
  19222. var rowIdsMap;
  19223. if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(rowNodes)) {
  19224. rowIdsMap = {
  19225. top: {},
  19226. bottom: {},
  19227. normal: {}
  19228. };
  19229. rowNodes.forEach(function (rowNode) {
  19230. if (rowNode.rowPinned === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_TOP) {
  19231. rowIdsMap.top[rowNode.id] = true;
  19232. }
  19233. else if (rowNode.rowPinned === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_BOTTOM) {
  19234. rowIdsMap.bottom[rowNode.id] = true;
  19235. }
  19236. else {
  19237. rowIdsMap.normal[rowNode.id] = true;
  19238. }
  19239. });
  19240. }
  19241. var colIdsMap;
  19242. if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(columns)) {
  19243. colIdsMap = {};
  19244. columns.forEach(function (colKey) {
  19245. var column = _this.columnController.getGridColumn(colKey);
  19246. if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(column)) {
  19247. colIdsMap[column.getId()] = true;
  19248. }
  19249. });
  19250. }
  19251. var processRow = function (rowComp) {
  19252. var rowNode = rowComp.getRowNode();
  19253. var id = rowNode.id;
  19254. var floating = rowNode.rowPinned;
  19255. // skip this row if it is missing from the provided list
  19256. if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(rowIdsMap)) {
  19257. if (floating === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_BOTTOM) {
  19258. if (!rowIdsMap.bottom[id]) {
  19259. return;
  19260. }
  19261. }
  19262. else if (floating === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_TOP) {
  19263. if (!rowIdsMap.top[id]) {
  19264. return;
  19265. }
  19266. }
  19267. else {
  19268. if (!rowIdsMap.normal[id]) {
  19269. return;
  19270. }
  19271. }
  19272. }
  19273. rowComp.forEachCellComp(function (cellComp) {
  19274. var colId = cellComp.getColumn().getId();
  19275. var excludeColFromRefresh = colIdsMap && !colIdsMap[colId];
  19276. if (excludeColFromRefresh) {
  19277. return;
  19278. }
  19279. callback(cellComp);
  19280. });
  19281. };
  19282. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.rowCompsByIndex, function (index, rowComp) {
  19283. processRow(rowComp);
  19284. });
  19285. if (this.floatingTopRowComps) {
  19286. this.floatingTopRowComps.forEach(processRow);
  19287. }
  19288. if (this.floatingBottomRowComps) {
  19289. this.floatingBottomRowComps.forEach(processRow);
  19290. }
  19291. };
  19292. RowRenderer.prototype.destroy = function () {
  19293. var rowIndexesToRemove = Object.keys(this.rowCompsByIndex);
  19294. this.removeRowComps(rowIndexesToRemove);
  19295. _super.prototype.destroy.call(this);
  19296. };
  19297. RowRenderer.prototype.binRowComps = function (recycleRows) {
  19298. var _this = this;
  19299. var rowsToRecycle = {};
  19300. var indexesToRemove;
  19301. if (recycleRows) {
  19302. indexesToRemove = [];
  19303. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.rowCompsByIndex, function (index, rowComp) {
  19304. var rowNode = rowComp.getRowNode();
  19305. if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(rowNode.id)) {
  19306. rowsToRecycle[rowNode.id] = rowComp;
  19307. delete _this.rowCompsByIndex[index];
  19308. }
  19309. else {
  19310. indexesToRemove.push(index);
  19311. }
  19312. });
  19313. }
  19314. else {
  19315. indexesToRemove = Object.keys(this.rowCompsByIndex);
  19316. }
  19317. this.removeRowComps(indexesToRemove);
  19318. return rowsToRecycle;
  19319. };
  19320. // takes array of row indexes
  19321. RowRenderer.prototype.removeRowComps = function (rowsToRemove) {
  19322. var _this = this;
  19323. // if no fromIndex then set to -1, which will refresh everything
  19324. // let realFromIndex = -1;
  19325. rowsToRemove.forEach(function (indexToRemove) {
  19326. var renderedRow = _this.rowCompsByIndex[indexToRemove];
  19327. renderedRow.destroy();
  19328. delete _this.rowCompsByIndex[indexToRemove];
  19329. });
  19330. };
  19331. // gets called when rows don't change, but viewport does, so after:
  19332. // 1) height of grid body changes, ie number of displayed rows has changed
  19333. // 2) grid scrolled to new position
  19334. // 3) ensure index visible (which is a scroll)
  19335. RowRenderer.prototype.redrawAfterScroll = function () {
  19336. this.getLockOnRefresh();
  19337. this.redraw(null, false, true);
  19338. this.releaseLockOnRefresh();
  19339. };
  19340. RowRenderer.prototype.removeRowCompsNotToDraw = function (indexesToDraw) {
  19341. // for speedy lookup, dump into map
  19342. var indexesToDrawMap = {};
  19343. indexesToDraw.forEach(function (index) { return (indexesToDrawMap[index] = true); });
  19344. var existingIndexes = Object.keys(this.rowCompsByIndex);
  19345. var indexesNotToDraw = existingIndexes.filter(function (index) { return !indexesToDrawMap[index]; });
  19346. this.removeRowComps(indexesNotToDraw);
  19347. };
  19348. RowRenderer.prototype.calculateIndexesToDraw = function (rowsToRecycle) {
  19349. var _this = this;
  19350. // all in all indexes in the viewport
  19351. var indexesToDraw = _utils__WEBPACK_IMPORTED_MODULE_8__["_"].createArrayOfNumbers(this.firstRenderedRow, this.lastRenderedRow);
  19352. var checkRowToDraw = function (indexStr, rowComp) {
  19353. var index = Number(indexStr);
  19354. if (index < _this.firstRenderedRow || index > _this.lastRenderedRow) {
  19355. if (_this.doNotUnVirtualiseRow(rowComp)) {
  19356. indexesToDraw.push(index);
  19357. }
  19358. }
  19359. };
  19360. // if we are redrawing due to scrolling change, then old rows are in this.rowCompsByIndex
  19361. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.rowCompsByIndex, checkRowToDraw);
  19362. // if we are redrawing due to model update, then old rows are in rowsToRecycle
  19363. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(rowsToRecycle, checkRowToDraw);
  19364. indexesToDraw.sort(function (a, b) { return a - b; });
  19365. return indexesToDraw;
  19366. };
  19367. RowRenderer.prototype.redraw = function (rowsToRecycle, animate, afterScroll) {
  19368. var _this = this;
  19369. if (animate === void 0) { animate = false; }
  19370. if (afterScroll === void 0) { afterScroll = false; }
  19371. this.maxDivHeightScaler.updateOffset();
  19372. this.workOutFirstAndLastRowsToRender();
  19373. // the row can already exist and be in the following:
  19374. // rowsToRecycle -> if model change, then the index may be different, however row may
  19375. // exist here from previous time (mapped by id).
  19376. // this.rowCompsByIndex -> if just a scroll, then this will contain what is currently in the viewport
  19377. // this is all the indexes we want, including those that already exist, so this method
  19378. // will end up going through each index and drawing only if the row doesn't already exist
  19379. var indexesToDraw = this.calculateIndexesToDraw(rowsToRecycle);
  19380. this.removeRowCompsNotToDraw(indexesToDraw);
  19381. // never animate when doing print layout - as we want to get things ready to print as quickly as possible,
  19382. // otherwise we risk the printer printing a row that's half faded (half way through fading in)
  19383. if (this.printLayout) {
  19384. animate = false;
  19385. }
  19386. // add in new rows
  19387. var nextVmTurnFunctions = [];
  19388. var rowComps = [];
  19389. indexesToDraw.forEach(function (rowIndex) {
  19390. var rowComp = _this.createOrUpdateRowComp(rowIndex, rowsToRecycle, animate, afterScroll);
  19391. if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(rowComp)) {
  19392. rowComps.push(rowComp);
  19393. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].pushAll(nextVmTurnFunctions, rowComp.getAndClearNextVMTurnFunctions());
  19394. }
  19395. });
  19396. this.flushContainers(rowComps);
  19397. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].executeNextVMTurn(nextVmTurnFunctions);
  19398. var useAnimationFrame = afterScroll && !this.gridOptionsWrapper.isSuppressAnimationFrame() && !this.printLayout;
  19399. if (useAnimationFrame) {
  19400. this.beans.taskQueue.addDestroyTask(this.destroyRowComps.bind(this, rowsToRecycle, animate));
  19401. }
  19402. else {
  19403. this.destroyRowComps(rowsToRecycle, animate);
  19404. }
  19405. this.checkAngularCompile();
  19406. this.gridPanel.updateRowCount();
  19407. };
  19408. RowRenderer.prototype.flushContainers = function (rowComps) {
  19409. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.rowContainers, function (key, rowContainerComp) {
  19410. if (rowContainerComp) {
  19411. rowContainerComp.flushRowTemplates();
  19412. }
  19413. });
  19414. rowComps.forEach(function (rowComp) { return rowComp.afterFlush(); });
  19415. };
  19416. RowRenderer.prototype.onDisplayedColumnsChanged = function () {
  19417. var pinningLeft = this.columnController.isPinningLeft();
  19418. var pinningRight = this.columnController.isPinningRight();
  19419. var atLeastOneChanged = this.pinningLeft !== pinningLeft || pinningRight !== this.pinningRight;
  19420. if (atLeastOneChanged) {
  19421. this.pinningLeft = pinningLeft;
  19422. this.pinningRight = pinningRight;
  19423. if (this.embedFullWidthRows) {
  19424. this.redrawFullWidthEmbeddedRows();
  19425. }
  19426. }
  19427. };
  19428. // when embedding, what gets showed in each section depends on what is pinned. eg if embedding group expand / collapse,
  19429. // then it should go into the pinned left area if pinning left, or the center area if not pinning.
  19430. RowRenderer.prototype.redrawFullWidthEmbeddedRows = function () {
  19431. // if either of the pinned panels has shown / hidden, then need to redraw the fullWidth bits when
  19432. // embedded, as what appears in each section depends on whether we are pinned or not
  19433. var rowsToRemove = [];
  19434. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.rowCompsByIndex, function (id, rowComp) {
  19435. if (rowComp.isFullWidth()) {
  19436. var rowIndex = rowComp.getRowNode().rowIndex;
  19437. rowsToRemove.push(rowIndex.toString());
  19438. }
  19439. });
  19440. this.refreshFloatingRowComps();
  19441. this.removeRowComps(rowsToRemove);
  19442. this.redrawAfterScroll();
  19443. };
  19444. RowRenderer.prototype.refreshFullWidthRows = function () {
  19445. var rowsToRemove = [];
  19446. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(this.rowCompsByIndex, function (id, rowComp) {
  19447. if (rowComp.isFullWidth()) {
  19448. var fullWidthRowsRefreshed = rowComp.refreshFullWidth();
  19449. if (!fullWidthRowsRefreshed) {
  19450. var rowIndex = rowComp.getRowNode().rowIndex;
  19451. rowsToRemove.push(rowIndex.toString());
  19452. }
  19453. }
  19454. });
  19455. this.removeRowComps(rowsToRemove);
  19456. this.redrawAfterScroll();
  19457. };
  19458. RowRenderer.prototype.createOrUpdateRowComp = function (rowIndex, rowsToRecycle, animate, afterScroll) {
  19459. var rowNode;
  19460. var rowComp = this.rowCompsByIndex[rowIndex];
  19461. // if no row comp, see if we can get it from the previous rowComps
  19462. if (!rowComp) {
  19463. rowNode = this.paginationProxy.getRow(rowIndex);
  19464. if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(rowNode) && _utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(rowsToRecycle) && rowsToRecycle[rowNode.id] && rowNode.alreadyRendered) {
  19465. rowComp = rowsToRecycle[rowNode.id];
  19466. rowsToRecycle[rowNode.id] = null;
  19467. }
  19468. }
  19469. var creatingNewRowComp = !rowComp;
  19470. if (creatingNewRowComp) {
  19471. // create a new one
  19472. if (!rowNode) {
  19473. rowNode = this.paginationProxy.getRow(rowIndex);
  19474. }
  19475. if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(rowNode)) {
  19476. rowComp = this.createRowComp(rowNode, animate, afterScroll);
  19477. }
  19478. else {
  19479. // this should never happen - if somehow we are trying to create
  19480. // a row for a rowNode that does not exist.
  19481. return;
  19482. }
  19483. }
  19484. else {
  19485. // ensure row comp is in right position in DOM
  19486. rowComp.ensureDomOrder();
  19487. }
  19488. if (rowNode) {
  19489. // set node as 'alreadyRendered' to ensure we only recycle rowComps that have been rendered, this ensures
  19490. // we don't reuse rowComps that have been removed and then re-added in the same batch transaction.
  19491. rowNode.alreadyRendered = true;
  19492. }
  19493. this.rowCompsByIndex[rowIndex] = rowComp;
  19494. return rowComp;
  19495. };
  19496. RowRenderer.prototype.destroyRowComps = function (rowCompsMap, animate) {
  19497. var delayedFuncs = [];
  19498. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].iterateObject(rowCompsMap, function (nodeId, rowComp) {
  19499. // if row was used, then it's null
  19500. if (!rowComp) {
  19501. return;
  19502. }
  19503. rowComp.destroy(animate);
  19504. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].pushAll(delayedFuncs, rowComp.getAndClearDelayedDestroyFunctions());
  19505. });
  19506. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].executeInAWhile(delayedFuncs);
  19507. };
  19508. RowRenderer.prototype.checkAngularCompile = function () {
  19509. var _this = this;
  19510. // if we are doing angular compiling, then do digest the scope here
  19511. if (this.gridOptionsWrapper.isAngularCompileRows()) {
  19512. // we do it in a timeout, in case we are already in an apply
  19513. window.setTimeout(function () {
  19514. _this.$scope.$apply();
  19515. }, 0);
  19516. }
  19517. };
  19518. RowRenderer.prototype.workOutFirstAndLastRowsToRender = function () {
  19519. var _this = this;
  19520. var newFirst;
  19521. var newLast;
  19522. if (!this.paginationProxy.isRowsToRender()) {
  19523. newFirst = 0;
  19524. newLast = -1; // setting to -1 means nothing in range
  19525. }
  19526. else if (this.printLayout) {
  19527. newFirst = this.paginationProxy.getPageFirstRow();
  19528. newLast = this.paginationProxy.getPageLastRow();
  19529. }
  19530. else {
  19531. var paginationOffset = this.paginationProxy.getPixelOffset();
  19532. var maxDivHeightScaler = this.maxDivHeightScaler.getOffset();
  19533. var bodyVRange = this.gridPanel.getVScrollPosition();
  19534. var bodyTopPixel = bodyVRange.top;
  19535. var bodyBottomPixel = bodyVRange.bottom;
  19536. var bufferPixels = this.gridOptionsWrapper.getRowBufferInPixels();
  19537. var firstPixel = bodyTopPixel + paginationOffset + maxDivHeightScaler - bufferPixels;
  19538. var lastPixel = bodyBottomPixel + paginationOffset + maxDivHeightScaler + bufferPixels;
  19539. this.ensureAllRowsInRangeHaveHeightsCalculated(firstPixel, lastPixel);
  19540. var firstRowIndex = this.paginationProxy.getRowIndexAtPixel(firstPixel);
  19541. var lastRowIndex = this.paginationProxy.getRowIndexAtPixel(lastPixel);
  19542. var pageFirstRow = this.paginationProxy.getPageFirstRow();
  19543. var pageLastRow = this.paginationProxy.getPageLastRow();
  19544. // adjust, in case buffer extended actual size
  19545. if (firstRowIndex < pageFirstRow) {
  19546. firstRowIndex = pageFirstRow;
  19547. }
  19548. if (lastRowIndex > pageLastRow) {
  19549. lastRowIndex = pageLastRow;
  19550. }
  19551. newFirst = firstRowIndex;
  19552. newLast = lastRowIndex;
  19553. }
  19554. // sometimes user doesn't set CSS right and ends up with grid with no height and grid ends up
  19555. // trying to render all the rows, eg 10,000+ rows. this will kill the browser. so instead of
  19556. // killing the browser, we limit the number of rows. just in case some use case we didn't think
  19557. // of, we also have a property to not do this operation.
  19558. var rowLayoutNormal = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].DOM_LAYOUT_NORMAL;
  19559. var suppressRowCountRestriction = this.gridOptionsWrapper.isSuppressMaxRenderedRowRestriction();
  19560. var rowBufferMaxSize = Math.max(this.gridOptionsWrapper.getRowBuffer(), 500);
  19561. if (rowLayoutNormal && !suppressRowCountRestriction) {
  19562. if (newLast - newFirst > rowBufferMaxSize) {
  19563. newLast = newFirst + rowBufferMaxSize;
  19564. }
  19565. }
  19566. var firstDiffers = newFirst !== this.firstRenderedRow;
  19567. var lastDiffers = newLast !== this.lastRenderedRow;
  19568. if (firstDiffers || lastDiffers) {
  19569. this.firstRenderedRow = newFirst;
  19570. this.lastRenderedRow = newLast;
  19571. var event_1 = {
  19572. type: _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_VIEWPORT_CHANGED,
  19573. firstRow: newFirst,
  19574. lastRow: newLast,
  19575. api: this.gridApi,
  19576. columnApi: this.columnApi
  19577. };
  19578. this.eventService.dispatchEvent(event_1);
  19579. }
  19580. // only dispatch firstDataRendered if we have actually rendered some data
  19581. if (this.paginationProxy.isRowsToRender()) {
  19582. var event_2 = {
  19583. type: _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_FIRST_DATA_RENDERED,
  19584. firstRow: newFirst,
  19585. lastRow: newLast,
  19586. api: this.gridApi,
  19587. columnApi: this.columnApi
  19588. };
  19589. // added a small delay here because in some scenarios this can be fired
  19590. // before the grid is actually rendered, causing component creation
  19591. // on EVENT_FIRST_DATA_RENDERED to fail.
  19592. window.setTimeout(function () { return _this.eventService.dispatchEventOnce(event_2); }, 50);
  19593. }
  19594. };
  19595. RowRenderer.prototype.ensureAllRowsInRangeHaveHeightsCalculated = function (topPixel, bottomPixel) {
  19596. // ensureRowHeightsVisible only works with CSRM, as it's the only row model that allows lazy row height calcs.
  19597. // all the other row models just hard code so the method just returns back false
  19598. var rowHeightsChanged = this.paginationProxy.ensureRowHeightsValid(topPixel, bottomPixel, -1, -1);
  19599. if (rowHeightsChanged) {
  19600. // if row heights have changed, we need to resize the containers the rows sit it
  19601. this.sizeContainerToPageHeight();
  19602. // we also need to update heightScaler as this has dependency of row container height
  19603. this.maxDivHeightScaler.updateOffset();
  19604. }
  19605. };
  19606. RowRenderer.prototype.getFirstVirtualRenderedRow = function () {
  19607. return this.firstRenderedRow;
  19608. };
  19609. RowRenderer.prototype.getLastVirtualRenderedRow = function () {
  19610. return this.lastRenderedRow;
  19611. };
  19612. // check that none of the rows to remove are editing or focused as:
  19613. // a) if editing, we want to keep them, otherwise the user will loose the context of the edit,
  19614. // eg user starts editing, enters some text, then scrolls down and then up, next time row rendered
  19615. // the edit is reset - so we want to keep it rendered.
  19616. // b) if focused, we want ot keep keyboard focus, so if user ctrl+c, it goes to clipboard,
  19617. // otherwise the user can range select and drag (with focus cell going out of the viewport)
  19618. // and then ctrl+c, nothing will happen if cell is removed from dom.
  19619. // c) if detail record of master detail, as users complained that the context of detail rows
  19620. // was getting lost when detail row out of view. eg user expands to show detail row,
  19621. // then manipulates the detail panel (eg sorts the detail grid), then context is lost
  19622. // after detail panel is scrolled out of / into view.
  19623. RowRenderer.prototype.doNotUnVirtualiseRow = function (rowComp) {
  19624. var REMOVE_ROW = false;
  19625. var KEEP_ROW = true;
  19626. var rowNode = rowComp.getRowNode();
  19627. var rowHasFocus = this.focusController.isRowNodeFocused(rowNode);
  19628. var rowIsEditing = rowComp.isEditing();
  19629. var rowIsDetail = rowNode.detail;
  19630. var mightWantToKeepRow = rowHasFocus || rowIsEditing || rowIsDetail;
  19631. // if we deffo don't want to keep it,
  19632. if (!mightWantToKeepRow) {
  19633. return REMOVE_ROW;
  19634. }
  19635. // editing row, only remove if it is no longer rendered, eg filtered out or new data set.
  19636. // the reason we want to keep is if user is scrolling up and down, we don't want to loose
  19637. // the context of the editing in process.
  19638. var rowNodePresent = this.paginationProxy.isRowPresent(rowNode);
  19639. return rowNodePresent ? KEEP_ROW : REMOVE_ROW;
  19640. };
  19641. RowRenderer.prototype.createRowComp = function (rowNode, animate, afterScroll) {
  19642. var suppressAnimationFrame = this.gridOptionsWrapper.isSuppressAnimationFrame();
  19643. // we don't use animations frames for printing, so the user can put the grid into print mode
  19644. // and immediately print - otherwise the user would have to wait for the rows to draw in the background
  19645. // (via the animation frames) which is awkward to do from code.
  19646. // we only do the animation frames after scrolling, as this is where we want the smooth user experience.
  19647. // having animation frames for other times makes the grid look 'jumpy'.
  19648. var useAnimationFrameForCreate = afterScroll && !suppressAnimationFrame && !this.printLayout;
  19649. var rowComp = new _rowComp__WEBPACK_IMPORTED_MODULE_1__["RowComp"](this.$scope, this.rowContainers.body, this.rowContainers.pinnedLeft, this.rowContainers.pinnedRight, this.rowContainers.fullWidth, rowNode, this.beans, animate, useAnimationFrameForCreate, this.printLayout, this.embedFullWidthRows);
  19650. rowComp.init();
  19651. return rowComp;
  19652. };
  19653. RowRenderer.prototype.getRenderedNodes = function () {
  19654. var renderedRows = this.rowCompsByIndex;
  19655. return Object.keys(renderedRows).map(function (key) { return renderedRows[key].getRowNode(); });
  19656. };
  19657. // we use index for rows, but column object for columns, as the next column (by index) might not
  19658. // be visible (header grouping) so it's not reliable, so using the column object instead.
  19659. RowRenderer.prototype.navigateToNextCell = function (event, key, currentCell, allowUserOverride) {
  19660. // we keep searching for a next cell until we find one. this is how the group rows get skipped
  19661. var nextCell = currentCell;
  19662. var hitEdgeOfGrid = false;
  19663. while (nextCell && (nextCell === currentCell || !this.isValidNavigateCell(nextCell))) {
  19664. // if the current cell is spanning across multiple columns, we need to move
  19665. // our current position to be the last cell on the right before finding the
  19666. // the next target.
  19667. if (this.gridOptionsWrapper.isEnableRtl()) {
  19668. if (key === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].KEY_LEFT) {
  19669. nextCell = this.getLastCellOfColSpan(nextCell);
  19670. }
  19671. }
  19672. else if (key === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].KEY_RIGHT) {
  19673. nextCell = this.getLastCellOfColSpan(nextCell);
  19674. }
  19675. nextCell = this.cellNavigationService.getNextCellToFocus(key, nextCell);
  19676. // eg if going down, and nextCell=undefined, means we are gone past the last row
  19677. hitEdgeOfGrid = _utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(nextCell);
  19678. }
  19679. if (hitEdgeOfGrid && event.keyCode === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].KEY_UP) {
  19680. nextCell = {
  19681. rowIndex: -1,
  19682. rowPinned: null,
  19683. column: currentCell.column
  19684. };
  19685. }
  19686. // allow user to override what cell to go to next. when doing normal cell navigation (with keys)
  19687. // we allow this, however if processing 'enter after edit' we don't allow override
  19688. if (allowUserOverride) {
  19689. var userFunc = this.gridOptionsWrapper.getNavigateToNextCellFunc();
  19690. if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(userFunc)) {
  19691. var params = {
  19692. key: key,
  19693. previousCellPosition: currentCell,
  19694. nextCellPosition: nextCell ? nextCell : null,
  19695. event: event
  19696. };
  19697. var userCell = userFunc(params);
  19698. if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(userCell)) {
  19699. if (userCell.floating) {
  19700. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].doOnce(function () { console.warn("ag-Grid: tabToNextCellFunc return type should have attributes: rowIndex, rowPinned, column. However you had 'floating', maybe you meant 'rowPinned'?"); }, 'no floating in userCell');
  19701. userCell.rowPinned = userCell.floating;
  19702. }
  19703. nextCell = {
  19704. rowPinned: userCell.rowPinned,
  19705. rowIndex: userCell.rowIndex,
  19706. column: userCell.column
  19707. };
  19708. }
  19709. else {
  19710. nextCell = null;
  19711. }
  19712. }
  19713. }
  19714. // no next cell means we have reached a grid boundary, eg left, right, top or bottom of grid
  19715. if (!nextCell) {
  19716. return;
  19717. }
  19718. if (nextCell.rowIndex < 0) {
  19719. var headerLen = this.beans.headerNavigationService.getHeaderRowCount();
  19720. this.focusController.focusHeaderPosition({
  19721. headerRowIndex: headerLen + (nextCell.rowIndex), column: currentCell.column
  19722. });
  19723. return;
  19724. }
  19725. // in case we have col spanning we get the cellComp and use it to
  19726. // get the position. This was we always focus the first cell inside
  19727. // the spanning.
  19728. this.ensureCellVisible(nextCell); // ensureCellVisible first, to make sure nextCell is rendered
  19729. var cellComp = this.getComponentForCell(nextCell);
  19730. // not guaranteed to have a cellComp when using the SSRM as blocks are loading.
  19731. if (!cellComp) {
  19732. return;
  19733. }
  19734. nextCell = cellComp.getCellPosition();
  19735. // we call this again, as nextCell can be different to it's previous value due to Column Spanning
  19736. // (ie if cursor moving from right to left, and cell is spanning columns, then nextCell was the
  19737. // last column in the group, however now it's the first column in the group). if we didn't do
  19738. // ensureCellVisible again, then we could only be showing the last portion (last column) of the
  19739. // merged cells.
  19740. this.ensureCellVisible(nextCell);
  19741. this.focusController.setFocusedCell(nextCell.rowIndex, nextCell.column, nextCell.rowPinned, true);
  19742. if (this.rangeController) {
  19743. this.rangeController.setRangeToCell(nextCell);
  19744. }
  19745. };
  19746. RowRenderer.prototype.isValidNavigateCell = function (cell) {
  19747. var rowNode = this.rowPositionUtils.getRowNode(cell);
  19748. // we do not allow focusing on detail rows and full width rows
  19749. if (rowNode.detail || rowNode.isFullWidthCell()) {
  19750. return false;
  19751. }
  19752. // if not a group, then we have a valid row, so quit the search
  19753. if (!rowNode.group) {
  19754. return true;
  19755. }
  19756. // full width rows cannot be focused, so if it's a group and using full width rows,
  19757. // we need to skip over the row
  19758. var pivotMode = this.columnController.isPivotMode();
  19759. var usingFullWidthRows = this.gridOptionsWrapper.isGroupUseEntireRow(pivotMode);
  19760. if (!usingFullWidthRows) {
  19761. return true;
  19762. }
  19763. return false;
  19764. };
  19765. RowRenderer.prototype.getLastCellOfColSpan = function (cell) {
  19766. var cellComp = this.getComponentForCell(cell);
  19767. if (!cellComp) {
  19768. return cell;
  19769. }
  19770. var colSpanningList = cellComp.getColSpanningList();
  19771. if (colSpanningList.length === 1) {
  19772. return cell;
  19773. }
  19774. return {
  19775. rowIndex: cell.rowIndex,
  19776. column: _utils__WEBPACK_IMPORTED_MODULE_8__["_"].last(colSpanningList),
  19777. rowPinned: cell.rowPinned
  19778. };
  19779. };
  19780. RowRenderer.prototype.ensureCellVisible = function (gridCell) {
  19781. // this scrolls the row into view
  19782. if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(gridCell.rowPinned)) {
  19783. this.gridPanel.ensureIndexVisible(gridCell.rowIndex);
  19784. }
  19785. if (!gridCell.column.isPinned()) {
  19786. this.gridPanel.ensureColumnVisible(gridCell.column);
  19787. }
  19788. // need to nudge the scrolls for the floating items. otherwise when we set focus on a non-visible
  19789. // floating cell, the scrolls get out of sync
  19790. this.gridPanel.horizontallyScrollHeaderCenterAndFloatingCenter();
  19791. // need to flush frames, to make sure the correct cells are rendered
  19792. this.animationFrameService.flushAllFrames();
  19793. };
  19794. RowRenderer.prototype.startEditingCell = function (gridCell, keyPress, charPress) {
  19795. var cell = this.getComponentForCell(gridCell);
  19796. if (cell) {
  19797. cell.startRowOrCellEdit(keyPress, charPress);
  19798. }
  19799. };
  19800. RowRenderer.prototype.getComponentForCell = function (cellPosition) {
  19801. var rowComponent;
  19802. switch (cellPosition.rowPinned) {
  19803. case _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_TOP:
  19804. rowComponent = this.floatingTopRowComps[cellPosition.rowIndex];
  19805. break;
  19806. case _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_BOTTOM:
  19807. rowComponent = this.floatingBottomRowComps[cellPosition.rowIndex];
  19808. break;
  19809. default:
  19810. rowComponent = this.rowCompsByIndex[cellPosition.rowIndex];
  19811. break;
  19812. }
  19813. if (!rowComponent) {
  19814. return null;
  19815. }
  19816. var cellComponent = rowComponent.getRenderedCellForColumn(cellPosition.column);
  19817. return cellComponent;
  19818. };
  19819. RowRenderer.prototype.getRowNode = function (gridRow) {
  19820. switch (gridRow.rowPinned) {
  19821. case _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_TOP:
  19822. return this.pinnedRowModel.getPinnedTopRowData()[gridRow.rowIndex];
  19823. case _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_BOTTOM:
  19824. return this.pinnedRowModel.getPinnedBottomRowData()[gridRow.rowIndex];
  19825. default:
  19826. return this.rowModel.getRow(gridRow.rowIndex);
  19827. }
  19828. };
  19829. RowRenderer.prototype.onTabKeyDown = function (previousRenderedCell, keyboardEvent) {
  19830. var backwards = keyboardEvent.shiftKey;
  19831. var success = this.moveToCellAfter(previousRenderedCell, backwards);
  19832. if (success) {
  19833. keyboardEvent.preventDefault();
  19834. }
  19835. else if (keyboardEvent.shiftKey) {
  19836. var cellPosition = previousRenderedCell.getCellPosition();
  19837. if (cellPosition.rowIndex === 0) {
  19838. keyboardEvent.preventDefault();
  19839. this.focusController.focusHeaderPosition({
  19840. headerRowIndex: this.beans.headerNavigationService.getHeaderRowCount() - 1,
  19841. column: _utils__WEBPACK_IMPORTED_MODULE_8__["_"].last(this.columnController.getAllDisplayedColumns())
  19842. });
  19843. }
  19844. }
  19845. };
  19846. RowRenderer.prototype.tabToNextCell = function (backwards) {
  19847. var focusedCell = this.focusController.getFocusedCell();
  19848. // if no focus, then cannot navigate
  19849. if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(focusedCell)) {
  19850. return false;
  19851. }
  19852. var renderedCell = this.getComponentForCell(focusedCell);
  19853. // if cell is not rendered, means user has scrolled away from the cell
  19854. if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(renderedCell)) {
  19855. return false;
  19856. }
  19857. var result = this.moveToCellAfter(renderedCell, backwards);
  19858. return result;
  19859. };
  19860. RowRenderer.prototype.moveToCellAfter = function (previousRenderedCell, backwards) {
  19861. var editing = previousRenderedCell.isEditing();
  19862. var res;
  19863. if (editing) {
  19864. if (this.gridOptionsWrapper.isFullRowEdit()) {
  19865. res = this.moveToNextEditingRow(previousRenderedCell, backwards);
  19866. }
  19867. else {
  19868. res = this.moveToNextEditingCell(previousRenderedCell, backwards);
  19869. }
  19870. }
  19871. else {
  19872. res = this.moveToNextCellNotEditing(previousRenderedCell, backwards);
  19873. }
  19874. return res;
  19875. };
  19876. RowRenderer.prototype.moveToNextEditingCell = function (previousRenderedCell, backwards) {
  19877. var gridCell = previousRenderedCell.getCellPosition();
  19878. // need to do this before getting next cell to edit, in case the next cell
  19879. // has editable function (eg colDef.editable=func() ) and it depends on the
  19880. // result of this cell, so need to save updates from the first edit, in case
  19881. // the value is referenced in the function.
  19882. previousRenderedCell.stopEditing();
  19883. // find the next cell to start editing
  19884. var nextRenderedCell = this.findNextCellToFocusOn(gridCell, backwards, true);
  19885. var foundCell = _utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(nextRenderedCell);
  19886. // only prevent default if we found a cell. so if user is on last cell and hits tab, then we default
  19887. // to the normal tabbing so user can exit the grid.
  19888. if (foundCell) {
  19889. nextRenderedCell.startEditingIfEnabled(null, null, true);
  19890. nextRenderedCell.focusCell(false);
  19891. }
  19892. return foundCell;
  19893. };
  19894. RowRenderer.prototype.moveToNextEditingRow = function (previousRenderedCell, backwards) {
  19895. var gridCell = previousRenderedCell.getCellPosition();
  19896. // find the next cell to start editing
  19897. var nextRenderedCell = this.findNextCellToFocusOn(gridCell, backwards, true);
  19898. var foundCell = _utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(nextRenderedCell);
  19899. // only prevent default if we found a cell. so if user is on last cell and hits tab, then we default
  19900. // to the normal tabbing so user can exit the grid.
  19901. if (foundCell) {
  19902. this.moveEditToNextCellOrRow(previousRenderedCell, nextRenderedCell);
  19903. }
  19904. return foundCell;
  19905. };
  19906. RowRenderer.prototype.moveToNextCellNotEditing = function (previousRenderedCell, backwards) {
  19907. var gridCell = previousRenderedCell.getCellPosition();
  19908. // find the next cell to start editing
  19909. var nextRenderedCell = this.findNextCellToFocusOn(gridCell, backwards, false);
  19910. var foundCell = _utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(nextRenderedCell);
  19911. // only prevent default if we found a cell. so if user is on last cell and hits tab, then we default
  19912. // to the normal tabbing so user can exit the grid.
  19913. if (foundCell) {
  19914. nextRenderedCell.focusCell(true);
  19915. }
  19916. return foundCell;
  19917. };
  19918. RowRenderer.prototype.moveEditToNextCellOrRow = function (previousRenderedCell, nextRenderedCell) {
  19919. var pGridCell = previousRenderedCell.getCellPosition();
  19920. var nGridCell = nextRenderedCell.getCellPosition();
  19921. var rowsMatch = pGridCell.rowIndex === nGridCell.rowIndex && pGridCell.rowPinned === nGridCell.rowPinned;
  19922. if (rowsMatch) {
  19923. // same row, so we don't start / stop editing, we just move the focus along
  19924. previousRenderedCell.setFocusOutOnEditor();
  19925. nextRenderedCell.setFocusInOnEditor();
  19926. }
  19927. else {
  19928. var pRow = previousRenderedCell.getRenderedRow();
  19929. var nRow = nextRenderedCell.getRenderedRow();
  19930. previousRenderedCell.setFocusOutOnEditor();
  19931. pRow.stopEditing();
  19932. nRow.startRowEditing();
  19933. nextRenderedCell.setFocusInOnEditor();
  19934. }
  19935. nextRenderedCell.focusCell();
  19936. };
  19937. // called by the cell, when tab is pressed while editing.
  19938. // @return: RenderedCell when navigation successful, otherwise null
  19939. RowRenderer.prototype.findNextCellToFocusOn = function (gridCell, backwards, startEditing) {
  19940. var nextCell = gridCell;
  19941. while (true) {
  19942. if (!backwards) {
  19943. nextCell = this.getLastCellOfColSpan(nextCell);
  19944. }
  19945. nextCell = this.cellNavigationService.getNextTabbedCell(nextCell, backwards);
  19946. // allow user to override what cell to go to next
  19947. var userFunc = this.gridOptionsWrapper.getTabToNextCellFunc();
  19948. if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(userFunc)) {
  19949. var params = {
  19950. backwards: backwards,
  19951. editing: startEditing,
  19952. previousCellPosition: gridCell,
  19953. nextCellPosition: nextCell ? nextCell : null
  19954. };
  19955. var userCell = userFunc(params);
  19956. if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].exists(userCell)) {
  19957. if (userCell.floating) {
  19958. _utils__WEBPACK_IMPORTED_MODULE_8__["_"].doOnce(function () { console.warn("ag-Grid: tabToNextCellFunc return type should have attributes: rowIndex, rowPinned, column. However you had 'floating', maybe you meant 'rowPinned'?"); }, 'no floating in userCell');
  19959. userCell.rowPinned = userCell.floating;
  19960. }
  19961. nextCell = {
  19962. rowIndex: userCell.rowIndex,
  19963. column: userCell.column,
  19964. rowPinned: userCell.rowPinned
  19965. };
  19966. }
  19967. else {
  19968. nextCell = null;
  19969. }
  19970. }
  19971. // if no 'next cell', means we have got to last cell of grid, so nothing to move to,
  19972. // so bottom right cell going forwards, or top left going backwards
  19973. if (!nextCell) {
  19974. return null;
  19975. }
  19976. // if editing, but cell not editable, skip cell. we do this before we do all of
  19977. // the 'ensure index visible' and 'flush all frames', otherwise if we are skipping
  19978. // a bunch of cells (eg 10 rows) then all the work on ensuring cell visible is useless
  19979. // (except for the last one) which causes grid to stall for a while.
  19980. if (startEditing) {
  19981. var rowNode = this.lookupRowNodeForCell(nextCell);
  19982. var cellIsEditable = nextCell.column.isCellEditable(rowNode);
  19983. if (!cellIsEditable) {
  19984. continue;
  19985. }
  19986. }
  19987. // this scrolls the row into view
  19988. var cellIsNotFloating = _utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(nextCell.rowPinned);
  19989. if (cellIsNotFloating) {
  19990. this.gridPanel.ensureIndexVisible(nextCell.rowIndex);
  19991. }
  19992. // pinned columns don't scroll, so no need to ensure index visible
  19993. if (!nextCell.column.isPinned()) {
  19994. this.gridPanel.ensureColumnVisible(nextCell.column);
  19995. }
  19996. // need to nudge the scrolls for the floating items. otherwise when we set focus on a non-visible
  19997. // floating cell, the scrolls get out of sync
  19998. this.gridPanel.horizontallyScrollHeaderCenterAndFloatingCenter();
  19999. // get the grid panel to flush all animation frames - otherwise the call below to get the cellComp
  20000. // could fail, if we just scrolled the grid (to make a cell visible) and the rendering hasn't finished.
  20001. this.animationFrameService.flushAllFrames();
  20002. // we have to call this after ensureColumnVisible - otherwise it could be a virtual column
  20003. // or row that is not currently in view, hence the renderedCell would not exist
  20004. var nextCellComp = this.getComponentForCell(nextCell);
  20005. // if next cell is fullWidth row, then no rendered cell,
  20006. // as fullWidth rows have no cells, so we skip it
  20007. if (_utils__WEBPACK_IMPORTED_MODULE_8__["_"].missing(nextCellComp)) {
  20008. continue;
  20009. }
  20010. if (nextCellComp.isSuppressNavigable()) {
  20011. continue;
  20012. }
  20013. // by default, when we click a cell, it gets selected into a range, so to keep keyboard navigation
  20014. // consistent, we set into range here also.
  20015. if (this.rangeController) {
  20016. this.rangeController.setRangeToCell(nextCell);
  20017. }
  20018. // we successfully tabbed onto a grid cell, so return true
  20019. return nextCellComp;
  20020. }
  20021. };
  20022. RowRenderer.prototype.lookupRowNodeForCell = function (cell) {
  20023. if (cell.rowPinned === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_TOP) {
  20024. return this.pinnedRowModel.getPinnedTopRow(cell.rowIndex);
  20025. }
  20026. if (cell.rowPinned === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_BOTTOM) {
  20027. return this.pinnedRowModel.getPinnedBottomRow(cell.rowIndex);
  20028. }
  20029. return this.paginationProxy.getRow(cell.rowIndex);
  20030. };
  20031. __decorate([
  20032. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("paginationProxy")
  20033. ], RowRenderer.prototype, "paginationProxy", void 0);
  20034. __decorate([
  20035. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("columnController")
  20036. ], RowRenderer.prototype, "columnController", void 0);
  20037. __decorate([
  20038. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("gridOptionsWrapper")
  20039. ], RowRenderer.prototype, "gridOptionsWrapper", void 0);
  20040. __decorate([
  20041. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("$scope")
  20042. ], RowRenderer.prototype, "$scope", void 0);
  20043. __decorate([
  20044. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("pinnedRowModel")
  20045. ], RowRenderer.prototype, "pinnedRowModel", void 0);
  20046. __decorate([
  20047. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("rowModel")
  20048. ], RowRenderer.prototype, "rowModel", void 0);
  20049. __decorate([
  20050. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("loggerFactory")
  20051. ], RowRenderer.prototype, "loggerFactory", void 0);
  20052. __decorate([
  20053. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("focusController")
  20054. ], RowRenderer.prototype, "focusController", void 0);
  20055. __decorate([
  20056. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("cellNavigationService")
  20057. ], RowRenderer.prototype, "cellNavigationService", void 0);
  20058. __decorate([
  20059. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("columnApi")
  20060. ], RowRenderer.prototype, "columnApi", void 0);
  20061. __decorate([
  20062. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("gridApi")
  20063. ], RowRenderer.prototype, "gridApi", void 0);
  20064. __decorate([
  20065. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("beans")
  20066. ], RowRenderer.prototype, "beans", void 0);
  20067. __decorate([
  20068. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("maxDivHeightScaler")
  20069. ], RowRenderer.prototype, "maxDivHeightScaler", void 0);
  20070. __decorate([
  20071. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("animationFrameService")
  20072. ], RowRenderer.prototype, "animationFrameService", void 0);
  20073. __decorate([
  20074. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Autowired"])("rowPositionUtils")
  20075. ], RowRenderer.prototype, "rowPositionUtils", void 0);
  20076. __decorate([
  20077. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Optional"])("rangeController")
  20078. ], RowRenderer.prototype, "rangeController", void 0);
  20079. __decorate([
  20080. __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Qualifier"])("loggerFactory"))
  20081. ], RowRenderer.prototype, "agWire", null);
  20082. RowRenderer = __decorate([
  20083. Object(_context_context__WEBPACK_IMPORTED_MODULE_6__["Bean"])("rowRenderer")
  20084. ], RowRenderer);
  20085. return RowRenderer;
  20086. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_7__["BeanStub"]));
  20087. /***/ }),
  20088. /* 100 */
  20089. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  20090. "use strict";
  20091. __webpack_require__.r(__webpack_exports__);
  20092. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowComp", function() { return RowComp; });
  20093. /* harmony import */ var _cellComp__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(101);
  20094. /* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(68);
  20095. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43);
  20096. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(56);
  20097. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(25);
  20098. /* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(38);
  20099. /* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(39);
  20100. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(7);
  20101. /**
  20102. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  20103. * @version v23.2.1
  20104. * @link http://www.ag-grid.com/
  20105. * @license MIT
  20106. */
  20107. var __extends = (undefined && undefined.__extends) || (function () {
  20108. var extendStatics = function (d, b) {
  20109. extendStatics = Object.setPrototypeOf ||
  20110. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  20111. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  20112. return extendStatics(d, b);
  20113. };
  20114. return function (d, b) {
  20115. extendStatics(d, b);
  20116. function __() { this.constructor = d; }
  20117. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  20118. };
  20119. })();
  20120. var __assign = (undefined && undefined.__assign) || function () {
  20121. __assign = Object.assign || function(t) {
  20122. for (var s, i = 1, n = arguments.length; i < n; i++) {
  20123. s = arguments[i];
  20124. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
  20125. t[p] = s[p];
  20126. }
  20127. return t;
  20128. };
  20129. return __assign.apply(this, arguments);
  20130. };
  20131. var RowComp = /** @class */ (function (_super) {
  20132. __extends(RowComp, _super);
  20133. function RowComp(parentScope, bodyContainerComp, pinnedLeftContainerComp, pinnedRightContainerComp, fullWidthContainerComp, rowNode, beans, animateIn, useAnimationFrameForCreate, printLayout, embedFullWidth) {
  20134. var _this = _super.call(this) || this;
  20135. _this.eAllRowContainers = [];
  20136. _this.active = true;
  20137. _this.rowContainerReadyCount = 0;
  20138. _this.refreshNeeded = false;
  20139. _this.columnRefreshPending = false;
  20140. _this.cellComps = {};
  20141. // for animations, there are bits we want done in the next VM turn, to all DOM to update first.
  20142. // instead of each row doing a setTimeout(func,0), we put the functions here and the rowRenderer
  20143. // executes them all in one timeout
  20144. _this.createSecondPassFuncs = [];
  20145. // these get called before the row is destroyed - they set up the DOM for the remove animation (ie they
  20146. // set the DOM up for the animation), then the delayedDestroyFunctions get called when the animation is
  20147. // complete (ie removes from the dom).
  20148. _this.removeFirstPassFuncs = [];
  20149. // for animations, these functions get called 400ms after the row is cleared, called by the rowRenderer
  20150. // so each row isn't setting up it's own timeout
  20151. _this.removeSecondPassFuncs = [];
  20152. _this.initialised = false;
  20153. _this.elementOrderChanged = false;
  20154. _this.lastMouseDownOnDragger = false;
  20155. _this.parentScope = parentScope;
  20156. _this.beans = beans;
  20157. _this.bodyContainerComp = bodyContainerComp;
  20158. _this.pinnedLeftContainerComp = pinnedLeftContainerComp;
  20159. _this.pinnedRightContainerComp = pinnedRightContainerComp;
  20160. _this.fullWidthContainerComp = fullWidthContainerComp;
  20161. _this.rowNode = rowNode;
  20162. _this.rowIsEven = _this.rowNode.rowIndex % 2 === 0;
  20163. _this.paginationPage = _this.beans.paginationProxy.getCurrentPage();
  20164. _this.useAnimationFrameForCreate = useAnimationFrameForCreate;
  20165. _this.printLayout = printLayout;
  20166. _this.embedFullWidth = embedFullWidth;
  20167. _this.setAnimateFlags(animateIn);
  20168. return _this;
  20169. }
  20170. RowComp.prototype.init = function () {
  20171. var _this = this;
  20172. this.rowFocused = this.beans.focusController.isRowFocused(this.rowNode.rowIndex, this.rowNode.rowPinned);
  20173. this.scope = this.createChildScopeOrNull(this.rowNode.data);
  20174. this.setupRowContainers();
  20175. this.addListeners();
  20176. if (this.slideRowIn) {
  20177. this.createSecondPassFuncs.push(function () {
  20178. _this.onTopChanged();
  20179. });
  20180. }
  20181. if (this.fadeRowIn) {
  20182. this.createSecondPassFuncs.push(function () {
  20183. _this.eAllRowContainers.forEach(function (eRow) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(eRow, 'ag-opacity-zero'); });
  20184. });
  20185. }
  20186. };
  20187. RowComp.prototype.createTemplate = function (contents, extraCssClass) {
  20188. if (extraCssClass === void 0) { extraCssClass = null; }
  20189. var templateParts = [];
  20190. var rowHeight = this.rowNode.rowHeight;
  20191. var rowClasses = this.getInitialRowClasses(extraCssClass).join(' ');
  20192. var rowIdSanitised = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].escape(this.rowNode.id);
  20193. var userRowStyles = this.preProcessStylesFromGridOptions();
  20194. var businessKey = this.getRowBusinessKey();
  20195. var businessKeySanitised = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].escape(businessKey);
  20196. var rowTopStyle = this.getInitialRowTopStyle();
  20197. var rowIdx = this.rowNode.getRowIndexString();
  20198. var headerRowCount = this.beans.headerNavigationService.getHeaderRowCount();
  20199. templateParts.push("<div");
  20200. templateParts.push(" role=\"row\"");
  20201. templateParts.push(" row-index=\"" + rowIdx + "\" aria-rowindex=\"" + (headerRowCount + this.rowNode.rowIndex + 1) + "\"");
  20202. templateParts.push(rowIdSanitised ? " row-id=\"" + rowIdSanitised + "\"" : "");
  20203. templateParts.push(businessKey ? " row-business-key=\"" + businessKeySanitised + "\"" : "");
  20204. templateParts.push(" comp-id=\"" + this.getCompId() + "\"");
  20205. templateParts.push(" class=\"" + rowClasses + "\"");
  20206. templateParts.push(" style=\"height: " + rowHeight + "px; " + rowTopStyle + " " + userRowStyles + "\">");
  20207. // add in the template for the cells
  20208. templateParts.push(contents);
  20209. templateParts.push("</div>");
  20210. return templateParts.join('');
  20211. };
  20212. RowComp.prototype.getCellForCol = function (column) {
  20213. var cellComp = this.cellComps[column.getColId()];
  20214. return cellComp ? cellComp.getGui() : null;
  20215. };
  20216. RowComp.prototype.afterFlush = function () {
  20217. if (this.initialised) {
  20218. return;
  20219. }
  20220. this.initialised = true;
  20221. this.executeProcessRowPostCreateFunc();
  20222. };
  20223. RowComp.prototype.executeProcessRowPostCreateFunc = function () {
  20224. var func = this.beans.gridOptionsWrapper.getProcessRowPostCreateFunc();
  20225. if (!func) {
  20226. return;
  20227. }
  20228. var params = {
  20229. eRow: this.eBodyRow,
  20230. ePinnedLeftRow: this.ePinnedLeftRow,
  20231. ePinnedRightRow: this.ePinnedRightRow,
  20232. node: this.rowNode,
  20233. api: this.beans.gridOptionsWrapper.getApi(),
  20234. rowIndex: this.rowNode.rowIndex,
  20235. addRenderedRowListener: this.addEventListener.bind(this),
  20236. columnApi: this.beans.gridOptionsWrapper.getColumnApi(),
  20237. context: this.beans.gridOptionsWrapper.getContext()
  20238. };
  20239. func(params);
  20240. };
  20241. RowComp.prototype.getInitialRowTopStyle = function () {
  20242. // print layout uses normal flow layout for row positioning
  20243. if (this.printLayout) {
  20244. return '';
  20245. }
  20246. // if sliding in, we take the old row top. otherwise we just set the current row top.
  20247. var pixels = this.slideRowIn ? this.roundRowTopToBounds(this.rowNode.oldRowTop) : this.rowNode.rowTop;
  20248. var afterPaginationPixels = this.applyPaginationOffset(pixels);
  20249. var afterScalingPixels = this.beans.maxDivHeightScaler.getRealPixelPosition(afterPaginationPixels);
  20250. var isSuppressRowTransform = this.beans.gridOptionsWrapper.isSuppressRowTransform();
  20251. return isSuppressRowTransform ? "top: " + afterScalingPixels + "px; " : "transform: translateY(" + afterScalingPixels + "px);";
  20252. };
  20253. RowComp.prototype.getRowBusinessKey = function () {
  20254. var businessKeyForNodeFunc = this.beans.gridOptionsWrapper.getBusinessKeyForNodeFunc();
  20255. if (typeof businessKeyForNodeFunc !== 'function') {
  20256. return;
  20257. }
  20258. return businessKeyForNodeFunc(this.rowNode);
  20259. };
  20260. RowComp.prototype.areAllContainersReady = function () {
  20261. return this.rowContainerReadyCount === 3;
  20262. };
  20263. RowComp.prototype.lazyCreateCells = function (cols, eRow) {
  20264. if (!this.active) {
  20265. return;
  20266. }
  20267. var cellTemplatesAndComps = this.createCells(cols);
  20268. eRow.innerHTML = cellTemplatesAndComps.template;
  20269. this.callAfterRowAttachedOnCells(cellTemplatesAndComps.cellComps, eRow);
  20270. this.rowContainerReadyCount++;
  20271. if (this.areAllContainersReady() && this.refreshNeeded) {
  20272. this.refreshCells();
  20273. }
  20274. };
  20275. RowComp.prototype.createRowContainer = function (rowContainerComp, cols, callback) {
  20276. var _this = this;
  20277. var useAnimationsFrameForCreate = this.useAnimationFrameForCreate;
  20278. var cellTemplatesAndComps = useAnimationsFrameForCreate ? { cellComps: [], template: '' } : this.createCells(cols);
  20279. var rowTemplate = this.createTemplate(cellTemplatesAndComps.template);
  20280. // the RowRenderer is probably inserting many rows. rather than inserting each template one
  20281. // at a time, the grid inserts all rows together - so the callback here is called by the
  20282. // rowRenderer when all RowComps are created, then all the HTML is inserted in one go,
  20283. // and then all the callbacks are called. this is NOT done in an animation frame.
  20284. rowContainerComp.appendRowTemplate(rowTemplate, function () {
  20285. var eRow = rowContainerComp.getRowElement(_this.getCompId());
  20286. _this.afterRowAttached(rowContainerComp, eRow);
  20287. callback(eRow);
  20288. if (useAnimationsFrameForCreate) {
  20289. _this.beans.taskQueue.createTask(_this.lazyCreateCells.bind(_this, cols, eRow), _this.rowNode.rowIndex, 'createTasksP1');
  20290. }
  20291. else {
  20292. _this.callAfterRowAttachedOnCells(cellTemplatesAndComps.cellComps, eRow);
  20293. _this.rowContainerReadyCount = 3;
  20294. }
  20295. });
  20296. };
  20297. RowComp.prototype.createChildScopeOrNull = function (data) {
  20298. var isAngularCompileRows = this.beans.gridOptionsWrapper.isAngularCompileRows();
  20299. if (!isAngularCompileRows) {
  20300. return null;
  20301. }
  20302. var newChildScope = this.parentScope.$new();
  20303. newChildScope.data = __assign({}, data);
  20304. newChildScope.rowNode = this.rowNode;
  20305. newChildScope.context = this.beans.gridOptionsWrapper.getContext();
  20306. this.addDestroyFunc(function () {
  20307. newChildScope.$destroy();
  20308. newChildScope.data = null;
  20309. newChildScope.rowNode = null;
  20310. newChildScope.context = null;
  20311. });
  20312. return newChildScope;
  20313. };
  20314. RowComp.prototype.setupRowContainers = function () {
  20315. var isFullWidthCell = this.rowNode.isFullWidthCell();
  20316. var isDetailCell = this.beans.doingMasterDetail && this.rowNode.detail;
  20317. var pivotMode = this.beans.columnController.isPivotMode();
  20318. // we only use full width for groups, not footers. it wouldn't make sense to include footers if not looking
  20319. // for totals. if users complain about this, then we should introduce a new property 'footerUseEntireRow'
  20320. // so each can be set independently (as a customer complained about footers getting full width, hence
  20321. // introducing this logic)
  20322. var isGroupRow = this.rowNode.group && !this.rowNode.footer;
  20323. var isFullWidthGroup = isGroupRow && this.beans.gridOptionsWrapper.isGroupUseEntireRow(pivotMode);
  20324. if (this.rowNode.stub) {
  20325. this.createFullWidthRows(RowComp.LOADING_CELL_RENDERER, RowComp.LOADING_CELL_RENDERER_COMP_NAME);
  20326. }
  20327. else if (isDetailCell) {
  20328. this.createFullWidthRows(RowComp.DETAIL_CELL_RENDERER, RowComp.DETAIL_CELL_RENDERER_COMP_NAME);
  20329. }
  20330. else if (isFullWidthCell) {
  20331. this.createFullWidthRows(RowComp.FULL_WIDTH_CELL_RENDERER, null);
  20332. }
  20333. else if (isFullWidthGroup) {
  20334. this.createFullWidthRows(RowComp.GROUP_ROW_RENDERER, RowComp.GROUP_ROW_RENDERER_COMP_NAME);
  20335. }
  20336. else {
  20337. this.setupNormalRowContainers();
  20338. }
  20339. };
  20340. RowComp.prototype.setupNormalRowContainers = function () {
  20341. var _this = this;
  20342. var centerCols;
  20343. var leftCols = [];
  20344. var rightCols = [];
  20345. if (this.printLayout) {
  20346. centerCols = this.beans.columnController.getAllDisplayedColumns();
  20347. }
  20348. else {
  20349. centerCols = this.beans.columnController.getAllDisplayedCenterVirtualColumnsForRow(this.rowNode);
  20350. leftCols = this.beans.columnController.getDisplayedLeftColumnsForRow(this.rowNode);
  20351. rightCols = this.beans.columnController.getDisplayedRightColumnsForRow(this.rowNode);
  20352. }
  20353. this.createRowContainer(this.bodyContainerComp, centerCols, function (eRow) { return _this.eBodyRow = eRow; });
  20354. this.createRowContainer(this.pinnedRightContainerComp, rightCols, function (eRow) { return _this.ePinnedRightRow = eRow; });
  20355. this.createRowContainer(this.pinnedLeftContainerComp, leftCols, function (eRow) { return _this.ePinnedLeftRow = eRow; });
  20356. };
  20357. RowComp.prototype.createFullWidthRows = function (type, name) {
  20358. var _this = this;
  20359. this.fullWidthRow = true;
  20360. if (this.embedFullWidth) {
  20361. this.createFullWidthRowContainer(this.bodyContainerComp, null, null, type, name, function (eRow) {
  20362. _this.eFullWidthRowBody = eRow;
  20363. }, function (cellRenderer) {
  20364. _this.fullWidthRowComponentBody = cellRenderer;
  20365. });
  20366. // printLayout doesn't put components into the pinned sections
  20367. if (this.printLayout) {
  20368. return;
  20369. }
  20370. this.createFullWidthRowContainer(this.pinnedLeftContainerComp, _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_LEFT, 'ag-cell-last-left-pinned', type, name, function (eRow) {
  20371. _this.eFullWidthRowLeft = eRow;
  20372. }, function (cellRenderer) {
  20373. _this.fullWidthRowComponentLeft = cellRenderer;
  20374. });
  20375. this.createFullWidthRowContainer(this.pinnedRightContainerComp, _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_RIGHT, 'ag-cell-first-right-pinned', type, name, function (eRow) {
  20376. _this.eFullWidthRowRight = eRow;
  20377. }, function (cellRenderer) {
  20378. _this.fullWidthRowComponentRight = cellRenderer;
  20379. });
  20380. }
  20381. else {
  20382. // otherwise we add to the fullWidth container as normal
  20383. // let previousFullWidth = ensureDomOrder ? this.lastPlacedElements.eFullWidth : null;
  20384. this.createFullWidthRowContainer(this.fullWidthContainerComp, null, null, type, name, function (eRow) {
  20385. _this.eFullWidthRow = eRow;
  20386. }, function (cellRenderer) {
  20387. _this.fullWidthRowComponent = cellRenderer;
  20388. });
  20389. }
  20390. };
  20391. RowComp.prototype.setAnimateFlags = function (animateIn) {
  20392. if (animateIn) {
  20393. var oldRowTopExists = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(this.rowNode.oldRowTop);
  20394. // if the row had a previous position, we slide it in (animate row top)
  20395. this.slideRowIn = oldRowTopExists;
  20396. // if the row had no previous position, we fade it in (animate
  20397. this.fadeRowIn = !oldRowTopExists;
  20398. }
  20399. else {
  20400. this.slideRowIn = false;
  20401. this.fadeRowIn = false;
  20402. }
  20403. };
  20404. RowComp.prototype.isEditing = function () {
  20405. return this.editingRow;
  20406. };
  20407. RowComp.prototype.stopRowEditing = function (cancel) {
  20408. this.stopEditing(cancel);
  20409. };
  20410. RowComp.prototype.isFullWidth = function () {
  20411. return this.fullWidthRow;
  20412. };
  20413. RowComp.prototype.refreshFullWidth = function () {
  20414. var _this = this;
  20415. // returns 'true' if refresh succeeded
  20416. var tryRefresh = function (eRow, eCellComp, pinned) {
  20417. if (!eRow || !eCellComp) {
  20418. return true;
  20419. } // no refresh needed
  20420. // no refresh method present, so can't refresh, hard refresh needed
  20421. if (!eCellComp.refresh) {
  20422. return false;
  20423. }
  20424. var params = _this.createFullWidthParams(eRow, pinned);
  20425. var refreshSucceeded = eCellComp.refresh(params);
  20426. return refreshSucceeded;
  20427. };
  20428. var normalSuccess = tryRefresh(this.eFullWidthRow, this.fullWidthRowComponent, null);
  20429. var bodySuccess = tryRefresh(this.eFullWidthRowBody, this.fullWidthRowComponentBody, null);
  20430. var leftSuccess = tryRefresh(this.eFullWidthRowLeft, this.fullWidthRowComponentLeft, _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_LEFT);
  20431. var rightSuccess = tryRefresh(this.eFullWidthRowRight, this.fullWidthRowComponentRight, _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_RIGHT);
  20432. var allFullWidthRowsRefreshed = normalSuccess && bodySuccess && leftSuccess && rightSuccess;
  20433. return allFullWidthRowsRefreshed;
  20434. };
  20435. RowComp.prototype.addListeners = function () {
  20436. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_HEIGHT_CHANGED, this.onRowHeightChanged.bind(this));
  20437. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_ROW_SELECTED, this.onRowSelected.bind(this));
  20438. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_ROW_INDEX_CHANGED, this.onRowIndexChanged.bind(this));
  20439. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_TOP_CHANGED, this.onTopChanged.bind(this));
  20440. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_EXPANDED_CHANGED, this.onExpandedChanged.bind(this));
  20441. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_DATA_CHANGED, this.onRowNodeDataChanged.bind(this));
  20442. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_CELL_CHANGED, this.onRowNodeCellChanged.bind(this));
  20443. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_HIGHLIGHT_CHANGED, this.onRowNodeHighlightChanged.bind(this));
  20444. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_DRAGGING_CHANGED, this.onRowNodeDraggingChanged.bind(this));
  20445. var eventService = this.beans.eventService;
  20446. this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_HEIGHT_SCALE_CHANGED, this.onTopChanged.bind(this));
  20447. this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this));
  20448. this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_VIRTUAL_COLUMNS_CHANGED, this.onVirtualColumnsChanged.bind(this));
  20449. this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_RESIZED, this.onColumnResized.bind(this));
  20450. this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_CELL_FOCUSED, this.onCellFocusChanged.bind(this));
  20451. this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_PAGINATION_CHANGED, this.onPaginationChanged.bind(this));
  20452. this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_MODEL_UPDATED, this.onModelUpdated.bind(this));
  20453. this.addManagedListener(eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_MOVED, this.onColumnMoved.bind(this));
  20454. this.addListenersForCellComps();
  20455. };
  20456. RowComp.prototype.addListenersForCellComps = function () {
  20457. var _this = this;
  20458. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_ROW_INDEX_CHANGED, function () {
  20459. _this.forEachCellComp(function (cellComp) { return cellComp.onRowIndexChanged(); });
  20460. });
  20461. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_CELL_CHANGED, function (event) {
  20462. _this.forEachCellComp(function (cellComp) { return cellComp.onCellChanged(event); });
  20463. });
  20464. };
  20465. RowComp.prototype.onRowNodeDataChanged = function (event) {
  20466. // if this is an update, we want to refresh, as this will allow the user to put in a transition
  20467. // into the cellRenderer refresh method. otherwise this might be completely new data, in which case
  20468. // we will want to completely replace the cells
  20469. this.forEachCellComp(function (cellComp) {
  20470. return cellComp.refreshCell({
  20471. suppressFlash: !event.update,
  20472. newData: !event.update
  20473. });
  20474. });
  20475. // check for selected also, as this could be after lazy loading of the row data, in which case
  20476. // the id might of just gotten set inside the row and the row selected state may of changed
  20477. // as a result. this is what happens when selected rows are loaded in virtual pagination.
  20478. // - niall note - since moving to the stub component, this may no longer be true, as replacing
  20479. // the stub component now replaces the entire row
  20480. this.onRowSelected();
  20481. // as data has changed, then the style and class needs to be recomputed
  20482. this.postProcessCss();
  20483. };
  20484. RowComp.prototype.onRowNodeCellChanged = function () {
  20485. // as data has changed, then the style and class needs to be recomputed
  20486. this.postProcessCss();
  20487. };
  20488. RowComp.prototype.postProcessCss = function () {
  20489. this.postProcessStylesFromGridOptions();
  20490. this.postProcessClassesFromGridOptions();
  20491. this.postProcessRowClassRules();
  20492. this.postProcessRowDragging();
  20493. };
  20494. RowComp.prototype.onRowNodeHighlightChanged = function () {
  20495. var highlighted = this.rowNode.highlighted;
  20496. this.eAllRowContainers.forEach(function (row) {
  20497. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(row, 'ag-row-highlight-above');
  20498. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(row, 'ag-row-highlight-below');
  20499. if (highlighted) {
  20500. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(row, 'ag-row-highlight-' + highlighted);
  20501. }
  20502. });
  20503. };
  20504. RowComp.prototype.onRowNodeDraggingChanged = function () {
  20505. this.postProcessRowDragging();
  20506. };
  20507. RowComp.prototype.postProcessRowDragging = function () {
  20508. var dragging = this.rowNode.dragging;
  20509. this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(row, 'ag-row-dragging', dragging); });
  20510. };
  20511. RowComp.prototype.onExpandedChanged = function () {
  20512. var rowNode = this.rowNode;
  20513. this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(row, 'ag-row-group-expanded', rowNode.expanded); });
  20514. this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(row, 'ag-row-group-contracted', !rowNode.expanded); });
  20515. };
  20516. RowComp.prototype.onDisplayedColumnsChanged = function () {
  20517. if (this.fullWidthRow) {
  20518. return;
  20519. }
  20520. this.refreshCells();
  20521. };
  20522. RowComp.prototype.destroyFullWidthComponents = function () {
  20523. if (this.fullWidthRowComponent) {
  20524. this.beans.detailRowCompCache.addOrDestroy(this.rowNode, null, this.fullWidthRowComponent);
  20525. this.fullWidthRowComponent = null;
  20526. }
  20527. if (this.fullWidthRowComponentBody) {
  20528. this.beans.detailRowCompCache.addOrDestroy(this.rowNode, null, this.fullWidthRowComponentBody);
  20529. this.fullWidthRowComponent = null;
  20530. }
  20531. if (this.fullWidthRowComponentLeft) {
  20532. this.beans.detailRowCompCache.addOrDestroy(this.rowNode, _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_LEFT, this.fullWidthRowComponentLeft);
  20533. this.fullWidthRowComponentLeft = null;
  20534. }
  20535. if (this.fullWidthRowComponentRight) {
  20536. this.beans.detailRowCompCache.addOrDestroy(this.rowNode, _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_RIGHT, this.fullWidthRowComponentRight);
  20537. this.fullWidthRowComponent = null;
  20538. }
  20539. };
  20540. RowComp.prototype.getContainerForCell = function (pinnedType) {
  20541. switch (pinnedType) {
  20542. case _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_LEFT: return this.ePinnedLeftRow;
  20543. case _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_RIGHT: return this.ePinnedRightRow;
  20544. default: return this.eBodyRow;
  20545. }
  20546. };
  20547. RowComp.prototype.onVirtualColumnsChanged = function () {
  20548. if (this.fullWidthRow) {
  20549. return;
  20550. }
  20551. this.refreshCells();
  20552. };
  20553. RowComp.prototype.onColumnResized = function () {
  20554. if (this.fullWidthRow) {
  20555. return;
  20556. }
  20557. this.refreshCells();
  20558. };
  20559. RowComp.prototype.refreshCells = function () {
  20560. if (!this.areAllContainersReady()) {
  20561. this.refreshNeeded = true;
  20562. return;
  20563. }
  20564. var suppressAnimationFrame = this.beans.gridOptionsWrapper.isSuppressAnimationFrame();
  20565. var skipAnimationFrame = suppressAnimationFrame || this.printLayout;
  20566. if (skipAnimationFrame) {
  20567. this.refreshCellsInAnimationFrame();
  20568. }
  20569. else {
  20570. if (this.columnRefreshPending) {
  20571. return;
  20572. }
  20573. this.beans.taskQueue.createTask(this.refreshCellsInAnimationFrame.bind(this), this.rowNode.rowIndex, 'createTasksP1');
  20574. }
  20575. };
  20576. RowComp.prototype.refreshCellsInAnimationFrame = function () {
  20577. if (!this.active) {
  20578. return;
  20579. }
  20580. this.columnRefreshPending = false;
  20581. var centerCols;
  20582. var leftCols;
  20583. var rightCols;
  20584. if (this.printLayout) {
  20585. centerCols = this.beans.columnController.getAllDisplayedColumns();
  20586. leftCols = [];
  20587. rightCols = [];
  20588. }
  20589. else {
  20590. centerCols = this.beans.columnController.getAllDisplayedCenterVirtualColumnsForRow(this.rowNode);
  20591. leftCols = this.beans.columnController.getDisplayedLeftColumnsForRow(this.rowNode);
  20592. rightCols = this.beans.columnController.getDisplayedRightColumnsForRow(this.rowNode);
  20593. }
  20594. this.insertCellsIntoContainer(this.eBodyRow, centerCols);
  20595. this.insertCellsIntoContainer(this.ePinnedLeftRow, leftCols);
  20596. this.insertCellsIntoContainer(this.ePinnedRightRow, rightCols);
  20597. this.elementOrderChanged = false;
  20598. var colIdsToRemove = Object.keys(this.cellComps);
  20599. centerCols.forEach(function (col) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeFromArray(colIdsToRemove, col.getId()); });
  20600. leftCols.forEach(function (col) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeFromArray(colIdsToRemove, col.getId()); });
  20601. rightCols.forEach(function (col) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeFromArray(colIdsToRemove, col.getId()); });
  20602. // we never remove editing cells, as this would cause the cells to loose their values while editing
  20603. // as the grid is scrolling horizontally.
  20604. var eligibleToBeRemoved = colIdsToRemove.filter(this.isCellEligibleToBeRemoved.bind(this));
  20605. // remove old cells from gui, but we don't destroy them, we might use them again
  20606. this.removeRenderedCells(eligibleToBeRemoved);
  20607. };
  20608. RowComp.prototype.onColumnMoved = function () {
  20609. this.elementOrderChanged = true;
  20610. };
  20611. RowComp.prototype.removeRenderedCells = function (colIds) {
  20612. var _this = this;
  20613. colIds.forEach(function (key) {
  20614. var cellComp = _this.cellComps[key];
  20615. // could be old reference, ie removed cell
  20616. if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(cellComp)) {
  20617. return;
  20618. }
  20619. cellComp.detach();
  20620. cellComp.destroy();
  20621. _this.cellComps[key] = null;
  20622. });
  20623. };
  20624. RowComp.prototype.isCellEligibleToBeRemoved = function (indexStr) {
  20625. var displayedColumns = this.beans.columnController.getAllDisplayedColumns();
  20626. var REMOVE_CELL = true;
  20627. var KEEP_CELL = false;
  20628. var renderedCell = this.cellComps[indexStr];
  20629. // always remove the cell if it's not rendered or if it's in the wrong pinned location
  20630. if (!renderedCell || this.isCellInWrongRow(renderedCell)) {
  20631. return REMOVE_CELL;
  20632. }
  20633. // we want to try and keep editing and focused cells
  20634. var editing = renderedCell.isEditing();
  20635. var focused = this.beans.focusController.isCellFocused(renderedCell.getCellPosition());
  20636. var mightWantToKeepCell = editing || focused;
  20637. if (mightWantToKeepCell) {
  20638. var column = renderedCell.getColumn();
  20639. var cellStillDisplayed = displayedColumns.indexOf(column) >= 0;
  20640. return cellStillDisplayed ? KEEP_CELL : REMOVE_CELL;
  20641. }
  20642. return REMOVE_CELL;
  20643. };
  20644. RowComp.prototype.ensureCellInCorrectContainer = function (cellComp) {
  20645. // for print layout, we always put cells into centre, otherwise we put in correct pinned section
  20646. if (this.printLayout) {
  20647. return;
  20648. }
  20649. var element = cellComp.getGui();
  20650. var column = cellComp.getColumn();
  20651. var pinnedType = column.getPinned();
  20652. var eContainer = this.getContainerForCell(pinnedType);
  20653. // if in wrong container, remove it
  20654. var eOldContainer = cellComp.getParentRow();
  20655. var inWrongRow = eOldContainer !== eContainer;
  20656. if (inWrongRow) {
  20657. // take out from old row
  20658. if (eOldContainer) {
  20659. eOldContainer.removeChild(element);
  20660. }
  20661. eContainer.appendChild(element);
  20662. cellComp.setParentRow(eContainer);
  20663. this.elementOrderChanged = true;
  20664. }
  20665. };
  20666. RowComp.prototype.isCellInWrongRow = function (cellComp) {
  20667. var column = cellComp.getColumn();
  20668. var rowWeWant = this.getContainerForCell(column.getPinned());
  20669. var oldRow = cellComp.getParentRow(); // if in wrong container, remove it
  20670. return oldRow !== rowWeWant;
  20671. };
  20672. RowComp.prototype.insertCellsIntoContainer = function (eRow, cols) {
  20673. var _this = this;
  20674. if (!eRow) {
  20675. return;
  20676. }
  20677. var cellTemplates = [];
  20678. var newCellComps = [];
  20679. cols.forEach(function (col) {
  20680. var colId = col.getId();
  20681. var existingCell = _this.cellComps[colId];
  20682. if (existingCell) {
  20683. _this.ensureCellInCorrectContainer(existingCell);
  20684. }
  20685. else {
  20686. _this.createNewCell(col, eRow, cellTemplates, newCellComps);
  20687. }
  20688. });
  20689. if (cellTemplates.length > 0) {
  20690. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].appendHtml(eRow, cellTemplates.join(''));
  20691. this.callAfterRowAttachedOnCells(newCellComps, eRow);
  20692. }
  20693. if (this.elementOrderChanged && this.beans.gridOptionsWrapper.isEnsureDomOrder()) {
  20694. var correctChildOrder = cols.map(function (col) { return _this.getCellForCol(col); });
  20695. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].setDomChildOrder(eRow, correctChildOrder);
  20696. }
  20697. };
  20698. RowComp.prototype.addDomData = function (eRowContainer) {
  20699. var gow = this.beans.gridOptionsWrapper;
  20700. gow.setDomData(eRowContainer, RowComp.DOM_DATA_KEY_RENDERED_ROW, this);
  20701. this.addDestroyFunc(function () {
  20702. gow.setDomData(eRowContainer, RowComp.DOM_DATA_KEY_RENDERED_ROW, null);
  20703. });
  20704. };
  20705. RowComp.prototype.createNewCell = function (col, eContainer, cellTemplates, newCellComps) {
  20706. var newCellComp = new _cellComp__WEBPACK_IMPORTED_MODULE_0__["CellComp"](this.scope, this.beans, col, this.rowNode, this, false, this.printLayout);
  20707. var cellTemplate = newCellComp.getCreateTemplate();
  20708. cellTemplates.push(cellTemplate);
  20709. newCellComps.push(newCellComp);
  20710. this.cellComps[col.getId()] = newCellComp;
  20711. newCellComp.setParentRow(eContainer);
  20712. this.elementOrderChanged = true;
  20713. };
  20714. RowComp.prototype.onMouseEvent = function (eventName, mouseEvent) {
  20715. switch (eventName) {
  20716. case 'dblclick':
  20717. this.onRowDblClick(mouseEvent);
  20718. break;
  20719. case 'click':
  20720. this.onRowClick(mouseEvent);
  20721. break;
  20722. case 'mousedown':
  20723. this.onRowMouseDown(mouseEvent);
  20724. break;
  20725. }
  20726. };
  20727. RowComp.prototype.createRowEvent = function (type, domEvent) {
  20728. return {
  20729. type: type,
  20730. node: this.rowNode,
  20731. data: this.rowNode.data,
  20732. rowIndex: this.rowNode.rowIndex,
  20733. rowPinned: this.rowNode.rowPinned,
  20734. context: this.beans.gridOptionsWrapper.getContext(),
  20735. api: this.beans.gridOptionsWrapper.getApi(),
  20736. columnApi: this.beans.gridOptionsWrapper.getColumnApi(),
  20737. event: domEvent
  20738. };
  20739. };
  20740. RowComp.prototype.createRowEventWithSource = function (type, domEvent) {
  20741. var event = this.createRowEvent(type, domEvent);
  20742. // when first developing this, we included the rowComp in the event.
  20743. // this seems very weird. so when introducing the event types, i left the 'source'
  20744. // out of the type, and just include the source in the two places where this event
  20745. // was fired (rowClicked and rowDoubleClicked). it doesn't make sense for any
  20746. // users to be using this, as the rowComp isn't an object we expose, so would be
  20747. // very surprising if a user was using it.
  20748. event.source = this;
  20749. return event;
  20750. };
  20751. RowComp.prototype.onRowDblClick = function (mouseEvent) {
  20752. if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].isStopPropagationForAgGrid(mouseEvent)) {
  20753. return;
  20754. }
  20755. var agEvent = this.createRowEventWithSource(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DOUBLE_CLICKED, mouseEvent);
  20756. this.beans.eventService.dispatchEvent(agEvent);
  20757. };
  20758. RowComp.prototype.onRowMouseDown = function (mouseEvent) {
  20759. this.lastMouseDownOnDragger = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].isElementChildOfClass(mouseEvent.target, 'ag-row-drag', 3);
  20760. };
  20761. RowComp.prototype.onRowClick = function (mouseEvent) {
  20762. var stop = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].isStopPropagationForAgGrid(mouseEvent) || this.lastMouseDownOnDragger;
  20763. if (stop) {
  20764. return;
  20765. }
  20766. var agEvent = this.createRowEventWithSource(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_CLICKED, mouseEvent);
  20767. this.beans.eventService.dispatchEvent(agEvent);
  20768. // ctrlKey for windows, metaKey for Apple
  20769. var multiSelectKeyPressed = mouseEvent.ctrlKey || mouseEvent.metaKey;
  20770. var shiftKeyPressed = mouseEvent.shiftKey;
  20771. if (
  20772. // we do not allow selecting groups by clicking (as the click here expands the group), or if it's a detail row,
  20773. // so return if it's a group row
  20774. this.rowNode.group ||
  20775. // this is needed so we don't unselect other rows when we click this row, eg if this row is not selectable,
  20776. // and we click it, the selection should not change (ie any currently selected row should stay selected)
  20777. !this.rowNode.selectable ||
  20778. // we also don't allow selection of pinned rows
  20779. this.rowNode.rowPinned ||
  20780. // if no selection method enabled, do nothing
  20781. !this.beans.gridOptionsWrapper.isRowSelection() ||
  20782. // if click selection suppressed, do nothing
  20783. this.beans.gridOptionsWrapper.isSuppressRowClickSelection()) {
  20784. return;
  20785. }
  20786. var multiSelectOnClick = this.beans.gridOptionsWrapper.isRowMultiSelectWithClick();
  20787. var rowDeselectionWithCtrl = this.beans.gridOptionsWrapper.isRowDeselection();
  20788. if (this.rowNode.isSelected()) {
  20789. if (multiSelectOnClick) {
  20790. this.rowNode.setSelectedParams({ newValue: false });
  20791. }
  20792. else if (multiSelectKeyPressed) {
  20793. if (rowDeselectionWithCtrl) {
  20794. this.rowNode.setSelectedParams({ newValue: false });
  20795. }
  20796. }
  20797. else {
  20798. // selected with no multi key, must make sure anything else is unselected
  20799. this.rowNode.setSelectedParams({ newValue: true, clearSelection: true });
  20800. }
  20801. }
  20802. else {
  20803. var clearSelection = multiSelectOnClick ? false : !multiSelectKeyPressed;
  20804. this.rowNode.setSelectedParams({ newValue: true, clearSelection: clearSelection, rangeSelect: shiftKeyPressed });
  20805. }
  20806. };
  20807. RowComp.prototype.createFullWidthRowContainer = function (rowContainerComp, pinned, extraCssClass, cellRendererType, cellRendererName, eRowCallback, cellRendererCallback) {
  20808. var _this = this;
  20809. var rowTemplate = this.createTemplate('', extraCssClass);
  20810. rowContainerComp.appendRowTemplate(rowTemplate, function () {
  20811. var eRow = rowContainerComp.getRowElement(_this.getCompId());
  20812. var params = _this.createFullWidthParams(eRow, pinned);
  20813. var callback = function (cellRenderer) {
  20814. if (_this.isAlive()) {
  20815. var gui = cellRenderer.getGui();
  20816. eRow.appendChild(gui);
  20817. cellRendererCallback(cellRenderer);
  20818. }
  20819. else {
  20820. _this.beans.context.destroyBean(cellRenderer);
  20821. }
  20822. };
  20823. // if doing master detail, it's possible we have a cached row comp from last time detail was displayed
  20824. var cachedRowComp = _this.beans.detailRowCompCache.get(_this.rowNode, pinned);
  20825. if (cachedRowComp) {
  20826. callback(cachedRowComp);
  20827. }
  20828. else {
  20829. var res = _this.beans.userComponentFactory.newFullWidthCellRenderer(params, cellRendererType, cellRendererName);
  20830. if (!res) {
  20831. var masterDetailModuleLoaded = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_6__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_5__["ModuleNames"].MasterDetailModule);
  20832. if (cellRendererName === 'agDetailCellRenderer' && !masterDetailModuleLoaded) {
  20833. console.warn("ag-Grid: cell renderer agDetailCellRenderer (for master detail) not found. Did you forget to include the master detail module?");
  20834. }
  20835. else {
  20836. console.error("ag-Grid: fullWidthCellRenderer " + cellRendererName + " not found");
  20837. }
  20838. return;
  20839. }
  20840. res.then(callback);
  20841. }
  20842. _this.afterRowAttached(rowContainerComp, eRow);
  20843. eRowCallback(eRow);
  20844. _this.angular1Compile(eRow);
  20845. });
  20846. };
  20847. RowComp.prototype.angular1Compile = function (element) {
  20848. if (!this.scope) {
  20849. return;
  20850. }
  20851. this.beans.$compile(element)(this.scope);
  20852. };
  20853. RowComp.prototype.createFullWidthParams = function (eRow, pinned) {
  20854. var params = {
  20855. fullWidth: true,
  20856. data: this.rowNode.data,
  20857. node: this.rowNode,
  20858. value: this.rowNode.key,
  20859. $scope: this.scope ? this.scope : this.parentScope,
  20860. $compile: this.beans.$compile,
  20861. rowIndex: this.rowNode.rowIndex,
  20862. api: this.beans.gridOptionsWrapper.getApi(),
  20863. columnApi: this.beans.gridOptionsWrapper.getColumnApi(),
  20864. context: this.beans.gridOptionsWrapper.getContext(),
  20865. // these need to be taken out, as part of 'afterAttached' now
  20866. eGridCell: eRow,
  20867. eParentOfValue: eRow,
  20868. pinned: pinned,
  20869. addRenderedRowListener: this.addEventListener.bind(this)
  20870. };
  20871. return params;
  20872. };
  20873. RowComp.prototype.getInitialRowClasses = function (extraCssClass) {
  20874. var classes = [];
  20875. var isTreeData = this.beans.gridOptionsWrapper.isTreeData();
  20876. var rowNode = this.rowNode;
  20877. if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(extraCssClass)) {
  20878. classes.push(extraCssClass);
  20879. }
  20880. classes.push('ag-row');
  20881. classes.push(this.rowFocused ? 'ag-row-focus' : 'ag-row-no-focus');
  20882. if (this.fadeRowIn) {
  20883. classes.push('ag-opacity-zero');
  20884. }
  20885. classes.push(this.rowIsEven ? 'ag-row-even' : 'ag-row-odd');
  20886. if (rowNode.isRowPinned()) {
  20887. classes.push('ag-row-pinned');
  20888. }
  20889. if (rowNode.isSelected()) {
  20890. classes.push('ag-row-selected');
  20891. }
  20892. if (rowNode.group) {
  20893. classes.push('ag-row-group');
  20894. // if a group, put the level of the group in
  20895. classes.push('ag-row-level-' + rowNode.level);
  20896. if (rowNode.footer) {
  20897. classes.push('ag-row-footer');
  20898. }
  20899. }
  20900. else {
  20901. // if a leaf, and a parent exists, put a level of the parent, else put level of 0 for top level item
  20902. classes.push('ag-row-level-' + (rowNode.parent ? (rowNode.parent.level + 1) : '0'));
  20903. }
  20904. if (rowNode.stub) {
  20905. classes.push('ag-row-loading');
  20906. }
  20907. if (this.fullWidthRow) {
  20908. classes.push('ag-full-width-row');
  20909. }
  20910. var addExpandedClass = isTreeData ?
  20911. // if doing tree data, we add the expanded classes if any children, as any node can be a parent
  20912. rowNode.allChildrenCount :
  20913. // if normal row grouping, we add expanded classes to groups only
  20914. rowNode.group && !rowNode.footer;
  20915. if (addExpandedClass) {
  20916. classes.push(rowNode.expanded ? 'ag-row-group-expanded' : 'ag-row-group-contracted');
  20917. }
  20918. if (rowNode.dragging) {
  20919. classes.push('ag-row-dragging');
  20920. }
  20921. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].pushAll(classes, this.processClassesFromGridOptions());
  20922. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].pushAll(classes, this.preProcessRowClassRules());
  20923. // we use absolute position unless we are doing print layout
  20924. classes.push(this.printLayout ? 'ag-row-position-relative' : 'ag-row-position-absolute');
  20925. this.firstRowOnPage = this.isFirstRowOnPage();
  20926. this.lastRowOnPage = this.isLastRowOnPage();
  20927. if (this.firstRowOnPage) {
  20928. classes.push('ag-row-first');
  20929. }
  20930. if (this.lastRowOnPage) {
  20931. classes.push('ag-row-last');
  20932. }
  20933. return classes;
  20934. };
  20935. RowComp.prototype.isFirstRowOnPage = function () {
  20936. return this.rowNode.rowIndex === this.beans.paginationProxy.getPageFirstRow();
  20937. };
  20938. RowComp.prototype.isLastRowOnPage = function () {
  20939. return this.rowNode.rowIndex === this.beans.paginationProxy.getPageLastRow();
  20940. };
  20941. RowComp.prototype.onModelUpdated = function () {
  20942. var newFirst = this.isFirstRowOnPage();
  20943. var newLast = this.isLastRowOnPage();
  20944. if (this.firstRowOnPage !== newFirst) {
  20945. this.firstRowOnPage = newFirst;
  20946. this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(row, 'ag-row-first', newFirst); });
  20947. }
  20948. if (this.lastRowOnPage !== newLast) {
  20949. this.lastRowOnPage = newLast;
  20950. this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(row, 'ag-row-last', newLast); });
  20951. }
  20952. };
  20953. RowComp.prototype.preProcessRowClassRules = function () {
  20954. var res = [];
  20955. this.processRowClassRules(function (className) {
  20956. res.push(className);
  20957. }, function (className) {
  20958. // not catered for, if creating, no need
  20959. // to remove class as it was never there
  20960. });
  20961. return res;
  20962. };
  20963. RowComp.prototype.processRowClassRules = function (onApplicableClass, onNotApplicableClass) {
  20964. this.beans.stylingService.processClassRules(this.beans.gridOptionsWrapper.rowClassRules(), {
  20965. value: undefined,
  20966. colDef: undefined,
  20967. data: this.rowNode.data,
  20968. node: this.rowNode,
  20969. rowIndex: this.rowNode.rowIndex,
  20970. api: this.beans.gridOptionsWrapper.getApi(),
  20971. columnApi: this.beans.gridOptionsWrapper.getColumnApi(),
  20972. $scope: this.scope,
  20973. context: this.beans.gridOptionsWrapper.getContext()
  20974. }, onApplicableClass, onNotApplicableClass);
  20975. };
  20976. RowComp.prototype.stopEditing = function (cancel) {
  20977. if (cancel === void 0) { cancel = false; }
  20978. this.forEachCellComp(function (renderedCell) {
  20979. renderedCell.stopEditing(cancel);
  20980. });
  20981. if (!this.editingRow) {
  20982. return;
  20983. }
  20984. if (!cancel) {
  20985. var event_1 = this.createRowEvent(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_VALUE_CHANGED);
  20986. this.beans.eventService.dispatchEvent(event_1);
  20987. }
  20988. this.setEditingRow(false);
  20989. };
  20990. RowComp.prototype.setEditingRow = function (value) {
  20991. this.editingRow = value;
  20992. this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(row, 'ag-row-editing', value); });
  20993. var event = value ?
  20994. this.createRowEvent(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_EDITING_STARTED)
  20995. : this.createRowEvent(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_EDITING_STOPPED);
  20996. this.beans.eventService.dispatchEvent(event);
  20997. };
  20998. RowComp.prototype.startRowEditing = function (keyPress, charPress, sourceRenderedCell) {
  20999. if (keyPress === void 0) { keyPress = null; }
  21000. if (charPress === void 0) { charPress = null; }
  21001. if (sourceRenderedCell === void 0) { sourceRenderedCell = null; }
  21002. // don't do it if already editing
  21003. if (this.editingRow) {
  21004. return;
  21005. }
  21006. this.forEachCellComp(function (renderedCell) {
  21007. var cellStartedEdit = renderedCell === sourceRenderedCell;
  21008. if (cellStartedEdit) {
  21009. renderedCell.startEditingIfEnabled(keyPress, charPress, cellStartedEdit);
  21010. }
  21011. else {
  21012. renderedCell.startEditingIfEnabled(null, null, cellStartedEdit);
  21013. }
  21014. });
  21015. this.setEditingRow(true);
  21016. };
  21017. RowComp.prototype.forEachCellComp = function (callback) {
  21018. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].iterateObject(this.cellComps, function (key, cellComp) {
  21019. if (!cellComp) {
  21020. return;
  21021. }
  21022. callback(cellComp);
  21023. });
  21024. };
  21025. RowComp.prototype.postProcessClassesFromGridOptions = function () {
  21026. var _this = this;
  21027. var cssClasses = this.processClassesFromGridOptions();
  21028. if (!cssClasses || !cssClasses.length) {
  21029. return;
  21030. }
  21031. cssClasses.forEach(function (classStr) {
  21032. _this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(row, classStr); });
  21033. });
  21034. };
  21035. RowComp.prototype.postProcessRowClassRules = function () {
  21036. var _this = this;
  21037. this.processRowClassRules(function (className) {
  21038. _this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(row, className); });
  21039. }, function (className) {
  21040. _this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(row, className); });
  21041. });
  21042. };
  21043. RowComp.prototype.processClassesFromGridOptions = function () {
  21044. var res = [];
  21045. var process = function (rowCls) {
  21046. if (typeof rowCls === 'string') {
  21047. res.push(rowCls);
  21048. }
  21049. else if (Array.isArray(rowCls)) {
  21050. rowCls.forEach(function (e) { return res.push(e); });
  21051. }
  21052. };
  21053. // part 1 - rowClass
  21054. var rowClass = this.beans.gridOptionsWrapper.getRowClass();
  21055. if (rowClass) {
  21056. if (typeof rowClass === 'function') {
  21057. console.warn('ag-Grid: rowClass should not be a function, please use getRowClass instead');
  21058. return;
  21059. }
  21060. process(rowClass);
  21061. }
  21062. // part 2 - rowClassFunc
  21063. var rowClassFunc = this.beans.gridOptionsWrapper.getRowClassFunc();
  21064. if (rowClassFunc) {
  21065. var params = {
  21066. node: this.rowNode,
  21067. data: this.rowNode.data,
  21068. rowIndex: this.rowNode.rowIndex,
  21069. context: this.beans.gridOptionsWrapper.getContext(),
  21070. api: this.beans.gridOptionsWrapper.getApi()
  21071. };
  21072. var rowClassFuncResult = rowClassFunc(params);
  21073. process(rowClassFuncResult);
  21074. }
  21075. return res;
  21076. };
  21077. RowComp.prototype.preProcessStylesFromGridOptions = function () {
  21078. var rowStyles = this.processStylesFromGridOptions();
  21079. return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].cssStyleObjectToMarkup(rowStyles);
  21080. };
  21081. RowComp.prototype.postProcessStylesFromGridOptions = function () {
  21082. var rowStyles = this.processStylesFromGridOptions();
  21083. this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addStylesToElement(row, rowStyles); });
  21084. };
  21085. RowComp.prototype.processStylesFromGridOptions = function () {
  21086. // part 1 - rowStyle
  21087. var rowStyle = this.beans.gridOptionsWrapper.getRowStyle();
  21088. if (rowStyle && typeof rowStyle === 'function') {
  21089. console.warn('ag-Grid: rowStyle should be an object of key/value styles, not be a function, use getRowStyle() instead');
  21090. return;
  21091. }
  21092. // part 1 - rowStyleFunc
  21093. var rowStyleFunc = this.beans.gridOptionsWrapper.getRowStyleFunc();
  21094. var rowStyleFuncResult;
  21095. if (rowStyleFunc) {
  21096. var params = {
  21097. data: this.rowNode.data,
  21098. node: this.rowNode,
  21099. api: this.beans.gridOptionsWrapper.getApi(),
  21100. context: this.beans.gridOptionsWrapper.getContext(),
  21101. $scope: this.scope
  21102. };
  21103. rowStyleFuncResult = rowStyleFunc(params);
  21104. }
  21105. return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].assign({}, rowStyle, rowStyleFuncResult);
  21106. };
  21107. RowComp.prototype.createCells = function (cols) {
  21108. var _this = this;
  21109. var templateParts = [];
  21110. var newCellComps = [];
  21111. cols.forEach(function (col) {
  21112. var newCellComp = new _cellComp__WEBPACK_IMPORTED_MODULE_0__["CellComp"](_this.scope, _this.beans, col, _this.rowNode, _this, false, _this.printLayout);
  21113. var cellTemplate = newCellComp.getCreateTemplate();
  21114. templateParts.push(cellTemplate);
  21115. newCellComps.push(newCellComp);
  21116. _this.cellComps[col.getId()] = newCellComp;
  21117. });
  21118. var templateAndComps = {
  21119. template: templateParts.join(''),
  21120. cellComps: newCellComps
  21121. };
  21122. return templateAndComps;
  21123. };
  21124. RowComp.prototype.onRowSelected = function () {
  21125. var selected = this.rowNode.isSelected();
  21126. this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(row, 'ag-row-selected', selected); });
  21127. };
  21128. // called:
  21129. // + after row created for first time
  21130. // + after horizontal scroll, so new cells due to column virtualisation
  21131. RowComp.prototype.callAfterRowAttachedOnCells = function (newCellComps, eRow) {
  21132. var _this = this;
  21133. newCellComps.forEach(function (cellComp) {
  21134. cellComp.setParentRow(eRow);
  21135. cellComp.afterAttached();
  21136. // if we are editing the row, then the cell needs to turn
  21137. // into edit mode
  21138. if (_this.editingRow) {
  21139. cellComp.startEditingIfEnabled();
  21140. }
  21141. });
  21142. };
  21143. RowComp.prototype.afterRowAttached = function (rowContainerComp, eRow) {
  21144. var _this = this;
  21145. this.addDomData(eRow);
  21146. this.removeSecondPassFuncs.push(function () {
  21147. rowContainerComp.removeRowElement(eRow);
  21148. });
  21149. this.removeFirstPassFuncs.push(function () {
  21150. if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(_this.rowNode.rowTop)) {
  21151. // the row top is updated anyway, however we set it here again
  21152. // to something more reasonable for the animation - ie if the
  21153. // row top is 10000px away, the row will flash out, so this
  21154. // gives it a rounded value, so row animates out more slowly
  21155. var rowTop = _this.roundRowTopToBounds(_this.rowNode.rowTop);
  21156. _this.setRowTop(rowTop);
  21157. }
  21158. else {
  21159. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(eRow, 'ag-opacity-zero');
  21160. }
  21161. });
  21162. this.eAllRowContainers.push(eRow);
  21163. // adding hover functionality adds listener to this row, so we
  21164. // do it lazily in an animation frame
  21165. if (this.useAnimationFrameForCreate) {
  21166. this.beans.taskQueue.createTask(this.addHoverFunctionality.bind(this, eRow), this.rowNode.rowIndex, 'createTasksP2');
  21167. }
  21168. else {
  21169. this.addHoverFunctionality(eRow);
  21170. }
  21171. };
  21172. RowComp.prototype.addHoverFunctionality = function (eRow) {
  21173. var _this = this;
  21174. // because we use animation frames to do this, it's possible the row no longer exists
  21175. // by the time we get to add it
  21176. if (!this.active) {
  21177. return;
  21178. }
  21179. // because mouseenter and mouseleave do not propagate, we cannot listen on the gridPanel
  21180. // like we do for all the other mouse events.
  21181. // because of the pinning, we cannot simply add / remove the class based on the eRow. we
  21182. // have to check all eRow's (body & pinned). so the trick is if any of the rows gets a
  21183. // mouse hover, it sets such in the rowNode, and then all three reflect the change as
  21184. // all are listening for event on the row node.
  21185. // step 1 - add listener, to set flag on row node
  21186. this.addManagedListener(eRow, 'mouseenter', function () { return _this.rowNode.onMouseEnter(); });
  21187. this.addManagedListener(eRow, 'mouseleave', function () { return _this.rowNode.onMouseLeave(); });
  21188. // step 2 - listen for changes on row node (which any eRow can trigger)
  21189. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_MOUSE_ENTER, function () {
  21190. // if hover turned off, we don't add the class. we do this here so that if the application
  21191. // toggles this property mid way, we remove the hover form the last row, but we stop
  21192. // adding hovers from that point onwards.
  21193. if (!_this.beans.gridOptionsWrapper.isSuppressRowHoverHighlight()) {
  21194. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(eRow, 'ag-row-hover');
  21195. }
  21196. });
  21197. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"].EVENT_MOUSE_LEAVE, function () {
  21198. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(eRow, 'ag-row-hover');
  21199. });
  21200. };
  21201. // for animation, we don't want to animate entry or exit to a very far away pixel,
  21202. // otherwise the row would move so fast, it would appear to disappear. so this method
  21203. // moves the row closer to the viewport if it is far away, so the row slide in / out
  21204. // at a speed the user can see.
  21205. RowComp.prototype.roundRowTopToBounds = function (rowTop) {
  21206. var range = this.beans.gridPanel.getVScrollPosition();
  21207. var minPixel = this.applyPaginationOffset(range.top, true) - 100;
  21208. var maxPixel = this.applyPaginationOffset(range.bottom, true) + 100;
  21209. return Math.min(Math.max(minPixel, rowTop), maxPixel);
  21210. };
  21211. RowComp.prototype.getFrameworkOverrides = function () {
  21212. return this.beans.frameworkOverrides;
  21213. };
  21214. RowComp.prototype.onRowHeightChanged = function () {
  21215. // check for exists first - if the user is resetting the row height, then
  21216. // it will be null (or undefined) momentarily until the next time the flatten
  21217. // stage is called where the row will then update again with a new height
  21218. if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(this.rowNode.rowHeight)) {
  21219. var heightPx_1 = this.rowNode.rowHeight + "px";
  21220. this.eAllRowContainers.forEach(function (row) { return row.style.height = heightPx_1; });
  21221. }
  21222. };
  21223. RowComp.prototype.addEventListener = function (eventType, listener) {
  21224. if (eventType === 'renderedRowRemoved' || eventType === 'rowRemoved') {
  21225. eventType = _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_VIRTUAL_ROW_REMOVED;
  21226. console.warn('ag-Grid: Since version 11, event renderedRowRemoved is now called ' + _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_VIRTUAL_ROW_REMOVED);
  21227. }
  21228. _super.prototype.addEventListener.call(this, eventType, listener);
  21229. };
  21230. RowComp.prototype.removeEventListener = function (eventType, listener) {
  21231. if (eventType === 'renderedRowRemoved' || eventType === 'rowRemoved') {
  21232. eventType = _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_VIRTUAL_ROW_REMOVED;
  21233. console.warn('ag-Grid: Since version 11, event renderedRowRemoved and rowRemoved is now called ' + _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_VIRTUAL_ROW_REMOVED);
  21234. }
  21235. _super.prototype.removeEventListener.call(this, eventType, listener);
  21236. };
  21237. // note - this is NOT called by context, as we don't wire / unwire the CellComp for performance reasons.
  21238. RowComp.prototype.destroy = function (animate) {
  21239. if (animate === void 0) { animate = false; }
  21240. this.active = false;
  21241. // why do we have this method? shouldn't everything below be added as a destroy func beside
  21242. // the corresponding create logic?
  21243. this.destroyFullWidthComponents();
  21244. if (animate) {
  21245. this.removeFirstPassFuncs.forEach(function (func) { return func(); });
  21246. this.removeSecondPassFuncs.push(this.destroyContainingCells.bind(this));
  21247. }
  21248. else {
  21249. this.destroyContainingCells();
  21250. // we are not animating, so execute the second stage of removal now.
  21251. // we call getAndClear, so that they are only called once
  21252. var delayedDestroyFunctions = this.getAndClearDelayedDestroyFunctions();
  21253. delayedDestroyFunctions.forEach(function (func) { return func(); });
  21254. }
  21255. var event = this.createRowEvent(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_VIRTUAL_ROW_REMOVED);
  21256. this.dispatchEvent(event);
  21257. this.beans.eventService.dispatchEvent(event);
  21258. _super.prototype.destroy.call(this);
  21259. };
  21260. RowComp.prototype.destroyContainingCells = function () {
  21261. this.forEachCellComp(function (renderedCell) { return renderedCell.destroy(); });
  21262. this.destroyFullWidthComponents();
  21263. };
  21264. // we clear so that the functions are never executed twice
  21265. RowComp.prototype.getAndClearDelayedDestroyFunctions = function () {
  21266. var result = this.removeSecondPassFuncs;
  21267. this.removeSecondPassFuncs = [];
  21268. return result;
  21269. };
  21270. RowComp.prototype.onCellFocusChanged = function () {
  21271. var rowFocused = this.beans.focusController.isRowFocused(this.rowNode.rowIndex, this.rowNode.rowPinned);
  21272. if (rowFocused !== this.rowFocused) {
  21273. this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(row, 'ag-row-focus', rowFocused); });
  21274. this.eAllRowContainers.forEach(function (row) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(row, 'ag-row-no-focus', !rowFocused); });
  21275. this.rowFocused = rowFocused;
  21276. }
  21277. // if we are editing, then moving the focus out of a row will stop editing
  21278. if (!rowFocused && this.editingRow) {
  21279. this.stopEditing(false);
  21280. }
  21281. };
  21282. RowComp.prototype.onPaginationChanged = function () {
  21283. var currentPage = this.beans.paginationProxy.getCurrentPage();
  21284. // it is possible this row is in the new page, but the page number has changed, which means
  21285. // it needs to reposition itself relative to the new page
  21286. if (this.paginationPage !== currentPage) {
  21287. this.paginationPage = currentPage;
  21288. this.onTopChanged();
  21289. }
  21290. };
  21291. RowComp.prototype.onTopChanged = function () {
  21292. this.setRowTop(this.rowNode.rowTop);
  21293. };
  21294. // applies pagination offset, eg if on second page, and page height is 500px, then removes
  21295. // 500px from the top position, so a row with rowTop 600px is displayed at location 100px.
  21296. // reverse will take the offset away rather than add.
  21297. RowComp.prototype.applyPaginationOffset = function (topPx, reverse) {
  21298. if (reverse === void 0) { reverse = false; }
  21299. if (this.rowNode.isRowPinned()) {
  21300. return topPx;
  21301. }
  21302. var pixelOffset = this.beans.paginationProxy.getPixelOffset();
  21303. var multiplier = reverse ? 1 : -1;
  21304. return topPx + (pixelOffset * multiplier);
  21305. };
  21306. RowComp.prototype.setRowTop = function (pixels) {
  21307. // print layout uses normal flow layout for row positioning
  21308. if (this.printLayout) {
  21309. return;
  21310. }
  21311. // need to make sure rowTop is not null, as this can happen if the node was once
  21312. // visible (ie parent group was expanded) but is now not visible
  21313. if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(pixels)) {
  21314. var afterPaginationPixels = this.applyPaginationOffset(pixels);
  21315. var afterScalingPixels = this.beans.maxDivHeightScaler.getRealPixelPosition(afterPaginationPixels);
  21316. var topPx_1 = afterScalingPixels + "px";
  21317. if (this.beans.gridOptionsWrapper.isSuppressRowTransform()) {
  21318. this.eAllRowContainers.forEach(function (row) { return row.style.top = topPx_1; });
  21319. }
  21320. else {
  21321. this.eAllRowContainers.forEach(function (row) { return row.style.transform = "translateY(" + topPx_1 + ")"; });
  21322. }
  21323. }
  21324. };
  21325. // we clear so that the functions are never executed twice
  21326. RowComp.prototype.getAndClearNextVMTurnFunctions = function () {
  21327. var result = this.createSecondPassFuncs;
  21328. this.createSecondPassFuncs = [];
  21329. return result;
  21330. };
  21331. RowComp.prototype.getRowNode = function () {
  21332. return this.rowNode;
  21333. };
  21334. RowComp.prototype.getRenderedCellForColumn = function (column) {
  21335. var _this = this;
  21336. var cellComp = this.cellComps[column.getColId()];
  21337. if (cellComp) {
  21338. return cellComp;
  21339. }
  21340. var spanList = Object.keys(this.cellComps)
  21341. .map(function (name) { return _this.cellComps[name]; })
  21342. .filter(function (cmp) { return cmp && cmp.getColSpanningList().indexOf(column) !== -1; });
  21343. return spanList.length ? spanList[0] : undefined;
  21344. };
  21345. RowComp.prototype.onRowIndexChanged = function () {
  21346. // we only bother updating if the rowIndex is present. if it is not present, it means this row
  21347. // is child of a group node, and the group node was closed, it's the only way to have no row index.
  21348. // when this happens, row is about to be de-rendered, so we don't care, rowComp is about to die!
  21349. if (this.rowNode.rowIndex != null) {
  21350. this.onCellFocusChanged();
  21351. this.updateRowIndexes();
  21352. }
  21353. };
  21354. RowComp.prototype.updateRowIndexes = function () {
  21355. var _this = this;
  21356. var rowIndexStr = this.rowNode.getRowIndexString();
  21357. var rowIsEven = this.rowNode.rowIndex % 2 === 0;
  21358. var rowIsEvenChanged = this.rowIsEven !== rowIsEven;
  21359. var headerRowCount = this.beans.headerNavigationService.getHeaderRowCount();
  21360. if (rowIsEvenChanged) {
  21361. this.rowIsEven = rowIsEven;
  21362. }
  21363. this.eAllRowContainers.forEach(function (eRow) {
  21364. eRow.setAttribute('row-index', rowIndexStr);
  21365. eRow.setAttribute('aria-rowindex', (headerRowCount + _this.rowNode.rowIndex + 1).toString());
  21366. if (!rowIsEvenChanged) {
  21367. return;
  21368. }
  21369. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(eRow, 'ag-row-even', rowIsEven);
  21370. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(eRow, 'ag-row-odd', !rowIsEven);
  21371. });
  21372. };
  21373. RowComp.prototype.ensureDomOrder = function () {
  21374. var sides = [
  21375. {
  21376. el: this.getBodyRowElement(),
  21377. ct: this.bodyContainerComp
  21378. },
  21379. {
  21380. el: this.getPinnedLeftRowElement(),
  21381. ct: this.pinnedLeftContainerComp
  21382. }, {
  21383. el: this.getPinnedRightRowElement(),
  21384. ct: this.pinnedRightContainerComp
  21385. }, {
  21386. el: this.getFullWidthRowElement(),
  21387. ct: this.fullWidthContainerComp
  21388. }
  21389. ];
  21390. sides.forEach(function (side) {
  21391. if (!side.el) {
  21392. return;
  21393. }
  21394. side.ct.ensureDomOrder(side.el);
  21395. });
  21396. };
  21397. // returns the pinned left container, either the normal one, or the embedded full with one if exists
  21398. RowComp.prototype.getPinnedLeftRowElement = function () {
  21399. return this.ePinnedLeftRow ? this.ePinnedLeftRow : this.eFullWidthRowLeft;
  21400. };
  21401. // returns the pinned right container, either the normal one, or the embedded full with one if exists
  21402. RowComp.prototype.getPinnedRightRowElement = function () {
  21403. return this.ePinnedRightRow ? this.ePinnedRightRow : this.eFullWidthRowRight;
  21404. };
  21405. // returns the body container, either the normal one, or the embedded full with one if exists
  21406. RowComp.prototype.getBodyRowElement = function () {
  21407. return this.eBodyRow ? this.eBodyRow : this.eFullWidthRowBody;
  21408. };
  21409. // returns the full width container
  21410. RowComp.prototype.getFullWidthRowElement = function () {
  21411. return this.eFullWidthRow;
  21412. };
  21413. RowComp.DOM_DATA_KEY_RENDERED_ROW = 'renderedRow';
  21414. RowComp.FULL_WIDTH_CELL_RENDERER = 'fullWidthCellRenderer';
  21415. RowComp.GROUP_ROW_RENDERER = 'groupRowRenderer';
  21416. RowComp.GROUP_ROW_RENDERER_COMP_NAME = 'agGroupRowRenderer';
  21417. RowComp.LOADING_CELL_RENDERER = 'loadingCellRenderer';
  21418. RowComp.LOADING_CELL_RENDERER_COMP_NAME = 'agLoadingCellRenderer';
  21419. RowComp.DETAIL_CELL_RENDERER = 'detailCellRenderer';
  21420. RowComp.DETAIL_CELL_RENDERER_COMP_NAME = 'agDetailCellRenderer';
  21421. return RowComp;
  21422. }(_widgets_component__WEBPACK_IMPORTED_MODULE_3__["Component"]));
  21423. /***/ }),
  21424. /* 101 */
  21425. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  21426. "use strict";
  21427. __webpack_require__.r(__webpack_exports__);
  21428. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellComp", function() { return CellComp; });
  21429. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(25);
  21430. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43);
  21431. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(56);
  21432. /* harmony import */ var _checkboxSelectionComponent__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(69);
  21433. /* harmony import */ var _interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(102);
  21434. /* harmony import */ var _rowDragComp__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(103);
  21435. /* harmony import */ var _cellEditors_popupEditorWrapper__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(105);
  21436. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(7);
  21437. /* harmony import */ var _dndSourceComp__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(106);
  21438. /* harmony import */ var _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(107);
  21439. /**
  21440. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  21441. * @version v23.2.1
  21442. * @link http://www.ag-grid.com/
  21443. * @license MIT
  21444. */
  21445. var __extends = (undefined && undefined.__extends) || (function () {
  21446. var extendStatics = function (d, b) {
  21447. extendStatics = Object.setPrototypeOf ||
  21448. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  21449. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  21450. return extendStatics(d, b);
  21451. };
  21452. return function (d, b) {
  21453. extendStatics(d, b);
  21454. function __() { this.constructor = d; }
  21455. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  21456. };
  21457. })();
  21458. var __assign = (undefined && undefined.__assign) || function () {
  21459. __assign = Object.assign || function(t) {
  21460. for (var s, i = 1, n = arguments.length; i < n; i++) {
  21461. s = arguments[i];
  21462. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
  21463. t[p] = s[p];
  21464. }
  21465. return t;
  21466. };
  21467. return __assign.apply(this, arguments);
  21468. };
  21469. var CellComp = /** @class */ (function (_super) {
  21470. __extends(CellComp, _super);
  21471. function CellComp(scope, beans, column, rowNode, rowComp, autoHeightCell, printLayout) {
  21472. var _this = _super.call(this) || this;
  21473. _this.hasChartRange = false;
  21474. _this.editingCell = false;
  21475. _this.suppressRefreshCell = false;
  21476. _this.scope = null;
  21477. // every time we go into edit mode, or back again, this gets incremented.
  21478. // it's the components way of dealing with the async nature of framework components,
  21479. // so if a framework component takes a while to be created, we know if the object
  21480. // is still relevant when creating is finished. eg we could click edit / un-edit 20
  21481. // times before the first React edit component comes back - we should discard
  21482. // the first 19.
  21483. _this.cellEditorVersion = 0;
  21484. _this.cellRendererVersion = 0;
  21485. _this.scope = scope;
  21486. _this.beans = beans;
  21487. _this.column = column;
  21488. _this.rowNode = rowNode;
  21489. _this.rowComp = rowComp;
  21490. _this.autoHeightCell = autoHeightCell;
  21491. _this.printLayout = printLayout;
  21492. _this.createGridCellVo();
  21493. _this.rangeSelectionEnabled = _this.beans.rangeController && beans.gridOptionsWrapper.isEnableRangeSelection();
  21494. _this.cellFocused = _this.beans.focusController.isCellFocused(_this.cellPosition);
  21495. _this.firstRightPinned = _this.column.isFirstRightPinned();
  21496. _this.lastLeftPinned = _this.column.isLastLeftPinned();
  21497. if (_this.rangeSelectionEnabled && _this.beans.rangeController) {
  21498. var rangeController = _this.beans.rangeController;
  21499. _this.rangeCount = rangeController.getCellRangeCount(_this.cellPosition);
  21500. _this.hasChartRange = _this.getHasChartRange();
  21501. }
  21502. _this.getValueAndFormat();
  21503. _this.setUsingWrapper();
  21504. _this.chooseCellRenderer();
  21505. _this.setupColSpan();
  21506. _this.rowSpan = _this.column.getRowSpan(_this.rowNode);
  21507. return _this;
  21508. }
  21509. CellComp.prototype.getCreateTemplate = function () {
  21510. var unselectable = !this.beans.gridOptionsWrapper.isEnableCellTextSelection() ? 'unselectable="on"' : '';
  21511. var templateParts = [];
  21512. var col = this.column;
  21513. var width = this.getCellWidth();
  21514. var left = this.modifyLeftForPrintLayout(this.getCellLeft());
  21515. var valueToRender = this.getInitialValueToRender();
  21516. var valueSanitised = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].get(this.column, 'colDef.template', null) ? valueToRender : _utils__WEBPACK_IMPORTED_MODULE_7__["_"].escape(valueToRender);
  21517. this.tooltip = this.getToolTip();
  21518. var tooltipSanitised = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].escape(this.tooltip);
  21519. var colIdSanitised = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].escape(col.getId());
  21520. var wrapperStartTemplate = '';
  21521. var wrapperEndTemplate = '';
  21522. var stylesFromColDef = this.preProcessStylesFromColDef();
  21523. var cssClasses = this.getInitialCssClasses();
  21524. var stylesForRowSpanning = this.getStylesForRowSpanning();
  21525. var colIdxSanitised = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].escape(this.getAriaColumnIndex());
  21526. if (this.usingWrapper) {
  21527. wrapperStartTemplate = "<div ref=\"eCellWrapper\" class=\"ag-cell-wrapper\" role=\"presentation\">\n <span ref=\"eCellValue\" role=\"gridcell\" aria-colindex=\"" + colIdxSanitised + "\" class=\"ag-cell-value\" " + unselectable + ">";
  21528. wrapperEndTemplate = '</span></div>';
  21529. }
  21530. templateParts.push("<div");
  21531. templateParts.push(" tabindex=\"-1\"");
  21532. templateParts.push(" " + unselectable); // THIS IS FOR IE ONLY so text selection doesn't bubble outside of the grid
  21533. templateParts.push(" role=\"" + (this.usingWrapper ? 'presentation' : 'gridcell') + "\"");
  21534. if (!this.usingWrapper) {
  21535. templateParts.push(" aria-colindex=" + colIdxSanitised);
  21536. }
  21537. templateParts.push(" comp-id=\"" + this.getCompId() + "\" ");
  21538. templateParts.push(" col-id=\"" + colIdSanitised + "\"");
  21539. templateParts.push(" class=\"" + _utils__WEBPACK_IMPORTED_MODULE_7__["_"].escape(cssClasses.join(' ')) + "\"");
  21540. if (this.beans.gridOptionsWrapper.isEnableBrowserTooltips() && _utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(tooltipSanitised)) {
  21541. templateParts.push("title=\"" + tooltipSanitised + "\"");
  21542. }
  21543. templateParts.push(" style=\"width: " + Number(width) + "px; left: " + Number(left) + "px; " + _utils__WEBPACK_IMPORTED_MODULE_7__["_"].escape(stylesFromColDef) + " " + _utils__WEBPACK_IMPORTED_MODULE_7__["_"].escape(stylesForRowSpanning) + "\" >");
  21544. templateParts.push(wrapperStartTemplate);
  21545. if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(valueSanitised, true)) {
  21546. templateParts.push(valueSanitised);
  21547. }
  21548. templateParts.push(wrapperEndTemplate);
  21549. templateParts.push("</div>");
  21550. return templateParts.join('');
  21551. };
  21552. CellComp.prototype.getStylesForRowSpanning = function () {
  21553. if (this.rowSpan === 1) {
  21554. return '';
  21555. }
  21556. var singleRowHeight = this.beans.gridOptionsWrapper.getRowHeightAsNumber();
  21557. var totalRowHeight = singleRowHeight * this.rowSpan;
  21558. return "height: " + totalRowHeight + "px; z-index: 1;";
  21559. };
  21560. CellComp.prototype.afterAttached = function () {
  21561. var querySelector = "[comp-id=\"" + this.getCompId() + "\"]";
  21562. var eGui = this.eParentRow.querySelector(querySelector);
  21563. this.setGui(eGui);
  21564. // all of these have dependencies on the eGui, so only do them after eGui is set
  21565. this.addDomData();
  21566. this.populateTemplate();
  21567. this.createCellRendererInstance(true);
  21568. this.angular1Compile();
  21569. this.refreshHandle();
  21570. if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(this.tooltip) && !this.beans.gridOptionsWrapper.isEnableBrowserTooltips()) {
  21571. this.createManagedBean(new _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_9__["TooltipFeature"](this, 'cell'), this.beans.context);
  21572. }
  21573. };
  21574. CellComp.prototype.onColumnHover = function () {
  21575. var isHovered = this.beans.columnHoverService.isHovered(this.column);
  21576. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui(), 'ag-column-hover', isHovered);
  21577. };
  21578. CellComp.prototype.onCellChanged = function (event) {
  21579. var eventImpactsThisCell = event.column === this.column;
  21580. if (eventImpactsThisCell) {
  21581. this.refreshCell({});
  21582. }
  21583. };
  21584. CellComp.prototype.getCellLeft = function () {
  21585. var mostLeftCol;
  21586. if (this.beans.gridOptionsWrapper.isEnableRtl() && this.colsSpanning) {
  21587. mostLeftCol = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].last(this.colsSpanning);
  21588. }
  21589. else {
  21590. mostLeftCol = this.column;
  21591. }
  21592. return mostLeftCol.getLeft();
  21593. };
  21594. CellComp.prototype.getCellWidth = function () {
  21595. if (!this.colsSpanning) {
  21596. return this.column.getActualWidth();
  21597. }
  21598. return this.colsSpanning.reduce(function (width, col) { return width + col.getActualWidth(); }, 0);
  21599. };
  21600. CellComp.prototype.onFlashCells = function (event) {
  21601. var cellId = this.beans.cellPositionUtils.createId(this.cellPosition);
  21602. var shouldFlash = event.cells[cellId];
  21603. if (shouldFlash) {
  21604. this.animateCell('highlight');
  21605. }
  21606. };
  21607. CellComp.prototype.setupColSpan = function () {
  21608. // if no col span is active, then we don't set it up, as it would be wasteful of CPU
  21609. if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(this.getComponentHolder().colSpan)) {
  21610. return;
  21611. }
  21612. // because we are col spanning, a reorder of the cols can change what cols we are spanning over
  21613. this.addManagedListener(this.beans.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayColumnsChanged.bind(this));
  21614. // because we are spanning over multiple cols, we check for width any time any cols width changes.
  21615. // this is expensive - really we should be explicitly checking only the cols we are spanning over
  21616. // instead of every col, however it would be tricky code to track the cols we are spanning over, so
  21617. // because hardly anyone will be using colSpan, am favouring this easier way for more maintainable code.
  21618. this.addManagedListener(this.beans.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, this.onWidthChanged.bind(this));
  21619. this.colsSpanning = this.getColSpanningList();
  21620. };
  21621. CellComp.prototype.getColSpanningList = function () {
  21622. var colSpan = this.column.getColSpan(this.rowNode);
  21623. var colsSpanning = [];
  21624. // if just one col, the col span is just the column we are in
  21625. if (colSpan === 1) {
  21626. colsSpanning.push(this.column);
  21627. }
  21628. else {
  21629. var pointer = this.column;
  21630. var pinned = this.column.getPinned();
  21631. for (var i = 0; pointer && i < colSpan; i++) {
  21632. colsSpanning.push(pointer);
  21633. pointer = this.beans.columnController.getDisplayedColAfter(pointer);
  21634. if (!pointer || _utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(pointer)) {
  21635. break;
  21636. }
  21637. // we do not allow col spanning to span outside of pinned areas
  21638. if (pinned !== pointer.getPinned()) {
  21639. break;
  21640. }
  21641. }
  21642. }
  21643. return colsSpanning;
  21644. };
  21645. CellComp.prototype.onDisplayColumnsChanged = function () {
  21646. var colsSpanning = this.getColSpanningList();
  21647. if (!_utils__WEBPACK_IMPORTED_MODULE_7__["_"].areEqual(this.colsSpanning, colsSpanning)) {
  21648. this.colsSpanning = colsSpanning;
  21649. this.onWidthChanged();
  21650. this.onLeftChanged(); // left changes when doing RTL
  21651. }
  21652. };
  21653. CellComp.prototype.getAriaColumnIndex = function () {
  21654. var allColumns = this.beans.columnController.getAllDisplayedColumns();
  21655. return (allColumns.indexOf(this.column) + 1).toString();
  21656. };
  21657. CellComp.prototype.refreshAriaIndex = function () {
  21658. var colIdx = this.getAriaColumnIndex();
  21659. var el = this.usingWrapper ? this.eCellValue : this.getGui();
  21660. el.setAttribute('aria-colindex', colIdx);
  21661. };
  21662. CellComp.prototype.getInitialCssClasses = function () {
  21663. var cssClasses = ["ag-cell", "ag-cell-not-inline-editing"];
  21664. // if we are putting the cell into a dummy container, to work out it's height,
  21665. // then we don't put the height css in, as we want cell to fit height in that case.
  21666. if (!this.autoHeightCell) {
  21667. cssClasses.push('ag-cell-auto-height');
  21668. }
  21669. var doingFocusCss = !this.beans.gridOptionsWrapper.isSuppressCellSelection();
  21670. if (doingFocusCss && this.cellFocused) {
  21671. // otherwise the class depends on the focus state
  21672. cssClasses.push('ag-cell-focus');
  21673. }
  21674. if (this.firstRightPinned) {
  21675. cssClasses.push('ag-cell-first-right-pinned');
  21676. }
  21677. if (this.lastLeftPinned) {
  21678. cssClasses.push('ag-cell-last-left-pinned');
  21679. }
  21680. if (this.beans.columnHoverService.isHovered(this.column)) {
  21681. cssClasses.push('ag-column-hover');
  21682. }
  21683. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].pushAll(cssClasses, this.preProcessClassesFromColDef());
  21684. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].pushAll(cssClasses, this.preProcessCellClassRules());
  21685. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].pushAll(cssClasses, this.getInitialRangeClasses());
  21686. // if using the wrapper, this class goes on the wrapper instead
  21687. if (!this.usingWrapper) {
  21688. cssClasses.push('ag-cell-value');
  21689. }
  21690. return cssClasses;
  21691. };
  21692. CellComp.prototype.getInitialValueToRender = function () {
  21693. // if using a cellRenderer, then render the html from the cell renderer if it exists
  21694. if (this.usingCellRenderer) {
  21695. if (typeof this.cellRendererGui === 'string') {
  21696. return this.cellRendererGui;
  21697. }
  21698. return '';
  21699. }
  21700. var colDef = this.getComponentHolder();
  21701. if (colDef.template) {
  21702. // template is really only used for angular 1 - as people using ng1 are used to providing templates with
  21703. // bindings in it. in ng2, people will hopefully want to provide components, not templates.
  21704. return colDef.template;
  21705. }
  21706. if (colDef.templateUrl) {
  21707. // likewise for templateUrl - it's for ng1 really - when we move away from ng1, we can take these out.
  21708. // niall was pro angular 1 when writing template and templateUrl, if writing from scratch now, would
  21709. // not do these, but would follow a pattern that was friendly towards components, not templates.
  21710. var template = this.beans.templateService.getTemplate(colDef.templateUrl, this.refreshCell.bind(this, true));
  21711. return template || '';
  21712. }
  21713. return this.getValueToUse();
  21714. };
  21715. CellComp.prototype.getRenderedRow = function () {
  21716. return this.rowComp;
  21717. };
  21718. CellComp.prototype.isSuppressNavigable = function () {
  21719. return this.column.isSuppressNavigable(this.rowNode);
  21720. };
  21721. CellComp.prototype.getCellRenderer = function () {
  21722. return this.cellRenderer;
  21723. };
  21724. CellComp.prototype.getCellEditor = function () {
  21725. return this.cellEditor;
  21726. };
  21727. // + stop editing {forceRefresh: true, suppressFlash: true}
  21728. // + event cellChanged {}
  21729. // + cellRenderer.params.refresh() {} -> method passes 'as is' to the cellRenderer, so params could be anything
  21730. // + rowComp: event dataChanged {animate: update, newData: !update}
  21731. // + rowComp: api refreshCells() {animate: true/false}
  21732. // + rowRenderer: api softRefreshView() {}
  21733. CellComp.prototype.refreshCell = function (params) {
  21734. // if we are in the middle of 'stopEditing', then we don't refresh here, as refresh gets called explicitly
  21735. if (this.suppressRefreshCell || this.editingCell) {
  21736. return;
  21737. }
  21738. var colDef = this.getComponentHolder();
  21739. var newData = params && params.newData;
  21740. var suppressFlash = (params && params.suppressFlash) || colDef.suppressCellFlash;
  21741. var forceRefresh = params && params.forceRefresh;
  21742. var oldValue = this.value;
  21743. // get latest value without invoking the value formatter as we may not be updating the cell
  21744. this.value = this.getValue();
  21745. // for simple values only (not objects), see if the value is the same, and if it is, skip the refresh.
  21746. // when never allow skipping after an edit, as after editing, we need to put the GUI back to the way
  21747. // if was before the edit.
  21748. var valuesDifferent = !this.valuesAreEqual(oldValue, this.value);
  21749. var dataNeedsUpdating = forceRefresh || valuesDifferent;
  21750. if (dataNeedsUpdating) {
  21751. // now invoke the value formatter as we are going to update cell
  21752. this.valueFormatted = this.beans.valueFormatterService.formatValue(this.column, this.rowNode, this.scope, this.value);
  21753. // if it's 'new data', then we don't refresh the cellRenderer, even if refresh method is available.
  21754. // this is because if the whole data is new (ie we are showing stock price 'BBA' now and not 'SSD')
  21755. // then we are not showing a movement in the stock price, rather we are showing different stock.
  21756. var cellRendererRefreshed = newData ? false : this.attemptCellRendererRefresh();
  21757. // we do the replace if not doing refresh, or if refresh was unsuccessful.
  21758. // the refresh can be unsuccessful if we are using a framework (eg ng2 or react) and the framework
  21759. // wrapper has the refresh method, but the underlying component doesn't
  21760. if (!cellRendererRefreshed) {
  21761. this.replaceContentsAfterRefresh();
  21762. }
  21763. // we don't want to flash the cells when processing a filter change, as otherwise the UI would
  21764. // be to busy. see comment in FilterManager with regards processingFilterChange
  21765. var processingFilterChange = this.beans.filterManager.isSuppressFlashingCellsBecauseFiltering();
  21766. var flashCell = !suppressFlash && !processingFilterChange &&
  21767. (this.beans.gridOptionsWrapper.isEnableCellChangeFlash() || colDef.enableCellChangeFlash);
  21768. if (flashCell) {
  21769. this.flashCell();
  21770. }
  21771. // need to check rules. note, we ignore colDef classes and styles, these are assumed to be static
  21772. this.postProcessStylesFromColDef();
  21773. this.postProcessClassesFromColDef();
  21774. }
  21775. // we can't readily determine if the data in an angularjs template has changed, so here we just update
  21776. // and recompile (if applicable)
  21777. this.updateAngular1ScopeAndCompile();
  21778. this.refreshToolTip();
  21779. // we do cellClassRules even if the value has not changed, so that users who have rules that
  21780. // look at other parts of the row (where the other part of the row might of changed) will work.
  21781. this.postProcessCellClassRules();
  21782. };
  21783. // user can also call this via API
  21784. CellComp.prototype.flashCell = function (delays) {
  21785. var flashDelay = delays && delays.flashDelay;
  21786. var fadeDelay = delays && delays.fadeDelay;
  21787. this.animateCell('data-changed', flashDelay, fadeDelay);
  21788. };
  21789. CellComp.prototype.animateCell = function (cssName, flashDelay, fadeDelay) {
  21790. var fullName = "ag-cell-" + cssName;
  21791. var animationFullName = "ag-cell-" + cssName + "-animation";
  21792. var element = this.getGui();
  21793. var gridOptionsWrapper = this.beans.gridOptionsWrapper;
  21794. if (!flashDelay) {
  21795. flashDelay = gridOptionsWrapper.getCellFlashDelay();
  21796. }
  21797. if (!fadeDelay) {
  21798. fadeDelay = gridOptionsWrapper.getCellFadeDelay();
  21799. }
  21800. // we want to highlight the cells, without any animation
  21801. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(element, fullName);
  21802. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(element, animationFullName);
  21803. // then once that is applied, we remove the highlight with animation
  21804. window.setTimeout(function () {
  21805. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(element, fullName);
  21806. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(element, animationFullName);
  21807. element.style.transition = "background-color " + fadeDelay + "ms";
  21808. window.setTimeout(function () {
  21809. // and then to leave things as we got them, we remove the animation
  21810. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(element, animationFullName);
  21811. element.style.transition = null;
  21812. }, fadeDelay);
  21813. }, flashDelay);
  21814. };
  21815. CellComp.prototype.replaceContentsAfterRefresh = function () {
  21816. // otherwise we rip out the cell and replace it
  21817. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].clearElement(this.eParentOfValue);
  21818. // remove old renderer component if it exists
  21819. this.cellRenderer = this.beans.context.destroyBean(this.cellRenderer);
  21820. this.cellRendererGui = null;
  21821. // populate
  21822. this.putDataIntoCellAfterRefresh();
  21823. this.updateAngular1ScopeAndCompile();
  21824. };
  21825. CellComp.prototype.updateAngular1ScopeAndCompile = function () {
  21826. if (this.beans.gridOptionsWrapper.isAngularCompileRows() && this.scope) {
  21827. this.scope.data = __assign({}, this.rowNode.data);
  21828. this.angular1Compile();
  21829. }
  21830. };
  21831. CellComp.prototype.angular1Compile = function () {
  21832. // if angular compiling, then need to also compile the cell again (angular compiling sucks, please wait...)
  21833. if (this.beans.gridOptionsWrapper.isAngularCompileRows()) {
  21834. var eGui = this.getGui();
  21835. // only compile the node if it hasn't already been done
  21836. // this prevents "orphaned" node leaks
  21837. if (!eGui.classList.contains('ng-scope') || eGui.childElementCount === 0) {
  21838. var compiledElement_1 = this.beans.$compile(eGui)(this.scope);
  21839. this.addDestroyFunc(function () { return compiledElement_1.remove(); });
  21840. }
  21841. }
  21842. };
  21843. CellComp.prototype.postProcessStylesFromColDef = function () {
  21844. var stylesToUse = this.processStylesFromColDef();
  21845. if (stylesToUse) {
  21846. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addStylesToElement(this.getGui(), stylesToUse);
  21847. }
  21848. };
  21849. CellComp.prototype.preProcessStylesFromColDef = function () {
  21850. return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].cssStyleObjectToMarkup(this.processStylesFromColDef());
  21851. };
  21852. CellComp.prototype.processStylesFromColDef = function () {
  21853. var colDef = this.getComponentHolder();
  21854. if (colDef.cellStyle) {
  21855. var cssToUse = void 0;
  21856. if (typeof colDef.cellStyle === 'function') {
  21857. var cellStyleParams = {
  21858. value: this.value,
  21859. data: this.rowNode.data,
  21860. node: this.rowNode,
  21861. colDef: colDef,
  21862. column: this.column,
  21863. $scope: this.scope,
  21864. context: this.beans.gridOptionsWrapper.getContext(),
  21865. api: this.beans.gridOptionsWrapper.getApi()
  21866. };
  21867. var cellStyleFunc = colDef.cellStyle;
  21868. cssToUse = cellStyleFunc(cellStyleParams);
  21869. }
  21870. else {
  21871. cssToUse = colDef.cellStyle;
  21872. }
  21873. return cssToUse;
  21874. }
  21875. };
  21876. CellComp.prototype.postProcessClassesFromColDef = function () {
  21877. var _this = this;
  21878. this.processClassesFromColDef(function (className) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(_this.getGui(), className); });
  21879. };
  21880. CellComp.prototype.preProcessClassesFromColDef = function () {
  21881. var res = [];
  21882. this.processClassesFromColDef(function (className) { return res.push(className); });
  21883. return res;
  21884. };
  21885. CellComp.prototype.processClassesFromColDef = function (onApplicableClass) {
  21886. var colDef = this.getComponentHolder();
  21887. this.beans.stylingService.processStaticCellClasses(colDef, {
  21888. value: this.value,
  21889. data: this.rowNode.data,
  21890. node: this.rowNode,
  21891. colDef: colDef,
  21892. rowIndex: this.rowNode.rowIndex,
  21893. $scope: this.scope,
  21894. api: this.beans.gridOptionsWrapper.getApi(),
  21895. columnApi: this.beans.gridOptionsWrapper.getColumnApi(),
  21896. context: this.beans.gridOptionsWrapper.getContext()
  21897. }, onApplicableClass);
  21898. };
  21899. CellComp.prototype.putDataIntoCellAfterRefresh = function () {
  21900. // template gets preference, then cellRenderer, then do it ourselves
  21901. var colDef = this.getComponentHolder();
  21902. if (colDef.template) {
  21903. // template is really only used for angular 1 - as people using ng1 are used to providing templates with
  21904. // bindings in it. in ng2, people will hopefully want to provide components, not templates.
  21905. this.eParentOfValue.innerHTML = colDef.template;
  21906. }
  21907. else if (colDef.templateUrl) {
  21908. // likewise for templateUrl - it's for ng1 really - when we move away from ng1, we can take these out.
  21909. // niall was pro angular 1 when writing template and templateUrl, if writing from scratch now, would
  21910. // not do these, but would follow a pattern that was friendly towards components, not templates.
  21911. var template = this.beans.templateService.getTemplate(colDef.templateUrl, this.refreshCell.bind(this, true));
  21912. if (template) {
  21913. this.eParentOfValue.innerHTML = template;
  21914. }
  21915. }
  21916. else {
  21917. // we can switch from using a cell renderer back to the default if a user
  21918. // is using cellRendererSelect
  21919. this.chooseCellRenderer();
  21920. if (this.usingCellRenderer) {
  21921. this.createCellRendererInstance();
  21922. }
  21923. else {
  21924. var valueToUse = this.getValueToUse();
  21925. if (valueToUse != null) {
  21926. this.eParentOfValue.innerHTML = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].escape(valueToUse);
  21927. }
  21928. }
  21929. }
  21930. };
  21931. CellComp.prototype.attemptCellRendererRefresh = function () {
  21932. if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(this.cellRenderer) || !this.cellRenderer || _utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(this.cellRenderer.refresh)) {
  21933. return false;
  21934. }
  21935. // if the cell renderer has a refresh method, we call this instead of doing a refresh
  21936. var params = this.createCellRendererParams();
  21937. // take any custom params off of the user
  21938. var finalParams = this.beans.userComponentFactory.createFinalParams(this.getComponentHolder(), this.cellRendererType, params);
  21939. var result = this.cellRenderer.refresh(finalParams);
  21940. // NOTE on undefined: previous version of the cellRenderer.refresh() interface
  21941. // returned nothing, if the method existed, we assumed it refreshed. so for
  21942. // backwards compatibility, we assume if method exists and returns nothing,
  21943. // that it was successful.
  21944. return result === true || result === undefined;
  21945. };
  21946. CellComp.prototype.refreshToolTip = function () {
  21947. var newTooltip = this.getToolTip();
  21948. if (this.tooltip === newTooltip) {
  21949. return;
  21950. }
  21951. var hasNewTooltip = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(newTooltip);
  21952. if (hasNewTooltip && this.tooltip === newTooltip.toString()) {
  21953. return;
  21954. }
  21955. var hadTooltip = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(this.tooltip);
  21956. this.tooltip = newTooltip;
  21957. if (this.beans.gridOptionsWrapper.isEnableBrowserTooltips()) {
  21958. if (hasNewTooltip) {
  21959. this.eParentOfValue.setAttribute('title', this.tooltip);
  21960. }
  21961. else {
  21962. this.eParentOfValue.removeAttribute('title');
  21963. }
  21964. }
  21965. };
  21966. CellComp.prototype.valuesAreEqual = function (val1, val2) {
  21967. // if the user provided an equals method, use that, otherwise do simple comparison
  21968. var colDef = this.getComponentHolder();
  21969. var equalsMethod = colDef ? colDef.equals : null;
  21970. return equalsMethod ? equalsMethod(val1, val2) : val1 === val2;
  21971. };
  21972. CellComp.prototype.getToolTip = function () {
  21973. var colDef = this.getComponentHolder();
  21974. var data = this.rowNode.data;
  21975. if (colDef.tooltipField && _utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(data)) {
  21976. return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].getValueUsingField(data, colDef.tooltipField, this.column.isTooltipFieldContainsDots());
  21977. }
  21978. var valueGetter = colDef.tooltipValueGetter || colDef.tooltip;
  21979. if (valueGetter) {
  21980. return valueGetter({
  21981. api: this.beans.gridOptionsWrapper.getApi(),
  21982. columnApi: this.beans.gridOptionsWrapper.getColumnApi(),
  21983. colDef: colDef,
  21984. column: this.getColumn(),
  21985. context: this.beans.gridOptionsWrapper.getContext(),
  21986. value: this.value,
  21987. valueFormatted: this.valueFormatted,
  21988. rowIndex: this.cellPosition.rowIndex,
  21989. node: this.rowNode,
  21990. data: this.rowNode.data
  21991. });
  21992. }
  21993. return null;
  21994. };
  21995. CellComp.prototype.getTooltipText = function (escape) {
  21996. if (escape === void 0) { escape = true; }
  21997. return escape ? _utils__WEBPACK_IMPORTED_MODULE_7__["_"].escape(this.tooltip) : this.tooltip;
  21998. };
  21999. CellComp.prototype.processCellClassRules = function (onApplicableClass, onNotApplicableClass) {
  22000. var colDef = this.getComponentHolder();
  22001. this.beans.stylingService.processClassRules(colDef.cellClassRules, {
  22002. value: this.value,
  22003. data: this.rowNode.data,
  22004. node: this.rowNode,
  22005. colDef: colDef,
  22006. rowIndex: this.cellPosition.rowIndex,
  22007. api: this.beans.gridOptionsWrapper.getApi(),
  22008. columnApi: this.beans.gridOptionsWrapper.getColumnApi(),
  22009. $scope: this.scope,
  22010. context: this.beans.gridOptionsWrapper.getContext()
  22011. }, onApplicableClass, onNotApplicableClass);
  22012. };
  22013. CellComp.prototype.postProcessCellClassRules = function () {
  22014. var _this = this;
  22015. this.processCellClassRules(function (className) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(_this.getGui(), className); }, function (className) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(_this.getGui(), className); });
  22016. };
  22017. CellComp.prototype.preProcessCellClassRules = function () {
  22018. var res = [];
  22019. this.processCellClassRules(function (className) { return res.push(className); }, function (_) {
  22020. // not catered for, if creating, no need
  22021. // to remove class as it was never there
  22022. });
  22023. return res;
  22024. };
  22025. // a wrapper is used when we are putting a selection checkbox in the cell with the value
  22026. CellComp.prototype.setUsingWrapper = function () {
  22027. var colDef = this.getComponentHolder();
  22028. // never allow selection or dragging on pinned rows
  22029. if (this.rowNode.rowPinned) {
  22030. this.usingWrapper = false;
  22031. this.includeSelectionComponent = false;
  22032. this.includeRowDraggingComponent = false;
  22033. this.includeDndSourceComponent = false;
  22034. return;
  22035. }
  22036. var cbSelectionIsFunc = typeof colDef.checkboxSelection === 'function';
  22037. var rowDraggableIsFunc = typeof colDef.rowDrag === 'function';
  22038. var dndSourceIsFunc = typeof colDef.dndSource === 'function';
  22039. this.includeSelectionComponent = cbSelectionIsFunc || colDef.checkboxSelection === true;
  22040. this.includeRowDraggingComponent = rowDraggableIsFunc || colDef.rowDrag === true;
  22041. this.includeDndSourceComponent = dndSourceIsFunc || colDef.dndSource === true;
  22042. var enableTextSelection = this.beans.gridOptionsWrapper.isEnableCellTextSelection();
  22043. this.usingWrapper = enableTextSelection || this.includeRowDraggingComponent || this.includeSelectionComponent || this.includeDndSourceComponent;
  22044. };
  22045. CellComp.prototype.chooseCellRenderer = function () {
  22046. // template gets preference, then cellRenderer, then do it ourselves
  22047. var colDef = this.getComponentHolder();
  22048. // templates are for ng1, ideally we wouldn't have these, they are ng1 support
  22049. // inside the core which is bad
  22050. if (colDef.template || colDef.templateUrl) {
  22051. this.usingCellRenderer = false;
  22052. return;
  22053. }
  22054. var params = this.createCellRendererParams();
  22055. var cellRenderer = this.beans.userComponentFactory.lookupComponentClassDef(colDef, 'cellRenderer', params);
  22056. var pinnedRowCellRenderer = this.beans.userComponentFactory.lookupComponentClassDef(colDef, 'pinnedRowCellRenderer', params);
  22057. if (pinnedRowCellRenderer && this.rowNode.rowPinned) {
  22058. this.cellRendererType = CellComp.CELL_RENDERER_TYPE_PINNED;
  22059. this.usingCellRenderer = true;
  22060. }
  22061. else if (cellRenderer) {
  22062. this.cellRendererType = CellComp.CELL_RENDERER_TYPE_NORMAL;
  22063. this.usingCellRenderer = true;
  22064. }
  22065. else {
  22066. this.usingCellRenderer = false;
  22067. }
  22068. };
  22069. CellComp.prototype.createCellRendererInstance = function (useTaskService) {
  22070. var _this = this;
  22071. if (useTaskService === void 0) { useTaskService = false; }
  22072. if (!this.usingCellRenderer) {
  22073. return;
  22074. }
  22075. // never use task service if angularCompileRows=true, as that assume the cell renderers
  22076. // are finished when the row is created. also we never use it if animation frame service
  22077. // is turned off.
  22078. // and lastly we never use it if doing auto-height, as the auto-height service checks the
  22079. // row height directly after the cell is created, it doesn't wait around for the tasks to complete
  22080. var angularCompileRows = this.beans.gridOptionsWrapper.isAngularCompileRows();
  22081. var suppressAnimationFrame = this.beans.gridOptionsWrapper.isSuppressAnimationFrame();
  22082. if (angularCompileRows || suppressAnimationFrame || this.autoHeightCell) {
  22083. useTaskService = false;
  22084. }
  22085. var params = this.createCellRendererParams();
  22086. this.cellRendererVersion++;
  22087. var callback = this.afterCellRendererCreated.bind(this, this.cellRendererVersion);
  22088. var cellRendererTypeNormal = this.cellRendererType === CellComp.CELL_RENDERER_TYPE_NORMAL;
  22089. this.createCellRendererFunc = function () {
  22090. _this.createCellRendererFunc = null;
  22091. // this can return null in the event that the user has switched from a renderer component to nothing, for example
  22092. // when using a cellRendererSelect to return a component or null depending on row data etc
  22093. var componentPromise = _this.beans.userComponentFactory.newCellRenderer(_this.getComponentHolder(), params, !cellRendererTypeNormal);
  22094. if (componentPromise) {
  22095. componentPromise.then(callback);
  22096. }
  22097. };
  22098. if (useTaskService) {
  22099. this.beans.taskQueue.createTask(this.createCellRendererFunc, this.rowNode.rowIndex, 'createTasksP2');
  22100. }
  22101. else {
  22102. this.createCellRendererFunc();
  22103. }
  22104. };
  22105. CellComp.prototype.afterCellRendererCreated = function (cellRendererVersion, cellRenderer) {
  22106. var cellRendererNotRequired = !this.isAlive() || (cellRendererVersion !== this.cellRendererVersion);
  22107. if (cellRendererNotRequired) {
  22108. this.beans.context.destroyBean(cellRenderer);
  22109. return;
  22110. }
  22111. this.cellRenderer = cellRenderer;
  22112. this.cellRendererGui = this.cellRenderer.getGui();
  22113. if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(this.cellRendererGui)) {
  22114. return;
  22115. }
  22116. // if async components, then it's possible the user started editing since this call was made
  22117. if (!this.editingCell) {
  22118. this.eParentOfValue.appendChild(this.cellRendererGui);
  22119. }
  22120. };
  22121. CellComp.prototype.createCellRendererParams = function () {
  22122. var _this = this;
  22123. return {
  22124. value: this.value,
  22125. valueFormatted: this.valueFormatted,
  22126. getValue: this.getValue.bind(this),
  22127. setValue: function (value) { return _this.beans.valueService.setValue(_this.rowNode, _this.column, value); },
  22128. formatValue: this.formatValue.bind(this),
  22129. data: this.rowNode.data,
  22130. node: this.rowNode,
  22131. colDef: this.getComponentHolder(),
  22132. column: this.column,
  22133. $scope: this.scope,
  22134. rowIndex: this.cellPosition.rowIndex,
  22135. api: this.beans.gridOptionsWrapper.getApi(),
  22136. columnApi: this.beans.gridOptionsWrapper.getColumnApi(),
  22137. context: this.beans.gridOptionsWrapper.getContext(),
  22138. refreshCell: this.refreshCell.bind(this),
  22139. eGridCell: this.getGui(),
  22140. eParentOfValue: this.eParentOfValue,
  22141. // these bits are not documented anywhere, so we could drop them?
  22142. // it was in the olden days to allow user to register for when rendered
  22143. // row was removed (the row comp was removed), however now that the user
  22144. // can provide components for cells, the destroy method gets call when this
  22145. // happens so no longer need to fire event.
  22146. addRowCompListener: this.rowComp ? this.rowComp.addEventListener.bind(this.rowComp) : null,
  22147. addRenderedRowListener: function (eventType, listener) {
  22148. console.warn('ag-Grid: since ag-Grid .v11, params.addRenderedRowListener() is now params.addRowCompListener()');
  22149. if (_this.rowComp) {
  22150. _this.rowComp.addEventListener(eventType, listener);
  22151. }
  22152. }
  22153. };
  22154. };
  22155. CellComp.prototype.formatValue = function (value) {
  22156. var valueFormatted = this.beans.valueFormatterService.formatValue(this.column, this.rowNode, this.scope, value);
  22157. return valueFormatted != null ? valueFormatted : value;
  22158. };
  22159. CellComp.prototype.getValueToUse = function () {
  22160. return this.valueFormatted != null ? this.valueFormatted : this.value;
  22161. };
  22162. CellComp.prototype.getValueAndFormat = function () {
  22163. this.value = this.getValue();
  22164. this.valueFormatted = this.beans.valueFormatterService.formatValue(this.column, this.rowNode, this.scope, this.value);
  22165. };
  22166. CellComp.prototype.getValue = function () {
  22167. // if we don't check this, then the grid will render leaf groups as open even if we are not
  22168. // allowing the user to open leaf groups. confused? remember for pivot mode we don't allow
  22169. // opening leaf groups, so we have to force leafGroups to be closed in case the user expanded
  22170. // them via the API, or user user expanded them in the UI before turning on pivot mode
  22171. var lockedClosedGroup = this.rowNode.leafGroup && this.beans.columnController.isPivotMode();
  22172. var isOpenGroup = this.rowNode.group && this.rowNode.expanded && !this.rowNode.footer && !lockedClosedGroup;
  22173. // are we showing group footers
  22174. var groupFootersEnabled = this.beans.gridOptionsWrapper.isGroupIncludeFooter();
  22175. // if doing footers, we normally don't show agg data at group level when group is open
  22176. var groupAlwaysShowAggData = this.beans.gridOptionsWrapper.isGroupSuppressBlankHeader();
  22177. // if doing grouping and footers, we don't want to include the agg value
  22178. // in the header when the group is open
  22179. var ignoreAggData = (isOpenGroup && groupFootersEnabled) && !groupAlwaysShowAggData;
  22180. return this.beans.valueService.getValue(this.column, this.rowNode, false, ignoreAggData);
  22181. };
  22182. CellComp.prototype.onMouseEvent = function (eventName, mouseEvent) {
  22183. if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].isStopPropagationForAgGrid(mouseEvent)) {
  22184. return;
  22185. }
  22186. switch (eventName) {
  22187. case 'click':
  22188. this.onCellClicked(mouseEvent);
  22189. break;
  22190. case 'mousedown':
  22191. this.onMouseDown(mouseEvent);
  22192. break;
  22193. case 'dblclick':
  22194. this.onCellDoubleClicked(mouseEvent);
  22195. break;
  22196. case 'mouseout':
  22197. this.onMouseOut(mouseEvent);
  22198. break;
  22199. case 'mouseover':
  22200. this.onMouseOver(mouseEvent);
  22201. break;
  22202. }
  22203. };
  22204. CellComp.prototype.dispatchCellContextMenuEvent = function (event) {
  22205. var colDef = this.getComponentHolder();
  22206. var cellContextMenuEvent = this.createEvent(event, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_CONTEXT_MENU);
  22207. this.beans.eventService.dispatchEvent(cellContextMenuEvent);
  22208. if (colDef.onCellContextMenu) {
  22209. // to make the callback async, do in a timeout
  22210. window.setTimeout(function () { return colDef.onCellContextMenu(cellContextMenuEvent); }, 0);
  22211. }
  22212. };
  22213. CellComp.prototype.createEvent = function (domEvent, eventType) {
  22214. var event = {
  22215. node: this.rowNode,
  22216. data: this.rowNode.data,
  22217. value: this.value,
  22218. column: this.column,
  22219. colDef: this.getComponentHolder(),
  22220. context: this.beans.gridOptionsWrapper.getContext(),
  22221. api: this.beans.gridApi,
  22222. columnApi: this.beans.columnApi,
  22223. rowPinned: this.rowNode.rowPinned,
  22224. event: domEvent,
  22225. type: eventType,
  22226. rowIndex: this.rowNode.rowIndex
  22227. };
  22228. // because we are hacking in $scope for angular 1, we have to de-reference
  22229. if (this.scope) {
  22230. event.$scope = this.scope;
  22231. }
  22232. return event;
  22233. };
  22234. CellComp.prototype.onMouseOut = function (mouseEvent) {
  22235. var cellMouseOutEvent = this.createEvent(mouseEvent, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_MOUSE_OUT);
  22236. this.beans.eventService.dispatchEvent(cellMouseOutEvent);
  22237. this.beans.columnHoverService.clearMouseOver();
  22238. };
  22239. CellComp.prototype.onMouseOver = function (mouseEvent) {
  22240. var cellMouseOverEvent = this.createEvent(mouseEvent, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_MOUSE_OVER);
  22241. this.beans.eventService.dispatchEvent(cellMouseOverEvent);
  22242. this.beans.columnHoverService.setMouseOver([this.column]);
  22243. };
  22244. CellComp.prototype.onCellDoubleClicked = function (mouseEvent) {
  22245. var colDef = this.getComponentHolder();
  22246. // always dispatch event to eventService
  22247. var cellDoubleClickedEvent = this.createEvent(mouseEvent, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_DOUBLE_CLICKED);
  22248. this.beans.eventService.dispatchEvent(cellDoubleClickedEvent);
  22249. // check if colDef also wants to handle event
  22250. if (typeof colDef.onCellDoubleClicked === 'function') {
  22251. // to make the callback async, do in a timeout
  22252. window.setTimeout(function () { return colDef.onCellDoubleClicked(cellDoubleClickedEvent); }, 0);
  22253. }
  22254. var editOnDoubleClick = !this.beans.gridOptionsWrapper.isSingleClickEdit()
  22255. && !this.beans.gridOptionsWrapper.isSuppressClickEdit();
  22256. if (editOnDoubleClick) {
  22257. this.startRowOrCellEdit();
  22258. }
  22259. };
  22260. // called by rowRenderer when user navigates via tab key
  22261. CellComp.prototype.startRowOrCellEdit = function (keyPress, charPress) {
  22262. if (this.beans.gridOptionsWrapper.isFullRowEdit()) {
  22263. this.rowComp.startRowEditing(keyPress, charPress, this);
  22264. }
  22265. else {
  22266. this.startEditingIfEnabled(keyPress, charPress, true);
  22267. }
  22268. };
  22269. CellComp.prototype.isCellEditable = function () {
  22270. return this.column.isCellEditable(this.rowNode);
  22271. };
  22272. // either called internally if single cell editing, or called by rowRenderer if row editing
  22273. CellComp.prototype.startEditingIfEnabled = function (keyPress, charPress, cellStartedEdit) {
  22274. if (keyPress === void 0) { keyPress = null; }
  22275. if (charPress === void 0) { charPress = null; }
  22276. if (cellStartedEdit === void 0) { cellStartedEdit = false; }
  22277. // don't do it if not editable
  22278. if (!this.isCellEditable()) {
  22279. return;
  22280. }
  22281. // don't do it if already editing
  22282. if (this.editingCell) {
  22283. return;
  22284. }
  22285. this.editingCell = true;
  22286. this.cellEditorVersion++;
  22287. var callback = this.afterCellEditorCreated.bind(this, this.cellEditorVersion);
  22288. var params = this.createCellEditorParams(keyPress, charPress, cellStartedEdit);
  22289. this.createCellEditor(params).then(callback);
  22290. // if we don't do this, and editor component is async, then there will be a period
  22291. // when the component isn't present and keyboard navigation won't work - so example
  22292. // of user hitting tab quickly (more quickly than renderers getting created) won't work
  22293. var cellEditorAsync = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(this.cellEditor);
  22294. if (cellEditorAsync && cellStartedEdit) {
  22295. this.focusCell(true);
  22296. }
  22297. };
  22298. CellComp.prototype.createCellEditor = function (params) {
  22299. var _this = this;
  22300. var cellEditorPromise = this.beans.userComponentFactory.newCellEditor(this.column.getColDef(), params);
  22301. return cellEditorPromise.then(function (cellEditor) {
  22302. var isPopup = cellEditor.isPopup && cellEditor.isPopup();
  22303. if (!isPopup) {
  22304. return cellEditor;
  22305. }
  22306. if (_this.beans.gridOptionsWrapper.isFullRowEdit()) {
  22307. console.warn('ag-Grid: popup cellEditor does not work with fullRowEdit - you cannot use them both ' +
  22308. '- either turn off fullRowEdit, or stop using popup editors.');
  22309. }
  22310. // if a popup, then we wrap in a popup editor and return the popup
  22311. var popupEditorWrapper = new _cellEditors_popupEditorWrapper__WEBPACK_IMPORTED_MODULE_6__["PopupEditorWrapper"](cellEditor);
  22312. _this.beans.context.createBean(popupEditorWrapper);
  22313. popupEditorWrapper.init(params);
  22314. return popupEditorWrapper;
  22315. });
  22316. };
  22317. CellComp.prototype.afterCellEditorCreated = function (cellEditorVersion, cellEditor) {
  22318. // if editingCell=false, means user cancelled the editor before component was ready.
  22319. // if versionMismatch, then user cancelled the edit, then started the edit again, and this
  22320. // is the first editor which is now stale.
  22321. var versionMismatch = cellEditorVersion !== this.cellEditorVersion;
  22322. var cellEditorNotNeeded = versionMismatch || !this.editingCell;
  22323. if (cellEditorNotNeeded) {
  22324. this.beans.context.destroyBean(cellEditor);
  22325. return;
  22326. }
  22327. var editingCancelledByUserComp = cellEditor.isCancelBeforeStart && cellEditor.isCancelBeforeStart();
  22328. if (editingCancelledByUserComp) {
  22329. this.beans.context.destroyBean(cellEditor);
  22330. this.editingCell = false;
  22331. return;
  22332. }
  22333. if (!cellEditor.getGui) {
  22334. console.warn("ag-Grid: cellEditor for column " + this.column.getId() + " is missing getGui() method");
  22335. // no getGui, for React guys, see if they attached a react component directly
  22336. if (cellEditor.render) {
  22337. console.warn("ag-Grid: we found 'render' on the component, are you trying to set a React renderer but added it as colDef.cellEditor instead of colDef.cellEditorFmk?");
  22338. }
  22339. this.beans.context.destroyBean(cellEditor);
  22340. this.editingCell = false;
  22341. return;
  22342. }
  22343. this.cellEditor = cellEditor;
  22344. this.cellEditorInPopup = cellEditor.isPopup !== undefined && cellEditor.isPopup();
  22345. this.setInlineEditingClass();
  22346. if (this.cellEditorInPopup) {
  22347. this.addPopupCellEditor();
  22348. }
  22349. else {
  22350. this.addInCellEditor();
  22351. }
  22352. if (cellEditor.afterGuiAttached) {
  22353. cellEditor.afterGuiAttached();
  22354. }
  22355. var event = this.createEvent(null, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_EDITING_STARTED);
  22356. this.beans.eventService.dispatchEvent(event);
  22357. };
  22358. CellComp.prototype.addInCellEditor = function () {
  22359. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].clearElement(this.getGui());
  22360. if (this.cellEditor) {
  22361. this.getGui().appendChild(this.cellEditor.getGui());
  22362. }
  22363. this.angular1Compile();
  22364. };
  22365. CellComp.prototype.addPopupCellEditor = function () {
  22366. var _this = this;
  22367. var ePopupGui = this.cellEditor ? this.cellEditor.getGui() : null;
  22368. var useModelPopup = this.beans.gridOptionsWrapper.isStopEditingWhenGridLosesFocus();
  22369. this.hideEditorPopup = this.beans.popupService.addPopup(useModelPopup, ePopupGui, true,
  22370. // callback for when popup disappears
  22371. function () {
  22372. _this.onPopupEditorClosed();
  22373. });
  22374. var params = {
  22375. column: this.column,
  22376. rowNode: this.rowNode,
  22377. type: 'popupCellEditor',
  22378. eventSource: this.getGui(),
  22379. ePopup: ePopupGui,
  22380. keepWithinBounds: true
  22381. };
  22382. var position = this.cellEditor && this.cellEditor.getPopupPosition ? this.cellEditor.getPopupPosition() : 'over';
  22383. if (position === 'under') {
  22384. this.beans.popupService.positionPopupUnderComponent(params);
  22385. }
  22386. else {
  22387. this.beans.popupService.positionPopupOverComponent(params);
  22388. }
  22389. this.angular1Compile();
  22390. };
  22391. CellComp.prototype.onPopupEditorClosed = function () {
  22392. // we only call stopEditing if we are editing, as
  22393. // it's possible the popup called 'stop editing'
  22394. // before this, eg if 'enter key' was pressed on
  22395. // the editor.
  22396. if (this.editingCell) {
  22397. // note: this only happens when use clicks outside of the grid. if use clicks on another
  22398. // cell, then the editing will have already stopped on this cell
  22399. this.stopRowOrCellEdit();
  22400. // we only focus cell again if this cell is still focused. it is possible
  22401. // it is not focused if the user cancelled the edit by clicking on another
  22402. // cell outside of this one
  22403. if (this.beans.focusController.isCellFocused(this.cellPosition)) {
  22404. this.focusCell(true);
  22405. }
  22406. }
  22407. };
  22408. // if we are editing inline, then we don't have the padding in the cell (set in the themes)
  22409. // to allow the text editor full access to the entire cell
  22410. CellComp.prototype.setInlineEditingClass = function () {
  22411. if (!this.isAlive()) {
  22412. return;
  22413. }
  22414. // ag-cell-inline-editing - appears when user is inline editing
  22415. // ag-cell-not-inline-editing - appears when user is no inline editing
  22416. // ag-cell-popup-editing - appears when user is editing cell in popup (appears on the cell, not on the popup)
  22417. // note: one of {ag-cell-inline-editing, ag-cell-not-inline-editing} is always present, they toggle.
  22418. // however {ag-cell-popup-editing} shows when popup, so you have both {ag-cell-popup-editing}
  22419. // and {ag-cell-not-inline-editing} showing at the same time.
  22420. var editingInline = this.editingCell && !this.cellEditorInPopup;
  22421. var popupEditorShowing = this.editingCell && this.cellEditorInPopup;
  22422. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui(), "ag-cell-inline-editing", editingInline);
  22423. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui(), "ag-cell-not-inline-editing", !editingInline);
  22424. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui(), "ag-cell-popup-editing", popupEditorShowing);
  22425. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui().parentNode, "ag-row-inline-editing", editingInline);
  22426. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui().parentNode, "ag-row-not-inline-editing", !editingInline);
  22427. };
  22428. CellComp.prototype.createCellEditorParams = function (keyPress, charPress, cellStartedEdit) {
  22429. return {
  22430. value: this.getValue(),
  22431. keyPress: keyPress,
  22432. charPress: charPress,
  22433. column: this.column,
  22434. colDef: this.column.getColDef(),
  22435. rowIndex: this.cellPosition.rowIndex,
  22436. node: this.rowNode,
  22437. data: this.rowNode.data,
  22438. api: this.beans.gridOptionsWrapper.getApi(),
  22439. cellStartedEdit: cellStartedEdit,
  22440. columnApi: this.beans.gridOptionsWrapper.getColumnApi(),
  22441. context: this.beans.gridOptionsWrapper.getContext(),
  22442. $scope: this.scope,
  22443. onKeyDown: this.onKeyDown.bind(this),
  22444. stopEditing: this.stopEditingAndFocus.bind(this),
  22445. eGridCell: this.getGui(),
  22446. parseValue: this.parseValue.bind(this),
  22447. formatValue: this.formatValue.bind(this)
  22448. };
  22449. };
  22450. // cell editors call this, when they want to stop for reasons other
  22451. // than what we pick up on. eg selecting from a dropdown ends editing.
  22452. CellComp.prototype.stopEditingAndFocus = function (suppressNavigateAfterEdit) {
  22453. if (suppressNavigateAfterEdit === void 0) { suppressNavigateAfterEdit = false; }
  22454. this.stopRowOrCellEdit();
  22455. this.focusCell(true);
  22456. if (!suppressNavigateAfterEdit) {
  22457. this.navigateAfterEdit();
  22458. }
  22459. };
  22460. CellComp.prototype.parseValue = function (newValue) {
  22461. var colDef = this.getComponentHolder();
  22462. var params = {
  22463. node: this.rowNode,
  22464. data: this.rowNode.data,
  22465. oldValue: this.value,
  22466. newValue: newValue,
  22467. colDef: colDef,
  22468. column: this.column,
  22469. api: this.beans.gridOptionsWrapper.getApi(),
  22470. columnApi: this.beans.gridOptionsWrapper.getColumnApi(),
  22471. context: this.beans.gridOptionsWrapper.getContext()
  22472. };
  22473. var valueParser = colDef.valueParser;
  22474. return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].exists(valueParser) ? this.beans.expressionService.evaluate(valueParser, params) : newValue;
  22475. };
  22476. CellComp.prototype.focusCell = function (forceBrowserFocus) {
  22477. if (forceBrowserFocus === void 0) { forceBrowserFocus = false; }
  22478. this.beans.focusController.setFocusedCell(this.cellPosition.rowIndex, this.column, this.rowNode.rowPinned, forceBrowserFocus);
  22479. };
  22480. CellComp.prototype.setFocusInOnEditor = function () {
  22481. if (this.editingCell) {
  22482. if (this.cellEditor && this.cellEditor.focusIn) {
  22483. // if the editor is present, then we just focus it
  22484. this.cellEditor.focusIn();
  22485. }
  22486. else {
  22487. // if the editor is not present, it means async cell editor (eg React fibre)
  22488. // and we are trying to set focus before the cell editor is present, so we
  22489. // focus the cell instead
  22490. this.focusCell(true);
  22491. }
  22492. }
  22493. };
  22494. CellComp.prototype.isEditing = function () {
  22495. return this.editingCell;
  22496. };
  22497. CellComp.prototype.onKeyDown = function (event) {
  22498. var key = event.which || event.keyCode;
  22499. switch (key) {
  22500. case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_ENTER:
  22501. this.onEnterKeyDown(event);
  22502. break;
  22503. case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_F2:
  22504. this.onF2KeyDown();
  22505. break;
  22506. case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_ESCAPE:
  22507. this.onEscapeKeyDown();
  22508. break;
  22509. case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_TAB:
  22510. this.onTabKeyDown(event);
  22511. break;
  22512. case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_BACKSPACE:
  22513. case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_DELETE:
  22514. this.onBackspaceOrDeleteKeyPressed(key);
  22515. break;
  22516. case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_DOWN:
  22517. case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_UP:
  22518. case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_RIGHT:
  22519. case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_LEFT:
  22520. this.onNavigationKeyPressed(event, key);
  22521. break;
  22522. }
  22523. };
  22524. CellComp.prototype.setFocusOutOnEditor = function () {
  22525. if (this.editingCell && this.cellEditor && this.cellEditor.focusOut) {
  22526. this.cellEditor.focusOut();
  22527. }
  22528. };
  22529. CellComp.prototype.onNavigationKeyPressed = function (event, key) {
  22530. if (this.editingCell) {
  22531. return;
  22532. }
  22533. if (event.shiftKey && this.rangeSelectionEnabled) {
  22534. this.onShiftRangeSelect(key);
  22535. }
  22536. else {
  22537. this.beans.rowRenderer.navigateToNextCell(event, key, this.cellPosition, true);
  22538. }
  22539. // if we don't prevent default, the grid will scroll with the navigation keys
  22540. event.preventDefault();
  22541. };
  22542. CellComp.prototype.onShiftRangeSelect = function (key) {
  22543. if (!this.beans.rangeController) {
  22544. return;
  22545. }
  22546. var endCell = this.beans.rangeController.extendLatestRangeInDirection(key);
  22547. if (endCell) {
  22548. this.beans.rowRenderer.ensureCellVisible(endCell);
  22549. }
  22550. };
  22551. CellComp.prototype.onTabKeyDown = function (event) {
  22552. this.beans.rowRenderer.onTabKeyDown(this, event);
  22553. };
  22554. CellComp.prototype.onBackspaceOrDeleteKeyPressed = function (key) {
  22555. if (!this.editingCell) {
  22556. this.startRowOrCellEdit(key);
  22557. }
  22558. };
  22559. CellComp.prototype.onEnterKeyDown = function (e) {
  22560. if (this.editingCell || this.rowComp.isEditing()) {
  22561. this.stopEditingAndFocus();
  22562. }
  22563. else {
  22564. if (this.beans.gridOptionsWrapper.isEnterMovesDown()) {
  22565. this.beans.rowRenderer.navigateToNextCell(null, _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_DOWN, this.cellPosition, false);
  22566. }
  22567. else {
  22568. e.preventDefault();
  22569. this.startRowOrCellEdit(_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_ENTER);
  22570. }
  22571. }
  22572. };
  22573. CellComp.prototype.navigateAfterEdit = function () {
  22574. var fullRowEdit = this.beans.gridOptionsWrapper.isFullRowEdit();
  22575. if (fullRowEdit) {
  22576. return;
  22577. }
  22578. var enterMovesDownAfterEdit = this.beans.gridOptionsWrapper.isEnterMovesDownAfterEdit();
  22579. if (enterMovesDownAfterEdit) {
  22580. this.beans.rowRenderer.navigateToNextCell(null, _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_DOWN, this.cellPosition, false);
  22581. }
  22582. };
  22583. CellComp.prototype.onF2KeyDown = function () {
  22584. if (!this.editingCell) {
  22585. this.startRowOrCellEdit(_constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_F2);
  22586. }
  22587. };
  22588. CellComp.prototype.onEscapeKeyDown = function () {
  22589. if (this.editingCell) {
  22590. this.stopRowOrCellEdit(true);
  22591. this.focusCell(true);
  22592. }
  22593. };
  22594. CellComp.prototype.onKeyPress = function (event) {
  22595. // check this, in case focus is on a (for example) a text field inside the cell,
  22596. // in which cse we should not be listening for these key pressed
  22597. var eventTarget = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].getTarget(event);
  22598. var eventOnChildComponent = eventTarget !== this.getGui();
  22599. if (eventOnChildComponent || this.editingCell) {
  22600. return;
  22601. }
  22602. var pressedChar = String.fromCharCode(event.charCode);
  22603. if (pressedChar === ' ') {
  22604. this.onSpaceKeyPressed(event);
  22605. }
  22606. else if (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].isEventFromPrintableCharacter(event)) {
  22607. this.startRowOrCellEdit(null, pressedChar);
  22608. // if we don't prevent default, then the keypress also gets applied to the text field
  22609. // (at least when doing the default editor), but we need to allow the editor to decide
  22610. // what it wants to do. we only do this IF editing was started - otherwise it messes
  22611. // up when the use is not doing editing, but using rendering with text fields in cellRenderer
  22612. // (as it would block the the user from typing into text fields).
  22613. event.preventDefault();
  22614. }
  22615. };
  22616. CellComp.prototype.onSpaceKeyPressed = function (event) {
  22617. var gridOptionsWrapper = this.beans.gridOptionsWrapper;
  22618. if (!this.editingCell && gridOptionsWrapper.isRowSelection()) {
  22619. var newSelection = !this.rowNode.isSelected();
  22620. if (newSelection || gridOptionsWrapper.isRowDeselection()) {
  22621. this.rowNode.setSelected(newSelection);
  22622. }
  22623. }
  22624. // prevent default as space key, by default, moves browser scroll down
  22625. event.preventDefault();
  22626. };
  22627. CellComp.prototype.onMouseDown = function (mouseEvent) {
  22628. var ctrlKey = mouseEvent.ctrlKey, metaKey = mouseEvent.metaKey, shiftKey = mouseEvent.shiftKey;
  22629. var target = mouseEvent.target;
  22630. var _a = this.beans, eventService = _a.eventService, rangeController = _a.rangeController;
  22631. // do not change the range for right-clicks inside an existing range
  22632. if (this.isRightClickInExistingRange(mouseEvent)) {
  22633. return;
  22634. }
  22635. if (!shiftKey || (rangeController && !rangeController.getCellRanges().length)) {
  22636. // We only need to pass true to focusCell when the browser is IE/Edge and we are trying
  22637. // to focus the cell itself. This should never be true if the mousedown was triggered
  22638. // due to a click on a cell editor for example.
  22639. var forceBrowserFocus = (_utils__WEBPACK_IMPORTED_MODULE_7__["_"].isBrowserIE() || _utils__WEBPACK_IMPORTED_MODULE_7__["_"].isBrowserEdge()) && !this.editingCell;
  22640. this.focusCell(forceBrowserFocus);
  22641. }
  22642. else {
  22643. // if a range is being changed, we need to make sure the focused cell does not change.
  22644. mouseEvent.preventDefault();
  22645. }
  22646. // if we are clicking on a checkbox, we need to make sure the cell wrapping that checkbox
  22647. // is focused but we don't want to change the range selection, so return here.
  22648. if (this.containsWidget(target)) {
  22649. return;
  22650. }
  22651. if (rangeController) {
  22652. var thisCell = this.cellPosition;
  22653. if (shiftKey) {
  22654. rangeController.extendLatestRangeToCell(thisCell);
  22655. }
  22656. else {
  22657. var ctrlKeyPressed = ctrlKey || metaKey;
  22658. rangeController.setRangeToCell(thisCell, ctrlKeyPressed);
  22659. }
  22660. }
  22661. eventService.dispatchEvent(this.createEvent(mouseEvent, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_MOUSE_DOWN));
  22662. };
  22663. CellComp.prototype.isRightClickInExistingRange = function (mouseEvent) {
  22664. var rangeController = this.beans.rangeController;
  22665. if (rangeController) {
  22666. var cellInRange = rangeController.isCellInAnyRange(this.getCellPosition());
  22667. if (cellInRange && mouseEvent.button === 2) {
  22668. return true;
  22669. }
  22670. }
  22671. return false;
  22672. };
  22673. CellComp.prototype.containsWidget = function (target) {
  22674. return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].isElementChildOfClass(target, 'ag-selection-checkbox', 3);
  22675. };
  22676. // returns true if on iPad and this is second 'click' event in 200ms
  22677. CellComp.prototype.isDoubleClickOnIPad = function () {
  22678. if (!_utils__WEBPACK_IMPORTED_MODULE_7__["_"].isIOSUserAgent() || _utils__WEBPACK_IMPORTED_MODULE_7__["_"].isEventSupported('dblclick')) {
  22679. return false;
  22680. }
  22681. var nowMillis = new Date().getTime();
  22682. var res = nowMillis - this.lastIPadMouseClickEvent < 200;
  22683. this.lastIPadMouseClickEvent = nowMillis;
  22684. return res;
  22685. };
  22686. CellComp.prototype.onCellClicked = function (mouseEvent) {
  22687. // iPad doesn't have double click - so we need to mimic it to enable editing for iPad.
  22688. if (this.isDoubleClickOnIPad()) {
  22689. this.onCellDoubleClicked(mouseEvent);
  22690. mouseEvent.preventDefault(); // if we don't do this, then iPad zooms in
  22691. return;
  22692. }
  22693. var _a = this.beans, eventService = _a.eventService, gridOptionsWrapper = _a.gridOptionsWrapper;
  22694. var cellClickedEvent = this.createEvent(mouseEvent, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_CLICKED);
  22695. eventService.dispatchEvent(cellClickedEvent);
  22696. var colDef = this.getComponentHolder();
  22697. if (colDef.onCellClicked) {
  22698. // to make callback async, do in a timeout
  22699. window.setTimeout(function () { return colDef.onCellClicked(cellClickedEvent); }, 0);
  22700. }
  22701. var editOnSingleClick = (gridOptionsWrapper.isSingleClickEdit() || colDef.singleClickEdit)
  22702. && !gridOptionsWrapper.isSuppressClickEdit();
  22703. if (editOnSingleClick) {
  22704. this.startRowOrCellEdit();
  22705. }
  22706. };
  22707. CellComp.prototype.createGridCellVo = function () {
  22708. this.cellPosition = {
  22709. rowIndex: this.rowNode.rowIndex,
  22710. rowPinned: this.rowNode.rowPinned,
  22711. column: this.column
  22712. };
  22713. };
  22714. CellComp.prototype.getCellPosition = function () {
  22715. return this.cellPosition;
  22716. };
  22717. CellComp.prototype.getParentRow = function () {
  22718. return this.eParentRow;
  22719. };
  22720. CellComp.prototype.setParentRow = function (eParentRow) {
  22721. this.eParentRow = eParentRow;
  22722. };
  22723. CellComp.prototype.getColumn = function () {
  22724. return this.column;
  22725. };
  22726. CellComp.prototype.getComponentHolder = function () {
  22727. return this.column.getColDef();
  22728. };
  22729. CellComp.prototype.detach = function () {
  22730. this.eParentRow.removeChild(this.getGui());
  22731. };
  22732. // if the row is also getting destroyed, then we don't need to remove from dom,
  22733. // as the row will also get removed, so no need to take out the cells from the row
  22734. // if the row is going (removing is an expensive operation, so only need to remove
  22735. // the top part)
  22736. //
  22737. // note - this is NOT called by context, as we don't wire / unwire the CellComp for performance reasons.
  22738. CellComp.prototype.destroy = function () {
  22739. if (this.createCellRendererFunc) {
  22740. this.beans.taskQueue.cancelTask(this.createCellRendererFunc);
  22741. }
  22742. this.stopEditing();
  22743. this.cellRenderer = this.beans.context.destroyBean(this.cellRenderer);
  22744. this.beans.context.destroyBean(this.selectionHandle);
  22745. _super.prototype.destroy.call(this);
  22746. };
  22747. CellComp.prototype.onLeftChanged = function () {
  22748. var left = this.modifyLeftForPrintLayout(this.getCellLeft());
  22749. this.getGui().style.left = left + 'px';
  22750. this.refreshAriaIndex();
  22751. };
  22752. CellComp.prototype.modifyLeftForPrintLayout = function (leftPosition) {
  22753. if (!this.printLayout || this.column.getPinned() === _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_LEFT) {
  22754. return leftPosition;
  22755. }
  22756. if (this.column.getPinned() === _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].PINNED_RIGHT) {
  22757. var leftWidth_1 = this.beans.columnController.getPinnedLeftContainerWidth();
  22758. var bodyWidth = this.beans.columnController.getBodyContainerWidth();
  22759. return leftWidth_1 + bodyWidth + leftPosition;
  22760. }
  22761. // is in body
  22762. var leftWidth = this.beans.columnController.getPinnedLeftContainerWidth();
  22763. return leftWidth + leftPosition;
  22764. };
  22765. CellComp.prototype.onWidthChanged = function () {
  22766. var width = this.getCellWidth();
  22767. this.getGui().style.width = width + 'px';
  22768. };
  22769. CellComp.prototype.getRangeBorders = function () {
  22770. var _this = this;
  22771. var isRtl = this.beans.gridOptionsWrapper.isEnableRtl();
  22772. var top = false;
  22773. var right = false;
  22774. var bottom = false;
  22775. var left = false;
  22776. var thisCol = this.cellPosition.column;
  22777. var _a = this.beans, rangeController = _a.rangeController, columnController = _a.columnController;
  22778. var leftCol;
  22779. var rightCol;
  22780. if (isRtl) {
  22781. leftCol = columnController.getDisplayedColAfter(thisCol);
  22782. rightCol = columnController.getDisplayedColBefore(thisCol);
  22783. }
  22784. else {
  22785. leftCol = columnController.getDisplayedColBefore(thisCol);
  22786. rightCol = columnController.getDisplayedColAfter(thisCol);
  22787. }
  22788. var ranges = rangeController.getCellRanges().filter(function (range) { return rangeController.isCellInSpecificRange(_this.cellPosition, range); });
  22789. // this means we are the first column in the grid
  22790. if (!leftCol) {
  22791. left = true;
  22792. }
  22793. // this means we are the last column in the grid
  22794. if (!rightCol) {
  22795. right = true;
  22796. }
  22797. for (var i = 0; i < ranges.length; i++) {
  22798. if (top && right && bottom && left) {
  22799. break;
  22800. }
  22801. var range = ranges[i];
  22802. var startRow = rangeController.getRangeStartRow(range);
  22803. var endRow = rangeController.getRangeEndRow(range);
  22804. if (!top && this.beans.rowPositionUtils.sameRow(startRow, this.cellPosition)) {
  22805. top = true;
  22806. }
  22807. if (!bottom && this.beans.rowPositionUtils.sameRow(endRow, this.cellPosition)) {
  22808. bottom = true;
  22809. }
  22810. if (!left && range.columns.indexOf(leftCol) < 0) {
  22811. left = true;
  22812. }
  22813. if (!right && range.columns.indexOf(rightCol) < 0) {
  22814. right = true;
  22815. }
  22816. }
  22817. return { top: top, right: right, bottom: bottom, left: left };
  22818. };
  22819. CellComp.prototype.getInitialRangeClasses = function () {
  22820. var classes = [];
  22821. if (!this.rangeSelectionEnabled || !this.rangeCount) {
  22822. return classes;
  22823. }
  22824. classes.push('ag-cell-range-selected');
  22825. if (this.hasChartRange) {
  22826. classes.push('ag-cell-range-chart');
  22827. }
  22828. var count = Math.min(this.rangeCount, 4);
  22829. classes.push("ag-cell-range-selected-" + count);
  22830. if (this.isSingleCell()) {
  22831. classes.push('ag-cell-range-single-cell');
  22832. }
  22833. if (this.rangeCount > 0) {
  22834. var borders = this.getRangeBorders();
  22835. if (borders.top) {
  22836. classes.push('ag-cell-range-top');
  22837. }
  22838. if (borders.right) {
  22839. classes.push('ag-cell-range-right');
  22840. }
  22841. if (borders.bottom) {
  22842. classes.push('ag-cell-range-bottom');
  22843. }
  22844. if (borders.left) {
  22845. classes.push('ag-cell-range-left');
  22846. }
  22847. }
  22848. if (!!this.selectionHandle) {
  22849. classes.push('ag-cell-range-handle');
  22850. }
  22851. return classes;
  22852. };
  22853. CellComp.prototype.onRowIndexChanged = function () {
  22854. // when index changes, this influences items that need the index, so we update the
  22855. // grid cell so they are working off the new index.
  22856. this.createGridCellVo();
  22857. // when the index of the row changes, ie means the cell may have lost or gained focus
  22858. this.onCellFocused();
  22859. // check range selection
  22860. this.onRangeSelectionChanged();
  22861. };
  22862. CellComp.prototype.onRangeSelectionChanged = function () {
  22863. var rangeController = this.beans.rangeController;
  22864. if (!rangeController) {
  22865. return;
  22866. }
  22867. var _a = this, cellPosition = _a.cellPosition, rangeCount = _a.rangeCount;
  22868. var newRangeCount = rangeController.getCellRangeCount(cellPosition);
  22869. var element = this.getGui();
  22870. if (rangeCount !== newRangeCount) {
  22871. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-selected', newRangeCount !== 0);
  22872. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-selected-1', newRangeCount === 1);
  22873. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-selected-2', newRangeCount === 2);
  22874. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-selected-3', newRangeCount === 3);
  22875. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-selected-4', newRangeCount >= 4);
  22876. this.rangeCount = newRangeCount;
  22877. }
  22878. var hasChartRange = this.getHasChartRange();
  22879. if (hasChartRange !== this.hasChartRange) {
  22880. this.hasChartRange = hasChartRange;
  22881. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-chart', this.hasChartRange);
  22882. }
  22883. this.updateRangeBorders();
  22884. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-single-cell', this.isSingleCell());
  22885. this.refreshHandle();
  22886. };
  22887. CellComp.prototype.getHasChartRange = function () {
  22888. var rangeController = this.beans.rangeController;
  22889. if (!this.rangeCount || !rangeController) {
  22890. return false;
  22891. }
  22892. var cellRanges = rangeController.getCellRanges();
  22893. return cellRanges.length > 0 && cellRanges.every(function (range) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].includes([_interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_4__["CellRangeType"].DIMENSION, _interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_4__["CellRangeType"].VALUE], range.type); });
  22894. };
  22895. CellComp.prototype.shouldHaveSelectionHandle = function () {
  22896. var _a = this.beans, gridOptionsWrapper = _a.gridOptionsWrapper, rangeController = _a.rangeController;
  22897. var cellRanges = rangeController.getCellRanges();
  22898. var rangesLen = cellRanges.length;
  22899. if (this.rangeCount < 1 || rangesLen < 1) {
  22900. return false;
  22901. }
  22902. var cellRange = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].last(cellRanges);
  22903. var cellPosition = this.getCellPosition();
  22904. var fillHandleIsAvailable = rangesLen === 1 &&
  22905. (gridOptionsWrapper.isEnableFillHandle() || gridOptionsWrapper.isEnableRangeHandle()) &&
  22906. !this.editingCell;
  22907. if (this.hasChartRange) {
  22908. var hasCategoryRange = cellRanges[0].type === _interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_4__["CellRangeType"].DIMENSION;
  22909. var isCategoryCell = hasCategoryRange && rangeController.isCellInSpecificRange(cellPosition, cellRanges[0]);
  22910. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui(), 'ag-cell-range-chart-category', isCategoryCell);
  22911. fillHandleIsAvailable = cellRange.type === _interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_4__["CellRangeType"].VALUE;
  22912. }
  22913. return fillHandleIsAvailable &&
  22914. cellRange.endRow != null &&
  22915. rangeController.isContiguousRange(cellRange) &&
  22916. rangeController.isBottomRightCell(cellRange, cellPosition);
  22917. };
  22918. CellComp.prototype.addSelectionHandle = function () {
  22919. var _a = this.beans, gridOptionsWrapper = _a.gridOptionsWrapper, context = _a.context, rangeController = _a.rangeController;
  22920. var cellRangeType = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].last(rangeController.getCellRanges()).type;
  22921. var selectionHandleFill = gridOptionsWrapper.isEnableFillHandle() && _utils__WEBPACK_IMPORTED_MODULE_7__["_"].missing(cellRangeType);
  22922. var type = selectionHandleFill ? _interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_4__["SelectionHandleType"].FILL : _interfaces_iRangeController__WEBPACK_IMPORTED_MODULE_4__["SelectionHandleType"].RANGE;
  22923. if (this.selectionHandle && this.selectionHandle.getType() !== type) {
  22924. this.selectionHandle = this.beans.context.destroyBean(this.selectionHandle);
  22925. }
  22926. if (!this.selectionHandle) {
  22927. this.selectionHandle = this.beans.selectionHandleFactory.createSelectionHandle(type);
  22928. }
  22929. this.selectionHandle.refresh(this);
  22930. };
  22931. CellComp.prototype.updateRangeBordersIfRangeCount = function () {
  22932. // we only need to update range borders if we are in a range
  22933. if (this.rangeCount > 0) {
  22934. this.updateRangeBorders();
  22935. this.refreshHandle();
  22936. }
  22937. };
  22938. CellComp.prototype.refreshHandle = function () {
  22939. if (!this.beans.rangeController) {
  22940. return;
  22941. }
  22942. var shouldHaveSelectionHandle = this.shouldHaveSelectionHandle();
  22943. if (this.selectionHandle && !shouldHaveSelectionHandle) {
  22944. this.selectionHandle = this.beans.context.destroyBean(this.selectionHandle);
  22945. }
  22946. if (shouldHaveSelectionHandle) {
  22947. this.addSelectionHandle();
  22948. }
  22949. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui(), 'ag-cell-range-handle', !!this.selectionHandle);
  22950. };
  22951. CellComp.prototype.updateRangeBorders = function () {
  22952. var rangeBorders = this.getRangeBorders();
  22953. var isSingleCell = this.isSingleCell();
  22954. var isTop = !isSingleCell && rangeBorders.top;
  22955. var isRight = !isSingleCell && rangeBorders.right;
  22956. var isBottom = !isSingleCell && rangeBorders.bottom;
  22957. var isLeft = !isSingleCell && rangeBorders.left;
  22958. var element = this.getGui();
  22959. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-top', isTop);
  22960. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-right', isRight);
  22961. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-bottom', isBottom);
  22962. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(element, 'ag-cell-range-left', isLeft);
  22963. };
  22964. CellComp.prototype.onFirstRightPinnedChanged = function () {
  22965. var firstRightPinned = this.column.isFirstRightPinned();
  22966. if (this.firstRightPinned !== firstRightPinned) {
  22967. this.firstRightPinned = firstRightPinned;
  22968. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui(), 'ag-cell-first-right-pinned', firstRightPinned);
  22969. }
  22970. };
  22971. CellComp.prototype.onLastLeftPinnedChanged = function () {
  22972. var lastLeftPinned = this.column.isLastLeftPinned();
  22973. if (this.lastLeftPinned !== lastLeftPinned) {
  22974. this.lastLeftPinned = lastLeftPinned;
  22975. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui(), 'ag-cell-last-left-pinned', lastLeftPinned);
  22976. }
  22977. };
  22978. CellComp.prototype.populateTemplate = function () {
  22979. if (this.usingWrapper) {
  22980. this.eParentOfValue = this.getRefElement('eCellValue');
  22981. this.eCellWrapper = this.getRefElement('eCellWrapper');
  22982. this.eCellValue = this.getRefElement('eCellValue');
  22983. if (this.includeRowDraggingComponent) {
  22984. this.addRowDragging();
  22985. }
  22986. if (this.includeDndSourceComponent) {
  22987. this.addDndSource();
  22988. }
  22989. if (this.includeSelectionComponent) {
  22990. this.addSelectionCheckbox();
  22991. }
  22992. }
  22993. else {
  22994. this.eParentOfValue = this.getGui();
  22995. }
  22996. };
  22997. CellComp.prototype.getFrameworkOverrides = function () {
  22998. return this.beans.frameworkOverrides;
  22999. };
  23000. CellComp.prototype.addRowDragging = function () {
  23001. var pagination = this.beans.gridOptionsWrapper.isPagination();
  23002. var rowDragManaged = this.beans.gridOptionsWrapper.isRowDragManaged();
  23003. var clientSideRowModelActive = this.beans.gridOptionsWrapper.isRowModelDefault();
  23004. if (rowDragManaged) {
  23005. // row dragging only available in default row model
  23006. if (!clientSideRowModelActive) {
  23007. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].doOnce(function () { return console.warn('ag-Grid: managed row dragging is only allowed in the Client Side Row Model'); }, 'CellComp.addRowDragging');
  23008. return;
  23009. }
  23010. if (pagination) {
  23011. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].doOnce(function () { return console.warn('ag-Grid: managed row dragging is not possible when doing pagination'); }, 'CellComp.addRowDragging');
  23012. return;
  23013. }
  23014. }
  23015. var rowDraggingComp = new _rowDragComp__WEBPACK_IMPORTED_MODULE_5__["RowDragComp"](this.rowNode, this.column, this.getValueToUse(), this.beans);
  23016. this.createManagedBean(rowDraggingComp, this.beans.context);
  23017. // put the checkbox in before the value
  23018. this.eCellWrapper.insertBefore(rowDraggingComp.getGui(), this.eParentOfValue);
  23019. };
  23020. CellComp.prototype.addDndSource = function () {
  23021. var dndSourceComp = new _dndSourceComp__WEBPACK_IMPORTED_MODULE_8__["DndSourceComp"](this.rowNode, this.column, this.getValueToUse(), this.beans, this.getGui());
  23022. this.createManagedBean(dndSourceComp, this.beans.context);
  23023. // put the checkbox in before the value
  23024. this.eCellWrapper.insertBefore(dndSourceComp.getGui(), this.eParentOfValue);
  23025. };
  23026. CellComp.prototype.addSelectionCheckbox = function () {
  23027. var _this = this;
  23028. var cbSelectionComponent = new _checkboxSelectionComponent__WEBPACK_IMPORTED_MODULE_3__["CheckboxSelectionComponent"]();
  23029. this.beans.context.createBean(cbSelectionComponent);
  23030. var visibleFunc = this.getComponentHolder().checkboxSelection;
  23031. visibleFunc = typeof visibleFunc === 'function' ? visibleFunc : null;
  23032. cbSelectionComponent.init({ rowNode: this.rowNode, column: this.column, visibleFunc: visibleFunc });
  23033. this.addDestroyFunc(function () { return _this.beans.context.destroyBean(cbSelectionComponent); });
  23034. // put the checkbox in before the value
  23035. this.eCellWrapper.insertBefore(cbSelectionComponent.getGui(), this.eParentOfValue);
  23036. };
  23037. CellComp.prototype.addDomData = function () {
  23038. var _this = this;
  23039. var element = this.getGui();
  23040. this.beans.gridOptionsWrapper.setDomData(element, CellComp.DOM_DATA_KEY_CELL_COMP, this);
  23041. this.addDestroyFunc(function () { return _this.beans.gridOptionsWrapper.setDomData(element, CellComp.DOM_DATA_KEY_CELL_COMP, null); });
  23042. };
  23043. CellComp.prototype.isSingleCell = function () {
  23044. var rangeController = this.beans.rangeController;
  23045. return this.rangeCount === 1 && rangeController && !rangeController.isMoreThanOneCell();
  23046. };
  23047. CellComp.prototype.onCellFocused = function (event) {
  23048. var cellFocused = this.beans.focusController.isCellFocused(this.cellPosition);
  23049. // see if we need to change the classes on this cell
  23050. if (cellFocused !== this.cellFocused) {
  23051. // if we are not doing cell selection, then the focus class does not change
  23052. var doingFocusCss = !this.beans.gridOptionsWrapper.isSuppressCellSelection();
  23053. if (doingFocusCss) {
  23054. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addOrRemoveCssClass(this.getGui(), 'ag-cell-focus', cellFocused);
  23055. }
  23056. this.cellFocused = cellFocused;
  23057. }
  23058. // see if we need to force browser focus - this can happen if focus is programmatically set
  23059. if (cellFocused && event && event.forceBrowserFocus) {
  23060. var focusEl = this.getFocusableElement();
  23061. focusEl.focus();
  23062. // Fix for AG-3465 "IE11 - After editing cell's content, selection doesn't go one cell below on enter"
  23063. // IE can fail to focus the cell after the first call to focus(), and needs a second call
  23064. if (!document.activeElement || document.activeElement === document.body) {
  23065. focusEl.focus();
  23066. }
  23067. }
  23068. // if another cell was focused, and we are editing, then stop editing
  23069. var fullRowEdit = this.beans.gridOptionsWrapper.isFullRowEdit();
  23070. if (!cellFocused && !fullRowEdit && this.editingCell) {
  23071. this.stopRowOrCellEdit();
  23072. }
  23073. };
  23074. // pass in 'true' to cancel the editing.
  23075. CellComp.prototype.stopRowOrCellEdit = function (cancel) {
  23076. if (cancel === void 0) { cancel = false; }
  23077. if (this.beans.gridOptionsWrapper.isFullRowEdit()) {
  23078. this.rowComp.stopRowEditing(cancel);
  23079. }
  23080. else {
  23081. this.stopEditing(cancel);
  23082. }
  23083. };
  23084. CellComp.prototype.stopEditing = function (cancel) {
  23085. if (cancel === void 0) { cancel = false; }
  23086. if (!this.editingCell) {
  23087. return;
  23088. }
  23089. // if no cell editor, this means due to async, that the cell editor never got initialised,
  23090. // so we just carry on regardless as if the editing was never started.
  23091. if (!this.cellEditor) {
  23092. this.editingCell = false;
  23093. return;
  23094. }
  23095. var oldValue = this.getValue();
  23096. var newValueExists = false;
  23097. var newValue;
  23098. if (!cancel) {
  23099. // also have another option here to cancel after editing, so for example user could have a popup editor and
  23100. // it is closed by user clicking outside the editor. then the editor will close automatically (with false
  23101. // passed above) and we need to see if the editor wants to accept the new value.
  23102. var userWantsToCancel = this.cellEditor.isCancelAfterEnd && this.cellEditor.isCancelAfterEnd();
  23103. if (!userWantsToCancel) {
  23104. newValue = this.cellEditor.getValue();
  23105. newValueExists = true;
  23106. }
  23107. }
  23108. // it is important we set this after setValue() above, as otherwise the cell will flash
  23109. // when editing stops. the 'refresh' method checks editing, and doesn't refresh editing cells.
  23110. // thus it will skip the refresh on this cell until the end of this method where we call
  23111. // refresh directly and we suppress the flash.
  23112. this.editingCell = false;
  23113. // important to clear this out - as parts of the code will check for
  23114. // this to see if an async cellEditor has yet to be created
  23115. this.cellEditor = this.beans.context.destroyBean(this.cellEditor);
  23116. this.cellEditor = null;
  23117. if (this.cellEditorInPopup && this.hideEditorPopup) {
  23118. this.hideEditorPopup();
  23119. this.hideEditorPopup = null;
  23120. }
  23121. else {
  23122. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].clearElement(this.getGui());
  23123. // put the cell back the way it was before editing
  23124. if (this.usingWrapper) {
  23125. // if wrapper, then put the wrapper back
  23126. this.getGui().appendChild(this.eCellWrapper);
  23127. }
  23128. else if (this.cellRenderer) {
  23129. // if cellRenderer, then put the gui back in. if the renderer has
  23130. // a refresh, it will be called. however if it doesn't, then later
  23131. // the renderer will be destroyed and a new one will be created.
  23132. // we know it's a dom element (not a string) because we converted
  23133. // it after the gui was attached if it was a string.
  23134. var eCell = this.cellRendererGui;
  23135. // can be null if cell was previously null / contained empty string,
  23136. // this will result in new value not being rendered.
  23137. if (eCell) {
  23138. this.getGui().appendChild(eCell);
  23139. }
  23140. }
  23141. }
  23142. this.setInlineEditingClass();
  23143. this.refreshHandle();
  23144. if (newValueExists && newValue !== oldValue) {
  23145. // we suppressRefreshCell because the call to rowNode.setDataValue() results in change detection
  23146. // getting triggered, which results in all cells getting refreshed. we do not want this refresh
  23147. // to happen on this call as we want to call it explicitly below. otherwise refresh gets called twice.
  23148. // if we only did this refresh (and not the one below) then the cell would flash and not be forced.
  23149. this.suppressRefreshCell = true;
  23150. this.rowNode.setDataValue(this.column, newValue);
  23151. this.suppressRefreshCell = false;
  23152. }
  23153. // we suppress the flash, as it is not correct to flash the cell the user has finished editing,
  23154. // the user doesn't need to flash as they were the one who did the edit, the flash is pointless
  23155. // (as the flash is meant to draw the user to a change that they didn't manually do themselves).
  23156. this.refreshCell({ forceRefresh: true, suppressFlash: true });
  23157. var event = this.createEvent(null, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_EDITING_STOPPED);
  23158. this.beans.eventService.dispatchEvent(event);
  23159. };
  23160. CellComp.DOM_DATA_KEY_CELL_COMP = 'cellComp';
  23161. CellComp.CELL_RENDERER_TYPE_NORMAL = 'cellRenderer';
  23162. CellComp.CELL_RENDERER_TYPE_PINNED = 'pinnedRowCellRenderer';
  23163. return CellComp;
  23164. }(_widgets_component__WEBPACK_IMPORTED_MODULE_2__["Component"]));
  23165. /***/ }),
  23166. /* 102 */
  23167. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  23168. "use strict";
  23169. __webpack_require__.r(__webpack_exports__);
  23170. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SelectionHandleType", function() { return SelectionHandleType; });
  23171. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellRangeType", function() { return CellRangeType; });
  23172. /**
  23173. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  23174. * @version v23.2.1
  23175. * @link http://www.ag-grid.com/
  23176. * @license MIT
  23177. */
  23178. var SelectionHandleType;
  23179. (function (SelectionHandleType) {
  23180. SelectionHandleType[SelectionHandleType["FILL"] = 0] = "FILL";
  23181. SelectionHandleType[SelectionHandleType["RANGE"] = 1] = "RANGE";
  23182. })(SelectionHandleType || (SelectionHandleType = {}));
  23183. var CellRangeType;
  23184. (function (CellRangeType) {
  23185. CellRangeType[CellRangeType["VALUE"] = 0] = "VALUE";
  23186. CellRangeType[CellRangeType["DIMENSION"] = 1] = "DIMENSION";
  23187. })(CellRangeType || (CellRangeType = {}));
  23188. /***/ }),
  23189. /* 103 */
  23190. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  23191. "use strict";
  23192. __webpack_require__.r(__webpack_exports__);
  23193. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowDragComp", function() { return RowDragComp; });
  23194. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56);
  23195. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  23196. /* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(68);
  23197. /* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(104);
  23198. /* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(44);
  23199. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(41);
  23200. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(7);
  23201. /**
  23202. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  23203. * @version v23.2.1
  23204. * @link http://www.ag-grid.com/
  23205. * @license MIT
  23206. */
  23207. var __extends = (undefined && undefined.__extends) || (function () {
  23208. var extendStatics = function (d, b) {
  23209. extendStatics = Object.setPrototypeOf ||
  23210. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  23211. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  23212. return extendStatics(d, b);
  23213. };
  23214. return function (d, b) {
  23215. extendStatics(d, b);
  23216. function __() { this.constructor = d; }
  23217. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  23218. };
  23219. })();
  23220. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  23221. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  23222. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  23223. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  23224. return c > 3 && r && Object.defineProperty(target, key, r), r;
  23225. };
  23226. var RowDragComp = /** @class */ (function (_super) {
  23227. __extends(RowDragComp, _super);
  23228. function RowDragComp(rowNode, column, cellValue, beans) {
  23229. var _this = _super.call(this, "<div class=\"ag-drag-handle ag-row-drag\" role=\"presentation\"></div>") || this;
  23230. _this.rowNode = rowNode;
  23231. _this.column = column;
  23232. _this.cellValue = cellValue;
  23233. _this.beans = beans;
  23234. return _this;
  23235. }
  23236. RowDragComp.prototype.postConstruct = function () {
  23237. var eGui = this.getGui();
  23238. eGui.appendChild(_utils__WEBPACK_IMPORTED_MODULE_6__["_"].createIconNoSpan('rowDrag', this.beans.gridOptionsWrapper, null));
  23239. this.addDragSource();
  23240. this.checkCompatibility();
  23241. var strategy = this.beans.gridOptionsWrapper.isRowDragManaged() ?
  23242. new ManagedVisibilityStrategy(this, this.beans, this.rowNode, this.column) :
  23243. new NonManagedVisibilityStrategy(this, this.beans, this.rowNode, this.column);
  23244. this.createManagedBean(strategy, this.beans.context);
  23245. };
  23246. RowDragComp.prototype.getSelectedCount = function () {
  23247. var multiRowEnabled = this.beans.gridOptionsWrapper.isEnableMultiRowDragging();
  23248. if (!multiRowEnabled) {
  23249. return 1;
  23250. }
  23251. var selection = this.beans.selectionController.getSelectedNodes();
  23252. return selection.indexOf(this.rowNode) !== -1 ? selection.length : 1;
  23253. };
  23254. // returns true if all compatibility items work out
  23255. RowDragComp.prototype.checkCompatibility = function () {
  23256. var managed = this.beans.gridOptionsWrapper.isRowDragManaged();
  23257. var treeData = this.beans.gridOptionsWrapper.isTreeData();
  23258. if (treeData && managed) {
  23259. _utils__WEBPACK_IMPORTED_MODULE_6__["_"].doOnce(function () {
  23260. return console.warn('ag-Grid: If using row drag with tree data, you cannot have rowDragManaged=true');
  23261. }, 'RowDragComp.managedAndTreeData');
  23262. }
  23263. };
  23264. RowDragComp.prototype.addDragSource = function () {
  23265. var _this = this;
  23266. var dragItem = {
  23267. rowNode: this.rowNode,
  23268. columns: [this.column],
  23269. defaultTextValue: this.cellValue,
  23270. };
  23271. var rowDragText = this.column.getColDef().rowDragText;
  23272. var dragSource = {
  23273. type: _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_3__["DragSourceType"].RowDrag,
  23274. eElement: this.getGui(),
  23275. dragItemName: function () {
  23276. var dragItemCount = _this.getSelectedCount();
  23277. if (rowDragText) {
  23278. return rowDragText(dragItem, dragItemCount);
  23279. }
  23280. return dragItemCount === 1 ? _this.cellValue : dragItemCount + " rows";
  23281. },
  23282. getDragItem: function () { return dragItem; },
  23283. dragStartPixels: 0
  23284. };
  23285. this.beans.dragAndDropService.addDragSource(dragSource, true);
  23286. this.addDestroyFunc(function () { return _this.beans.dragAndDropService.removeDragSource(dragSource); });
  23287. };
  23288. __decorate([
  23289. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  23290. ], RowDragComp.prototype, "postConstruct", null);
  23291. return RowDragComp;
  23292. }(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"]));
  23293. var VisibilityStrategy = /** @class */ (function (_super) {
  23294. __extends(VisibilityStrategy, _super);
  23295. function VisibilityStrategy(parent, rowNode, column) {
  23296. var _this = _super.call(this) || this;
  23297. _this.parent = parent;
  23298. _this.column = column;
  23299. _this.rowNode = rowNode;
  23300. return _this;
  23301. }
  23302. VisibilityStrategy.prototype.setDisplayedOrVisible = function (neverDisplayed) {
  23303. if (neverDisplayed) {
  23304. this.parent.setDisplayed(false);
  23305. }
  23306. else {
  23307. var shown = this.column.isRowDrag(this.rowNode);
  23308. var isShownSometimes = _utils__WEBPACK_IMPORTED_MODULE_6__["_"].isFunction(this.column.getColDef().rowDrag);
  23309. // if shown sometimes, them some rows can have drag handle while other don't,
  23310. // so we use setVisible to keep the handles horizontally aligned (as setVisible
  23311. // keeps the empty space, whereas setDisplayed looses the space)
  23312. if (isShownSometimes) {
  23313. this.parent.setDisplayed(true);
  23314. this.parent.setVisible(shown);
  23315. }
  23316. else {
  23317. this.parent.setDisplayed(shown);
  23318. }
  23319. }
  23320. };
  23321. return VisibilityStrategy;
  23322. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_5__["BeanStub"]));
  23323. // when non managed, the visibility depends on suppressRowDrag property only
  23324. var NonManagedVisibilityStrategy = /** @class */ (function (_super) {
  23325. __extends(NonManagedVisibilityStrategy, _super);
  23326. function NonManagedVisibilityStrategy(parent, beans, rowNode, column) {
  23327. var _this = _super.call(this, parent, rowNode, column) || this;
  23328. _this.beans = beans;
  23329. return _this;
  23330. }
  23331. NonManagedVisibilityStrategy.prototype.postConstruct = function () {
  23332. this.addManagedListener(this.beans.gridOptionsWrapper, 'suppressRowDrag', this.onSuppressRowDrag.bind(this));
  23333. // in case data changes, then we need to update visibility of drag item
  23334. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_DATA_CHANGED, this.workOutVisibility.bind(this));
  23335. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_CELL_CHANGED, this.workOutVisibility.bind(this));
  23336. this.workOutVisibility();
  23337. };
  23338. NonManagedVisibilityStrategy.prototype.onSuppressRowDrag = function () {
  23339. this.workOutVisibility();
  23340. };
  23341. NonManagedVisibilityStrategy.prototype.workOutVisibility = function () {
  23342. // only show the drag if both sort and filter are not present
  23343. var neverDisplayed = this.beans.gridOptionsWrapper.isSuppressRowDrag();
  23344. this.setDisplayedOrVisible(neverDisplayed);
  23345. };
  23346. __decorate([
  23347. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  23348. ], NonManagedVisibilityStrategy.prototype, "postConstruct", null);
  23349. return NonManagedVisibilityStrategy;
  23350. }(VisibilityStrategy));
  23351. // when managed, the visibility depends on sort, filter and row group, as well as suppressRowDrag property
  23352. var ManagedVisibilityStrategy = /** @class */ (function (_super) {
  23353. __extends(ManagedVisibilityStrategy, _super);
  23354. function ManagedVisibilityStrategy(parent, beans, rowNode, column) {
  23355. var _this = _super.call(this, parent, rowNode, column) || this;
  23356. _this.beans = beans;
  23357. return _this;
  23358. }
  23359. ManagedVisibilityStrategy.prototype.postConstruct = function () {
  23360. // we do not show the component if sort, filter or grouping is active
  23361. this.addManagedListener(this.beans.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_SORT_CHANGED, this.workOutVisibility.bind(this));
  23362. this.addManagedListener(this.beans.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_FILTER_CHANGED, this.workOutVisibility.bind(this));
  23363. this.addManagedListener(this.beans.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, this.workOutVisibility.bind(this));
  23364. // in case data changes, then we need to update visibility of drag item
  23365. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_DATA_CHANGED, this.workOutVisibility.bind(this));
  23366. this.addManagedListener(this.rowNode, _entities_rowNode__WEBPACK_IMPORTED_MODULE_2__["RowNode"].EVENT_CELL_CHANGED, this.workOutVisibility.bind(this));
  23367. this.addManagedListener(this.beans.gridOptionsWrapper, 'suppressRowDrag', this.onSuppressRowDrag.bind(this));
  23368. this.workOutVisibility();
  23369. };
  23370. ManagedVisibilityStrategy.prototype.onSuppressRowDrag = function () {
  23371. this.workOutVisibility();
  23372. };
  23373. ManagedVisibilityStrategy.prototype.workOutVisibility = function () {
  23374. // only show the drag if both sort and filter are not present
  23375. var rowDragFeature = this.beans.gridPanel.getRowDragFeature();
  23376. var shouldPreventRowMove = rowDragFeature && rowDragFeature.shouldPreventRowMove();
  23377. var suppressRowDrag = this.beans.gridOptionsWrapper.isSuppressRowDrag();
  23378. var hasExternalDropZones = this.beans.dragAndDropService.hasExternalDropZones();
  23379. var neverDisplayed = (shouldPreventRowMove && !hasExternalDropZones) || suppressRowDrag;
  23380. this.setDisplayedOrVisible(neverDisplayed);
  23381. };
  23382. __decorate([
  23383. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  23384. ], ManagedVisibilityStrategy.prototype, "postConstruct", null);
  23385. return ManagedVisibilityStrategy;
  23386. }(VisibilityStrategy));
  23387. /***/ }),
  23388. /* 104 */
  23389. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  23390. "use strict";
  23391. __webpack_require__.r(__webpack_exports__);
  23392. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DragSourceType", function() { return DragSourceType; });
  23393. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "VerticalDirection", function() { return VerticalDirection; });
  23394. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HorizontalDirection", function() { return HorizontalDirection; });
  23395. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DragAndDropService", function() { return DragAndDropService; });
  23396. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(41);
  23397. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  23398. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
  23399. /**
  23400. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  23401. * @version v23.2.1
  23402. * @link http://www.ag-grid.com/
  23403. * @license MIT
  23404. */
  23405. var __extends = (undefined && undefined.__extends) || (function () {
  23406. var extendStatics = function (d, b) {
  23407. extendStatics = Object.setPrototypeOf ||
  23408. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  23409. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  23410. return extendStatics(d, b);
  23411. };
  23412. return function (d, b) {
  23413. extendStatics(d, b);
  23414. function __() { this.constructor = d; }
  23415. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  23416. };
  23417. })();
  23418. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  23419. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  23420. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  23421. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  23422. return c > 3 && r && Object.defineProperty(target, key, r), r;
  23423. };
  23424. var DragSourceType;
  23425. (function (DragSourceType) {
  23426. DragSourceType[DragSourceType["ToolPanel"] = 0] = "ToolPanel";
  23427. DragSourceType[DragSourceType["HeaderCell"] = 1] = "HeaderCell";
  23428. DragSourceType[DragSourceType["RowDrag"] = 2] = "RowDrag";
  23429. DragSourceType[DragSourceType["ChartPanel"] = 3] = "ChartPanel";
  23430. })(DragSourceType || (DragSourceType = {}));
  23431. var VerticalDirection;
  23432. (function (VerticalDirection) {
  23433. VerticalDirection[VerticalDirection["Up"] = 0] = "Up";
  23434. VerticalDirection[VerticalDirection["Down"] = 1] = "Down";
  23435. })(VerticalDirection || (VerticalDirection = {}));
  23436. var HorizontalDirection;
  23437. (function (HorizontalDirection) {
  23438. HorizontalDirection[HorizontalDirection["Left"] = 0] = "Left";
  23439. HorizontalDirection[HorizontalDirection["Right"] = 1] = "Right";
  23440. })(HorizontalDirection || (HorizontalDirection = {}));
  23441. var DragAndDropService = /** @class */ (function (_super) {
  23442. __extends(DragAndDropService, _super);
  23443. function DragAndDropService() {
  23444. var _this = _super !== null && _super.apply(this, arguments) || this;
  23445. _this.dragSourceAndParamsList = [];
  23446. _this.dropTargets = [];
  23447. return _this;
  23448. }
  23449. DragAndDropService_1 = DragAndDropService;
  23450. DragAndDropService.prototype.init = function () {
  23451. this.ePinnedIcon = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIcon('columnMovePin', this.gridOptionsWrapper, null);
  23452. this.eHideIcon = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIcon('columnMoveHide', this.gridOptionsWrapper, null);
  23453. this.eMoveIcon = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIcon('columnMoveMove', this.gridOptionsWrapper, null);
  23454. this.eLeftIcon = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIcon('columnMoveLeft', this.gridOptionsWrapper, null);
  23455. this.eRightIcon = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIcon('columnMoveRight', this.gridOptionsWrapper, null);
  23456. this.eGroupIcon = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIcon('columnMoveGroup', this.gridOptionsWrapper, null);
  23457. this.eAggregateIcon = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIcon('columnMoveValue', this.gridOptionsWrapper, null);
  23458. this.ePivotIcon = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIcon('columnMovePivot', this.gridOptionsWrapper, null);
  23459. this.eDropNotAllowedIcon = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIcon('dropNotAllowed', this.gridOptionsWrapper, null);
  23460. };
  23461. DragAndDropService.prototype.addDragSource = function (dragSource, allowTouch) {
  23462. if (allowTouch === void 0) { allowTouch = false; }
  23463. var params = {
  23464. eElement: dragSource.eElement,
  23465. dragStartPixels: dragSource.dragStartPixels,
  23466. onDragStart: this.onDragStart.bind(this, dragSource),
  23467. onDragStop: this.onDragStop.bind(this),
  23468. onDragging: this.onDragging.bind(this)
  23469. };
  23470. this.dragSourceAndParamsList.push({ params: params, dragSource: dragSource });
  23471. this.dragService.addDragSource(params, allowTouch);
  23472. };
  23473. DragAndDropService.prototype.removeDragSource = function (dragSource) {
  23474. var sourceAndParams = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].find(this.dragSourceAndParamsList, function (item) { return item.dragSource === dragSource; });
  23475. if (sourceAndParams) {
  23476. this.dragService.removeDragSource(sourceAndParams.params);
  23477. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].removeFromArray(this.dragSourceAndParamsList, sourceAndParams);
  23478. }
  23479. };
  23480. DragAndDropService.prototype.clearDragSourceParamsList = function () {
  23481. var _this = this;
  23482. this.dragSourceAndParamsList.forEach(function (sourceAndParams) { return _this.dragService.removeDragSource(sourceAndParams.params); });
  23483. this.dragSourceAndParamsList.length = 0;
  23484. };
  23485. DragAndDropService.prototype.nudge = function () {
  23486. if (this.dragging) {
  23487. this.onDragging(this.eventLastTime, true);
  23488. }
  23489. };
  23490. DragAndDropService.prototype.onDragStart = function (dragSource, mouseEvent) {
  23491. this.dragging = true;
  23492. this.dragSource = dragSource;
  23493. this.eventLastTime = mouseEvent;
  23494. this.dragItem = this.dragSource.getDragItem();
  23495. this.lastDropTarget = this.dragSource.dragSourceDropTarget;
  23496. if (this.dragSource.onDragStarted) {
  23497. this.dragSource.onDragStarted();
  23498. }
  23499. this.createGhost();
  23500. };
  23501. DragAndDropService.prototype.onDragStop = function (mouseEvent) {
  23502. this.eventLastTime = null;
  23503. this.dragging = false;
  23504. if (this.dragSource.onDragStopped) {
  23505. this.dragSource.onDragStopped();
  23506. }
  23507. if (this.lastDropTarget && this.lastDropTarget.onDragStop) {
  23508. var draggingEvent = this.createDropTargetEvent(this.lastDropTarget, mouseEvent, null, null, false);
  23509. this.lastDropTarget.onDragStop(draggingEvent);
  23510. }
  23511. this.lastDropTarget = null;
  23512. this.dragItem = null;
  23513. this.removeGhost();
  23514. };
  23515. DragAndDropService.prototype.onDragging = function (mouseEvent, fromNudge) {
  23516. var hDirection = this.getHorizontalDirection(mouseEvent);
  23517. var vDirection = this.getVerticalDirection(mouseEvent);
  23518. this.eventLastTime = mouseEvent;
  23519. this.positionGhost(mouseEvent);
  23520. // check if mouseEvent intersects with any of the drop targets
  23521. var dropTarget = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].find(this.dropTargets, this.isMouseOnDropTarget.bind(this, mouseEvent));
  23522. if (dropTarget !== this.lastDropTarget) {
  23523. this.leaveLastTargetIfExists(mouseEvent, hDirection, vDirection, fromNudge);
  23524. this.enterDragTargetIfExists(dropTarget, mouseEvent, hDirection, vDirection, fromNudge);
  23525. this.lastDropTarget = dropTarget;
  23526. }
  23527. else if (dropTarget && dropTarget.onDragging) {
  23528. var draggingEvent = this.createDropTargetEvent(dropTarget, mouseEvent, hDirection, vDirection, fromNudge);
  23529. dropTarget.onDragging(draggingEvent);
  23530. }
  23531. };
  23532. DragAndDropService.prototype.enterDragTargetIfExists = function (dropTarget, mouseEvent, hDirection, vDirection, fromNudge) {
  23533. if (!dropTarget) {
  23534. return;
  23535. }
  23536. if (dropTarget.onDragEnter) {
  23537. var dragEnterEvent = this.createDropTargetEvent(dropTarget, mouseEvent, hDirection, vDirection, fromNudge);
  23538. dropTarget.onDragEnter(dragEnterEvent);
  23539. }
  23540. this.setGhostIcon(dropTarget.getIconName ? dropTarget.getIconName() : null);
  23541. };
  23542. DragAndDropService.prototype.leaveLastTargetIfExists = function (mouseEvent, hDirection, vDirection, fromNudge) {
  23543. if (!this.lastDropTarget) {
  23544. return;
  23545. }
  23546. if (this.lastDropTarget.onDragLeave) {
  23547. var dragLeaveEvent = this.createDropTargetEvent(this.lastDropTarget, mouseEvent, hDirection, vDirection, fromNudge);
  23548. this.lastDropTarget.onDragLeave(dragLeaveEvent);
  23549. }
  23550. this.setGhostIcon(null);
  23551. };
  23552. DragAndDropService.prototype.getAllContainersFromDropTarget = function (dropTarget) {
  23553. var containers = [dropTarget.getContainer()];
  23554. var secondaryContainers = dropTarget.getSecondaryContainers ? dropTarget.getSecondaryContainers() : null;
  23555. if (secondaryContainers) {
  23556. containers = containers.concat(secondaryContainers);
  23557. }
  23558. return containers;
  23559. };
  23560. // checks if the mouse is on the drop target. it checks eContainer and eSecondaryContainers
  23561. DragAndDropService.prototype.isMouseOnDropTarget = function (mouseEvent, dropTarget) {
  23562. var mouseOverTarget = false;
  23563. this.getAllContainersFromDropTarget(dropTarget)
  23564. .filter(function (eContainer) { return eContainer; }) // secondary can be missing
  23565. .forEach(function (eContainer) {
  23566. var rect = eContainer.getBoundingClientRect();
  23567. // if element is not visible, then width and height are zero
  23568. if (rect.width === 0 || rect.height === 0) {
  23569. return;
  23570. }
  23571. var horizontalFit = mouseEvent.clientX >= rect.left && mouseEvent.clientX <= rect.right;
  23572. var verticalFit = mouseEvent.clientY >= rect.top && mouseEvent.clientY <= rect.bottom;
  23573. if (horizontalFit && verticalFit) {
  23574. mouseOverTarget = true;
  23575. }
  23576. });
  23577. return mouseOverTarget && dropTarget.isInterestedIn(this.dragSource.type);
  23578. };
  23579. DragAndDropService.prototype.addDropTarget = function (dropTarget) {
  23580. this.dropTargets.push(dropTarget);
  23581. };
  23582. DragAndDropService.prototype.removeDropTarget = function (dropTarget) {
  23583. this.dropTargets = this.dropTargets.filter(function (target) { return target.getContainer() !== dropTarget.getContainer(); });
  23584. };
  23585. DragAndDropService.prototype.hasExternalDropZones = function () {
  23586. return this.dropTargets.some(function (zones) { return zones.external; });
  23587. };
  23588. DragAndDropService.prototype.findExternalZone = function (params) {
  23589. var externalTargets = this.dropTargets.filter(function (target) { return target.external; });
  23590. return _utils__WEBPACK_IMPORTED_MODULE_2__["_"].find(externalTargets, function (zone) { return zone.getContainer() === params.getContainer(); });
  23591. };
  23592. DragAndDropService.prototype.getHorizontalDirection = function (event) {
  23593. var clientX = this.eventLastTime.clientX;
  23594. var eClientX = event.clientX;
  23595. if (clientX === eClientX) {
  23596. return null;
  23597. }
  23598. return clientX > eClientX ? HorizontalDirection.Left : HorizontalDirection.Right;
  23599. };
  23600. DragAndDropService.prototype.getVerticalDirection = function (event) {
  23601. var clientY = this.eventLastTime.clientY;
  23602. var eClientY = event.clientY;
  23603. if (clientY === eClientY) {
  23604. return null;
  23605. }
  23606. return clientY > eClientY ? VerticalDirection.Up : VerticalDirection.Down;
  23607. };
  23608. DragAndDropService.prototype.createDropTargetEvent = function (dropTarget, event, hDirection, vDirection, fromNudge) {
  23609. // localise x and y to the target
  23610. var dropZoneTarget = dropTarget.getContainer();
  23611. var rect = dropZoneTarget.getBoundingClientRect();
  23612. var _a = this, api = _a.gridApi, columnApi = _a.columnApi, dragItem = _a.dragItem, dragSource = _a.dragSource;
  23613. var x = event.clientX - rect.left;
  23614. var y = event.clientY - rect.top;
  23615. return { event: event, x: x, y: y, vDirection: vDirection, hDirection: hDirection, dragSource: dragSource, fromNudge: fromNudge, dragItem: dragItem, api: api, columnApi: columnApi, dropZoneTarget: dropZoneTarget };
  23616. };
  23617. DragAndDropService.prototype.positionGhost = function (event) {
  23618. var ghost = this.eGhost;
  23619. var ghostRect = ghost.getBoundingClientRect();
  23620. var ghostHeight = ghostRect.height;
  23621. // for some reason, without the '-2', it still overlapped by 1 or 2 pixels, which
  23622. // then brought in scrollbars to the browser. no idea why, but putting in -2 here
  23623. // works around it which is good enough for me.
  23624. var browserWidth = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].getBodyWidth() - 2;
  23625. var browserHeight = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].getBodyHeight() - 2;
  23626. var top = event.pageY - (ghostHeight / 2);
  23627. var left = event.pageX - 10;
  23628. var usrDocument = this.gridOptionsWrapper.getDocument();
  23629. var windowScrollY = window.pageYOffset || usrDocument.documentElement.scrollTop;
  23630. var windowScrollX = window.pageXOffset || usrDocument.documentElement.scrollLeft;
  23631. // check ghost is not positioned outside of the browser
  23632. if (browserWidth > 0 && ((left + ghost.clientWidth) > (browserWidth + windowScrollX))) {
  23633. left = browserWidth + windowScrollX - ghost.clientWidth;
  23634. }
  23635. if (left < 0) {
  23636. left = 0;
  23637. }
  23638. if (browserHeight > 0 && ((top + ghost.clientHeight) > (browserHeight + windowScrollY))) {
  23639. top = browserHeight + windowScrollY - ghost.clientHeight;
  23640. }
  23641. if (top < 0) {
  23642. top = 0;
  23643. }
  23644. ghost.style.left = left + "px";
  23645. ghost.style.top = top + "px";
  23646. };
  23647. DragAndDropService.prototype.removeGhost = function () {
  23648. if (this.eGhost && this.eGhostParent) {
  23649. this.eGhostParent.removeChild(this.eGhost);
  23650. }
  23651. this.eGhost = null;
  23652. };
  23653. DragAndDropService.prototype.createGhost = function () {
  23654. this.eGhost = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].loadTemplate(DragAndDropService_1.GHOST_TEMPLATE);
  23655. var theme = this.environment.getTheme().theme;
  23656. if (theme) {
  23657. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(this.eGhost, theme);
  23658. }
  23659. this.eGhostIcon = this.eGhost.querySelector('.ag-dnd-ghost-icon');
  23660. this.setGhostIcon(null);
  23661. var eText = this.eGhost.querySelector('.ag-dnd-ghost-label');
  23662. var dragItemName = this.dragSource.dragItemName;
  23663. if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].isFunction(dragItemName)) {
  23664. dragItemName = dragItemName();
  23665. }
  23666. eText.innerHTML = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].escape(dragItemName);
  23667. this.eGhost.style.height = '25px';
  23668. this.eGhost.style.top = '20px';
  23669. this.eGhost.style.left = '20px';
  23670. var usrDocument = this.gridOptionsWrapper.getDocument();
  23671. this.eGhostParent = usrDocument.querySelector('body');
  23672. if (!this.eGhostParent) {
  23673. console.warn('ag-Grid: could not find document body, it is needed for dragging columns');
  23674. }
  23675. else {
  23676. this.eGhostParent.appendChild(this.eGhost);
  23677. }
  23678. };
  23679. DragAndDropService.prototype.setGhostIcon = function (iconName, shake) {
  23680. if (shake === void 0) { shake = false; }
  23681. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].clearElement(this.eGhostIcon);
  23682. var eIcon;
  23683. if (!iconName) {
  23684. iconName = this.dragSource.defaultIconName || DragAndDropService_1.ICON_NOT_ALLOWED;
  23685. }
  23686. switch (iconName) {
  23687. case DragAndDropService_1.ICON_PINNED:
  23688. eIcon = this.ePinnedIcon;
  23689. break;
  23690. case DragAndDropService_1.ICON_MOVE:
  23691. eIcon = this.eMoveIcon;
  23692. break;
  23693. case DragAndDropService_1.ICON_LEFT:
  23694. eIcon = this.eLeftIcon;
  23695. break;
  23696. case DragAndDropService_1.ICON_RIGHT:
  23697. eIcon = this.eRightIcon;
  23698. break;
  23699. case DragAndDropService_1.ICON_GROUP:
  23700. eIcon = this.eGroupIcon;
  23701. break;
  23702. case DragAndDropService_1.ICON_AGGREGATE:
  23703. eIcon = this.eAggregateIcon;
  23704. break;
  23705. case DragAndDropService_1.ICON_PIVOT:
  23706. eIcon = this.ePivotIcon;
  23707. break;
  23708. case DragAndDropService_1.ICON_NOT_ALLOWED:
  23709. eIcon = this.eDropNotAllowedIcon;
  23710. break;
  23711. case DragAndDropService_1.ICON_HIDE:
  23712. eIcon = this.eHideIcon;
  23713. break;
  23714. }
  23715. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addOrRemoveCssClass(this.eGhostIcon, 'ag-shake-left-to-right', shake);
  23716. if (eIcon === this.eHideIcon && this.gridOptionsWrapper.isSuppressDragLeaveHidesColumns()) {
  23717. return;
  23718. }
  23719. if (eIcon) {
  23720. this.eGhostIcon.appendChild(eIcon);
  23721. }
  23722. };
  23723. var DragAndDropService_1;
  23724. DragAndDropService.ICON_PINNED = 'pinned';
  23725. DragAndDropService.ICON_MOVE = 'move';
  23726. DragAndDropService.ICON_LEFT = 'left';
  23727. DragAndDropService.ICON_RIGHT = 'right';
  23728. DragAndDropService.ICON_GROUP = 'group';
  23729. DragAndDropService.ICON_AGGREGATE = 'aggregate';
  23730. DragAndDropService.ICON_PIVOT = 'pivot';
  23731. DragAndDropService.ICON_NOT_ALLOWED = 'notAllowed';
  23732. DragAndDropService.ICON_HIDE = 'hide';
  23733. DragAndDropService.GHOST_TEMPLATE = "<div class=\"ag-dnd-ghost ag-unselectable\">\n <span class=\"ag-dnd-ghost-icon ag-shake-left-to-right\"></span>\n <div class=\"ag-dnd-ghost-label\"></div>\n </div>";
  23734. __decorate([
  23735. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  23736. ], DragAndDropService.prototype, "gridOptionsWrapper", void 0);
  23737. __decorate([
  23738. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('dragService')
  23739. ], DragAndDropService.prototype, "dragService", void 0);
  23740. __decorate([
  23741. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('environment')
  23742. ], DragAndDropService.prototype, "environment", void 0);
  23743. __decorate([
  23744. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnApi')
  23745. ], DragAndDropService.prototype, "columnApi", void 0);
  23746. __decorate([
  23747. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridApi')
  23748. ], DragAndDropService.prototype, "gridApi", void 0);
  23749. __decorate([
  23750. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  23751. ], DragAndDropService.prototype, "init", null);
  23752. __decorate([
  23753. _context_context__WEBPACK_IMPORTED_MODULE_1__["PreDestroy"]
  23754. ], DragAndDropService.prototype, "clearDragSourceParamsList", null);
  23755. DragAndDropService = DragAndDropService_1 = __decorate([
  23756. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('dragAndDropService')
  23757. ], DragAndDropService);
  23758. return DragAndDropService;
  23759. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"]));
  23760. /***/ }),
  23761. /* 105 */
  23762. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  23763. "use strict";
  23764. __webpack_require__.r(__webpack_exports__);
  23765. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PopupEditorWrapper", function() { return PopupEditorWrapper; });
  23766. /* harmony import */ var _widgets_popupComponent__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(55);
  23767. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  23768. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
  23769. /**
  23770. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  23771. * @version v23.2.1
  23772. * @link http://www.ag-grid.com/
  23773. * @license MIT
  23774. */
  23775. var __extends = (undefined && undefined.__extends) || (function () {
  23776. var extendStatics = function (d, b) {
  23777. extendStatics = Object.setPrototypeOf ||
  23778. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  23779. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  23780. return extendStatics(d, b);
  23781. };
  23782. return function (d, b) {
  23783. extendStatics(d, b);
  23784. function __() { this.constructor = d; }
  23785. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  23786. };
  23787. })();
  23788. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  23789. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  23790. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  23791. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  23792. return c > 3 && r && Object.defineProperty(target, key, r), r;
  23793. };
  23794. var PopupEditorWrapper = /** @class */ (function (_super) {
  23795. __extends(PopupEditorWrapper, _super);
  23796. function PopupEditorWrapper(cellEditor) {
  23797. var _this = _super.call(this, "<div class=\"ag-popup-editor\" tabindex=\"-1\"/>") || this;
  23798. _this.getGuiCalledOnChild = false;
  23799. _this.cellEditor = cellEditor;
  23800. return _this;
  23801. }
  23802. PopupEditorWrapper.prototype.onKeyDown = function (event) {
  23803. if (!_utils__WEBPACK_IMPORTED_MODULE_2__["_"].isUserSuppressingKeyboardEvent(this.gridOptionsWrapper, event, this.params.node, this.params.column, true)) {
  23804. this.params.onKeyDown(event);
  23805. }
  23806. };
  23807. PopupEditorWrapper.prototype.getGui = function () {
  23808. // we call getGui() on child here (rather than in the constructor)
  23809. // as we should wait for 'init' to be called on child first.
  23810. if (!this.getGuiCalledOnChild) {
  23811. this.appendChild(this.cellEditor.getGui());
  23812. this.getGuiCalledOnChild = true;
  23813. }
  23814. return _super.prototype.getGui.call(this);
  23815. };
  23816. PopupEditorWrapper.prototype.init = function (params) {
  23817. var _this = this;
  23818. this.params = params;
  23819. this.gridOptionsWrapper.setDomData(this.getGui(), PopupEditorWrapper.DOM_KEY_POPUP_EDITOR_WRAPPER, true);
  23820. this.addDestroyFunc(function () { return _this.destroyBean(_this.cellEditor); });
  23821. this.addManagedListener(
  23822. // this needs to be 'super' and not 'this' as if we call 'this',
  23823. // it ends up called 'getGui()' on the child before 'init' was called,
  23824. // which is not good
  23825. _super.prototype.getGui.call(this), 'keydown', this.onKeyDown.bind(this));
  23826. };
  23827. PopupEditorWrapper.prototype.afterGuiAttached = function () {
  23828. if (this.cellEditor.afterGuiAttached) {
  23829. this.cellEditor.afterGuiAttached();
  23830. }
  23831. };
  23832. PopupEditorWrapper.prototype.getValue = function () {
  23833. return this.cellEditor.getValue();
  23834. };
  23835. PopupEditorWrapper.prototype.isCancelBeforeStart = function () {
  23836. if (this.cellEditor.isCancelBeforeStart) {
  23837. return this.cellEditor.isCancelBeforeStart();
  23838. }
  23839. };
  23840. PopupEditorWrapper.prototype.isCancelAfterEnd = function () {
  23841. if (this.cellEditor.isCancelAfterEnd) {
  23842. return this.cellEditor.isCancelAfterEnd();
  23843. }
  23844. };
  23845. PopupEditorWrapper.prototype.getPopupPosition = function () {
  23846. if (this.cellEditor.getPopupPosition) {
  23847. return this.cellEditor.getPopupPosition();
  23848. }
  23849. };
  23850. PopupEditorWrapper.prototype.focusIn = function () {
  23851. if (this.cellEditor.focusIn) {
  23852. this.cellEditor.focusIn();
  23853. }
  23854. };
  23855. PopupEditorWrapper.prototype.focusOut = function () {
  23856. if (this.cellEditor.focusOut) {
  23857. this.cellEditor.focusOut();
  23858. }
  23859. };
  23860. PopupEditorWrapper.DOM_KEY_POPUP_EDITOR_WRAPPER = 'popupEditorWrapper';
  23861. __decorate([
  23862. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  23863. ], PopupEditorWrapper.prototype, "gridOptionsWrapper", void 0);
  23864. return PopupEditorWrapper;
  23865. }(_widgets_popupComponent__WEBPACK_IMPORTED_MODULE_0__["PopupComponent"]));
  23866. /***/ }),
  23867. /* 106 */
  23868. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  23869. "use strict";
  23870. __webpack_require__.r(__webpack_exports__);
  23871. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DndSourceComp", function() { return DndSourceComp; });
  23872. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56);
  23873. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  23874. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
  23875. /**
  23876. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  23877. * @version v23.2.1
  23878. * @link http://www.ag-grid.com/
  23879. * @license MIT
  23880. */
  23881. var __extends = (undefined && undefined.__extends) || (function () {
  23882. var extendStatics = function (d, b) {
  23883. extendStatics = Object.setPrototypeOf ||
  23884. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  23885. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  23886. return extendStatics(d, b);
  23887. };
  23888. return function (d, b) {
  23889. extendStatics(d, b);
  23890. function __() { this.constructor = d; }
  23891. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  23892. };
  23893. })();
  23894. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  23895. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  23896. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  23897. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  23898. return c > 3 && r && Object.defineProperty(target, key, r), r;
  23899. };
  23900. var DndSourceComp = /** @class */ (function (_super) {
  23901. __extends(DndSourceComp, _super);
  23902. function DndSourceComp(rowNode, column, cellValue, beans, eCell) {
  23903. var _this = _super.call(this, "<div class=\"ag-drag-handle ag-row-drag\" draggable=\"true\"></div>") || this;
  23904. _this.rowNode = rowNode;
  23905. _this.column = column;
  23906. _this.cellValue = cellValue;
  23907. _this.beans = beans;
  23908. _this.eCell = eCell;
  23909. return _this;
  23910. }
  23911. DndSourceComp.prototype.postConstruct = function () {
  23912. var eGui = this.getGui();
  23913. eGui.appendChild(_utils__WEBPACK_IMPORTED_MODULE_2__["_"].createIconNoSpan('rowDrag', this.beans.gridOptionsWrapper, null));
  23914. this.addDragSource();
  23915. this.checkVisibility();
  23916. };
  23917. DndSourceComp.prototype.addDragSource = function () {
  23918. this.addGuiEventListener('dragstart', this.onDragStart.bind(this));
  23919. };
  23920. DndSourceComp.prototype.onDragStart = function (dragEvent) {
  23921. var _this = this;
  23922. var providedOnRowDrag = this.column.getColDef().dndSourceOnRowDrag;
  23923. var isIE = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].isBrowserIE();
  23924. if (!isIE) {
  23925. dragEvent.dataTransfer.setDragImage(this.eCell, 0, 0);
  23926. }
  23927. // default behaviour is to convert data to json and set into drag component
  23928. var defaultOnRowDrag = function () {
  23929. try {
  23930. var jsonData = JSON.stringify(_this.rowNode.data);
  23931. if (isIE) {
  23932. dragEvent.dataTransfer.setData('text', jsonData);
  23933. }
  23934. else {
  23935. dragEvent.dataTransfer.setData('application/json', jsonData);
  23936. dragEvent.dataTransfer.setData('text/plain', jsonData);
  23937. }
  23938. }
  23939. catch (e) {
  23940. // if we cannot convert the data to json, then we do not set the type
  23941. }
  23942. };
  23943. if (providedOnRowDrag) {
  23944. providedOnRowDrag({ rowNode: this.rowNode, dragEvent: dragEvent });
  23945. }
  23946. else {
  23947. defaultOnRowDrag();
  23948. }
  23949. };
  23950. DndSourceComp.prototype.checkVisibility = function () {
  23951. var visible = this.column.isDndSource(this.rowNode);
  23952. this.setDisplayed(visible);
  23953. };
  23954. __decorate([
  23955. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  23956. ], DndSourceComp.prototype, "postConstruct", null);
  23957. return DndSourceComp;
  23958. }(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"]));
  23959. /***/ }),
  23960. /* 107 */
  23961. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  23962. "use strict";
  23963. __webpack_require__.r(__webpack_exports__);
  23964. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TooltipFeature", function() { return TooltipFeature; });
  23965. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  23966. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  23967. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
  23968. /**
  23969. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  23970. * @version v23.2.1
  23971. * @link http://www.ag-grid.com/
  23972. * @license MIT
  23973. */
  23974. var __extends = (undefined && undefined.__extends) || (function () {
  23975. var extendStatics = function (d, b) {
  23976. extendStatics = Object.setPrototypeOf ||
  23977. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  23978. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  23979. return extendStatics(d, b);
  23980. };
  23981. return function (d, b) {
  23982. extendStatics(d, b);
  23983. function __() { this.constructor = d; }
  23984. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  23985. };
  23986. })();
  23987. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  23988. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  23989. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  23990. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  23991. return c > 3 && r && Object.defineProperty(target, key, r), r;
  23992. };
  23993. var TooltipStates;
  23994. (function (TooltipStates) {
  23995. TooltipStates[TooltipStates["NOTHING"] = 0] = "NOTHING";
  23996. TooltipStates[TooltipStates["WAITING_TO_SHOW"] = 1] = "WAITING_TO_SHOW";
  23997. TooltipStates[TooltipStates["SHOWING"] = 2] = "SHOWING";
  23998. })(TooltipStates || (TooltipStates = {}));
  23999. var TooltipFeature = /** @class */ (function (_super) {
  24000. __extends(TooltipFeature, _super);
  24001. function TooltipFeature(parentComp, location) {
  24002. var _this = _super.call(this) || this;
  24003. _this.DEFAULT_HIDE_TOOLTIP_TIMEOUT = 10000;
  24004. _this.SHOW_QUICK_TOOLTIP_DIFF = 1000;
  24005. _this.FADE_OUT_TOOLTIP_TIMEOUT = 1000;
  24006. _this.state = TooltipStates.NOTHING;
  24007. // when showing the tooltip, we need to make sure it's the most recent instance we request, as due to
  24008. // async we could request two tooltips before the first instance returns, in which case we should
  24009. // disregard the second instance.
  24010. _this.tooltipInstanceCount = 0;
  24011. _this.tooltipMouseTrack = false;
  24012. _this.parentComp = parentComp;
  24013. _this.location = location;
  24014. return _this;
  24015. }
  24016. TooltipFeature.prototype.postConstruct = function () {
  24017. this.tooltipShowDelay = this.gridOptionsWrapper.getTooltipShowDelay() || 2000;
  24018. this.tooltipMouseTrack = this.gridOptionsWrapper.isTooltipMouseTrack();
  24019. var el = this.parentComp.getGui();
  24020. this.addManagedListener(el, 'mouseenter', this.onMouseEnter.bind(this));
  24021. this.addManagedListener(el, 'mouseleave', this.onMouseLeave.bind(this));
  24022. this.addManagedListener(el, 'mousemove', this.onMouseMove.bind(this));
  24023. this.addManagedListener(el, 'mousedown', this.onMouseDown.bind(this));
  24024. };
  24025. TooltipFeature.prototype.destroy = function () {
  24026. // if this component gets destroyed while tooltip is showing, need to make sure
  24027. // we don't end with no mouseLeave event resulting in zombie tooltip
  24028. this.setToDoNothing();
  24029. _super.prototype.destroy.call(this);
  24030. };
  24031. TooltipFeature.prototype.onMouseEnter = function (e) {
  24032. // if another tooltip was hidden very recently, we only wait 200ms to show, not the normal waiting time
  24033. var delay = this.isLastTooltipHiddenRecently() ? 200 : this.tooltipShowDelay;
  24034. this.showTooltipTimeoutId = window.setTimeout(this.showTooltip.bind(this), delay);
  24035. this.lastMouseEvent = e;
  24036. this.state = TooltipStates.WAITING_TO_SHOW;
  24037. };
  24038. TooltipFeature.prototype.onMouseLeave = function () {
  24039. this.setToDoNothing();
  24040. };
  24041. TooltipFeature.prototype.setToDoNothing = function () {
  24042. if (this.state === TooltipStates.SHOWING) {
  24043. this.hideTooltip();
  24044. }
  24045. this.clearTimeouts();
  24046. this.state = TooltipStates.NOTHING;
  24047. };
  24048. TooltipFeature.prototype.onMouseMove = function (e) {
  24049. // there is a delay from the time we mouseOver a component and the time the
  24050. // tooltip is displayed, so we need to track mousemove to be able to correctly
  24051. // position the tooltip when showTooltip is called.
  24052. this.lastMouseEvent = e;
  24053. if (this.tooltipMouseTrack &&
  24054. this.state === TooltipStates.SHOWING &&
  24055. this.tooltipComp) {
  24056. this.positionTooltipUnderLastMouseEvent();
  24057. }
  24058. };
  24059. TooltipFeature.prototype.onMouseDown = function () {
  24060. this.setToDoNothing();
  24061. };
  24062. TooltipFeature.prototype.hideTooltip = function () {
  24063. // check if comp exists - due to async, although we asked for
  24064. // one, the instance may not be back yet
  24065. if (this.tooltipComp) {
  24066. this.destroyTooltipComp();
  24067. TooltipFeature.lastTooltipHideTime = new Date().getTime();
  24068. }
  24069. this.state = TooltipStates.NOTHING;
  24070. };
  24071. TooltipFeature.prototype.destroyTooltipComp = function () {
  24072. var _this = this;
  24073. // add class to fade out the tooltip
  24074. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(this.tooltipComp.getGui(), 'ag-tooltip-hiding');
  24075. // make local copies of these variables, as we use them in the async function below,
  24076. // and we clear then to 'undefined' later, so need to take a copy before they are undefined.
  24077. var tooltipPopupDestroyFunc = this.tooltipPopupDestroyFunc;
  24078. var tooltipComp = this.tooltipComp;
  24079. window.setTimeout(function () {
  24080. tooltipPopupDestroyFunc();
  24081. _this.getContext().destroyBean(tooltipComp);
  24082. }, this.FADE_OUT_TOOLTIP_TIMEOUT);
  24083. this.tooltipPopupDestroyFunc = undefined;
  24084. this.tooltipComp = undefined;
  24085. };
  24086. TooltipFeature.prototype.isLastTooltipHiddenRecently = function () {
  24087. // return true if <1000ms since last time we hid a tooltip
  24088. var now = new Date().getTime();
  24089. var then = TooltipFeature.lastTooltipHideTime;
  24090. return (now - then) < this.SHOW_QUICK_TOOLTIP_DIFF;
  24091. };
  24092. TooltipFeature.prototype.showTooltip = function () {
  24093. var tooltipText = this.parentComp.getTooltipText();
  24094. if (!tooltipText) {
  24095. this.setToDoNothing();
  24096. return;
  24097. }
  24098. this.state = TooltipStates.SHOWING;
  24099. this.tooltipInstanceCount++;
  24100. var params = {
  24101. location: this.location,
  24102. api: this.gridApi,
  24103. columnApi: this.columnApi,
  24104. colDef: this.parentComp.getComponentHolder(),
  24105. column: this.parentComp.getColumn,
  24106. context: this.gridOptionsWrapper.getContext(),
  24107. rowIndex: this.parentComp.getCellPosition && this.parentComp.getCellPosition().rowIndex,
  24108. value: tooltipText
  24109. };
  24110. // we pass in tooltipInstanceCount so the callback knows what the count was when
  24111. // we requested the tooltip, so if another tooltip was requested in the mean time
  24112. // we disregard it
  24113. var callback = this.newTooltipComponentCallback.bind(this, this.tooltipInstanceCount);
  24114. this.userComponentFactory.newTooltipComponent(params).then(callback);
  24115. };
  24116. TooltipFeature.prototype.newTooltipComponentCallback = function (tooltipInstanceCopy, tooltipComp) {
  24117. var compNoLongerNeeded = this.state !== TooltipStates.SHOWING || this.tooltipInstanceCount !== tooltipInstanceCopy;
  24118. if (compNoLongerNeeded) {
  24119. this.getContext().destroyBean(tooltipComp);
  24120. return;
  24121. }
  24122. var eGui = tooltipComp.getGui();
  24123. this.tooltipComp = tooltipComp;
  24124. if (!_utils__WEBPACK_IMPORTED_MODULE_2__["_"].containsClass(eGui, 'ag-tooltip')) {
  24125. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(eGui, 'ag-tooltip-custom');
  24126. }
  24127. this.tooltipPopupDestroyFunc = this.popupService.addPopup(false, eGui, false);
  24128. this.positionTooltipUnderLastMouseEvent();
  24129. this.hideTooltipTimeoutId = window.setTimeout(this.hideTooltip.bind(this), this.DEFAULT_HIDE_TOOLTIP_TIMEOUT);
  24130. };
  24131. TooltipFeature.prototype.positionTooltipUnderLastMouseEvent = function () {
  24132. this.popupService.positionPopupUnderMouseEvent({
  24133. type: 'tooltip',
  24134. mouseEvent: this.lastMouseEvent,
  24135. ePopup: this.tooltipComp.getGui(),
  24136. nudgeY: 18
  24137. });
  24138. };
  24139. TooltipFeature.prototype.clearTimeouts = function () {
  24140. if (this.showTooltipTimeoutId) {
  24141. window.clearTimeout(this.showTooltipTimeoutId);
  24142. this.showTooltipTimeoutId = undefined;
  24143. }
  24144. if (this.hideTooltipTimeoutId) {
  24145. window.clearTimeout(this.hideTooltipTimeoutId);
  24146. this.hideTooltipTimeoutId = undefined;
  24147. }
  24148. };
  24149. __decorate([
  24150. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('popupService')
  24151. ], TooltipFeature.prototype, "popupService", void 0);
  24152. __decorate([
  24153. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('userComponentFactory')
  24154. ], TooltipFeature.prototype, "userComponentFactory", void 0);
  24155. __decorate([
  24156. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi')
  24157. ], TooltipFeature.prototype, "columnApi", void 0);
  24158. __decorate([
  24159. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi')
  24160. ], TooltipFeature.prototype, "gridApi", void 0);
  24161. __decorate([
  24162. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  24163. ], TooltipFeature.prototype, "gridOptionsWrapper", void 0);
  24164. __decorate([
  24165. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  24166. ], TooltipFeature.prototype, "postConstruct", null);
  24167. return TooltipFeature;
  24168. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  24169. /***/ }),
  24170. /* 108 */
  24171. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  24172. "use strict";
  24173. __webpack_require__.r(__webpack_exports__);
  24174. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderRootComp", function() { return HeaderRootComp; });
  24175. /* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(50);
  24176. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  24177. /* harmony import */ var _headerContainer__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(109);
  24178. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(43);
  24179. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(57);
  24180. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(25);
  24181. /* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(12);
  24182. /* harmony import */ var _widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(117);
  24183. /* harmony import */ var _header_headerNavigationService__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(124);
  24184. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(7);
  24185. /**
  24186. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  24187. * @version v23.2.1
  24188. * @link http://www.ag-grid.com/
  24189. * @license MIT
  24190. */
  24191. var __extends = (undefined && undefined.__extends) || (function () {
  24192. var extendStatics = function (d, b) {
  24193. extendStatics = Object.setPrototypeOf ||
  24194. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  24195. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  24196. return extendStatics(d, b);
  24197. };
  24198. return function (d, b) {
  24199. extendStatics(d, b);
  24200. function __() { this.constructor = d; }
  24201. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  24202. };
  24203. })();
  24204. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  24205. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  24206. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  24207. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  24208. return c > 3 && r && Object.defineProperty(target, key, r), r;
  24209. };
  24210. var HeaderRootComp = /** @class */ (function (_super) {
  24211. __extends(HeaderRootComp, _super);
  24212. function HeaderRootComp() {
  24213. var _this = _super.call(this, HeaderRootComp.TEMPLATE) || this;
  24214. _this.headerContainers = new Map();
  24215. return _this;
  24216. }
  24217. HeaderRootComp.prototype.postConstruct = function () {
  24218. var _this = this;
  24219. _super.prototype.postConstruct.call(this);
  24220. this.printLayout = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_5__["Constants"].DOM_LAYOUT_PRINT;
  24221. this.gridApi.registerHeaderRootComp(this);
  24222. this.autoWidthCalculator.registerHeaderRootComp(this);
  24223. this.registerHeaderContainer(new _headerContainer__WEBPACK_IMPORTED_MODULE_2__["HeaderContainer"](this.eHeaderContainer, this.eHeaderViewport, null), 'center');
  24224. this.registerHeaderContainer(new _headerContainer__WEBPACK_IMPORTED_MODULE_2__["HeaderContainer"](this.ePinnedLeftHeader, null, _constants__WEBPACK_IMPORTED_MODULE_5__["Constants"].PINNED_LEFT), 'left');
  24225. this.registerHeaderContainer(new _headerContainer__WEBPACK_IMPORTED_MODULE_2__["HeaderContainer"](this.ePinnedRightHeader, null, _constants__WEBPACK_IMPORTED_MODULE_5__["Constants"].PINNED_RIGHT), 'right');
  24226. this.headerContainers.forEach(function (container) { return _this.createManagedBean(container); });
  24227. this.headerNavigationService.registerHeaderRoot(this);
  24228. // shotgun way to get labels to change, eg from sum(amount) to avg(amount)
  24229. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_VALUE_CHANGED, this.refreshHeader.bind(this));
  24230. this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_DOM_LAYOUT, this.onDomLayoutChanged.bind(this));
  24231. // for setting ag-pivot-on / ag-pivot-off CSS classes
  24232. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_PIVOT_MODE_CHANGED, this.onPivotModeChanged.bind(this));
  24233. this.onPivotModeChanged();
  24234. this.addPreventHeaderScroll();
  24235. if (this.columnController.isReady()) {
  24236. this.refreshHeader();
  24237. }
  24238. };
  24239. HeaderRootComp.prototype.registerGridComp = function (gridPanel) {
  24240. this.gridPanel = gridPanel;
  24241. this.headerContainers.forEach(function (c) { return c.setupDragAndDrop(gridPanel); });
  24242. };
  24243. HeaderRootComp.prototype.registerHeaderContainer = function (headerContainer, type) {
  24244. this.headerContainers.set(type, headerContainer);
  24245. };
  24246. HeaderRootComp.prototype.onTabKeyDown = function (e) {
  24247. var isRtl = this.gridOptionsWrapper.isEnableRtl();
  24248. var direction = e.shiftKey !== isRtl
  24249. ? _header_headerNavigationService__WEBPACK_IMPORTED_MODULE_8__["HeaderNavigationDirection"].LEFT
  24250. : _header_headerNavigationService__WEBPACK_IMPORTED_MODULE_8__["HeaderNavigationDirection"].RIGHT;
  24251. if (this.headerNavigationService.navigateHorizontally(direction, true) ||
  24252. this.focusController.focusNextGridCoreContainer(e.shiftKey)) {
  24253. e.preventDefault();
  24254. }
  24255. };
  24256. HeaderRootComp.prototype.handleKeyDown = function (e) {
  24257. var direction;
  24258. switch (e.keyCode) {
  24259. case _constants__WEBPACK_IMPORTED_MODULE_5__["Constants"].KEY_LEFT:
  24260. direction = _header_headerNavigationService__WEBPACK_IMPORTED_MODULE_8__["HeaderNavigationDirection"].LEFT;
  24261. case _constants__WEBPACK_IMPORTED_MODULE_5__["Constants"].KEY_RIGHT:
  24262. if (!_utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(direction)) {
  24263. direction = _header_headerNavigationService__WEBPACK_IMPORTED_MODULE_8__["HeaderNavigationDirection"].RIGHT;
  24264. }
  24265. this.headerNavigationService.navigateHorizontally(direction);
  24266. break;
  24267. case _constants__WEBPACK_IMPORTED_MODULE_5__["Constants"].KEY_UP:
  24268. direction = _header_headerNavigationService__WEBPACK_IMPORTED_MODULE_8__["HeaderNavigationDirection"].UP;
  24269. case _constants__WEBPACK_IMPORTED_MODULE_5__["Constants"].KEY_DOWN:
  24270. if (!_utils__WEBPACK_IMPORTED_MODULE_9__["_"].exists(direction)) {
  24271. direction = _header_headerNavigationService__WEBPACK_IMPORTED_MODULE_8__["HeaderNavigationDirection"].DOWN;
  24272. }
  24273. if (this.headerNavigationService.navigateVertically(direction)) {
  24274. e.preventDefault();
  24275. }
  24276. break;
  24277. default:
  24278. return;
  24279. }
  24280. };
  24281. HeaderRootComp.prototype.onFocusOut = function (e) {
  24282. var relatedTarget = e.relatedTarget;
  24283. var eGui = this.getGui();
  24284. if (!relatedTarget && eGui.contains(document.activeElement)) {
  24285. return;
  24286. }
  24287. if (!eGui.contains(relatedTarget)) {
  24288. this.focusController.clearFocusedHeader();
  24289. }
  24290. };
  24291. HeaderRootComp.prototype.onDomLayoutChanged = function () {
  24292. var newValue = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_5__["Constants"].DOM_LAYOUT_PRINT;
  24293. if (this.printLayout !== newValue) {
  24294. this.printLayout = newValue;
  24295. this.refreshHeader();
  24296. }
  24297. };
  24298. HeaderRootComp.prototype.setHorizontalScroll = function (offset) {
  24299. this.eHeaderContainer.style.transform = "translateX(" + offset + "px)";
  24300. };
  24301. HeaderRootComp.prototype.forEachHeaderElement = function (callback) {
  24302. this.headerContainers.forEach(function (childContainer) { return childContainer.forEachHeaderElement(callback); });
  24303. };
  24304. HeaderRootComp.prototype.refreshHeader = function () {
  24305. this.headerContainers.forEach(function (container) { return container.refresh(); });
  24306. };
  24307. HeaderRootComp.prototype.onPivotModeChanged = function () {
  24308. var pivotMode = this.columnController.isPivotMode();
  24309. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["addOrRemoveCssClass"])(this.getGui(), 'ag-pivot-on', pivotMode);
  24310. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["addOrRemoveCssClass"])(this.getGui(), 'ag-pivot-off', !pivotMode);
  24311. };
  24312. HeaderRootComp.prototype.setHeight = function (height) {
  24313. // one extra pixel is needed here to account for the
  24314. // height of the border
  24315. var px = height + 1 + "px";
  24316. this.getGui().style.height = px;
  24317. this.getGui().style.minHeight = px;
  24318. };
  24319. // if the user is in floating filter and hits tab a few times, the header can
  24320. // end up scrolling to show items off the screen, leaving the grid and header
  24321. // and the grid columns no longer in sync.
  24322. HeaderRootComp.prototype.addPreventHeaderScroll = function () {
  24323. var _this = this;
  24324. this.addManagedListener(this.eHeaderViewport, 'scroll', function () {
  24325. // if the header scrolls, the header will be out of sync. so we reset the
  24326. // header scroll, and then scroll the body, which will in turn set the offset
  24327. // on the header, giving the impression that the header scrolled as expected.
  24328. var scrollLeft = _this.eHeaderViewport.scrollLeft;
  24329. if (scrollLeft !== 0) {
  24330. _this.gridPanel.scrollHorizontally(scrollLeft);
  24331. _this.eHeaderViewport.scrollLeft = 0;
  24332. }
  24333. });
  24334. };
  24335. HeaderRootComp.prototype.getHeaderContainers = function () {
  24336. return this.headerContainers;
  24337. };
  24338. HeaderRootComp.prototype.setHeaderContainerWidth = function (width) {
  24339. this.eHeaderContainer.style.width = width + "px";
  24340. };
  24341. HeaderRootComp.prototype.setLeftVisible = function (visible) {
  24342. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["setDisplayed"])(this.ePinnedLeftHeader, visible);
  24343. };
  24344. HeaderRootComp.prototype.setRightVisible = function (visible) {
  24345. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_6__["setDisplayed"])(this.ePinnedRightHeader, visible);
  24346. };
  24347. HeaderRootComp.TEMPLATE = "<div class=\"ag-header\" role=\"presentation\">\n <div class=\"ag-pinned-left-header\" ref=\"ePinnedLeftHeader\" role=\"presentation\"></div>\n <div class=\"ag-header-viewport\" ref=\"eHeaderViewport\" role=\"presentation\">\n <div class=\"ag-header-container\" ref=\"eHeaderContainer\" role=\"rowgroup\"></div>\n </div>\n <div class=\"ag-pinned-right-header\" ref=\"ePinnedRightHeader\" role=\"presentation\"></div>\n </div>";
  24348. __decorate([
  24349. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('ePinnedLeftHeader')
  24350. ], HeaderRootComp.prototype, "ePinnedLeftHeader", void 0);
  24351. __decorate([
  24352. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('ePinnedRightHeader')
  24353. ], HeaderRootComp.prototype, "ePinnedRightHeader", void 0);
  24354. __decorate([
  24355. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eHeaderContainer')
  24356. ], HeaderRootComp.prototype, "eHeaderContainer", void 0);
  24357. __decorate([
  24358. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_4__["RefSelector"])('eHeaderViewport')
  24359. ], HeaderRootComp.prototype, "eHeaderViewport", void 0);
  24360. __decorate([
  24361. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  24362. ], HeaderRootComp.prototype, "gridOptionsWrapper", void 0);
  24363. __decorate([
  24364. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController')
  24365. ], HeaderRootComp.prototype, "columnController", void 0);
  24366. __decorate([
  24367. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridApi')
  24368. ], HeaderRootComp.prototype, "gridApi", void 0);
  24369. __decorate([
  24370. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('autoWidthCalculator')
  24371. ], HeaderRootComp.prototype, "autoWidthCalculator", void 0);
  24372. __decorate([
  24373. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('headerNavigationService')
  24374. ], HeaderRootComp.prototype, "headerNavigationService", void 0);
  24375. return HeaderRootComp;
  24376. }(_widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_7__["ManagedFocusComponent"]));
  24377. /***/ }),
  24378. /* 109 */
  24379. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  24380. "use strict";
  24381. __webpack_require__.r(__webpack_exports__);
  24382. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderContainer", function() { return HeaderContainer; });
  24383. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  24384. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43);
  24385. /* harmony import */ var _headerRowComp__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(110);
  24386. /* harmony import */ var _bodyDropTarget__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(121);
  24387. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(25);
  24388. /* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(12);
  24389. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(41);
  24390. /**
  24391. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  24392. * @version v23.2.1
  24393. * @link http://www.ag-grid.com/
  24394. * @license MIT
  24395. */
  24396. var __extends = (undefined && undefined.__extends) || (function () {
  24397. var extendStatics = function (d, b) {
  24398. extendStatics = Object.setPrototypeOf ||
  24399. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  24400. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  24401. return extendStatics(d, b);
  24402. };
  24403. return function (d, b) {
  24404. extendStatics(d, b);
  24405. function __() { this.constructor = d; }
  24406. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  24407. };
  24408. })();
  24409. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  24410. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  24411. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  24412. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  24413. return c > 3 && r && Object.defineProperty(target, key, r), r;
  24414. };
  24415. var HeaderContainer = /** @class */ (function (_super) {
  24416. __extends(HeaderContainer, _super);
  24417. function HeaderContainer(eContainer, eViewport, pinned) {
  24418. var _this = _super.call(this) || this;
  24419. _this.headerRowComps = [];
  24420. _this.eContainer = eContainer;
  24421. _this.pinned = pinned;
  24422. _this.eViewport = eViewport;
  24423. return _this;
  24424. }
  24425. HeaderContainer.prototype.forEachHeaderElement = function (callback) {
  24426. this.headerRowComps.forEach(function (headerRowComp) { return headerRowComp.forEachHeaderElement(callback); });
  24427. };
  24428. HeaderContainer.prototype.init = function () {
  24429. this.scrollWidth = this.gridOptionsWrapper.getScrollbarWidth();
  24430. // if value changes, then if not pivoting, we at least need to change the label eg from sum() to avg(),
  24431. // if pivoting, then the columns have changed
  24432. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_VALUE_CHANGED, this.onColumnValueChanged.bind(this)),
  24433. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, this.onColumnRowGroupChanged.bind(this)),
  24434. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_GRID_COLUMNS_CHANGED, this.onGridColumnsChanged.bind(this)),
  24435. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_SCROLL_VISIBILITY_CHANGED, this.onScrollVisibilityChanged.bind(this)),
  24436. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_RESIZED, this.onColumnResized.bind(this)),
  24437. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this));
  24438. };
  24439. // if row group changes, that means we may need to add aggFuncs to the column headers,
  24440. // if the grid goes from no aggregation (ie no grouping) to grouping
  24441. HeaderContainer.prototype.onColumnRowGroupChanged = function () {
  24442. this.onGridColumnsChanged();
  24443. };
  24444. // if the agg func of a column changes, then we may need to update the agg func in columns header
  24445. HeaderContainer.prototype.onColumnValueChanged = function () {
  24446. this.onGridColumnsChanged();
  24447. };
  24448. HeaderContainer.prototype.onColumnResized = function () {
  24449. this.setWidthOfPinnedContainer();
  24450. };
  24451. HeaderContainer.prototype.onDisplayedColumnsChanged = function () {
  24452. this.setWidthOfPinnedContainer();
  24453. };
  24454. HeaderContainer.prototype.onScrollVisibilityChanged = function () {
  24455. this.setWidthOfPinnedContainer();
  24456. };
  24457. HeaderContainer.prototype.setWidthOfPinnedContainer = function () {
  24458. var pinningLeft = this.pinned === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_LEFT;
  24459. var pinningRight = this.pinned === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_RIGHT;
  24460. var controller = this.columnController;
  24461. var isRtl = this.gridOptionsWrapper.isEnableRtl();
  24462. if (pinningLeft || pinningRight) {
  24463. // size to fit all columns
  24464. var width = controller[pinningLeft ? 'getPinnedLeftContainerWidth' : 'getPinnedRightContainerWidth']();
  24465. // if there is a scroll showing (and taking up space, so Windows, and not iOS)
  24466. // in the body, then we add extra space to keep header aligned with the body,
  24467. // as body width fits the cols and the scrollbar
  24468. var addPaddingForScrollbar = this.scrollVisibleService.isVerticalScrollShowing() && ((isRtl && pinningLeft) || (!isRtl && pinningRight));
  24469. if (addPaddingForScrollbar) {
  24470. width += this.scrollWidth;
  24471. }
  24472. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["setFixedWidth"])(this.eContainer, width);
  24473. }
  24474. };
  24475. HeaderContainer.prototype.getRowComps = function () {
  24476. return this.headerRowComps;
  24477. };
  24478. // grid cols have changed - this also means the number of rows in the header can have
  24479. // changed. so we remove all the old rows and insert new ones for a complete refresh
  24480. HeaderContainer.prototype.onGridColumnsChanged = function () {
  24481. this.removeAndCreateAllRowComps();
  24482. };
  24483. HeaderContainer.prototype.removeAndCreateAllRowComps = function () {
  24484. this.removeHeaderRowComps();
  24485. this.createHeaderRowComps();
  24486. };
  24487. // we expose this for gridOptions.api.refreshHeader() to call
  24488. HeaderContainer.prototype.refresh = function () {
  24489. this.removeAndCreateAllRowComps();
  24490. };
  24491. HeaderContainer.prototype.setupDragAndDrop = function (gridComp) {
  24492. var dropContainer = this.eViewport ? this.eViewport : this.eContainer;
  24493. var bodyDropTarget = new _bodyDropTarget__WEBPACK_IMPORTED_MODULE_3__["BodyDropTarget"](this.pinned, dropContainer);
  24494. this.createManagedBean(bodyDropTarget);
  24495. bodyDropTarget.registerGridComp(gridComp);
  24496. };
  24497. HeaderContainer.prototype.removeHeaderRowComps = function () {
  24498. var _this = this;
  24499. this.headerRowComps.forEach(function (headerRowComp) { return _this.destroyBean(headerRowComp); });
  24500. this.headerRowComps.length = 0;
  24501. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_5__["clearElement"])(this.eContainer);
  24502. };
  24503. HeaderContainer.prototype.createHeaderRowComps = function () {
  24504. // if we are displaying header groups, then we have many rows here.
  24505. // go through each row of the header, one by one.
  24506. var rowCount = this.columnController.getHeaderRowCount();
  24507. for (var dept = 0; dept < rowCount; dept++) {
  24508. var groupRow = dept !== (rowCount - 1);
  24509. var type = groupRow ? _headerRowComp__WEBPACK_IMPORTED_MODULE_2__["HeaderRowType"].COLUMN_GROUP : _headerRowComp__WEBPACK_IMPORTED_MODULE_2__["HeaderRowType"].COLUMN;
  24510. var headerRowComp = new _headerRowComp__WEBPACK_IMPORTED_MODULE_2__["HeaderRowComp"](dept, type, this.pinned, this.dropTarget);
  24511. this.createBean(headerRowComp);
  24512. this.headerRowComps.push(headerRowComp);
  24513. headerRowComp.setRowIndex(this.headerRowComps.length - 1);
  24514. this.eContainer.appendChild(headerRowComp.getGui());
  24515. }
  24516. if (!this.columnController.isPivotMode() && this.columnController.hasFloatingFilters()) {
  24517. var headerRowComp = new _headerRowComp__WEBPACK_IMPORTED_MODULE_2__["HeaderRowComp"](rowCount, _headerRowComp__WEBPACK_IMPORTED_MODULE_2__["HeaderRowType"].FLOATING_FILTER, this.pinned, this.dropTarget);
  24518. this.createBean(headerRowComp);
  24519. this.headerRowComps.push(headerRowComp);
  24520. headerRowComp.setRowIndex(this.headerRowComps.length - 1);
  24521. this.eContainer.appendChild(headerRowComp.getGui());
  24522. }
  24523. };
  24524. __decorate([
  24525. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  24526. ], HeaderContainer.prototype, "gridOptionsWrapper", void 0);
  24527. __decorate([
  24528. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController')
  24529. ], HeaderContainer.prototype, "columnController", void 0);
  24530. __decorate([
  24531. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('scrollVisibleService')
  24532. ], HeaderContainer.prototype, "scrollVisibleService", void 0);
  24533. __decorate([
  24534. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  24535. ], HeaderContainer.prototype, "init", null);
  24536. __decorate([
  24537. _context_context__WEBPACK_IMPORTED_MODULE_0__["PreDestroy"]
  24538. ], HeaderContainer.prototype, "removeHeaderRowComps", null);
  24539. return HeaderContainer;
  24540. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_6__["BeanStub"]));
  24541. /***/ }),
  24542. /* 110 */
  24543. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  24544. "use strict";
  24545. __webpack_require__.r(__webpack_exports__);
  24546. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderRowType", function() { return HeaderRowType; });
  24547. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderRowComp", function() { return HeaderRowComp; });
  24548. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56);
  24549. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  24550. /* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(50);
  24551. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(43);
  24552. /* harmony import */ var _header_headerWrapperComp__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(111);
  24553. /* harmony import */ var _headerGroup_headerGroupWrapperComp__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(118);
  24554. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(25);
  24555. /* harmony import */ var _filter_floating_floatingFilterWrapper__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(119);
  24556. /* harmony import */ var _utils_browser__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(13);
  24557. /* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(14);
  24558. /* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(17);
  24559. /* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(12);
  24560. /**
  24561. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  24562. * @version v23.2.1
  24563. * @link http://www.ag-grid.com/
  24564. * @license MIT
  24565. */
  24566. var __extends = (undefined && undefined.__extends) || (function () {
  24567. var extendStatics = function (d, b) {
  24568. extendStatics = Object.setPrototypeOf ||
  24569. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  24570. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  24571. return extendStatics(d, b);
  24572. };
  24573. return function (d, b) {
  24574. extendStatics(d, b);
  24575. function __() { this.constructor = d; }
  24576. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  24577. };
  24578. })();
  24579. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  24580. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  24581. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  24582. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  24583. return c > 3 && r && Object.defineProperty(target, key, r), r;
  24584. };
  24585. var HeaderRowType;
  24586. (function (HeaderRowType) {
  24587. HeaderRowType[HeaderRowType["COLUMN_GROUP"] = 0] = "COLUMN_GROUP";
  24588. HeaderRowType[HeaderRowType["COLUMN"] = 1] = "COLUMN";
  24589. HeaderRowType[HeaderRowType["FLOATING_FILTER"] = 2] = "FLOATING_FILTER";
  24590. })(HeaderRowType || (HeaderRowType = {}));
  24591. var HeaderRowComp = /** @class */ (function (_super) {
  24592. __extends(HeaderRowComp, _super);
  24593. function HeaderRowComp(dept, type, pinned, dropTarget) {
  24594. var _this = _super.call(this, /* html */ "<div class=\"ag-header-row\" role=\"row\" />") || this;
  24595. _this.headerComps = {};
  24596. _this.dept = dept;
  24597. _this.type = type;
  24598. _this.pinned = pinned;
  24599. _this.dropTarget = dropTarget;
  24600. var niceClassName = HeaderRowType[type].toLowerCase().replace(/_/g, '-');
  24601. _this.addCssClass("ag-header-row-" + niceClassName);
  24602. if (Object(_utils_browser__WEBPACK_IMPORTED_MODULE_8__["isBrowserSafari"])()) {
  24603. // fix for a Safari rendering bug that caused the header to flicker above chart panels
  24604. // as you move the mouse over the header
  24605. _this.getGui().style.transform = 'translateZ(0)';
  24606. }
  24607. return _this;
  24608. }
  24609. HeaderRowComp.prototype.forEachHeaderElement = function (callback) {
  24610. var _this = this;
  24611. Object.keys(this.headerComps).forEach(function (key) {
  24612. callback(_this.headerComps[key]);
  24613. });
  24614. };
  24615. HeaderRowComp.prototype.setRowIndex = function (idx) {
  24616. this.rowIndex = idx;
  24617. this.getGui().setAttribute('aria-rowindex', (idx + 1).toString());
  24618. };
  24619. HeaderRowComp.prototype.getRowIndex = function () {
  24620. return this.rowIndex;
  24621. };
  24622. HeaderRowComp.prototype.getType = function () {
  24623. return this.type;
  24624. };
  24625. HeaderRowComp.prototype.destroyAllChildComponents = function () {
  24626. var idsOfAllChildren = Object.keys(this.headerComps);
  24627. this.destroyChildComponents(idsOfAllChildren);
  24628. };
  24629. HeaderRowComp.prototype.destroyChildComponents = function (idsToDestroy, keepFocused) {
  24630. var _this = this;
  24631. idsToDestroy.forEach(function (id) {
  24632. var childHeaderWrapper = _this.headerComps[id];
  24633. if (keepFocused &&
  24634. !childHeaderWrapper.getColumn().isMoving() &&
  24635. _this.focusController.isHeaderWrapperFocused(childHeaderWrapper)) {
  24636. return;
  24637. }
  24638. _this.getGui().removeChild(childHeaderWrapper.getGui());
  24639. _this.destroyBean(childHeaderWrapper);
  24640. delete _this.headerComps[id];
  24641. });
  24642. };
  24643. HeaderRowComp.prototype.onRowHeightChanged = function () {
  24644. var headerRowCount = this.columnController.getHeaderRowCount();
  24645. var sizes = [];
  24646. var numberOfFloating = 0;
  24647. var groupHeight;
  24648. var headerHeight;
  24649. if (this.columnController.isPivotMode()) {
  24650. groupHeight = this.gridOptionsWrapper.getPivotGroupHeaderHeight();
  24651. headerHeight = this.gridOptionsWrapper.getPivotHeaderHeight();
  24652. }
  24653. else {
  24654. if (this.columnController.hasFloatingFilters()) {
  24655. headerRowCount++;
  24656. numberOfFloating = 1;
  24657. }
  24658. groupHeight = this.gridOptionsWrapper.getGroupHeaderHeight();
  24659. headerHeight = this.gridOptionsWrapper.getHeaderHeight();
  24660. }
  24661. var numberOfNonGroups = 1 + numberOfFloating;
  24662. var numberOfGroups = headerRowCount - numberOfNonGroups;
  24663. for (var i = 0; i < numberOfGroups; i++) {
  24664. sizes.push(groupHeight);
  24665. }
  24666. sizes.push(headerHeight);
  24667. for (var i = 0; i < numberOfFloating; i++) {
  24668. sizes.push(this.gridOptionsWrapper.getFloatingFiltersHeight());
  24669. }
  24670. var rowHeight = 0;
  24671. for (var i = 0; i < this.dept; i++) {
  24672. rowHeight += sizes[i];
  24673. }
  24674. this.getGui().style.top = rowHeight + 'px';
  24675. this.getGui().style.height = sizes[this.dept] + 'px';
  24676. };
  24677. //noinspection JSUnusedLocalSymbols
  24678. HeaderRowComp.prototype.init = function () {
  24679. this.onRowHeightChanged();
  24680. this.onVirtualColumnsChanged();
  24681. this.setWidth();
  24682. this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__["GridOptionsWrapper"].PROP_HEADER_HEIGHT, this.onRowHeightChanged.bind(this));
  24683. this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__["GridOptionsWrapper"].PROP_PIVOT_HEADER_HEIGHT, this.onRowHeightChanged.bind(this));
  24684. this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__["GridOptionsWrapper"].PROP_GROUP_HEADER_HEIGHT, this.onRowHeightChanged.bind(this));
  24685. this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__["GridOptionsWrapper"].PROP_PIVOT_GROUP_HEADER_HEIGHT, this.onRowHeightChanged.bind(this));
  24686. this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_2__["GridOptionsWrapper"].PROP_FLOATING_FILTERS_HEIGHT, this.onRowHeightChanged.bind(this));
  24687. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_VIRTUAL_COLUMNS_CHANGED, this.onVirtualColumnsChanged.bind(this));
  24688. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this));
  24689. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_COLUMN_RESIZED, this.onColumnResized.bind(this));
  24690. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_GRID_COLUMNS_CHANGED, this.onGridColumnsChanged.bind(this));
  24691. };
  24692. HeaderRowComp.prototype.onColumnResized = function () {
  24693. this.setWidth();
  24694. };
  24695. HeaderRowComp.prototype.setWidth = function () {
  24696. var width = this.getWidthForRow();
  24697. this.getGui().style.width = width + 'px';
  24698. };
  24699. HeaderRowComp.prototype.getWidthForRow = function () {
  24700. var printLayout = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_6__["Constants"].DOM_LAYOUT_PRINT;
  24701. if (printLayout) {
  24702. var centerRow = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(this.pinned);
  24703. if (centerRow) {
  24704. return this.columnController.getContainerWidth(_constants__WEBPACK_IMPORTED_MODULE_6__["Constants"].PINNED_RIGHT)
  24705. + this.columnController.getContainerWidth(_constants__WEBPACK_IMPORTED_MODULE_6__["Constants"].PINNED_LEFT)
  24706. + this.columnController.getContainerWidth(null);
  24707. }
  24708. return 0;
  24709. }
  24710. // if not printing, just return the width as normal
  24711. return this.columnController.getContainerWidth(this.pinned);
  24712. };
  24713. HeaderRowComp.prototype.onGridColumnsChanged = function () {
  24714. this.removeAndDestroyAllChildComponents();
  24715. };
  24716. HeaderRowComp.prototype.removeAndDestroyAllChildComponents = function () {
  24717. var idsOfAllChildren = Object.keys(this.headerComps);
  24718. this.destroyChildComponents(idsOfAllChildren);
  24719. };
  24720. HeaderRowComp.prototype.onDisplayedColumnsChanged = function () {
  24721. this.onVirtualColumnsChanged();
  24722. this.setWidth();
  24723. };
  24724. HeaderRowComp.prototype.getItemsAtDepth = function () {
  24725. var _this = this;
  24726. var printLayout = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_6__["Constants"].DOM_LAYOUT_PRINT;
  24727. if (printLayout) {
  24728. // for print layout, we add all columns into the center
  24729. var centerContainer = Object(_utils_generic__WEBPACK_IMPORTED_MODULE_9__["missing"])(this.pinned);
  24730. if (centerContainer) {
  24731. var result_1 = [];
  24732. [_constants__WEBPACK_IMPORTED_MODULE_6__["Constants"].PINNED_LEFT, null, _constants__WEBPACK_IMPORTED_MODULE_6__["Constants"].PINNED_RIGHT].forEach(function (pinned) {
  24733. var items = _this.columnController.getVirtualHeaderGroupRow(pinned, _this.type == HeaderRowType.FLOATING_FILTER ?
  24734. _this.dept - 1 :
  24735. _this.dept);
  24736. result_1 = result_1.concat(items);
  24737. });
  24738. return result_1;
  24739. }
  24740. return [];
  24741. }
  24742. // when in normal layout, we add the columns for that container only
  24743. return this.columnController.getVirtualHeaderGroupRow(this.pinned, this.type == HeaderRowType.FLOATING_FILTER ?
  24744. this.dept - 1 :
  24745. this.dept);
  24746. };
  24747. HeaderRowComp.prototype.onVirtualColumnsChanged = function () {
  24748. var _this = this;
  24749. var currentChildIds = Object.keys(this.headerComps);
  24750. var correctChildIds = [];
  24751. var itemsAtDepth = this.getItemsAtDepth();
  24752. itemsAtDepth.forEach(function (child) {
  24753. // skip groups that have no displayed children. this can happen when the group is broken,
  24754. // and this section happens to have nothing to display for the open / closed state.
  24755. // (a broken group is one that is split, ie columns in the group have a non-group column
  24756. // in between them)
  24757. if (child.isEmptyGroup()) {
  24758. return;
  24759. }
  24760. var idOfChild = child.getUniqueId();
  24761. var eParentContainer = _this.getGui();
  24762. // if we already have this cell rendered, do nothing
  24763. var colAlreadyInDom = currentChildIds.indexOf(idOfChild) >= 0;
  24764. var headerComp;
  24765. var eHeaderCompGui;
  24766. if (colAlreadyInDom) {
  24767. Object(_utils_array__WEBPACK_IMPORTED_MODULE_10__["removeFromArray"])(currentChildIds, idOfChild);
  24768. }
  24769. else {
  24770. headerComp = _this.createHeaderComp(child);
  24771. _this.headerComps[idOfChild] = headerComp;
  24772. eHeaderCompGui = headerComp.getGui();
  24773. eParentContainer.appendChild(eHeaderCompGui);
  24774. }
  24775. correctChildIds.push(idOfChild);
  24776. });
  24777. // at this point, anything left in currentChildIds is an element that is no longer in the viewport
  24778. this.destroyChildComponents(currentChildIds, true);
  24779. var ensureDomOrder = this.gridOptionsWrapper.isEnsureDomOrder();
  24780. if (ensureDomOrder) {
  24781. var correctChildOrder = correctChildIds.map(function (id) { return _this.headerComps[id].getGui(); });
  24782. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_11__["setDomChildOrder"])(this.getGui(), correctChildOrder);
  24783. }
  24784. };
  24785. HeaderRowComp.prototype.createHeaderComp = function (columnGroupChild) {
  24786. var result;
  24787. switch (this.type) {
  24788. case HeaderRowType.COLUMN:
  24789. result = new _header_headerWrapperComp__WEBPACK_IMPORTED_MODULE_4__["HeaderWrapperComp"](columnGroupChild, this.dropTarget, this.pinned);
  24790. break;
  24791. case HeaderRowType.COLUMN_GROUP:
  24792. result = new _headerGroup_headerGroupWrapperComp__WEBPACK_IMPORTED_MODULE_5__["HeaderGroupWrapperComp"](columnGroupChild, this.dropTarget, this.pinned);
  24793. break;
  24794. case HeaderRowType.FLOATING_FILTER:
  24795. result = new _filter_floating_floatingFilterWrapper__WEBPACK_IMPORTED_MODULE_7__["FloatingFilterWrapper"](columnGroupChild, this.pinned);
  24796. break;
  24797. }
  24798. this.createBean(result);
  24799. result.setParentComponent(this);
  24800. return result;
  24801. };
  24802. HeaderRowComp.prototype.getHeaderComps = function () {
  24803. return this.headerComps;
  24804. };
  24805. __decorate([
  24806. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  24807. ], HeaderRowComp.prototype, "gridOptionsWrapper", void 0);
  24808. __decorate([
  24809. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController')
  24810. ], HeaderRowComp.prototype, "columnController", void 0);
  24811. __decorate([
  24812. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('focusController')
  24813. ], HeaderRowComp.prototype, "focusController", void 0);
  24814. __decorate([
  24815. _context_context__WEBPACK_IMPORTED_MODULE_1__["PreDestroy"]
  24816. ], HeaderRowComp.prototype, "destroyAllChildComponents", null);
  24817. __decorate([
  24818. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  24819. ], HeaderRowComp.prototype, "init", null);
  24820. return HeaderRowComp;
  24821. }(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"]));
  24822. /***/ }),
  24823. /* 111 */
  24824. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  24825. "use strict";
  24826. __webpack_require__.r(__webpack_exports__);
  24827. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderWrapperComp", function() { return HeaderWrapperComp; });
  24828. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  24829. /* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(35);
  24830. /* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(104);
  24831. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25);
  24832. /* harmony import */ var _cssClassApplier__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(112);
  24833. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(43);
  24834. /* harmony import */ var _hoverFeature__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(113);
  24835. /* harmony import */ var _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(114);
  24836. /* harmony import */ var _selectAllFeature__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(115);
  24837. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(57);
  24838. /* harmony import */ var _widgets_touchListener__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(65);
  24839. /* harmony import */ var _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(107);
  24840. /* harmony import */ var _abstractHeaderWrapper__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(116);
  24841. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(7);
  24842. /**
  24843. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  24844. * @version v23.2.1
  24845. * @link http://www.ag-grid.com/
  24846. * @license MIT
  24847. */
  24848. var __extends = (undefined && undefined.__extends) || (function () {
  24849. var extendStatics = function (d, b) {
  24850. extendStatics = Object.setPrototypeOf ||
  24851. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  24852. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  24853. return extendStatics(d, b);
  24854. };
  24855. return function (d, b) {
  24856. extendStatics(d, b);
  24857. function __() { this.constructor = d; }
  24858. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  24859. };
  24860. })();
  24861. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  24862. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  24863. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  24864. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  24865. return c > 3 && r && Object.defineProperty(target, key, r), r;
  24866. };
  24867. var HeaderWrapperComp = /** @class */ (function (_super) {
  24868. __extends(HeaderWrapperComp, _super);
  24869. function HeaderWrapperComp(column, dragSourceDropTarget, pinned) {
  24870. var _this = _super.call(this, HeaderWrapperComp.TEMPLATE) || this;
  24871. _this.column = column;
  24872. _this.dragSourceDropTarget = dragSourceDropTarget;
  24873. _this.pinned = pinned;
  24874. return _this;
  24875. }
  24876. HeaderWrapperComp.prototype.postConstruct = function () {
  24877. _super.prototype.postConstruct.call(this);
  24878. var colDef = this.getComponentHolder();
  24879. var displayName = this.columnController.getDisplayNameForColumn(this.column, 'header', true);
  24880. var enableSorting = colDef.sortable;
  24881. var enableMenu = this.menuEnabled = this.menuFactory.isMenuEnabled(this.column) && !colDef.suppressMenu;
  24882. this.appendHeaderComp(displayName, enableSorting, enableMenu);
  24883. this.setupWidth();
  24884. this.setupMovingCss();
  24885. this.setupTooltip();
  24886. this.setupResize();
  24887. this.setupMenuClass();
  24888. this.setupSortableClass(enableSorting);
  24889. this.addColumnHoverListener();
  24890. this.addDisplayMenuListeners();
  24891. this.cbSelectAll.setInputAriaLabel('Toggle Selection of All Rows');
  24892. this.createManagedBean(new _hoverFeature__WEBPACK_IMPORTED_MODULE_6__["HoverFeature"]([this.column], this.getGui()));
  24893. this.addManagedListener(this.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_FILTER_ACTIVE_CHANGED, this.onFilterChanged.bind(this));
  24894. this.onFilterChanged();
  24895. this.createManagedBean(new _selectAllFeature__WEBPACK_IMPORTED_MODULE_8__["SelectAllFeature"](this.cbSelectAll, this.column));
  24896. var setLeftFeature = new _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_7__["SetLeftFeature"](this.column, this.getGui(), this.beans);
  24897. this.createManagedBean(setLeftFeature);
  24898. this.addAttributes();
  24899. _cssClassApplier__WEBPACK_IMPORTED_MODULE_4__["CssClassApplier"].addHeaderClassesFromColDef(colDef, this.getGui(), this.gridOptionsWrapper, this.column, null);
  24900. };
  24901. HeaderWrapperComp.prototype.addDisplayMenuListeners = function () {
  24902. var mouseListener = this.onMouseOverOut.bind(this);
  24903. this.addGuiEventListener('mouseenter', mouseListener);
  24904. this.addGuiEventListener('mouseleave', mouseListener);
  24905. };
  24906. HeaderWrapperComp.prototype.onMouseOverOut = function (e) {
  24907. if (this.headerComp && this.headerComp.setActiveParent) {
  24908. this.headerComp.setActiveParent(e.type === 'mouseenter');
  24909. }
  24910. };
  24911. HeaderWrapperComp.prototype.onFocusIn = function (e) {
  24912. if (!this.getGui().contains(e.relatedTarget)) {
  24913. var headerRow = this.getParentComponent();
  24914. this.focusController.setFocusedHeader(headerRow.getRowIndex(), this.getColumn());
  24915. }
  24916. if (this.headerComp && this.headerComp.setActiveParent) {
  24917. this.headerComp.setActiveParent(true);
  24918. }
  24919. };
  24920. HeaderWrapperComp.prototype.onFocusOut = function (e) {
  24921. if (!this.headerComp ||
  24922. !this.headerComp.setActiveParent ||
  24923. this.getGui().contains(e.relatedTarget)) {
  24924. return;
  24925. }
  24926. this.headerComp.setActiveParent(false);
  24927. };
  24928. HeaderWrapperComp.prototype.handleKeyDown = function (e) {
  24929. var headerComp = this.headerComp;
  24930. if (!headerComp) {
  24931. return;
  24932. }
  24933. if (e.keyCode === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_SPACE) {
  24934. var checkbox = this.cbSelectAll;
  24935. if (checkbox.isDisplayed() && !checkbox.getGui().contains(document.activeElement)) {
  24936. checkbox.setValue(!checkbox.getValue());
  24937. }
  24938. }
  24939. if (e.keyCode === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_ENTER) {
  24940. if (e.ctrlKey || e.metaKey) {
  24941. if (this.menuEnabled && headerComp.showMenu) {
  24942. e.preventDefault();
  24943. headerComp.showMenu();
  24944. }
  24945. }
  24946. else if (this.sortable) {
  24947. var multiSort = e.shiftKey;
  24948. this.sortController.progressSort(this.column, multiSort, "uiColumnSorted");
  24949. }
  24950. }
  24951. };
  24952. HeaderWrapperComp.prototype.getComponentHolder = function () {
  24953. return this.column.getColDef();
  24954. };
  24955. HeaderWrapperComp.prototype.addColumnHoverListener = function () {
  24956. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_5__["Events"].EVENT_COLUMN_HOVER_CHANGED, this.onColumnHover.bind(this));
  24957. this.onColumnHover();
  24958. };
  24959. HeaderWrapperComp.prototype.onColumnHover = function () {
  24960. var isHovered = this.columnHoverService.isHovered(this.column);
  24961. _utils__WEBPACK_IMPORTED_MODULE_13__["_"].addOrRemoveCssClass(this.getGui(), 'ag-column-hover', isHovered);
  24962. };
  24963. HeaderWrapperComp.prototype.setupSortableClass = function (enableSorting) {
  24964. if (!enableSorting) {
  24965. return;
  24966. }
  24967. var element = this.getGui();
  24968. _utils__WEBPACK_IMPORTED_MODULE_13__["_"].addCssClass(element, 'ag-header-cell-sortable');
  24969. this.sortable = true;
  24970. };
  24971. HeaderWrapperComp.prototype.onFilterChanged = function () {
  24972. var filterPresent = this.column.isFilterActive();
  24973. _utils__WEBPACK_IMPORTED_MODULE_13__["_"].addOrRemoveCssClass(this.getGui(), 'ag-header-cell-filtered', filterPresent);
  24974. };
  24975. HeaderWrapperComp.prototype.appendHeaderComp = function (displayName, enableSorting, enableMenu) {
  24976. var _this = this;
  24977. var params = {
  24978. column: this.column,
  24979. displayName: displayName,
  24980. enableSorting: enableSorting,
  24981. enableMenu: enableMenu,
  24982. showColumnMenu: function (source) {
  24983. _this.gridApi.showColumnMenuAfterButtonClick(_this.column, source);
  24984. },
  24985. progressSort: function (multiSort) {
  24986. _this.sortController.progressSort(_this.column, !!multiSort, "uiColumnSorted");
  24987. },
  24988. setSort: function (sort, multiSort) {
  24989. _this.sortController.setSortForColumn(_this.column, sort, !!multiSort, "uiColumnSorted");
  24990. },
  24991. api: this.gridApi,
  24992. columnApi: this.columnApi,
  24993. context: this.gridOptionsWrapper.getContext()
  24994. };
  24995. var callback = this.afterHeaderCompCreated.bind(this, displayName);
  24996. this.userComponentFactory.newHeaderComponent(params).then(callback);
  24997. };
  24998. HeaderWrapperComp.prototype.afterHeaderCompCreated = function (displayName, headerComp) {
  24999. var _this = this;
  25000. this.getGui().appendChild(headerComp.getGui());
  25001. this.addDestroyFunc(function () {
  25002. _this.getContext().destroyBean(headerComp);
  25003. });
  25004. this.setupMove(headerComp.getGui(), displayName);
  25005. this.headerComp = headerComp;
  25006. };
  25007. HeaderWrapperComp.prototype.onColumnMovingChanged = function () {
  25008. // this function adds or removes the moving css, based on if the col is moving.
  25009. // this is what makes the header go dark when it is been moved (gives impression to
  25010. // user that the column was picked up).
  25011. if (this.column.isMoving()) {
  25012. _utils__WEBPACK_IMPORTED_MODULE_13__["_"].addCssClass(this.getGui(), 'ag-header-cell-moving');
  25013. }
  25014. else {
  25015. _utils__WEBPACK_IMPORTED_MODULE_13__["_"].removeCssClass(this.getGui(), 'ag-header-cell-moving');
  25016. }
  25017. };
  25018. HeaderWrapperComp.prototype.setupMove = function (eHeaderCellLabel, displayName) {
  25019. var _this = this;
  25020. var colDef = this.column.getColDef();
  25021. var suppressMove = this.gridOptionsWrapper.isSuppressMovableColumns()
  25022. || this.getComponentHolder().suppressMovable
  25023. || colDef.lockPosition;
  25024. if (suppressMove &&
  25025. !colDef.enableRowGroup &&
  25026. !colDef.enablePivot) {
  25027. return;
  25028. }
  25029. if (eHeaderCellLabel) {
  25030. var dragSource_1 = {
  25031. type: _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragSourceType"].HeaderCell,
  25032. eElement: eHeaderCellLabel,
  25033. defaultIconName: _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_HIDE,
  25034. getDragItem: function () { return _this.createDragItem(); },
  25035. dragItemName: displayName,
  25036. dragSourceDropTarget: this.dragSourceDropTarget,
  25037. onDragStarted: function () { return !suppressMove && _this.column.setMoving(true, "uiColumnMoved"); },
  25038. onDragStopped: function () { return !suppressMove && _this.column.setMoving(false, "uiColumnMoved"); }
  25039. };
  25040. this.dragAndDropService.addDragSource(dragSource_1, true);
  25041. this.addDestroyFunc(function () { return _this.dragAndDropService.removeDragSource(dragSource_1); });
  25042. }
  25043. };
  25044. HeaderWrapperComp.prototype.createDragItem = function () {
  25045. var visibleState = {};
  25046. visibleState[this.column.getId()] = this.column.isVisible();
  25047. return {
  25048. columns: [this.column],
  25049. visibleState: visibleState
  25050. };
  25051. };
  25052. HeaderWrapperComp.prototype.setupResize = function () {
  25053. var _this = this;
  25054. var colDef = this.getComponentHolder();
  25055. // if no eResize in template, do nothing
  25056. if (!this.eResize) {
  25057. return;
  25058. }
  25059. if (!this.column.isResizable()) {
  25060. _utils__WEBPACK_IMPORTED_MODULE_13__["_"].removeFromParent(this.eResize);
  25061. return;
  25062. }
  25063. var finishedWithResizeFunc = this.horizontalResizeService.addResizeBar({
  25064. eResizeBar: this.eResize,
  25065. onResizeStart: this.onResizeStart.bind(this),
  25066. onResizing: this.onResizing.bind(this, false),
  25067. onResizeEnd: this.onResizing.bind(this, true)
  25068. });
  25069. this.addDestroyFunc(finishedWithResizeFunc);
  25070. var weWantAutoSize = !this.gridOptionsWrapper.isSuppressAutoSize() && !colDef.suppressAutoSize;
  25071. var skipHeaderOnAutoSize = this.gridOptionsWrapper.isSkipHeaderOnAutoSize();
  25072. if (weWantAutoSize) {
  25073. this.addManagedListener(this.eResize, 'dblclick', function () {
  25074. _this.columnController.autoSizeColumn(_this.column, skipHeaderOnAutoSize, "uiColumnResized");
  25075. });
  25076. var touchListener = new _widgets_touchListener__WEBPACK_IMPORTED_MODULE_10__["TouchListener"](this.eResize);
  25077. this.addManagedListener(touchListener, _widgets_touchListener__WEBPACK_IMPORTED_MODULE_10__["TouchListener"].EVENT_DOUBLE_TAP, function () {
  25078. _this.columnController.autoSizeColumn(_this.column, skipHeaderOnAutoSize, "uiColumnResized");
  25079. });
  25080. this.addDestroyFunc(touchListener.destroy.bind(touchListener));
  25081. }
  25082. };
  25083. HeaderWrapperComp.prototype.onResizing = function (finished, resizeAmount) {
  25084. var resizeAmountNormalised = this.normaliseResizeAmount(resizeAmount);
  25085. var columnWidths = [{ key: this.column, newWidth: this.resizeStartWidth + resizeAmountNormalised }];
  25086. this.columnController.setColumnWidths(columnWidths, this.resizeWithShiftKey, finished, "uiColumnDragged");
  25087. if (finished) {
  25088. _utils__WEBPACK_IMPORTED_MODULE_13__["_"].removeCssClass(this.getGui(), 'ag-column-resizing');
  25089. }
  25090. };
  25091. HeaderWrapperComp.prototype.onResizeStart = function (shiftKey) {
  25092. this.resizeStartWidth = this.column.getActualWidth();
  25093. this.resizeWithShiftKey = shiftKey;
  25094. _utils__WEBPACK_IMPORTED_MODULE_13__["_"].addCssClass(this.getGui(), 'ag-column-resizing');
  25095. };
  25096. HeaderWrapperComp.prototype.getTooltipText = function () {
  25097. var colDef = this.getComponentHolder();
  25098. return colDef.headerTooltip;
  25099. };
  25100. HeaderWrapperComp.prototype.setupTooltip = function () {
  25101. var tooltipText = this.getTooltipText();
  25102. // add tooltip if exists
  25103. if (tooltipText == null) {
  25104. return;
  25105. }
  25106. if (this.gridOptionsWrapper.isEnableBrowserTooltips()) {
  25107. this.getGui().setAttribute('title', tooltipText);
  25108. }
  25109. else {
  25110. this.createManagedBean(new _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_11__["TooltipFeature"](this, 'header'));
  25111. }
  25112. };
  25113. HeaderWrapperComp.prototype.setupMovingCss = function () {
  25114. this.addManagedListener(this.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_MOVING_CHANGED, this.onColumnMovingChanged.bind(this));
  25115. this.onColumnMovingChanged();
  25116. };
  25117. HeaderWrapperComp.prototype.addAttributes = function () {
  25118. this.getGui().setAttribute("col-id", this.column.getColId());
  25119. };
  25120. HeaderWrapperComp.prototype.setupWidth = function () {
  25121. this.addManagedListener(this.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_WIDTH_CHANGED, this.onColumnWidthChanged.bind(this));
  25122. this.onColumnWidthChanged();
  25123. };
  25124. HeaderWrapperComp.prototype.setupMenuClass = function () {
  25125. this.addManagedListener(this.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_MENU_VISIBLE_CHANGED, this.onMenuVisible.bind(this));
  25126. this.onColumnWidthChanged();
  25127. };
  25128. HeaderWrapperComp.prototype.onMenuVisible = function () {
  25129. this.addOrRemoveCssClass('ag-column-menu-visible', this.column.isMenuVisible());
  25130. };
  25131. HeaderWrapperComp.prototype.onColumnWidthChanged = function () {
  25132. this.getGui().style.width = this.column.getActualWidth() + 'px';
  25133. };
  25134. // optionally inverts the drag, depending on pinned and RTL
  25135. // note - this method is duplicated in RenderedHeaderGroupCell - should refactor out?
  25136. HeaderWrapperComp.prototype.normaliseResizeAmount = function (dragChange) {
  25137. var result = dragChange;
  25138. if (this.gridOptionsWrapper.isEnableRtl()) {
  25139. // for RTL, dragging left makes the col bigger, except when pinning left
  25140. if (this.pinned !== _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_LEFT) {
  25141. result *= -1;
  25142. }
  25143. }
  25144. else {
  25145. // for LTR (ie normal), dragging left makes the col smaller, except when pinning right
  25146. if (this.pinned === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_RIGHT) {
  25147. result *= -1;
  25148. }
  25149. }
  25150. return result;
  25151. };
  25152. HeaderWrapperComp.TEMPLATE = "<div class=\"ag-header-cell\" role=\"presentation\" unselectable=\"on\" tabindex=\"-1\">\n <div ref=\"eResize\" class=\"ag-header-cell-resize\" role=\"presentation\"></div>\n <ag-checkbox ref=\"cbSelectAll\" class=\"ag-header-select-all\" role=\"presentation\"></ag-checkbox>\n </div>";
  25153. __decorate([
  25154. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  25155. ], HeaderWrapperComp.prototype, "gridOptionsWrapper", void 0);
  25156. __decorate([
  25157. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('dragAndDropService')
  25158. ], HeaderWrapperComp.prototype, "dragAndDropService", void 0);
  25159. __decorate([
  25160. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController')
  25161. ], HeaderWrapperComp.prototype, "columnController", void 0);
  25162. __decorate([
  25163. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('horizontalResizeService')
  25164. ], HeaderWrapperComp.prototype, "horizontalResizeService", void 0);
  25165. __decorate([
  25166. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('menuFactory')
  25167. ], HeaderWrapperComp.prototype, "menuFactory", void 0);
  25168. __decorate([
  25169. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi')
  25170. ], HeaderWrapperComp.prototype, "gridApi", void 0);
  25171. __decorate([
  25172. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi')
  25173. ], HeaderWrapperComp.prototype, "columnApi", void 0);
  25174. __decorate([
  25175. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('sortController')
  25176. ], HeaderWrapperComp.prototype, "sortController", void 0);
  25177. __decorate([
  25178. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('userComponentFactory')
  25179. ], HeaderWrapperComp.prototype, "userComponentFactory", void 0);
  25180. __decorate([
  25181. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnHoverService')
  25182. ], HeaderWrapperComp.prototype, "columnHoverService", void 0);
  25183. __decorate([
  25184. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('beans')
  25185. ], HeaderWrapperComp.prototype, "beans", void 0);
  25186. __decorate([
  25187. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eResize')
  25188. ], HeaderWrapperComp.prototype, "eResize", void 0);
  25189. __decorate([
  25190. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('cbSelectAll')
  25191. ], HeaderWrapperComp.prototype, "cbSelectAll", void 0);
  25192. return HeaderWrapperComp;
  25193. }(_abstractHeaderWrapper__WEBPACK_IMPORTED_MODULE_12__["AbstractHeaderWrapper"]));
  25194. /***/ }),
  25195. /* 112 */
  25196. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  25197. "use strict";
  25198. __webpack_require__.r(__webpack_exports__);
  25199. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CssClassApplier", function() { return CssClassApplier; });
  25200. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7);
  25201. /**
  25202. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  25203. * @version v23.2.1
  25204. * @link http://www.ag-grid.com/
  25205. * @license MIT
  25206. */
  25207. var CssClassApplier = /** @class */ (function () {
  25208. function CssClassApplier() {
  25209. }
  25210. CssClassApplier.addHeaderClassesFromColDef = function (abstractColDef, eHeaderCell, gridOptionsWrapper, column, columnGroup) {
  25211. if (_utils__WEBPACK_IMPORTED_MODULE_0__["_"].missing(abstractColDef)) {
  25212. return;
  25213. }
  25214. this.addColumnClassesFromCollDef(abstractColDef.headerClass, abstractColDef, eHeaderCell, gridOptionsWrapper, column, columnGroup);
  25215. };
  25216. CssClassApplier.addToolPanelClassesFromColDef = function (abstractColDef, eHeaderCell, gridOptionsWrapper, column, columnGroup) {
  25217. if (_utils__WEBPACK_IMPORTED_MODULE_0__["_"].missing(abstractColDef)) {
  25218. return;
  25219. }
  25220. this.addColumnClassesFromCollDef(abstractColDef.toolPanelClass, abstractColDef, eHeaderCell, gridOptionsWrapper, column, columnGroup);
  25221. };
  25222. CssClassApplier.addColumnClassesFromCollDef = function (classesOrFunc, abstractColDef, eHeaderCell, gridOptionsWrapper, column, columnGroup) {
  25223. if (_utils__WEBPACK_IMPORTED_MODULE_0__["_"].missing(classesOrFunc)) {
  25224. return;
  25225. }
  25226. var classToUse;
  25227. if (typeof classesOrFunc === 'function') {
  25228. var params = {
  25229. // bad naming, as colDef here can be a group or a column,
  25230. // however most people won't appreciate the difference,
  25231. // so keeping it as colDef to avoid confusion.
  25232. colDef: abstractColDef,
  25233. column: column,
  25234. columnGroup: columnGroup,
  25235. context: gridOptionsWrapper.getContext(),
  25236. api: gridOptionsWrapper.getApi()
  25237. };
  25238. var headerClassFunc = classesOrFunc;
  25239. classToUse = headerClassFunc(params);
  25240. }
  25241. else {
  25242. classToUse = classesOrFunc;
  25243. }
  25244. if (typeof classToUse === 'string') {
  25245. _utils__WEBPACK_IMPORTED_MODULE_0__["_"].addCssClass(eHeaderCell, classToUse);
  25246. }
  25247. else if (Array.isArray(classToUse)) {
  25248. classToUse.forEach(function (cssClassItem) {
  25249. _utils__WEBPACK_IMPORTED_MODULE_0__["_"].addCssClass(eHeaderCell, cssClassItem);
  25250. });
  25251. }
  25252. };
  25253. return CssClassApplier;
  25254. }());
  25255. /***/ }),
  25256. /* 113 */
  25257. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  25258. "use strict";
  25259. __webpack_require__.r(__webpack_exports__);
  25260. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HoverFeature", function() { return HoverFeature; });
  25261. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(41);
  25262. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  25263. /**
  25264. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  25265. * @version v23.2.1
  25266. * @link http://www.ag-grid.com/
  25267. * @license MIT
  25268. */
  25269. var __extends = (undefined && undefined.__extends) || (function () {
  25270. var extendStatics = function (d, b) {
  25271. extendStatics = Object.setPrototypeOf ||
  25272. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  25273. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  25274. return extendStatics(d, b);
  25275. };
  25276. return function (d, b) {
  25277. extendStatics(d, b);
  25278. function __() { this.constructor = d; }
  25279. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  25280. };
  25281. })();
  25282. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  25283. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  25284. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  25285. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  25286. return c > 3 && r && Object.defineProperty(target, key, r), r;
  25287. };
  25288. var HoverFeature = /** @class */ (function (_super) {
  25289. __extends(HoverFeature, _super);
  25290. function HoverFeature(columns, element) {
  25291. var _this = _super.call(this) || this;
  25292. _this.columns = columns;
  25293. _this.element = element;
  25294. return _this;
  25295. }
  25296. HoverFeature.prototype.postConstruct = function () {
  25297. this.addMouseHoverListeners();
  25298. };
  25299. HoverFeature.prototype.addMouseHoverListeners = function () {
  25300. this.addManagedListener(this.element, 'mouseout', this.onMouseOut.bind(this));
  25301. this.addManagedListener(this.element, 'mouseover', this.onMouseOver.bind(this));
  25302. };
  25303. HoverFeature.prototype.onMouseOut = function () {
  25304. this.columnHoverService.clearMouseOver();
  25305. };
  25306. HoverFeature.prototype.onMouseOver = function () {
  25307. this.columnHoverService.setMouseOver(this.columns);
  25308. };
  25309. __decorate([
  25310. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnHoverService')
  25311. ], HoverFeature.prototype, "columnHoverService", void 0);
  25312. __decorate([
  25313. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  25314. ], HoverFeature.prototype, "postConstruct", null);
  25315. return HoverFeature;
  25316. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"]));
  25317. /***/ }),
  25318. /* 114 */
  25319. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  25320. "use strict";
  25321. __webpack_require__.r(__webpack_exports__);
  25322. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SetLeftFeature", function() { return SetLeftFeature; });
  25323. /* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(35);
  25324. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  25325. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25);
  25326. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(37);
  25327. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7);
  25328. /**
  25329. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  25330. * @version v23.2.1
  25331. * @link http://www.ag-grid.com/
  25332. * @license MIT
  25333. */
  25334. var __extends = (undefined && undefined.__extends) || (function () {
  25335. var extendStatics = function (d, b) {
  25336. extendStatics = Object.setPrototypeOf ||
  25337. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  25338. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  25339. return extendStatics(d, b);
  25340. };
  25341. return function (d, b) {
  25342. extendStatics(d, b);
  25343. function __() { this.constructor = d; }
  25344. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  25345. };
  25346. })();
  25347. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  25348. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  25349. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  25350. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  25351. return c > 3 && r && Object.defineProperty(target, key, r), r;
  25352. };
  25353. var SetLeftFeature = /** @class */ (function (_super) {
  25354. __extends(SetLeftFeature, _super);
  25355. function SetLeftFeature(columnOrGroup, eCell, beans, colsSpanning) {
  25356. var _this = _super.call(this) || this;
  25357. _this.columnOrGroup = columnOrGroup;
  25358. _this.eCell = eCell;
  25359. _this.ariaEl = _this.eCell.querySelector('[role=columnheader]') || _this.eCell;
  25360. _this.colsSpanning = colsSpanning;
  25361. _this.beans = beans;
  25362. _this.printLayout = beans.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].DOM_LAYOUT_PRINT;
  25363. return _this;
  25364. }
  25365. SetLeftFeature.prototype.setColsSpanning = function (colsSpanning) {
  25366. this.colsSpanning = colsSpanning;
  25367. this.onLeftChanged();
  25368. };
  25369. SetLeftFeature.prototype.getColumnOrGroup = function () {
  25370. if (this.beans.gridOptionsWrapper.isEnableRtl() && this.colsSpanning) {
  25371. return _utils__WEBPACK_IMPORTED_MODULE_4__["_"].last(this.colsSpanning);
  25372. }
  25373. return this.columnOrGroup;
  25374. };
  25375. SetLeftFeature.prototype.postConstruct = function () {
  25376. this.addManagedListener(this.columnOrGroup, _entities_column__WEBPACK_IMPORTED_MODULE_0__["Column"].EVENT_LEFT_CHANGED, this.onLeftChanged.bind(this));
  25377. this.setLeftFirstTime();
  25378. };
  25379. SetLeftFeature.prototype.setLeftFirstTime = function () {
  25380. var suppressMoveAnimation = this.beans.gridOptionsWrapper.isSuppressColumnMoveAnimation();
  25381. var oldLeftExists = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].exists(this.columnOrGroup.getOldLeft());
  25382. var animateColumnMove = this.beans.columnAnimationService.isActive() && oldLeftExists && !suppressMoveAnimation;
  25383. if (animateColumnMove) {
  25384. this.animateInLeft();
  25385. }
  25386. else {
  25387. this.onLeftChanged();
  25388. }
  25389. };
  25390. SetLeftFeature.prototype.animateInLeft = function () {
  25391. var _this = this;
  25392. var left = this.getColumnOrGroup().getLeft();
  25393. var oldLeft = this.getColumnOrGroup().getOldLeft();
  25394. this.setLeft(oldLeft);
  25395. // we must keep track of the left we want to set to, as this would otherwise lead to a race
  25396. // condition, if the user changed the left value many times in one VM turn, then we want to make
  25397. // make sure the actualLeft we set in the timeout below (in the next VM turn) is the correct left
  25398. // position. eg if user changes column position twice, then setLeft() below executes twice in next
  25399. // VM turn, but only one (the correct one) should get applied.
  25400. this.actualLeft = left;
  25401. this.beans.columnAnimationService.executeNextVMTurn(function () {
  25402. // test this left value is the latest one to be applied, and if not, do nothing
  25403. if (_this.actualLeft === left) {
  25404. _this.setLeft(left);
  25405. }
  25406. });
  25407. };
  25408. SetLeftFeature.prototype.onLeftChanged = function () {
  25409. var colOrGroup = this.getColumnOrGroup();
  25410. var left = colOrGroup.getLeft();
  25411. this.actualLeft = this.modifyLeftForPrintLayout(colOrGroup, left);
  25412. this.setLeft(this.actualLeft);
  25413. };
  25414. SetLeftFeature.prototype.modifyLeftForPrintLayout = function (colOrGroup, leftPosition) {
  25415. if (!this.printLayout) {
  25416. return leftPosition;
  25417. }
  25418. if (colOrGroup.getPinned() === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_LEFT) {
  25419. return leftPosition;
  25420. }
  25421. if (colOrGroup.getPinned() === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_RIGHT) {
  25422. var leftWidth_1 = this.beans.columnController.getPinnedLeftContainerWidth();
  25423. var bodyWidth = this.beans.columnController.getBodyContainerWidth();
  25424. return leftWidth_1 + bodyWidth + leftPosition;
  25425. }
  25426. // is in body
  25427. var leftWidth = this.beans.columnController.getPinnedLeftContainerWidth();
  25428. return leftWidth + leftPosition;
  25429. };
  25430. SetLeftFeature.prototype.setLeft = function (value) {
  25431. // if the value is null, then that means the column is no longer
  25432. // displayed. there is logic in the rendering to fade these columns
  25433. // out, so we don't try and change their left positions.
  25434. if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].exists(value)) {
  25435. this.eCell.style.left = value + "px";
  25436. }
  25437. if (this.columnOrGroup instanceof _entities_column__WEBPACK_IMPORTED_MODULE_0__["Column"]) {
  25438. var colIndex = this.beans.columnController.getAllDisplayedColumns().indexOf(this.columnOrGroup);
  25439. this.ariaEl.setAttribute('aria-colindex', (colIndex + 1).toString());
  25440. }
  25441. else {
  25442. this.ariaEl.removeAttribute('aria-colindex');
  25443. }
  25444. };
  25445. __decorate([
  25446. _context_context__WEBPACK_IMPORTED_MODULE_3__["PostConstruct"]
  25447. ], SetLeftFeature.prototype, "postConstruct", null);
  25448. return SetLeftFeature;
  25449. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  25450. /***/ }),
  25451. /* 115 */
  25452. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  25453. "use strict";
  25454. __webpack_require__.r(__webpack_exports__);
  25455. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SelectAllFeature", function() { return SelectAllFeature; });
  25456. /* harmony import */ var _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(70);
  25457. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  25458. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37);
  25459. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(43);
  25460. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(25);
  25461. /**
  25462. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  25463. * @version v23.2.1
  25464. * @link http://www.ag-grid.com/
  25465. * @license MIT
  25466. */
  25467. var __extends = (undefined && undefined.__extends) || (function () {
  25468. var extendStatics = function (d, b) {
  25469. extendStatics = Object.setPrototypeOf ||
  25470. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  25471. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  25472. return extendStatics(d, b);
  25473. };
  25474. return function (d, b) {
  25475. extendStatics(d, b);
  25476. function __() { this.constructor = d; }
  25477. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  25478. };
  25479. })();
  25480. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  25481. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  25482. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  25483. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  25484. return c > 3 && r && Object.defineProperty(target, key, r), r;
  25485. };
  25486. var SelectAllFeature = /** @class */ (function (_super) {
  25487. __extends(SelectAllFeature, _super);
  25488. function SelectAllFeature(cbSelectAll, column) {
  25489. var _this = _super.call(this) || this;
  25490. _this.cbSelectAllVisible = false;
  25491. _this.processingEventFromCheckbox = false;
  25492. _this.cbSelectAll = cbSelectAll;
  25493. _this.column = column;
  25494. var colDef = column.getColDef();
  25495. _this.filteredOnly = colDef ? !!colDef.headerCheckboxSelectionFilteredOnly : false;
  25496. return _this;
  25497. }
  25498. SelectAllFeature.prototype.postConstruct = function () {
  25499. this.showOrHideSelectAll();
  25500. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.showOrHideSelectAll.bind(this));
  25501. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_SELECTION_CHANGED, this.onSelectionChanged.bind(this));
  25502. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_MODEL_UPDATED, this.onModelChanged.bind(this));
  25503. this.addManagedListener(this.cbSelectAll, _widgets_agCheckbox__WEBPACK_IMPORTED_MODULE_0__["AgCheckbox"].EVENT_CHANGED, this.onCbSelectAll.bind(this));
  25504. };
  25505. SelectAllFeature.prototype.showOrHideSelectAll = function () {
  25506. this.cbSelectAllVisible = this.isCheckboxSelection();
  25507. this.cbSelectAll.setDisplayed(this.cbSelectAllVisible);
  25508. if (this.cbSelectAllVisible) {
  25509. // in case user is trying this feature with the wrong model type
  25510. this.checkRightRowModelType();
  25511. // make sure checkbox is showing the right state
  25512. this.updateStateOfCheckbox();
  25513. }
  25514. };
  25515. SelectAllFeature.prototype.onModelChanged = function () {
  25516. if (!this.cbSelectAllVisible) {
  25517. return;
  25518. }
  25519. this.updateStateOfCheckbox();
  25520. };
  25521. SelectAllFeature.prototype.onSelectionChanged = function () {
  25522. if (!this.cbSelectAllVisible) {
  25523. return;
  25524. }
  25525. this.updateStateOfCheckbox();
  25526. };
  25527. SelectAllFeature.prototype.getNextCheckboxState = function (selectionCount) {
  25528. // if no rows, always have it unselected
  25529. if (selectionCount.selected === 0 && selectionCount.notSelected === 0) {
  25530. return false;
  25531. }
  25532. // if mix of selected and unselected, this is the tri-state
  25533. if (selectionCount.selected > 0 && selectionCount.notSelected > 0) {
  25534. return null;
  25535. }
  25536. // only selected
  25537. if (selectionCount.selected > 0) {
  25538. return true;
  25539. }
  25540. // nothing selected
  25541. return false;
  25542. };
  25543. SelectAllFeature.prototype.updateStateOfCheckbox = function () {
  25544. if (this.processingEventFromCheckbox) {
  25545. return;
  25546. }
  25547. this.processingEventFromCheckbox = true;
  25548. var selectionCount = this.getSelectionCount();
  25549. var allSelected = this.getNextCheckboxState(selectionCount);
  25550. this.cbSelectAll.setValue(allSelected);
  25551. this.processingEventFromCheckbox = false;
  25552. };
  25553. SelectAllFeature.prototype.getSelectionCount = function () {
  25554. var _this = this;
  25555. var selectedCount = 0;
  25556. var notSelectedCount = 0;
  25557. var callback = function (node) {
  25558. if (_this.gridOptionsWrapper.isGroupSelectsChildren() && node.group) {
  25559. return;
  25560. }
  25561. if (node.isSelected()) {
  25562. selectedCount++;
  25563. }
  25564. else if (!node.selectable) {
  25565. // don't count non-selectable nodes!
  25566. }
  25567. else {
  25568. notSelectedCount++;
  25569. }
  25570. };
  25571. if (this.filteredOnly) {
  25572. this.gridApi.forEachNodeAfterFilter(callback);
  25573. }
  25574. else {
  25575. this.gridApi.forEachNode(callback);
  25576. }
  25577. return {
  25578. notSelected: notSelectedCount,
  25579. selected: selectedCount
  25580. };
  25581. };
  25582. SelectAllFeature.prototype.checkRightRowModelType = function () {
  25583. var rowModelType = this.rowModel.getType();
  25584. var rowModelMatches = rowModelType === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE;
  25585. if (!rowModelMatches) {
  25586. console.warn("ag-Grid: selectAllCheckbox is only available if using normal row model, you are using " + rowModelType);
  25587. }
  25588. };
  25589. SelectAllFeature.prototype.onCbSelectAll = function () {
  25590. if (this.processingEventFromCheckbox) {
  25591. return;
  25592. }
  25593. if (!this.cbSelectAllVisible) {
  25594. return;
  25595. }
  25596. var value = this.cbSelectAll.getValue();
  25597. if (value) {
  25598. this.selectionController.selectAllRowNodes(this.filteredOnly);
  25599. }
  25600. else {
  25601. this.selectionController.deselectAllRowNodes(this.filteredOnly);
  25602. }
  25603. };
  25604. SelectAllFeature.prototype.isCheckboxSelection = function () {
  25605. var result = this.column.getColDef().headerCheckboxSelection;
  25606. if (typeof result === 'function') {
  25607. var func = result;
  25608. result = func({
  25609. column: this.column,
  25610. colDef: this.column.getColDef(),
  25611. columnApi: this.columnApi,
  25612. api: this.gridApi
  25613. });
  25614. }
  25615. if (result) {
  25616. if (this.gridOptionsWrapper.isRowModelServerSide()) {
  25617. console.warn('headerCheckboxSelection is not supported for Server Side Row Model');
  25618. return false;
  25619. }
  25620. if (this.gridOptionsWrapper.isRowModelInfinite()) {
  25621. console.warn('headerCheckboxSelection is not supported for Infinite Row Model');
  25622. return false;
  25623. }
  25624. if (this.gridOptionsWrapper.isRowModelViewport()) {
  25625. console.warn('headerCheckboxSelection is not supported for Viewport Row Model');
  25626. return false;
  25627. }
  25628. // otherwise the row model is compatible, so return true
  25629. return true;
  25630. }
  25631. return false;
  25632. };
  25633. __decorate([
  25634. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridApi')
  25635. ], SelectAllFeature.prototype, "gridApi", void 0);
  25636. __decorate([
  25637. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnApi')
  25638. ], SelectAllFeature.prototype, "columnApi", void 0);
  25639. __decorate([
  25640. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('rowModel')
  25641. ], SelectAllFeature.prototype, "rowModel", void 0);
  25642. __decorate([
  25643. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('selectionController')
  25644. ], SelectAllFeature.prototype, "selectionController", void 0);
  25645. __decorate([
  25646. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper')
  25647. ], SelectAllFeature.prototype, "gridOptionsWrapper", void 0);
  25648. __decorate([
  25649. _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"]
  25650. ], SelectAllFeature.prototype, "postConstruct", null);
  25651. return SelectAllFeature;
  25652. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  25653. /***/ }),
  25654. /* 116 */
  25655. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  25656. "use strict";
  25657. __webpack_require__.r(__webpack_exports__);
  25658. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AbstractHeaderWrapper", function() { return AbstractHeaderWrapper; });
  25659. /* harmony import */ var _widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(117);
  25660. /**
  25661. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  25662. * @version v23.2.1
  25663. * @link http://www.ag-grid.com/
  25664. * @license MIT
  25665. */
  25666. var __extends = (undefined && undefined.__extends) || (function () {
  25667. var extendStatics = function (d, b) {
  25668. extendStatics = Object.setPrototypeOf ||
  25669. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  25670. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  25671. return extendStatics(d, b);
  25672. };
  25673. return function (d, b) {
  25674. extendStatics(d, b);
  25675. function __() { this.constructor = d; }
  25676. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  25677. };
  25678. })();
  25679. var AbstractHeaderWrapper = /** @class */ (function (_super) {
  25680. __extends(AbstractHeaderWrapper, _super);
  25681. function AbstractHeaderWrapper() {
  25682. return _super !== null && _super.apply(this, arguments) || this;
  25683. }
  25684. AbstractHeaderWrapper.prototype.getColumn = function () {
  25685. return this.column;
  25686. };
  25687. AbstractHeaderWrapper.prototype.getPinned = function () {
  25688. return this.pinned;
  25689. };
  25690. return AbstractHeaderWrapper;
  25691. }(_widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_0__["ManagedFocusComponent"]));
  25692. /***/ }),
  25693. /* 117 */
  25694. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  25695. "use strict";
  25696. __webpack_require__.r(__webpack_exports__);
  25697. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ManagedFocusComponent", function() { return ManagedFocusComponent; });
  25698. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  25699. /* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(56);
  25700. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25);
  25701. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  25702. /**
  25703. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  25704. * @version v23.2.1
  25705. * @link http://www.ag-grid.com/
  25706. * @license MIT
  25707. */
  25708. var __extends = (undefined && undefined.__extends) || (function () {
  25709. var extendStatics = function (d, b) {
  25710. extendStatics = Object.setPrototypeOf ||
  25711. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  25712. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  25713. return extendStatics(d, b);
  25714. };
  25715. return function (d, b) {
  25716. extendStatics(d, b);
  25717. function __() { this.constructor = d; }
  25718. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  25719. };
  25720. })();
  25721. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  25722. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  25723. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  25724. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  25725. return c > 3 && r && Object.defineProperty(target, key, r), r;
  25726. };
  25727. /**
  25728. * This provides logic to override the default browser focus logic.
  25729. *
  25730. * When the component gets focus, it uses the grid logic to find out what should be focused,
  25731. * and then focuses that instead.
  25732. *
  25733. * This is how we ensure when user tabs into the relevant section, we focus the correct item.
  25734. * For example GridCore extends ManagedFocusComponent, and it ensures when it receives focus
  25735. * that focus goes to the first cell of the first header row.
  25736. */
  25737. var ManagedFocusComponent = /** @class */ (function (_super) {
  25738. __extends(ManagedFocusComponent, _super);
  25739. function ManagedFocusComponent() {
  25740. var _this = _super !== null && _super.apply(this, arguments) || this;
  25741. _this.skipTabGuardFocus = false;
  25742. return _this;
  25743. }
  25744. ManagedFocusComponent.prototype.postConstruct = function () {
  25745. var focusableElement = this.getFocusableElement();
  25746. if (!focusableElement) {
  25747. return;
  25748. }
  25749. this.wireFocusManagement();
  25750. };
  25751. ManagedFocusComponent.prototype.wireFocusManagement = function () {
  25752. var _this = this;
  25753. var focusableElement = this.getFocusableElement();
  25754. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addCssClass(focusableElement, ManagedFocusComponent.FOCUS_MANAGED_CLASS);
  25755. if (this.isFocusableContainer()) {
  25756. this.topTabGuard = this.createTabGuard('top');
  25757. this.bottomTabGuard = this.createTabGuard('bottom');
  25758. this.addTabGuards();
  25759. this.activateTabGuards();
  25760. this.forEachTabGuard(function (tabGuards) {
  25761. _this.addManagedListener(tabGuards, 'focus', _this.onFocus.bind(_this));
  25762. });
  25763. }
  25764. if (this.onTabKeyDown || this.handleKeyDown) {
  25765. this.addKeyDownListeners(focusableElement);
  25766. }
  25767. this.addManagedListener(focusableElement, 'focusin', this.onFocusIn.bind(this));
  25768. this.addManagedListener(focusableElement, 'focusout', this.onFocusOut.bind(this));
  25769. };
  25770. /*
  25771. * Override this method to return true if this component will contain multiple focus-managed
  25772. * elements within. When set to true, this component will add tabGuards that will be responsible
  25773. * for receiving focus from outside and focusing an internal element using the focusInnerElementMethod
  25774. */
  25775. ManagedFocusComponent.prototype.isFocusableContainer = function () {
  25776. return false;
  25777. };
  25778. /*
  25779. * Override this method if focusing the default element requires special logic.
  25780. */
  25781. ManagedFocusComponent.prototype.focusInnerElement = function (fromBottom) {
  25782. var focusable = this.focusController.findFocusableElements(this.getFocusableElement(), '.ag-tab-guard, :not([tabindex="-1"])');
  25783. if (!focusable.length) {
  25784. return;
  25785. }
  25786. focusable[fromBottom ? focusable.length - 1 : 0].focus();
  25787. };
  25788. ManagedFocusComponent.prototype.onFocusIn = function (e) {
  25789. if (!this.isFocusableContainer()) {
  25790. return;
  25791. }
  25792. this.deactivateTabGuards();
  25793. };
  25794. ManagedFocusComponent.prototype.onFocusOut = function (e) {
  25795. if (!this.isFocusableContainer()) {
  25796. return;
  25797. }
  25798. var focusEl = this.getFocusableElement();
  25799. if (!focusEl.contains(e.relatedTarget)) {
  25800. this.activateTabGuards();
  25801. }
  25802. };
  25803. ManagedFocusComponent.prototype.forceFocusOutOfContainer = function () {
  25804. this.activateTabGuards();
  25805. this.skipTabGuardFocus = true;
  25806. this.bottomTabGuard.focus();
  25807. };
  25808. ManagedFocusComponent.prototype.appendChild = function (newChild, container) {
  25809. if (!this.isFocusableContainer()) {
  25810. _super.prototype.appendChild.call(this, newChild, container);
  25811. }
  25812. else {
  25813. if (!_utils__WEBPACK_IMPORTED_MODULE_3__["_"].isNodeOrElement(newChild)) {
  25814. newChild = newChild.getGui();
  25815. }
  25816. var bottomTabGuard = this.bottomTabGuard;
  25817. if (bottomTabGuard) {
  25818. bottomTabGuard.insertAdjacentElement('beforebegin', newChild);
  25819. }
  25820. else {
  25821. _super.prototype.appendChild.call(this, newChild, container);
  25822. }
  25823. }
  25824. };
  25825. ManagedFocusComponent.prototype.createTabGuard = function (side) {
  25826. var tabGuard = document.createElement('div');
  25827. tabGuard.classList.add('ag-tab-guard');
  25828. tabGuard.classList.add("ag-tab-guard-" + side);
  25829. return tabGuard;
  25830. };
  25831. ManagedFocusComponent.prototype.addTabGuards = function () {
  25832. var focusableEl = this.getFocusableElement();
  25833. focusableEl.insertAdjacentElement('afterbegin', this.topTabGuard);
  25834. focusableEl.insertAdjacentElement('beforeend', this.bottomTabGuard);
  25835. };
  25836. ManagedFocusComponent.prototype.forEachTabGuard = function (callback) {
  25837. [this.topTabGuard, this.bottomTabGuard].forEach(callback);
  25838. };
  25839. ManagedFocusComponent.prototype.addKeyDownListeners = function (eGui) {
  25840. var _this = this;
  25841. this.addManagedListener(eGui, 'keydown', function (e) {
  25842. if (e.defaultPrevented) {
  25843. return;
  25844. }
  25845. if (e.keyCode === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_TAB && _this.onTabKeyDown) {
  25846. _this.onTabKeyDown(e);
  25847. }
  25848. else if (_this.handleKeyDown) {
  25849. _this.handleKeyDown(e);
  25850. }
  25851. });
  25852. };
  25853. ManagedFocusComponent.prototype.onFocus = function (e) {
  25854. if (!this.isFocusableContainer()) {
  25855. return;
  25856. }
  25857. if (this.skipTabGuardFocus) {
  25858. this.skipTabGuardFocus = false;
  25859. return;
  25860. }
  25861. this.focusInnerElement(e.target === this.bottomTabGuard);
  25862. };
  25863. ManagedFocusComponent.prototype.activateTabGuards = function () {
  25864. this.forEachTabGuard(function (tabGuard) { return tabGuard.setAttribute('tabIndex', '0'); });
  25865. };
  25866. ManagedFocusComponent.prototype.deactivateTabGuards = function () {
  25867. this.forEachTabGuard(function (tabGuards) { return tabGuards.removeAttribute('tabindex'); });
  25868. };
  25869. ManagedFocusComponent.FOCUS_MANAGED_CLASS = 'ag-focus-managed';
  25870. __decorate([
  25871. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusController')
  25872. ], ManagedFocusComponent.prototype, "focusController", void 0);
  25873. __decorate([
  25874. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  25875. ], ManagedFocusComponent.prototype, "postConstruct", null);
  25876. return ManagedFocusComponent;
  25877. }(_component__WEBPACK_IMPORTED_MODULE_1__["Component"]));
  25878. /***/ }),
  25879. /* 118 */
  25880. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  25881. "use strict";
  25882. __webpack_require__.r(__webpack_exports__);
  25883. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderGroupWrapperComp", function() { return HeaderGroupWrapperComp; });
  25884. /* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(35);
  25885. /* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(34);
  25886. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25);
  25887. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(37);
  25888. /* harmony import */ var _cssClassApplier__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(112);
  25889. /* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(104);
  25890. /* harmony import */ var _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(114);
  25891. /* harmony import */ var _hoverFeature__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(113);
  25892. /* harmony import */ var _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(107);
  25893. /* harmony import */ var _header_abstractHeaderWrapper__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(116);
  25894. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(7);
  25895. /**
  25896. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  25897. * @version v23.2.1
  25898. * @link http://www.ag-grid.com/
  25899. * @license MIT
  25900. */
  25901. var __extends = (undefined && undefined.__extends) || (function () {
  25902. var extendStatics = function (d, b) {
  25903. extendStatics = Object.setPrototypeOf ||
  25904. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  25905. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  25906. return extendStatics(d, b);
  25907. };
  25908. return function (d, b) {
  25909. extendStatics(d, b);
  25910. function __() { this.constructor = d; }
  25911. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  25912. };
  25913. })();
  25914. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  25915. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  25916. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  25917. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  25918. return c > 3 && r && Object.defineProperty(target, key, r), r;
  25919. };
  25920. var HeaderGroupWrapperComp = /** @class */ (function (_super) {
  25921. __extends(HeaderGroupWrapperComp, _super);
  25922. function HeaderGroupWrapperComp(columnGroup, dragSourceDropTarget, pinned) {
  25923. var _this = _super.call(this, HeaderGroupWrapperComp.TEMPLATE) || this;
  25924. // the children can change, we keep destroy functions related to listening to the children here
  25925. _this.removeChildListenersFuncs = [];
  25926. _this.column = columnGroup;
  25927. _this.dragSourceDropTarget = dragSourceDropTarget;
  25928. _this.pinned = pinned;
  25929. return _this;
  25930. }
  25931. HeaderGroupWrapperComp.prototype.postConstruct = function () {
  25932. _super.prototype.postConstruct.call(this);
  25933. _cssClassApplier__WEBPACK_IMPORTED_MODULE_4__["CssClassApplier"].addHeaderClassesFromColDef(this.getComponentHolder(), this.getGui(), this.gridOptionsWrapper, null, this.column);
  25934. var displayName = this.columnController.getDisplayNameForColumnGroup(this.column, 'header');
  25935. this.appendHeaderGroupComp(displayName);
  25936. this.setupResize();
  25937. this.addClasses();
  25938. this.setupWidth();
  25939. this.addAttributes();
  25940. this.setupMovingCss();
  25941. this.setupTooltip();
  25942. this.createManagedBean(new _hoverFeature__WEBPACK_IMPORTED_MODULE_7__["HoverFeature"](this.column.getOriginalColumnGroup().getLeafColumns(), this.getGui()));
  25943. this.createManagedBean(new _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_6__["SetLeftFeature"](this.column, this.getGui(), this.beans));
  25944. };
  25945. HeaderGroupWrapperComp.prototype.onFocusIn = function (e) {
  25946. if (!this.getGui().contains(e.relatedTarget)) {
  25947. var headerRow = this.getParentComponent();
  25948. this.beans.focusController.setFocusedHeader(headerRow.getRowIndex(), this.getColumn());
  25949. }
  25950. };
  25951. HeaderGroupWrapperComp.prototype.handleKeyDown = function (e) {
  25952. var activeEl = document.activeElement;
  25953. var eGui = this.getGui();
  25954. var wrapperHasFocus = activeEl === eGui;
  25955. switch (e.keyCode) {
  25956. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_ENTER:
  25957. if (wrapperHasFocus) {
  25958. var column = this.getColumn();
  25959. var expandable = column.isExpandable();
  25960. if (expandable) {
  25961. var newExpandedValue = !column.isExpanded();
  25962. this.columnController.setColumnGroupOpened(column.getOriginalColumnGroup(), newExpandedValue, "uiColumnExpanded");
  25963. }
  25964. }
  25965. }
  25966. };
  25967. HeaderGroupWrapperComp.prototype.setupMovingCss = function () {
  25968. var _this = this;
  25969. var originalColumnGroup = this.column.getOriginalColumnGroup();
  25970. var leafColumns = originalColumnGroup.getLeafColumns();
  25971. leafColumns.forEach(function (col) {
  25972. _this.addManagedListener(col, _entities_column__WEBPACK_IMPORTED_MODULE_0__["Column"].EVENT_MOVING_CHANGED, _this.onColumnMovingChanged.bind(_this));
  25973. });
  25974. this.onColumnMovingChanged();
  25975. };
  25976. HeaderGroupWrapperComp.prototype.getComponentHolder = function () {
  25977. return this.column.getColGroupDef();
  25978. };
  25979. HeaderGroupWrapperComp.prototype.getTooltipText = function () {
  25980. var colGroupDef = this.getComponentHolder();
  25981. return colGroupDef && colGroupDef.headerTooltip;
  25982. };
  25983. HeaderGroupWrapperComp.prototype.setupTooltip = function () {
  25984. var tooltipText = this.getTooltipText();
  25985. if (tooltipText == null) {
  25986. return;
  25987. }
  25988. if (this.gridOptionsWrapper.isEnableBrowserTooltips()) {
  25989. this.getGui().setAttribute('title', tooltipText);
  25990. }
  25991. else {
  25992. this.createManagedBean(new _widgets_tooltipFeature__WEBPACK_IMPORTED_MODULE_8__["TooltipFeature"](this, 'headerGroup'));
  25993. }
  25994. };
  25995. HeaderGroupWrapperComp.prototype.onColumnMovingChanged = function () {
  25996. // this function adds or removes the moving css, based on if the col is moving.
  25997. // this is what makes the header go dark when it is been moved (gives impression to
  25998. // user that the column was picked up).
  25999. _utils__WEBPACK_IMPORTED_MODULE_10__["_"].addOrRemoveCssClass(this.getGui(), 'ag-header-cell-moving', this.column.isMoving());
  26000. };
  26001. HeaderGroupWrapperComp.prototype.addAttributes = function () {
  26002. this.getGui().setAttribute("col-id", this.column.getUniqueId());
  26003. };
  26004. HeaderGroupWrapperComp.prototype.appendHeaderGroupComp = function (displayName) {
  26005. var _this = this;
  26006. var params = {
  26007. displayName: displayName,
  26008. columnGroup: this.column,
  26009. setExpanded: function (expanded) {
  26010. _this.columnController.setColumnGroupOpened(_this.column.getOriginalColumnGroup(), expanded, "gridInitializing");
  26011. },
  26012. api: this.gridApi,
  26013. columnApi: this.columnApi,
  26014. context: this.gridOptionsWrapper.getContext()
  26015. };
  26016. if (!displayName) {
  26017. var columnGroup = this.column;
  26018. var leafCols = columnGroup.getLeafColumns();
  26019. // find the top most column group that represents the same columns. so if we are dragging a group, we also
  26020. // want to visually show the parent groups dragging for the same column set. for example imaging 5 levels
  26021. // of grouping, with each group only containing the next group, and the last group containing three columns,
  26022. // then when you move any group (even the lowest level group) you are in-fact moving all the groups, as all
  26023. // the groups represent the same column set.
  26024. while (columnGroup.getParent() && columnGroup.getParent().getLeafColumns().length === leafCols.length) {
  26025. columnGroup = columnGroup.getParent();
  26026. }
  26027. var colGroupDef = columnGroup.getColGroupDef();
  26028. if (colGroupDef) {
  26029. displayName = colGroupDef.headerName;
  26030. }
  26031. if (!displayName) {
  26032. displayName = leafCols ? this.columnController.getDisplayNameForColumn(leafCols[0], 'header', true) : '';
  26033. }
  26034. }
  26035. var callback = this.afterHeaderCompCreated.bind(this, displayName);
  26036. this.userComponentFactory.newHeaderGroupComponent(params).then(callback);
  26037. };
  26038. HeaderGroupWrapperComp.prototype.afterHeaderCompCreated = function (displayName, headerGroupComp) {
  26039. var _this = this;
  26040. this.getGui().appendChild(headerGroupComp.getGui());
  26041. this.addDestroyFunc(function () {
  26042. _this.getContext().destroyBean(headerGroupComp);
  26043. });
  26044. this.setupMove(headerGroupComp.getGui(), displayName);
  26045. };
  26046. HeaderGroupWrapperComp.prototype.addClasses = function () {
  26047. // having different classes below allows the style to not have a bottom border
  26048. // on the group header, if no group is specified
  26049. // columnGroup.getColGroupDef
  26050. var style = this.column.isPadding() ? 'no' : 'with';
  26051. this.addCssClass("ag-header-group-cell-" + style + "-group");
  26052. };
  26053. HeaderGroupWrapperComp.prototype.setupMove = function (eHeaderGroup, displayName) {
  26054. var _this = this;
  26055. if (!eHeaderGroup) {
  26056. return;
  26057. }
  26058. if (this.isSuppressMoving()) {
  26059. return;
  26060. }
  26061. var allLeafColumns = this.column.getOriginalColumnGroup().getLeafColumns();
  26062. var dragSource = {
  26063. type: _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_5__["DragSourceType"].HeaderCell,
  26064. eElement: eHeaderGroup,
  26065. defaultIconName: _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_5__["DragAndDropService"].ICON_HIDE,
  26066. dragItemName: displayName,
  26067. // we add in the original group leaf columns, so we move both visible and non-visible items
  26068. getDragItem: this.getDragItemForGroup.bind(this),
  26069. dragSourceDropTarget: this.dragSourceDropTarget,
  26070. onDragStarted: function () { return allLeafColumns.forEach(function (col) { return col.setMoving(true, "uiColumnDragged"); }); },
  26071. onDragStopped: function () { return allLeafColumns.forEach(function (col) { return col.setMoving(false, "uiColumnDragged"); }); }
  26072. };
  26073. this.dragAndDropService.addDragSource(dragSource, true);
  26074. this.addDestroyFunc(function () { return _this.dragAndDropService.removeDragSource(dragSource); });
  26075. };
  26076. // when moving the columns, we want to move all the columns (contained within the DragItem) in this group in one go,
  26077. // and in the order they are currently in the screen.
  26078. HeaderGroupWrapperComp.prototype.getDragItemForGroup = function () {
  26079. var allColumnsOriginalOrder = this.column.getOriginalColumnGroup().getLeafColumns();
  26080. // capture visible state, used when re-entering grid to dictate which columns should be visible
  26081. var visibleState = {};
  26082. allColumnsOriginalOrder.forEach(function (column) { return visibleState[column.getId()] = column.isVisible(); });
  26083. var allColumnsCurrentOrder = [];
  26084. this.columnController.getAllDisplayedColumns().forEach(function (column) {
  26085. if (allColumnsOriginalOrder.indexOf(column) >= 0) {
  26086. allColumnsCurrentOrder.push(column);
  26087. _utils__WEBPACK_IMPORTED_MODULE_10__["_"].removeFromArray(allColumnsOriginalOrder, column);
  26088. }
  26089. });
  26090. // we are left with non-visible columns, stick these in at the end
  26091. allColumnsOriginalOrder.forEach(function (column) { return allColumnsCurrentOrder.push(column); });
  26092. // create and return dragItem
  26093. return {
  26094. columns: allColumnsCurrentOrder,
  26095. visibleState: visibleState
  26096. };
  26097. };
  26098. HeaderGroupWrapperComp.prototype.isSuppressMoving = function () {
  26099. // if any child is fixed, then don't allow moving
  26100. var childSuppressesMoving = false;
  26101. this.column.getLeafColumns().forEach(function (column) {
  26102. if (column.getColDef().suppressMovable || column.getColDef().lockPosition) {
  26103. childSuppressesMoving = true;
  26104. }
  26105. });
  26106. var result = childSuppressesMoving || this.gridOptionsWrapper.isSuppressMovableColumns();
  26107. return result;
  26108. };
  26109. HeaderGroupWrapperComp.prototype.setupWidth = function () {
  26110. // we need to listen to changes in child columns, as they impact our width
  26111. this.addListenersToChildrenColumns();
  26112. // the children belonging to this group can change, so we need to add and remove listeners as they change
  26113. this.addManagedListener(this.column, _entities_columnGroup__WEBPACK_IMPORTED_MODULE_1__["ColumnGroup"].EVENT_DISPLAYED_CHILDREN_CHANGED, this.onDisplayedChildrenChanged.bind(this));
  26114. this.onWidthChanged();
  26115. // the child listeners are not tied to this components life-cycle, as children can get added and removed
  26116. // to the group - hence they are on a different life-cycle. so we must make sure the existing children
  26117. // listeners are removed when we finally get destroyed
  26118. this.addDestroyFunc(this.removeListenersOnChildrenColumns.bind(this));
  26119. };
  26120. HeaderGroupWrapperComp.prototype.onDisplayedChildrenChanged = function () {
  26121. this.addListenersToChildrenColumns();
  26122. this.onWidthChanged();
  26123. };
  26124. HeaderGroupWrapperComp.prototype.addListenersToChildrenColumns = function () {
  26125. var _this = this;
  26126. // first destroy any old listeners
  26127. this.removeListenersOnChildrenColumns();
  26128. // now add new listeners to the new set of children
  26129. var widthChangedListener = this.onWidthChanged.bind(this);
  26130. this.column.getLeafColumns().forEach(function (column) {
  26131. column.addEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_0__["Column"].EVENT_WIDTH_CHANGED, widthChangedListener);
  26132. column.addEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_0__["Column"].EVENT_VISIBLE_CHANGED, widthChangedListener);
  26133. _this.removeChildListenersFuncs.push(function () {
  26134. column.removeEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_0__["Column"].EVENT_WIDTH_CHANGED, widthChangedListener);
  26135. column.removeEventListener(_entities_column__WEBPACK_IMPORTED_MODULE_0__["Column"].EVENT_VISIBLE_CHANGED, widthChangedListener);
  26136. });
  26137. });
  26138. };
  26139. HeaderGroupWrapperComp.prototype.removeListenersOnChildrenColumns = function () {
  26140. this.removeChildListenersFuncs.forEach(function (func) { return func(); });
  26141. this.removeChildListenersFuncs = [];
  26142. };
  26143. HeaderGroupWrapperComp.prototype.onWidthChanged = function () {
  26144. this.getGui().style.width = this.column.getActualWidth() + 'px';
  26145. };
  26146. HeaderGroupWrapperComp.prototype.setupResize = function () {
  26147. var _this = this;
  26148. this.eHeaderCellResize = this.getRefElement('agResize');
  26149. if (!this.column.isResizable()) {
  26150. _utils__WEBPACK_IMPORTED_MODULE_10__["_"].removeFromParent(this.eHeaderCellResize);
  26151. return;
  26152. }
  26153. var finishedWithResizeFunc = this.horizontalResizeService.addResizeBar({
  26154. eResizeBar: this.eHeaderCellResize,
  26155. onResizeStart: this.onResizeStart.bind(this),
  26156. onResizing: this.onResizing.bind(this, false),
  26157. onResizeEnd: this.onResizing.bind(this, true)
  26158. });
  26159. this.addDestroyFunc(finishedWithResizeFunc);
  26160. if (!this.gridOptionsWrapper.isSuppressAutoSize()) {
  26161. var skipHeaderOnAutoSize_1 = this.gridOptionsWrapper.isSkipHeaderOnAutoSize();
  26162. this.eHeaderCellResize.addEventListener('dblclick', function (event) {
  26163. // get list of all the column keys we are responsible for
  26164. var keys = [];
  26165. _this.column.getDisplayedLeafColumns().forEach(function (column) {
  26166. // not all cols in the group may be participating with auto-resize
  26167. if (!column.getColDef().suppressAutoSize) {
  26168. keys.push(column.getColId());
  26169. }
  26170. });
  26171. if (keys.length > 0) {
  26172. _this.columnController.autoSizeColumns(keys, skipHeaderOnAutoSize_1, "uiColumnResized");
  26173. }
  26174. });
  26175. }
  26176. };
  26177. HeaderGroupWrapperComp.prototype.onResizeStart = function (shiftKey) {
  26178. var _this = this;
  26179. var leafCols = this.column.getDisplayedLeafColumns();
  26180. this.resizeCols = leafCols.filter(function (col) { return col.isResizable(); });
  26181. this.resizeStartWidth = 0;
  26182. this.resizeCols.forEach(function (col) { return _this.resizeStartWidth += col.getActualWidth(); });
  26183. this.resizeRatios = [];
  26184. this.resizeCols.forEach(function (col) { return _this.resizeRatios.push(col.getActualWidth() / _this.resizeStartWidth); });
  26185. var takeFromGroup = null;
  26186. if (shiftKey) {
  26187. takeFromGroup = this.columnController.getDisplayedGroupAfter(this.column);
  26188. }
  26189. if (takeFromGroup) {
  26190. var takeFromLeafCols = takeFromGroup.getDisplayedLeafColumns();
  26191. this.resizeTakeFromCols = takeFromLeafCols.filter(function (col) { return col.isResizable(); });
  26192. this.resizeTakeFromStartWidth = 0;
  26193. this.resizeTakeFromCols.forEach(function (col) { return _this.resizeTakeFromStartWidth += col.getActualWidth(); });
  26194. this.resizeTakeFromRatios = [];
  26195. this.resizeTakeFromCols.forEach(function (col) { return _this.resizeTakeFromRatios.push(col.getActualWidth() / _this.resizeTakeFromStartWidth); });
  26196. }
  26197. else {
  26198. this.resizeTakeFromCols = null;
  26199. this.resizeTakeFromStartWidth = null;
  26200. this.resizeTakeFromRatios = null;
  26201. }
  26202. _utils__WEBPACK_IMPORTED_MODULE_10__["_"].addCssClass(this.getGui(), 'ag-column-resizing');
  26203. };
  26204. HeaderGroupWrapperComp.prototype.onResizing = function (finished, resizeAmount) {
  26205. var resizeSets = [];
  26206. var resizeAmountNormalised = this.normaliseDragChange(resizeAmount);
  26207. resizeSets.push({
  26208. columns: this.resizeCols,
  26209. ratios: this.resizeRatios,
  26210. width: this.resizeStartWidth + resizeAmountNormalised
  26211. });
  26212. if (this.resizeTakeFromCols) {
  26213. resizeSets.push({
  26214. columns: this.resizeTakeFromCols,
  26215. ratios: this.resizeTakeFromRatios,
  26216. width: this.resizeTakeFromStartWidth - resizeAmountNormalised
  26217. });
  26218. }
  26219. this.columnController.resizeColumnSets(resizeSets, finished, 'uiColumnDragged');
  26220. if (finished) {
  26221. _utils__WEBPACK_IMPORTED_MODULE_10__["_"].removeCssClass(this.getGui(), 'ag-column-resizing');
  26222. }
  26223. };
  26224. // optionally inverts the drag, depending on pinned and RTL
  26225. // note - this method is duplicated in RenderedHeaderCell - should refactor out?
  26226. HeaderGroupWrapperComp.prototype.normaliseDragChange = function (dragChange) {
  26227. var result = dragChange;
  26228. if (this.gridOptionsWrapper.isEnableRtl()) {
  26229. // for RTL, dragging left makes the col bigger, except when pinning left
  26230. if (this.pinned !== _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_LEFT) {
  26231. result *= -1;
  26232. }
  26233. }
  26234. else if (this.pinned === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_RIGHT) {
  26235. // for LTR (ie normal), dragging left makes the col smaller, except when pinning right
  26236. result *= -1;
  26237. }
  26238. return result;
  26239. };
  26240. HeaderGroupWrapperComp.TEMPLATE = "<div class=\"ag-header-group-cell\" role=\"presentation\" tabindex=\"-1\">\n <div ref=\"agResize\" class=\"ag-header-cell-resize\" role=\"presentation\"></div>\n </div>";
  26241. __decorate([
  26242. Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('gridOptionsWrapper')
  26243. ], HeaderGroupWrapperComp.prototype, "gridOptionsWrapper", void 0);
  26244. __decorate([
  26245. Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('columnController')
  26246. ], HeaderGroupWrapperComp.prototype, "columnController", void 0);
  26247. __decorate([
  26248. Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('horizontalResizeService')
  26249. ], HeaderGroupWrapperComp.prototype, "horizontalResizeService", void 0);
  26250. __decorate([
  26251. Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('dragAndDropService')
  26252. ], HeaderGroupWrapperComp.prototype, "dragAndDropService", void 0);
  26253. __decorate([
  26254. Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('userComponentFactory')
  26255. ], HeaderGroupWrapperComp.prototype, "userComponentFactory", void 0);
  26256. __decorate([
  26257. Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('beans')
  26258. ], HeaderGroupWrapperComp.prototype, "beans", void 0);
  26259. __decorate([
  26260. Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('gridApi')
  26261. ], HeaderGroupWrapperComp.prototype, "gridApi", void 0);
  26262. __decorate([
  26263. Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('columnApi')
  26264. ], HeaderGroupWrapperComp.prototype, "columnApi", void 0);
  26265. return HeaderGroupWrapperComp;
  26266. }(_header_abstractHeaderWrapper__WEBPACK_IMPORTED_MODULE_9__["AbstractHeaderWrapper"]));
  26267. /***/ }),
  26268. /* 119 */
  26269. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  26270. "use strict";
  26271. __webpack_require__.r(__webpack_exports__);
  26272. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FloatingFilterWrapper", function() { return FloatingFilterWrapper; });
  26273. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  26274. /* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(35);
  26275. /* harmony import */ var _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(114);
  26276. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(57);
  26277. /* harmony import */ var _headerRendering_hoverFeature__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(113);
  26278. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(43);
  26279. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(7);
  26280. /* harmony import */ var _provided_readOnlyFloatingFilter__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(120);
  26281. /* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(38);
  26282. /* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(39);
  26283. /* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(12);
  26284. /* harmony import */ var _utils_icon__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(23);
  26285. /* harmony import */ var _headerRendering_header_abstractHeaderWrapper__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(116);
  26286. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(25);
  26287. /**
  26288. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  26289. * @version v23.2.1
  26290. * @link http://www.ag-grid.com/
  26291. * @license MIT
  26292. */
  26293. var __extends = (undefined && undefined.__extends) || (function () {
  26294. var extendStatics = function (d, b) {
  26295. extendStatics = Object.setPrototypeOf ||
  26296. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  26297. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  26298. return extendStatics(d, b);
  26299. };
  26300. return function (d, b) {
  26301. extendStatics(d, b);
  26302. function __() { this.constructor = d; }
  26303. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  26304. };
  26305. })();
  26306. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  26307. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  26308. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  26309. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  26310. return c > 3 && r && Object.defineProperty(target, key, r), r;
  26311. };
  26312. var FloatingFilterWrapper = /** @class */ (function (_super) {
  26313. __extends(FloatingFilterWrapper, _super);
  26314. function FloatingFilterWrapper(column, pinned) {
  26315. var _this = _super.call(this, FloatingFilterWrapper.TEMPLATE) || this;
  26316. _this.column = column;
  26317. _this.pinned = pinned;
  26318. return _this;
  26319. }
  26320. FloatingFilterWrapper.prototype.postConstruct = function () {
  26321. _super.prototype.postConstruct.call(this);
  26322. this.setupFloatingFilter();
  26323. this.setupWidth();
  26324. this.setupLeftPositioning();
  26325. this.setupColumnHover();
  26326. this.createManagedBean(new _headerRendering_hoverFeature__WEBPACK_IMPORTED_MODULE_4__["HoverFeature"]([this.column], this.getGui()));
  26327. this.addManagedListener(this.eButtonShowMainFilter, 'click', this.showParentFilter.bind(this));
  26328. };
  26329. FloatingFilterWrapper.prototype.onTabKeyDown = function (e) {
  26330. var activeEl = document.activeElement;
  26331. var eGui = this.getGui();
  26332. var wrapperHasFocus = activeEl === eGui;
  26333. if (wrapperHasFocus) {
  26334. return;
  26335. }
  26336. e.preventDefault();
  26337. var nextFocusableEl = this.focusController.findNextFocusableElement(eGui, null, e.shiftKey);
  26338. if (nextFocusableEl) {
  26339. nextFocusableEl.focus();
  26340. }
  26341. else {
  26342. eGui.focus();
  26343. }
  26344. };
  26345. FloatingFilterWrapper.prototype.handleKeyDown = function (e) {
  26346. var activeEl = document.activeElement;
  26347. var eGui = this.getGui();
  26348. var wrapperHasFocus = activeEl === eGui;
  26349. switch (e.keyCode) {
  26350. case _constants__WEBPACK_IMPORTED_MODULE_13__["Constants"].KEY_UP:
  26351. case _constants__WEBPACK_IMPORTED_MODULE_13__["Constants"].KEY_DOWN:
  26352. if (!wrapperHasFocus) {
  26353. e.preventDefault();
  26354. }
  26355. case _constants__WEBPACK_IMPORTED_MODULE_13__["Constants"].KEY_LEFT:
  26356. case _constants__WEBPACK_IMPORTED_MODULE_13__["Constants"].KEY_RIGHT:
  26357. if (wrapperHasFocus) {
  26358. return;
  26359. }
  26360. e.stopPropagation();
  26361. case _constants__WEBPACK_IMPORTED_MODULE_13__["Constants"].KEY_ENTER:
  26362. if (wrapperHasFocus) {
  26363. if (this.focusController.focusFirstFocusableElement(eGui)) {
  26364. e.preventDefault();
  26365. }
  26366. }
  26367. break;
  26368. case _constants__WEBPACK_IMPORTED_MODULE_13__["Constants"].KEY_ESCAPE:
  26369. if (!wrapperHasFocus) {
  26370. this.getGui().focus();
  26371. }
  26372. }
  26373. };
  26374. FloatingFilterWrapper.prototype.onFocusIn = function (e) {
  26375. var eGui = this.getGui();
  26376. if (!eGui.contains(e.relatedTarget)) {
  26377. var headerRow = this.getParentComponent();
  26378. this.beans.focusController.setFocusedHeader(headerRow.getRowIndex(), this.getColumn());
  26379. }
  26380. };
  26381. FloatingFilterWrapper.prototype.setupFloatingFilter = function () {
  26382. var _this = this;
  26383. var colDef = this.column.getColDef();
  26384. if (colDef.filter && colDef.floatingFilter) {
  26385. this.floatingFilterCompPromise = this.getFloatingFilterInstance();
  26386. if (this.floatingFilterCompPromise) {
  26387. this.floatingFilterCompPromise.then(function (compInstance) {
  26388. if (compInstance) {
  26389. _this.setupWithFloatingFilter(compInstance);
  26390. _this.setupSyncWithFilter();
  26391. }
  26392. else {
  26393. _this.setupEmpty();
  26394. }
  26395. });
  26396. }
  26397. else {
  26398. this.setupEmpty();
  26399. }
  26400. }
  26401. else {
  26402. this.setupEmpty();
  26403. }
  26404. };
  26405. FloatingFilterWrapper.prototype.setupLeftPositioning = function () {
  26406. var setLeftFeature = new _rendering_features_setLeftFeature__WEBPACK_IMPORTED_MODULE_2__["SetLeftFeature"](this.column, this.getGui(), this.beans);
  26407. this.createManagedBean(setLeftFeature);
  26408. };
  26409. FloatingFilterWrapper.prototype.setupSyncWithFilter = function () {
  26410. var _this = this;
  26411. var syncWithFilter = function (filterChangedEvent) {
  26412. var parentModel = _this.getFilterComponent().resolveNow(null, function (filter) { return filter.getModel(); });
  26413. _this.onParentModelChanged(parentModel, filterChangedEvent);
  26414. };
  26415. this.addManagedListener(this.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_FILTER_CHANGED, syncWithFilter);
  26416. if (this.filterManager.isFilterActive(this.column)) {
  26417. syncWithFilter(null);
  26418. }
  26419. };
  26420. // linked to event listener in template
  26421. FloatingFilterWrapper.prototype.showParentFilter = function () {
  26422. this.menuFactory.showMenuAfterButtonClick(this.column, this.eButtonShowMainFilter, 'filterMenuTab', ['filterMenuTab']);
  26423. };
  26424. FloatingFilterWrapper.prototype.setupColumnHover = function () {
  26425. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_5__["Events"].EVENT_COLUMN_HOVER_CHANGED, this.onColumnHover.bind(this));
  26426. this.onColumnHover();
  26427. };
  26428. FloatingFilterWrapper.prototype.onColumnHover = function () {
  26429. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_10__["addOrRemoveCssClass"])(this.getGui(), 'ag-column-hover', this.columnHoverService.isHovered(this.column));
  26430. };
  26431. FloatingFilterWrapper.prototype.setupWidth = function () {
  26432. this.addManagedListener(this.column, _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"].EVENT_WIDTH_CHANGED, this.onColumnWidthChanged.bind(this));
  26433. this.onColumnWidthChanged();
  26434. };
  26435. FloatingFilterWrapper.prototype.onColumnWidthChanged = function () {
  26436. this.getGui().style.width = this.column.getActualWidth() + "px";
  26437. };
  26438. FloatingFilterWrapper.prototype.setupWithFloatingFilter = function (floatingFilterComp) {
  26439. var _this = this;
  26440. var disposeFunc = function () {
  26441. _this.getContext().destroyBean(floatingFilterComp);
  26442. };
  26443. if (!this.isAlive()) {
  26444. disposeFunc();
  26445. return;
  26446. }
  26447. this.addDestroyFunc(disposeFunc);
  26448. var floatingFilterCompUi = floatingFilterComp.getGui();
  26449. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_10__["addOrRemoveCssClass"])(this.eFloatingFilterBody, 'ag-floating-filter-body', !this.suppressFilterButton);
  26450. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_10__["addOrRemoveCssClass"])(this.eFloatingFilterBody, 'ag-floating-filter-full-body', this.suppressFilterButton);
  26451. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_10__["setDisplayed"])(this.eButtonWrapper, !this.suppressFilterButton);
  26452. var eIcon = Object(_utils_icon__WEBPACK_IMPORTED_MODULE_11__["createIconNoSpan"])('filter', this.gridOptionsWrapper, this.column);
  26453. this.eButtonShowMainFilter.appendChild(eIcon);
  26454. this.eFloatingFilterBody.appendChild(floatingFilterCompUi);
  26455. if (floatingFilterComp.afterGuiAttached) {
  26456. floatingFilterComp.afterGuiAttached();
  26457. }
  26458. };
  26459. FloatingFilterWrapper.prototype.parentFilterInstance = function (callback) {
  26460. this.getFilterComponent().then(callback);
  26461. };
  26462. FloatingFilterWrapper.prototype.getFilterComponent = function () {
  26463. return this.filterManager.getFilterComponent(this.column, 'NO_UI');
  26464. };
  26465. FloatingFilterWrapper.prototype.getFloatingFilterInstance = function () {
  26466. var colDef = this.column.getColDef();
  26467. var defaultFloatingFilterType;
  26468. if (typeof colDef.filter === 'string') {
  26469. // will be undefined if not in the map
  26470. defaultFloatingFilterType = FloatingFilterWrapper.filterToFloatingFilterNames[colDef.filter];
  26471. }
  26472. else if (colDef.filterFramework) {
  26473. // If filterFramework, then grid is NOT using one of the provided filters, hence no default.
  26474. // Note: We could combine this with another part of the 'if' statement, however explicitly
  26475. // having this section makes the code easier to read.
  26476. }
  26477. else if (colDef.filter === true) {
  26478. var setFilterModuleLoaded = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_9__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_8__["ModuleNames"].SetFilterModule);
  26479. defaultFloatingFilterType = setFilterModuleLoaded ? 'agSetColumnFloatingFilter' : 'agTextColumnFloatingFilter';
  26480. }
  26481. var filterParams = this.filterManager.createFilterParams(this.column, this.column.getColDef());
  26482. var finalFilterParams = this.userComponentFactory.createFinalParams(colDef, 'filter', filterParams);
  26483. var params = {
  26484. api: this.gridApi,
  26485. column: this.column,
  26486. filterParams: finalFilterParams,
  26487. currentParentModel: this.currentParentModel.bind(this),
  26488. parentFilterInstance: this.parentFilterInstance.bind(this),
  26489. onFloatingFilterChanged: this.onFloatingFilterChanged.bind(this),
  26490. suppressFilterButton: false // This one might be overridden from the colDef
  26491. };
  26492. // this is unusual - we need a params value OUTSIDE the component the params are for.
  26493. // the params are for the floating filter component, but this property is actually for the wrapper.
  26494. this.suppressFilterButton = colDef.floatingFilterComponentParams ? !!colDef.floatingFilterComponentParams.suppressFilterButton : false;
  26495. var promise = this.userComponentFactory.newFloatingFilterComponent(colDef, params, defaultFloatingFilterType);
  26496. if (!promise) {
  26497. var filterComponent = this.getFilterComponentPrototype(colDef);
  26498. var getModelAsStringExists = filterComponent && filterComponent.prototype && filterComponent.prototype.getModelAsString;
  26499. if (getModelAsStringExists) {
  26500. var compInstance = this.userComponentFactory.createUserComponentFromConcreteClass(_provided_readOnlyFloatingFilter__WEBPACK_IMPORTED_MODULE_7__["ReadOnlyFloatingFilter"], params);
  26501. promise = _utils__WEBPACK_IMPORTED_MODULE_6__["Promise"].resolve(compInstance);
  26502. }
  26503. }
  26504. return promise;
  26505. };
  26506. FloatingFilterWrapper.prototype.createDynamicParams = function () {
  26507. return {
  26508. column: this.column,
  26509. colDef: this.column.getColDef(),
  26510. api: this.gridApi,
  26511. columnApi: this.columnApi
  26512. };
  26513. };
  26514. FloatingFilterWrapper.prototype.getFilterComponentPrototype = function (colDef) {
  26515. var resolvedComponent = this.userComponentFactory.lookupComponentClassDef(colDef, 'filter', this.createDynamicParams());
  26516. return resolvedComponent ? resolvedComponent.component : null;
  26517. };
  26518. FloatingFilterWrapper.prototype.setupEmpty = function () {
  26519. Object(_utils_dom__WEBPACK_IMPORTED_MODULE_10__["setDisplayed"])(this.eButtonWrapper, false);
  26520. };
  26521. FloatingFilterWrapper.prototype.currentParentModel = function () {
  26522. return this.getFilterComponent().resolveNow(null, function (filter) { return filter.getModel(); });
  26523. };
  26524. FloatingFilterWrapper.prototype.onParentModelChanged = function (model, filterChangedEvent) {
  26525. if (!this.floatingFilterCompPromise) {
  26526. return;
  26527. }
  26528. this.floatingFilterCompPromise.then(function (comp) { return comp.onParentModelChanged(model, filterChangedEvent); });
  26529. };
  26530. FloatingFilterWrapper.prototype.onFloatingFilterChanged = function () {
  26531. console.warn('ag-Grid: since version 21.x, how floating filters are implemented has changed. ' +
  26532. 'Instead of calling params.onFloatingFilterChanged(), get a reference to the main filter via ' +
  26533. 'params.parentFilterInstance() and then set a value on the parent filter directly.');
  26534. };
  26535. FloatingFilterWrapper.filterToFloatingFilterNames = {
  26536. set: 'agSetColumnFloatingFilter',
  26537. agSetColumnFilter: 'agSetColumnFloatingFilter',
  26538. number: 'agNumberColumnFloatingFilter',
  26539. agNumberColumnFilter: 'agNumberColumnFloatingFilter',
  26540. date: 'agDateColumnFloatingFilter',
  26541. agDateColumnFilter: 'agDateColumnFloatingFilter',
  26542. text: 'agTextColumnFloatingFilter',
  26543. agTextColumnFilter: 'agTextColumnFloatingFilter'
  26544. };
  26545. FloatingFilterWrapper.TEMPLATE = "<div class=\"ag-header-cell\" role=\"presentation\" tabindex=\"-1\">\n <div ref=\"eFloatingFilterBody\" role=\"columnheader\"></div>\n <div class=\"ag-floating-filter-button\" ref=\"eButtonWrapper\" role=\"presentation\">\n <button type=\"button\" aria-label=\"Open Filter Menu\" class=\"ag-floating-filter-button-button\" ref=\"eButtonShowMainFilter\" tabindex=\"-1\"></button>\n </div>\n </div>";
  26546. __decorate([
  26547. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnHoverService')
  26548. ], FloatingFilterWrapper.prototype, "columnHoverService", void 0);
  26549. __decorate([
  26550. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  26551. ], FloatingFilterWrapper.prototype, "gridOptionsWrapper", void 0);
  26552. __decorate([
  26553. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('userComponentFactory')
  26554. ], FloatingFilterWrapper.prototype, "userComponentFactory", void 0);
  26555. __decorate([
  26556. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi')
  26557. ], FloatingFilterWrapper.prototype, "gridApi", void 0);
  26558. __decorate([
  26559. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi')
  26560. ], FloatingFilterWrapper.prototype, "columnApi", void 0);
  26561. __decorate([
  26562. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager')
  26563. ], FloatingFilterWrapper.prototype, "filterManager", void 0);
  26564. __decorate([
  26565. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('menuFactory')
  26566. ], FloatingFilterWrapper.prototype, "menuFactory", void 0);
  26567. __decorate([
  26568. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('beans')
  26569. ], FloatingFilterWrapper.prototype, "beans", void 0);
  26570. __decorate([
  26571. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eFloatingFilterBody')
  26572. ], FloatingFilterWrapper.prototype, "eFloatingFilterBody", void 0);
  26573. __decorate([
  26574. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eButtonWrapper')
  26575. ], FloatingFilterWrapper.prototype, "eButtonWrapper", void 0);
  26576. __decorate([
  26577. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eButtonShowMainFilter')
  26578. ], FloatingFilterWrapper.prototype, "eButtonShowMainFilter", void 0);
  26579. return FloatingFilterWrapper;
  26580. }(_headerRendering_header_abstractHeaderWrapper__WEBPACK_IMPORTED_MODULE_12__["AbstractHeaderWrapper"]));
  26581. /***/ }),
  26582. /* 120 */
  26583. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  26584. "use strict";
  26585. __webpack_require__.r(__webpack_exports__);
  26586. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ReadOnlyFloatingFilter", function() { return ReadOnlyFloatingFilter; });
  26587. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56);
  26588. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57);
  26589. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37);
  26590. /**
  26591. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  26592. * @version v23.2.1
  26593. * @link http://www.ag-grid.com/
  26594. * @license MIT
  26595. */
  26596. var __extends = (undefined && undefined.__extends) || (function () {
  26597. var extendStatics = function (d, b) {
  26598. extendStatics = Object.setPrototypeOf ||
  26599. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  26600. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  26601. return extendStatics(d, b);
  26602. };
  26603. return function (d, b) {
  26604. extendStatics(d, b);
  26605. function __() { this.constructor = d; }
  26606. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  26607. };
  26608. })();
  26609. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  26610. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  26611. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  26612. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  26613. return c > 3 && r && Object.defineProperty(target, key, r), r;
  26614. };
  26615. // optional floating filter for user provided filters - instead of providing a floating filter,
  26616. // they can provide a getModelAsString() method on the filter instead. this class just displays
  26617. // the string returned from getModelAsString()
  26618. var ReadOnlyFloatingFilter = /** @class */ (function (_super) {
  26619. __extends(ReadOnlyFloatingFilter, _super);
  26620. function ReadOnlyFloatingFilter() {
  26621. return _super.call(this, /* html */ "\n <div class=\"ag-floating-filter-input\" role=\"presentation\">\n <ag-input-text-field ref=\"eFloatingFilterText\"></ag-input-text-field>\n </div>") || this;
  26622. }
  26623. // this is a user component, and IComponent has "public destroy()" as part of the interface.
  26624. // so we need to override destroy() just to make the method public.
  26625. ReadOnlyFloatingFilter.prototype.destroy = function () {
  26626. _super.prototype.destroy.call(this);
  26627. };
  26628. ReadOnlyFloatingFilter.prototype.init = function (params) {
  26629. this.params = params;
  26630. var displayName = this.columnController.getDisplayNameForColumn(params.column, 'header', true);
  26631. this.eFloatingFilterText
  26632. .setDisabled(true)
  26633. .setInputAriaLabel(displayName + " Filter Input");
  26634. };
  26635. ReadOnlyFloatingFilter.prototype.onParentModelChanged = function (parentModel) {
  26636. var _this = this;
  26637. if (!parentModel) {
  26638. this.eFloatingFilterText.setValue('');
  26639. return;
  26640. }
  26641. this.params.parentFilterInstance(function (filterInstance) {
  26642. // getModelAsString should be present, as we check this
  26643. // in floatingFilterWrapper
  26644. if (filterInstance.getModelAsString) {
  26645. var modelAsString = filterInstance.getModelAsString(parentModel);
  26646. _this.eFloatingFilterText.setValue(modelAsString);
  26647. }
  26648. });
  26649. };
  26650. __decorate([
  26651. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eFloatingFilterText')
  26652. ], ReadOnlyFloatingFilter.prototype, "eFloatingFilterText", void 0);
  26653. __decorate([
  26654. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnController')
  26655. ], ReadOnlyFloatingFilter.prototype, "columnController", void 0);
  26656. return ReadOnlyFloatingFilter;
  26657. }(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"]));
  26658. /***/ }),
  26659. /* 121 */
  26660. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  26661. "use strict";
  26662. __webpack_require__.r(__webpack_exports__);
  26663. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BodyDropTarget", function() { return BodyDropTarget; });
  26664. /* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(104);
  26665. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  26666. /* harmony import */ var _moveColumnController__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(122);
  26667. /* harmony import */ var _bodyDropPivotTarget__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(123);
  26668. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(25);
  26669. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(41);
  26670. /**
  26671. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  26672. * @version v23.2.1
  26673. * @link http://www.ag-grid.com/
  26674. * @license MIT
  26675. */
  26676. var __extends = (undefined && undefined.__extends) || (function () {
  26677. var extendStatics = function (d, b) {
  26678. extendStatics = Object.setPrototypeOf ||
  26679. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  26680. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  26681. return extendStatics(d, b);
  26682. };
  26683. return function (d, b) {
  26684. extendStatics(d, b);
  26685. function __() { this.constructor = d; }
  26686. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  26687. };
  26688. })();
  26689. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  26690. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  26691. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  26692. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  26693. return c > 3 && r && Object.defineProperty(target, key, r), r;
  26694. };
  26695. var DropType;
  26696. (function (DropType) {
  26697. DropType[DropType["ColumnMove"] = 0] = "ColumnMove";
  26698. DropType[DropType["Pivot"] = 1] = "Pivot";
  26699. })(DropType || (DropType = {}));
  26700. var BodyDropTarget = /** @class */ (function (_super) {
  26701. __extends(BodyDropTarget, _super);
  26702. function BodyDropTarget(pinned, eContainer) {
  26703. var _this = _super.call(this) || this;
  26704. _this.dropListeners = {};
  26705. _this.pinned = pinned;
  26706. _this.eContainer = eContainer;
  26707. return _this;
  26708. }
  26709. BodyDropTarget.prototype.registerGridComp = function (gridPanel) {
  26710. this.gridPanel = gridPanel;
  26711. this.moveColumnController.registerGridComp(gridPanel);
  26712. switch (this.pinned) {
  26713. case _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_LEFT:
  26714. this.eSecondaryContainers = this.gridPanel.getDropTargetLeftContainers();
  26715. break;
  26716. case _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].PINNED_RIGHT:
  26717. this.eSecondaryContainers = this.gridPanel.getDropTargetRightContainers();
  26718. break;
  26719. default:
  26720. this.eSecondaryContainers = this.gridPanel.getDropTargetBodyContainers();
  26721. break;
  26722. }
  26723. };
  26724. BodyDropTarget.prototype.isInterestedIn = function (type) {
  26725. return type === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragSourceType"].HeaderCell ||
  26726. (type === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragSourceType"].ToolPanel && this.gridOptionsWrapper.isAllowDragFromColumnsToolPanel());
  26727. };
  26728. BodyDropTarget.prototype.getSecondaryContainers = function () {
  26729. return this.eSecondaryContainers;
  26730. };
  26731. BodyDropTarget.prototype.getContainer = function () {
  26732. return this.eContainer;
  26733. };
  26734. BodyDropTarget.prototype.init = function () {
  26735. this.moveColumnController = this.createBean(new _moveColumnController__WEBPACK_IMPORTED_MODULE_2__["MoveColumnController"](this.pinned, this.eContainer));
  26736. var bodyDropPivotTarget = new _bodyDropPivotTarget__WEBPACK_IMPORTED_MODULE_3__["BodyDropPivotTarget"](this.pinned);
  26737. this.createBean(bodyDropPivotTarget);
  26738. this.dropListeners[DropType.ColumnMove] = this.moveColumnController;
  26739. this.dropListeners[DropType.Pivot] = bodyDropPivotTarget;
  26740. this.dragAndDropService.addDropTarget(this);
  26741. };
  26742. BodyDropTarget.prototype.getIconName = function () {
  26743. return this.currentDropListener.getIconName();
  26744. };
  26745. // we want to use the bodyPivotTarget if the user is dragging columns in from the toolPanel
  26746. // and we are in pivot mode, as it has to logic to set pivot/value/group on the columns when
  26747. // dropped into the grid's body.
  26748. BodyDropTarget.prototype.getDropType = function (draggingEvent) {
  26749. if (this.columnController.isPivotMode()) {
  26750. // in pivot mode, then if moving a column (ie didn't come from toolpanel) then it's
  26751. // a standard column move, however if it came from the toolpanel, then we are introducing
  26752. // dimensions or values to the grid
  26753. if (draggingEvent.dragSource.type === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragSourceType"].ToolPanel) {
  26754. return DropType.Pivot;
  26755. }
  26756. return DropType.ColumnMove;
  26757. }
  26758. // it's a column, and not pivot mode, so always moving
  26759. return DropType.ColumnMove;
  26760. };
  26761. BodyDropTarget.prototype.onDragEnter = function (draggingEvent) {
  26762. // we pick the drop listener depending on whether we are in pivot mode are not. if we are
  26763. // in pivot mode, then dropping cols changes the row group, pivot, value stats. otherwise
  26764. // we change visibility state and position.
  26765. // if (this.columnController.isPivotMode()) {
  26766. var dropType = this.getDropType(draggingEvent);
  26767. this.currentDropListener = this.dropListeners[dropType];
  26768. this.currentDropListener.onDragEnter(draggingEvent);
  26769. };
  26770. BodyDropTarget.prototype.onDragLeave = function (params) {
  26771. this.currentDropListener.onDragLeave(params);
  26772. };
  26773. BodyDropTarget.prototype.onDragging = function (params) {
  26774. this.currentDropListener.onDragging(params);
  26775. };
  26776. BodyDropTarget.prototype.onDragStop = function (params) {
  26777. this.currentDropListener.onDragStop(params);
  26778. };
  26779. __decorate([
  26780. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('dragAndDropService')
  26781. ], BodyDropTarget.prototype, "dragAndDropService", void 0);
  26782. __decorate([
  26783. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController')
  26784. ], BodyDropTarget.prototype, "columnController", void 0);
  26785. __decorate([
  26786. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  26787. ], BodyDropTarget.prototype, "gridOptionsWrapper", void 0);
  26788. __decorate([
  26789. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  26790. ], BodyDropTarget.prototype, "init", null);
  26791. return BodyDropTarget;
  26792. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_5__["BeanStub"]));
  26793. /***/ }),
  26794. /* 122 */
  26795. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  26796. "use strict";
  26797. __webpack_require__.r(__webpack_exports__);
  26798. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MoveColumnController", function() { return MoveColumnController; });
  26799. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  26800. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(25);
  26801. /* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(104);
  26802. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  26803. /**
  26804. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  26805. * @version v23.2.1
  26806. * @link http://www.ag-grid.com/
  26807. * @license MIT
  26808. */
  26809. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  26810. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  26811. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  26812. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  26813. return c > 3 && r && Object.defineProperty(target, key, r), r;
  26814. };
  26815. var MoveColumnController = /** @class */ (function () {
  26816. function MoveColumnController(pinned, eContainer) {
  26817. this.needToMoveLeft = false;
  26818. this.needToMoveRight = false;
  26819. this.pinned = pinned;
  26820. this.eContainer = eContainer;
  26821. this.centerContainer = !_utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(pinned);
  26822. }
  26823. MoveColumnController.prototype.registerGridComp = function (gridPanel) {
  26824. this.gridPanel = gridPanel;
  26825. };
  26826. MoveColumnController.prototype.init = function () {
  26827. this.logger = this.loggerFactory.create('MoveColumnController');
  26828. };
  26829. MoveColumnController.prototype.getIconName = function () {
  26830. return this.pinned ? _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_PINNED : _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_MOVE;
  26831. };
  26832. MoveColumnController.prototype.onDragEnter = function (draggingEvent) {
  26833. // we do dummy drag, so make sure column appears in the right location when first placed
  26834. var columns = draggingEvent.dragItem.columns;
  26835. var dragCameFromToolPanel = draggingEvent.dragSource.type === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragSourceType"].ToolPanel;
  26836. if (dragCameFromToolPanel) {
  26837. // the if statement doesn't work if drag leaves grid, then enters again
  26838. this.setColumnsVisible(columns, true, "uiColumnDragged");
  26839. }
  26840. else {
  26841. // restore previous state of visible columns upon re-entering. this means if the user drags
  26842. // a group out, and then drags the group back in, only columns that were originally visible
  26843. // will be visible again. otherwise a group with three columns (but only two visible) could
  26844. // be dragged out, then when it's dragged in again, all three are visible. this stops that.
  26845. var visibleState_1 = draggingEvent.dragItem.visibleState;
  26846. var visibleColumns = columns.filter(function (column) { return visibleState_1[column.getId()]; });
  26847. this.setColumnsVisible(visibleColumns, true, "uiColumnDragged");
  26848. }
  26849. this.setColumnsPinned(columns, this.pinned, "uiColumnDragged");
  26850. this.onDragging(draggingEvent, true);
  26851. };
  26852. MoveColumnController.prototype.onDragLeave = function (draggingEvent) {
  26853. var hideColumnOnExit = !this.gridOptionsWrapper.isSuppressDragLeaveHidesColumns() && !draggingEvent.fromNudge;
  26854. if (hideColumnOnExit) {
  26855. var dragItem = draggingEvent.dragSource.getDragItem();
  26856. var columns = dragItem.columns;
  26857. this.setColumnsVisible(columns, false, "uiColumnDragged");
  26858. }
  26859. this.ensureIntervalCleared();
  26860. };
  26861. MoveColumnController.prototype.setColumnsVisible = function (columns, visible, source) {
  26862. if (source === void 0) { source = "api"; }
  26863. if (columns) {
  26864. var allowedCols = columns.filter(function (c) { return !c.getColDef().lockVisible; });
  26865. this.columnController.setColumnsVisible(allowedCols, visible, source);
  26866. }
  26867. };
  26868. MoveColumnController.prototype.setColumnsPinned = function (columns, pinned, source) {
  26869. if (source === void 0) { source = "api"; }
  26870. if (columns) {
  26871. var allowedCols = columns.filter(function (c) { return !c.getColDef().lockPinned; });
  26872. this.columnController.setColumnsPinned(allowedCols, pinned, source);
  26873. }
  26874. };
  26875. MoveColumnController.prototype.onDragStop = function () {
  26876. this.ensureIntervalCleared();
  26877. };
  26878. MoveColumnController.prototype.normaliseX = function (x) {
  26879. // flip the coordinate if doing RTL
  26880. if (this.gridOptionsWrapper.isEnableRtl()) {
  26881. var clientWidth = this.eContainer.clientWidth;
  26882. x = clientWidth - x;
  26883. }
  26884. // adjust for scroll only if centre container (the pinned containers don't scroll)
  26885. if (this.centerContainer) {
  26886. x += this.gridPanel.getCenterViewportScrollLeft();
  26887. }
  26888. return x;
  26889. };
  26890. MoveColumnController.prototype.checkCenterForScrolling = function (xAdjustedForScroll) {
  26891. if (this.centerContainer) {
  26892. // scroll if the mouse has gone outside the grid (or just outside the scrollable part if pinning)
  26893. // putting in 50 buffer, so even if user gets to edge of grid, a scroll will happen
  26894. var firstVisiblePixel = this.gridPanel.getCenterViewportScrollLeft();
  26895. var lastVisiblePixel = firstVisiblePixel + this.gridPanel.getCenterWidth();
  26896. if (this.gridOptionsWrapper.isEnableRtl()) {
  26897. this.needToMoveRight = xAdjustedForScroll < (firstVisiblePixel + 50);
  26898. this.needToMoveLeft = xAdjustedForScroll > (lastVisiblePixel - 50);
  26899. }
  26900. else {
  26901. this.needToMoveLeft = xAdjustedForScroll < (firstVisiblePixel + 50);
  26902. this.needToMoveRight = xAdjustedForScroll > (lastVisiblePixel - 50);
  26903. }
  26904. if (this.needToMoveLeft || this.needToMoveRight) {
  26905. this.ensureIntervalStarted();
  26906. }
  26907. else {
  26908. this.ensureIntervalCleared();
  26909. }
  26910. }
  26911. };
  26912. MoveColumnController.prototype.onDragging = function (draggingEvent, fromEnter) {
  26913. var _this = this;
  26914. if (fromEnter === void 0) { fromEnter = false; }
  26915. this.lastDraggingEvent = draggingEvent;
  26916. // if moving up or down (ie not left or right) then do nothing
  26917. if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].missing(draggingEvent.hDirection)) {
  26918. return;
  26919. }
  26920. var mouseXNormalised = this.normaliseX(draggingEvent.x);
  26921. // if the user is dragging into the panel, ie coming from the side panel into the main grid,
  26922. // we don't want to scroll the grid this time, it would appear like the table is jumping
  26923. // each time a column is dragged in.
  26924. if (!fromEnter) {
  26925. this.checkCenterForScrolling(mouseXNormalised);
  26926. }
  26927. var hDirectionNormalised = this.normaliseDirection(draggingEvent.hDirection);
  26928. var dragSourceType = draggingEvent.dragSource.type;
  26929. var columnsToMove = draggingEvent.dragSource.getDragItem().columns;
  26930. columnsToMove = columnsToMove.filter(function (col) {
  26931. if (col.getColDef().lockPinned) {
  26932. // if locked return true only if both col and container are same pin type.
  26933. // double equals (==) here on purpose so that null==undefined is true (for not pinned options)
  26934. return col.getPinned() == _this.pinned;
  26935. }
  26936. else {
  26937. // if not pin locked, then always allowed to be in this container
  26938. return true;
  26939. }
  26940. });
  26941. this.attemptMoveColumns(dragSourceType, columnsToMove, hDirectionNormalised, mouseXNormalised, fromEnter);
  26942. };
  26943. MoveColumnController.prototype.normaliseDirection = function (hDirection) {
  26944. if (this.gridOptionsWrapper.isEnableRtl()) {
  26945. switch (hDirection) {
  26946. case _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["HorizontalDirection"].Left: return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["HorizontalDirection"].Right;
  26947. case _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["HorizontalDirection"].Right: return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["HorizontalDirection"].Left;
  26948. default: console.error("ag-Grid: Unknown direction " + hDirection);
  26949. }
  26950. }
  26951. else {
  26952. return hDirection;
  26953. }
  26954. };
  26955. // returns the index of the first column in the list ONLY if the cols are all beside
  26956. // each other. if the cols are not beside each other, then returns null
  26957. MoveColumnController.prototype.calculateOldIndex = function (movingCols) {
  26958. var gridCols = this.columnController.getAllGridColumns();
  26959. var indexes = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].sortNumerically(movingCols.map(function (col) { return gridCols.indexOf(col); }));
  26960. var firstIndex = indexes[0];
  26961. var lastIndex = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].last(indexes);
  26962. var spread = lastIndex - firstIndex;
  26963. var gapsExist = spread !== indexes.length - 1;
  26964. return gapsExist ? null : firstIndex;
  26965. };
  26966. MoveColumnController.prototype.attemptMoveColumns = function (dragSourceType, allMovingColumns, hDirection, mouseX, fromEnter) {
  26967. var draggingLeft = hDirection === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["HorizontalDirection"].Left;
  26968. var draggingRight = hDirection === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["HorizontalDirection"].Right;
  26969. var validMoves = this.calculateValidMoves(allMovingColumns, draggingRight, mouseX);
  26970. // if cols are not adjacent, then this returns null. when moving, we constrain the direction of the move
  26971. // (ie left or right) to the mouse direction. however
  26972. var oldIndex = this.calculateOldIndex(allMovingColumns);
  26973. if (validMoves.length === 0) {
  26974. return;
  26975. }
  26976. var firstValidMove = validMoves[0];
  26977. // the two check below stop an error when the user grabs a group my a middle column, then
  26978. // it is possible the mouse pointer is to the right of a column while been dragged left.
  26979. // so we need to make sure that the mouse pointer is actually left of the left most column
  26980. // if moving left, and right of the right most column if moving right
  26981. // we check 'fromEnter' below so we move the column to the new spot if the mouse is coming from
  26982. // outside the grid, eg if the column is moving from side panel, mouse is moving left, then we should
  26983. // place the column to the RHS even if the mouse is moving left and the column is already on
  26984. // the LHS. otherwise we stick to the rule described above.
  26985. var constrainDirection = oldIndex !== null && !fromEnter;
  26986. // don't consider 'fromEnter' when dragging header cells, otherwise group can jump to opposite direction of drag
  26987. if (dragSourceType == _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragSourceType"].HeaderCell) {
  26988. constrainDirection = oldIndex !== null;
  26989. }
  26990. if (constrainDirection) {
  26991. // only allow left drag if this column is moving left
  26992. if (draggingLeft && firstValidMove >= oldIndex) {
  26993. return;
  26994. }
  26995. // only allow right drag if this column is moving right
  26996. if (draggingRight && firstValidMove <= oldIndex) {
  26997. return;
  26998. }
  26999. }
  27000. for (var i = 0; i < validMoves.length; i++) {
  27001. var move = validMoves[i];
  27002. if (!this.columnController.doesMovePassRules(allMovingColumns, move)) {
  27003. continue;
  27004. }
  27005. this.columnController.moveColumns(allMovingColumns, move, "uiColumnDragged");
  27006. // important to return here, so once we do the first valid move, we don't try do any more
  27007. return;
  27008. }
  27009. };
  27010. MoveColumnController.prototype.calculateValidMoves = function (movingCols, draggingRight, mouseX) {
  27011. var isMoveBlocked = this.gridOptionsWrapper.isSuppressMovableColumns() || movingCols.some(function (col) { return col.getColDef().suppressMovable; });
  27012. if (isMoveBlocked) {
  27013. return [];
  27014. }
  27015. // this is the list of cols on the screen, so it's these we use when comparing the x mouse position
  27016. var allDisplayedCols = this.columnController.getDisplayedColumns(this.pinned);
  27017. // but this list is the list of all cols, when we move a col it's the index within this list that gets used,
  27018. // so the result we return has to be and index location for this list
  27019. var allGridCols = this.columnController.getAllGridColumns();
  27020. var movingDisplayedCols = allDisplayedCols.filter(function (col) { return _utils__WEBPACK_IMPORTED_MODULE_3__["_"].includes(movingCols, col); });
  27021. var otherDisplayedCols = allDisplayedCols.filter(function (col) { return !_utils__WEBPACK_IMPORTED_MODULE_3__["_"].includes(movingCols, col); });
  27022. var otherGridCols = allGridCols.filter(function (col) { return !_utils__WEBPACK_IMPORTED_MODULE_3__["_"].includes(movingCols, col); });
  27023. // work out how many DISPLAYED columns fit before the 'x' position. this gives us the displayIndex.
  27024. // for example, if cols are a,b,c,d and we find a,b fit before 'x', then we want to place the moving
  27025. // col between b and c (so that it is under the mouse position).
  27026. var displayIndex = 0;
  27027. var availableWidth = mouseX;
  27028. // if we are dragging right, then the columns will be to the left of the mouse, so we also want to
  27029. // include the width of the moving columns
  27030. if (draggingRight) {
  27031. var widthOfMovingDisplayedCols_1 = 0;
  27032. movingDisplayedCols.forEach(function (col) { return widthOfMovingDisplayedCols_1 += col.getActualWidth(); });
  27033. availableWidth -= widthOfMovingDisplayedCols_1;
  27034. }
  27035. if (availableWidth > 0) {
  27036. // now count how many of the displayed columns will fit to the left
  27037. for (var i = 0; i < otherDisplayedCols.length; i++) {
  27038. var col = otherDisplayedCols[i];
  27039. availableWidth -= col.getActualWidth();
  27040. if (availableWidth < 0) {
  27041. break;
  27042. }
  27043. displayIndex++;
  27044. }
  27045. // trial and error, if going right, we adjust by one, i didn't manage to quantify why, but it works
  27046. if (draggingRight) {
  27047. displayIndex++;
  27048. }
  27049. }
  27050. // the display index is with respect to all the showing columns, however when we move, it's with
  27051. // respect to all grid columns, so we need to translate from display index to grid index
  27052. var firstValidMove;
  27053. if (displayIndex > 0) {
  27054. var leftColumn = otherDisplayedCols[displayIndex - 1];
  27055. firstValidMove = otherGridCols.indexOf(leftColumn) + 1;
  27056. }
  27057. else {
  27058. firstValidMove = otherGridCols.indexOf(otherDisplayedCols[0]);
  27059. if (firstValidMove === -1) {
  27060. firstValidMove = 0;
  27061. }
  27062. }
  27063. var validMoves = [firstValidMove];
  27064. // add in other valid moves due to hidden columns and married children. for example, a particular
  27065. // move might break a group that has married children (so move isn't valid), however there could
  27066. // be hidden columns (not displayed) that we could jump over to make the move valid. because
  27067. // they are hidden, user doesn't see any different, however it allows moves that would otherwise
  27068. // not work. for example imagine a group with 9 columns and all columns are hidden except the
  27069. // middle one (so 4 hidden to left, 4 hidden to right), then when moving 'firstValidMove' will
  27070. // be relative to the not-shown column, however we need to consider the move jumping over all the
  27071. // hidden children. if we didn't do this, then if the group just described was at the end (RHS) of the
  27072. // grid, there would be no way to put a column after it (as the grid would only consider beside the
  27073. // visible column, which would fail valid move rules).
  27074. if (draggingRight) {
  27075. // if dragging right, then we add all the additional moves to the right. so in other words
  27076. // if the next move is not valid, find the next move to the right that is valid.
  27077. var pointer = firstValidMove + 1;
  27078. var lastIndex = allGridCols.length - 1;
  27079. while (pointer <= lastIndex) {
  27080. validMoves.push(pointer);
  27081. pointer++;
  27082. }
  27083. }
  27084. else {
  27085. // if dragging left we do the reverse of dragging right, we add in all the valid moves to the
  27086. // left. however we also have to consider moves to the right for all hidden columns first.
  27087. // (this logic is hard to reason with, it was worked out with trial and error,
  27088. // move observation rather than science).
  27089. // add moves to the right
  27090. var pointer = firstValidMove;
  27091. var lastIndex = allGridCols.length - 1;
  27092. var displacedCol = allGridCols[pointer];
  27093. while (pointer <= lastIndex && this.isColumnHidden(allDisplayedCols, displacedCol)) {
  27094. pointer++;
  27095. validMoves.push(pointer);
  27096. displacedCol = allGridCols[pointer];
  27097. }
  27098. // add moves to the left
  27099. pointer = firstValidMove - 1;
  27100. var firstDisplayIndex = 0;
  27101. while (pointer >= firstDisplayIndex) {
  27102. validMoves.push(pointer);
  27103. pointer--;
  27104. }
  27105. }
  27106. return validMoves;
  27107. };
  27108. // isHidden takes into account visible=false and group=closed, ie it is not displayed
  27109. MoveColumnController.prototype.isColumnHidden = function (displayedColumns, col) {
  27110. return displayedColumns.indexOf(col) < 0;
  27111. };
  27112. MoveColumnController.prototype.ensureIntervalStarted = function () {
  27113. if (!this.movingIntervalId) {
  27114. this.intervalCount = 0;
  27115. this.failedMoveAttempts = 0;
  27116. this.movingIntervalId = window.setInterval(this.moveInterval.bind(this), 100);
  27117. if (this.needToMoveLeft) {
  27118. this.dragAndDropService.setGhostIcon(_dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_LEFT, true);
  27119. }
  27120. else {
  27121. this.dragAndDropService.setGhostIcon(_dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_RIGHT, true);
  27122. }
  27123. }
  27124. };
  27125. MoveColumnController.prototype.ensureIntervalCleared = function () {
  27126. if (this.moveInterval) {
  27127. window.clearInterval(this.movingIntervalId);
  27128. this.movingIntervalId = null;
  27129. this.dragAndDropService.setGhostIcon(_dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_MOVE);
  27130. }
  27131. };
  27132. MoveColumnController.prototype.moveInterval = function () {
  27133. // the amounts we move get bigger at each interval, so the speed accelerates, starting a bit slow
  27134. // and getting faster. this is to give smoother user experience. we max at 100px to limit the speed.
  27135. var pixelsToMove;
  27136. this.intervalCount++;
  27137. pixelsToMove = 10 + (this.intervalCount * 5);
  27138. if (pixelsToMove > 100) {
  27139. pixelsToMove = 100;
  27140. }
  27141. var pixelsMoved;
  27142. if (this.needToMoveLeft) {
  27143. pixelsMoved = this.gridPanel.scrollHorizontally(-pixelsToMove);
  27144. }
  27145. else if (this.needToMoveRight) {
  27146. pixelsMoved = this.gridPanel.scrollHorizontally(pixelsToMove);
  27147. }
  27148. if (pixelsMoved !== 0) {
  27149. this.onDragging(this.lastDraggingEvent);
  27150. this.failedMoveAttempts = 0;
  27151. }
  27152. else {
  27153. // we count the failed move attempts. if we fail to move 7 times, then we pin the column.
  27154. // this is how we achieve pining by dragging the column to the edge of the grid.
  27155. this.failedMoveAttempts++;
  27156. var columns = this.lastDraggingEvent.dragItem.columns;
  27157. var columnsThatCanPin = columns.filter(function (c) { return !c.getColDef().lockPinned; });
  27158. if (columnsThatCanPin.length > 0) {
  27159. this.dragAndDropService.setGhostIcon(_dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_2__["DragAndDropService"].ICON_PINNED);
  27160. if (this.failedMoveAttempts > 7) {
  27161. var pinType = this.needToMoveLeft ? _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].PINNED_LEFT : _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].PINNED_RIGHT;
  27162. this.setColumnsPinned(columnsThatCanPin, pinType, "uiColumnDragged");
  27163. this.dragAndDropService.nudge();
  27164. }
  27165. }
  27166. }
  27167. };
  27168. __decorate([
  27169. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('loggerFactory')
  27170. ], MoveColumnController.prototype, "loggerFactory", void 0);
  27171. __decorate([
  27172. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController')
  27173. ], MoveColumnController.prototype, "columnController", void 0);
  27174. __decorate([
  27175. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('dragAndDropService')
  27176. ], MoveColumnController.prototype, "dragAndDropService", void 0);
  27177. __decorate([
  27178. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  27179. ], MoveColumnController.prototype, "gridOptionsWrapper", void 0);
  27180. __decorate([
  27181. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  27182. ], MoveColumnController.prototype, "init", null);
  27183. return MoveColumnController;
  27184. }());
  27185. /***/ }),
  27186. /* 123 */
  27187. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  27188. "use strict";
  27189. __webpack_require__.r(__webpack_exports__);
  27190. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BodyDropPivotTarget", function() { return BodyDropPivotTarget; });
  27191. /* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(104);
  27192. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  27193. /**
  27194. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  27195. * @version v23.2.1
  27196. * @link http://www.ag-grid.com/
  27197. * @license MIT
  27198. */
  27199. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  27200. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  27201. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  27202. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  27203. return c > 3 && r && Object.defineProperty(target, key, r), r;
  27204. };
  27205. var BodyDropPivotTarget = /** @class */ (function () {
  27206. function BodyDropPivotTarget(pinned) {
  27207. this.columnsToAggregate = [];
  27208. this.columnsToGroup = [];
  27209. this.columnsToPivot = [];
  27210. this.pinned = pinned;
  27211. }
  27212. /** Callback for when drag enters */
  27213. BodyDropPivotTarget.prototype.onDragEnter = function (draggingEvent) {
  27214. var _this = this;
  27215. this.clearColumnsList();
  27216. // in pivot mode, we don't accept any drops if functions are read only
  27217. if (this.gridOptionsWrapper.isFunctionsReadOnly()) {
  27218. return;
  27219. }
  27220. var dragColumns = draggingEvent.dragItem.columns;
  27221. dragColumns.forEach(function (column) {
  27222. // we don't allow adding secondary columns
  27223. if (!column.isPrimary()) {
  27224. return;
  27225. }
  27226. if (column.isAnyFunctionActive()) {
  27227. return;
  27228. }
  27229. if (column.isAllowValue()) {
  27230. _this.columnsToAggregate.push(column);
  27231. }
  27232. else if (column.isAllowRowGroup()) {
  27233. _this.columnsToGroup.push(column);
  27234. }
  27235. else if (column.isAllowRowGroup()) {
  27236. _this.columnsToPivot.push(column);
  27237. }
  27238. });
  27239. };
  27240. BodyDropPivotTarget.prototype.getIconName = function () {
  27241. var totalColumns = this.columnsToAggregate.length + this.columnsToGroup.length + this.columnsToPivot.length;
  27242. if (totalColumns > 0) {
  27243. return this.pinned ? _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragAndDropService"].ICON_PINNED : _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragAndDropService"].ICON_MOVE;
  27244. }
  27245. else {
  27246. return null;
  27247. }
  27248. };
  27249. /** Callback for when drag leaves */
  27250. BodyDropPivotTarget.prototype.onDragLeave = function (draggingEvent) {
  27251. // if we are taking columns out of the center, then we remove them from the report
  27252. this.clearColumnsList();
  27253. };
  27254. BodyDropPivotTarget.prototype.clearColumnsList = function () {
  27255. this.columnsToAggregate.length = 0;
  27256. this.columnsToGroup.length = 0;
  27257. this.columnsToPivot.length = 0;
  27258. };
  27259. /** Callback for when dragging */
  27260. BodyDropPivotTarget.prototype.onDragging = function (draggingEvent) {
  27261. };
  27262. /** Callback for when drag stops */
  27263. BodyDropPivotTarget.prototype.onDragStop = function (draggingEvent) {
  27264. if (this.columnsToAggregate.length > 0) {
  27265. this.columnController.addValueColumns(this.columnsToAggregate, "toolPanelDragAndDrop");
  27266. }
  27267. if (this.columnsToGroup.length > 0) {
  27268. this.columnController.addRowGroupColumns(this.columnsToGroup, "toolPanelDragAndDrop");
  27269. }
  27270. if (this.columnsToPivot.length > 0) {
  27271. this.columnController.addPivotColumns(this.columnsToPivot, "toolPanelDragAndDrop");
  27272. }
  27273. };
  27274. __decorate([
  27275. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController')
  27276. ], BodyDropPivotTarget.prototype, "columnController", void 0);
  27277. __decorate([
  27278. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  27279. ], BodyDropPivotTarget.prototype, "gridOptionsWrapper", void 0);
  27280. return BodyDropPivotTarget;
  27281. }());
  27282. /***/ }),
  27283. /* 124 */
  27284. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  27285. "use strict";
  27286. __webpack_require__.r(__webpack_exports__);
  27287. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderNavigationDirection", function() { return HeaderNavigationDirection; });
  27288. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderNavigationService", function() { return HeaderNavigationService; });
  27289. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  27290. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  27291. /* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(34);
  27292. /* harmony import */ var _headerRowComp__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(110);
  27293. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7);
  27294. /**
  27295. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  27296. * @version v23.2.1
  27297. * @link http://www.ag-grid.com/
  27298. * @license MIT
  27299. */
  27300. var __extends = (undefined && undefined.__extends) || (function () {
  27301. var extendStatics = function (d, b) {
  27302. extendStatics = Object.setPrototypeOf ||
  27303. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  27304. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  27305. return extendStatics(d, b);
  27306. };
  27307. return function (d, b) {
  27308. extendStatics(d, b);
  27309. function __() { this.constructor = d; }
  27310. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  27311. };
  27312. })();
  27313. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  27314. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  27315. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  27316. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  27317. return c > 3 && r && Object.defineProperty(target, key, r), r;
  27318. };
  27319. var HeaderNavigationDirection;
  27320. (function (HeaderNavigationDirection) {
  27321. HeaderNavigationDirection[HeaderNavigationDirection["UP"] = 0] = "UP";
  27322. HeaderNavigationDirection[HeaderNavigationDirection["DOWN"] = 1] = "DOWN";
  27323. HeaderNavigationDirection[HeaderNavigationDirection["LEFT"] = 2] = "LEFT";
  27324. HeaderNavigationDirection[HeaderNavigationDirection["RIGHT"] = 3] = "RIGHT";
  27325. })(HeaderNavigationDirection || (HeaderNavigationDirection = {}));
  27326. var HeaderNavigationService = /** @class */ (function (_super) {
  27327. __extends(HeaderNavigationService, _super);
  27328. function HeaderNavigationService() {
  27329. return _super !== null && _super.apply(this, arguments) || this;
  27330. }
  27331. HeaderNavigationService.prototype.registerGridComp = function (gridPanel) {
  27332. this.gridPanel = gridPanel;
  27333. };
  27334. HeaderNavigationService.prototype.registerHeaderRoot = function (headerRoot) {
  27335. this.headerRoot = headerRoot;
  27336. };
  27337. HeaderNavigationService.prototype.getHeaderRowCount = function () {
  27338. var headerContainers = this.headerRoot.getHeaderContainers();
  27339. return headerContainers.size === 0 ? 0 : this.getHeaderContainer().getRowComps().length;
  27340. };
  27341. HeaderNavigationService.prototype.getHeaderRowType = function (idx) {
  27342. if (this.getHeaderRowCount()) {
  27343. return this.getHeaderContainer().getRowComps()[idx].getType();
  27344. }
  27345. };
  27346. HeaderNavigationService.prototype.getHeaderContainer = function (position) {
  27347. if (position === void 0) { position = 'center'; }
  27348. if (position === null) {
  27349. position = 'center';
  27350. }
  27351. return this.headerRoot.getHeaderContainers().get(position);
  27352. };
  27353. /*
  27354. * This method navigates grid header vertically
  27355. * @return {boolean} true to preventDefault on the event that caused this navigation.
  27356. */
  27357. HeaderNavigationService.prototype.navigateVertically = function (direction, fromHeader) {
  27358. if (!fromHeader) {
  27359. fromHeader = this.focusController.getFocusedHeader();
  27360. }
  27361. if (!fromHeader) {
  27362. return false;
  27363. }
  27364. var headerRowIndex = fromHeader.headerRowIndex, column = fromHeader.column;
  27365. var rowLen = this.getHeaderRowCount();
  27366. var isUp = direction === HeaderNavigationDirection.UP;
  27367. var nextRow = isUp ? headerRowIndex - 1 : headerRowIndex + 1;
  27368. if (nextRow < 0) {
  27369. return false;
  27370. }
  27371. if (nextRow >= rowLen) {
  27372. // focusGridView returns false when the grid has no cells rendered.
  27373. return this.focusController.focusGridView();
  27374. }
  27375. var currentRowType = this.getHeaderRowType(headerRowIndex);
  27376. var nextFocusColumn;
  27377. if (currentRowType === _headerRowComp__WEBPACK_IMPORTED_MODULE_3__["HeaderRowType"].COLUMN_GROUP) {
  27378. var currentColumn = column;
  27379. nextFocusColumn = isUp ? column.getParent() : currentColumn.getDisplayedChildren()[0];
  27380. }
  27381. else if (currentRowType === _headerRowComp__WEBPACK_IMPORTED_MODULE_3__["HeaderRowType"].FLOATING_FILTER) {
  27382. nextFocusColumn = column;
  27383. }
  27384. else {
  27385. var currentColumn = column;
  27386. nextFocusColumn = isUp ? currentColumn.getParent() : currentColumn;
  27387. }
  27388. if (!nextFocusColumn) {
  27389. return false;
  27390. }
  27391. this.focusController.focusHeaderPosition({
  27392. headerRowIndex: nextRow,
  27393. column: nextFocusColumn
  27394. });
  27395. return true;
  27396. };
  27397. /*
  27398. * This method navigates grid header horizontally
  27399. * @return {boolean} true to preventDefault on the event that caused this navigation.
  27400. */
  27401. HeaderNavigationService.prototype.navigateHorizontally = function (direction, fromTab) {
  27402. var focusedHeader = this.focusController.getFocusedHeader();
  27403. var isLeft = direction === HeaderNavigationDirection.LEFT;
  27404. var isRtl = this.gridOptionsWrapper.isEnableRtl();
  27405. var nextHeader;
  27406. var normalisedDirection;
  27407. // either navigating to the left or isRtl (cannot be both)
  27408. if (isLeft !== isRtl) {
  27409. normalisedDirection = 'Before';
  27410. nextHeader = this.headerPositionUtils.findHeader(focusedHeader, normalisedDirection);
  27411. }
  27412. else {
  27413. normalisedDirection = 'After';
  27414. nextHeader = this.headerPositionUtils.findHeader(focusedHeader, normalisedDirection);
  27415. }
  27416. if (nextHeader) {
  27417. this.focusController.focusHeaderPosition(nextHeader, normalisedDirection);
  27418. return true;
  27419. }
  27420. if (!fromTab) {
  27421. return true;
  27422. }
  27423. return this.focusNextHeaderRow(focusedHeader, normalisedDirection);
  27424. };
  27425. HeaderNavigationService.prototype.focusNextHeaderRow = function (focusedHeader, direction) {
  27426. var currentIndex = focusedHeader.headerRowIndex;
  27427. var nextPosition;
  27428. var nextRowIndex;
  27429. if (direction === 'Before') {
  27430. if (currentIndex === 0) {
  27431. return false;
  27432. }
  27433. nextRowIndex = currentIndex - 1;
  27434. nextPosition = this.headerPositionUtils.findColAtEdgeForHeaderRow(nextRowIndex, 'end');
  27435. }
  27436. else {
  27437. nextRowIndex = currentIndex + 1;
  27438. nextPosition = this.headerPositionUtils.findColAtEdgeForHeaderRow(nextRowIndex, 'start');
  27439. }
  27440. if (nextPosition) {
  27441. if (nextPosition.headerRowIndex === -1) {
  27442. return this.focusController.focusGridView(nextPosition.column);
  27443. }
  27444. return this.focusController.focusHeaderPosition(nextPosition, direction);
  27445. }
  27446. return false;
  27447. };
  27448. HeaderNavigationService.prototype.scrollToColumn = function (column, direction) {
  27449. if (direction === void 0) { direction = 'After'; }
  27450. if (column.getPinned()) {
  27451. return;
  27452. }
  27453. var columnToScrollTo;
  27454. if (column instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_2__["ColumnGroup"]) {
  27455. var columns = column.getDisplayedLeafColumns();
  27456. columnToScrollTo = direction === 'Before' ? _utils__WEBPACK_IMPORTED_MODULE_4__["_"].last(columns) : columns[0];
  27457. }
  27458. else {
  27459. columnToScrollTo = column;
  27460. }
  27461. this.gridPanel.ensureColumnVisible(columnToScrollTo);
  27462. // need to nudge the scrolls for the floating items. otherwise when we set focus on a non-visible
  27463. // floating cell, the scrolls get out of sync
  27464. this.gridPanel.horizontallyScrollHeaderCenterAndFloatingCenter();
  27465. // need to flush frames, to make sure the correct cells are rendered
  27466. this.animationFrameService.flushAllFrames();
  27467. };
  27468. __decorate([
  27469. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  27470. ], HeaderNavigationService.prototype, "gridOptionsWrapper", void 0);
  27471. __decorate([
  27472. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusController')
  27473. ], HeaderNavigationService.prototype, "focusController", void 0);
  27474. __decorate([
  27475. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('headerPositionUtils')
  27476. ], HeaderNavigationService.prototype, "headerPositionUtils", void 0);
  27477. __decorate([
  27478. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('animationFrameService')
  27479. ], HeaderNavigationService.prototype, "animationFrameService", void 0);
  27480. HeaderNavigationService = __decorate([
  27481. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('headerNavigationService')
  27482. ], HeaderNavigationService);
  27483. return HeaderNavigationService;
  27484. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  27485. /***/ }),
  27486. /* 125 */
  27487. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  27488. "use strict";
  27489. __webpack_require__.r(__webpack_exports__);
  27490. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FilterManager", function() { return FilterManager; });
  27491. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7);
  27492. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  27493. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43);
  27494. /* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(38);
  27495. /* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(39);
  27496. /* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(17);
  27497. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(41);
  27498. /* harmony import */ var _utils_set__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(29);
  27499. /* harmony import */ var _utils_generic__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(14);
  27500. /* harmony import */ var _utils_object__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(16);
  27501. /* harmony import */ var _utils_dom__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(12);
  27502. /**
  27503. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  27504. * @version v23.2.1
  27505. * @link http://www.ag-grid.com/
  27506. * @license MIT
  27507. */
  27508. var __extends = (undefined && undefined.__extends) || (function () {
  27509. var extendStatics = function (d, b) {
  27510. extendStatics = Object.setPrototypeOf ||
  27511. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  27512. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  27513. return extendStatics(d, b);
  27514. };
  27515. return function (d, b) {
  27516. extendStatics(d, b);
  27517. function __() { this.constructor = d; }
  27518. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  27519. };
  27520. })();
  27521. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  27522. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  27523. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  27524. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  27525. return c > 3 && r && Object.defineProperty(target, key, r), r;
  27526. };
  27527. var FilterManager = /** @class */ (function (_super) {
  27528. __extends(FilterManager, _super);
  27529. function FilterManager() {
  27530. var _this = _super !== null && _super.apply(this, arguments) || this;
  27531. _this.allFilters = new Map();
  27532. _this.quickFilter = null;
  27533. _this.quickFilterParts = null;
  27534. // this is true when the grid is processing the filter change. this is used by the cell comps, so that they
  27535. // don't flash when data changes due to filter changes. there is no need to flash when filter changes as the
  27536. // user is in control, so doesn't make sense to show flashing changes. for example, go to main demo where
  27537. // this feature is turned off (hack code to always return false for isSuppressFlashingCellsBecauseFiltering(), put in)
  27538. // 100,000 rows and group by country. then do some filtering. all the cells flash, which is silly.
  27539. _this.processingFilterChange = false;
  27540. return _this;
  27541. }
  27542. FilterManager_1 = FilterManager;
  27543. FilterManager.prototype.init = function () {
  27544. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DATA_CHANGED, this.onNewRowsLoaded.bind(this));
  27545. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_NEW_COLUMNS_LOADED, this.onNewColumnsLoaded.bind(this));
  27546. this.quickFilter = this.parseQuickFilter(this.gridOptionsWrapper.getQuickFilterText());
  27547. this.setQuickFilterParts();
  27548. this.allowShowChangeAfterFilter = this.gridOptionsWrapper.isAllowShowChangeAfterFilter();
  27549. // check this here, in case there is a filter from the start
  27550. this.checkExternalFilter();
  27551. };
  27552. FilterManager.prototype.setQuickFilterParts = function () {
  27553. this.quickFilterParts = this.quickFilter ? this.quickFilter.split(' ') : null;
  27554. };
  27555. FilterManager.prototype.setFilterModel = function (model) {
  27556. var _this = this;
  27557. var allPromises = [];
  27558. if (model) {
  27559. // mark the filters as we set them, so any active filters left over we stop
  27560. var modelKeys_1 = Object(_utils_set__WEBPACK_IMPORTED_MODULE_7__["convertToSet"])(Object.keys(model));
  27561. this.allFilters.forEach(function (filterWrapper, colId) {
  27562. var newModel = model[colId];
  27563. allPromises.push(_this.setModelOnFilterWrapper(filterWrapper.filterPromise, newModel));
  27564. modelKeys_1.delete(colId);
  27565. });
  27566. // at this point, processedFields contains data for which we don't have a filter working yet
  27567. modelKeys_1.forEach(function (colId) {
  27568. var column = _this.columnController.getPrimaryColumn(colId);
  27569. if (!column) {
  27570. console.warn('Warning ag-grid setFilterModel - no column found for colId ' + colId);
  27571. return;
  27572. }
  27573. var filterWrapper = _this.getOrCreateFilterWrapper(column, 'NO_UI');
  27574. allPromises.push(_this.setModelOnFilterWrapper(filterWrapper.filterPromise, model[colId]));
  27575. });
  27576. }
  27577. else {
  27578. this.allFilters.forEach(function (filterWrapper) {
  27579. allPromises.push(_this.setModelOnFilterWrapper(filterWrapper.filterPromise, null));
  27580. });
  27581. }
  27582. _utils__WEBPACK_IMPORTED_MODULE_0__["Promise"].all(allPromises).then(function () { return _this.onFilterChanged(); });
  27583. };
  27584. FilterManager.prototype.setModelOnFilterWrapper = function (filterPromise, newModel) {
  27585. return new _utils__WEBPACK_IMPORTED_MODULE_0__["Promise"](function (resolve) {
  27586. filterPromise.then(function (filter) {
  27587. if (typeof filter.setModel !== 'function') {
  27588. console.warn('Warning ag-grid - filter missing setModel method, which is needed for setFilterModel');
  27589. resolve();
  27590. }
  27591. var promise = filter.setModel(newModel);
  27592. if (promise == null) {
  27593. resolve();
  27594. }
  27595. else {
  27596. promise.then(function () { return resolve(); });
  27597. }
  27598. });
  27599. });
  27600. };
  27601. FilterManager.prototype.getFilterModel = function () {
  27602. var result = {};
  27603. this.allFilters.forEach(function (filterWrapper, key) {
  27604. // because user can provide filters, we provide useful error checking and messages
  27605. var filterPromise = filterWrapper.filterPromise;
  27606. var filter = filterPromise.resolveNow(null, function (filter) { return filter; });
  27607. if (filter == null) {
  27608. return null;
  27609. }
  27610. if (typeof filter.getModel !== 'function') {
  27611. console.warn('Warning ag-grid - filter API missing getModel method, which is needed for getFilterModel');
  27612. return;
  27613. }
  27614. var model = filter.getModel();
  27615. if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_8__["exists"])(model)) {
  27616. result[key] = model;
  27617. }
  27618. });
  27619. return result;
  27620. };
  27621. // returns true if any advanced filter (ie not quick filter) active
  27622. FilterManager.prototype.isAdvancedFilterPresent = function () {
  27623. return this.advancedFilterPresent;
  27624. };
  27625. // called by:
  27626. // 1) onFilterChanged()
  27627. // 2) onNewRowsLoaded()
  27628. FilterManager.prototype.setAdvancedFilterPresent = function () {
  27629. var atLeastOneActive = false;
  27630. this.allFilters.forEach(function (filterWrapper) {
  27631. if (atLeastOneActive) {
  27632. return;
  27633. } // no need to check any more
  27634. if (filterWrapper.filterPromise.resolveNow(false, function (filter) { return filter.isFilterActive(); })) {
  27635. atLeastOneActive = true;
  27636. }
  27637. });
  27638. this.advancedFilterPresent = atLeastOneActive;
  27639. };
  27640. FilterManager.prototype.updateFilterFlagInColumns = function (source, additionalEventAttributes) {
  27641. this.allFilters.forEach(function (filterWrapper) {
  27642. var isFilterActive = filterWrapper.filterPromise.resolveNow(false, function (filter) { return filter.isFilterActive(); });
  27643. filterWrapper.column.setFilterActive(isFilterActive, source, additionalEventAttributes);
  27644. });
  27645. };
  27646. // returns true if quickFilter or advancedFilter
  27647. FilterManager.prototype.isAnyFilterPresent = function () {
  27648. return this.isQuickFilterPresent() || this.advancedFilterPresent || this.externalFilterPresent;
  27649. };
  27650. FilterManager.prototype.doesFilterPass = function (node, filterToSkip) {
  27651. var data = node.data;
  27652. var filterPasses = true;
  27653. this.allFilters.forEach(function (filterWrapper) {
  27654. // if a filter has already failed, no need to run any more
  27655. if (!filterPasses) {
  27656. return;
  27657. }
  27658. // if no filter, always pass
  27659. if (filterWrapper == null) {
  27660. return;
  27661. }
  27662. var filter = filterWrapper.filterPromise.resolveNow(undefined, function (filter) { return filter; });
  27663. if (filter == null || filter === filterToSkip || !filter.isFilterActive()) {
  27664. return;
  27665. }
  27666. if (!filter.doesFilterPass) { // because users can do custom filters, give nice error message
  27667. throw new Error('Filter is missing method doesFilterPass');
  27668. }
  27669. filterPasses = filter.doesFilterPass({ node: node, data: data });
  27670. });
  27671. return filterPasses;
  27672. };
  27673. FilterManager.prototype.parseQuickFilter = function (newFilter) {
  27674. if (!Object(_utils_generic__WEBPACK_IMPORTED_MODULE_8__["exists"])(newFilter)) {
  27675. return null;
  27676. }
  27677. if (!this.gridOptionsWrapper.isRowModelDefault()) {
  27678. console.warn('ag-grid: quick filtering only works with the Client-Side Row Model');
  27679. return null;
  27680. }
  27681. return newFilter.toUpperCase();
  27682. };
  27683. FilterManager.prototype.setQuickFilter = function (newFilter) {
  27684. var parsedFilter = this.parseQuickFilter(newFilter);
  27685. if (this.quickFilter !== parsedFilter) {
  27686. this.quickFilter = parsedFilter;
  27687. this.setQuickFilterParts();
  27688. this.onFilterChanged();
  27689. }
  27690. };
  27691. FilterManager.prototype.checkExternalFilter = function () {
  27692. this.externalFilterPresent = this.gridOptionsWrapper.isExternalFilterPresent();
  27693. };
  27694. FilterManager.prototype.onFilterChanged = function (filterInstance, additionalEventAttributes) {
  27695. this.setAdvancedFilterPresent();
  27696. this.updateFilterFlagInColumns('filterChanged', additionalEventAttributes);
  27697. this.checkExternalFilter();
  27698. this.allFilters.forEach(function (filterWrapper) {
  27699. filterWrapper.filterPromise.then(function (filter) {
  27700. if (filter !== filterInstance && filter.onAnyFilterChanged) {
  27701. filter.onAnyFilterChanged();
  27702. }
  27703. });
  27704. });
  27705. var filterChangedEvent = {
  27706. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_FILTER_CHANGED,
  27707. api: this.gridApi,
  27708. columnApi: this.columnApi
  27709. };
  27710. if (additionalEventAttributes) {
  27711. Object(_utils_object__WEBPACK_IMPORTED_MODULE_9__["mergeDeep"])(filterChangedEvent, additionalEventAttributes);
  27712. }
  27713. // because internal events are not async in ag-grid, when the dispatchEvent
  27714. // method comes back, we know all listeners have finished executing.
  27715. this.processingFilterChange = true;
  27716. this.eventService.dispatchEvent(filterChangedEvent);
  27717. this.processingFilterChange = false;
  27718. };
  27719. FilterManager.prototype.isSuppressFlashingCellsBecauseFiltering = function () {
  27720. // if user has elected to always flash cell changes, then always return false, otherwise we suppress flashing
  27721. // changes when filtering
  27722. return !this.allowShowChangeAfterFilter && this.processingFilterChange;
  27723. };
  27724. FilterManager.prototype.isQuickFilterPresent = function () {
  27725. return this.quickFilter !== null;
  27726. };
  27727. FilterManager.prototype.doesRowPassOtherFilters = function (filterToSkip, node) {
  27728. return this.doesRowPassFilter(node, filterToSkip);
  27729. };
  27730. FilterManager.prototype.doesRowPassQuickFilterNoCache = function (node, filterPart) {
  27731. var _this = this;
  27732. var columns = this.columnController.getAllColumnsForQuickFilter();
  27733. return Object(_utils_array__WEBPACK_IMPORTED_MODULE_5__["some"])(columns, function (column) {
  27734. var part = _this.getQuickFilterTextForColumn(column, node);
  27735. return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_8__["exists"])(part) && part.indexOf(filterPart) >= 0;
  27736. });
  27737. };
  27738. FilterManager.prototype.doesRowPassQuickFilterCache = function (node, filterPart) {
  27739. if (!node.quickFilterAggregateText) {
  27740. this.aggregateRowForQuickFilter(node);
  27741. }
  27742. return node.quickFilterAggregateText.indexOf(filterPart) >= 0;
  27743. };
  27744. FilterManager.prototype.doesRowPassQuickFilter = function (node) {
  27745. var _this = this;
  27746. var usingCache = this.gridOptionsWrapper.isCacheQuickFilter();
  27747. // each part must pass, if any fails, then the whole filter fails
  27748. return Object(_utils_array__WEBPACK_IMPORTED_MODULE_5__["every"])(this.quickFilterParts, function (part) {
  27749. return usingCache ? _this.doesRowPassQuickFilterCache(node, part) : _this.doesRowPassQuickFilterNoCache(node, part);
  27750. });
  27751. };
  27752. FilterManager.prototype.doesRowPassFilter = function (node, filterToSkip) {
  27753. // the row must pass ALL of the filters, so if any of them fail,
  27754. // we return true. that means if a row passes the quick filter,
  27755. // but fails the column filter, it fails overall
  27756. // first up, check quick filter
  27757. if (this.isQuickFilterPresent() && !this.doesRowPassQuickFilter(node)) {
  27758. return false;
  27759. }
  27760. // secondly, give the client a chance to reject this row
  27761. if (this.externalFilterPresent && !this.gridOptionsWrapper.doesExternalFilterPass(node)) {
  27762. return false;
  27763. }
  27764. // lastly, check our internal advanced filter
  27765. if (this.advancedFilterPresent && !this.doesFilterPass(node, filterToSkip)) {
  27766. return false;
  27767. }
  27768. // got this far, all filters pass
  27769. return true;
  27770. };
  27771. FilterManager.prototype.getQuickFilterTextForColumn = function (column, node) {
  27772. var value = this.valueService.getValue(column, node, true);
  27773. var colDef = column.getColDef();
  27774. if (colDef.getQuickFilterText) {
  27775. var params = {
  27776. value: value,
  27777. node: node,
  27778. data: node.data,
  27779. column: column,
  27780. colDef: colDef,
  27781. context: this.gridOptionsWrapper.getContext()
  27782. };
  27783. value = colDef.getQuickFilterText(params);
  27784. }
  27785. return Object(_utils_generic__WEBPACK_IMPORTED_MODULE_8__["exists"])(value) ? value.toString().toUpperCase() : null;
  27786. };
  27787. FilterManager.prototype.aggregateRowForQuickFilter = function (node) {
  27788. var _this = this;
  27789. var stringParts = [];
  27790. var columns = this.columnController.getAllColumnsForQuickFilter();
  27791. Object(_utils_array__WEBPACK_IMPORTED_MODULE_5__["forEach"])(columns, function (column) {
  27792. var part = _this.getQuickFilterTextForColumn(column, node);
  27793. if (Object(_utils_generic__WEBPACK_IMPORTED_MODULE_8__["exists"])(part)) {
  27794. stringParts.push(part);
  27795. }
  27796. });
  27797. node.quickFilterAggregateText = stringParts.join(FilterManager_1.QUICK_FILTER_SEPARATOR);
  27798. };
  27799. FilterManager.prototype.onNewRowsLoaded = function (source) {
  27800. this.allFilters.forEach(function (filterWrapper) {
  27801. filterWrapper.filterPromise.then(function (filter) {
  27802. if (filter.onNewRowsLoaded) {
  27803. filter.onNewRowsLoaded();
  27804. }
  27805. });
  27806. });
  27807. this.updateFilterFlagInColumns(source);
  27808. this.setAdvancedFilterPresent();
  27809. };
  27810. FilterManager.prototype.createValueGetter = function (column) {
  27811. var _this = this;
  27812. return function (node) { return _this.valueService.getValue(column, node, true); };
  27813. };
  27814. FilterManager.prototype.getFilterComponent = function (column, source) {
  27815. return this.getOrCreateFilterWrapper(column, source).filterPromise;
  27816. };
  27817. FilterManager.prototype.isFilterActive = function (column) {
  27818. var filterWrapper = this.cachedFilter(column);
  27819. return filterWrapper && filterWrapper.filterPromise.resolveNow(false, function (filter) { return filter.isFilterActive(); });
  27820. };
  27821. FilterManager.prototype.getOrCreateFilterWrapper = function (column, source) {
  27822. var filterWrapper = this.cachedFilter(column);
  27823. if (!filterWrapper) {
  27824. filterWrapper = this.createFilterWrapper(column, source);
  27825. this.allFilters.set(column.getColId(), filterWrapper);
  27826. }
  27827. else if (source !== 'NO_UI') {
  27828. this.putIntoGui(filterWrapper, source);
  27829. }
  27830. return filterWrapper;
  27831. };
  27832. FilterManager.prototype.cachedFilter = function (column) {
  27833. return this.allFilters.get(column.getColId());
  27834. };
  27835. FilterManager.prototype.createFilterInstance = function (column, $scope) {
  27836. var _this = this;
  27837. var defaultFilter = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].SetFilterModule) ? 'agSetColumnFilter' : 'agTextColumnFilter';
  27838. var sanitisedColDef = Object(_utils_object__WEBPACK_IMPORTED_MODULE_9__["cloneObject"])(column.getColDef());
  27839. var filterInstance;
  27840. var params = this.createFilterParams(column, sanitisedColDef, $scope);
  27841. params.filterModifiedCallback = function () {
  27842. var event = {
  27843. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_FILTER_MODIFIED,
  27844. api: _this.gridApi,
  27845. columnApi: _this.columnApi,
  27846. column: column,
  27847. filterInstance: filterInstance
  27848. };
  27849. _this.eventService.dispatchEvent(event);
  27850. };
  27851. // we modify params in a callback as we need the filter instance, and this isn't available
  27852. // when creating the params above
  27853. var modifyParamsCallback = function (params, filterInstance) { return Object(_utils_object__WEBPACK_IMPORTED_MODULE_9__["assign"])(params, {
  27854. doesRowPassOtherFilter: function (node) { return _this.doesRowPassOtherFilters(filterInstance, node); },
  27855. filterChangedCallback: function (additionalEventAttributes) {
  27856. return _this.onFilterChanged(filterInstance, additionalEventAttributes);
  27857. }
  27858. }); };
  27859. var res = this.userComponentFactory.newFilterComponent(sanitisedColDef, params, defaultFilter, modifyParamsCallback);
  27860. if (res) {
  27861. res.then(function (r) { return filterInstance = r; });
  27862. }
  27863. return res;
  27864. };
  27865. FilterManager.prototype.createFilterParams = function (column, colDef, $scope) {
  27866. if ($scope === void 0) { $scope = null; }
  27867. var params = {
  27868. api: this.gridOptionsWrapper.getApi(),
  27869. column: column,
  27870. colDef: colDef,
  27871. rowModel: this.rowModel,
  27872. filterChangedCallback: null,
  27873. filterModifiedCallback: null,
  27874. valueGetter: this.createValueGetter(column),
  27875. context: this.gridOptionsWrapper.getContext(),
  27876. doesRowPassOtherFilter: null
  27877. };
  27878. // hack in scope if using AngularJS
  27879. if ($scope) {
  27880. params.$scope = $scope;
  27881. }
  27882. return params;
  27883. };
  27884. FilterManager.prototype.createFilterWrapper = function (column, source) {
  27885. var filterWrapper = {
  27886. column: column,
  27887. filterPromise: null,
  27888. scope: null,
  27889. compiledElement: null,
  27890. guiPromise: _utils__WEBPACK_IMPORTED_MODULE_0__["Promise"].resolve(null)
  27891. };
  27892. filterWrapper.scope = this.gridOptionsWrapper.isAngularCompileFilters() ? this.$scope.$new() : null;
  27893. filterWrapper.filterPromise = this.createFilterInstance(column, filterWrapper.scope);
  27894. if (filterWrapper.filterPromise) {
  27895. this.putIntoGui(filterWrapper, source);
  27896. }
  27897. return filterWrapper;
  27898. };
  27899. FilterManager.prototype.putIntoGui = function (filterWrapper, source) {
  27900. var _this = this;
  27901. var eFilterGui = document.createElement('div');
  27902. eFilterGui.className = 'ag-filter';
  27903. filterWrapper.guiPromise = new _utils__WEBPACK_IMPORTED_MODULE_0__["Promise"](function (resolve) {
  27904. filterWrapper.filterPromise.then(function (filter) {
  27905. var guiFromFilter = filter.getGui();
  27906. if (!Object(_utils_generic__WEBPACK_IMPORTED_MODULE_8__["exists"])(guiFromFilter)) {
  27907. console.warn("getGui method from filter returned " + guiFromFilter + ", it should be a DOM element or an HTML template string.");
  27908. }
  27909. // for backwards compatibility with Angular 1 - we
  27910. // used to allow providing back HTML from getGui().
  27911. // once we move away from supporting Angular 1
  27912. // directly, we can change this.
  27913. if (typeof guiFromFilter === 'string') {
  27914. guiFromFilter = Object(_utils_dom__WEBPACK_IMPORTED_MODULE_10__["loadTemplate"])(guiFromFilter);
  27915. }
  27916. eFilterGui.appendChild(guiFromFilter);
  27917. if (filterWrapper.scope) {
  27918. var compiledElement = _this.$compile(eFilterGui)(filterWrapper.scope);
  27919. filterWrapper.compiledElement = compiledElement;
  27920. window.setTimeout(function () { return filterWrapper.scope.$apply(); }, 0);
  27921. }
  27922. resolve(eFilterGui);
  27923. _this.eventService.dispatchEvent({
  27924. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_FILTER_OPENED,
  27925. column: filterWrapper.column,
  27926. source: source,
  27927. eGui: eFilterGui,
  27928. api: _this.gridApi,
  27929. columnApi: _this.columnApi
  27930. });
  27931. });
  27932. });
  27933. };
  27934. FilterManager.prototype.onNewColumnsLoaded = function () {
  27935. var _this = this;
  27936. var atLeastOneFilterGone = false;
  27937. this.allFilters.forEach(function (filterWrapper) {
  27938. var oldColumn = !_this.columnController.getPrimaryColumn(filterWrapper.column);
  27939. if (oldColumn) {
  27940. atLeastOneFilterGone = true;
  27941. _this.disposeFilterWrapper(filterWrapper, 'filterDestroyed');
  27942. }
  27943. });
  27944. if (atLeastOneFilterGone) {
  27945. this.onFilterChanged();
  27946. }
  27947. };
  27948. // destroys the filter, so it not longer takes part
  27949. FilterManager.prototype.destroyFilter = function (column, source) {
  27950. if (source === void 0) { source = 'api'; }
  27951. var filterWrapper = this.allFilters.get(column.getColId());
  27952. if (filterWrapper) {
  27953. this.disposeFilterWrapper(filterWrapper, source);
  27954. this.onFilterChanged();
  27955. }
  27956. };
  27957. FilterManager.prototype.disposeFilterWrapper = function (filterWrapper, source) {
  27958. var _this = this;
  27959. filterWrapper.filterPromise.then(function (filter) {
  27960. filter.setModel(null);
  27961. _this.getContext().destroyBean(filter);
  27962. filterWrapper.column.setFilterActive(false, source);
  27963. if (filterWrapper.scope) {
  27964. if (filterWrapper.compiledElement) {
  27965. filterWrapper.compiledElement.remove();
  27966. }
  27967. filterWrapper.scope.$destroy();
  27968. }
  27969. _this.allFilters.delete(filterWrapper.column.getColId());
  27970. });
  27971. };
  27972. FilterManager.prototype.destroy = function () {
  27973. var _this = this;
  27974. _super.prototype.destroy.call(this);
  27975. this.allFilters.forEach(function (filterWrapper) { return _this.disposeFilterWrapper(filterWrapper, 'filterDestroyed'); });
  27976. };
  27977. var FilterManager_1;
  27978. FilterManager.QUICK_FILTER_SEPARATOR = '\n';
  27979. __decorate([
  27980. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('$compile')
  27981. ], FilterManager.prototype, "$compile", void 0);
  27982. __decorate([
  27983. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('$scope')
  27984. ], FilterManager.prototype, "$scope", void 0);
  27985. __decorate([
  27986. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  27987. ], FilterManager.prototype, "gridOptionsWrapper", void 0);
  27988. __decorate([
  27989. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('valueService')
  27990. ], FilterManager.prototype, "valueService", void 0);
  27991. __decorate([
  27992. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController')
  27993. ], FilterManager.prototype, "columnController", void 0);
  27994. __decorate([
  27995. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowModel')
  27996. ], FilterManager.prototype, "rowModel", void 0);
  27997. __decorate([
  27998. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnApi')
  27999. ], FilterManager.prototype, "columnApi", void 0);
  28000. __decorate([
  28001. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridApi')
  28002. ], FilterManager.prototype, "gridApi", void 0);
  28003. __decorate([
  28004. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('userComponentFactory')
  28005. ], FilterManager.prototype, "userComponentFactory", void 0);
  28006. __decorate([
  28007. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  28008. ], FilterManager.prototype, "init", null);
  28009. __decorate([
  28010. _context_context__WEBPACK_IMPORTED_MODULE_1__["PreDestroy"]
  28011. ], FilterManager.prototype, "destroy", null);
  28012. FilterManager = FilterManager_1 = __decorate([
  28013. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('filterManager')
  28014. ], FilterManager);
  28015. return FilterManager;
  28016. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_6__["BeanStub"]));
  28017. /***/ }),
  28018. /* 126 */
  28019. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  28020. "use strict";
  28021. __webpack_require__.r(__webpack_exports__);
  28022. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ValueService", function() { return ValueService; });
  28023. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  28024. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43);
  28025. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
  28026. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(41);
  28027. /**
  28028. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  28029. * @version v23.2.1
  28030. * @link http://www.ag-grid.com/
  28031. * @license MIT
  28032. */
  28033. var __extends = (undefined && undefined.__extends) || (function () {
  28034. var extendStatics = function (d, b) {
  28035. extendStatics = Object.setPrototypeOf ||
  28036. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  28037. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  28038. return extendStatics(d, b);
  28039. };
  28040. return function (d, b) {
  28041. extendStatics(d, b);
  28042. function __() { this.constructor = d; }
  28043. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  28044. };
  28045. })();
  28046. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  28047. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  28048. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  28049. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  28050. return c > 3 && r && Object.defineProperty(target, key, r), r;
  28051. };
  28052. var ValueService = /** @class */ (function (_super) {
  28053. __extends(ValueService, _super);
  28054. function ValueService() {
  28055. var _this = _super !== null && _super.apply(this, arguments) || this;
  28056. _this.initialised = false;
  28057. return _this;
  28058. }
  28059. ValueService.prototype.init = function () {
  28060. this.cellExpressions = this.gridOptionsWrapper.isEnableCellExpressions();
  28061. this.initialised = true;
  28062. };
  28063. ValueService.prototype.getValue = function (column, rowNode, forFilter, ignoreAggData) {
  28064. if (forFilter === void 0) { forFilter = false; }
  28065. if (ignoreAggData === void 0) { ignoreAggData = false; }
  28066. // hack - the grid is getting refreshed before this bean gets initialised, race condition.
  28067. // really should have a way so they get initialised in the right order???
  28068. if (!this.initialised) {
  28069. this.init();
  28070. }
  28071. if (!rowNode) {
  28072. return;
  28073. }
  28074. // pull these out to make code below easier to read
  28075. var colDef = column.getColDef();
  28076. var field = colDef.field;
  28077. var colId = column.getId();
  28078. var data = rowNode.data;
  28079. var result;
  28080. // if there is a value getter, this gets precedence over a field
  28081. var groupDataExists = rowNode.groupData && rowNode.groupData[colId] !== undefined;
  28082. var aggDataExists = !ignoreAggData && rowNode.aggData && rowNode.aggData[colId] !== undefined;
  28083. if (forFilter && colDef.filterValueGetter) {
  28084. result = this.executeFilterValueGetter(colDef.filterValueGetter, data, column, rowNode);
  28085. }
  28086. else if (this.gridOptionsWrapper.isTreeData() && aggDataExists) {
  28087. result = rowNode.aggData[colId];
  28088. }
  28089. else if (this.gridOptionsWrapper.isTreeData() && colDef.valueGetter) {
  28090. result = this.executeValueGetter(colDef.valueGetter, data, column, rowNode);
  28091. }
  28092. else if (this.gridOptionsWrapper.isTreeData() && (field && data)) {
  28093. result = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].getValueUsingField(data, field, column.isFieldContainsDots());
  28094. }
  28095. else if (groupDataExists) {
  28096. result = rowNode.groupData[colId];
  28097. }
  28098. else if (aggDataExists) {
  28099. result = rowNode.aggData[colId];
  28100. }
  28101. else if (colDef.valueGetter) {
  28102. result = this.executeValueGetter(colDef.valueGetter, data, column, rowNode);
  28103. }
  28104. else if (field && data) {
  28105. result = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].getValueUsingField(data, field, column.isFieldContainsDots());
  28106. }
  28107. // the result could be an expression itself, if we are allowing cell values to be expressions
  28108. if (this.cellExpressions && (typeof result === 'string') && result.indexOf('=') === 0) {
  28109. var cellValueGetter = result.substring(1);
  28110. result = this.executeValueGetter(cellValueGetter, data, column, rowNode);
  28111. }
  28112. return result;
  28113. };
  28114. ValueService.prototype.setValue = function (rowNode, colKey, newValue, eventSource) {
  28115. var column = this.columnController.getPrimaryColumn(colKey);
  28116. if (!rowNode || !column) {
  28117. return;
  28118. }
  28119. // this will only happen if user is trying to paste into a group row, which doesn't make sense
  28120. // the user should not be trying to paste into group rows
  28121. if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].missing(rowNode.data)) {
  28122. rowNode.data = {};
  28123. }
  28124. // for backwards compatibility we are also retrieving the newValueHandler as well as the valueSetter
  28125. var _a = column.getColDef(), field = _a.field, newValueHandler = _a.newValueHandler, valueSetter = _a.valueSetter;
  28126. // need either a field or a newValueHandler for this to work
  28127. if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].missing(field) && _utils__WEBPACK_IMPORTED_MODULE_2__["_"].missing(newValueHandler) && _utils__WEBPACK_IMPORTED_MODULE_2__["_"].missing(valueSetter)) {
  28128. // we don't tell user about newValueHandler, as that is deprecated
  28129. console.warn("ag-Grid: you need either field or valueSetter set on colDef for editing to work");
  28130. return;
  28131. }
  28132. var params = {
  28133. node: rowNode,
  28134. data: rowNode.data,
  28135. oldValue: this.getValue(column, rowNode),
  28136. newValue: newValue,
  28137. colDef: column.getColDef(),
  28138. column: column,
  28139. api: this.gridOptionsWrapper.getApi(),
  28140. columnApi: this.gridOptionsWrapper.getColumnApi(),
  28141. context: this.gridOptionsWrapper.getContext()
  28142. };
  28143. params.newValue = newValue;
  28144. var valueWasDifferent;
  28145. if (newValueHandler && _utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(newValueHandler)) {
  28146. valueWasDifferent = newValueHandler(params);
  28147. }
  28148. else if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(valueSetter)) {
  28149. valueWasDifferent = this.expressionService.evaluate(valueSetter, params);
  28150. }
  28151. else {
  28152. valueWasDifferent = this.setValueUsingField(rowNode.data, field, newValue, column.isFieldContainsDots());
  28153. }
  28154. // in case user forgot to return something (possible if they are not using TypeScript
  28155. // and just forgot, or using an old newValueHandler we didn't always expect a return
  28156. // value here), we default the return value to true, so we always refresh.
  28157. if (valueWasDifferent === undefined) {
  28158. valueWasDifferent = true;
  28159. }
  28160. // if no change to the value, then no need to do the updating, or notifying via events.
  28161. // otherwise the user could be tabbing around the grid, and cellValueChange would get called
  28162. // all the time.
  28163. if (!valueWasDifferent) {
  28164. return;
  28165. }
  28166. // reset quick filter on this row
  28167. rowNode.resetQuickFilterAggregateText();
  28168. this.valueCache.onDataChanged();
  28169. params.newValue = this.getValue(column, rowNode);
  28170. var onCellValueChanged = column.getColDef().onCellValueChanged;
  28171. if (typeof onCellValueChanged === 'function') {
  28172. // to make callback async, do in a timeout
  28173. setTimeout(function () { return onCellValueChanged(params); }, 0);
  28174. }
  28175. var event = {
  28176. type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_VALUE_CHANGED,
  28177. event: null,
  28178. rowIndex: rowNode.rowIndex,
  28179. rowPinned: rowNode.rowPinned,
  28180. column: params.column,
  28181. api: params.api,
  28182. colDef: params.colDef,
  28183. columnApi: params.columnApi,
  28184. context: params.context,
  28185. data: rowNode.data,
  28186. node: rowNode,
  28187. oldValue: params.oldValue,
  28188. newValue: params.newValue,
  28189. value: params.newValue,
  28190. source: eventSource
  28191. };
  28192. this.eventService.dispatchEvent(event);
  28193. };
  28194. ValueService.prototype.setValueUsingField = function (data, field, newValue, isFieldContainsDots) {
  28195. if (!field) {
  28196. return false;
  28197. }
  28198. // if no '.', then it's not a deep value
  28199. var valuesAreSame = false;
  28200. if (!isFieldContainsDots) {
  28201. data[field] = newValue;
  28202. }
  28203. else {
  28204. // otherwise it is a deep value, so need to dig for it
  28205. var fieldPieces = field.split('.');
  28206. var currentObject = data;
  28207. while (fieldPieces.length > 0 && currentObject) {
  28208. var fieldPiece = fieldPieces.shift();
  28209. if (fieldPieces.length === 0) {
  28210. currentObject[fieldPiece] = newValue;
  28211. }
  28212. else {
  28213. currentObject = currentObject[fieldPiece];
  28214. }
  28215. }
  28216. }
  28217. return !valuesAreSame;
  28218. };
  28219. ValueService.prototype.executeFilterValueGetter = function (valueGetter, data, column, rowNode) {
  28220. var params = {
  28221. data: data,
  28222. node: rowNode,
  28223. column: column,
  28224. colDef: column.getColDef(),
  28225. api: this.gridOptionsWrapper.getApi(),
  28226. columnApi: this.gridOptionsWrapper.getColumnApi(),
  28227. context: this.gridOptionsWrapper.getContext(),
  28228. getValue: this.getValueCallback.bind(this, rowNode)
  28229. };
  28230. return this.expressionService.evaluate(valueGetter, params);
  28231. };
  28232. ValueService.prototype.executeValueGetter = function (valueGetter, data, column, rowNode) {
  28233. var colId = column.getId();
  28234. // if inside the same turn, just return back the value we got last time
  28235. var valueFromCache = this.valueCache.getValue(rowNode, colId);
  28236. if (valueFromCache !== undefined) {
  28237. return valueFromCache;
  28238. }
  28239. var params = {
  28240. data: data,
  28241. node: rowNode,
  28242. column: column,
  28243. colDef: column.getColDef(),
  28244. api: this.gridOptionsWrapper.getApi(),
  28245. columnApi: this.gridOptionsWrapper.getColumnApi(),
  28246. context: this.gridOptionsWrapper.getContext(),
  28247. getValue: this.getValueCallback.bind(this, rowNode)
  28248. };
  28249. var result = this.expressionService.evaluate(valueGetter, params);
  28250. // if a turn is active, store the value in case the grid asks for it again
  28251. this.valueCache.setValue(rowNode, colId, result);
  28252. return result;
  28253. };
  28254. ValueService.prototype.getValueCallback = function (node, field) {
  28255. var otherColumn = this.columnController.getPrimaryColumn(field);
  28256. if (otherColumn) {
  28257. return this.getValue(otherColumn, node);
  28258. }
  28259. return null;
  28260. };
  28261. // used by row grouping and pivot, to get key for a row. col can be a pivot col or a row grouping col
  28262. ValueService.prototype.getKeyForNode = function (col, rowNode) {
  28263. var value = this.getValue(col, rowNode);
  28264. var keyCreator = col.getColDef().keyCreator;
  28265. var result = keyCreator ? keyCreator({ value: value }) : value;
  28266. // if already a string, or missing, just return it
  28267. if (typeof result === 'string' || result == null) {
  28268. return result;
  28269. }
  28270. result = String(result);
  28271. if (result === '[object Object]') {
  28272. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].doOnce(function () {
  28273. console.warn('ag-Grid: a column you are grouping or pivoting by has objects as values. If you want to group by complex objects then either a) use a colDef.keyCreator (se ag-Grid docs) or b) to toString() on the object to return a key');
  28274. }, 'getKeyForNode - warn about [object,object]');
  28275. }
  28276. return result;
  28277. };
  28278. __decorate([
  28279. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  28280. ], ValueService.prototype, "gridOptionsWrapper", void 0);
  28281. __decorate([
  28282. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('expressionService')
  28283. ], ValueService.prototype, "expressionService", void 0);
  28284. __decorate([
  28285. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController')
  28286. ], ValueService.prototype, "columnController", void 0);
  28287. __decorate([
  28288. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueCache')
  28289. ], ValueService.prototype, "valueCache", void 0);
  28290. __decorate([
  28291. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  28292. ], ValueService.prototype, "init", null);
  28293. ValueService = __decorate([
  28294. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('valueService')
  28295. ], ValueService);
  28296. return ValueService;
  28297. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"]));
  28298. /***/ }),
  28299. /* 127 */
  28300. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  28301. "use strict";
  28302. __webpack_require__.r(__webpack_exports__);
  28303. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridPanel", function() { return GridPanel; });
  28304. /* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(50);
  28305. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  28306. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43);
  28307. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25);
  28308. /* harmony import */ var _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(128);
  28309. /* harmony import */ var _rendering_rowComp__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(100);
  28310. /* harmony import */ var _widgets_touchListener__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(65);
  28311. /* harmony import */ var _rowDragFeature__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(129);
  28312. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(56);
  28313. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(57);
  28314. /* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(39);
  28315. /* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(38);
  28316. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(7);
  28317. /**
  28318. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  28319. * @version v23.2.1
  28320. * @link http://www.ag-grid.com/
  28321. * @license MIT
  28322. */
  28323. var __extends = (undefined && undefined.__extends) || (function () {
  28324. var extendStatics = function (d, b) {
  28325. extendStatics = Object.setPrototypeOf ||
  28326. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  28327. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  28328. return extendStatics(d, b);
  28329. };
  28330. return function (d, b) {
  28331. extendStatics(d, b);
  28332. function __() { this.constructor = d; }
  28333. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  28334. };
  28335. })();
  28336. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  28337. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  28338. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  28339. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  28340. return c > 3 && r && Object.defineProperty(target, key, r), r;
  28341. };
  28342. // in the html below, it is important that there are no white space between some of the divs, as if there is white space,
  28343. // it won't render correctly in safari, as safari renders white space as a gap
  28344. var GRID_PANEL_NORMAL_TEMPLATE = /* html */ "<div class=\"ag-root ag-unselectable\" role=\"grid\" unselectable=\"on\">\n <ag-header-root ref=\"headerRoot\" unselectable=\"on\"></ag-header-root>\n <div class=\"ag-floating-top\" ref=\"eTop\" role=\"presentation\" unselectable=\"on\">\n <div class=\"ag-pinned-left-floating-top\" ref=\"eLeftTop\" role=\"presentation\" unselectable=\"on\"></div>\n <div class=\"ag-floating-top-viewport\" ref=\"eTopViewport\" role=\"presentation\" unselectable=\"on\">\n <div class=\"ag-floating-top-container\" ref=\"eTopContainer\" role=\"presentation\" unselectable=\"on\"></div>\n </div>\n <div class=\"ag-pinned-right-floating-top\" ref=\"eRightTop\" role=\"presentation\" unselectable=\"on\"></div>\n <div class=\"ag-floating-top-full-width-container\" ref=\"eTopFullWidthContainer\" role=\"presentation\" unselectable=\"on\"></div>\n </div>\n <div class=\"ag-body-viewport\" ref=\"eBodyViewport\" role=\"presentation\">\n <div class=\"ag-pinned-left-cols-container\" ref=\"eLeftContainer\" role=\"presentation\" unselectable=\"on\"></div>\n <div class=\"ag-center-cols-clipper\" ref=\"eCenterColsClipper\" role=\"presentation\" unselectable=\"on\">\n <div class=\"ag-center-cols-viewport\" ref=\"eCenterViewport\" role=\"presentation\">\n <div class=\"ag-center-cols-container\" ref=\"eCenterContainer\" role=\"rowgroup\" unselectable=\"on\"></div>\n </div>\n </div>\n <div class=\"ag-pinned-right-cols-container\" ref=\"eRightContainer\" role=\"presentation\" unselectable=\"on\"></div>\n <div class=\"ag-full-width-container\" ref=\"eFullWidthContainer\" role=\"presentation\" unselectable=\"on\"></div>\n </div>\n <div class=\"ag-floating-bottom\" ref=\"eBottom\" role=\"presentation\" unselectable=\"on\">\n <div class=\"ag-pinned-left-floating-bottom\" ref=\"eLeftBottom\" role=\"presentation\" unselectable=\"on\"></div>\n <div class=\"ag-floating-bottom-viewport\" ref=\"eBottomViewport\" role=\"presentation\" unselectable=\"on\">\n <div class=\"ag-floating-bottom-container\" ref=\"eBottomContainer\" role=\"presentation\" unselectable=\"on\"></div>\n </div>\n <div class=\"ag-pinned-right-floating-bottom\" ref=\"eRightBottom\" role=\"presentation\" unselectable=\"on\"></div>\n <div class=\"ag-floating-bottom-full-width-container\" ref=\"eBottomFullWidthContainer\" role=\"presentation\" unselectable=\"on\"></div>\n </div>\n <div class=\"ag-body-horizontal-scroll\" ref=\"eHorizontalScrollBody\" aria-hidden=\"true\">\n <div class=\"ag-horizontal-left-spacer\" ref=\"eHorizontalLeftSpacer\"></div>\n <div class=\"ag-body-horizontal-scroll-viewport\" ref=\"eBodyHorizontalScrollViewport\">\n <div class=\"ag-body-horizontal-scroll-container\" ref=\"eBodyHorizontalScrollContainer\"></div>\n </div>\n <div class=\"ag-horizontal-right-spacer\" ref=\"eHorizontalRightSpacer\"></div>\n </div>\n <ag-overlay-wrapper ref=\"overlayWrapper\"></ag-overlay-wrapper>\n </div>";
  28345. var GridPanel = /** @class */ (function (_super) {
  28346. __extends(GridPanel, _super);
  28347. function GridPanel() {
  28348. var _this = _super.call(this, GRID_PANEL_NORMAL_TEMPLATE) || this;
  28349. _this.scrollLeft = -1;
  28350. _this.scrollTop = -1;
  28351. _this.resetLastHorizontalScrollElementDebounced = _utils__WEBPACK_IMPORTED_MODULE_12__["_"].debounce(_this.resetLastHorizontalScrollElement.bind(_this), 500);
  28352. return _this;
  28353. }
  28354. GridPanel.prototype.getVScrollPosition = function () {
  28355. var result = {
  28356. top: this.eBodyViewport.scrollTop,
  28357. bottom: this.eBodyViewport.scrollTop + this.eBodyViewport.offsetHeight
  28358. };
  28359. return result;
  28360. };
  28361. GridPanel.prototype.getHScrollPosition = function () {
  28362. var result = {
  28363. left: this.eCenterViewport.scrollLeft,
  28364. right: this.eCenterViewport.scrollLeft + this.eCenterViewport.offsetWidth
  28365. };
  28366. return result;
  28367. };
  28368. GridPanel.prototype.onRowDataChanged = function () {
  28369. this.showOrHideOverlay();
  28370. };
  28371. GridPanel.prototype.showOrHideOverlay = function () {
  28372. var isEmpty = this.paginationProxy.isEmpty();
  28373. var isSuppressNoRowsOverlay = this.gridOptionsWrapper.isSuppressNoRowsOverlay();
  28374. var method = isEmpty && !isSuppressNoRowsOverlay ? 'showNoRowsOverlay' : 'hideOverlay';
  28375. this[method]();
  28376. };
  28377. GridPanel.prototype.onNewColumnsLoaded = function () {
  28378. // hide overlay if columns and rows exist, this can happen if columns are loaded after data.
  28379. // this problem exists before of the race condition between the services (column controller in this case)
  28380. // and the view (grid panel). if the model beans were all initialised first, and then the view beans second,
  28381. // this race condition would not happen.
  28382. if (this.beans.columnController.isReady() && !this.paginationProxy.isEmpty()) {
  28383. this.hideOverlay();
  28384. }
  28385. };
  28386. GridPanel.prototype.init = function () {
  28387. var _this = this;
  28388. this.scrollWidth = this.gridOptionsWrapper.getScrollbarWidth();
  28389. this.enableRtl = this.gridOptionsWrapper.isEnableRtl();
  28390. this.printLayout = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].DOM_LAYOUT_PRINT;
  28391. // these elements have different CSS when layout changes
  28392. this.gridOptionsWrapper.addLayoutElement(this.getGui());
  28393. this.gridOptionsWrapper.addLayoutElement(this.eBodyViewport);
  28394. this.suppressScrollOnFloatingRow();
  28395. this.setupRowAnimationCssClass();
  28396. this.buildRowContainerComponents();
  28397. this.addEventListeners();
  28398. this.addDragListeners();
  28399. this.addScrollListener();
  28400. if (this.gridOptionsWrapper.isRowModelDefault() && !this.gridOptionsWrapper.getRowData()) {
  28401. this.showLoadingOverlay();
  28402. }
  28403. this.setCellTextSelection(this.gridOptionsWrapper.isEnableCellTextSelect());
  28404. this.setPinnedContainerSize();
  28405. this.setHeaderAndFloatingHeights();
  28406. this.disableBrowserDragging();
  28407. this.addMouseListeners();
  28408. this.addKeyboardEvents();
  28409. this.addBodyViewportListener();
  28410. this.addStopEditingWhenGridLosesFocus();
  28411. this.mockContextMenuForIPad();
  28412. this.addRowDragListener();
  28413. if (this.$scope) {
  28414. this.addAngularApplyCheck();
  28415. }
  28416. this.onDisplayedColumnsWidthChanged();
  28417. this.gridApi.registerGridComp(this);
  28418. this.alignedGridsService.registerGridComp(this);
  28419. this.headerRootComp.registerGridComp(this);
  28420. this.navigationService.registerGridComp(this);
  28421. this.headerNavigationService.registerGridComp(this);
  28422. this.heightScaler.registerGridComp(this);
  28423. this.autoHeightCalculator.registerGridComp(this);
  28424. this.columnAnimationService.registerGridComp(this);
  28425. this.autoWidthCalculator.registerGridComp(this);
  28426. this.paginationAutoPageSizeService.registerGridComp(this);
  28427. this.mouseEventService.registerGridComp(this);
  28428. this.beans.registerGridComp(this);
  28429. this.rowRenderer.registerGridComp(this);
  28430. if (this.rangeController) {
  28431. this.rangeController.registerGridComp(this);
  28432. }
  28433. [this.eCenterViewport, this.eBodyViewport].forEach(function (viewport) {
  28434. var unsubscribeFromResize = _this.resizeObserverService.observeResize(viewport, _this.onCenterViewportResized.bind(_this));
  28435. _this.addDestroyFunc(function () { return unsubscribeFromResize(); });
  28436. });
  28437. [this.eTop, this.eBodyViewport, this.eBottom].forEach(function (element) {
  28438. _this.addManagedListener(element, 'focusin', function () {
  28439. _utils__WEBPACK_IMPORTED_MODULE_12__["_"].addCssClass(element, 'ag-has-focus');
  28440. });
  28441. _this.addManagedListener(element, 'focusout', function (e) {
  28442. if (!element.contains(e.relatedTarget)) {
  28443. _utils__WEBPACK_IMPORTED_MODULE_12__["_"].removeCssClass(element, 'ag-has-focus');
  28444. }
  28445. });
  28446. });
  28447. };
  28448. GridPanel.prototype.onDomLayoutChanged = function () {
  28449. var newPrintLayout = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].DOM_LAYOUT_PRINT;
  28450. if (this.printLayout !== newPrintLayout) {
  28451. this.printLayout = newPrintLayout;
  28452. this.setWidthsOfContainers();
  28453. // pinned containers are always hidden for print layout
  28454. this.setPinnedContainerSize();
  28455. }
  28456. };
  28457. GridPanel.prototype.onCenterViewportResized = function () {
  28458. if (_utils__WEBPACK_IMPORTED_MODULE_12__["_"].isVisible(this.eCenterViewport)) {
  28459. this.checkViewportAndScrolls();
  28460. this.beans.columnController.refreshFlexedColumns(this.getCenterWidth());
  28461. }
  28462. else {
  28463. this.bodyHeight = 0;
  28464. }
  28465. };
  28466. // used by ColumnAnimationService
  28467. GridPanel.prototype.setColumnMovingCss = function (moving) {
  28468. this.addOrRemoveCssClass('ag-column-moving', moving);
  28469. };
  28470. GridPanel.prototype.setCellTextSelection = function (selectable) {
  28471. if (selectable === void 0) { selectable = false; }
  28472. [this.eTop, this.eBodyViewport, this.eBottom]
  28473. .forEach(function (ct) { return _utils__WEBPACK_IMPORTED_MODULE_12__["_"].addOrRemoveCssClass(ct, 'ag-selectable', selectable); });
  28474. };
  28475. GridPanel.prototype.addRowDragListener = function () {
  28476. this.rowDragFeature = this.createManagedBean(new _rowDragFeature__WEBPACK_IMPORTED_MODULE_7__["RowDragFeature"](this.eBodyViewport, this));
  28477. this.dragAndDropService.addDropTarget(this.rowDragFeature);
  28478. };
  28479. GridPanel.prototype.getRowDragFeature = function () {
  28480. return this.rowDragFeature;
  28481. };
  28482. GridPanel.prototype.addStopEditingWhenGridLosesFocus = function () {
  28483. var _this = this;
  28484. if (!this.gridOptionsWrapper.isStopEditingWhenGridLosesFocus()) {
  28485. return;
  28486. }
  28487. var viewports = [this.eBodyViewport, this.eBottom, this.eTop];
  28488. var focusOutListener = function (event) {
  28489. // this is the element the focus is moving to
  28490. var elementWithFocus = event.relatedTarget;
  28491. if (_utils__WEBPACK_IMPORTED_MODULE_12__["_"].getTabIndex(elementWithFocus) === null) {
  28492. _this.rowRenderer.stopEditing();
  28493. return;
  28494. }
  28495. var clickInsideGrid = viewports.some(function (viewport) { return viewport.contains(elementWithFocus); });
  28496. if (!clickInsideGrid) {
  28497. var popupService = _this.beans.popupService;
  28498. clickInsideGrid =
  28499. popupService.getActivePopups().some(function (popup) { return popup.contains(elementWithFocus); }) ||
  28500. popupService.isElementWithinCustomPopup(elementWithFocus);
  28501. }
  28502. if (!clickInsideGrid) {
  28503. _this.rowRenderer.stopEditing();
  28504. }
  28505. };
  28506. viewports.forEach(function (viewport) { return _this.addManagedListener(viewport, 'focusout', focusOutListener); });
  28507. };
  28508. GridPanel.prototype.addAngularApplyCheck = function () {
  28509. var _this = this;
  28510. // this makes sure if we queue up requests, we only execute oe
  28511. var applyTriggered = false;
  28512. var listener = function () {
  28513. // only need to do one apply at a time
  28514. if (applyTriggered) {
  28515. return;
  28516. }
  28517. applyTriggered = true; // mark 'need apply' to true
  28518. window.setTimeout(function () {
  28519. applyTriggered = false;
  28520. _this.$scope.$apply();
  28521. }, 0);
  28522. };
  28523. // these are the events we need to do an apply after - these are the ones that can end up
  28524. // with columns added or removed
  28525. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, listener);
  28526. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_VIRTUAL_COLUMNS_CHANGED, listener);
  28527. };
  28528. // if we do not do this, then the user can select a pic in the grid (eg an image in a custom cell renderer)
  28529. // and then that will start the browser native drag n' drop, which messes up with our own drag and drop.
  28530. GridPanel.prototype.disableBrowserDragging = function () {
  28531. this.addGuiEventListener('dragstart', function (event) {
  28532. if (event.target instanceof HTMLImageElement) {
  28533. event.preventDefault();
  28534. return false;
  28535. }
  28536. });
  28537. };
  28538. GridPanel.prototype.addEventListeners = function () {
  28539. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_COLUMNS_CHANGED, this.onDisplayedColumnsChanged.bind(this));
  28540. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DISPLAYED_COLUMNS_WIDTH_CHANGED, this.onDisplayedColumnsWidthChanged.bind(this));
  28541. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_PINNED_ROW_DATA_CHANGED, this.setHeaderAndFloatingHeights.bind(this));
  28542. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DATA_CHANGED, this.onRowDataChanged.bind(this));
  28543. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DATA_UPDATED, this.onRowDataChanged.bind(this));
  28544. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_NEW_COLUMNS_LOADED, this.onNewColumnsLoaded.bind(this));
  28545. this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_HEADER_HEIGHT, this.setHeaderAndFloatingHeights.bind(this));
  28546. this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_PIVOT_HEADER_HEIGHT, this.setHeaderAndFloatingHeights.bind(this));
  28547. this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GROUP_HEADER_HEIGHT, this.setHeaderAndFloatingHeights.bind(this));
  28548. this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_PIVOT_GROUP_HEADER_HEIGHT, this.setHeaderAndFloatingHeights.bind(this));
  28549. this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_FLOATING_FILTERS_HEIGHT, this.setHeaderAndFloatingHeights.bind(this));
  28550. this.addManagedListener(this.gridOptionsWrapper, _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_DOM_LAYOUT, this.onDomLayoutChanged.bind(this));
  28551. };
  28552. GridPanel.prototype.addDragListeners = function () {
  28553. var _this = this;
  28554. if (!this.gridOptionsWrapper.isEnableRangeSelection() || // no range selection if no property
  28555. _utils__WEBPACK_IMPORTED_MODULE_12__["_"].missing(this.rangeController) // no range selection if not enterprise version
  28556. ) {
  28557. return;
  28558. }
  28559. var containers = [
  28560. this.eLeftContainer,
  28561. this.eRightContainer,
  28562. this.eCenterContainer,
  28563. this.eTop,
  28564. this.eBottom
  28565. ];
  28566. containers.forEach(function (container) {
  28567. var params = {
  28568. eElement: container,
  28569. onDragStart: _this.rangeController.onDragStart.bind(_this.rangeController),
  28570. onDragStop: _this.rangeController.onDragStop.bind(_this.rangeController),
  28571. onDragging: _this.rangeController.onDragging.bind(_this.rangeController)
  28572. };
  28573. _this.dragService.addDragSource(params);
  28574. _this.addDestroyFunc(function () { return _this.dragService.removeDragSource(params); });
  28575. });
  28576. };
  28577. GridPanel.prototype.addMouseListeners = function () {
  28578. var _this = this;
  28579. var eventNames = ['click', 'mousedown', 'dblclick', 'contextmenu', 'mouseover', 'mouseout'];
  28580. eventNames.forEach(function (eventName) {
  28581. var listener = _this.processMouseEvent.bind(_this, eventName);
  28582. _this.eAllCellContainers.forEach(function (container) {
  28583. return _this.addManagedListener(container, eventName, listener);
  28584. });
  28585. });
  28586. };
  28587. GridPanel.prototype.addKeyboardEvents = function () {
  28588. var _this = this;
  28589. var eventNames = ['keydown', 'keypress'];
  28590. eventNames.forEach(function (eventName) {
  28591. var listener = _this.processKeyboardEvent.bind(_this, eventName);
  28592. _this.eAllCellContainers.forEach(function (container) {
  28593. _this.addManagedListener(container, eventName, listener);
  28594. });
  28595. });
  28596. };
  28597. GridPanel.prototype.addBodyViewportListener = function () {
  28598. var _this = this;
  28599. // we want to listen for clicks directly on the eBodyViewport, so the user has a way of showing
  28600. // the context menu if no rows or columns are displayed, or user simply clicks outside of a cell
  28601. var listener = function (mouseEvent) {
  28602. var target = _utils__WEBPACK_IMPORTED_MODULE_12__["_"].getTarget(mouseEvent);
  28603. if (target === _this.eBodyViewport || target === _this.eCenterViewport) {
  28604. // show it
  28605. _this.onContextMenu(mouseEvent, null, null, null, null);
  28606. _this.preventDefaultOnContextMenu(mouseEvent);
  28607. }
  28608. };
  28609. this.addManagedListener(this.eBodyViewport, 'contextmenu', listener);
  28610. };
  28611. // + rangeController - used to know when to scroll when user is dragging outside the
  28612. // main viewport while doing a range selection
  28613. GridPanel.prototype.getBodyClientRect = function () {
  28614. if (!this.eBodyViewport) {
  28615. return;
  28616. }
  28617. return this.eBodyViewport.getBoundingClientRect();
  28618. };
  28619. GridPanel.prototype.getRowForEvent = function (event) {
  28620. var sourceElement = _utils__WEBPACK_IMPORTED_MODULE_12__["_"].getTarget(event);
  28621. while (sourceElement) {
  28622. var renderedRow = this.gridOptionsWrapper.getDomData(sourceElement, _rendering_rowComp__WEBPACK_IMPORTED_MODULE_5__["RowComp"].DOM_DATA_KEY_RENDERED_ROW);
  28623. if (renderedRow) {
  28624. return renderedRow;
  28625. }
  28626. sourceElement = sourceElement.parentElement;
  28627. }
  28628. return null;
  28629. };
  28630. GridPanel.prototype.processKeyboardEvent = function (eventName, keyboardEvent) {
  28631. var cellComp = _utils__WEBPACK_IMPORTED_MODULE_12__["_"].getCellCompForEvent(this.gridOptionsWrapper, keyboardEvent);
  28632. if (!cellComp || keyboardEvent.defaultPrevented) {
  28633. return;
  28634. }
  28635. var rowNode = cellComp.getRenderedRow().getRowNode();
  28636. var column = cellComp.getColumn();
  28637. var editing = cellComp.isEditing();
  28638. var gridProcessingAllowed = !_utils__WEBPACK_IMPORTED_MODULE_12__["_"].isUserSuppressingKeyboardEvent(this.gridOptionsWrapper, keyboardEvent, rowNode, column, editing);
  28639. if (gridProcessingAllowed) {
  28640. switch (eventName) {
  28641. case 'keydown':
  28642. // first see if it's a scroll key, page up / down, home / end etc
  28643. var wasScrollKey = !editing && this.navigationService.handlePageScrollingKey(keyboardEvent);
  28644. // if not a scroll key, then we pass onto cell
  28645. if (!wasScrollKey) {
  28646. cellComp.onKeyDown(keyboardEvent);
  28647. }
  28648. // perform clipboard and undo / redo operations
  28649. this.doGridOperations(keyboardEvent, cellComp);
  28650. break;
  28651. case 'keypress':
  28652. cellComp.onKeyPress(keyboardEvent);
  28653. break;
  28654. }
  28655. }
  28656. if (eventName === 'keydown') {
  28657. var cellKeyDownEvent = cellComp.createEvent(keyboardEvent, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_CELL_KEY_DOWN);
  28658. this.beans.eventService.dispatchEvent(cellKeyDownEvent);
  28659. }
  28660. if (eventName === 'keypress') {
  28661. var cellKeyPressEvent = cellComp.createEvent(keyboardEvent, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_CELL_KEY_PRESS);
  28662. this.beans.eventService.dispatchEvent(cellKeyPressEvent);
  28663. }
  28664. };
  28665. GridPanel.prototype.doGridOperations = function (keyboardEvent, cellComp) {
  28666. // check if ctrl or meta key pressed
  28667. if (!keyboardEvent.ctrlKey && !keyboardEvent.metaKey) {
  28668. return;
  28669. }
  28670. // if the cell the event came from is editing, then we do not
  28671. // want to do the default shortcut keys, otherwise the editor
  28672. // (eg a text field) would not be able to do the normal cut/copy/paste
  28673. if (cellComp.isEditing()) {
  28674. return;
  28675. }
  28676. // for copy / paste, we don't want to execute when the event
  28677. // was from a child grid (happens in master detail)
  28678. if (!this.mouseEventService.isEventFromThisGrid(keyboardEvent)) {
  28679. return;
  28680. }
  28681. switch (keyboardEvent.which) {
  28682. case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_A:
  28683. return this.onCtrlAndA(keyboardEvent);
  28684. case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_C:
  28685. return this.onCtrlAndC(keyboardEvent);
  28686. case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_V:
  28687. return this.onCtrlAndV();
  28688. case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_D:
  28689. return this.onCtrlAndD(keyboardEvent);
  28690. case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_Z:
  28691. return keyboardEvent.shiftKey ? this.undoRedoService.redo() : this.undoRedoService.undo();
  28692. case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_Y:
  28693. return this.undoRedoService.redo();
  28694. }
  28695. };
  28696. // gets called by rowRenderer when new data loaded, as it will want to scroll to the top
  28697. GridPanel.prototype.scrollToTop = function () {
  28698. this.eBodyViewport.scrollTop = 0;
  28699. };
  28700. GridPanel.prototype.processMouseEvent = function (eventName, mouseEvent) {
  28701. if (!this.mouseEventService.isEventFromThisGrid(mouseEvent) ||
  28702. _utils__WEBPACK_IMPORTED_MODULE_12__["_"].isStopPropagationForAgGrid(mouseEvent)) {
  28703. return;
  28704. }
  28705. var rowComp = this.getRowForEvent(mouseEvent);
  28706. var cellComp = this.mouseEventService.getRenderedCellForEvent(mouseEvent);
  28707. if (eventName === "contextmenu") {
  28708. this.preventDefaultOnContextMenu(mouseEvent);
  28709. this.handleContextMenuMouseEvent(mouseEvent, null, rowComp, cellComp);
  28710. }
  28711. else {
  28712. if (cellComp) {
  28713. cellComp.onMouseEvent(eventName, mouseEvent);
  28714. }
  28715. if (rowComp) {
  28716. rowComp.onMouseEvent(eventName, mouseEvent);
  28717. }
  28718. }
  28719. };
  28720. GridPanel.prototype.mockContextMenuForIPad = function () {
  28721. var _this = this;
  28722. // we do NOT want this when not in iPad, otherwise we will be doing
  28723. if (!_utils__WEBPACK_IMPORTED_MODULE_12__["_"].isIOSUserAgent()) {
  28724. return;
  28725. }
  28726. this.eAllCellContainers.forEach(function (container) {
  28727. var touchListener = new _widgets_touchListener__WEBPACK_IMPORTED_MODULE_6__["TouchListener"](container);
  28728. var longTapListener = function (event) {
  28729. var rowComp = _this.getRowForEvent(event.touchEvent);
  28730. var cellComp = _this.mouseEventService.getRenderedCellForEvent(event.touchEvent);
  28731. _this.handleContextMenuMouseEvent(null, event.touchEvent, rowComp, cellComp);
  28732. };
  28733. _this.addManagedListener(touchListener, _widgets_touchListener__WEBPACK_IMPORTED_MODULE_6__["TouchListener"].EVENT_LONG_TAP, longTapListener);
  28734. _this.addDestroyFunc(function () { return touchListener.destroy(); });
  28735. });
  28736. };
  28737. GridPanel.prototype.handleContextMenuMouseEvent = function (mouseEvent, touchEvent, rowComp, cellComp) {
  28738. var rowNode = rowComp ? rowComp.getRowNode() : null;
  28739. var column = cellComp ? cellComp.getColumn() : null;
  28740. var value = null;
  28741. if (column) {
  28742. var event_1 = mouseEvent ? mouseEvent : touchEvent;
  28743. cellComp.dispatchCellContextMenuEvent(event_1);
  28744. value = this.valueService.getValue(column, rowNode);
  28745. }
  28746. this.onContextMenu(mouseEvent, touchEvent, rowNode, column, value);
  28747. };
  28748. GridPanel.prototype.onContextMenu = function (mouseEvent, touchEvent, rowNode, column, value) {
  28749. // to allow us to debug in chrome, we ignore the event if ctrl is pressed.
  28750. // not everyone wants this, so first 'if' below allows to turn this hack off.
  28751. if (!this.gridOptionsWrapper.isAllowContextMenuWithControlKey()) {
  28752. // then do the check
  28753. if (mouseEvent && (mouseEvent.ctrlKey || mouseEvent.metaKey)) {
  28754. return;
  28755. }
  28756. }
  28757. if (this.contextMenuFactory && !this.gridOptionsWrapper.isSuppressContextMenu()) {
  28758. var eventOrTouch = mouseEvent ? mouseEvent : touchEvent.touches[0];
  28759. if (this.contextMenuFactory.showMenu(rowNode, column, value, eventOrTouch)) {
  28760. var event_2 = mouseEvent ? mouseEvent : touchEvent;
  28761. event_2.preventDefault();
  28762. }
  28763. }
  28764. };
  28765. GridPanel.prototype.preventDefaultOnContextMenu = function (mouseEvent) {
  28766. // if we don't do this, then middle click will never result in a 'click' event, as 'mousedown'
  28767. // will be consumed by the browser to mean 'scroll' (as you can scroll with the middle mouse
  28768. // button in the browser). so this property allows the user to receive middle button clicks if
  28769. // they want.
  28770. var gridOptionsWrapper = this.gridOptionsWrapper;
  28771. var which = mouseEvent.which;
  28772. if (gridOptionsWrapper.isPreventDefaultOnContextMenu() ||
  28773. (gridOptionsWrapper.isSuppressMiddleClickScrolls() && which === 2)) {
  28774. mouseEvent.preventDefault();
  28775. }
  28776. };
  28777. GridPanel.prototype.onCtrlAndA = function (event) {
  28778. var _a = this, beans = _a.beans, pinnedRowModel = _a.pinnedRowModel, paginationProxy = _a.paginationProxy, rangeController = _a.rangeController;
  28779. var PINNED_BOTTOM = _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_BOTTOM, PINNED_TOP = _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_TOP;
  28780. if (rangeController && paginationProxy.isRowsToRender()) {
  28781. var _b = [
  28782. pinnedRowModel.isEmpty(PINNED_TOP),
  28783. pinnedRowModel.isEmpty(PINNED_BOTTOM)
  28784. ], isEmptyPinnedTop = _b[0], isEmptyPinnedBottom = _b[1];
  28785. var floatingStart = isEmptyPinnedTop ? null : PINNED_TOP;
  28786. var floatingEnd = void 0;
  28787. var rowEnd = void 0;
  28788. if (isEmptyPinnedBottom) {
  28789. floatingEnd = null;
  28790. rowEnd = this.paginationProxy.getRowCount() - 1;
  28791. }
  28792. else {
  28793. floatingEnd = PINNED_BOTTOM;
  28794. rowEnd = pinnedRowModel.getPinnedBottomRowData().length - 1;
  28795. }
  28796. var allDisplayedColumns = beans.columnController.getAllDisplayedColumns();
  28797. if (_utils__WEBPACK_IMPORTED_MODULE_12__["_"].missingOrEmpty(allDisplayedColumns)) {
  28798. return;
  28799. }
  28800. rangeController.setCellRange({
  28801. rowStartIndex: 0,
  28802. rowStartPinned: floatingStart,
  28803. rowEndIndex: rowEnd,
  28804. rowEndPinned: floatingEnd,
  28805. columnStart: allDisplayedColumns[0],
  28806. columnEnd: _utils__WEBPACK_IMPORTED_MODULE_12__["_"].last(allDisplayedColumns)
  28807. });
  28808. }
  28809. event.preventDefault();
  28810. };
  28811. GridPanel.prototype.onCtrlAndC = function (event) {
  28812. if (!this.clipboardService || this.gridOptionsWrapper.isEnableCellTextSelection()) {
  28813. return;
  28814. }
  28815. this.clipboardService.copyToClipboard();
  28816. event.preventDefault();
  28817. };
  28818. GridPanel.prototype.onCtrlAndV = function () {
  28819. if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_10__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_11__["ModuleNames"].ClipboardModule) && !this.gridOptionsWrapper.isSuppressClipboardPaste()) {
  28820. this.clipboardService.pasteFromClipboard();
  28821. }
  28822. };
  28823. GridPanel.prototype.onCtrlAndD = function (event) {
  28824. if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_10__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_11__["ModuleNames"].ClipboardModule) && !this.gridOptionsWrapper.isSuppressClipboardPaste()) {
  28825. this.clipboardService.copyRangeDown();
  28826. }
  28827. event.preventDefault();
  28828. };
  28829. // Valid values for position are bottom, middle and top
  28830. // position should be {'top','middle','bottom', or undefined/null}.
  28831. // if undefined/null, then the grid will to the minimal amount of scrolling,
  28832. // eg if grid needs to scroll up, it scrolls until row is on top,
  28833. // if grid needs to scroll down, it scrolls until row is on bottom,
  28834. // if row is already in view, grid does not scroll
  28835. GridPanel.prototype.ensureIndexVisible = function (index, position) {
  28836. // if for print or auto height, everything is always visible
  28837. if (this.printLayout) {
  28838. return;
  28839. }
  28840. var rowCount = this.paginationProxy.getRowCount();
  28841. if (typeof index !== 'number' || index < 0 || index >= rowCount) {
  28842. console.warn('invalid row index for ensureIndexVisible: ' + index);
  28843. return;
  28844. }
  28845. this.paginationProxy.goToPageWithIndex(index);
  28846. var rowNode = this.paginationProxy.getRow(index);
  28847. var rowGotShiftedDuringOperation;
  28848. do {
  28849. var startingRowTop = rowNode.rowTop;
  28850. var startingRowHeight = rowNode.rowHeight;
  28851. var paginationOffset = this.paginationProxy.getPixelOffset();
  28852. var rowTopPixel = rowNode.rowTop - paginationOffset;
  28853. var rowBottomPixel = rowTopPixel + rowNode.rowHeight;
  28854. var scrollPosition = this.getVScrollPosition();
  28855. var heightOffset = this.heightScaler.getOffset();
  28856. var vScrollTop = scrollPosition.top + heightOffset;
  28857. var vScrollBottom = scrollPosition.bottom + heightOffset;
  28858. var viewportHeight = vScrollBottom - vScrollTop;
  28859. // work out the pixels for top, middle and bottom up front,
  28860. // make the if/else below easier to read
  28861. var pxTop = this.heightScaler.getScrollPositionForPixel(rowTopPixel);
  28862. var pxBottom = this.heightScaler.getScrollPositionForPixel(rowBottomPixel - viewportHeight);
  28863. // make sure if middle, the row is not outside the top of the grid
  28864. var pxMiddle = Math.min((pxTop + pxBottom) / 2, rowTopPixel);
  28865. var rowBelowViewport = vScrollTop > rowTopPixel;
  28866. var rowAboveViewport = vScrollBottom < rowBottomPixel;
  28867. var newScrollPosition = null;
  28868. if (position === 'top') {
  28869. newScrollPosition = pxTop;
  28870. }
  28871. else if (position === 'bottom') {
  28872. newScrollPosition = pxBottom;
  28873. }
  28874. else if (position === 'middle') {
  28875. newScrollPosition = pxMiddle;
  28876. }
  28877. else if (rowBelowViewport) {
  28878. // if row is before, scroll up with row at top
  28879. newScrollPosition = pxTop;
  28880. }
  28881. else if (rowAboveViewport) {
  28882. // if row is below, scroll down with row at bottom
  28883. newScrollPosition = pxBottom;
  28884. }
  28885. if (newScrollPosition !== null) {
  28886. this.eBodyViewport.scrollTop = newScrollPosition;
  28887. this.rowRenderer.redrawAfterScroll();
  28888. }
  28889. // the row can get shifted if during the rendering (during rowRenderer.redrawAfterScroll()),
  28890. // the height of a row changes due to lazy calculation of row heights when using
  28891. // colDef.autoHeight or gridOptions.getRowHeight.
  28892. // if row was shifted, then the position we scrolled to is incorrect.
  28893. rowGotShiftedDuringOperation = (startingRowTop !== rowNode.rowTop)
  28894. || (startingRowHeight !== rowNode.rowHeight);
  28895. } while (rowGotShiftedDuringOperation);
  28896. // so when we return back to user, the cells have rendered
  28897. this.animationFrameService.flushAllFrames();
  28898. };
  28899. // + moveColumnController
  28900. GridPanel.prototype.getCenterWidth = function () {
  28901. return this.eCenterViewport.clientWidth;
  28902. };
  28903. GridPanel.prototype.isVerticalScrollShowing = function () {
  28904. var isAlwaysShowVerticalScroll = this.gridOptionsWrapper.isAlwaysShowVerticalScroll();
  28905. _utils__WEBPACK_IMPORTED_MODULE_12__["_"].addOrRemoveCssClass(this.eBodyViewport, 'ag-force-vertical-scroll', isAlwaysShowVerticalScroll);
  28906. return isAlwaysShowVerticalScroll || _utils__WEBPACK_IMPORTED_MODULE_12__["_"].isVerticalScrollShowing(this.eBodyViewport);
  28907. };
  28908. GridPanel.prototype.isHorizontalScrollShowing = function () {
  28909. return _utils__WEBPACK_IMPORTED_MODULE_12__["_"].isHorizontalScrollShowing(this.eCenterViewport);
  28910. };
  28911. // gets called every time the viewport size changes. we use this to check visibility of scrollbars
  28912. // in the grid panel, and also to check size and position of viewport for row and column virtualisation.
  28913. GridPanel.prototype.checkViewportAndScrolls = function () {
  28914. // results in updating anything that depends on scroll showing
  28915. this.updateScrollVisibleService();
  28916. // fires event if height changes, used by PaginationService, HeightScalerService, RowRenderer
  28917. this.checkBodyHeight();
  28918. // check for virtual columns for ColumnController
  28919. this.onHorizontalViewportChanged();
  28920. this.setPinnedContainerSize();
  28921. // this is to cater for AG-3274, where grid is removed from the dom and then inserted back in again.
  28922. // (which happens with some implementations of tabbing). this can result in horizontal scroll getting
  28923. // reset back to the left, however no scroll event is fired. so we need to get header to also scroll
  28924. // back to the left to be kept in sync.
  28925. // adding and removing the grid from the DOM both resets the scroll position and
  28926. // triggers a resize event, so notify listeners if the scroll position has changed
  28927. if (this.scrollLeft !== this.getCenterViewportScrollLeft()) {
  28928. this.onBodyHorizontalScroll(this.eCenterViewport);
  28929. }
  28930. };
  28931. GridPanel.prototype.updateScrollVisibleService = function () {
  28932. // because of column animation (which takes 200ms), we have to do this twice.
  28933. // eg if user removes cols anywhere except at the RHS, then the cols on the RHS
  28934. // will animate to the left to fill the gap. this animation means just after
  28935. // the cols are removed, the remaining cols are still in the original location
  28936. // at the start of the animation, so pre animation the H scrollbar is still needed,
  28937. // but post animation it is not.
  28938. this.updateScrollVisibleServiceImpl();
  28939. setTimeout(this.updateScrollVisibleServiceImpl.bind(this), 500);
  28940. };
  28941. GridPanel.prototype.updateScrollVisibleServiceImpl = function () {
  28942. var params = {
  28943. horizontalScrollShowing: false,
  28944. verticalScrollShowing: false
  28945. };
  28946. params.verticalScrollShowing = this.isVerticalScrollShowing();
  28947. params.horizontalScrollShowing = this.isHorizontalScrollShowing();
  28948. this.scrollVisibleService.setScrollsVisible(params);
  28949. this.setHorizontalScrollVisible(params.horizontalScrollShowing);
  28950. this.setVerticalScrollPaddingVisible(params.verticalScrollShowing);
  28951. };
  28952. GridPanel.prototype.setHorizontalScrollVisible = function (visible) {
  28953. var isSuppressHorizontalScroll = this.gridOptionsWrapper.isSuppressHorizontalScroll();
  28954. var scrollSize = visible ? (this.gridOptionsWrapper.getScrollbarWidth() || 0) : 0;
  28955. var scrollContainerSize = !isSuppressHorizontalScroll ? scrollSize : 0;
  28956. var addIEPadding = _utils__WEBPACK_IMPORTED_MODULE_12__["_"].isBrowserIE() && visible;
  28957. this.eCenterViewport.style.height = "calc(100% + " + scrollSize + "px)";
  28958. _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setFixedHeight(this.eHorizontalScrollBody, scrollContainerSize);
  28959. // we have to add an extra pixel to the scroller viewport on IE because
  28960. // if the container has the same size as the scrollbar, the scroll button won't work
  28961. _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setFixedHeight(this.eBodyHorizontalScrollViewport, scrollContainerSize + (addIEPadding ? 1 : 0));
  28962. _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setFixedHeight(this.eBodyHorizontalScrollContainer, scrollContainerSize);
  28963. };
  28964. GridPanel.prototype.setVerticalScrollPaddingVisible = function (show) {
  28965. var scroller = show ? 'scroll' : 'hidden';
  28966. this.eTop.style.overflowY = this.eBottom.style.overflowY = scroller;
  28967. this.setFakeHScrollSpacerWidths();
  28968. };
  28969. GridPanel.prototype.updateRowCount = function () {
  28970. var headerCount = this.headerNavigationService.getHeaderRowCount();
  28971. var rowCount = this.paginationProxy.getRowCount();
  28972. var total = (headerCount + rowCount).toString();
  28973. this.getGui().setAttribute('aria-rowcount', total);
  28974. };
  28975. GridPanel.prototype.updateColumnCount = function () {
  28976. var columns = this.columnController.getAllDisplayedColumns();
  28977. this.getGui().setAttribute('aria-colcount', columns.length.toString());
  28978. };
  28979. GridPanel.prototype.ensureColumnVisible = function (key) {
  28980. var column = this.columnController.getGridColumn(key);
  28981. if (!column) {
  28982. return;
  28983. }
  28984. if (column.isPinned()) {
  28985. console.warn('calling ensureIndexVisible on a ' + column.getPinned() + ' pinned column doesn\'t make sense for column ' + column.getColId());
  28986. return;
  28987. }
  28988. if (!this.columnController.isColumnDisplayed(column)) {
  28989. console.warn('column is not currently visible');
  28990. return;
  28991. }
  28992. var colLeftPixel = column.getLeft();
  28993. var colRightPixel = colLeftPixel + column.getActualWidth();
  28994. var viewportWidth = this.eCenterViewport.clientWidth;
  28995. var scrollPosition = this.getCenterViewportScrollLeft();
  28996. var bodyWidth = this.columnController.getBodyContainerWidth();
  28997. var viewportLeftPixel;
  28998. var viewportRightPixel;
  28999. // the logic of working out left and right viewport px is both here and in the ColumnController,
  29000. // need to refactor it out to one place
  29001. if (this.enableRtl) {
  29002. viewportLeftPixel = bodyWidth - scrollPosition - viewportWidth;
  29003. viewportRightPixel = bodyWidth - scrollPosition;
  29004. }
  29005. else {
  29006. viewportLeftPixel = scrollPosition;
  29007. viewportRightPixel = viewportWidth + scrollPosition;
  29008. }
  29009. var viewportScrolledPastCol = viewportLeftPixel > colLeftPixel;
  29010. var viewportScrolledBeforeCol = viewportRightPixel < colRightPixel;
  29011. var colToSmallForViewport = viewportWidth < column.getActualWidth();
  29012. var alignColToLeft = viewportScrolledPastCol || colToSmallForViewport;
  29013. var alignColToRight = viewportScrolledBeforeCol;
  29014. var newScrollPosition = this.getCenterViewportScrollLeft();
  29015. if (alignColToLeft || alignColToRight) {
  29016. if (this.enableRtl) {
  29017. newScrollPosition = alignColToLeft ? (bodyWidth - viewportWidth - colLeftPixel) : (bodyWidth - colRightPixel);
  29018. }
  29019. else {
  29020. newScrollPosition = alignColToLeft ? colLeftPixel : (colRightPixel - viewportWidth);
  29021. }
  29022. this.setCenterViewportScrollLeft(newScrollPosition);
  29023. }
  29024. else {
  29025. // otherwise, col is already in view, so do nothing
  29026. }
  29027. // this will happen anyway, as the move will cause a 'scroll' event on the body, however
  29028. // it is possible that the ensureColumnVisible method is called from within ag-Grid and
  29029. // the caller will need to have the columns rendered to continue, which will be before
  29030. // the event has been worked on (which is the case for cell navigation).
  29031. this.onHorizontalViewportChanged();
  29032. // so when we return back to user, the cells have rendered
  29033. this.animationFrameService.flushAllFrames();
  29034. };
  29035. GridPanel.prototype.showLoadingOverlay = function () {
  29036. if (!this.gridOptionsWrapper.isSuppressLoadingOverlay()) {
  29037. this.overlayWrapper.showLoadingOverlay();
  29038. }
  29039. };
  29040. GridPanel.prototype.showNoRowsOverlay = function () {
  29041. if (!this.gridOptionsWrapper.isSuppressNoRowsOverlay()) {
  29042. this.overlayWrapper.showNoRowsOverlay();
  29043. }
  29044. };
  29045. GridPanel.prototype.hideOverlay = function () {
  29046. this.overlayWrapper.hideOverlay();
  29047. };
  29048. // method will call itself if no available width. this covers if the grid
  29049. // isn't visible, but is just about to be visible.
  29050. GridPanel.prototype.sizeColumnsToFit = function (nextTimeout) {
  29051. var _this = this;
  29052. var availableWidth = this.eBodyViewport.clientWidth;
  29053. if (availableWidth > 0) {
  29054. this.columnController.sizeColumnsToFit(availableWidth, "sizeColumnsToFit");
  29055. return;
  29056. }
  29057. if (nextTimeout === undefined) {
  29058. window.setTimeout(function () {
  29059. _this.sizeColumnsToFit(100);
  29060. }, 0);
  29061. }
  29062. else if (nextTimeout === 100) {
  29063. window.setTimeout(function () {
  29064. _this.sizeColumnsToFit(500);
  29065. }, 100);
  29066. }
  29067. else if (nextTimeout === 500) {
  29068. window.setTimeout(function () {
  29069. _this.sizeColumnsToFit(-1);
  29070. }, 500);
  29071. }
  29072. else {
  29073. console.warn('ag-Grid: tried to call sizeColumnsToFit() but the grid is coming back with ' +
  29074. 'zero width, maybe the grid is not visible yet on the screen?');
  29075. }
  29076. };
  29077. // used by autoWidthCalculator and autoHeightCalculator
  29078. GridPanel.prototype.getCenterContainer = function () {
  29079. return this.eCenterContainer;
  29080. };
  29081. GridPanel.prototype.getDropTargetBodyContainers = function () {
  29082. return [this.eCenterViewport, this.eTopViewport, this.eBottomViewport];
  29083. };
  29084. GridPanel.prototype.getDropTargetLeftContainers = function () {
  29085. return [this.eLeftContainer, this.eLeftBottom, this.eLeftTop];
  29086. };
  29087. GridPanel.prototype.getDropTargetRightContainers = function () {
  29088. return [this.eRightContainer, this.eRightBottom, this.eRightTop];
  29089. };
  29090. GridPanel.prototype.buildRowContainerComponents = function () {
  29091. var _this = this;
  29092. this.eAllCellContainers = [
  29093. this.eLeftContainer, this.eRightContainer, this.eCenterContainer,
  29094. this.eTop, this.eBottom, this.eFullWidthContainer
  29095. ];
  29096. this.rowContainerComponents = {
  29097. body: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({
  29098. eContainer: this.eCenterContainer,
  29099. eWrapper: this.eCenterColsClipper,
  29100. eViewport: this.eBodyViewport
  29101. }),
  29102. fullWidth: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({
  29103. eContainer: this.eFullWidthContainer
  29104. }),
  29105. pinnedLeft: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ eContainer: this.eLeftContainer }),
  29106. pinnedRight: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ eContainer: this.eRightContainer }),
  29107. floatingTop: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ eContainer: this.eTopContainer }),
  29108. floatingTopPinnedLeft: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ eContainer: this.eLeftTop }),
  29109. floatingTopPinnedRight: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ eContainer: this.eRightTop }),
  29110. floatingTopFullWidth: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({
  29111. eContainer: this.eTopFullWidthContainer,
  29112. hideWhenNoChildren: true
  29113. }),
  29114. floatingBottom: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ eContainer: this.eBottomContainer }),
  29115. floatingBottomPinnedLeft: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ eContainer: this.eLeftBottom }),
  29116. floatingBottomPinnedRight: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({ eContainer: this.eRightBottom }),
  29117. floatingBottomFullWidth: new _rendering_rowContainerComponent__WEBPACK_IMPORTED_MODULE_4__["RowContainerComponent"]({
  29118. eContainer: this.eBottomFullWidthContainer,
  29119. hideWhenNoChildren: true
  29120. }),
  29121. };
  29122. _utils__WEBPACK_IMPORTED_MODULE_12__["_"].iterateObject(this.rowContainerComponents, function (key, container) {
  29123. if (container) {
  29124. _this.getContext().createBean(container);
  29125. }
  29126. });
  29127. };
  29128. GridPanel.prototype.setupRowAnimationCssClass = function () {
  29129. var _this = this;
  29130. var listener = function () {
  29131. // we don't want to use row animation if scaling, as rows jump strangely as you scroll,
  29132. // when scaling and doing row animation.
  29133. var animateRows = _this.gridOptionsWrapper.isAnimateRows() && !_this.heightScaler.isScaling();
  29134. _utils__WEBPACK_IMPORTED_MODULE_12__["_"].addOrRemoveCssClass(_this.eBodyViewport, 'ag-row-animation', animateRows);
  29135. _utils__WEBPACK_IMPORTED_MODULE_12__["_"].addOrRemoveCssClass(_this.eBodyViewport, 'ag-row-no-animation', !animateRows);
  29136. };
  29137. listener();
  29138. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_HEIGHT_SCALE_CHANGED, listener);
  29139. };
  29140. // when editing a pinned row, if the cell is half outside the scrollable area, the browser can
  29141. // scroll the column into view. we do not want this, the pinned sections should never scroll.
  29142. // so we listen to scrolls on these containers and reset the scroll if we find one.
  29143. GridPanel.prototype.suppressScrollOnFloatingRow = function () {
  29144. var _this = this;
  29145. var resetTopScroll = function () { return _this.eTopViewport.scrollLeft = 0; };
  29146. var resetBottomScroll = function () { return _this.eTopViewport.scrollLeft = 0; };
  29147. this.addManagedListener(this.eTopViewport, 'scroll', resetTopScroll);
  29148. this.addManagedListener(this.eBottomViewport, 'scroll', resetBottomScroll);
  29149. };
  29150. GridPanel.prototype.getRowContainers = function () {
  29151. return this.rowContainerComponents;
  29152. };
  29153. GridPanel.prototype.getFloatingTopBottom = function () {
  29154. return [this.eTop, this.eBottom];
  29155. };
  29156. GridPanel.prototype.onDisplayedColumnsChanged = function () {
  29157. this.setPinnedContainerSize();
  29158. this.setHeaderAndFloatingHeights();
  29159. this.onHorizontalViewportChanged();
  29160. this.updateScrollVisibleService();
  29161. this.updateColumnCount();
  29162. };
  29163. GridPanel.prototype.onDisplayedColumnsWidthChanged = function () {
  29164. this.setWidthsOfContainers();
  29165. this.onHorizontalViewportChanged();
  29166. this.updateScrollVisibleService();
  29167. if (this.enableRtl) {
  29168. // because RTL is all backwards, a change in the width of the row
  29169. // can cause a change in the scroll position, without a scroll event,
  29170. // because the scroll position in RTL is a function that depends on
  29171. // the width. to be convinced of this, take out this line, enable RTL,
  29172. // scroll all the way to the left and then resize a column
  29173. this.horizontallyScrollHeaderCenterAndFloatingCenter();
  29174. }
  29175. };
  29176. GridPanel.prototype.setWidthsOfContainers = function () {
  29177. this.setCenterWidth();
  29178. this.setPinnedContainerSize();
  29179. };
  29180. GridPanel.prototype.setCenterWidth = function () {
  29181. var _a = this, headerRootComp = _a.headerRootComp, columnController = _a.columnController;
  29182. var width = columnController.getBodyContainerWidth();
  29183. if (this.printLayout) {
  29184. var pinnedContainerWidths = columnController.getPinnedLeftContainerWidth()
  29185. + columnController.getPinnedRightContainerWidth();
  29186. width += pinnedContainerWidths;
  29187. }
  29188. headerRootComp.setHeaderContainerWidth(width);
  29189. var widthPx = width + "px";
  29190. this.eCenterContainer.style.width = widthPx;
  29191. this.eBottomContainer.style.width = widthPx;
  29192. this.eTopContainer.style.width = widthPx;
  29193. if (!this.printLayout) {
  29194. this.eBodyHorizontalScrollContainer.style.width = widthPx;
  29195. }
  29196. };
  29197. GridPanel.prototype.setPinnedLeftWidth = function () {
  29198. var _this = this;
  29199. var oldPinning = this.pinningLeft;
  29200. var widthOfCols = this.columnController.getPinnedLeftContainerWidth();
  29201. var newPinning = this.pinningLeft = !this.printLayout && widthOfCols > 0;
  29202. var containers = [this.eLeftContainer, this.eLeftTop, this.eLeftBottom];
  29203. if (oldPinning !== newPinning) {
  29204. this.headerRootComp.setLeftVisible(newPinning);
  29205. }
  29206. containers.forEach(function (e) { return _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setDisplayed(e, _this.pinningLeft); });
  29207. if (newPinning) {
  29208. containers.forEach(function (ct) { return _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setFixedWidth(ct, widthOfCols); });
  29209. }
  29210. };
  29211. GridPanel.prototype.setPinnedRightWidth = function () {
  29212. var oldPinning = this.pinningRight;
  29213. var widthOfCols = this.columnController.getPinnedRightContainerWidth();
  29214. var newPinning = this.pinningRight = !this.printLayout && widthOfCols > 0;
  29215. var containers = [this.eRightContainer, this.eRightTop, this.eRightBottom];
  29216. if (oldPinning !== newPinning) {
  29217. this.headerRootComp.setRightVisible(newPinning);
  29218. }
  29219. containers.forEach(function (ct) { return _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setDisplayed(ct, newPinning); });
  29220. if (newPinning) {
  29221. containers.forEach(function (ct) { return _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setFixedWidth(ct, widthOfCols); });
  29222. }
  29223. };
  29224. GridPanel.prototype.setPinnedContainerSize = function () {
  29225. this.setPinnedLeftWidth();
  29226. this.setPinnedRightWidth();
  29227. this.setFakeHScrollSpacerWidths();
  29228. };
  29229. GridPanel.prototype.setFakeHScrollSpacerWidths = function () {
  29230. // we pad the right based on a) if cols are pinned to the right and
  29231. // b) if v scroll is showing on the right (normal position of scroll)
  29232. var rightSpacing = this.columnController.getPinnedRightContainerWidth();
  29233. var scrollOnRight = !this.enableRtl && this.isVerticalScrollShowing();
  29234. if (scrollOnRight) {
  29235. rightSpacing += this.scrollWidth;
  29236. }
  29237. _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setFixedWidth(this.eHorizontalRightSpacer, rightSpacing);
  29238. _utils__WEBPACK_IMPORTED_MODULE_12__["_"].addOrRemoveCssClass(this.eHorizontalRightSpacer, 'ag-scroller-corner', rightSpacing <= this.scrollWidth);
  29239. // we pad the left based on a) if cols are pinned to the left and
  29240. // b) if v scroll is showing on the left (happens in LTR layout only)
  29241. var leftSpacing = this.columnController.getPinnedLeftContainerWidth();
  29242. var scrollOnLeft = this.enableRtl && this.isVerticalScrollShowing();
  29243. if (scrollOnLeft) {
  29244. leftSpacing += this.scrollWidth;
  29245. }
  29246. _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setFixedWidth(this.eHorizontalLeftSpacer, leftSpacing);
  29247. _utils__WEBPACK_IMPORTED_MODULE_12__["_"].addOrRemoveCssClass(this.eHorizontalLeftSpacer, 'ag-scroller-corner', leftSpacing <= this.scrollWidth);
  29248. };
  29249. GridPanel.prototype.checkBodyHeight = function () {
  29250. var bodyHeight = this.eBodyViewport.clientHeight;
  29251. if (this.bodyHeight !== bodyHeight) {
  29252. this.bodyHeight = bodyHeight;
  29253. var event_3 = {
  29254. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_BODY_HEIGHT_CHANGED,
  29255. api: this.gridApi,
  29256. columnApi: this.columnApi
  29257. };
  29258. this.eventService.dispatchEvent(event_3);
  29259. }
  29260. };
  29261. GridPanel.prototype.setHeaderAndFloatingHeights = function () {
  29262. var _a = this, columnController = _a.columnController, gridOptionsWrapper = _a.gridOptionsWrapper, pinnedRowModel = _a.pinnedRowModel, eTop = _a.eTop, eBottom = _a.eBottom;
  29263. var numberOfFloating = 0;
  29264. var headerRowCount = columnController.getHeaderRowCount();
  29265. var totalHeaderHeight;
  29266. var groupHeight;
  29267. var headerHeight;
  29268. if (columnController.isPivotMode()) {
  29269. groupHeight = gridOptionsWrapper.getPivotGroupHeaderHeight();
  29270. headerHeight = gridOptionsWrapper.getPivotHeaderHeight();
  29271. }
  29272. else {
  29273. var hasFloatingFilters = columnController.hasFloatingFilters();
  29274. if (hasFloatingFilters) {
  29275. headerRowCount++;
  29276. numberOfFloating = 1;
  29277. }
  29278. groupHeight = gridOptionsWrapper.getGroupHeaderHeight();
  29279. headerHeight = gridOptionsWrapper.getHeaderHeight();
  29280. }
  29281. var numberOfNonGroups = 1 + numberOfFloating;
  29282. var numberOfGroups = headerRowCount - numberOfNonGroups;
  29283. totalHeaderHeight = numberOfFloating * gridOptionsWrapper.getFloatingFiltersHeight();
  29284. totalHeaderHeight += numberOfGroups * groupHeight;
  29285. totalHeaderHeight += headerHeight;
  29286. this.headerRootComp.setHeight(totalHeaderHeight);
  29287. var floatingTopHeight = pinnedRowModel.getPinnedTopTotalHeight();
  29288. if (floatingTopHeight) {
  29289. // adding 1px for cell bottom border
  29290. floatingTopHeight += 1;
  29291. }
  29292. var floatingBottomHeight = pinnedRowModel.getPinnedBottomTotalHeight();
  29293. if (floatingBottomHeight) {
  29294. // adding 1px for cell bottom border
  29295. floatingBottomHeight += 1;
  29296. }
  29297. var floatingTopHeightString = floatingTopHeight + "px";
  29298. var floatingBottomHeightString = floatingBottomHeight + "px";
  29299. eTop.style.minHeight = floatingTopHeightString;
  29300. eTop.style.height = floatingTopHeightString;
  29301. eTop.style.display = floatingTopHeight ? 'inherit' : 'none';
  29302. eBottom.style.minHeight = floatingBottomHeightString;
  29303. eBottom.style.height = floatingBottomHeightString;
  29304. eBottom.style.display = floatingBottomHeight ? 'inherit' : 'none';
  29305. this.checkBodyHeight();
  29306. };
  29307. GridPanel.prototype.getBodyHeight = function () {
  29308. return this.bodyHeight;
  29309. };
  29310. // called by scrollHorizontally method and alignedGridsService
  29311. GridPanel.prototype.setHorizontalScrollPosition = function (hScrollPosition) {
  29312. this.eCenterViewport.scrollLeft = hScrollPosition;
  29313. // we need to manually do the event handling (rather than wait for the event)
  29314. // for the alignedGridsService, as if we don't, the aligned grid service gets
  29315. // notified async, and then it's 'consuming' flag doesn't get used right, and
  29316. // we can end up with an infinite loop
  29317. this.doHorizontalScroll(hScrollPosition);
  29318. };
  29319. GridPanel.prototype.setVerticalScrollPosition = function (vScrollPosition) {
  29320. this.eBodyViewport.scrollTop = vScrollPosition;
  29321. };
  29322. // called by the headerRootComp and moveColumnController
  29323. GridPanel.prototype.scrollHorizontally = function (pixels) {
  29324. var oldScrollPosition = this.eCenterViewport.scrollLeft;
  29325. this.setHorizontalScrollPosition(oldScrollPosition + pixels);
  29326. return this.eCenterViewport.scrollLeft - oldScrollPosition;
  29327. };
  29328. // called by rowDragFeature
  29329. GridPanel.prototype.scrollVertically = function (pixels) {
  29330. var oldScrollPosition = this.eBodyViewport.scrollTop;
  29331. this.setVerticalScrollPosition(oldScrollPosition + pixels);
  29332. return this.eBodyViewport.scrollTop - oldScrollPosition;
  29333. };
  29334. GridPanel.prototype.addScrollListener = function () {
  29335. this.addManagedListener(this.eCenterViewport, 'scroll', this.onCenterViewportScroll.bind(this));
  29336. this.addManagedListener(this.eBodyHorizontalScrollViewport, 'scroll', this.onFakeHorizontalScroll.bind(this));
  29337. this.addManagedListener(this.eBodyViewport, 'scroll', this.onVerticalScroll.bind(this));
  29338. };
  29339. GridPanel.prototype.onVerticalScroll = function () {
  29340. var scrollTop = this.eBodyViewport.scrollTop;
  29341. this.animationFrameService.setScrollTop(scrollTop);
  29342. this.scrollTop = scrollTop;
  29343. this.redrawRowsAfterScroll();
  29344. };
  29345. GridPanel.prototype.isControllingScroll = function (eDiv) {
  29346. if (!this.lastHorizontalScrollElement) {
  29347. this.lastHorizontalScrollElement = eDiv;
  29348. return true;
  29349. }
  29350. return eDiv === this.lastHorizontalScrollElement;
  29351. };
  29352. GridPanel.prototype.onFakeHorizontalScroll = function () {
  29353. if (!this.isControllingScroll(this.eBodyHorizontalScrollViewport)) {
  29354. return;
  29355. }
  29356. this.onBodyHorizontalScroll(this.eBodyHorizontalScrollViewport);
  29357. };
  29358. GridPanel.prototype.onCenterViewportScroll = function () {
  29359. if (!this.isControllingScroll(this.eCenterViewport)) {
  29360. return;
  29361. }
  29362. this.onBodyHorizontalScroll(this.eCenterViewport);
  29363. };
  29364. GridPanel.prototype.onBodyHorizontalScroll = function (eSource) {
  29365. var _a = this.eCenterViewport, scrollWidth = _a.scrollWidth, clientWidth = _a.clientWidth;
  29366. // in chrome, fractions can be in the scroll left, eg 250.342234 - which messes up our 'scrollWentPastBounds'
  29367. // formula. so we floor it to allow the formula to work.
  29368. var scrollLeft = Math.floor(_utils__WEBPACK_IMPORTED_MODULE_12__["_"].getScrollLeft(eSource, this.enableRtl));
  29369. // touch devices allow elastic scroll - which temporally scrolls the panel outside of the viewport
  29370. // (eg user uses touch to go to the left of the grid, but drags past the left, the rows will actually
  29371. // scroll past the left until the user releases the mouse). when this happens, we want ignore the scroll,
  29372. // as otherwise it was causing the rows and header to flicker.
  29373. // sometimes when scrolling, we got values that extended the maximum scroll allowed. we used to
  29374. // ignore these scrolls. problem is the max scroll position could be skipped (eg the previous scroll event
  29375. // could be 10px before the max position, and then current scroll event could be 20px after the max position).
  29376. // if we just ignored the last event, we would be setting the scroll to 10px before the max position, when in
  29377. // actual fact the user has exceeded the max scroll and thus scroll should be set to the max.
  29378. var minScroll = 0;
  29379. var maxScroll = scrollWidth - clientWidth;
  29380. if (scrollLeft < minScroll) {
  29381. scrollLeft = minScroll;
  29382. }
  29383. else if (scrollLeft > maxScroll) {
  29384. scrollLeft = maxScroll;
  29385. }
  29386. this.doHorizontalScroll(scrollLeft);
  29387. this.resetLastHorizontalScrollElementDebounced();
  29388. };
  29389. GridPanel.prototype.resetLastHorizontalScrollElement = function () {
  29390. this.lastHorizontalScrollElement = null;
  29391. };
  29392. GridPanel.prototype.doHorizontalScroll = function (scrollLeft) {
  29393. this.scrollLeft = scrollLeft;
  29394. var event = {
  29395. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_BODY_SCROLL,
  29396. api: this.gridApi,
  29397. columnApi: this.columnApi,
  29398. direction: 'horizontal',
  29399. left: this.scrollLeft,
  29400. top: this.scrollTop
  29401. };
  29402. this.eventService.dispatchEvent(event);
  29403. this.horizontallyScrollHeaderCenterAndFloatingCenter(scrollLeft);
  29404. this.onHorizontalViewportChanged();
  29405. };
  29406. GridPanel.prototype.redrawRowsAfterScroll = function () {
  29407. var event = {
  29408. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_BODY_SCROLL,
  29409. direction: 'vertical',
  29410. api: this.gridApi,
  29411. columnApi: this.columnApi,
  29412. left: this.scrollLeft,
  29413. top: this.scrollTop
  29414. };
  29415. this.eventService.dispatchEvent(event);
  29416. };
  29417. // this gets called whenever a change in the viewport, so we can inform column controller it has to work
  29418. // out the virtual columns again. gets called from following locations:
  29419. // + ensureColVisible, scroll, init, layoutChanged, displayedColumnsChanged, API (doLayout)
  29420. GridPanel.prototype.onHorizontalViewportChanged = function () {
  29421. var scrollWidth = this.eCenterViewport.clientWidth;
  29422. var scrollPosition = this.getCenterViewportScrollLeft();
  29423. this.columnController.setVirtualViewportPosition(scrollWidth, scrollPosition);
  29424. };
  29425. GridPanel.prototype.getCenterViewportScrollLeft = function () {
  29426. // we defer to a util, as how you calculated scrollLeft when doing RTL depends on the browser
  29427. return _utils__WEBPACK_IMPORTED_MODULE_12__["_"].getScrollLeft(this.eCenterViewport, this.enableRtl);
  29428. };
  29429. GridPanel.prototype.setCenterViewportScrollLeft = function (value) {
  29430. // we defer to a util, as how you calculated scrollLeft when doing RTL depends on the browser
  29431. _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setScrollLeft(this.eCenterViewport, value, this.enableRtl);
  29432. };
  29433. GridPanel.prototype.horizontallyScrollHeaderCenterAndFloatingCenter = function (scrollLeft) {
  29434. if (scrollLeft === undefined) {
  29435. scrollLeft = this.getCenterViewportScrollLeft();
  29436. }
  29437. var offset = this.enableRtl ? scrollLeft : -scrollLeft;
  29438. var _a = this.eCenterViewport, clientWidth = _a.clientWidth, scrollWidth = _a.scrollWidth;
  29439. var scrollWentPastBounds = Math.abs(offset) + clientWidth > scrollWidth;
  29440. if (scrollWentPastBounds ||
  29441. (this.enableRtl && offset < 0) ||
  29442. (!this.enableRtl && offset > 0)) {
  29443. return;
  29444. }
  29445. this.headerRootComp.setHorizontalScroll(offset);
  29446. this.eBottomContainer.style.transform = "translateX(" + offset + "px)";
  29447. this.eTopContainer.style.transform = "translateX(" + offset + "px)";
  29448. var partner = this.lastHorizontalScrollElement === this.eCenterViewport ? this.eBodyHorizontalScrollViewport : this.eCenterViewport;
  29449. _utils__WEBPACK_IMPORTED_MODULE_12__["_"].setScrollLeft(partner, scrollLeft, this.enableRtl);
  29450. };
  29451. // + rangeController
  29452. GridPanel.prototype.addScrollEventListener = function (listener) {
  29453. this.eBodyViewport.addEventListener('scroll', listener);
  29454. };
  29455. // + rangeController
  29456. GridPanel.prototype.removeScrollEventListener = function (listener) {
  29457. this.eBodyViewport.removeEventListener('scroll', listener);
  29458. };
  29459. __decorate([
  29460. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('alignedGridsService')
  29461. ], GridPanel.prototype, "alignedGridsService", void 0);
  29462. __decorate([
  29463. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  29464. ], GridPanel.prototype, "gridOptionsWrapper", void 0);
  29465. __decorate([
  29466. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowRenderer')
  29467. ], GridPanel.prototype, "rowRenderer", void 0);
  29468. __decorate([
  29469. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('pinnedRowModel')
  29470. ], GridPanel.prototype, "pinnedRowModel", void 0);
  29471. __decorate([
  29472. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('animationFrameService')
  29473. ], GridPanel.prototype, "animationFrameService", void 0);
  29474. __decorate([
  29475. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('navigationService')
  29476. ], GridPanel.prototype, "navigationService", void 0);
  29477. __decorate([
  29478. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('autoHeightCalculator')
  29479. ], GridPanel.prototype, "autoHeightCalculator", void 0);
  29480. __decorate([
  29481. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnAnimationService')
  29482. ], GridPanel.prototype, "columnAnimationService", void 0);
  29483. __decorate([
  29484. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('autoWidthCalculator')
  29485. ], GridPanel.prototype, "autoWidthCalculator", void 0);
  29486. __decorate([
  29487. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('paginationAutoPageSizeService')
  29488. ], GridPanel.prototype, "paginationAutoPageSizeService", void 0);
  29489. __decorate([
  29490. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('beans')
  29491. ], GridPanel.prototype, "beans", void 0);
  29492. __decorate([
  29493. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('paginationProxy')
  29494. ], GridPanel.prototype, "paginationProxy", void 0);
  29495. __decorate([
  29496. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnApi')
  29497. ], GridPanel.prototype, "columnApi", void 0);
  29498. __decorate([
  29499. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridApi')
  29500. ], GridPanel.prototype, "gridApi", void 0);
  29501. __decorate([
  29502. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('dragService')
  29503. ], GridPanel.prototype, "dragService", void 0);
  29504. __decorate([
  29505. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('mouseEventService')
  29506. ], GridPanel.prototype, "mouseEventService", void 0);
  29507. __decorate([
  29508. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('$scope')
  29509. ], GridPanel.prototype, "$scope", void 0);
  29510. __decorate([
  29511. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('scrollVisibleService')
  29512. ], GridPanel.prototype, "scrollVisibleService", void 0);
  29513. __decorate([
  29514. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('valueService')
  29515. ], GridPanel.prototype, "valueService", void 0);
  29516. __decorate([
  29517. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('dragAndDropService')
  29518. ], GridPanel.prototype, "dragAndDropService", void 0);
  29519. __decorate([
  29520. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('maxDivHeightScaler')
  29521. ], GridPanel.prototype, "heightScaler", void 0);
  29522. __decorate([
  29523. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('resizeObserverService')
  29524. ], GridPanel.prototype, "resizeObserverService", void 0);
  29525. __decorate([
  29526. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('undoRedoService')
  29527. ], GridPanel.prototype, "undoRedoService", void 0);
  29528. __decorate([
  29529. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController')
  29530. ], GridPanel.prototype, "columnController", void 0);
  29531. __decorate([
  29532. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('headerNavigationService')
  29533. ], GridPanel.prototype, "headerNavigationService", void 0);
  29534. __decorate([
  29535. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Optional"])('rangeController')
  29536. ], GridPanel.prototype, "rangeController", void 0);
  29537. __decorate([
  29538. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Optional"])('contextMenuFactory')
  29539. ], GridPanel.prototype, "contextMenuFactory", void 0);
  29540. __decorate([
  29541. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Optional"])('clipboardService')
  29542. ], GridPanel.prototype, "clipboardService", void 0);
  29543. __decorate([
  29544. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eBodyViewport')
  29545. ], GridPanel.prototype, "eBodyViewport", void 0);
  29546. __decorate([
  29547. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eCenterContainer')
  29548. ], GridPanel.prototype, "eCenterContainer", void 0);
  29549. __decorate([
  29550. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eCenterViewport')
  29551. ], GridPanel.prototype, "eCenterViewport", void 0);
  29552. __decorate([
  29553. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eLeftContainer')
  29554. ], GridPanel.prototype, "eLeftContainer", void 0);
  29555. __decorate([
  29556. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eRightContainer')
  29557. ], GridPanel.prototype, "eRightContainer", void 0);
  29558. __decorate([
  29559. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eCenterColsClipper')
  29560. ], GridPanel.prototype, "eCenterColsClipper", void 0);
  29561. __decorate([
  29562. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eHorizontalScrollBody')
  29563. ], GridPanel.prototype, "eHorizontalScrollBody", void 0);
  29564. __decorate([
  29565. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eHorizontalLeftSpacer')
  29566. ], GridPanel.prototype, "eHorizontalLeftSpacer", void 0);
  29567. __decorate([
  29568. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eHorizontalRightSpacer')
  29569. ], GridPanel.prototype, "eHorizontalRightSpacer", void 0);
  29570. __decorate([
  29571. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eBodyHorizontalScrollViewport')
  29572. ], GridPanel.prototype, "eBodyHorizontalScrollViewport", void 0);
  29573. __decorate([
  29574. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eBodyHorizontalScrollContainer')
  29575. ], GridPanel.prototype, "eBodyHorizontalScrollContainer", void 0);
  29576. __decorate([
  29577. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eFullWidthContainer')
  29578. ], GridPanel.prototype, "eFullWidthContainer", void 0);
  29579. __decorate([
  29580. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eTop')
  29581. ], GridPanel.prototype, "eTop", void 0);
  29582. __decorate([
  29583. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eLeftTop')
  29584. ], GridPanel.prototype, "eLeftTop", void 0);
  29585. __decorate([
  29586. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eRightTop')
  29587. ], GridPanel.prototype, "eRightTop", void 0);
  29588. __decorate([
  29589. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eTopContainer')
  29590. ], GridPanel.prototype, "eTopContainer", void 0);
  29591. __decorate([
  29592. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eTopViewport')
  29593. ], GridPanel.prototype, "eTopViewport", void 0);
  29594. __decorate([
  29595. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eTopFullWidthContainer')
  29596. ], GridPanel.prototype, "eTopFullWidthContainer", void 0);
  29597. __decorate([
  29598. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eBottom')
  29599. ], GridPanel.prototype, "eBottom", void 0);
  29600. __decorate([
  29601. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eLeftBottom')
  29602. ], GridPanel.prototype, "eLeftBottom", void 0);
  29603. __decorate([
  29604. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eRightBottom')
  29605. ], GridPanel.prototype, "eRightBottom", void 0);
  29606. __decorate([
  29607. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eBottomContainer')
  29608. ], GridPanel.prototype, "eBottomContainer", void 0);
  29609. __decorate([
  29610. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eBottomViewport')
  29611. ], GridPanel.prototype, "eBottomViewport", void 0);
  29612. __decorate([
  29613. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('eBottomFullWidthContainer')
  29614. ], GridPanel.prototype, "eBottomFullWidthContainer", void 0);
  29615. __decorate([
  29616. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('headerRoot')
  29617. ], GridPanel.prototype, "headerRootComp", void 0);
  29618. __decorate([
  29619. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_9__["RefSelector"])('overlayWrapper')
  29620. ], GridPanel.prototype, "overlayWrapper", void 0);
  29621. __decorate([
  29622. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  29623. ], GridPanel.prototype, "init", null);
  29624. return GridPanel;
  29625. }(_widgets_component__WEBPACK_IMPORTED_MODULE_8__["Component"]));
  29626. /***/ }),
  29627. /* 128 */
  29628. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  29629. "use strict";
  29630. __webpack_require__.r(__webpack_exports__);
  29631. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowContainerComponent", function() { return RowContainerComponent; });
  29632. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  29633. /* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(50);
  29634. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
  29635. /**
  29636. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  29637. * @version v23.2.1
  29638. * @link http://www.ag-grid.com/
  29639. * @license MIT
  29640. */
  29641. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  29642. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  29643. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  29644. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  29645. return c > 3 && r && Object.defineProperty(target, key, r), r;
  29646. };
  29647. /**
  29648. * There are many instances of this component covering each of the areas a row can be entered
  29649. * eg body, pinned left, fullWidth. The component differs from others in that it's given the
  29650. * elements, there is no template. All of the elements are part of the GridPanel.
  29651. */
  29652. var RowContainerComponent = /** @class */ (function () {
  29653. function RowContainerComponent(params) {
  29654. this.childCount = 0;
  29655. this.rowTemplatesToAdd = [];
  29656. this.afterGuiAttachedCallbacks = [];
  29657. // this is to cater for a 'strange behaviour' where when a panel is made visible, it is firing a scroll
  29658. // event which we want to ignore. see gridPanel.onAnyBodyScroll()
  29659. this.lastMadeVisibleTime = 0;
  29660. this.eContainer = params.eContainer;
  29661. this.eViewport = params.eViewport;
  29662. if (params.eWrapper) {
  29663. this.eWrapper = params.eWrapper;
  29664. }
  29665. this.hideWhenNoChildren = params.hideWhenNoChildren;
  29666. }
  29667. RowContainerComponent.prototype.setVerticalScrollPosition = function (verticalScrollPosition) {
  29668. this.scrollTop = verticalScrollPosition;
  29669. };
  29670. RowContainerComponent.prototype.postConstruct = function () {
  29671. this.checkDomOrder();
  29672. this.checkVisibility();
  29673. this.gridOptionsWrapper.addEventListener(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_1__["GridOptionsWrapper"].PROP_DOM_LAYOUT, this.checkDomOrder.bind(this));
  29674. };
  29675. RowContainerComponent.prototype.checkDomOrder = function () {
  29676. this.domOrder = this.gridOptionsWrapper.isEnsureDomOrder();
  29677. };
  29678. RowContainerComponent.prototype.getRowElement = function (compId) {
  29679. return this.eContainer.querySelector("[comp-id=\"" + compId + "\"]");
  29680. };
  29681. RowContainerComponent.prototype.setHeight = function (height) {
  29682. if (height == null) {
  29683. this.eContainer.style.height = '';
  29684. return;
  29685. }
  29686. this.eContainer.style.height = height + "px";
  29687. if (this.eWrapper) {
  29688. this.eWrapper.style.height = height + "px";
  29689. }
  29690. };
  29691. RowContainerComponent.prototype.flushRowTemplates = function () {
  29692. // if doing dom order, then rowTemplates will be empty,
  29693. // or if no rows added since last time also empty.
  29694. if (this.rowTemplatesToAdd.length !== 0) {
  29695. var htmlToAdd = this.rowTemplatesToAdd.join('');
  29696. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].appendHtml(this.eContainer, htmlToAdd);
  29697. this.rowTemplatesToAdd.length = 0;
  29698. }
  29699. // this only empty if no rows since last time, as when
  29700. // doing dom order, we still have callbacks to process
  29701. this.afterGuiAttachedCallbacks.forEach(function (func) { return func(); });
  29702. this.afterGuiAttachedCallbacks.length = 0;
  29703. this.lastPlacedElement = null;
  29704. };
  29705. RowContainerComponent.prototype.appendRowTemplate = function (rowTemplate, callback) {
  29706. if (this.domOrder) {
  29707. this.lastPlacedElement = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].insertTemplateWithDomOrder(this.eContainer, rowTemplate, this.lastPlacedElement);
  29708. }
  29709. else {
  29710. this.rowTemplatesToAdd.push(rowTemplate);
  29711. }
  29712. this.afterGuiAttachedCallbacks.push(callback);
  29713. // it is important we put items in in order, so that when we open a row group,
  29714. // the new rows are inserted after the opened group, but before the rows below.
  29715. // that way, the rows below are over the new rows (as dom renders last in dom over
  29716. // items previous in dom), otherwise the child rows would cover the row below and
  29717. // that meant the user doesn't see the rows below slide away.
  29718. this.childCount++;
  29719. this.checkVisibility();
  29720. };
  29721. RowContainerComponent.prototype.ensureDomOrder = function (eRow) {
  29722. if (this.domOrder) {
  29723. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].ensureDomOrder(this.eContainer, eRow, this.lastPlacedElement);
  29724. this.lastPlacedElement = eRow;
  29725. }
  29726. };
  29727. RowContainerComponent.prototype.removeRowElement = function (eRow) {
  29728. this.eContainer.removeChild(eRow);
  29729. this.childCount--;
  29730. this.checkVisibility();
  29731. };
  29732. RowContainerComponent.prototype.checkVisibility = function () {
  29733. if (!this.hideWhenNoChildren) {
  29734. return;
  29735. }
  29736. var eGui = this.eViewport ? this.eViewport : this.eContainer;
  29737. var visible = this.childCount > 0;
  29738. if (this.visible !== visible) {
  29739. this.visible = visible;
  29740. this.lastMadeVisibleTime = new Date().getTime();
  29741. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].setDisplayed(eGui, visible);
  29742. // if we are showing the viewport, then the scroll is always zero,
  29743. // so we need to align with the other sections (ie if this is full
  29744. // width container, and first time showing a full width row, we need to
  29745. // scroll it so full width rows are show in right place alongside the
  29746. // body rows). without this, there was an issue with 'loading rows' for
  29747. // server side row model, as loading rows are full width, and they were
  29748. // not getting displayed in the right location when rows were expanded.
  29749. if (visible && this.eViewport) {
  29750. this.eViewport.scrollTop = this.scrollTop;
  29751. }
  29752. }
  29753. };
  29754. RowContainerComponent.prototype.isMadeVisibleRecently = function () {
  29755. var now = new Date().getTime();
  29756. var millisSinceVisible = now - this.lastMadeVisibleTime;
  29757. return millisSinceVisible < 500;
  29758. };
  29759. __decorate([
  29760. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  29761. ], RowContainerComponent.prototype, "gridOptionsWrapper", void 0);
  29762. __decorate([
  29763. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  29764. ], RowContainerComponent.prototype, "postConstruct", null);
  29765. return RowContainerComponent;
  29766. }());
  29767. /***/ }),
  29768. /* 129 */
  29769. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  29770. "use strict";
  29771. __webpack_require__.r(__webpack_exports__);
  29772. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowDragFeature", function() { return RowDragFeature; });
  29773. /* harmony import */ var _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(104);
  29774. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  29775. /* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(44);
  29776. /* harmony import */ var _utils_array__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(17);
  29777. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(41);
  29778. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7);
  29779. /**
  29780. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  29781. * @version v23.2.1
  29782. * @link http://www.ag-grid.com/
  29783. * @license MIT
  29784. */
  29785. var __extends = (undefined && undefined.__extends) || (function () {
  29786. var extendStatics = function (d, b) {
  29787. extendStatics = Object.setPrototypeOf ||
  29788. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  29789. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  29790. return extendStatics(d, b);
  29791. };
  29792. return function (d, b) {
  29793. extendStatics(d, b);
  29794. function __() { this.constructor = d; }
  29795. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  29796. };
  29797. })();
  29798. var __assign = (undefined && undefined.__assign) || function () {
  29799. __assign = Object.assign || function(t) {
  29800. for (var s, i = 1, n = arguments.length; i < n; i++) {
  29801. s = arguments[i];
  29802. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
  29803. t[p] = s[p];
  29804. }
  29805. return t;
  29806. };
  29807. return __assign.apply(this, arguments);
  29808. };
  29809. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  29810. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  29811. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  29812. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  29813. return c > 3 && r && Object.defineProperty(target, key, r), r;
  29814. };
  29815. var __spreadArrays = (undefined && undefined.__spreadArrays) || function () {
  29816. for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;
  29817. for (var r = Array(s), k = 0, i = 0; i < il; i++)
  29818. for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
  29819. r[k] = a[j];
  29820. return r;
  29821. };
  29822. var RowDragFeature = /** @class */ (function (_super) {
  29823. __extends(RowDragFeature, _super);
  29824. function RowDragFeature(eContainer, gridPanel) {
  29825. var _this = _super.call(this) || this;
  29826. _this.isMultiRowDrag = false;
  29827. _this.isGridSorted = false;
  29828. _this.isGridFiltered = false;
  29829. _this.isRowGroupActive = false;
  29830. _this.eContainer = eContainer;
  29831. _this.gridPanel = gridPanel;
  29832. return _this;
  29833. }
  29834. RowDragFeature.prototype.postConstruct = function () {
  29835. if (this.gridOptionsWrapper.isRowModelDefault()) {
  29836. this.clientSideRowModel = this.rowModel;
  29837. }
  29838. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_SORT_CHANGED, this.onSortChanged.bind(this));
  29839. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_FILTER_CHANGED, this.onFilterChanged.bind(this));
  29840. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, this.onRowGroupChanged.bind(this));
  29841. this.onSortChanged();
  29842. this.onFilterChanged();
  29843. this.onRowGroupChanged();
  29844. };
  29845. RowDragFeature.prototype.onSortChanged = function () {
  29846. var sortModel = this.sortController.getSortModel();
  29847. this.isGridSorted = !_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missingOrEmpty(sortModel);
  29848. };
  29849. RowDragFeature.prototype.onFilterChanged = function () {
  29850. this.isGridFiltered = this.filterManager.isAnyFilterPresent();
  29851. };
  29852. RowDragFeature.prototype.onRowGroupChanged = function () {
  29853. var rowGroups = this.columnController.getRowGroupColumns();
  29854. this.isRowGroupActive = !_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missingOrEmpty(rowGroups);
  29855. };
  29856. RowDragFeature.prototype.getContainer = function () {
  29857. return this.eContainer;
  29858. };
  29859. RowDragFeature.prototype.isInterestedIn = function (type) {
  29860. return type === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragSourceType"].RowDrag;
  29861. };
  29862. RowDragFeature.prototype.getIconName = function () {
  29863. var managedDrag = this.gridOptionsWrapper.isRowDragManaged();
  29864. if (managedDrag && this.shouldPreventRowMove()) {
  29865. return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragAndDropService"].ICON_NOT_ALLOWED;
  29866. }
  29867. return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragAndDropService"].ICON_MOVE;
  29868. };
  29869. RowDragFeature.prototype.shouldPreventRowMove = function () {
  29870. return this.isGridSorted || this.isGridFiltered || this.isRowGroupActive;
  29871. };
  29872. RowDragFeature.prototype.getRowNodes = function (draggingEvent) {
  29873. if (!this.isFromThisGrid(draggingEvent)) {
  29874. return draggingEvent.dragItem.rowNodes;
  29875. }
  29876. var enableMultiRowDragging = this.gridOptionsWrapper.isEnableMultiRowDragging();
  29877. var selectedNodes = this.selectionController.getSelectedNodes();
  29878. var currentNode = draggingEvent.dragItem.rowNode;
  29879. if (enableMultiRowDragging && selectedNodes.indexOf(currentNode) !== -1) {
  29880. this.isMultiRowDrag = true;
  29881. return __spreadArrays(selectedNodes);
  29882. }
  29883. this.isMultiRowDrag = false;
  29884. return [currentNode];
  29885. };
  29886. RowDragFeature.prototype.onDragEnter = function (draggingEvent) {
  29887. // when entering, we fire the enter event, then in onEnterOrDragging,
  29888. // we also fire the move event. so we get both events when entering.
  29889. this.dispatchGridEvent(_eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DRAG_ENTER, draggingEvent);
  29890. this.getRowNodes(draggingEvent).forEach(function (rowNode) {
  29891. rowNode.setDragging(true);
  29892. });
  29893. this.onEnterOrDragging(draggingEvent);
  29894. };
  29895. RowDragFeature.prototype.onDragging = function (draggingEvent) {
  29896. this.onEnterOrDragging(draggingEvent);
  29897. };
  29898. RowDragFeature.prototype.isFromThisGrid = function (draggingEvent) {
  29899. return this.gridPanel.getGui().contains(draggingEvent.dragSource.eElement);
  29900. };
  29901. RowDragFeature.prototype.isDropZoneWithinThisGrid = function (draggingEvent) {
  29902. var gridGui = this.gridPanel.getGui();
  29903. var dropZoneTarget = draggingEvent.dropZoneTarget;
  29904. return !gridGui.contains(dropZoneTarget);
  29905. };
  29906. RowDragFeature.prototype.onEnterOrDragging = function (draggingEvent) {
  29907. // this event is fired for enter and move
  29908. this.dispatchGridEvent(_eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DRAG_MOVE, draggingEvent);
  29909. this.lastDraggingEvent = draggingEvent;
  29910. var pixel = this.mouseEventService.getNormalisedPosition(draggingEvent).y;
  29911. var managedDrag = this.gridOptionsWrapper.isRowDragManaged();
  29912. if (managedDrag) {
  29913. this.doManagedDrag(draggingEvent, pixel);
  29914. }
  29915. this.checkCenterForScrolling(pixel);
  29916. };
  29917. RowDragFeature.prototype.doManagedDrag = function (draggingEvent, pixel) {
  29918. var _this = this;
  29919. var rowNodes;
  29920. var isFromThisGrid = this.isFromThisGrid(draggingEvent);
  29921. if (isFromThisGrid) {
  29922. rowNodes = [draggingEvent.dragItem.rowNode];
  29923. if (this.isMultiRowDrag) {
  29924. rowNodes = __spreadArrays(this.selectionController.getSelectedNodes()).sort(function (a, b) { return _this.getRowIndexNumber(a) - _this.getRowIndexNumber(b); });
  29925. }
  29926. draggingEvent.dragItem.rowNodes = rowNodes;
  29927. }
  29928. else {
  29929. rowNodes = draggingEvent.dragItem.rowNodes;
  29930. }
  29931. var managedDrag = this.gridOptionsWrapper.isRowDragManaged();
  29932. if (managedDrag && this.shouldPreventRowMove()) {
  29933. return;
  29934. }
  29935. if (this.gridOptionsWrapper.isSuppressMoveWhenRowDragging() || !isFromThisGrid) {
  29936. if (!this.isDropZoneWithinThisGrid(draggingEvent)) {
  29937. this.clientSideRowModel.highlightRowAtPixel(rowNodes[0], pixel);
  29938. }
  29939. }
  29940. else {
  29941. this.moveRows(rowNodes, pixel);
  29942. }
  29943. };
  29944. RowDragFeature.prototype.getRowIndexNumber = function (rowNode) {
  29945. return parseInt(Object(_utils_array__WEBPACK_IMPORTED_MODULE_3__["last"])(rowNode.getRowIndexString().split('-')), 10);
  29946. };
  29947. RowDragFeature.prototype.moveRowAndClearHighlight = function (draggingEvent) {
  29948. var _this = this;
  29949. var lastHighlightedRowNode = this.clientSideRowModel.getLastHighlightedRowNode();
  29950. var isBelow = lastHighlightedRowNode && lastHighlightedRowNode.highlighted === 'below';
  29951. var pixel = this.mouseEventService.getNormalisedPosition(draggingEvent).y;
  29952. var rowNodes = draggingEvent.dragItem.rowNodes;
  29953. var increment = isBelow ? 1 : 0;
  29954. if (this.isFromThisGrid(draggingEvent)) {
  29955. rowNodes.forEach(function (rowNode) {
  29956. if (rowNode.rowTop < pixel) {
  29957. increment -= 1;
  29958. }
  29959. });
  29960. this.moveRows(rowNodes, pixel, increment);
  29961. }
  29962. else {
  29963. var getRowNodeId_1 = this.gridOptionsWrapper.getRowNodeIdFunc();
  29964. var addIndex = this.clientSideRowModel.getRowIndexAtPixel(pixel) + 1;
  29965. if (this.clientSideRowModel.getHighlightPosition(pixel) === 'above') {
  29966. addIndex--;
  29967. }
  29968. this.clientSideRowModel.updateRowData({
  29969. add: rowNodes
  29970. .map(function (node) { return node.data; })
  29971. .filter(function (data) { return !_this.clientSideRowModel.getRowNode(getRowNodeId_1 ? getRowNodeId_1(data) : data.id); }),
  29972. addIndex: addIndex
  29973. });
  29974. }
  29975. this.clearRowHighlight();
  29976. };
  29977. RowDragFeature.prototype.clearRowHighlight = function () {
  29978. this.clientSideRowModel.highlightRowAtPixel(null);
  29979. };
  29980. RowDragFeature.prototype.moveRows = function (rowNodes, pixel, increment) {
  29981. if (increment === void 0) { increment = 0; }
  29982. var rowWasMoved = this.clientSideRowModel.ensureRowsAtPixel(rowNodes, pixel, increment);
  29983. if (rowWasMoved) {
  29984. this.focusController.clearFocusedCell();
  29985. if (this.rangeController) {
  29986. this.rangeController.removeAllCellRanges();
  29987. }
  29988. }
  29989. };
  29990. RowDragFeature.prototype.checkCenterForScrolling = function (pixel) {
  29991. // scroll if the mouse is within 50px of the grid edge
  29992. var pixelRange = this.gridPanel.getVScrollPosition();
  29993. // console.log(`pixelRange = (${pixelRange.top}, ${pixelRange.bottom})`);
  29994. this.needToMoveUp = pixel < (pixelRange.top + 50);
  29995. this.needToMoveDown = pixel > (pixelRange.bottom - 50);
  29996. // console.log(`needToMoveUp = ${this.needToMoveUp} = pixel < (pixelRange.top + 50) = ${pixel} < (${pixelRange.top} + 50)`);
  29997. // console.log(`needToMoveDown = ${this.needToMoveDown} = pixel < (pixelRange.top + 50) = ${pixel} < (${pixelRange.top} + 50)`);
  29998. if (this.needToMoveUp || this.needToMoveDown) {
  29999. this.ensureIntervalStarted();
  30000. }
  30001. else {
  30002. this.ensureIntervalCleared();
  30003. }
  30004. };
  30005. RowDragFeature.prototype.ensureIntervalStarted = function () {
  30006. if (this.movingIntervalId) {
  30007. return;
  30008. }
  30009. this.intervalCount = 0;
  30010. this.movingIntervalId = window.setInterval(this.moveInterval.bind(this), 100);
  30011. };
  30012. RowDragFeature.prototype.ensureIntervalCleared = function () {
  30013. if (!this.moveInterval) {
  30014. return;
  30015. }
  30016. window.clearInterval(this.movingIntervalId);
  30017. this.movingIntervalId = null;
  30018. };
  30019. RowDragFeature.prototype.moveInterval = function () {
  30020. // the amounts we move get bigger at each interval, so the speed accelerates, starting a bit slow
  30021. // and getting faster. this is to give smoother user experience. we max at 100px to limit the speed.
  30022. var pixelsToMove;
  30023. this.intervalCount++;
  30024. pixelsToMove = 10 + (this.intervalCount * 5);
  30025. if (pixelsToMove > 100) {
  30026. pixelsToMove = 100;
  30027. }
  30028. var pixelsMoved;
  30029. if (this.needToMoveDown) {
  30030. pixelsMoved = this.gridPanel.scrollVertically(pixelsToMove);
  30031. }
  30032. else if (this.needToMoveUp) {
  30033. pixelsMoved = this.gridPanel.scrollVertically(-pixelsToMove);
  30034. }
  30035. if (pixelsMoved !== 0) {
  30036. this.onDragging(this.lastDraggingEvent);
  30037. }
  30038. };
  30039. RowDragFeature.prototype.addRowDropZone = function (params) {
  30040. var _this = this;
  30041. if (!params.getContainer()) {
  30042. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].doOnce(function () { return console.warn('ag-Grid: addRowDropZone - A container target needs to be provided'); }, 'add-drop-zone-empty-target');
  30043. return;
  30044. }
  30045. if (this.dragAndDropService.findExternalZone(params)) {
  30046. console.warn('ag-Grid: addRowDropZone - target already exists in the list of DropZones. Use `removeRowDropZone` before adding it again.');
  30047. return;
  30048. }
  30049. var processedParams = {
  30050. getContainer: params.getContainer
  30051. };
  30052. if (params.fromGrid) {
  30053. params.fromGrid = undefined;
  30054. processedParams = params;
  30055. }
  30056. else {
  30057. if (params.onDragEnter) {
  30058. processedParams.onDragEnter = function (e) {
  30059. params.onDragEnter(_this.draggingToRowDragEvent(_eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DRAG_ENTER, e));
  30060. };
  30061. }
  30062. if (params.onDragLeave) {
  30063. processedParams.onDragLeave = function (e) {
  30064. params.onDragLeave(_this.draggingToRowDragEvent(_eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DRAG_LEAVE, e));
  30065. };
  30066. }
  30067. if (params.onDragging) {
  30068. processedParams.onDragging = function (e) {
  30069. params.onDragging(_this.draggingToRowDragEvent(_eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DRAG_MOVE, e));
  30070. };
  30071. }
  30072. if (params.onDragStop) {
  30073. processedParams.onDragStop = function (e) {
  30074. params.onDragStop(_this.draggingToRowDragEvent(_eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DRAG_END, e));
  30075. };
  30076. }
  30077. }
  30078. this.dragAndDropService.addDropTarget(__assign({ isInterestedIn: function (type) { return type === _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragSourceType"].RowDrag; }, getIconName: function () { return _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["DragAndDropService"].ICON_MOVE; }, external: true }, processedParams));
  30079. };
  30080. RowDragFeature.prototype.getRowDropZone = function (events) {
  30081. var _this = this;
  30082. var getContainer = this.getContainer.bind(this);
  30083. var onDragEnter = this.onDragEnter.bind(this);
  30084. var onDragLeave = this.onDragLeave.bind(this);
  30085. var onDragging = this.onDragging.bind(this);
  30086. var onDragStop = this.onDragStop.bind(this);
  30087. if (!events) {
  30088. return { getContainer: getContainer, onDragEnter: onDragEnter, onDragLeave: onDragLeave, onDragging: onDragging, onDragStop: onDragStop, fromGrid: true };
  30089. }
  30090. return {
  30091. getContainer: getContainer,
  30092. onDragEnter: events.onDragEnter
  30093. ? (function (e) {
  30094. onDragEnter(e);
  30095. events.onDragEnter(_this.draggingToRowDragEvent(_eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DRAG_ENTER, e));
  30096. })
  30097. : onDragEnter,
  30098. onDragLeave: events.onDragLeave
  30099. ? (function (e) {
  30100. onDragLeave(e);
  30101. events.onDragLeave(_this.draggingToRowDragEvent(_eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DRAG_LEAVE, e));
  30102. })
  30103. : onDragLeave,
  30104. onDragging: events.onDragging
  30105. ? (function (e) {
  30106. onDragging(e);
  30107. events.onDragging(_this.draggingToRowDragEvent(_eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DRAG_MOVE, e));
  30108. })
  30109. : onDragging,
  30110. onDragStop: events.onDragStop
  30111. ? (function (e) {
  30112. onDragStop(e);
  30113. events.onDragStop(_this.draggingToRowDragEvent(_eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DRAG_END, e));
  30114. })
  30115. : onDragStop,
  30116. fromGrid: true
  30117. };
  30118. };
  30119. RowDragFeature.prototype.draggingToRowDragEvent = function (type, draggingEvent) {
  30120. var yNormalised = this.mouseEventService.getNormalisedPosition(draggingEvent).y;
  30121. var mouseIsPastLastRow = yNormalised > this.rowModel.getCurrentPageHeight();
  30122. var overIndex = -1;
  30123. var overNode = null;
  30124. if (!mouseIsPastLastRow) {
  30125. overIndex = this.rowModel.getRowIndexAtPixel(yNormalised);
  30126. overNode = this.rowModel.getRow(overIndex);
  30127. }
  30128. var vDirectionString;
  30129. switch (draggingEvent.vDirection) {
  30130. case _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["VerticalDirection"].Down:
  30131. vDirectionString = 'down';
  30132. break;
  30133. case _dragAndDrop_dragAndDropService__WEBPACK_IMPORTED_MODULE_0__["VerticalDirection"].Up:
  30134. vDirectionString = 'up';
  30135. break;
  30136. default:
  30137. vDirectionString = null;
  30138. break;
  30139. }
  30140. var event = {
  30141. type: type,
  30142. api: this.gridOptionsWrapper.getApi(),
  30143. columnApi: this.gridOptionsWrapper.getColumnApi(),
  30144. event: draggingEvent.event,
  30145. node: draggingEvent.dragItem.rowNode,
  30146. nodes: draggingEvent.dragItem.rowNodes,
  30147. overIndex: overIndex,
  30148. overNode: overNode,
  30149. y: yNormalised,
  30150. vDirection: vDirectionString
  30151. };
  30152. return event;
  30153. };
  30154. RowDragFeature.prototype.dispatchGridEvent = function (type, draggingEvent) {
  30155. var event = this.draggingToRowDragEvent(type, draggingEvent);
  30156. this.eventService.dispatchEvent(event);
  30157. };
  30158. RowDragFeature.prototype.onDragLeave = function (draggingEvent) {
  30159. this.dispatchGridEvent(_eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DRAG_LEAVE, draggingEvent);
  30160. this.stopDragging(draggingEvent);
  30161. this.clearRowHighlight();
  30162. if (this.isFromThisGrid(draggingEvent)) {
  30163. this.isMultiRowDrag = false;
  30164. }
  30165. };
  30166. RowDragFeature.prototype.onDragStop = function (draggingEvent) {
  30167. this.dispatchGridEvent(_eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_ROW_DRAG_END, draggingEvent);
  30168. this.stopDragging(draggingEvent);
  30169. if (this.gridOptionsWrapper.isRowDragManaged() &&
  30170. (this.gridOptionsWrapper.isSuppressMoveWhenRowDragging() || !this.isFromThisGrid(draggingEvent)) &&
  30171. !this.isDropZoneWithinThisGrid(draggingEvent)) {
  30172. this.moveRowAndClearHighlight(draggingEvent);
  30173. }
  30174. };
  30175. RowDragFeature.prototype.stopDragging = function (draggingEvent) {
  30176. this.ensureIntervalCleared();
  30177. this.getRowNodes(draggingEvent).forEach(function (rowNode) {
  30178. rowNode.setDragging(false);
  30179. });
  30180. };
  30181. __decorate([
  30182. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('dragAndDropService')
  30183. ], RowDragFeature.prototype, "dragAndDropService", void 0);
  30184. __decorate([
  30185. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowModel')
  30186. ], RowDragFeature.prototype, "rowModel", void 0);
  30187. __decorate([
  30188. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController')
  30189. ], RowDragFeature.prototype, "columnController", void 0);
  30190. __decorate([
  30191. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('focusController')
  30192. ], RowDragFeature.prototype, "focusController", void 0);
  30193. __decorate([
  30194. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('sortController')
  30195. ], RowDragFeature.prototype, "sortController", void 0);
  30196. __decorate([
  30197. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('filterManager')
  30198. ], RowDragFeature.prototype, "filterManager", void 0);
  30199. __decorate([
  30200. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  30201. ], RowDragFeature.prototype, "gridOptionsWrapper", void 0);
  30202. __decorate([
  30203. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('selectionController')
  30204. ], RowDragFeature.prototype, "selectionController", void 0);
  30205. __decorate([
  30206. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Optional"])('rangeController')
  30207. ], RowDragFeature.prototype, "rangeController", void 0);
  30208. __decorate([
  30209. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('mouseEventService')
  30210. ], RowDragFeature.prototype, "mouseEventService", void 0);
  30211. __decorate([
  30212. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  30213. ], RowDragFeature.prototype, "postConstruct", null);
  30214. return RowDragFeature;
  30215. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_4__["BeanStub"]));
  30216. /***/ }),
  30217. /* 130 */
  30218. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  30219. "use strict";
  30220. __webpack_require__.r(__webpack_exports__);
  30221. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridApi", function() { return GridApi; });
  30222. /* harmony import */ var _gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(50);
  30223. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(25);
  30224. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37);
  30225. /* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(38);
  30226. /* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(39);
  30227. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7);
  30228. /**
  30229. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  30230. * @version v23.2.1
  30231. * @link http://www.ag-grid.com/
  30232. * @license MIT
  30233. */
  30234. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  30235. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  30236. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  30237. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  30238. return c > 3 && r && Object.defineProperty(target, key, r), r;
  30239. };
  30240. var GridApi = /** @class */ (function () {
  30241. function GridApi() {
  30242. this.detailGridInfoMap = {};
  30243. this.destroyCalled = false;
  30244. }
  30245. GridApi.prototype.registerGridComp = function (gridPanel) {
  30246. this.gridPanel = gridPanel;
  30247. };
  30248. GridApi.prototype.registerGridCore = function (gridCore) {
  30249. this.gridCore = gridCore;
  30250. };
  30251. GridApi.prototype.registerHeaderRootComp = function (headerRootComp) {
  30252. this.headerRootComp = headerRootComp;
  30253. };
  30254. GridApi.prototype.init = function () {
  30255. switch (this.rowModel.getType()) {
  30256. case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE:
  30257. this.clientSideRowModel = this.rowModel;
  30258. break;
  30259. case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_INFINITE:
  30260. this.infiniteRowModel = this.rowModel;
  30261. break;
  30262. case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE:
  30263. this.serverSideRowModel = this.rowModel;
  30264. break;
  30265. }
  30266. };
  30267. /** Used internally by grid. Not intended to be used by the client. Interface may change between releases. */
  30268. GridApi.prototype.__getAlignedGridService = function () {
  30269. return this.alignedGridsService;
  30270. };
  30271. GridApi.prototype.addDetailGridInfo = function (id, gridInfo) {
  30272. this.detailGridInfoMap[id] = gridInfo;
  30273. };
  30274. GridApi.prototype.removeDetailGridInfo = function (id) {
  30275. this.detailGridInfoMap[id] = undefined;
  30276. };
  30277. GridApi.prototype.getDetailGridInfo = function (id) {
  30278. return this.detailGridInfoMap[id];
  30279. };
  30280. GridApi.prototype.forEachDetailGridInfo = function (callback) {
  30281. var index = 0;
  30282. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].iterateObject(this.detailGridInfoMap, function (id, gridInfo) {
  30283. // check for undefined, as old references will still be lying around
  30284. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(gridInfo)) {
  30285. callback(gridInfo, index);
  30286. index++;
  30287. }
  30288. });
  30289. };
  30290. GridApi.prototype.getDataAsCsv = function (params) {
  30291. if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].CsvExportModule, 'api.getDataAsCsv')) {
  30292. return this.csvCreator.getDataAsCsv(params);
  30293. }
  30294. };
  30295. GridApi.prototype.exportDataAsCsv = function (params) {
  30296. if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].CsvExportModule, 'api.exportDataAsCSv')) {
  30297. this.csvCreator.exportDataAsCsv(params);
  30298. }
  30299. };
  30300. GridApi.prototype.getDataAsExcel = function (params) {
  30301. if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].ExcelExportModule, 'api.getDataAsExcel')) {
  30302. return this.excelCreator.getDataAsExcelXml(params);
  30303. }
  30304. };
  30305. GridApi.prototype.exportDataAsExcel = function (params) {
  30306. if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].ExcelExportModule, 'api.exportDataAsExcel')) {
  30307. this.excelCreator.exportDataAsExcel(params);
  30308. }
  30309. };
  30310. /** @deprecated */
  30311. GridApi.prototype.setEnterpriseDatasource = function (datasource) {
  30312. console.warn("ag-grid: since version 18.x, api.setEnterpriseDatasource() should be replaced with api.setServerSideDatasource()");
  30313. this.setServerSideDatasource(datasource);
  30314. };
  30315. GridApi.prototype.setServerSideDatasource = function (datasource) {
  30316. if (this.gridOptionsWrapper.isRowModelServerSide()) {
  30317. // should really have an IEnterpriseRowModel interface, so we are not casting to any
  30318. this.rowModel.setDatasource(datasource);
  30319. }
  30320. else {
  30321. console.warn("ag-Grid: you can only use an enterprise datasource when gridOptions.rowModelType is '" + _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE + "'");
  30322. }
  30323. };
  30324. GridApi.prototype.setDatasource = function (datasource) {
  30325. if (this.gridOptionsWrapper.isRowModelInfinite()) {
  30326. this.rowModel.setDatasource(datasource);
  30327. }
  30328. else {
  30329. console.warn("ag-Grid: you can only use a datasource when gridOptions.rowModelType is '" + _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_INFINITE + "'");
  30330. }
  30331. };
  30332. GridApi.prototype.setViewportDatasource = function (viewportDatasource) {
  30333. if (this.gridOptionsWrapper.isRowModelViewport()) {
  30334. // this is bad coding, because it's using an interface that's exposed in the enterprise.
  30335. // really we should create an interface in the core for viewportDatasource and let
  30336. // the enterprise implement it, rather than casting to 'any' here
  30337. this.rowModel.setViewportDatasource(viewportDatasource);
  30338. }
  30339. else {
  30340. console.warn("ag-Grid: you can only use a viewport datasource when gridOptions.rowModelType is '" + _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].ROW_MODEL_TYPE_VIEWPORT + "'");
  30341. }
  30342. };
  30343. GridApi.prototype.setRowData = function (rowData) {
  30344. if (this.gridOptionsWrapper.isRowModelDefault()) {
  30345. if (this.gridOptionsWrapper.isImmutableData()) {
  30346. var res = this.immutableService.createTransactionForRowData(rowData);
  30347. if (!res) {
  30348. return;
  30349. }
  30350. var transaction = res[0], orderIdMap = res[1];
  30351. this.clientSideRowModel.updateRowData(transaction, orderIdMap);
  30352. // need to force updating of full width rows - note this wouldn't be necessary the full width cell comp listened
  30353. // to the data change event on the row node and refreshed itself.
  30354. this.rowRenderer.refreshFullWidthRows();
  30355. }
  30356. else {
  30357. this.selectionController.reset();
  30358. this.clientSideRowModel.setRowData(rowData);
  30359. }
  30360. }
  30361. else {
  30362. console.warn('cannot call setRowData unless using normal row model');
  30363. }
  30364. };
  30365. /** @deprecated */
  30366. GridApi.prototype.setFloatingTopRowData = function (rows) {
  30367. console.warn('ag-Grid: since v12, api.setFloatingTopRowData() is now api.setPinnedTopRowData()');
  30368. this.setPinnedTopRowData(rows);
  30369. };
  30370. /** @deprecated */
  30371. GridApi.prototype.setFloatingBottomRowData = function (rows) {
  30372. console.warn('ag-Grid: since v12, api.setFloatingBottomRowData() is now api.setPinnedBottomRowData()');
  30373. this.setPinnedBottomRowData(rows);
  30374. };
  30375. /** @deprecated */
  30376. GridApi.prototype.getFloatingTopRowCount = function () {
  30377. console.warn('ag-Grid: since v12, api.getFloatingTopRowCount() is now api.getPinnedTopRowCount()');
  30378. return this.getPinnedTopRowCount();
  30379. };
  30380. /** @deprecated */
  30381. GridApi.prototype.getFloatingBottomRowCount = function () {
  30382. console.warn('ag-Grid: since v12, api.getFloatingBottomRowCount() is now api.getPinnedBottomRowCount()');
  30383. return this.getPinnedBottomRowCount();
  30384. };
  30385. /** @deprecated */
  30386. GridApi.prototype.getFloatingTopRow = function (index) {
  30387. console.warn('ag-Grid: since v12, api.getFloatingTopRow() is now api.getPinnedTopRow()');
  30388. return this.getPinnedTopRow(index);
  30389. };
  30390. /** @deprecated */
  30391. GridApi.prototype.getFloatingBottomRow = function (index) {
  30392. console.warn('ag-Grid: since v12, api.getFloatingBottomRow() is now api.getPinnedBottomRow()');
  30393. return this.getPinnedBottomRow(index);
  30394. };
  30395. GridApi.prototype.setPinnedTopRowData = function (rows) {
  30396. this.pinnedRowModel.setPinnedTopRowData(rows);
  30397. };
  30398. GridApi.prototype.setPinnedBottomRowData = function (rows) {
  30399. this.pinnedRowModel.setPinnedBottomRowData(rows);
  30400. };
  30401. GridApi.prototype.getPinnedTopRowCount = function () {
  30402. return this.pinnedRowModel.getPinnedTopRowCount();
  30403. };
  30404. GridApi.prototype.getPinnedBottomRowCount = function () {
  30405. return this.pinnedRowModel.getPinnedBottomRowCount();
  30406. };
  30407. GridApi.prototype.getPinnedTopRow = function (index) {
  30408. return this.pinnedRowModel.getPinnedTopRow(index);
  30409. };
  30410. GridApi.prototype.getPinnedBottomRow = function (index) {
  30411. return this.pinnedRowModel.getPinnedBottomRow(index);
  30412. };
  30413. GridApi.prototype.setColumnDefs = function (colDefs, source) {
  30414. if (source === void 0) { source = "api"; }
  30415. this.columnController.setColumnDefs(colDefs, source);
  30416. };
  30417. GridApi.prototype.setAutoGroupColumnDef = function (colDef, source) {
  30418. if (source === void 0) { source = "api"; }
  30419. this.gridOptionsWrapper.setProperty('autoGroupColumnDef', colDef, true);
  30420. };
  30421. GridApi.prototype.expireValueCache = function () {
  30422. this.valueCache.expire();
  30423. };
  30424. GridApi.prototype.getVerticalPixelRange = function () {
  30425. return this.gridPanel.getVScrollPosition();
  30426. };
  30427. GridApi.prototype.getHorizontalPixelRange = function () {
  30428. return this.gridPanel.getHScrollPosition();
  30429. };
  30430. GridApi.prototype.setAlwaysShowVerticalScroll = function (show) {
  30431. this.gridOptionsWrapper.setProperty('alwaysShowVerticalScroll', show);
  30432. };
  30433. GridApi.prototype.refreshToolPanel = function () {
  30434. this.gridCore.refreshSideBar();
  30435. };
  30436. GridApi.prototype.refreshCells = function (params) {
  30437. if (params === void 0) { params = {}; }
  30438. if (Array.isArray(params)) {
  30439. // the old version of refreshCells() took an array of rowNodes for the first argument
  30440. console.warn('since ag-Grid v11.1, refreshCells() now takes parameters, please see the documentation.');
  30441. return;
  30442. }
  30443. this.rowRenderer.refreshCells(params);
  30444. };
  30445. GridApi.prototype.flashCells = function (params) {
  30446. if (params === void 0) { params = {}; }
  30447. this.rowRenderer.flashCells(params);
  30448. };
  30449. GridApi.prototype.redrawRows = function (params) {
  30450. if (params === void 0) { params = {}; }
  30451. if (params && params.rowNodes) {
  30452. this.rowRenderer.redrawRows(params.rowNodes);
  30453. }
  30454. else {
  30455. this.rowRenderer.redrawAfterModelUpdate();
  30456. }
  30457. };
  30458. GridApi.prototype.timeFullRedraw = function (count) {
  30459. if (count === void 0) { count = 1; }
  30460. var iterationCount = 0;
  30461. var totalProcessing = 0;
  30462. var totalReflow = 0;
  30463. var that = this;
  30464. doOneIteration();
  30465. function doOneIteration() {
  30466. var start = (new Date()).getTime();
  30467. that.rowRenderer.redrawAfterModelUpdate();
  30468. var endProcessing = (new Date()).getTime();
  30469. window.setTimeout(function () {
  30470. var endReflow = (new Date()).getTime();
  30471. var durationProcessing = endProcessing - start;
  30472. var durationReflow = endReflow - endProcessing;
  30473. // tslint:disable-next-line
  30474. console.log('duration: processing = ' + durationProcessing + 'ms, reflow = ' + durationReflow + 'ms');
  30475. iterationCount++;
  30476. totalProcessing += durationProcessing;
  30477. totalReflow += durationReflow;
  30478. if (iterationCount < count) {
  30479. // wait for 1s between tests
  30480. window.setTimeout(doOneIteration, 1000);
  30481. }
  30482. else {
  30483. finish();
  30484. }
  30485. }, 0);
  30486. }
  30487. function finish() {
  30488. // tslint:disable-next-line
  30489. console.log('tests complete. iteration count = ' + iterationCount);
  30490. // tslint:disable-next-line
  30491. console.log('average processing = ' + (totalProcessing / iterationCount) + 'ms');
  30492. // tslint:disable-next-line
  30493. console.log('average reflow = ' + (totalReflow / iterationCount) + 'ms');
  30494. }
  30495. };
  30496. /** @deprecated */
  30497. GridApi.prototype.refreshView = function () {
  30498. console.warn('ag-Grid: since v11.1, refreshView() is deprecated, please call refreshCells() or redrawRows() instead');
  30499. this.redrawRows();
  30500. };
  30501. /** @deprecated */
  30502. GridApi.prototype.refreshRows = function (rowNodes) {
  30503. console.warn('since ag-Grid v11.1, refreshRows() is deprecated, please use refreshCells({rowNodes: rows}) or redrawRows({rowNodes: rows}) instead');
  30504. this.refreshCells({ rowNodes: rowNodes });
  30505. };
  30506. /** @deprecated */
  30507. GridApi.prototype.rowDataChanged = function (rows) {
  30508. console.warn('ag-Grid: rowDataChanged is deprecated, either call refreshView() to refresh everything, or call rowNode.setRowData(newData) to set value on a particular node');
  30509. this.redrawRows();
  30510. };
  30511. /** @deprecated */
  30512. GridApi.prototype.softRefreshView = function () {
  30513. console.error('ag-Grid: since v16, softRefreshView() is no longer supported. Please check the documentation on how to refresh.');
  30514. };
  30515. /** @deprecated */
  30516. GridApi.prototype.refreshGroupRows = function () {
  30517. console.warn('ag-Grid: since v11.1, refreshGroupRows() is no longer supported, call refreshCells() instead. ' +
  30518. 'Because refreshCells() now does dirty checking, it will only refresh cells that have changed, so it should ' +
  30519. 'not be necessary to only refresh the group rows.');
  30520. this.refreshCells();
  30521. };
  30522. GridApi.prototype.setFunctionsReadOnly = function (readOnly) {
  30523. this.gridOptionsWrapper.setProperty('functionsReadOnly', readOnly);
  30524. };
  30525. GridApi.prototype.refreshHeader = function () {
  30526. this.headerRootComp.refreshHeader();
  30527. this.gridPanel.setHeaderAndFloatingHeights();
  30528. };
  30529. GridApi.prototype.isAnyFilterPresent = function () {
  30530. return this.filterManager.isAnyFilterPresent();
  30531. };
  30532. /** @deprecated */
  30533. GridApi.prototype.isAdvancedFilterPresent = function () {
  30534. console.warn('ag-Grid: isAdvancedFilterPresent() is deprecated, please use isColumnFilterPresent()');
  30535. return this.isColumnFilterPresent();
  30536. };
  30537. GridApi.prototype.isColumnFilterPresent = function () {
  30538. return this.filterManager.isAdvancedFilterPresent();
  30539. };
  30540. GridApi.prototype.isQuickFilterPresent = function () {
  30541. return this.filterManager.isQuickFilterPresent();
  30542. };
  30543. GridApi.prototype.getModel = function () {
  30544. return this.rowModel;
  30545. };
  30546. GridApi.prototype.setRowNodeExpanded = function (rowNode, expanded) {
  30547. if (rowNode) {
  30548. rowNode.setExpanded(expanded);
  30549. }
  30550. };
  30551. GridApi.prototype.onGroupExpandedOrCollapsed = function (deprecated_refreshFromIndex) {
  30552. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.clientSideRowModel)) {
  30553. console.warn('ag-Grid: cannot call onGroupExpandedOrCollapsed unless using normal row model');
  30554. }
  30555. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(deprecated_refreshFromIndex)) {
  30556. console.warn('ag-Grid: api.onGroupExpandedOrCollapsed - refreshFromIndex parameter is no longer used, the grid will refresh all rows');
  30557. }
  30558. // we don't really want the user calling this if only one rowNode was expanded, instead they should be
  30559. // calling rowNode.setExpanded(boolean) - this way we do a 'keepRenderedRows=false' so that the whole
  30560. // grid gets refreshed again - otherwise the row with the rowNodes that were changed won't get updated,
  30561. // and thus the expand icon in the group cell won't get 'opened' or 'closed'.
  30562. this.clientSideRowModel.refreshModel({ step: _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].STEP_MAP });
  30563. };
  30564. GridApi.prototype.refreshInMemoryRowModel = function (step) {
  30565. console.warn("ag-grid: since version 18.x, api.refreshInMemoryRowModel() should be replaced with api.refreshClientSideRowModel()");
  30566. this.refreshClientSideRowModel(step);
  30567. };
  30568. GridApi.prototype.refreshClientSideRowModel = function (step) {
  30569. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.clientSideRowModel)) {
  30570. console.warn('cannot call refreshClientSideRowModel unless using normal row model');
  30571. }
  30572. var paramsStep = _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].STEP_EVERYTHING;
  30573. var stepsMapped = {
  30574. group: _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].STEP_EVERYTHING,
  30575. filter: _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].STEP_FILTER,
  30576. map: _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].STEP_MAP,
  30577. aggregate: _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].STEP_AGGREGATE,
  30578. sort: _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].STEP_SORT,
  30579. pivot: _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].STEP_PIVOT
  30580. };
  30581. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(step)) {
  30582. paramsStep = stepsMapped[step];
  30583. }
  30584. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(paramsStep)) {
  30585. console.error("ag-Grid: invalid step " + step + ", available steps are " + Object.keys(stepsMapped).join(', '));
  30586. return;
  30587. }
  30588. var modelParams = {
  30589. step: paramsStep,
  30590. keepRenderedRows: true,
  30591. animate: true,
  30592. keepEditingRows: true
  30593. };
  30594. this.clientSideRowModel.refreshModel(modelParams);
  30595. };
  30596. GridApi.prototype.isAnimationFrameQueueEmpty = function () {
  30597. return this.animationFrameService.isQueueEmpty();
  30598. };
  30599. GridApi.prototype.getRowNode = function (id) {
  30600. return this.rowModel.getRowNode(id);
  30601. };
  30602. GridApi.prototype.getSizesForCurrentTheme = function () {
  30603. return {
  30604. rowHeight: this.gridOptionsWrapper.getRowHeightAsNumber(),
  30605. headerHeight: this.gridOptionsWrapper.getHeaderHeight()
  30606. };
  30607. };
  30608. GridApi.prototype.expandAll = function () {
  30609. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.clientSideRowModel)) {
  30610. console.warn('ag-Grid: cannot call expandAll unless using normal row model');
  30611. return;
  30612. }
  30613. this.clientSideRowModel.expandOrCollapseAll(true);
  30614. };
  30615. GridApi.prototype.collapseAll = function () {
  30616. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.clientSideRowModel)) {
  30617. console.warn('ag-Grid: cannot call collapseAll unless using normal row model');
  30618. return;
  30619. }
  30620. this.clientSideRowModel.expandOrCollapseAll(false);
  30621. };
  30622. GridApi.prototype.getToolPanelInstance = function (id) {
  30623. return this.gridCore.getToolPanelInstance(id);
  30624. };
  30625. GridApi.prototype.addVirtualRowListener = function (eventName, rowIndex, callback) {
  30626. if (typeof eventName !== 'string') {
  30627. console.warn('ag-Grid: addVirtualRowListener is deprecated, please use addRenderedRowListener.');
  30628. }
  30629. this.addRenderedRowListener(eventName, rowIndex, callback);
  30630. };
  30631. GridApi.prototype.addRenderedRowListener = function (eventName, rowIndex, callback) {
  30632. if (eventName === 'virtualRowSelected') {
  30633. console.warn("ag-Grid: event virtualRowSelected is deprecated, to register for individual row\n selection events, add a listener directly to the row node.");
  30634. }
  30635. this.rowRenderer.addRenderedRowListener(eventName, rowIndex, callback);
  30636. };
  30637. GridApi.prototype.setQuickFilter = function (newFilter) {
  30638. this.filterManager.setQuickFilter(newFilter);
  30639. };
  30640. GridApi.prototype.selectIndex = function (index, tryMulti, suppressEvents) {
  30641. console.warn('ag-Grid: do not use api for selection, call node.setSelected(value) instead');
  30642. if (suppressEvents) {
  30643. console.warn('ag-Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it');
  30644. }
  30645. this.selectionController.selectIndex(index, tryMulti);
  30646. };
  30647. GridApi.prototype.deselectIndex = function (index, suppressEvents) {
  30648. if (suppressEvents === void 0) { suppressEvents = false; }
  30649. console.warn('ag-Grid: do not use api for selection, call node.setSelected(value) instead');
  30650. if (suppressEvents) {
  30651. console.warn('ag-Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it');
  30652. }
  30653. this.selectionController.deselectIndex(index);
  30654. };
  30655. GridApi.prototype.selectNode = function (node, tryMulti, suppressEvents) {
  30656. if (tryMulti === void 0) { tryMulti = false; }
  30657. if (suppressEvents === void 0) { suppressEvents = false; }
  30658. console.warn('ag-Grid: API for selection is deprecated, call node.setSelected(value) instead');
  30659. if (suppressEvents) {
  30660. console.warn('ag-Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it');
  30661. }
  30662. node.setSelectedParams({ newValue: true, clearSelection: !tryMulti });
  30663. };
  30664. GridApi.prototype.deselectNode = function (node, suppressEvents) {
  30665. if (suppressEvents === void 0) { suppressEvents = false; }
  30666. console.warn('ag-Grid: API for selection is deprecated, call node.setSelected(value) instead');
  30667. if (suppressEvents) {
  30668. console.warn('ag-Grid: suppressEvents is no longer supported, stop listening for the event if you no longer want it');
  30669. }
  30670. node.setSelectedParams({ newValue: false });
  30671. };
  30672. GridApi.prototype.selectAll = function () {
  30673. this.selectionController.selectAllRowNodes();
  30674. };
  30675. GridApi.prototype.deselectAll = function () {
  30676. this.selectionController.deselectAllRowNodes();
  30677. };
  30678. GridApi.prototype.selectAllFiltered = function () {
  30679. this.selectionController.selectAllRowNodes(true);
  30680. };
  30681. GridApi.prototype.deselectAllFiltered = function () {
  30682. this.selectionController.deselectAllRowNodes(true);
  30683. };
  30684. GridApi.prototype.recomputeAggregates = function () {
  30685. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.clientSideRowModel)) {
  30686. console.warn('cannot call recomputeAggregates unless using normal row model');
  30687. }
  30688. console.warn("recomputeAggregates is deprecated, please call api.refreshClientSideRowModel('aggregate') instead");
  30689. this.clientSideRowModel.refreshModel({ step: _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].STEP_AGGREGATE });
  30690. };
  30691. GridApi.prototype.sizeColumnsToFit = function () {
  30692. this.gridPanel.sizeColumnsToFit();
  30693. };
  30694. GridApi.prototype.showLoadingOverlay = function () {
  30695. this.gridPanel.showLoadingOverlay();
  30696. };
  30697. GridApi.prototype.showNoRowsOverlay = function () {
  30698. this.gridPanel.showNoRowsOverlay();
  30699. };
  30700. GridApi.prototype.hideOverlay = function () {
  30701. this.gridPanel.hideOverlay();
  30702. };
  30703. GridApi.prototype.isNodeSelected = function (node) {
  30704. console.warn('ag-Grid: no need to call api.isNodeSelected(), just call node.isSelected() instead');
  30705. return node.isSelected();
  30706. };
  30707. GridApi.prototype.getSelectedNodesById = function () {
  30708. console.error('ag-Grid: since version 3.4, getSelectedNodesById no longer exists, use getSelectedNodes() instead');
  30709. return null;
  30710. };
  30711. GridApi.prototype.getSelectedNodes = function () {
  30712. return this.selectionController.getSelectedNodes();
  30713. };
  30714. GridApi.prototype.getSelectedRows = function () {
  30715. return this.selectionController.getSelectedRows();
  30716. };
  30717. GridApi.prototype.getBestCostNodeSelection = function () {
  30718. return this.selectionController.getBestCostNodeSelection();
  30719. };
  30720. GridApi.prototype.getRenderedNodes = function () {
  30721. return this.rowRenderer.getRenderedNodes();
  30722. };
  30723. GridApi.prototype.ensureColIndexVisible = function (index) {
  30724. console.warn('ag-Grid: ensureColIndexVisible(index) no longer supported, use ensureColumnVisible(colKey) instead.');
  30725. };
  30726. GridApi.prototype.ensureColumnVisible = function (key) {
  30727. this.gridPanel.ensureColumnVisible(key);
  30728. };
  30729. // Valid values for position are bottom, middle and top
  30730. GridApi.prototype.ensureIndexVisible = function (index, position) {
  30731. this.gridPanel.ensureIndexVisible(index, position);
  30732. };
  30733. // Valid values for position are bottom, middle and top
  30734. GridApi.prototype.ensureNodeVisible = function (comparator, position) {
  30735. this.gridCore.ensureNodeVisible(comparator, position);
  30736. };
  30737. GridApi.prototype.forEachLeafNode = function (callback) {
  30738. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.clientSideRowModel)) {
  30739. console.warn('cannot call forEachNode unless using normal row model');
  30740. }
  30741. this.clientSideRowModel.forEachLeafNode(callback);
  30742. };
  30743. GridApi.prototype.forEachNode = function (callback) {
  30744. this.rowModel.forEachNode(callback);
  30745. };
  30746. GridApi.prototype.forEachNodeAfterFilter = function (callback) {
  30747. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.clientSideRowModel)) {
  30748. console.warn('cannot call forEachNodeAfterFilter unless using normal row model');
  30749. }
  30750. this.clientSideRowModel.forEachNodeAfterFilter(callback);
  30751. };
  30752. GridApi.prototype.forEachNodeAfterFilterAndSort = function (callback) {
  30753. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.clientSideRowModel)) {
  30754. console.warn('cannot call forEachNodeAfterFilterAndSort unless using normal row model');
  30755. }
  30756. this.clientSideRowModel.forEachNodeAfterFilterAndSort(callback);
  30757. };
  30758. GridApi.prototype.getFilterApiForColDef = function (colDef) {
  30759. console.warn('ag-grid API method getFilterApiForColDef deprecated, use getFilterInstance instead');
  30760. return this.getFilterInstance(colDef);
  30761. };
  30762. GridApi.prototype.getFilterInstance = function (key, callback) {
  30763. var column = this.columnController.getPrimaryColumn(key);
  30764. if (column) {
  30765. var filterPromise = this.filterManager.getFilterComponent(column, 'NO_UI');
  30766. var currentValue = filterPromise.resolveNow(null, function (filterComp) { return filterComp; });
  30767. if (callback) {
  30768. if (currentValue) {
  30769. setTimeout(callback, 0, currentValue);
  30770. }
  30771. else {
  30772. filterPromise.then(callback);
  30773. }
  30774. }
  30775. return currentValue;
  30776. }
  30777. };
  30778. GridApi.prototype.getFilterApi = function (key) {
  30779. console.warn('ag-Grid: getFilterApi is deprecated, use getFilterInstance instead');
  30780. return this.getFilterInstance(key);
  30781. };
  30782. GridApi.prototype.destroyFilter = function (key) {
  30783. var column = this.columnController.getPrimaryColumn(key);
  30784. if (column) {
  30785. return this.filterManager.destroyFilter(column, "filterDestroyed");
  30786. }
  30787. };
  30788. GridApi.prototype.getStatusPanel = function (key) {
  30789. if (this.statusBarService) {
  30790. return this.statusBarService.getStatusPanel(key);
  30791. }
  30792. };
  30793. GridApi.prototype.getColumnDef = function (key) {
  30794. var column = this.columnController.getPrimaryColumn(key);
  30795. if (column) {
  30796. return column.getColDef();
  30797. }
  30798. return null;
  30799. };
  30800. GridApi.prototype.onFilterChanged = function () {
  30801. this.filterManager.onFilterChanged();
  30802. };
  30803. GridApi.prototype.onSortChanged = function () {
  30804. this.sortController.onSortChanged();
  30805. };
  30806. GridApi.prototype.setSortModel = function (sortModel, source) {
  30807. if (source === void 0) { source = "api"; }
  30808. this.sortController.setSortModel(sortModel, source);
  30809. };
  30810. GridApi.prototype.getSortModel = function () {
  30811. return this.sortController.getSortModel();
  30812. };
  30813. GridApi.prototype.setFilterModel = function (model) {
  30814. this.filterManager.setFilterModel(model);
  30815. };
  30816. GridApi.prototype.getFilterModel = function () {
  30817. return this.filterManager.getFilterModel();
  30818. };
  30819. GridApi.prototype.getFocusedCell = function () {
  30820. return this.focusController.getFocusedCell();
  30821. };
  30822. GridApi.prototype.clearFocusedCell = function () {
  30823. return this.focusController.clearFocusedCell();
  30824. };
  30825. GridApi.prototype.setFocusedCell = function (rowIndex, colKey, floating) {
  30826. this.focusController.setFocusedCell(rowIndex, colKey, floating, true);
  30827. };
  30828. GridApi.prototype.setSuppressRowDrag = function (value) {
  30829. this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_SUPPRESS_ROW_DRAG, value);
  30830. };
  30831. GridApi.prototype.setSuppressMoveWhenRowDragging = function (value) {
  30832. this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_SUPPRESS_MOVE_WHEN_ROW_DRAG, value);
  30833. };
  30834. GridApi.prototype.setSuppressRowClickSelection = function (value) {
  30835. this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_SUPPRESS_ROW_CLICK_SELECTION, value);
  30836. };
  30837. GridApi.prototype.addRowDropZone = function (params) {
  30838. this.gridPanel.getRowDragFeature().addRowDropZone(params);
  30839. };
  30840. GridApi.prototype.removeRowDropZone = function (params) {
  30841. var activeDropTarget = this.dragAndDropService.findExternalZone(params);
  30842. if (activeDropTarget) {
  30843. this.dragAndDropService.removeDropTarget(activeDropTarget);
  30844. }
  30845. };
  30846. GridApi.prototype.getRowDropZoneParams = function (events) {
  30847. return this.gridPanel.getRowDragFeature().getRowDropZone(events);
  30848. };
  30849. GridApi.prototype.setHeaderHeight = function (headerHeight) {
  30850. this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_HEADER_HEIGHT, headerHeight);
  30851. this.doLayout();
  30852. };
  30853. GridApi.prototype.setGridAutoHeight = function (gridAutoHeight) {
  30854. console.warn('api.setGridAutoHeight(boolean) is deprecated, please use api.setDomLayout() instead');
  30855. this.setDomLayout(gridAutoHeight ? 'autoHeight' : 'normal');
  30856. };
  30857. GridApi.prototype.setDomLayout = function (domLayout) {
  30858. this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_DOM_LAYOUT, domLayout);
  30859. };
  30860. GridApi.prototype.setEnableCellTextSelection = function (selectable) {
  30861. this.gridPanel.setCellTextSelection(selectable);
  30862. };
  30863. GridApi.prototype.setGroupHeaderHeight = function (headerHeight) {
  30864. this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GROUP_HEADER_HEIGHT, headerHeight);
  30865. this.doLayout();
  30866. };
  30867. GridApi.prototype.setFloatingFiltersHeight = function (headerHeight) {
  30868. this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_FLOATING_FILTERS_HEIGHT, headerHeight);
  30869. this.doLayout();
  30870. };
  30871. GridApi.prototype.setPivotGroupHeaderHeight = function (headerHeight) {
  30872. this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_PIVOT_GROUP_HEADER_HEIGHT, headerHeight);
  30873. this.doLayout();
  30874. };
  30875. GridApi.prototype.setPivotHeaderHeight = function (headerHeight) {
  30876. this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_PIVOT_HEADER_HEIGHT, headerHeight);
  30877. this.doLayout();
  30878. };
  30879. GridApi.prototype.isSideBarVisible = function () {
  30880. return this.gridCore.isSideBarVisible();
  30881. };
  30882. GridApi.prototype.setSideBarVisible = function (show) {
  30883. this.gridCore.setSideBarVisible(show);
  30884. };
  30885. GridApi.prototype.setSideBarPosition = function (position) {
  30886. this.gridCore.setSideBarPosition(position);
  30887. };
  30888. GridApi.prototype.showToolPanel = function (show) {
  30889. console.warn("ag-grid: from v19 api.showToolPanel has been deprecated in favour of api.setSideBarVisible");
  30890. this.setSideBarVisible(show);
  30891. };
  30892. GridApi.prototype.openToolPanel = function (key) {
  30893. this.gridCore.openToolPanel(key);
  30894. };
  30895. GridApi.prototype.closeToolPanel = function () {
  30896. this.gridCore.closeToolPanel();
  30897. };
  30898. GridApi.prototype.getOpenedToolPanel = function () {
  30899. return this.gridCore.getOpenedToolPanel();
  30900. };
  30901. GridApi.prototype.getSideBar = function () {
  30902. return this.gridCore.getSideBar();
  30903. };
  30904. GridApi.prototype.setSideBar = function (def) {
  30905. return this.gridCore.setSideBar(def);
  30906. };
  30907. GridApi.prototype.setSuppressClipboardPaste = function (value) {
  30908. this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_SUPPRESS_CLIPBOARD_PASTE, value);
  30909. };
  30910. GridApi.prototype.isToolPanelShowing = function () {
  30911. return this.gridCore.isToolPanelShowing();
  30912. };
  30913. GridApi.prototype.doLayout = function () {
  30914. this.gridPanel.checkViewportAndScrolls();
  30915. };
  30916. GridApi.prototype.resetRowHeights = function () {
  30917. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(this.clientSideRowModel)) {
  30918. this.clientSideRowModel.resetRowHeights();
  30919. }
  30920. };
  30921. GridApi.prototype.setGroupRemoveSingleChildren = function (value) {
  30922. this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GROUP_REMOVE_SINGLE_CHILDREN, value);
  30923. };
  30924. GridApi.prototype.setGroupRemoveLowestSingleChildren = function (value) {
  30925. this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GROUP_REMOVE_LOWEST_SINGLE_CHILDREN, value);
  30926. };
  30927. GridApi.prototype.onRowHeightChanged = function () {
  30928. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(this.clientSideRowModel)) {
  30929. this.clientSideRowModel.onRowHeightChanged();
  30930. }
  30931. };
  30932. GridApi.prototype.getValue = function (colKey, rowNode) {
  30933. var column = this.columnController.getPrimaryColumn(colKey);
  30934. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(column)) {
  30935. column = this.columnController.getGridColumn(colKey);
  30936. }
  30937. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(column)) {
  30938. return null;
  30939. }
  30940. return this.valueService.getValue(column, rowNode);
  30941. };
  30942. GridApi.prototype.addEventListener = function (eventType, listener) {
  30943. var async = this.gridOptionsWrapper.useAsyncEvents();
  30944. this.eventService.addEventListener(eventType, listener, async);
  30945. };
  30946. GridApi.prototype.addGlobalListener = function (listener) {
  30947. var async = this.gridOptionsWrapper.useAsyncEvents();
  30948. this.eventService.addGlobalListener(listener, async);
  30949. };
  30950. GridApi.prototype.removeEventListener = function (eventType, listener) {
  30951. var async = this.gridOptionsWrapper.useAsyncEvents();
  30952. this.eventService.removeEventListener(eventType, listener, async);
  30953. };
  30954. GridApi.prototype.removeGlobalListener = function (listener) {
  30955. var async = this.gridOptionsWrapper.useAsyncEvents();
  30956. this.eventService.removeGlobalListener(listener, async);
  30957. };
  30958. GridApi.prototype.dispatchEvent = function (event) {
  30959. this.eventService.dispatchEvent(event);
  30960. };
  30961. GridApi.prototype.destroy = function () {
  30962. // this is needed as GridAPI is a bean, and GridAPI.destroy() is called as part
  30963. // of context.destroy(). so we need to stop the infinite loop.
  30964. if (this.destroyCalled) {
  30965. return;
  30966. }
  30967. this.destroyCalled = true;
  30968. // destroy the UI first (as they use the services)
  30969. this.context.destroyBean(this.gridCore);
  30970. // destroy the services
  30971. this.context.destroy();
  30972. };
  30973. GridApi.prototype.resetQuickFilter = function () {
  30974. this.rowModel.forEachNode(function (node) { return node.quickFilterAggregateText = null; });
  30975. };
  30976. GridApi.prototype.getRangeSelections = function () {
  30977. console.warn("ag-Grid: in v20.1.x, api.getRangeSelections() is gone, please use getCellRanges() instead.\n We had to change how cell selections works a small bit to allow charting to integrate. The return type of\n getCellRanges() is a bit different, please check the ag-Grid documentation.");
  30978. return null;
  30979. };
  30980. GridApi.prototype.getCellRanges = function () {
  30981. if (this.rangeController) {
  30982. return this.rangeController.getCellRanges();
  30983. }
  30984. console.warn('ag-Grid: cell range selection is only available in ag-Grid Enterprise');
  30985. return null;
  30986. };
  30987. GridApi.prototype.camelCaseToHumanReadable = function (camelCase) {
  30988. return _utils__WEBPACK_IMPORTED_MODULE_5__["_"].camelCaseToHumanText(camelCase);
  30989. };
  30990. GridApi.prototype.addRangeSelection = function (deprecatedNoLongerUsed) {
  30991. console.warn('ag-Grid: As of version 21.x, range selection changed slightly to allow charting integration. Please call api.addCellRange() instead of api.addRangeSelection()');
  30992. };
  30993. GridApi.prototype.addCellRange = function (params) {
  30994. if (!this.rangeController) {
  30995. console.warn('ag-Grid: cell range selection is only available in ag-Grid Enterprise');
  30996. }
  30997. this.rangeController.addCellRange(params);
  30998. };
  30999. GridApi.prototype.clearRangeSelection = function () {
  31000. if (!this.rangeController) {
  31001. console.warn('ag-Grid: cell range selection is only available in ag-Grid Enterprise');
  31002. }
  31003. this.rangeController.removeAllCellRanges();
  31004. };
  31005. GridApi.prototype.undoCellEditing = function () {
  31006. this.undoRedoService.undo();
  31007. };
  31008. GridApi.prototype.redoCellEditing = function () {
  31009. this.undoRedoService.redo();
  31010. };
  31011. GridApi.prototype.getChartModels = function () {
  31012. if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].RangeSelectionModule, 'api.getChartModels') &&
  31013. _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].GridChartsModule, 'api.getChartModels')) {
  31014. return this.chartService.getChartModels();
  31015. }
  31016. };
  31017. GridApi.prototype.createRangeChart = function (params) {
  31018. if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].RangeSelectionModule, 'api.createRangeChart') &&
  31019. _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].GridChartsModule, 'api.createRangeChart')) {
  31020. return this.chartService.createRangeChart(params);
  31021. }
  31022. };
  31023. GridApi.prototype.createPivotChart = function (params) {
  31024. if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].RangeSelectionModule, 'api.createPivotChart') &&
  31025. _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_4__["ModuleRegistry"].assertRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"].GridChartsModule, 'api.createPivotChart')) {
  31026. return this.chartService.createPivotChart(params);
  31027. }
  31028. };
  31029. GridApi.prototype.copySelectedRowsToClipboard = function (includeHeader, columnKeys) {
  31030. if (!this.clipboardService) {
  31031. console.warn('ag-Grid: clipboard is only available in ag-Grid Enterprise');
  31032. }
  31033. this.clipboardService.copySelectedRowsToClipboard(includeHeader, columnKeys);
  31034. };
  31035. GridApi.prototype.copySelectedRangeToClipboard = function (includeHeader) {
  31036. if (!this.clipboardService) {
  31037. console.warn('ag-Grid: clipboard is only available in ag-Grid Enterprise');
  31038. }
  31039. this.clipboardService.copySelectedRangeToClipboard(includeHeader);
  31040. };
  31041. GridApi.prototype.copySelectedRangeDown = function () {
  31042. if (!this.clipboardService) {
  31043. console.warn('ag-Grid: clipboard is only available in ag-Grid Enterprise');
  31044. }
  31045. this.clipboardService.copyRangeDown();
  31046. };
  31047. GridApi.prototype.showColumnMenuAfterButtonClick = function (colKey, buttonElement) {
  31048. // use grid column so works with pivot mode
  31049. var column = this.columnController.getGridColumn(colKey);
  31050. this.menuFactory.showMenuAfterButtonClick(column, buttonElement);
  31051. };
  31052. GridApi.prototype.showColumnMenuAfterMouseClick = function (colKey, mouseEvent) {
  31053. // use grid column so works with pivot mode
  31054. var column = this.columnController.getGridColumn(colKey);
  31055. if (!column) {
  31056. column = this.columnController.getPrimaryColumn(colKey);
  31057. }
  31058. if (!column) {
  31059. console.error("ag-Grid: column '" + colKey + "' not found");
  31060. return;
  31061. }
  31062. this.menuFactory.showMenuAfterMouseEvent(column, mouseEvent);
  31063. };
  31064. GridApi.prototype.hidePopupMenu = function () {
  31065. // hide the context menu if in enterprise
  31066. if (this.contextMenuFactory) {
  31067. this.contextMenuFactory.hideActiveMenu();
  31068. }
  31069. // and hide the column menu always
  31070. this.menuFactory.hideActiveMenu();
  31071. };
  31072. GridApi.prototype.setPopupParent = function (ePopupParent) {
  31073. this.gridOptionsWrapper.setProperty(_gridOptionsWrapper__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_POPUP_PARENT, ePopupParent);
  31074. };
  31075. GridApi.prototype.tabToNextCell = function () {
  31076. return this.rowRenderer.tabToNextCell(false);
  31077. };
  31078. GridApi.prototype.tabToPreviousCell = function () {
  31079. return this.rowRenderer.tabToNextCell(true);
  31080. };
  31081. GridApi.prototype.getCellRendererInstances = function (params) {
  31082. if (params === void 0) { params = {}; }
  31083. return this.rowRenderer.getCellRendererInstances(params);
  31084. };
  31085. GridApi.prototype.getCellEditorInstances = function (params) {
  31086. if (params === void 0) { params = {}; }
  31087. return this.rowRenderer.getCellEditorInstances(params);
  31088. };
  31089. GridApi.prototype.getEditingCells = function () {
  31090. return this.rowRenderer.getEditingCells();
  31091. };
  31092. GridApi.prototype.stopEditing = function (cancel) {
  31093. if (cancel === void 0) { cancel = false; }
  31094. this.rowRenderer.stopEditing(cancel);
  31095. };
  31096. GridApi.prototype.startEditingCell = function (params) {
  31097. var column = this.columnController.getGridColumn(params.colKey);
  31098. if (!column) {
  31099. console.warn("ag-Grid: no column found for " + params.colKey);
  31100. return;
  31101. }
  31102. var cellPosition = {
  31103. rowIndex: params.rowIndex,
  31104. rowPinned: params.rowPinned,
  31105. column: column
  31106. };
  31107. var notPinned = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(params.rowPinned);
  31108. if (notPinned) {
  31109. this.gridPanel.ensureIndexVisible(params.rowIndex);
  31110. }
  31111. this.rowRenderer.startEditingCell(cellPosition, params.keyPress, params.charPress);
  31112. };
  31113. GridApi.prototype.addAggFunc = function (key, aggFunc) {
  31114. if (this.aggFuncService) {
  31115. this.aggFuncService.addAggFunc(key, aggFunc);
  31116. }
  31117. };
  31118. GridApi.prototype.addAggFuncs = function (aggFuncs) {
  31119. if (this.aggFuncService) {
  31120. this.aggFuncService.addAggFuncs(aggFuncs);
  31121. }
  31122. };
  31123. GridApi.prototype.clearAggFuncs = function () {
  31124. if (this.aggFuncService) {
  31125. this.aggFuncService.clear();
  31126. }
  31127. };
  31128. GridApi.prototype.applyTransaction = function (rowDataTransaction) {
  31129. var res = null;
  31130. if (this.clientSideRowModel) {
  31131. if (rowDataTransaction && rowDataTransaction.addIndex != null) {
  31132. var message_1 = 'ag-Grid: as of v23.1, transaction.addIndex is deprecated. If you want precision control of adding data, use immutableData instead';
  31133. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].doOnce(function () { return console.warn(message_1); }, 'transaction.addIndex deprecated');
  31134. }
  31135. res = this.clientSideRowModel.updateRowData(rowDataTransaction);
  31136. }
  31137. else if (this.infiniteRowModel) {
  31138. var message_2 = 'ag-Grid: as of v23.1, transactions for Infinite Row Model are deprecated. If you want to make updates to data in Infinite Row Models, then refresh the data.';
  31139. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].doOnce(function () { return console.warn(message_2); }, 'applyTransaction infiniteRowModel deprecated');
  31140. this.infiniteRowModel.updateRowData(rowDataTransaction);
  31141. }
  31142. else {
  31143. console.error('ag-Grid: updateRowData() only works with ClientSideRowModel and InfiniteRowModel.');
  31144. }
  31145. // refresh all the full width rows
  31146. this.rowRenderer.refreshFullWidthRows();
  31147. // do change detection for all present cells
  31148. if (!this.gridOptionsWrapper.isSuppressChangeDetection()) {
  31149. this.rowRenderer.refreshCells();
  31150. }
  31151. return res;
  31152. };
  31153. /** @deprecated */
  31154. GridApi.prototype.updateRowData = function (rowDataTransaction) {
  31155. var message = 'ag-Grid: as of v23.1, grid API updateRowData(transaction) is now called applyTransaction(transaction). updateRowData is deprecated and will be removed in a future major release.';
  31156. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].doOnce(function () { return console.warn(message); }, 'updateRowData deprecated');
  31157. return this.applyTransaction(rowDataTransaction);
  31158. };
  31159. GridApi.prototype.applyTransactionAsync = function (rowDataTransaction, callback) {
  31160. if (!this.clientSideRowModel) {
  31161. console.error('ag-Grid: api.applyTransactionAsync() only works with ClientSideRowModel.');
  31162. return;
  31163. }
  31164. this.clientSideRowModel.batchUpdateRowData(rowDataTransaction, callback);
  31165. };
  31166. /** @deprecated */
  31167. GridApi.prototype.batchUpdateRowData = function (rowDataTransaction, callback) {
  31168. var message = 'ag-Grid: as of v23.1, grid API batchUpdateRowData(transaction, callback) is now called applyTransactionAsync(transaction, callback). batchUpdateRowData is deprecated and will be removed in a future major release.';
  31169. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].doOnce(function () { return console.warn(message); }, 'batchUpdateRowData deprecated');
  31170. this.applyTransactionAsync(rowDataTransaction, callback);
  31171. };
  31172. GridApi.prototype.insertItemsAtIndex = function (index, items, skipRefresh) {
  31173. if (skipRefresh === void 0) { skipRefresh = false; }
  31174. console.warn('ag-Grid: insertItemsAtIndex() is deprecated, use updateRowData(transaction) instead.');
  31175. this.updateRowData({ add: items, addIndex: index, update: null, remove: null });
  31176. };
  31177. GridApi.prototype.removeItems = function (rowNodes, skipRefresh) {
  31178. if (skipRefresh === void 0) { skipRefresh = false; }
  31179. console.warn('ag-Grid: removeItems() is deprecated, use updateRowData(transaction) instead.');
  31180. var dataToRemove = rowNodes.map(function (rowNode) { return rowNode.data; });
  31181. this.updateRowData({ add: null, addIndex: null, update: null, remove: dataToRemove });
  31182. };
  31183. GridApi.prototype.addItems = function (items, skipRefresh) {
  31184. if (skipRefresh === void 0) { skipRefresh = false; }
  31185. console.warn('ag-Grid: addItems() is deprecated, use updateRowData(transaction) instead.');
  31186. this.updateRowData({ add: items, addIndex: null, update: null, remove: null });
  31187. };
  31188. GridApi.prototype.refreshVirtualPageCache = function () {
  31189. console.warn('ag-Grid: refreshVirtualPageCache() is now called refreshInfiniteCache(), please call refreshInfiniteCache() instead');
  31190. this.refreshInfiniteCache();
  31191. };
  31192. GridApi.prototype.refreshInfinitePageCache = function () {
  31193. console.warn('ag-Grid: refreshInfinitePageCache() is now called refreshInfiniteCache(), please call refreshInfiniteCache() instead');
  31194. this.refreshInfiniteCache();
  31195. };
  31196. GridApi.prototype.refreshInfiniteCache = function () {
  31197. if (this.infiniteRowModel) {
  31198. this.infiniteRowModel.refreshCache();
  31199. }
  31200. else {
  31201. console.warn("ag-Grid: api.refreshInfiniteCache is only available when rowModelType='infinite'.");
  31202. }
  31203. };
  31204. GridApi.prototype.purgeVirtualPageCache = function () {
  31205. console.warn('ag-Grid: purgeVirtualPageCache() is now called purgeInfiniteCache(), please call purgeInfiniteCache() instead');
  31206. this.purgeInfinitePageCache();
  31207. };
  31208. GridApi.prototype.purgeInfinitePageCache = function () {
  31209. console.warn('ag-Grid: purgeInfinitePageCache() is now called purgeInfiniteCache(), please call purgeInfiniteCache() instead');
  31210. this.purgeInfiniteCache();
  31211. };
  31212. GridApi.prototype.purgeInfiniteCache = function () {
  31213. if (this.infiniteRowModel) {
  31214. this.infiniteRowModel.purgeCache();
  31215. }
  31216. else {
  31217. console.warn("ag-Grid: api.purgeInfiniteCache is only available when rowModelType='infinite'.");
  31218. }
  31219. };
  31220. /** @deprecated */
  31221. GridApi.prototype.purgeEnterpriseCache = function (route) {
  31222. console.warn("ag-grid: since version 18.x, api.purgeEnterpriseCache() should be replaced with api.purgeServerSideCache()");
  31223. this.purgeServerSideCache(route);
  31224. };
  31225. GridApi.prototype.purgeServerSideCache = function (route) {
  31226. if (this.serverSideRowModel) {
  31227. this.serverSideRowModel.purgeCache(route);
  31228. }
  31229. else {
  31230. console.warn("ag-Grid: api.purgeServerSideCache is only available when rowModelType='enterprise'.");
  31231. }
  31232. };
  31233. GridApi.prototype.getVirtualRowCount = function () {
  31234. console.warn('ag-Grid: getVirtualRowCount() is now called getInfiniteRowCount(), please call getInfiniteRowCount() instead');
  31235. return this.getInfiniteRowCount();
  31236. };
  31237. GridApi.prototype.getInfiniteRowCount = function () {
  31238. if (this.infiniteRowModel) {
  31239. return this.infiniteRowModel.getVirtualRowCount();
  31240. }
  31241. else {
  31242. console.warn("ag-Grid: api.getVirtualRowCount is only available when rowModelType='virtual'.");
  31243. }
  31244. };
  31245. GridApi.prototype.isMaxRowFound = function () {
  31246. if (this.infiniteRowModel) {
  31247. return this.infiniteRowModel.isMaxRowFound();
  31248. }
  31249. else {
  31250. console.warn("ag-Grid: api.isMaxRowFound is only available when rowModelType='virtual'.");
  31251. }
  31252. };
  31253. GridApi.prototype.setVirtualRowCount = function (rowCount, maxRowFound) {
  31254. console.warn('ag-Grid: setVirtualRowCount() is now called setInfiniteRowCount(), please call setInfiniteRowCount() instead');
  31255. this.setInfiniteRowCount(rowCount, maxRowFound);
  31256. };
  31257. GridApi.prototype.setInfiniteRowCount = function (rowCount, maxRowFound) {
  31258. if (this.infiniteRowModel) {
  31259. this.infiniteRowModel.setVirtualRowCount(rowCount, maxRowFound);
  31260. }
  31261. else {
  31262. console.warn("ag-Grid: api.setVirtualRowCount is only available when rowModelType='virtual'.");
  31263. }
  31264. };
  31265. GridApi.prototype.getVirtualPageState = function () {
  31266. console.warn('ag-Grid: getVirtualPageState() is now called getCacheBlockState(), please call getCacheBlockState() instead');
  31267. return this.getCacheBlockState();
  31268. };
  31269. GridApi.prototype.getInfinitePageState = function () {
  31270. console.warn('ag-Grid: getInfinitePageState() is now called getCacheBlockState(), please call getCacheBlockState() instead');
  31271. return this.getCacheBlockState();
  31272. };
  31273. GridApi.prototype.getCacheBlockState = function () {
  31274. if (this.infiniteRowModel) {
  31275. return this.infiniteRowModel.getBlockState();
  31276. }
  31277. else if (this.serverSideRowModel) {
  31278. return this.serverSideRowModel.getBlockState();
  31279. }
  31280. else {
  31281. console.warn("ag-Grid: api.getCacheBlockState() is only available when rowModelType='infinite' or rowModelType='serverSide'.");
  31282. }
  31283. };
  31284. GridApi.prototype.checkGridSize = function () {
  31285. this.gridPanel.setHeaderAndFloatingHeights();
  31286. };
  31287. GridApi.prototype.getFirstRenderedRow = function () {
  31288. console.warn('in ag-Grid v12, getFirstRenderedRow() was renamed to getFirstDisplayedRow()');
  31289. return this.getFirstDisplayedRow();
  31290. };
  31291. GridApi.prototype.getFirstDisplayedRow = function () {
  31292. return this.rowRenderer.getFirstVirtualRenderedRow();
  31293. };
  31294. GridApi.prototype.getLastRenderedRow = function () {
  31295. console.warn('in ag-Grid v12, getLastRenderedRow() was renamed to getLastDisplayedRow()');
  31296. return this.getLastDisplayedRow();
  31297. };
  31298. GridApi.prototype.getLastDisplayedRow = function () {
  31299. return this.rowRenderer.getLastVirtualRenderedRow();
  31300. };
  31301. GridApi.prototype.getDisplayedRowAtIndex = function (index) {
  31302. return this.rowModel.getRow(index);
  31303. };
  31304. GridApi.prototype.getDisplayedRowCount = function () {
  31305. return this.rowModel.getRowCount();
  31306. };
  31307. GridApi.prototype.paginationIsLastPageFound = function () {
  31308. return this.paginationProxy.isLastPageFound();
  31309. };
  31310. GridApi.prototype.paginationGetPageSize = function () {
  31311. return this.paginationProxy.getPageSize();
  31312. };
  31313. GridApi.prototype.paginationSetPageSize = function (size) {
  31314. this.gridOptionsWrapper.setProperty('paginationPageSize', size);
  31315. };
  31316. GridApi.prototype.paginationGetCurrentPage = function () {
  31317. return this.paginationProxy.getCurrentPage();
  31318. };
  31319. GridApi.prototype.paginationGetTotalPages = function () {
  31320. return this.paginationProxy.getTotalPages();
  31321. };
  31322. GridApi.prototype.paginationGetRowCount = function () {
  31323. return this.paginationProxy.getMasterRowCount();
  31324. };
  31325. GridApi.prototype.paginationGoToNextPage = function () {
  31326. this.paginationProxy.goToNextPage();
  31327. };
  31328. GridApi.prototype.paginationGoToPreviousPage = function () {
  31329. this.paginationProxy.goToPreviousPage();
  31330. };
  31331. GridApi.prototype.paginationGoToFirstPage = function () {
  31332. this.paginationProxy.goToFirstPage();
  31333. };
  31334. GridApi.prototype.paginationGoToLastPage = function () {
  31335. this.paginationProxy.goToLastPage();
  31336. };
  31337. GridApi.prototype.paginationGoToPage = function (page) {
  31338. this.paginationProxy.goToPage(page);
  31339. };
  31340. __decorate([
  31341. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('immutableService')
  31342. ], GridApi.prototype, "immutableService", void 0);
  31343. __decorate([
  31344. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('csvCreator')
  31345. ], GridApi.prototype, "csvCreator", void 0);
  31346. __decorate([
  31347. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('excelCreator')
  31348. ], GridApi.prototype, "excelCreator", void 0);
  31349. __decorate([
  31350. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('rowRenderer')
  31351. ], GridApi.prototype, "rowRenderer", void 0);
  31352. __decorate([
  31353. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('filterManager')
  31354. ], GridApi.prototype, "filterManager", void 0);
  31355. __decorate([
  31356. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnController')
  31357. ], GridApi.prototype, "columnController", void 0);
  31358. __decorate([
  31359. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('selectionController')
  31360. ], GridApi.prototype, "selectionController", void 0);
  31361. __decorate([
  31362. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper')
  31363. ], GridApi.prototype, "gridOptionsWrapper", void 0);
  31364. __decorate([
  31365. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('valueService')
  31366. ], GridApi.prototype, "valueService", void 0);
  31367. __decorate([
  31368. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('alignedGridsService')
  31369. ], GridApi.prototype, "alignedGridsService", void 0);
  31370. __decorate([
  31371. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('eventService')
  31372. ], GridApi.prototype, "eventService", void 0);
  31373. __decorate([
  31374. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('pinnedRowModel')
  31375. ], GridApi.prototype, "pinnedRowModel", void 0);
  31376. __decorate([
  31377. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('context')
  31378. ], GridApi.prototype, "context", void 0);
  31379. __decorate([
  31380. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('rowModel')
  31381. ], GridApi.prototype, "rowModel", void 0);
  31382. __decorate([
  31383. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('sortController')
  31384. ], GridApi.prototype, "sortController", void 0);
  31385. __decorate([
  31386. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('paginationProxy')
  31387. ], GridApi.prototype, "paginationProxy", void 0);
  31388. __decorate([
  31389. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('focusController')
  31390. ], GridApi.prototype, "focusController", void 0);
  31391. __decorate([
  31392. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('dragAndDropService')
  31393. ], GridApi.prototype, "dragAndDropService", void 0);
  31394. __decorate([
  31395. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('rangeController')
  31396. ], GridApi.prototype, "rangeController", void 0);
  31397. __decorate([
  31398. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('clipboardService')
  31399. ], GridApi.prototype, "clipboardService", void 0);
  31400. __decorate([
  31401. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('aggFuncService')
  31402. ], GridApi.prototype, "aggFuncService", void 0);
  31403. __decorate([
  31404. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('menuFactory')
  31405. ], GridApi.prototype, "menuFactory", void 0);
  31406. __decorate([
  31407. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('contextMenuFactory')
  31408. ], GridApi.prototype, "contextMenuFactory", void 0);
  31409. __decorate([
  31410. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('cellRendererFactory')
  31411. ], GridApi.prototype, "cellRendererFactory", void 0);
  31412. __decorate([
  31413. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('valueCache')
  31414. ], GridApi.prototype, "valueCache", void 0);
  31415. __decorate([
  31416. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('animationFrameService')
  31417. ], GridApi.prototype, "animationFrameService", void 0);
  31418. __decorate([
  31419. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('statusBarService')
  31420. ], GridApi.prototype, "statusBarService", void 0);
  31421. __decorate([
  31422. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('chartService')
  31423. ], GridApi.prototype, "chartService", void 0);
  31424. __decorate([
  31425. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Optional"])('undoRedoService')
  31426. ], GridApi.prototype, "undoRedoService", void 0);
  31427. __decorate([
  31428. _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"]
  31429. ], GridApi.prototype, "init", null);
  31430. GridApi = __decorate([
  31431. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Bean"])('gridApi')
  31432. ], GridApi);
  31433. return GridApi;
  31434. }());
  31435. /***/ }),
  31436. /* 131 */
  31437. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  31438. "use strict";
  31439. __webpack_require__.r(__webpack_exports__);
  31440. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ExpressionService", function() { return ExpressionService; });
  31441. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  31442. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  31443. /**
  31444. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  31445. * @version v23.2.1
  31446. * @link http://www.ag-grid.com/
  31447. * @license MIT
  31448. */
  31449. var __extends = (undefined && undefined.__extends) || (function () {
  31450. var extendStatics = function (d, b) {
  31451. extendStatics = Object.setPrototypeOf ||
  31452. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  31453. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  31454. return extendStatics(d, b);
  31455. };
  31456. return function (d, b) {
  31457. extendStatics(d, b);
  31458. function __() { this.constructor = d; }
  31459. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  31460. };
  31461. })();
  31462. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  31463. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  31464. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  31465. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  31466. return c > 3 && r && Object.defineProperty(target, key, r), r;
  31467. };
  31468. var __param = (undefined && undefined.__param) || function (paramIndex, decorator) {
  31469. return function (target, key) { decorator(target, key, paramIndex); }
  31470. };
  31471. var ExpressionService = /** @class */ (function (_super) {
  31472. __extends(ExpressionService, _super);
  31473. function ExpressionService() {
  31474. var _this = _super !== null && _super.apply(this, arguments) || this;
  31475. _this.expressionToFunctionCache = {};
  31476. return _this;
  31477. }
  31478. ExpressionService.prototype.setBeans = function (loggerFactory) {
  31479. this.logger = loggerFactory.create('ExpressionService');
  31480. };
  31481. ExpressionService.prototype.evaluate = function (expressionOrFunc, params) {
  31482. if (typeof expressionOrFunc === 'function') {
  31483. // valueGetter is a function, so just call it
  31484. var func = expressionOrFunc;
  31485. return func(params);
  31486. }
  31487. else if (typeof expressionOrFunc === 'string') {
  31488. // valueGetter is an expression, so execute the expression
  31489. var expression = expressionOrFunc;
  31490. return this.evaluateExpression(expression, params);
  31491. }
  31492. else {
  31493. console.error('ag-Grid: value should be either a string or a function', expressionOrFunc);
  31494. }
  31495. };
  31496. ExpressionService.prototype.evaluateExpression = function (expression, params) {
  31497. try {
  31498. var javaScriptFunction = this.createExpressionFunction(expression);
  31499. // the params don't have all these values, rather we add every possible
  31500. // value a params can have, which makes whatever is in the params available.
  31501. var result = javaScriptFunction(params.value, params.context, params.oldValue, params.newValue, params.value, params.node, params.data, params.colDef, params.rowIndex, params.api, params.columnApi, params.getValue, params.column, params.columnGroup);
  31502. return result;
  31503. }
  31504. catch (e) {
  31505. // the expression failed, which can happen, as it's the client that
  31506. // provides the expression. so print a nice message
  31507. // tslint:disable-next-line
  31508. console.log('Processing of the expression failed');
  31509. // tslint:disable-next-line
  31510. console.log('Expression = ' + expression);
  31511. // tslint:disable-next-line
  31512. console.log('Params =', params);
  31513. // tslint:disable-next-line
  31514. console.log('Exception = ' + e);
  31515. return null;
  31516. }
  31517. };
  31518. ExpressionService.prototype.createExpressionFunction = function (expression) {
  31519. // check cache first
  31520. if (this.expressionToFunctionCache[expression]) {
  31521. return this.expressionToFunctionCache[expression];
  31522. }
  31523. // if not found in cache, return the function
  31524. var functionBody = this.createFunctionBody(expression);
  31525. var theFunction = new Function('x, ctx, oldValue, newValue, value, node, data, colDef, rowIndex, api, columnApi, getValue, column, columnGroup', functionBody);
  31526. // store in cache
  31527. this.expressionToFunctionCache[expression] = theFunction;
  31528. return theFunction;
  31529. };
  31530. ExpressionService.prototype.createFunctionBody = function (expression) {
  31531. // if the expression has the 'return' word in it, then use as is,
  31532. // if not, then wrap it with return and ';' to make a function
  31533. if (expression.indexOf('return') >= 0) {
  31534. return expression;
  31535. }
  31536. else {
  31537. return 'return ' + expression + ';';
  31538. }
  31539. };
  31540. __decorate([
  31541. __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('loggerFactory'))
  31542. ], ExpressionService.prototype, "setBeans", null);
  31543. ExpressionService = __decorate([
  31544. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('expressionService')
  31545. ], ExpressionService);
  31546. return ExpressionService;
  31547. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  31548. /***/ }),
  31549. /* 132 */
  31550. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  31551. "use strict";
  31552. __webpack_require__.r(__webpack_exports__);
  31553. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TemplateService", function() { return TemplateService; });
  31554. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  31555. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  31556. /**
  31557. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  31558. * @version v23.2.1
  31559. * @link http://www.ag-grid.com/
  31560. * @license MIT
  31561. */
  31562. var __extends = (undefined && undefined.__extends) || (function () {
  31563. var extendStatics = function (d, b) {
  31564. extendStatics = Object.setPrototypeOf ||
  31565. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  31566. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  31567. return extendStatics(d, b);
  31568. };
  31569. return function (d, b) {
  31570. extendStatics(d, b);
  31571. function __() { this.constructor = d; }
  31572. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  31573. };
  31574. })();
  31575. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  31576. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  31577. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  31578. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  31579. return c > 3 && r && Object.defineProperty(target, key, r), r;
  31580. };
  31581. var TemplateService = /** @class */ (function (_super) {
  31582. __extends(TemplateService, _super);
  31583. function TemplateService() {
  31584. var _this = _super !== null && _super.apply(this, arguments) || this;
  31585. _this.templateCache = {};
  31586. _this.waitingCallbacks = {};
  31587. return _this;
  31588. }
  31589. // returns the template if it is loaded, or null if it is not loaded
  31590. // but will call the callback when it is loaded
  31591. TemplateService.prototype.getTemplate = function (url, callback) {
  31592. var templateFromCache = this.templateCache[url];
  31593. if (templateFromCache) {
  31594. return templateFromCache;
  31595. }
  31596. var callbackList = this.waitingCallbacks[url];
  31597. var that = this;
  31598. if (!callbackList) {
  31599. // first time this was called, so need a new list for callbacks
  31600. callbackList = [];
  31601. this.waitingCallbacks[url] = callbackList;
  31602. // and also need to do the http request
  31603. var client = new XMLHttpRequest();
  31604. client.onload = function () {
  31605. that.handleHttpResult(this, url);
  31606. };
  31607. client.open("GET", url);
  31608. client.send();
  31609. }
  31610. // add this callback
  31611. if (callback) {
  31612. callbackList.push(callback);
  31613. }
  31614. // caller needs to wait for template to load, so return null
  31615. return null;
  31616. };
  31617. TemplateService.prototype.handleHttpResult = function (httpResult, url) {
  31618. if (httpResult.status !== 200 || httpResult.response === null) {
  31619. console.warn("Unable to get template error " + httpResult.status + " - " + url);
  31620. return;
  31621. }
  31622. // response success, so process it
  31623. // in IE9 the response is in - responseText
  31624. this.templateCache[url] = httpResult.response || httpResult.responseText;
  31625. // inform all listeners that this is now in the cache
  31626. var callbacks = this.waitingCallbacks[url];
  31627. for (var i = 0; i < callbacks.length; i++) {
  31628. var callback = callbacks[i];
  31629. // we could pass the callback the response, however we know the client of this code
  31630. // is the cell renderer, and it passes the 'cellRefresh' method in as the callback
  31631. // which doesn't take any parameters.
  31632. callback();
  31633. }
  31634. if (this.$scope) {
  31635. var that_1 = this;
  31636. window.setTimeout(function () {
  31637. that_1.$scope.$apply();
  31638. }, 0);
  31639. }
  31640. };
  31641. __decorate([
  31642. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('$scope')
  31643. ], TemplateService.prototype, "$scope", void 0);
  31644. TemplateService = __decorate([
  31645. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('templateService')
  31646. ], TemplateService);
  31647. return TemplateService;
  31648. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  31649. /***/ }),
  31650. /* 133 */
  31651. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  31652. "use strict";
  31653. __webpack_require__.r(__webpack_exports__);
  31654. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PopupService", function() { return PopupService; });
  31655. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(25);
  31656. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  31657. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43);
  31658. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(41);
  31659. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7);
  31660. /**
  31661. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  31662. * @version v23.2.1
  31663. * @link http://www.ag-grid.com/
  31664. * @license MIT
  31665. */
  31666. var __extends = (undefined && undefined.__extends) || (function () {
  31667. var extendStatics = function (d, b) {
  31668. extendStatics = Object.setPrototypeOf ||
  31669. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  31670. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  31671. return extendStatics(d, b);
  31672. };
  31673. return function (d, b) {
  31674. extendStatics(d, b);
  31675. function __() { this.constructor = d; }
  31676. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  31677. };
  31678. })();
  31679. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  31680. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  31681. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  31682. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  31683. return c > 3 && r && Object.defineProperty(target, key, r), r;
  31684. };
  31685. var PopupService = /** @class */ (function (_super) {
  31686. __extends(PopupService, _super);
  31687. function PopupService() {
  31688. var _this = _super !== null && _super.apply(this, arguments) || this;
  31689. _this.popupList = [];
  31690. return _this;
  31691. }
  31692. PopupService.prototype.init = function () {
  31693. var _this = this;
  31694. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_KEYBOARD_FOCUS, function () {
  31695. _this.popupList.forEach(function (popup) {
  31696. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(popup.element, 'ag-keyboard-focus');
  31697. });
  31698. });
  31699. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_MOUSE_FOCUS, function () {
  31700. _this.popupList.forEach(function (popup) {
  31701. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].removeCssClass(popup.element, 'ag-keyboard-focus');
  31702. });
  31703. });
  31704. };
  31705. PopupService.prototype.registerGridCore = function (gridCore) {
  31706. this.gridCore = gridCore;
  31707. };
  31708. PopupService.prototype.getPopupParent = function () {
  31709. var ePopupParent = this.gridOptionsWrapper.getPopupParent();
  31710. if (ePopupParent) {
  31711. return ePopupParent;
  31712. }
  31713. return this.gridCore.getRootGui();
  31714. };
  31715. PopupService.prototype.positionPopupForMenu = function (params) {
  31716. var sourceRect = params.eventSource.getBoundingClientRect();
  31717. var parentRect = this.getParentRect();
  31718. var y = this.keepYWithinBounds(params, sourceRect.top - parentRect.top);
  31719. var minWidth = (params.ePopup.clientWidth > 0) ? params.ePopup.clientWidth : 200;
  31720. params.ePopup.style.minWidth = minWidth + "px";
  31721. var widthOfParent = parentRect.right - parentRect.left;
  31722. var maxX = widthOfParent - minWidth;
  31723. // the x position of the popup depends on RTL or LTR. for normal cases, LTR, we put the child popup
  31724. // to the right, unless it doesn't fit and we then put it to the left. for RTL it's the other way around,
  31725. // we try place it first to the left, and then if not to the right.
  31726. var x;
  31727. if (this.gridOptionsWrapper.isEnableRtl()) {
  31728. // for RTL, try left first
  31729. x = xLeftPosition();
  31730. if (x < 0) {
  31731. x = xRightPosition();
  31732. }
  31733. if (x > maxX) {
  31734. x = 0;
  31735. }
  31736. }
  31737. else {
  31738. // for LTR, try right first
  31739. x = xRightPosition();
  31740. if (x > maxX) {
  31741. x = xLeftPosition();
  31742. }
  31743. if (x < 0) {
  31744. x = 0;
  31745. }
  31746. }
  31747. params.ePopup.style.left = x + "px";
  31748. params.ePopup.style.top = y + "px";
  31749. function xRightPosition() {
  31750. return sourceRect.right - parentRect.left - 2;
  31751. }
  31752. function xLeftPosition() {
  31753. return sourceRect.left - parentRect.left - minWidth;
  31754. }
  31755. };
  31756. PopupService.prototype.positionPopupUnderMouseEvent = function (params) {
  31757. var _a = this.calculatePointerAlign(params.mouseEvent), x = _a.x, y = _a.y;
  31758. var ePopup = params.ePopup, nudgeX = params.nudgeX, nudgeY = params.nudgeY;
  31759. this.positionPopup({
  31760. ePopup: ePopup,
  31761. x: x,
  31762. y: y,
  31763. nudgeX: nudgeX,
  31764. nudgeY: nudgeY,
  31765. keepWithinBounds: true
  31766. });
  31767. this.callPostProcessPopup(params.type, params.ePopup, null, params.mouseEvent, params.column, params.rowNode);
  31768. };
  31769. PopupService.prototype.calculatePointerAlign = function (e) {
  31770. var parentRect = this.getParentRect();
  31771. return {
  31772. x: e.clientX - parentRect.left,
  31773. y: e.clientY - parentRect.top
  31774. };
  31775. };
  31776. PopupService.prototype.positionPopupUnderComponent = function (params) {
  31777. var sourceRect = params.eventSource.getBoundingClientRect();
  31778. var alignSide = params.alignSide || 'left';
  31779. var parentRect = this.getParentRect();
  31780. var x = sourceRect.left - parentRect.left;
  31781. if (alignSide === 'right') {
  31782. x -= (params.ePopup.offsetWidth - sourceRect.width);
  31783. }
  31784. this.positionPopup({
  31785. ePopup: params.ePopup,
  31786. minWidth: params.minWidth,
  31787. minHeight: params.minHeight,
  31788. nudgeX: params.nudgeX,
  31789. nudgeY: params.nudgeY,
  31790. x: x,
  31791. y: sourceRect.top - parentRect.top + sourceRect.height,
  31792. keepWithinBounds: params.keepWithinBounds
  31793. });
  31794. this.callPostProcessPopup(params.type, params.ePopup, params.eventSource, null, params.column, params.rowNode);
  31795. };
  31796. PopupService.prototype.positionPopupOverComponent = function (params) {
  31797. var sourceRect = params.eventSource.getBoundingClientRect();
  31798. var parentRect = this.getParentRect();
  31799. this.positionPopup({
  31800. ePopup: params.ePopup,
  31801. minWidth: params.minWidth,
  31802. nudgeX: params.nudgeX,
  31803. nudgeY: params.nudgeY,
  31804. x: sourceRect.left - parentRect.left,
  31805. y: sourceRect.top - parentRect.top,
  31806. keepWithinBounds: params.keepWithinBounds
  31807. });
  31808. this.callPostProcessPopup(params.type, params.ePopup, params.eventSource, null, params.column, params.rowNode);
  31809. };
  31810. PopupService.prototype.callPostProcessPopup = function (type, ePopup, eventSource, mouseEvent, column, rowNode) {
  31811. var callback = this.gridOptionsWrapper.getPostProcessPopupFunc();
  31812. if (callback) {
  31813. var params = {
  31814. column: column,
  31815. rowNode: rowNode,
  31816. ePopup: ePopup,
  31817. type: type,
  31818. eventSource: eventSource,
  31819. mouseEvent: mouseEvent
  31820. };
  31821. callback(params);
  31822. }
  31823. };
  31824. PopupService.prototype.positionPopup = function (params) {
  31825. var x = params.x;
  31826. var y = params.y;
  31827. if (params.nudgeX) {
  31828. x += params.nudgeX;
  31829. }
  31830. if (params.nudgeY) {
  31831. y += params.nudgeY;
  31832. }
  31833. // if popup is overflowing to the bottom, move it up
  31834. if (params.keepWithinBounds) {
  31835. x = this.keepXWithinBounds(params, x);
  31836. y = this.keepYWithinBounds(params, y);
  31837. }
  31838. params.ePopup.style.left = x + "px";
  31839. params.ePopup.style.top = y + "px";
  31840. };
  31841. PopupService.prototype.getActivePopups = function () {
  31842. return this.popupList.map(function (popup) { return popup.element; });
  31843. };
  31844. PopupService.prototype.getParentRect = function () {
  31845. // subtract the popup parent borders, because popupParent.getBoundingClientRect
  31846. // returns the rect outside the borders, but the 0,0 coordinate for absolute
  31847. // positioning is inside the border, leading the popup to be off by the width
  31848. // of the border
  31849. var popupParent = this.getPopupParent();
  31850. var eDocument = this.gridOptionsWrapper.getDocument();
  31851. if (popupParent === eDocument.body) {
  31852. popupParent = eDocument.documentElement;
  31853. }
  31854. var style = getComputedStyle(popupParent);
  31855. var bounds = popupParent.getBoundingClientRect();
  31856. return {
  31857. top: bounds.top + parseFloat(style.borderTopWidth) || 0,
  31858. left: bounds.left + parseFloat(style.borderLeftWidth) || 0,
  31859. right: bounds.right + parseFloat(style.borderRightWidth) || 0,
  31860. bottom: bounds.bottom + parseFloat(style.borderBottomWidth) || 0,
  31861. };
  31862. };
  31863. PopupService.prototype.keepYWithinBounds = function (params, y) {
  31864. var eDocument = this.gridOptionsWrapper.getDocument();
  31865. var docElement = eDocument.documentElement;
  31866. var popupParent = this.getPopupParent();
  31867. var parentRect = popupParent.getBoundingClientRect();
  31868. var documentRect = eDocument.documentElement.getBoundingClientRect();
  31869. var isBody = popupParent === eDocument.body;
  31870. var minHeight = Math.min(200, parentRect.height);
  31871. var diff = 0;
  31872. if (params.minHeight && params.minHeight < minHeight) {
  31873. minHeight = params.minHeight;
  31874. }
  31875. else if (params.ePopup.offsetHeight > 0) {
  31876. minHeight = params.ePopup.clientHeight;
  31877. diff = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].getAbsoluteHeight(params.ePopup) - minHeight;
  31878. }
  31879. var heightOfParent = isBody ? (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].getAbsoluteHeight(docElement) + docElement.scrollTop) : parentRect.height;
  31880. if (isBody) {
  31881. heightOfParent -= Math.abs(documentRect.top - parentRect.top);
  31882. }
  31883. var maxY = heightOfParent - minHeight - diff;
  31884. return Math.min(Math.max(y, 0), Math.abs(maxY));
  31885. };
  31886. PopupService.prototype.keepXWithinBounds = function (params, x) {
  31887. var eDocument = this.gridOptionsWrapper.getDocument();
  31888. var docElement = eDocument.documentElement;
  31889. var popupParent = this.getPopupParent();
  31890. var parentRect = popupParent.getBoundingClientRect();
  31891. var documentRect = eDocument.documentElement.getBoundingClientRect();
  31892. var isBody = popupParent === eDocument.body;
  31893. var ePopup = params.ePopup;
  31894. var minWidth = Math.min(200, parentRect.width);
  31895. var diff = 0;
  31896. if (params.minWidth && params.minWidth < minWidth) {
  31897. minWidth = params.minWidth;
  31898. }
  31899. else if (ePopup.offsetWidth > 0) {
  31900. minWidth = ePopup.offsetWidth;
  31901. ePopup.style.minWidth = minWidth + "px";
  31902. diff = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].getAbsoluteWidth(ePopup) - minWidth;
  31903. }
  31904. var widthOfParent = isBody ? (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].getAbsoluteWidth(docElement) + docElement.scrollLeft) : parentRect.width;
  31905. if (isBody) {
  31906. widthOfParent -= Math.abs(documentRect.left - parentRect.left);
  31907. }
  31908. var maxX = widthOfParent - minWidth - diff;
  31909. return Math.min(Math.max(x, 0), Math.abs(maxX));
  31910. };
  31911. // adds an element to a div, but also listens to background checking for clicks,
  31912. // so that when the background is clicked, the child is removed again, giving
  31913. // a model look to popups.
  31914. PopupService.prototype.addAsModalPopup = function (eChild, closeOnEsc, closedCallback, click) {
  31915. return this.addPopup(true, eChild, closeOnEsc, closedCallback, click);
  31916. };
  31917. PopupService.prototype.addPopup = function (modal, eChild, closeOnEsc, closedCallback, click, alwaysOnTop) {
  31918. var _this = this;
  31919. var eDocument = this.gridOptionsWrapper.getDocument();
  31920. if (!eDocument) {
  31921. console.warn('ag-grid: could not find the document, document is empty');
  31922. return function () { };
  31923. }
  31924. var pos = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].findIndex(this.popupList, function (popup) { return popup.element === eChild; });
  31925. if (pos !== -1) {
  31926. var popup = this.popupList[pos];
  31927. return popup.hideFunc;
  31928. }
  31929. var ePopupParent = this.getPopupParent();
  31930. // for angular specifically, but shouldn't cause an issue with js or other fw's
  31931. // https://github.com/angular/angular/issues/8563
  31932. ePopupParent.appendChild(eChild);
  31933. eChild.style.top = '0px';
  31934. eChild.style.left = '0px';
  31935. // add env CSS class to child, in case user provided a popup parent, which means
  31936. // theme class may be missing
  31937. var eWrapper = document.createElement('div');
  31938. var theme = this.environment.getTheme().theme;
  31939. if (theme) {
  31940. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(eWrapper, theme);
  31941. }
  31942. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(eWrapper, 'ag-popup');
  31943. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(eChild, this.gridOptionsWrapper.isEnableRtl() ? 'ag-rtl' : 'ag-ltr');
  31944. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(eChild, 'ag-popup-child');
  31945. eWrapper.appendChild(eChild);
  31946. ePopupParent.appendChild(eWrapper);
  31947. if (alwaysOnTop) {
  31948. this.setAlwaysOnTop(eWrapper, true);
  31949. }
  31950. else {
  31951. this.bringPopupToFront(eWrapper);
  31952. }
  31953. var popupHidden = false;
  31954. var hidePopupOnKeyboardEvent = function (event) {
  31955. var key = event.which || event.keyCode;
  31956. if (!eWrapper.contains(document.activeElement)) {
  31957. return;
  31958. }
  31959. switch (key) {
  31960. case _constants__WEBPACK_IMPORTED_MODULE_0__["Constants"].KEY_ESCAPE:
  31961. hidePopup({ keyboardEvent: event });
  31962. }
  31963. };
  31964. var hidePopupOnMouseEvent = function (event) {
  31965. hidePopup({ mouseEvent: event });
  31966. };
  31967. var hidePopupOnTouchEvent = function (event) {
  31968. hidePopup({ touchEvent: event });
  31969. };
  31970. var hidePopup = function (params) {
  31971. if (params === void 0) { params = {}; }
  31972. var mouseEvent = params.mouseEvent, touchEvent = params.touchEvent, keyboardEvent = params.keyboardEvent;
  31973. if (
  31974. // we don't hide popup if the event was on the child, or any
  31975. // children of this child
  31976. _this.isEventFromCurrentPopup({ mouseEvent: mouseEvent, touchEvent: touchEvent }, eChild) ||
  31977. // if the event to close is actually the open event, then ignore it
  31978. _this.isEventSameChainAsOriginalEvent({ originalMouseEvent: click, mouseEvent: mouseEvent, touchEvent: touchEvent }) ||
  31979. // this method should only be called once. the client can have different
  31980. // paths, each one wanting to close, so this method may be called multiple times.
  31981. popupHidden) {
  31982. return;
  31983. }
  31984. popupHidden = true;
  31985. ePopupParent.removeChild(eWrapper);
  31986. eDocument.removeEventListener('keydown', hidePopupOnKeyboardEvent);
  31987. eDocument.removeEventListener('mousedown', hidePopupOnMouseEvent);
  31988. eDocument.removeEventListener('touchstart', hidePopupOnTouchEvent);
  31989. eDocument.removeEventListener('contextmenu', hidePopupOnMouseEvent);
  31990. _this.eventService.removeEventListener(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DRAG_STARTED, hidePopupOnMouseEvent);
  31991. if (closedCallback) {
  31992. closedCallback(mouseEvent || touchEvent || keyboardEvent);
  31993. }
  31994. _this.popupList = _this.popupList.filter(function (popup) { return popup.element !== eChild; });
  31995. };
  31996. // if we add these listeners now, then the current mouse
  31997. // click will be included, which we don't want
  31998. window.setTimeout(function () {
  31999. if (closeOnEsc) {
  32000. eDocument.addEventListener('keydown', hidePopupOnKeyboardEvent);
  32001. }
  32002. if (modal) {
  32003. eDocument.addEventListener('mousedown', hidePopupOnMouseEvent);
  32004. _this.eventService.addEventListener(_events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_DRAG_STARTED, hidePopupOnMouseEvent);
  32005. eDocument.addEventListener('touchstart', hidePopupOnTouchEvent);
  32006. eDocument.addEventListener('contextmenu', hidePopupOnMouseEvent);
  32007. }
  32008. }, 0);
  32009. this.popupList.push({
  32010. element: eChild,
  32011. hideFunc: hidePopup
  32012. });
  32013. return hidePopup;
  32014. };
  32015. PopupService.prototype.isEventFromCurrentPopup = function (params, target) {
  32016. var mouseEvent = params.mouseEvent, touchEvent = params.touchEvent;
  32017. var event = mouseEvent ? mouseEvent : touchEvent;
  32018. if (!event) {
  32019. return false;
  32020. }
  32021. var indexOfThisChild = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].findIndex(this.popupList, function (popup) { return popup.element === target; });
  32022. if (indexOfThisChild === -1) {
  32023. return false;
  32024. }
  32025. for (var i = indexOfThisChild; i < this.popupList.length; i++) {
  32026. var popup = this.popupList[i];
  32027. if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].isElementInEventPath(popup.element, event)) {
  32028. return true;
  32029. }
  32030. }
  32031. // if the user did not write their own Custom Element to be rendered as popup
  32032. // and this component has an additional popup element, they should have the
  32033. // `ag-custom-component-popup` class to be detected as part of the Custom Component
  32034. return this.isElementWithinCustomPopup(event.target);
  32035. };
  32036. PopupService.prototype.isElementWithinCustomPopup = function (el) {
  32037. if (!this.popupList.length) {
  32038. return false;
  32039. }
  32040. while (el && el !== document.body) {
  32041. if (el.classList.contains('ag-custom-component-popup') || el.parentElement === null) {
  32042. return true;
  32043. }
  32044. el = el.parentElement;
  32045. }
  32046. return false;
  32047. };
  32048. // in some browsers, the context menu event can be fired before the click event, which means
  32049. // the context menu event could open the popup, but then the click event closes it straight away.
  32050. PopupService.prototype.isEventSameChainAsOriginalEvent = function (params) {
  32051. var originalMouseEvent = params.originalMouseEvent, mouseEvent = params.mouseEvent, touchEvent = params.touchEvent;
  32052. // we check the coordinates of the event, to see if it's the same event. there is a 1 / 1000 chance that
  32053. // the event is a different event, however that is an edge case that is not very relevant (the user clicking
  32054. // twice on the same location isn't a normal path).
  32055. // event could be mouse event or touch event.
  32056. var mouseEventOrTouch = null;
  32057. if (mouseEvent) {
  32058. // mouse event can be used direction, it has coordinates
  32059. mouseEventOrTouch = mouseEvent;
  32060. }
  32061. else if (touchEvent) {
  32062. // touch event doesn't have coordinates, need it's touch object
  32063. mouseEventOrTouch = touchEvent.touches[0];
  32064. }
  32065. if (mouseEventOrTouch && originalMouseEvent) {
  32066. // for x, allow 4px margin, to cover iPads, where touch (which opens menu) is followed
  32067. // by browser click (when you finger up, touch is interrupted as click in browser)
  32068. var screenX_1 = mouseEvent ? mouseEvent.screenX : 0;
  32069. var screenY_1 = mouseEvent ? mouseEvent.screenY : 0;
  32070. var xMatch = Math.abs(originalMouseEvent.screenX - screenX_1) < 5;
  32071. var yMatch = Math.abs(originalMouseEvent.screenY - screenY_1) < 5;
  32072. if (xMatch && yMatch) {
  32073. return true;
  32074. }
  32075. }
  32076. return false;
  32077. };
  32078. PopupService.prototype.getWrapper = function (ePopup) {
  32079. while (!_utils__WEBPACK_IMPORTED_MODULE_4__["_"].containsClass(ePopup, 'ag-popup') && ePopup.parentElement) {
  32080. ePopup = ePopup.parentElement;
  32081. }
  32082. return _utils__WEBPACK_IMPORTED_MODULE_4__["_"].containsClass(ePopup, 'ag-popup') ? ePopup : null;
  32083. };
  32084. PopupService.prototype.setAlwaysOnTop = function (ePopup, alwaysOnTop) {
  32085. var eWrapper = this.getWrapper(ePopup);
  32086. if (!eWrapper) {
  32087. return;
  32088. }
  32089. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addOrRemoveCssClass(eWrapper, 'ag-always-on-top', !!alwaysOnTop);
  32090. if (alwaysOnTop) {
  32091. this.bringPopupToFront(eWrapper);
  32092. }
  32093. };
  32094. PopupService.prototype.bringPopupToFront = function (ePopup) {
  32095. var parent = this.getPopupParent();
  32096. var popupList = Array.prototype.slice.call(parent.querySelectorAll('.ag-popup'));
  32097. var popupLen = popupList.length;
  32098. var alwaysOnTopList = Array.prototype.slice.call(parent.querySelectorAll('.ag-popup.ag-always-on-top'));
  32099. var onTopLength = alwaysOnTopList.length;
  32100. var eWrapper = this.getWrapper(ePopup);
  32101. if (!eWrapper || popupLen <= 1 || !parent.contains(ePopup)) {
  32102. return;
  32103. }
  32104. var pos = popupList.indexOf(eWrapper);
  32105. if (onTopLength) {
  32106. var isPopupAlwaysOnTop = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].containsClass(eWrapper, 'ag-always-on-top');
  32107. if (isPopupAlwaysOnTop) {
  32108. if (pos !== popupLen - 1) {
  32109. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].last(alwaysOnTopList).insertAdjacentElement('afterend', eWrapper);
  32110. }
  32111. }
  32112. else if (pos !== popupLen - onTopLength - 1) {
  32113. alwaysOnTopList[0].insertAdjacentElement('beforebegin', eWrapper);
  32114. }
  32115. }
  32116. else if (pos !== popupLen - 1) {
  32117. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].last(popupList).insertAdjacentElement('afterend', eWrapper);
  32118. }
  32119. var params = {
  32120. type: 'popupToFront',
  32121. api: this.gridOptionsWrapper.getApi(),
  32122. columnApi: this.gridOptionsWrapper.getColumnApi(),
  32123. eWrapper: eWrapper
  32124. };
  32125. this.eventService.dispatchEvent(params);
  32126. };
  32127. __decorate([
  32128. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  32129. ], PopupService.prototype, "gridOptionsWrapper", void 0);
  32130. __decorate([
  32131. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('environment')
  32132. ], PopupService.prototype, "environment", void 0);
  32133. __decorate([
  32134. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  32135. ], PopupService.prototype, "init", null);
  32136. PopupService = __decorate([
  32137. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('popupService')
  32138. ], PopupService);
  32139. return PopupService;
  32140. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"]));
  32141. /***/ }),
  32142. /* 134 */
  32143. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  32144. "use strict";
  32145. __webpack_require__.r(__webpack_exports__);
  32146. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LoggerFactory", function() { return LoggerFactory; });
  32147. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Logger", function() { return Logger; });
  32148. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  32149. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  32150. /**
  32151. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  32152. * @version v23.2.1
  32153. * @link http://www.ag-grid.com/
  32154. * @license MIT
  32155. */
  32156. var __extends = (undefined && undefined.__extends) || (function () {
  32157. var extendStatics = function (d, b) {
  32158. extendStatics = Object.setPrototypeOf ||
  32159. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  32160. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  32161. return extendStatics(d, b);
  32162. };
  32163. return function (d, b) {
  32164. extendStatics(d, b);
  32165. function __() { this.constructor = d; }
  32166. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  32167. };
  32168. })();
  32169. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  32170. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  32171. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  32172. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  32173. return c > 3 && r && Object.defineProperty(target, key, r), r;
  32174. };
  32175. var __param = (undefined && undefined.__param) || function (paramIndex, decorator) {
  32176. return function (target, key) { decorator(target, key, paramIndex); }
  32177. };
  32178. var LoggerFactory = /** @class */ (function (_super) {
  32179. __extends(LoggerFactory, _super);
  32180. function LoggerFactory() {
  32181. return _super !== null && _super.apply(this, arguments) || this;
  32182. }
  32183. LoggerFactory.prototype.setBeans = function (gridOptionsWrapper) {
  32184. this.logging = gridOptionsWrapper.isDebug();
  32185. };
  32186. LoggerFactory.prototype.create = function (name) {
  32187. return new Logger(name, this.isLogging.bind(this));
  32188. };
  32189. LoggerFactory.prototype.isLogging = function () {
  32190. return this.logging;
  32191. };
  32192. __decorate([
  32193. __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('gridOptionsWrapper'))
  32194. ], LoggerFactory.prototype, "setBeans", null);
  32195. LoggerFactory = __decorate([
  32196. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('loggerFactory')
  32197. ], LoggerFactory);
  32198. return LoggerFactory;
  32199. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  32200. var Logger = /** @class */ (function () {
  32201. function Logger(name, isLoggingFunc) {
  32202. this.name = name;
  32203. this.isLoggingFunc = isLoggingFunc;
  32204. }
  32205. Logger.prototype.isLogging = function () {
  32206. return this.isLoggingFunc();
  32207. };
  32208. Logger.prototype.log = function (message) {
  32209. if (this.isLoggingFunc()) {
  32210. // tslint:disable-next-line
  32211. console.log('ag-Grid.' + this.name + ': ' + message);
  32212. }
  32213. };
  32214. return Logger;
  32215. }());
  32216. /***/ }),
  32217. /* 135 */
  32218. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  32219. "use strict";
  32220. __webpack_require__.r(__webpack_exports__);
  32221. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AutoWidthCalculator", function() { return AutoWidthCalculator; });
  32222. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  32223. /* harmony import */ var _headerRendering_header_headerWrapperComp__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(111);
  32224. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
  32225. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(41);
  32226. /**
  32227. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  32228. * @version v23.2.1
  32229. * @link http://www.ag-grid.com/
  32230. * @license MIT
  32231. */
  32232. var __extends = (undefined && undefined.__extends) || (function () {
  32233. var extendStatics = function (d, b) {
  32234. extendStatics = Object.setPrototypeOf ||
  32235. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  32236. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  32237. return extendStatics(d, b);
  32238. };
  32239. return function (d, b) {
  32240. extendStatics(d, b);
  32241. function __() { this.constructor = d; }
  32242. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  32243. };
  32244. })();
  32245. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  32246. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  32247. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  32248. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  32249. return c > 3 && r && Object.defineProperty(target, key, r), r;
  32250. };
  32251. var AutoWidthCalculator = /** @class */ (function (_super) {
  32252. __extends(AutoWidthCalculator, _super);
  32253. function AutoWidthCalculator() {
  32254. return _super !== null && _super.apply(this, arguments) || this;
  32255. }
  32256. AutoWidthCalculator.prototype.registerGridComp = function (gridPanel) {
  32257. this.gridPanel = gridPanel;
  32258. };
  32259. AutoWidthCalculator.prototype.registerHeaderRootComp = function (headerRootComp) {
  32260. this.headerRootComp = headerRootComp;
  32261. };
  32262. // this is the trick: we create a dummy container and clone all the cells
  32263. // into the dummy, then check the dummy's width. then destroy the dummy
  32264. // as we don't need it any more.
  32265. // drawback: only the cells visible on the screen are considered
  32266. AutoWidthCalculator.prototype.getPreferredWidthForColumn = function (column, skipHeader) {
  32267. var eHeaderCell = this.getHeaderCellForColumn(column);
  32268. // cell isn't visible
  32269. if (!eHeaderCell) {
  32270. return -1;
  32271. }
  32272. var eDummyContainer = document.createElement('span');
  32273. // position fixed, so it isn't restricted to the boundaries of the parent
  32274. eDummyContainer.style.position = 'fixed';
  32275. // we put the dummy into the body container, so it will inherit all the
  32276. // css styles that the real cells are inheriting
  32277. var eBodyContainer = this.gridPanel.getCenterContainer();
  32278. eBodyContainer.appendChild(eDummyContainer);
  32279. // get all the cells that are currently displayed (this only brings back
  32280. // rendered cells, rows not rendered due to row visualisation will not be here)
  32281. this.putRowCellsIntoDummyContainer(column, eDummyContainer);
  32282. if (!skipHeader) {
  32283. // we only consider the lowest level cell, not the group cell. in 99% of the time, this
  32284. // will be enough. if we consider groups, then it gets too complicated for what it's worth,
  32285. // as the groups can span columns and this class only considers one column at a time.
  32286. this.cloneItemIntoDummy(eHeaderCell, eDummyContainer);
  32287. }
  32288. // at this point, all the clones are lined up vertically with natural widths. the dummy
  32289. // container will have a width wide enough just to fit the largest.
  32290. var dummyContainerWidth = eDummyContainer.offsetWidth;
  32291. // we are finished with the dummy container, so get rid of it
  32292. eBodyContainer.removeChild(eDummyContainer);
  32293. // we add padding as I found sometimes the gui still put '...' after some of the texts. so the
  32294. // user can configure the grid to add a few more pixels after the calculated width
  32295. var autoSizePadding = this.gridOptionsWrapper.getAutoSizePadding();
  32296. return dummyContainerWidth + autoSizePadding;
  32297. };
  32298. AutoWidthCalculator.prototype.getHeaderCellForColumn = function (column) {
  32299. var comp = null;
  32300. // find the rendered header cell
  32301. this.headerRootComp.forEachHeaderElement(function (headerElement) {
  32302. if (headerElement instanceof _headerRendering_header_headerWrapperComp__WEBPACK_IMPORTED_MODULE_1__["HeaderWrapperComp"]) {
  32303. var headerWrapperComp = headerElement;
  32304. if (headerWrapperComp.getColumn() === column) {
  32305. comp = headerWrapperComp;
  32306. }
  32307. }
  32308. });
  32309. return comp ? comp.getGui() : null;
  32310. };
  32311. AutoWidthCalculator.prototype.putRowCellsIntoDummyContainer = function (column, eDummyContainer) {
  32312. var _this = this;
  32313. var eCells = this.rowRenderer.getAllCellsForColumn(column);
  32314. eCells.forEach(function (eCell) { return _this.cloneItemIntoDummy(eCell, eDummyContainer); });
  32315. };
  32316. AutoWidthCalculator.prototype.cloneItemIntoDummy = function (eCell, eDummyContainer) {
  32317. // make a deep clone of the cell
  32318. var eCellClone = eCell.cloneNode(true);
  32319. // the original has a fixed width, we remove this to allow the natural width based on content
  32320. eCellClone.style.width = '';
  32321. // the original has position = absolute, we need to remove this so it's positioned normally
  32322. eCellClone.style.position = 'static';
  32323. eCellClone.style.left = '';
  32324. // we put the cell into a containing div, as otherwise the cells would just line up
  32325. // on the same line, standard flow layout, by putting them into divs, they are laid
  32326. // out one per line
  32327. var eCloneParent = document.createElement('div');
  32328. if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].containsClass(eCellClone, 'ag-header-cell')) {
  32329. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(eCloneParent, 'ag-header');
  32330. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(eCloneParent, 'ag-header-row');
  32331. eCloneParent.style.position = 'static';
  32332. }
  32333. // table-row, so that each cell is on a row. i also tried display='block', but this
  32334. // didn't work in IE
  32335. eCloneParent.style.display = 'table-row';
  32336. // the twig on the branch, the branch on the tree, the tree in the hole,
  32337. // the hole in the bog, the bog in the clone, the clone in the parent,
  32338. // the parent in the dummy, and the dummy down in the vall-e-ooo, OOOOOOOOO! Oh row the rattling bog....
  32339. eCloneParent.appendChild(eCellClone);
  32340. eDummyContainer.appendChild(eCloneParent);
  32341. };
  32342. __decorate([
  32343. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer')
  32344. ], AutoWidthCalculator.prototype, "rowRenderer", void 0);
  32345. __decorate([
  32346. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  32347. ], AutoWidthCalculator.prototype, "gridOptionsWrapper", void 0);
  32348. AutoWidthCalculator = __decorate([
  32349. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('autoWidthCalculator')
  32350. ], AutoWidthCalculator);
  32351. return AutoWidthCalculator;
  32352. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"]));
  32353. /***/ }),
  32354. /* 136 */
  32355. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  32356. "use strict";
  32357. __webpack_require__.r(__webpack_exports__);
  32358. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HorizontalResizeService", function() { return HorizontalResizeService; });
  32359. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  32360. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  32361. /**
  32362. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  32363. * @version v23.2.1
  32364. * @link http://www.ag-grid.com/
  32365. * @license MIT
  32366. */
  32367. var __extends = (undefined && undefined.__extends) || (function () {
  32368. var extendStatics = function (d, b) {
  32369. extendStatics = Object.setPrototypeOf ||
  32370. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  32371. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  32372. return extendStatics(d, b);
  32373. };
  32374. return function (d, b) {
  32375. extendStatics(d, b);
  32376. function __() { this.constructor = d; }
  32377. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  32378. };
  32379. })();
  32380. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  32381. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  32382. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  32383. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  32384. return c > 3 && r && Object.defineProperty(target, key, r), r;
  32385. };
  32386. var HorizontalResizeService = /** @class */ (function (_super) {
  32387. __extends(HorizontalResizeService, _super);
  32388. function HorizontalResizeService() {
  32389. return _super !== null && _super.apply(this, arguments) || this;
  32390. }
  32391. HorizontalResizeService.prototype.addResizeBar = function (params) {
  32392. var _this = this;
  32393. var dragSource = {
  32394. dragStartPixels: params.dragStartPixels || 0,
  32395. eElement: params.eResizeBar,
  32396. onDragStart: this.onDragStart.bind(this, params),
  32397. onDragStop: this.onDragStop.bind(this, params),
  32398. onDragging: this.onDragging.bind(this, params)
  32399. };
  32400. this.dragService.addDragSource(dragSource, true);
  32401. // we pass remove func back to the caller, so call can tell us when they
  32402. // are finished, and then we remove the listener from the drag source
  32403. var finishedWithResizeFunc = function () { return _this.dragService.removeDragSource(dragSource); };
  32404. return finishedWithResizeFunc;
  32405. };
  32406. HorizontalResizeService.prototype.onDragStart = function (params, mouseEvent) {
  32407. this.dragStartX = mouseEvent.clientX;
  32408. this.setResizeIcons();
  32409. var shiftKey = mouseEvent instanceof MouseEvent ? mouseEvent.shiftKey === true : false;
  32410. params.onResizeStart(shiftKey);
  32411. };
  32412. HorizontalResizeService.prototype.setResizeIcons = function () {
  32413. this.oldBodyCursor = this.eGridDiv.style.cursor;
  32414. this.oldMsUserSelect = this.eGridDiv.style.msUserSelect;
  32415. this.oldWebkitUserSelect = this.eGridDiv.style.webkitUserSelect;
  32416. // change the body cursor, so when drag moves out of the drag bar, the cursor is still 'resize' (or 'move'
  32417. this.eGridDiv.style.cursor = 'ew-resize';
  32418. // we don't want text selection outside the grid (otherwise it looks weird as text highlights when we move)
  32419. this.eGridDiv.style.msUserSelect = 'none';
  32420. this.eGridDiv.style.webkitUserSelect = 'none';
  32421. };
  32422. HorizontalResizeService.prototype.onDragStop = function (params, mouseEvent) {
  32423. params.onResizeEnd(this.resizeAmount);
  32424. this.resetIcons();
  32425. };
  32426. HorizontalResizeService.prototype.resetIcons = function () {
  32427. // we don't want text selection outside the grid (otherwise it looks weird as text highlights when we move)
  32428. this.eGridDiv.style.cursor = this.oldBodyCursor;
  32429. this.eGridDiv.style.msUserSelect = this.oldMsUserSelect;
  32430. this.eGridDiv.style.webkitUserSelect = this.oldWebkitUserSelect;
  32431. };
  32432. HorizontalResizeService.prototype.onDragging = function (params, mouseEvent) {
  32433. this.resizeAmount = mouseEvent.clientX - this.dragStartX;
  32434. params.onResizing(this.resizeAmount);
  32435. };
  32436. __decorate([
  32437. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('dragService')
  32438. ], HorizontalResizeService.prototype, "dragService", void 0);
  32439. __decorate([
  32440. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('eGridDiv')
  32441. ], HorizontalResizeService.prototype, "eGridDiv", void 0);
  32442. HorizontalResizeService = __decorate([
  32443. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('horizontalResizeService')
  32444. ], HorizontalResizeService);
  32445. return HorizontalResizeService;
  32446. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  32447. /***/ }),
  32448. /* 137 */
  32449. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  32450. "use strict";
  32451. __webpack_require__.r(__webpack_exports__);
  32452. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridCore", function() { return GridCore; });
  32453. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  32454. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57);
  32455. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43);
  32456. /* harmony import */ var _entities_sideBar__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(52);
  32457. /* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(38);
  32458. /* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(39);
  32459. /* harmony import */ var _widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(117);
  32460. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(7);
  32461. /**
  32462. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  32463. * @version v23.2.1
  32464. * @link http://www.ag-grid.com/
  32465. * @license MIT
  32466. */
  32467. var __extends = (undefined && undefined.__extends) || (function () {
  32468. var extendStatics = function (d, b) {
  32469. extendStatics = Object.setPrototypeOf ||
  32470. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  32471. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  32472. return extendStatics(d, b);
  32473. };
  32474. return function (d, b) {
  32475. extendStatics(d, b);
  32476. function __() { this.constructor = d; }
  32477. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  32478. };
  32479. })();
  32480. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  32481. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  32482. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  32483. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  32484. return c > 3 && r && Object.defineProperty(target, key, r), r;
  32485. };
  32486. var GridCore = /** @class */ (function (_super) {
  32487. __extends(GridCore, _super);
  32488. function GridCore() {
  32489. return _super !== null && _super.apply(this, arguments) || this;
  32490. }
  32491. GridCore.prototype.postConstruct = function () {
  32492. var _this = this;
  32493. this.logger = this.loggerFactory.create('GridCore');
  32494. var template = this.createTemplate();
  32495. this.setTemplate(template);
  32496. // register with services that need grid core
  32497. [
  32498. this.gridApi,
  32499. this.rowRenderer,
  32500. this.popupService,
  32501. this.focusController
  32502. ].forEach(function (service) { return service.registerGridCore(_this); });
  32503. if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].ClipboardModule)) {
  32504. this.clipboardService.registerGridCore(this);
  32505. }
  32506. this.gridOptionsWrapper.addLayoutElement(this.getGui());
  32507. this.eGridDiv.appendChild(this.getGui());
  32508. this.addDestroyFunc(function () {
  32509. _this.eGridDiv.removeChild(_this.getGui());
  32510. });
  32511. // if using angular, watch for quickFilter changes
  32512. if (this.$scope) {
  32513. var quickFilterUnregisterFn = this.$scope.$watch(this.quickFilterOnScope, function (newFilter) { return _this.filterManager.setQuickFilter(newFilter); });
  32514. this.addDestroyFunc(quickFilterUnregisterFn);
  32515. }
  32516. // important to set rtl before doLayout, as setting the RTL class impacts the scroll position,
  32517. // which doLayout indirectly depends on
  32518. this.addRtlSupport();
  32519. this.logger.log('ready');
  32520. this.gridOptionsWrapper.addLayoutElement(this.eRootWrapperBody);
  32521. var unsubscribeFromResize = this.resizeObserverService.observeResize(this.eGridDiv, this.onGridSizeChanged.bind(this));
  32522. this.addDestroyFunc(function () { return unsubscribeFromResize(); });
  32523. var eGui = this.getGui();
  32524. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_KEYBOARD_FOCUS, function () {
  32525. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(eGui, 'ag-keyboard-focus');
  32526. });
  32527. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_MOUSE_FOCUS, function () {
  32528. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].removeCssClass(eGui, 'ag-keyboard-focus');
  32529. });
  32530. _super.prototype.postConstruct.call(this);
  32531. };
  32532. GridCore.prototype.getFocusableElement = function () {
  32533. return this.eRootWrapperBody;
  32534. };
  32535. GridCore.prototype.createTemplate = function () {
  32536. var sideBarModuleLoaded = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].SideBarModule);
  32537. var statusBarModuleLoaded = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].StatusBarModule);
  32538. var rowGroupingLoaded = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].RowGroupingModule);
  32539. var enterpriseCoreLoaded = _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].EnterpriseCoreModule);
  32540. var dropZones = rowGroupingLoaded ? '<ag-grid-header-drop-zones></ag-grid-header-drop-zones>' : '';
  32541. var sideBar = sideBarModuleLoaded ? '<ag-side-bar ref="sideBar"></ag-side-bar>' : '';
  32542. var statusBar = statusBarModuleLoaded ? '<ag-status-bar ref="statusBar"></ag-status-bar>' : '';
  32543. var watermark = enterpriseCoreLoaded ? '<ag-watermark></ag-watermark>' : '';
  32544. var template = "<div ref=\"eRootWrapper\" class=\"ag-root-wrapper\">\n " + dropZones + "\n <div class=\"ag-root-wrapper-body\" ref=\"rootWrapperBody\">\n <ag-grid-comp ref=\"gridPanel\"></ag-grid-comp>\n " + sideBar + "\n </div>\n " + statusBar + "\n <ag-pagination></ag-pagination>\n " + watermark + "\n </div>";
  32545. return template;
  32546. };
  32547. GridCore.prototype.isFocusableContainer = function () {
  32548. return true;
  32549. };
  32550. GridCore.prototype.getFocusableContainers = function () {
  32551. var focusableContainers = [
  32552. this.gridPanel.getGui()
  32553. ];
  32554. if (this.sideBarComp) {
  32555. focusableContainers.push(this.sideBarComp.getGui());
  32556. }
  32557. return focusableContainers.filter(function (el) { return _utils__WEBPACK_IMPORTED_MODULE_7__["_"].isVisible(el); });
  32558. };
  32559. GridCore.prototype.focusNextInnerContainer = function (backwards) {
  32560. var focusableContainers = this.getFocusableContainers();
  32561. var idxWithFocus = _utils__WEBPACK_IMPORTED_MODULE_7__["_"].findIndex(focusableContainers, function (container) { return container.contains(document.activeElement); });
  32562. var nextIdx = idxWithFocus + (backwards ? -1 : 1);
  32563. if (nextIdx < 0 || nextIdx >= focusableContainers.length) {
  32564. return false;
  32565. }
  32566. if (nextIdx === 0) {
  32567. return this.focusGridHeader();
  32568. }
  32569. return this.focusController.focusFirstFocusableElement(focusableContainers[nextIdx]);
  32570. };
  32571. GridCore.prototype.focusInnerElement = function (fromBottom) {
  32572. var focusableContainers = this.getFocusableContainers();
  32573. if (fromBottom && focusableContainers.length > 1) {
  32574. return this.focusController.focusFirstFocusableElement(_utils__WEBPACK_IMPORTED_MODULE_7__["_"].last(focusableContainers));
  32575. }
  32576. return this.focusGridHeader();
  32577. };
  32578. GridCore.prototype.focusGridHeader = function () {
  32579. var firstColumn = this.columnController.getAllDisplayedColumns()[0];
  32580. if (!firstColumn) {
  32581. return false;
  32582. }
  32583. if (firstColumn.getParent()) {
  32584. firstColumn = this.columnController.getColumnGroupAtLevel(firstColumn, 0);
  32585. }
  32586. this.focusController.focusHeaderPosition({
  32587. headerRowIndex: 0,
  32588. column: firstColumn
  32589. });
  32590. return true;
  32591. };
  32592. GridCore.prototype.onGridSizeChanged = function () {
  32593. var event = {
  32594. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_GRID_SIZE_CHANGED,
  32595. api: this.gridApi,
  32596. columnApi: this.columnApi,
  32597. clientWidth: this.eGridDiv.clientWidth,
  32598. clientHeight: this.eGridDiv.clientHeight
  32599. };
  32600. this.eventService.dispatchEvent(event);
  32601. };
  32602. GridCore.prototype.addRtlSupport = function () {
  32603. var cssClass = this.gridOptionsWrapper.isEnableRtl() ? 'ag-rtl' : 'ag-ltr';
  32604. _utils__WEBPACK_IMPORTED_MODULE_7__["_"].addCssClass(this.getGui(), cssClass);
  32605. };
  32606. GridCore.prototype.getRootGui = function () {
  32607. return this.getGui();
  32608. };
  32609. GridCore.prototype.isSideBarVisible = function () {
  32610. if (!this.sideBarComp) {
  32611. return false;
  32612. }
  32613. return this.sideBarComp.isDisplayed();
  32614. };
  32615. GridCore.prototype.setSideBarVisible = function (show) {
  32616. if (!this.sideBarComp) {
  32617. if (show) {
  32618. console.warn('ag-Grid: sideBar is not loaded');
  32619. }
  32620. return;
  32621. }
  32622. this.sideBarComp.setDisplayed(show);
  32623. };
  32624. GridCore.prototype.setSideBarPosition = function (position) {
  32625. if (!this.sideBarComp) {
  32626. console.warn('ag-Grid: sideBar is not loaded');
  32627. return;
  32628. }
  32629. this.sideBarComp.setSideBarPosition(position);
  32630. };
  32631. GridCore.prototype.closeToolPanel = function () {
  32632. if (!this.sideBarComp) {
  32633. console.warn('ag-Grid: toolPanel is only available in ag-Grid Enterprise');
  32634. return;
  32635. }
  32636. this.sideBarComp.close();
  32637. };
  32638. GridCore.prototype.getSideBar = function () {
  32639. return this.gridOptions.sideBar;
  32640. };
  32641. GridCore.prototype.getToolPanelInstance = function (key) {
  32642. if (!this.sideBarComp) {
  32643. console.warn('ag-Grid: toolPanel is only available in ag-Grid Enterprise');
  32644. return;
  32645. }
  32646. return this.sideBarComp.getToolPanelInstance(key);
  32647. };
  32648. GridCore.prototype.refreshSideBar = function () {
  32649. if (this.sideBarComp) {
  32650. this.sideBarComp.refresh();
  32651. }
  32652. };
  32653. GridCore.prototype.setSideBar = function (def) {
  32654. if (!this.sideBarComp) {
  32655. return;
  32656. }
  32657. this.eRootWrapperBody.removeChild(this.sideBarComp.getGui());
  32658. this.gridOptions.sideBar = _entities_sideBar__WEBPACK_IMPORTED_MODULE_3__["SideBarDefParser"].parse(def);
  32659. this.sideBarComp.reset();
  32660. this.eRootWrapperBody.appendChild(this.sideBarComp.getGui());
  32661. };
  32662. GridCore.prototype.getOpenedToolPanel = function () {
  32663. if (!this.sideBarComp) {
  32664. return null;
  32665. }
  32666. return this.sideBarComp.openedItem();
  32667. };
  32668. GridCore.prototype.openToolPanel = function (key) {
  32669. if (!this.sideBarComp) {
  32670. console.warn('ag-Grid: toolPanel is only available in ag-Grid Enterprise');
  32671. return;
  32672. }
  32673. this.sideBarComp.openToolPanel(key);
  32674. };
  32675. GridCore.prototype.isToolPanelShowing = function () {
  32676. return this.sideBarComp.isToolPanelShowing();
  32677. };
  32678. GridCore.prototype.destroy = function () {
  32679. this.logger.log('Grid DOM removed');
  32680. _super.prototype.destroy.call(this);
  32681. };
  32682. // Valid values for position are bottom, middle and top
  32683. GridCore.prototype.ensureNodeVisible = function (comparator, position) {
  32684. if (position === void 0) { position = null; }
  32685. if (this.doingVirtualPaging) {
  32686. throw new Error('Cannot use ensureNodeVisible when doing virtual paging, as we cannot check rows that are not in memory');
  32687. }
  32688. // look for the node index we want to display
  32689. var rowCount = this.rowModel.getRowCount();
  32690. var comparatorIsAFunction = typeof comparator === 'function';
  32691. var indexToSelect = -1;
  32692. // go through all the nodes, find the one we want to show
  32693. for (var i = 0; i < rowCount; i++) {
  32694. var node = this.rowModel.getRow(i);
  32695. if (comparatorIsAFunction) {
  32696. if (comparator(node)) {
  32697. indexToSelect = i;
  32698. break;
  32699. }
  32700. }
  32701. else {
  32702. // check object equality against node and data
  32703. if (comparator === node || comparator === node.data) {
  32704. indexToSelect = i;
  32705. break;
  32706. }
  32707. }
  32708. }
  32709. if (indexToSelect >= 0) {
  32710. this.gridPanel.ensureIndexVisible(indexToSelect, position);
  32711. }
  32712. };
  32713. __decorate([
  32714. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptions')
  32715. ], GridCore.prototype, "gridOptions", void 0);
  32716. __decorate([
  32717. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  32718. ], GridCore.prototype, "gridOptionsWrapper", void 0);
  32719. __decorate([
  32720. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel')
  32721. ], GridCore.prototype, "rowModel", void 0);
  32722. __decorate([
  32723. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('resizeObserverService')
  32724. ], GridCore.prototype, "resizeObserverService", void 0);
  32725. __decorate([
  32726. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer')
  32727. ], GridCore.prototype, "rowRenderer", void 0);
  32728. __decorate([
  32729. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager')
  32730. ], GridCore.prototype, "filterManager", void 0);
  32731. __decorate([
  32732. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('eGridDiv')
  32733. ], GridCore.prototype, "eGridDiv", void 0);
  32734. __decorate([
  32735. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('$scope')
  32736. ], GridCore.prototype, "$scope", void 0);
  32737. __decorate([
  32738. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('quickFilterOnScope')
  32739. ], GridCore.prototype, "quickFilterOnScope", void 0);
  32740. __decorate([
  32741. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('popupService')
  32742. ], GridCore.prototype, "popupService", void 0);
  32743. __decorate([
  32744. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController')
  32745. ], GridCore.prototype, "columnController", void 0);
  32746. __decorate([
  32747. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('loggerFactory')
  32748. ], GridCore.prototype, "loggerFactory", void 0);
  32749. __decorate([
  32750. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi')
  32751. ], GridCore.prototype, "columnApi", void 0);
  32752. __decorate([
  32753. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi')
  32754. ], GridCore.prototype, "gridApi", void 0);
  32755. __decorate([
  32756. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])('clipboardService')
  32757. ], GridCore.prototype, "clipboardService", void 0);
  32758. __decorate([
  32759. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('gridPanel')
  32760. ], GridCore.prototype, "gridPanel", void 0);
  32761. __decorate([
  32762. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('sideBar')
  32763. ], GridCore.prototype, "sideBarComp", void 0);
  32764. __decorate([
  32765. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('rootWrapperBody')
  32766. ], GridCore.prototype, "eRootWrapperBody", void 0);
  32767. return GridCore;
  32768. }(_widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_6__["ManagedFocusComponent"]));
  32769. /***/ }),
  32770. /* 138 */
  32771. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  32772. "use strict";
  32773. __webpack_require__.r(__webpack_exports__);
  32774. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "StandardMenuFactory", function() { return StandardMenuFactory; });
  32775. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  32776. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  32777. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25);
  32778. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  32779. /**
  32780. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  32781. * @version v23.2.1
  32782. * @link http://www.ag-grid.com/
  32783. * @license MIT
  32784. */
  32785. var __extends = (undefined && undefined.__extends) || (function () {
  32786. var extendStatics = function (d, b) {
  32787. extendStatics = Object.setPrototypeOf ||
  32788. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  32789. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  32790. return extendStatics(d, b);
  32791. };
  32792. return function (d, b) {
  32793. extendStatics(d, b);
  32794. function __() { this.constructor = d; }
  32795. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  32796. };
  32797. })();
  32798. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  32799. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  32800. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  32801. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  32802. return c > 3 && r && Object.defineProperty(target, key, r), r;
  32803. };
  32804. var StandardMenuFactory = /** @class */ (function (_super) {
  32805. __extends(StandardMenuFactory, _super);
  32806. function StandardMenuFactory() {
  32807. return _super !== null && _super.apply(this, arguments) || this;
  32808. }
  32809. StandardMenuFactory.prototype.hideActiveMenu = function () {
  32810. if (this.hidePopup) {
  32811. this.hidePopup();
  32812. }
  32813. };
  32814. StandardMenuFactory.prototype.showMenuAfterMouseEvent = function (column, mouseEvent) {
  32815. var _this = this;
  32816. this.showPopup(column, function (eMenu) {
  32817. _this.popupService.positionPopupUnderMouseEvent({
  32818. column: column,
  32819. type: 'columnMenu',
  32820. mouseEvent: mouseEvent,
  32821. ePopup: eMenu
  32822. });
  32823. }, mouseEvent.target);
  32824. };
  32825. StandardMenuFactory.prototype.showMenuAfterButtonClick = function (column, eventSource) {
  32826. var _this = this;
  32827. this.showPopup(column, function (eMenu) {
  32828. _this.popupService.positionPopupUnderComponent({
  32829. type: 'columnMenu',
  32830. eventSource: eventSource,
  32831. ePopup: eMenu,
  32832. keepWithinBounds: true,
  32833. column: column
  32834. });
  32835. }, eventSource);
  32836. };
  32837. StandardMenuFactory.prototype.showPopup = function (column, positionCallback, eventSource) {
  32838. var _this = this;
  32839. var filterWrapper = this.filterManager.getOrCreateFilterWrapper(column, 'COLUMN_MENU');
  32840. var eMenu = document.createElement('div');
  32841. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addCssClass(eMenu, 'ag-menu');
  32842. this.tabListener = this.addManagedListener(eMenu, 'keydown', function (e) { return _this.trapFocusWithin(e, eMenu); });
  32843. filterWrapper.guiPromise.then(function (gui) { return eMenu.appendChild(gui); });
  32844. var hidePopup;
  32845. var bodyScrollListener = function (event) {
  32846. // if h scroll, popup is no longer over the column
  32847. if (event.direction === 'horizontal') {
  32848. hidePopup();
  32849. }
  32850. };
  32851. this.eventService.addEventListener('bodyScroll', bodyScrollListener);
  32852. var closedCallback = function (e) {
  32853. _this.eventService.removeEventListener('bodyScroll', bodyScrollListener);
  32854. column.setMenuVisible(false, 'contextMenu');
  32855. var isKeyboardEvent = e instanceof KeyboardEvent;
  32856. if (_this.tabListener) {
  32857. _this.tabListener = _this.tabListener();
  32858. }
  32859. if (isKeyboardEvent && eventSource && _utils__WEBPACK_IMPORTED_MODULE_3__["_"].isVisible(eventSource)) {
  32860. var focusableEl = _this.focusController.findTabbableParent(eventSource);
  32861. if (focusableEl) {
  32862. focusableEl.focus();
  32863. }
  32864. }
  32865. };
  32866. // need to show filter before positioning, as only after filter
  32867. // is visible can we find out what the width of it is
  32868. hidePopup = this.popupService.addAsModalPopup(eMenu, true, closedCallback);
  32869. positionCallback(eMenu);
  32870. filterWrapper.filterPromise.then(function (filter) {
  32871. if (filter.afterGuiAttached) {
  32872. var params = {
  32873. hidePopup: hidePopup
  32874. };
  32875. filter.afterGuiAttached(params);
  32876. }
  32877. });
  32878. this.hidePopup = hidePopup;
  32879. column.setMenuVisible(true, 'contextMenu');
  32880. };
  32881. StandardMenuFactory.prototype.trapFocusWithin = function (e, menu) {
  32882. if (e.keyCode !== _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_TAB) {
  32883. return;
  32884. }
  32885. if (this.focusController.findNextFocusableElement(menu, false, e.shiftKey)) {
  32886. return;
  32887. }
  32888. e.preventDefault();
  32889. if (e.shiftKey) {
  32890. this.focusController.focusLastFocusableElement(menu);
  32891. }
  32892. else {
  32893. this.focusController.focusFirstFocusableElement(menu);
  32894. }
  32895. };
  32896. StandardMenuFactory.prototype.isMenuEnabled = function (column) {
  32897. // for standard, we show menu if filter is enabled, and the menu is not suppressed
  32898. return column.isFilterAllowed();
  32899. };
  32900. __decorate([
  32901. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager')
  32902. ], StandardMenuFactory.prototype, "filterManager", void 0);
  32903. __decorate([
  32904. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('popupService')
  32905. ], StandardMenuFactory.prototype, "popupService", void 0);
  32906. __decorate([
  32907. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusController')
  32908. ], StandardMenuFactory.prototype, "focusController", void 0);
  32909. StandardMenuFactory = __decorate([
  32910. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('menuFactory')
  32911. ], StandardMenuFactory);
  32912. return StandardMenuFactory;
  32913. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  32914. /***/ }),
  32915. /* 139 */
  32916. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  32917. "use strict";
  32918. __webpack_require__.r(__webpack_exports__);
  32919. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DragService", function() { return DragService; });
  32920. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  32921. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43);
  32922. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
  32923. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(41);
  32924. /**
  32925. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  32926. * @version v23.2.1
  32927. * @link http://www.ag-grid.com/
  32928. * @license MIT
  32929. */
  32930. var __extends = (undefined && undefined.__extends) || (function () {
  32931. var extendStatics = function (d, b) {
  32932. extendStatics = Object.setPrototypeOf ||
  32933. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  32934. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  32935. return extendStatics(d, b);
  32936. };
  32937. return function (d, b) {
  32938. extendStatics(d, b);
  32939. function __() { this.constructor = d; }
  32940. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  32941. };
  32942. })();
  32943. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  32944. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  32945. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  32946. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  32947. return c > 3 && r && Object.defineProperty(target, key, r), r;
  32948. };
  32949. /** Adds drag listening onto an element. In ag-Grid this is used twice, first is resizing columns,
  32950. * second is moving the columns and column groups around (ie the 'drag' part of Drag and Drop. */
  32951. var DragService = /** @class */ (function (_super) {
  32952. __extends(DragService, _super);
  32953. function DragService() {
  32954. var _this = _super !== null && _super.apply(this, arguments) || this;
  32955. _this.dragEndFunctions = [];
  32956. _this.dragSources = [];
  32957. return _this;
  32958. }
  32959. DragService.prototype.init = function () {
  32960. this.logger = this.loggerFactory.create('DragService');
  32961. };
  32962. DragService.prototype.removeAllListeners = function () {
  32963. this.dragSources.forEach(this.removeListener.bind(this));
  32964. this.dragSources.length = 0;
  32965. };
  32966. DragService.prototype.removeListener = function (dragSourceAndListener) {
  32967. var element = dragSourceAndListener.dragSource.eElement;
  32968. var mouseDownListener = dragSourceAndListener.mouseDownListener;
  32969. element.removeEventListener('mousedown', mouseDownListener);
  32970. // remove touch listener only if it exists
  32971. if (dragSourceAndListener.touchEnabled) {
  32972. var touchStartListener = dragSourceAndListener.touchStartListener;
  32973. element.removeEventListener('touchstart', touchStartListener, { passive: true });
  32974. }
  32975. };
  32976. DragService.prototype.removeDragSource = function (params) {
  32977. var dragSourceAndListener = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].find(this.dragSources, function (item) { return item.dragSource === params; });
  32978. if (!dragSourceAndListener) {
  32979. return;
  32980. }
  32981. this.removeListener(dragSourceAndListener);
  32982. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].removeFromArray(this.dragSources, dragSourceAndListener);
  32983. };
  32984. DragService.prototype.setNoSelectToBody = function (noSelect) {
  32985. var eDocument = this.gridOptionsWrapper.getDocument();
  32986. var eBody = eDocument.querySelector('body');
  32987. if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(eBody)) {
  32988. // when we drag the mouse in ag-Grid, this class gets added / removed from the body, so that
  32989. // the mouse isn't selecting text when dragging.
  32990. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addOrRemoveCssClass(eBody, 'ag-unselectable', noSelect);
  32991. }
  32992. };
  32993. DragService.prototype.addDragSource = function (params, includeTouch) {
  32994. if (includeTouch === void 0) { includeTouch = false; }
  32995. var mouseListener = this.onMouseDown.bind(this, params);
  32996. params.eElement.addEventListener('mousedown', mouseListener);
  32997. var touchListener = null;
  32998. var suppressTouch = this.gridOptionsWrapper.isSuppressTouch();
  32999. if (includeTouch && !suppressTouch) {
  33000. touchListener = this.onTouchStart.bind(this, params);
  33001. params.eElement.addEventListener('touchstart', touchListener, { passive: false });
  33002. }
  33003. this.dragSources.push({
  33004. dragSource: params,
  33005. mouseDownListener: mouseListener,
  33006. touchStartListener: touchListener,
  33007. touchEnabled: includeTouch
  33008. });
  33009. };
  33010. // gets called whenever mouse down on any drag source
  33011. DragService.prototype.onTouchStart = function (params, touchEvent) {
  33012. var _this = this;
  33013. this.currentDragParams = params;
  33014. this.dragging = false;
  33015. var touch = touchEvent.touches[0];
  33016. this.touchLastTime = touch;
  33017. this.touchStart = touch;
  33018. if (touchEvent.cancelable) {
  33019. touchEvent.preventDefault();
  33020. }
  33021. var touchMoveEvent = function (e) { return _this.onTouchMove(e, params.eElement); };
  33022. var touchEndEvent = function (e) { return _this.onTouchUp(e, params.eElement); };
  33023. var target = params.eElement;
  33024. var events = [
  33025. { target: target, type: 'touchmove', listener: touchMoveEvent, options: { passive: true } },
  33026. { target: target, type: 'touchend', listener: touchEndEvent, options: { passive: true } },
  33027. { target: target, type: 'touchcancel', listener: touchEndEvent, options: { passive: true } }
  33028. ];
  33029. // temporally add these listeners, for the duration of the drag
  33030. this.addTemporaryEvents(events);
  33031. // see if we want to start dragging straight away
  33032. if (params.dragStartPixels === 0) {
  33033. this.onCommonMove(touch, this.touchStart, params.eElement);
  33034. }
  33035. };
  33036. // gets called whenever mouse down on any drag source
  33037. DragService.prototype.onMouseDown = function (params, mouseEvent) {
  33038. var _this = this;
  33039. var e = mouseEvent;
  33040. if (params.skipMouseEvent && params.skipMouseEvent(mouseEvent)) {
  33041. return;
  33042. }
  33043. // if there are two elements with parent / child relationship, and both are draggable,
  33044. // when we drag the child, we should NOT drag the parent. an example of this is row moving
  33045. // and range selection - row moving should get preference when use drags the rowDrag component.
  33046. if (e._alreadyProcessedByDragService) {
  33047. return;
  33048. }
  33049. e._alreadyProcessedByDragService = true;
  33050. // only interested in left button clicks
  33051. if (mouseEvent.button !== 0) {
  33052. return;
  33053. }
  33054. this.currentDragParams = params;
  33055. this.dragging = false;
  33056. this.mouseStartEvent = mouseEvent;
  33057. var eDocument = this.gridOptionsWrapper.getDocument();
  33058. this.setNoSelectToBody(true);
  33059. var mouseMoveEvent = function (e, el) { return _this.onMouseMove(e, params.eElement); };
  33060. var mouseUpEvent = function (e, el) { return _this.onMouseUp(e, params.eElement); };
  33061. var contextEvent = function (e) { return e.preventDefault(); };
  33062. var target = eDocument;
  33063. var events = [
  33064. { target: target, type: 'mousemove', listener: mouseMoveEvent },
  33065. { target: target, type: 'mouseup', listener: mouseUpEvent },
  33066. { target: target, type: 'contextmenu', listener: contextEvent }
  33067. ];
  33068. // temporally add these listeners, for the duration of the drag
  33069. this.addTemporaryEvents(events);
  33070. //see if we want to start dragging straight away
  33071. if (params.dragStartPixels === 0) {
  33072. this.onMouseMove(mouseEvent, params.eElement);
  33073. }
  33074. };
  33075. DragService.prototype.addTemporaryEvents = function (events) {
  33076. events.forEach(function (currentEvent) {
  33077. var target = currentEvent.target, type = currentEvent.type, listener = currentEvent.listener, options = currentEvent.options;
  33078. target.addEventListener(type, listener, options);
  33079. });
  33080. this.dragEndFunctions.push(function () {
  33081. events.forEach(function (currentEvent) {
  33082. var target = currentEvent.target, type = currentEvent.type, listener = currentEvent.listener, options = currentEvent.options;
  33083. target.removeEventListener(type, listener, options);
  33084. });
  33085. });
  33086. };
  33087. // returns true if the event is close to the original event by X pixels either vertically or horizontally.
  33088. // we only start dragging after X pixels so this allows us to know if we should start dragging yet.
  33089. DragService.prototype.isEventNearStartEvent = function (currentEvent, startEvent) {
  33090. // by default, we wait 4 pixels before starting the drag
  33091. var dragStartPixels = this.currentDragParams.dragStartPixels;
  33092. var requiredPixelDiff = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(dragStartPixels) ? dragStartPixels : 4;
  33093. return _utils__WEBPACK_IMPORTED_MODULE_2__["_"].areEventsNear(currentEvent, startEvent, requiredPixelDiff);
  33094. };
  33095. DragService.prototype.getFirstActiveTouch = function (touchList) {
  33096. for (var i = 0; i < touchList.length; i++) {
  33097. if (touchList[i].identifier === this.touchStart.identifier) {
  33098. return touchList[i];
  33099. }
  33100. }
  33101. return null;
  33102. };
  33103. DragService.prototype.onCommonMove = function (currentEvent, startEvent, el) {
  33104. if (!this.dragging) {
  33105. // if mouse hasn't travelled from the start position enough, do nothing
  33106. if (!this.dragging && this.isEventNearStartEvent(currentEvent, startEvent)) {
  33107. return;
  33108. }
  33109. this.dragging = true;
  33110. var event_1 = {
  33111. type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_DRAG_STARTED,
  33112. api: this.gridApi,
  33113. columnApi: this.columnApi,
  33114. target: el
  33115. };
  33116. this.eventService.dispatchEvent(event_1);
  33117. this.currentDragParams.onDragStart(startEvent);
  33118. }
  33119. this.currentDragParams.onDragging(currentEvent);
  33120. };
  33121. DragService.prototype.onTouchMove = function (touchEvent, el) {
  33122. var touch = this.getFirstActiveTouch(touchEvent.touches);
  33123. if (!touch) {
  33124. return;
  33125. }
  33126. // this.___statusPanel.setInfoText(Math.random() + ' onTouchMove preventDefault stopPropagation');
  33127. // if we don't preview default, then the browser will try and do it's own touch stuff,
  33128. // like do 'back button' (chrome does this) or scroll the page (eg drag column could be confused
  33129. // with scroll page in the app)
  33130. // touchEvent.preventDefault();
  33131. this.onCommonMove(touch, this.touchStart, el);
  33132. };
  33133. // only gets called after a mouse down - as this is only added after mouseDown
  33134. // and is removed when mouseUp happens
  33135. DragService.prototype.onMouseMove = function (mouseEvent, el) {
  33136. this.onCommonMove(mouseEvent, this.mouseStartEvent, el);
  33137. };
  33138. DragService.prototype.onTouchUp = function (touchEvent, el) {
  33139. var touch = this.getFirstActiveTouch(touchEvent.changedTouches);
  33140. // i haven't worked this out yet, but there is no matching touch
  33141. // when we get the touch up event. to get around this, we swap in
  33142. // the last touch. this is a hack to 'get it working' while we
  33143. // figure out what's going on, why we are not getting a touch in
  33144. // current event.
  33145. if (!touch) {
  33146. touch = this.touchLastTime;
  33147. }
  33148. // if mouse was left up before we started to move, then this is a tap.
  33149. // we check this before onUpCommon as onUpCommon resets the dragging
  33150. // let tap = !this.dragging;
  33151. // let tapTarget = this.currentDragParams.eElement;
  33152. this.onUpCommon(touch, el);
  33153. // if tap, tell user
  33154. // console.log(`${Math.random()} tap = ${tap}`);
  33155. // if (tap) {
  33156. // tapTarget.click();
  33157. // }
  33158. };
  33159. DragService.prototype.onMouseUp = function (mouseEvent, el) {
  33160. this.onUpCommon(mouseEvent, el);
  33161. };
  33162. DragService.prototype.onUpCommon = function (eventOrTouch, el) {
  33163. if (this.dragging) {
  33164. this.dragging = false;
  33165. this.currentDragParams.onDragStop(eventOrTouch);
  33166. var event_2 = {
  33167. type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_DRAG_STOPPED,
  33168. api: this.gridApi,
  33169. columnApi: this.columnApi,
  33170. target: el
  33171. };
  33172. this.eventService.dispatchEvent(event_2);
  33173. }
  33174. this.setNoSelectToBody(false);
  33175. this.mouseStartEvent = null;
  33176. this.touchStart = null;
  33177. this.touchLastTime = null;
  33178. this.currentDragParams = null;
  33179. this.dragEndFunctions.forEach(function (func) { return func(); });
  33180. this.dragEndFunctions.length = 0;
  33181. };
  33182. __decorate([
  33183. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('loggerFactory')
  33184. ], DragService.prototype, "loggerFactory", void 0);
  33185. __decorate([
  33186. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  33187. ], DragService.prototype, "gridOptionsWrapper", void 0);
  33188. __decorate([
  33189. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi')
  33190. ], DragService.prototype, "columnApi", void 0);
  33191. __decorate([
  33192. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi')
  33193. ], DragService.prototype, "gridApi", void 0);
  33194. __decorate([
  33195. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  33196. ], DragService.prototype, "init", null);
  33197. __decorate([
  33198. _context_context__WEBPACK_IMPORTED_MODULE_0__["PreDestroy"]
  33199. ], DragService.prototype, "removeAllListeners", null);
  33200. DragService = __decorate([
  33201. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('dragService')
  33202. ], DragService);
  33203. return DragService;
  33204. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"]));
  33205. /***/ }),
  33206. /* 140 */
  33207. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  33208. "use strict";
  33209. __webpack_require__.r(__webpack_exports__);
  33210. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SortController", function() { return SortController; });
  33211. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  33212. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  33213. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25);
  33214. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(43);
  33215. /**
  33216. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  33217. * @version v23.2.1
  33218. * @link http://www.ag-grid.com/
  33219. * @license MIT
  33220. */
  33221. var __extends = (undefined && undefined.__extends) || (function () {
  33222. var extendStatics = function (d, b) {
  33223. extendStatics = Object.setPrototypeOf ||
  33224. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  33225. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  33226. return extendStatics(d, b);
  33227. };
  33228. return function (d, b) {
  33229. extendStatics(d, b);
  33230. function __() { this.constructor = d; }
  33231. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  33232. };
  33233. })();
  33234. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  33235. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  33236. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  33237. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  33238. return c > 3 && r && Object.defineProperty(target, key, r), r;
  33239. };
  33240. var SortController = /** @class */ (function (_super) {
  33241. __extends(SortController, _super);
  33242. function SortController() {
  33243. var _this = _super !== null && _super.apply(this, arguments) || this;
  33244. // used by the public api, for saving the sort model
  33245. _this.getSortModel = function () {
  33246. return _this.getColumnsWithSortingOrdered().map(function (column) { return ({
  33247. colId: column.getColId(),
  33248. sort: column.getSort()
  33249. }); });
  33250. };
  33251. return _this;
  33252. }
  33253. SortController_1 = SortController;
  33254. SortController.prototype.progressSort = function (column, multiSort, source) {
  33255. if (source === void 0) { source = "api"; }
  33256. var nextDirection = this.getNextSortDirection(column);
  33257. this.setSortForColumn(column, nextDirection, multiSort, source);
  33258. };
  33259. SortController.prototype.setSortForColumn = function (column, sort, multiSort, source) {
  33260. if (source === void 0) { source = "api"; }
  33261. // auto correct - if sort not legal value, then set it to 'no sort' (which is null)
  33262. if (sort !== _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_ASC && sort !== _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_DESC) {
  33263. sort = null;
  33264. }
  33265. // update sort on current col
  33266. column.setSort(sort, source);
  33267. // sortedAt used for knowing order of cols when multi-col sort
  33268. if (column.getSort()) {
  33269. var sortedAt = Number(new Date().valueOf());
  33270. column.setSortedAt(sortedAt);
  33271. }
  33272. else {
  33273. column.setSortedAt(null);
  33274. }
  33275. var doingMultiSort = multiSort && !this.gridOptionsWrapper.isSuppressMultiSort();
  33276. // clear sort on all columns except this one, and update the icons
  33277. if (!doingMultiSort) {
  33278. this.clearSortBarThisColumn(column, source);
  33279. }
  33280. this.dispatchSortChangedEvents();
  33281. };
  33282. // gets called by API, so if data changes, use can call this, which will end up
  33283. // working out the sort order again of the rows.
  33284. SortController.prototype.onSortChanged = function () {
  33285. this.dispatchSortChangedEvents();
  33286. };
  33287. SortController.prototype.dispatchSortChangedEvents = function () {
  33288. var event = {
  33289. type: _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_SORT_CHANGED,
  33290. api: this.gridApi,
  33291. columnApi: this.columnApi
  33292. };
  33293. this.eventService.dispatchEvent(event);
  33294. };
  33295. SortController.prototype.clearSortBarThisColumn = function (columnToSkip, source) {
  33296. this.columnController.getPrimaryAndSecondaryAndAutoColumns().forEach(function (columnToClear) {
  33297. // Do not clear if either holding shift, or if column in question was clicked
  33298. if (!(columnToClear === columnToSkip)) {
  33299. // setting to 'undefined' as null means 'none' rather than cleared, otherwise issue will arise
  33300. // if sort order is: ['desc', null , 'asc'], as it will start at null rather than 'desc'.
  33301. columnToClear.setSort(undefined, source);
  33302. }
  33303. });
  33304. };
  33305. SortController.prototype.getNextSortDirection = function (column) {
  33306. var sortingOrder;
  33307. if (column.getColDef().sortingOrder) {
  33308. sortingOrder = column.getColDef().sortingOrder;
  33309. }
  33310. else if (this.gridOptionsWrapper.getSortingOrder()) {
  33311. sortingOrder = this.gridOptionsWrapper.getSortingOrder();
  33312. }
  33313. else {
  33314. sortingOrder = SortController_1.DEFAULT_SORTING_ORDER;
  33315. }
  33316. if (!Array.isArray(sortingOrder) || sortingOrder.length <= 0) {
  33317. console.warn("ag-grid: sortingOrder must be an array with at least one element, currently it's " + sortingOrder);
  33318. return null;
  33319. }
  33320. var currentIndex = sortingOrder.indexOf(column.getSort());
  33321. var notInArray = currentIndex < 0;
  33322. var lastItemInArray = currentIndex == sortingOrder.length - 1;
  33323. var result;
  33324. if (notInArray || lastItemInArray) {
  33325. result = sortingOrder[0];
  33326. }
  33327. else {
  33328. result = sortingOrder[currentIndex + 1];
  33329. }
  33330. // verify the sort type exists, as the user could provide the sortingOrder, need to make sure it's valid
  33331. if (SortController_1.DEFAULT_SORTING_ORDER.indexOf(result) < 0) {
  33332. console.warn('ag-grid: invalid sort type ' + result);
  33333. return null;
  33334. }
  33335. return result;
  33336. };
  33337. SortController.prototype.setSortModel = function (sortModel, source) {
  33338. var _this = this;
  33339. if (source === void 0) { source = "api"; }
  33340. // first up, clear any previous sort
  33341. var sortModelProvided = sortModel && sortModel.length > 0;
  33342. var allColumnsIncludingAuto = this.columnController.getPrimaryAndSecondaryAndAutoColumns();
  33343. allColumnsIncludingAuto.forEach(function (column) {
  33344. var sortForCol = null;
  33345. var sortedAt = -1;
  33346. if (sortModelProvided && column.getColDef().sortable) {
  33347. for (var j = 0; j < sortModel.length; j++) {
  33348. var sortModelEntry = sortModel[j];
  33349. if (typeof sortModelEntry.colId === 'string'
  33350. && typeof column.getColId() === 'string'
  33351. && _this.compareColIds(sortModelEntry, column)) {
  33352. sortForCol = sortModelEntry.sort;
  33353. sortedAt = j;
  33354. }
  33355. }
  33356. }
  33357. if (sortForCol) {
  33358. column.setSort(sortForCol, source);
  33359. column.setSortedAt(sortedAt);
  33360. }
  33361. else {
  33362. column.setSort(null, source);
  33363. column.setSortedAt(null);
  33364. }
  33365. });
  33366. this.dispatchSortChangedEvents();
  33367. };
  33368. SortController.prototype.compareColIds = function (sortModelEntry, column) {
  33369. return sortModelEntry.colId === column.getColId();
  33370. };
  33371. SortController.prototype.getColumnsWithSortingOrdered = function () {
  33372. // pull out all the columns that have sorting set
  33373. var allColumnsIncludingAuto = this.columnController.getPrimaryAndSecondaryAndAutoColumns();
  33374. var columnsWithSorting = allColumnsIncludingAuto.filter(function (column) { return !!column.getSort(); });
  33375. // put the columns in order of which one got sorted first
  33376. columnsWithSorting.sort(function (a, b) { return a.sortedAt - b.sortedAt; });
  33377. return columnsWithSorting;
  33378. };
  33379. // used by row controller, when doing the sorting
  33380. SortController.prototype.getSortForRowController = function () {
  33381. return this.getColumnsWithSortingOrdered().map(function (column) {
  33382. var isAscending = column.getSort() === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_ASC;
  33383. return {
  33384. inverter: isAscending ? 1 : -1,
  33385. column: column
  33386. };
  33387. });
  33388. };
  33389. var SortController_1;
  33390. SortController.DEFAULT_SORTING_ORDER = [_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_ASC, _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].SORT_DESC, null];
  33391. __decorate([
  33392. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  33393. ], SortController.prototype, "gridOptionsWrapper", void 0);
  33394. __decorate([
  33395. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController')
  33396. ], SortController.prototype, "columnController", void 0);
  33397. __decorate([
  33398. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi')
  33399. ], SortController.prototype, "columnApi", void 0);
  33400. __decorate([
  33401. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi')
  33402. ], SortController.prototype, "gridApi", void 0);
  33403. SortController = SortController_1 = __decorate([
  33404. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('sortController')
  33405. ], SortController);
  33406. return SortController;
  33407. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  33408. /***/ }),
  33409. /* 141 */
  33410. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  33411. "use strict";
  33412. __webpack_require__.r(__webpack_exports__);
  33413. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FocusController", function() { return FocusController; });
  33414. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  33415. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  33416. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43);
  33417. /* harmony import */ var _rendering_cellComp__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(101);
  33418. /* harmony import */ var _widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(117);
  33419. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7);
  33420. /**
  33421. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  33422. * @version v23.2.1
  33423. * @link http://www.ag-grid.com/
  33424. * @license MIT
  33425. */
  33426. var __extends = (undefined && undefined.__extends) || (function () {
  33427. var extendStatics = function (d, b) {
  33428. extendStatics = Object.setPrototypeOf ||
  33429. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  33430. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  33431. return extendStatics(d, b);
  33432. };
  33433. return function (d, b) {
  33434. extendStatics(d, b);
  33435. function __() { this.constructor = d; }
  33436. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  33437. };
  33438. })();
  33439. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  33440. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  33441. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  33442. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  33443. return c > 3 && r && Object.defineProperty(target, key, r), r;
  33444. };
  33445. var FocusController = /** @class */ (function (_super) {
  33446. __extends(FocusController, _super);
  33447. function FocusController() {
  33448. var _this = _super !== null && _super.apply(this, arguments) || this;
  33449. _this.keyboardFocusActive = false;
  33450. return _this;
  33451. }
  33452. FocusController_1 = FocusController;
  33453. FocusController.prototype.init = function () {
  33454. var eDocument = this.gridOptionsWrapper.getDocument();
  33455. var clearFocusedCellListener = this.clearFocusedCell.bind(this);
  33456. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_PIVOT_MODE_CHANGED, clearFocusedCellListener);
  33457. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_EVERYTHING_CHANGED, this.onColumnEverythingChanged.bind(this));
  33458. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_GROUP_OPENED, clearFocusedCellListener);
  33459. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, clearFocusedCellListener);
  33460. this.addManagedListener(eDocument, 'keydown', this.activateKeyboardMode.bind(this));
  33461. this.addManagedListener(eDocument, 'mousedown', this.activateMouseMode.bind(this));
  33462. };
  33463. FocusController.prototype.registerGridCore = function (gridCore) {
  33464. this.gridCore = gridCore;
  33465. };
  33466. FocusController.prototype.onColumnEverythingChanged = function () {
  33467. // if the columns change, check and see if this column still exists. if it does,
  33468. // then we can keep the focused cell. if it doesn't, then we need to drop the focused
  33469. // cell.
  33470. if (this.focusedCellPosition) {
  33471. var col = this.focusedCellPosition.column;
  33472. var colFromColumnController = this.columnController.getGridColumn(col.getId());
  33473. if (col !== colFromColumnController) {
  33474. this.clearFocusedCell();
  33475. }
  33476. }
  33477. };
  33478. FocusController.prototype.isKeyboardFocus = function () {
  33479. return this.keyboardFocusActive;
  33480. };
  33481. FocusController.prototype.activateMouseMode = function () {
  33482. this.keyboardFocusActive = false;
  33483. this.eventService.dispatchEvent({ type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_MOUSE_FOCUS });
  33484. };
  33485. FocusController.prototype.activateKeyboardMode = function () {
  33486. this.keyboardFocusActive = true;
  33487. this.eventService.dispatchEvent({ type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_KEYBOARD_FOCUS });
  33488. };
  33489. // we check if the browser is focusing something, and if it is, and
  33490. // it's the cell we think is focused, then return the cell. so this
  33491. // methods returns the cell if a) we think it has focus and b) the
  33492. // browser thinks it has focus. this then returns nothing if we
  33493. // first focus a cell, then second click outside the grid, as then the
  33494. // grid cell will still be focused as far as the grid is concerned,
  33495. // however the browser focus will have moved somewhere else.
  33496. FocusController.prototype.getFocusCellToUseAfterRefresh = function () {
  33497. if (this.gridOptionsWrapper.isSuppressFocusAfterRefresh() || !this.focusedCellPosition) {
  33498. return null;
  33499. }
  33500. // we check that the browser is actually focusing on the grid, if it is not, then
  33501. // we have nothing to worry about
  33502. var browserFocusedCell = this.getGridCellForDomElement(document.activeElement);
  33503. if (!browserFocusedCell) {
  33504. return null;
  33505. }
  33506. return this.focusedCellPosition;
  33507. };
  33508. FocusController.prototype.getGridCellForDomElement = function (eBrowserCell) {
  33509. var ePointer = eBrowserCell;
  33510. while (ePointer) {
  33511. var cellComp = this.gridOptionsWrapper.getDomData(ePointer, _rendering_cellComp__WEBPACK_IMPORTED_MODULE_3__["CellComp"].DOM_DATA_KEY_CELL_COMP);
  33512. if (cellComp) {
  33513. return cellComp.getCellPosition();
  33514. }
  33515. ePointer = ePointer.parentNode;
  33516. }
  33517. return null;
  33518. };
  33519. FocusController.prototype.clearFocusedCell = function () {
  33520. this.focusedCellPosition = null;
  33521. this.onCellFocused(false);
  33522. };
  33523. FocusController.prototype.getFocusedCell = function () {
  33524. return this.focusedCellPosition;
  33525. };
  33526. FocusController.prototype.setFocusedCell = function (rowIndex, colKey, floating, forceBrowserFocus) {
  33527. if (forceBrowserFocus === void 0) { forceBrowserFocus = false; }
  33528. var column = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].makeNull(this.columnController.getGridColumn(colKey));
  33529. this.focusedCellPosition = { rowIndex: rowIndex, rowPinned: _utils__WEBPACK_IMPORTED_MODULE_5__["_"].makeNull(floating), column: column };
  33530. this.onCellFocused(forceBrowserFocus);
  33531. };
  33532. FocusController.prototype.isCellFocused = function (cellPosition) {
  33533. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.focusedCellPosition)) {
  33534. return false;
  33535. }
  33536. return this.focusedCellPosition.column === cellPosition.column && this.isRowFocused(cellPosition.rowIndex, cellPosition.rowPinned);
  33537. };
  33538. FocusController.prototype.isRowNodeFocused = function (rowNode) {
  33539. return this.isRowFocused(rowNode.rowIndex, rowNode.rowPinned);
  33540. };
  33541. FocusController.prototype.isHeaderWrapperFocused = function (headerWrapper) {
  33542. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.focusedHeaderPosition)) {
  33543. return false;
  33544. }
  33545. var column = headerWrapper.getColumn();
  33546. var headerRowIndex = headerWrapper.getParentComponent().getRowIndex();
  33547. var pinned = headerWrapper.getPinned();
  33548. var _a = this.focusedHeaderPosition, focusedColumn = _a.column, focusedHeaderRowIndex = _a.headerRowIndex;
  33549. return column === focusedColumn &&
  33550. headerRowIndex === focusedHeaderRowIndex &&
  33551. pinned == focusedColumn.getPinned();
  33552. };
  33553. FocusController.prototype.clearFocusedHeader = function () {
  33554. this.focusedHeaderPosition = null;
  33555. };
  33556. FocusController.prototype.getFocusedHeader = function () {
  33557. return this.focusedHeaderPosition;
  33558. };
  33559. FocusController.prototype.setFocusedHeader = function (headerRowIndex, column) {
  33560. this.focusedHeaderPosition = { headerRowIndex: headerRowIndex, column: column };
  33561. };
  33562. FocusController.prototype.focusHeaderPosition = function (headerPosition, direction) {
  33563. this.headerNavigationService.scrollToColumn(headerPosition.column, direction);
  33564. var childContainer = this.headerNavigationService.getHeaderContainer(headerPosition.column.getPinned());
  33565. var rowComps = childContainer.getRowComps();
  33566. var nextRowComp = rowComps[headerPosition.headerRowIndex];
  33567. var headerComps = nextRowComp.getHeaderComps();
  33568. var nextHeader = headerComps[headerPosition.column.getUniqueId()];
  33569. if (nextHeader) {
  33570. // this will automatically call the setFocusedHeader method above
  33571. nextHeader.getFocusableElement().focus();
  33572. return true;
  33573. }
  33574. return false;
  33575. };
  33576. FocusController.prototype.isAnyCellFocused = function () {
  33577. return !!this.focusedCellPosition;
  33578. };
  33579. FocusController.prototype.isRowFocused = function (rowIndex, floating) {
  33580. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].missing(this.focusedCellPosition)) {
  33581. return false;
  33582. }
  33583. var floatingOrNull = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].makeNull(floating);
  33584. return this.focusedCellPosition.rowIndex === rowIndex && this.focusedCellPosition.rowPinned === floatingOrNull;
  33585. };
  33586. FocusController.prototype.findFocusableElements = function (rootNode, exclude, onlyUnmanaged) {
  33587. var focusableString = FocusController_1.FOCUSABLE_SELECTOR;
  33588. var excludeString = FocusController_1.FOCUSABLE_EXCLUDE;
  33589. if (exclude) {
  33590. excludeString += ', ' + exclude;
  33591. }
  33592. if (onlyUnmanaged) {
  33593. excludeString += ', [tabindex="-1"]';
  33594. }
  33595. var nodes = Array.prototype.slice.apply(rootNode.querySelectorAll(focusableString));
  33596. var excludeNodes = Array.prototype.slice.apply(rootNode.querySelectorAll(excludeString));
  33597. if (!excludeNodes.length) {
  33598. return nodes;
  33599. }
  33600. var diff = function (a, b) { return a.filter(function (element) { return b.indexOf(element) === -1; }); };
  33601. return diff(nodes, excludeNodes);
  33602. };
  33603. FocusController.prototype.focusFirstFocusableElement = function (rootNode, onlyUnmanaged) {
  33604. var focusable = this.findFocusableElements(rootNode, null, onlyUnmanaged)[0];
  33605. if (focusable) {
  33606. focusable.focus();
  33607. return true;
  33608. }
  33609. return false;
  33610. };
  33611. FocusController.prototype.focusLastFocusableElement = function (rootNode, onlyUnmanaged) {
  33612. var focusable = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].last(this.findFocusableElements(rootNode, null, onlyUnmanaged));
  33613. if (focusable) {
  33614. focusable.focus();
  33615. return true;
  33616. }
  33617. return false;
  33618. };
  33619. FocusController.prototype.findNextFocusableElement = function (rootNode, onlyManaged, backwards) {
  33620. var focusable = this.findFocusableElements(rootNode, onlyManaged ? ':not([tabindex="-1"])' : null);
  33621. var currentIndex;
  33622. if (onlyManaged) {
  33623. currentIndex = _utils__WEBPACK_IMPORTED_MODULE_5__["_"].findIndex(focusable, function (el) { return el.contains(document.activeElement); });
  33624. }
  33625. else {
  33626. currentIndex = focusable.indexOf(document.activeElement);
  33627. }
  33628. var nextIndex = currentIndex + (backwards ? -1 : 1);
  33629. if (nextIndex < 0 || nextIndex > focusable.length) {
  33630. return;
  33631. }
  33632. return focusable[nextIndex];
  33633. };
  33634. FocusController.prototype.isFocusUnderManagedComponent = function (rootNode) {
  33635. var managedContainers = rootNode.querySelectorAll("." + _widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_4__["ManagedFocusComponent"].FOCUS_MANAGED_CLASS);
  33636. if (!managedContainers.length) {
  33637. return false;
  33638. }
  33639. for (var i = 0; i < managedContainers.length; i++) {
  33640. if (managedContainers[i].contains(document.activeElement)) {
  33641. return true;
  33642. }
  33643. }
  33644. return false;
  33645. };
  33646. FocusController.prototype.findTabbableParent = function (node, limit) {
  33647. if (limit === void 0) { limit = 5; }
  33648. var counter = 0;
  33649. while (node && _utils__WEBPACK_IMPORTED_MODULE_5__["_"].getTabIndex(node) === null && ++counter <= limit) {
  33650. node = node.parentElement;
  33651. }
  33652. if (_utils__WEBPACK_IMPORTED_MODULE_5__["_"].getTabIndex(node) === null) {
  33653. return null;
  33654. }
  33655. return node;
  33656. };
  33657. FocusController.prototype.onCellFocused = function (forceBrowserFocus) {
  33658. var event = {
  33659. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_CELL_FOCUSED,
  33660. forceBrowserFocus: forceBrowserFocus,
  33661. rowIndex: null,
  33662. column: null,
  33663. floating: null,
  33664. api: this.gridApi,
  33665. columnApi: this.columnApi,
  33666. rowPinned: null
  33667. };
  33668. if (this.focusedCellPosition) {
  33669. event.rowIndex = this.focusedCellPosition.rowIndex;
  33670. event.column = this.focusedCellPosition.column;
  33671. event.rowPinned = this.focusedCellPosition.rowPinned;
  33672. }
  33673. this.eventService.dispatchEvent(event);
  33674. };
  33675. FocusController.prototype.focusGridView = function (column) {
  33676. var firstRow = this.rowPositionUtils.getFirstRow();
  33677. if (!firstRow) {
  33678. return false;
  33679. }
  33680. var rowIndex = firstRow.rowIndex, rowPinned = firstRow.rowPinned;
  33681. var focusedHeader = this.getFocusedHeader();
  33682. if (!column) {
  33683. column = focusedHeader.column;
  33684. }
  33685. if (!_utils__WEBPACK_IMPORTED_MODULE_5__["_"].exists(rowIndex)) {
  33686. return false;
  33687. }
  33688. this.rowRenderer.ensureCellVisible({ rowIndex: rowIndex, column: column, rowPinned: rowPinned });
  33689. this.setFocusedCell(rowIndex, column, _utils__WEBPACK_IMPORTED_MODULE_5__["_"].makeNull(rowPinned), true);
  33690. if (this.rangeController) {
  33691. var cellPosition = { rowIndex: rowIndex, rowPinned: rowPinned, column: column };
  33692. this.rangeController.setRangeToCell(cellPosition);
  33693. }
  33694. return true;
  33695. };
  33696. FocusController.prototype.focusNextGridCoreContainer = function (backwards) {
  33697. if (this.gridCore.focusNextInnerContainer(backwards)) {
  33698. return true;
  33699. }
  33700. if (!backwards) {
  33701. this.gridCore.forceFocusOutOfContainer();
  33702. }
  33703. };
  33704. var FocusController_1;
  33705. FocusController.FOCUSABLE_SELECTOR = '[tabindex], input, select, button, textarea';
  33706. FocusController.FOCUSABLE_EXCLUDE = '.ag-hidden, .ag-hidden *, .ag-disabled, .ag-disabled *';
  33707. __decorate([
  33708. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  33709. ], FocusController.prototype, "gridOptionsWrapper", void 0);
  33710. __decorate([
  33711. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController')
  33712. ], FocusController.prototype, "columnController", void 0);
  33713. __decorate([
  33714. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('headerNavigationService')
  33715. ], FocusController.prototype, "headerNavigationService", void 0);
  33716. __decorate([
  33717. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi')
  33718. ], FocusController.prototype, "columnApi", void 0);
  33719. __decorate([
  33720. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi')
  33721. ], FocusController.prototype, "gridApi", void 0);
  33722. __decorate([
  33723. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer')
  33724. ], FocusController.prototype, "rowRenderer", void 0);
  33725. __decorate([
  33726. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowPositionUtils')
  33727. ], FocusController.prototype, "rowPositionUtils", void 0);
  33728. __decorate([
  33729. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])('rangeController')
  33730. ], FocusController.prototype, "rangeController", void 0);
  33731. __decorate([
  33732. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  33733. ], FocusController.prototype, "init", null);
  33734. FocusController = FocusController_1 = __decorate([
  33735. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('focusController')
  33736. ], FocusController);
  33737. return FocusController;
  33738. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  33739. /***/ }),
  33740. /* 142 */
  33741. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  33742. "use strict";
  33743. __webpack_require__.r(__webpack_exports__);
  33744. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MouseEventService", function() { return MouseEventService; });
  33745. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  33746. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7);
  33747. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25);
  33748. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(41);
  33749. /**
  33750. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  33751. * @version v23.2.1
  33752. * @link http://www.ag-grid.com/
  33753. * @license MIT
  33754. */
  33755. var __extends = (undefined && undefined.__extends) || (function () {
  33756. var extendStatics = function (d, b) {
  33757. extendStatics = Object.setPrototypeOf ||
  33758. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  33759. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  33760. return extendStatics(d, b);
  33761. };
  33762. return function (d, b) {
  33763. extendStatics(d, b);
  33764. function __() { this.constructor = d; }
  33765. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  33766. };
  33767. })();
  33768. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  33769. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  33770. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  33771. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  33772. return c > 3 && r && Object.defineProperty(target, key, r), r;
  33773. };
  33774. var MouseEventService = /** @class */ (function (_super) {
  33775. __extends(MouseEventService, _super);
  33776. function MouseEventService() {
  33777. var _this = _super !== null && _super.apply(this, arguments) || this;
  33778. _this.gridInstanceId = MouseEventService_1.gridInstanceSequence.next();
  33779. return _this;
  33780. }
  33781. MouseEventService_1 = MouseEventService;
  33782. MouseEventService.prototype.init = function () {
  33783. this.stampDomElementWithGridInstance();
  33784. };
  33785. MouseEventService.prototype.registerGridComp = function (gridPanel) {
  33786. this.gridPanel = gridPanel;
  33787. };
  33788. // we put the instance id onto the main DOM element. this is used for events, when grids are inside grids,
  33789. // so the grid can work out if the even came from this grid or a grid inside this one. see the ctrl+v logic
  33790. // for where this is used.
  33791. MouseEventService.prototype.stampDomElementWithGridInstance = function () {
  33792. this.eGridDiv[MouseEventService_1.GRID_DOM_KEY] = this.gridInstanceId;
  33793. };
  33794. MouseEventService.prototype.getRenderedCellForEvent = function (event) {
  33795. return _utils__WEBPACK_IMPORTED_MODULE_1__["_"].getCellCompForEvent(this.gridOptionsWrapper, event);
  33796. };
  33797. // walks the path of the event, and returns true if this grid is the first one that it finds. if doing
  33798. // master / detail grids, and a child grid is found, then it returns false. this stops things like copy/paste
  33799. // getting executed on many grids at the same time.
  33800. MouseEventService.prototype.isEventFromThisGrid = function (event) {
  33801. var path = _utils__WEBPACK_IMPORTED_MODULE_1__["_"].getEventPath(event);
  33802. for (var i = 0; i < path.length; i++) {
  33803. var element = path[i];
  33804. var instanceId = element[MouseEventService_1.GRID_DOM_KEY];
  33805. if (_utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(instanceId)) {
  33806. var eventFromThisGrid = instanceId === this.gridInstanceId;
  33807. return eventFromThisGrid;
  33808. }
  33809. }
  33810. return false;
  33811. };
  33812. MouseEventService.prototype.getCellPositionForEvent = function (event) {
  33813. var cellComp = this.getRenderedCellForEvent(event);
  33814. return cellComp ? cellComp.getCellPosition() : null;
  33815. };
  33816. MouseEventService.prototype.getNormalisedPosition = function (event) {
  33817. var gridPanelHasScrolls = this.gridOptionsWrapper.getDomLayout() === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].DOM_LAYOUT_NORMAL;
  33818. var x = event.x, y = event.y;
  33819. if (gridPanelHasScrolls) {
  33820. var vRange = this.gridPanel.getVScrollPosition();
  33821. var hRange = this.gridPanel.getHScrollPosition();
  33822. return { x: x + hRange.left, y: y + vRange.top };
  33823. }
  33824. return { x: x, y: y };
  33825. };
  33826. var MouseEventService_1;
  33827. MouseEventService.gridInstanceSequence = new _utils__WEBPACK_IMPORTED_MODULE_1__["NumberSequence"]();
  33828. MouseEventService.GRID_DOM_KEY = '__ag_grid_instance';
  33829. __decorate([
  33830. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  33831. ], MouseEventService.prototype, "gridOptionsWrapper", void 0);
  33832. __decorate([
  33833. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('eGridDiv')
  33834. ], MouseEventService.prototype, "eGridDiv", void 0);
  33835. __decorate([
  33836. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  33837. ], MouseEventService.prototype, "init", null);
  33838. MouseEventService = MouseEventService_1 = __decorate([
  33839. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('mouseEventService')
  33840. ], MouseEventService);
  33841. return MouseEventService;
  33842. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"]));
  33843. /***/ }),
  33844. /* 143 */
  33845. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  33846. "use strict";
  33847. __webpack_require__.r(__webpack_exports__);
  33848. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellNavigationService", function() { return CellNavigationService; });
  33849. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  33850. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  33851. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25);
  33852. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  33853. /**
  33854. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  33855. * @version v23.2.1
  33856. * @link http://www.ag-grid.com/
  33857. * @license MIT
  33858. */
  33859. var __extends = (undefined && undefined.__extends) || (function () {
  33860. var extendStatics = function (d, b) {
  33861. extendStatics = Object.setPrototypeOf ||
  33862. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  33863. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  33864. return extendStatics(d, b);
  33865. };
  33866. return function (d, b) {
  33867. extendStatics(d, b);
  33868. function __() { this.constructor = d; }
  33869. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  33870. };
  33871. })();
  33872. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  33873. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  33874. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  33875. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  33876. return c > 3 && r && Object.defineProperty(target, key, r), r;
  33877. };
  33878. var CellNavigationService = /** @class */ (function (_super) {
  33879. __extends(CellNavigationService, _super);
  33880. function CellNavigationService() {
  33881. return _super !== null && _super.apply(this, arguments) || this;
  33882. }
  33883. // returns null if no cell to focus on, ie at the end of the grid
  33884. CellNavigationService.prototype.getNextCellToFocus = function (key, lastCellToFocus) {
  33885. // starting with the provided cell, we keep moving until we find a cell we can
  33886. // focus on.
  33887. var pointer = lastCellToFocus;
  33888. var finished = false;
  33889. // finished will be true when either:
  33890. // a) cell found that we can focus on
  33891. // b) run out of cells (ie the method returns null)
  33892. while (!finished) {
  33893. switch (key) {
  33894. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_UP:
  33895. pointer = this.getCellAbove(pointer);
  33896. break;
  33897. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_DOWN:
  33898. pointer = this.getCellBelow(pointer);
  33899. break;
  33900. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_RIGHT:
  33901. if (this.gridOptionsWrapper.isEnableRtl()) {
  33902. pointer = this.getCellToLeft(pointer);
  33903. }
  33904. else {
  33905. pointer = this.getCellToRight(pointer);
  33906. }
  33907. break;
  33908. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_LEFT:
  33909. if (this.gridOptionsWrapper.isEnableRtl()) {
  33910. pointer = this.getCellToRight(pointer);
  33911. }
  33912. else {
  33913. pointer = this.getCellToLeft(pointer);
  33914. }
  33915. break;
  33916. default:
  33917. pointer = null;
  33918. console.warn('ag-Grid: unknown key for navigation ' + key);
  33919. break;
  33920. }
  33921. if (pointer) {
  33922. finished = this.isCellGoodToFocusOn(pointer);
  33923. }
  33924. else {
  33925. finished = true;
  33926. }
  33927. }
  33928. return pointer;
  33929. };
  33930. CellNavigationService.prototype.isCellGoodToFocusOn = function (gridCell) {
  33931. var column = gridCell.column;
  33932. var rowNode;
  33933. switch (gridCell.rowPinned) {
  33934. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP:
  33935. rowNode = this.pinnedRowModel.getPinnedTopRow(gridCell.rowIndex);
  33936. break;
  33937. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM:
  33938. rowNode = this.pinnedRowModel.getPinnedBottomRow(gridCell.rowIndex);
  33939. break;
  33940. default:
  33941. rowNode = this.rowModel.getRow(gridCell.rowIndex);
  33942. break;
  33943. }
  33944. var suppressNavigable = column.isSuppressNavigable(rowNode);
  33945. return !suppressNavigable;
  33946. };
  33947. CellNavigationService.prototype.getCellToLeft = function (lastCell) {
  33948. if (!lastCell) {
  33949. return null;
  33950. }
  33951. var colToLeft = this.columnController.getDisplayedColBefore(lastCell.column);
  33952. if (!colToLeft) {
  33953. return null;
  33954. }
  33955. return {
  33956. rowIndex: lastCell.rowIndex,
  33957. column: colToLeft,
  33958. rowPinned: lastCell.rowPinned
  33959. };
  33960. };
  33961. CellNavigationService.prototype.getCellToRight = function (lastCell) {
  33962. if (!lastCell) {
  33963. return null;
  33964. }
  33965. var colToRight = this.columnController.getDisplayedColAfter(lastCell.column);
  33966. // if already on right, do nothing
  33967. if (!colToRight) {
  33968. return null;
  33969. }
  33970. return {
  33971. rowIndex: lastCell.rowIndex,
  33972. column: colToRight,
  33973. rowPinned: lastCell.rowPinned
  33974. };
  33975. };
  33976. CellNavigationService.prototype.getRowBelow = function (rowPosition) {
  33977. // if already on top row, do nothing
  33978. var index = rowPosition.rowIndex;
  33979. var pinned = rowPosition.rowPinned;
  33980. if (this.isLastRowInContainer(rowPosition)) {
  33981. switch (pinned) {
  33982. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM:
  33983. // never any rows after pinned bottom
  33984. return null;
  33985. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP:
  33986. // if on last row of pinned top, then next row is main body (if rows exist),
  33987. // otherwise it's the pinned bottom
  33988. if (this.rowModel.isRowsToRender()) {
  33989. return { rowIndex: 0, rowPinned: null };
  33990. }
  33991. else if (this.pinnedRowModel.isRowsToRender(_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM)) {
  33992. return { rowIndex: 0, rowPinned: _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM };
  33993. }
  33994. return null;
  33995. default:
  33996. // if in the main body, then try pinned bottom, otherwise return nothing
  33997. if (this.pinnedRowModel.isRowsToRender(_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM)) {
  33998. return { rowIndex: 0, rowPinned: _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM };
  33999. }
  34000. return null;
  34001. }
  34002. }
  34003. return { rowIndex: index + 1, rowPinned: pinned };
  34004. };
  34005. CellNavigationService.prototype.getCellBelow = function (lastCell) {
  34006. if (!lastCell) {
  34007. return null;
  34008. }
  34009. var rowBelow = this.getRowBelow(lastCell);
  34010. if (rowBelow) {
  34011. return {
  34012. rowIndex: rowBelow.rowIndex,
  34013. column: lastCell.column,
  34014. rowPinned: rowBelow.rowPinned
  34015. };
  34016. }
  34017. return null;
  34018. };
  34019. CellNavigationService.prototype.isLastRowInContainer = function (rowPosition) {
  34020. var pinned = rowPosition.rowPinned;
  34021. var index = rowPosition.rowIndex;
  34022. if (pinned === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP) {
  34023. var lastTopIndex = this.pinnedRowModel.getPinnedTopRowData().length - 1;
  34024. return lastTopIndex <= index;
  34025. }
  34026. else if (pinned === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM) {
  34027. var lastBottomIndex = this.pinnedRowModel.getPinnedBottomRowData().length - 1;
  34028. return lastBottomIndex <= index;
  34029. }
  34030. var lastBodyIndex = this.rowModel.getRowCount() - 1;
  34031. return lastBodyIndex <= index;
  34032. };
  34033. CellNavigationService.prototype.getRowAbove = function (rowPosition) {
  34034. // if already on top row, do nothing
  34035. var index = rowPosition.rowIndex;
  34036. var pinned = rowPosition.rowPinned;
  34037. // if already on top row, do nothing
  34038. if (index === 0) {
  34039. if (pinned === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP) {
  34040. return null;
  34041. }
  34042. else if (!pinned) {
  34043. if (this.pinnedRowModel.isRowsToRender(_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP)) {
  34044. return this.getLastFloatingTopRow();
  34045. }
  34046. return null;
  34047. }
  34048. else {
  34049. // last floating bottom
  34050. if (this.rowModel.isRowsToRender()) {
  34051. return this.getLastBodyCell();
  34052. }
  34053. else if (this.pinnedRowModel.isRowsToRender(_constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP)) {
  34054. return this.getLastFloatingTopRow();
  34055. }
  34056. return null;
  34057. }
  34058. }
  34059. return { rowIndex: index - 1, rowPinned: pinned };
  34060. };
  34061. CellNavigationService.prototype.getCellAbove = function (lastCell) {
  34062. if (!lastCell) {
  34063. return null;
  34064. }
  34065. var rowAbove = this.getRowAbove({ rowIndex: lastCell.rowIndex, rowPinned: lastCell.rowPinned });
  34066. if (rowAbove) {
  34067. return {
  34068. rowIndex: rowAbove.rowIndex,
  34069. column: lastCell.column,
  34070. rowPinned: rowAbove.rowPinned
  34071. };
  34072. }
  34073. return null;
  34074. };
  34075. CellNavigationService.prototype.getLastBodyCell = function () {
  34076. var lastBodyRow = this.rowModel.getRowCount() - 1;
  34077. return { rowIndex: lastBodyRow, rowPinned: null };
  34078. };
  34079. CellNavigationService.prototype.getLastFloatingTopRow = function () {
  34080. var lastFloatingRow = this.pinnedRowModel.getPinnedTopRowData().length - 1;
  34081. return { rowIndex: lastFloatingRow, rowPinned: _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP };
  34082. };
  34083. CellNavigationService.prototype.getNextTabbedCell = function (gridCell, backwards) {
  34084. if (backwards) {
  34085. return this.getNextTabbedCellBackwards(gridCell);
  34086. }
  34087. return this.getNextTabbedCellForwards(gridCell);
  34088. };
  34089. CellNavigationService.prototype.getNextTabbedCellForwards = function (gridCell) {
  34090. var displayedColumns = this.columnController.getAllDisplayedColumns();
  34091. var newRowIndex = gridCell.rowIndex;
  34092. var newFloating = gridCell.rowPinned;
  34093. // move along to the next cell
  34094. var newColumn = this.columnController.getDisplayedColAfter(gridCell.column);
  34095. // check if end of the row, and if so, go forward a row
  34096. if (!newColumn) {
  34097. newColumn = displayedColumns[0];
  34098. var rowBelow = this.getRowBelow(gridCell);
  34099. if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].missing(rowBelow)) {
  34100. return null;
  34101. }
  34102. newRowIndex = rowBelow ? rowBelow.rowIndex : null;
  34103. newFloating = rowBelow ? rowBelow.rowPinned : null;
  34104. }
  34105. return { rowIndex: newRowIndex, column: newColumn, rowPinned: newFloating };
  34106. };
  34107. CellNavigationService.prototype.getNextTabbedCellBackwards = function (gridCell) {
  34108. var displayedColumns = this.columnController.getAllDisplayedColumns();
  34109. var newRowIndex = gridCell.rowIndex;
  34110. var newFloating = gridCell.rowPinned;
  34111. // move along to the next cell
  34112. var newColumn = this.columnController.getDisplayedColBefore(gridCell.column);
  34113. // check if end of the row, and if so, go forward a row
  34114. if (!newColumn) {
  34115. newColumn = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].last(displayedColumns);
  34116. var rowAbove = this.getRowAbove({ rowIndex: gridCell.rowIndex, rowPinned: gridCell.rowPinned });
  34117. if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].missing(rowAbove)) {
  34118. return null;
  34119. }
  34120. newRowIndex = rowAbove ? rowAbove.rowIndex : null;
  34121. newFloating = rowAbove ? rowAbove.rowPinned : null;
  34122. }
  34123. return { rowIndex: newRowIndex, column: newColumn, rowPinned: newFloating };
  34124. };
  34125. __decorate([
  34126. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController')
  34127. ], CellNavigationService.prototype, "columnController", void 0);
  34128. __decorate([
  34129. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel')
  34130. ], CellNavigationService.prototype, "rowModel", void 0);
  34131. __decorate([
  34132. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('pinnedRowModel')
  34133. ], CellNavigationService.prototype, "pinnedRowModel", void 0);
  34134. __decorate([
  34135. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  34136. ], CellNavigationService.prototype, "gridOptionsWrapper", void 0);
  34137. CellNavigationService = __decorate([
  34138. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('cellNavigationService')
  34139. ], CellNavigationService);
  34140. return CellNavigationService;
  34141. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  34142. /***/ }),
  34143. /* 144 */
  34144. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  34145. "use strict";
  34146. __webpack_require__.r(__webpack_exports__);
  34147. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellRendererFactory", function() { return CellRendererFactory; });
  34148. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  34149. /* harmony import */ var _cellRenderers_animateSlideCellRenderer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(77);
  34150. /* harmony import */ var _cellRenderers_animateShowChangeCellRenderer__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(76);
  34151. /* harmony import */ var _cellRenderers_groupCellRenderer__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(67);
  34152. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7);
  34153. /**
  34154. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  34155. * @version v23.2.1
  34156. * @link http://www.ag-grid.com/
  34157. * @license MIT
  34158. */
  34159. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  34160. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  34161. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  34162. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  34163. return c > 3 && r && Object.defineProperty(target, key, r), r;
  34164. };
  34165. var CellRendererFactory = /** @class */ (function () {
  34166. function CellRendererFactory() {
  34167. this.cellRendererMap = {};
  34168. }
  34169. CellRendererFactory_1 = CellRendererFactory;
  34170. CellRendererFactory.prototype.init = function () {
  34171. this.cellRendererMap[CellRendererFactory_1.ANIMATE_SLIDE] = _cellRenderers_animateSlideCellRenderer__WEBPACK_IMPORTED_MODULE_1__["AnimateSlideCellRenderer"];
  34172. this.cellRendererMap[CellRendererFactory_1.ANIMATE_SHOW_CHANGE] = _cellRenderers_animateShowChangeCellRenderer__WEBPACK_IMPORTED_MODULE_2__["AnimateShowChangeCellRenderer"];
  34173. this.cellRendererMap[CellRendererFactory_1.GROUP] = _cellRenderers_groupCellRenderer__WEBPACK_IMPORTED_MODULE_3__["GroupCellRenderer"];
  34174. // this.registerRenderersFromGridOptions();
  34175. };
  34176. // private registerRenderersFromGridOptions(): void {
  34177. // let userProvidedCellRenderers = this.gridOptionsWrapper.getCellRenderers();
  34178. // _.iterateObject(userProvidedCellRenderers, (key: string, cellRenderer: {new(): ICellRenderer} | ICellRendererFunc)=> {
  34179. // this.addCellRenderer(key, cellRenderer);
  34180. // });
  34181. // }
  34182. CellRendererFactory.prototype.addCellRenderer = function (key, cellRenderer) {
  34183. this.cellRendererMap[key] = cellRenderer;
  34184. };
  34185. CellRendererFactory.prototype.getCellRenderer = function (key) {
  34186. var result = this.cellRendererMap[key];
  34187. if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].missing(result)) {
  34188. console.warn('ag-Grid: unable to find cellRenderer for key ' + key);
  34189. return null;
  34190. }
  34191. return result;
  34192. };
  34193. var CellRendererFactory_1;
  34194. CellRendererFactory.ANIMATE_SLIDE = 'animateSlide';
  34195. CellRendererFactory.ANIMATE_SHOW_CHANGE = 'animateShowChange';
  34196. CellRendererFactory.GROUP = 'group';
  34197. __decorate([
  34198. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  34199. ], CellRendererFactory.prototype, "gridOptionsWrapper", void 0);
  34200. __decorate([
  34201. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('expressionService')
  34202. ], CellRendererFactory.prototype, "expressionService", void 0);
  34203. __decorate([
  34204. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('eventService')
  34205. ], CellRendererFactory.prototype, "eventService", void 0);
  34206. __decorate([
  34207. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  34208. ], CellRendererFactory.prototype, "init", null);
  34209. CellRendererFactory = CellRendererFactory_1 = __decorate([
  34210. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('cellRendererFactory')
  34211. ], CellRendererFactory);
  34212. return CellRendererFactory;
  34213. }());
  34214. /***/ }),
  34215. /* 145 */
  34216. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  34217. "use strict";
  34218. __webpack_require__.r(__webpack_exports__);
  34219. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ValueFormatterService", function() { return ValueFormatterService; });
  34220. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  34221. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  34222. /**
  34223. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  34224. * @version v23.2.1
  34225. * @link http://www.ag-grid.com/
  34226. * @license MIT
  34227. */
  34228. var __extends = (undefined && undefined.__extends) || (function () {
  34229. var extendStatics = function (d, b) {
  34230. extendStatics = Object.setPrototypeOf ||
  34231. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  34232. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  34233. return extendStatics(d, b);
  34234. };
  34235. return function (d, b) {
  34236. extendStatics(d, b);
  34237. function __() { this.constructor = d; }
  34238. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  34239. };
  34240. })();
  34241. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  34242. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  34243. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  34244. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  34245. return c > 3 && r && Object.defineProperty(target, key, r), r;
  34246. };
  34247. var ValueFormatterService = /** @class */ (function (_super) {
  34248. __extends(ValueFormatterService, _super);
  34249. function ValueFormatterService() {
  34250. return _super !== null && _super.apply(this, arguments) || this;
  34251. }
  34252. ValueFormatterService.prototype.formatValue = function (column, node, $scope, value, suppliedFormatter, useFormatterFromColumn) {
  34253. if (useFormatterFromColumn === void 0) { useFormatterFromColumn = true; }
  34254. var result = null;
  34255. var formatter;
  34256. var colDef = column.getColDef();
  34257. if (suppliedFormatter) {
  34258. // use supplied formatter if provided, e.g. set filter items can have their own value formatters
  34259. formatter = suppliedFormatter;
  34260. }
  34261. else if (useFormatterFromColumn) {
  34262. // if row is pinned, give preference to the pinned formatter
  34263. formatter = node && node.rowPinned && colDef.pinnedRowValueFormatter ?
  34264. colDef.pinnedRowValueFormatter : colDef.valueFormatter;
  34265. }
  34266. if (formatter) {
  34267. var params = {
  34268. value: value,
  34269. node: node,
  34270. data: node ? node.data : null,
  34271. colDef: colDef,
  34272. column: column,
  34273. api: this.gridOptionsWrapper.getApi(),
  34274. columnApi: this.gridOptionsWrapper.getColumnApi(),
  34275. context: this.gridOptionsWrapper.getContext()
  34276. };
  34277. // originally we put the angular 1 scope here, but we don't want the scope
  34278. // in the params interface, as other frameworks will see the interface, and
  34279. // angular 1 is not cool any more. so we hack the scope in here (we cannot
  34280. // include it above, as it's not in the interface, so would cause a compile error).
  34281. // in the future, when we stop supporting angular 1, we can take this out.
  34282. params.$scope = $scope;
  34283. result = this.expressionService.evaluate(formatter, params);
  34284. }
  34285. else if (colDef.refData) {
  34286. return colDef.refData[value] || '';
  34287. }
  34288. // if we don't do this, then arrays get displayed as 1,2,3, but we want 1, 2, 3 (i.e. with spaces)
  34289. if (result == null && Array.isArray(value)) {
  34290. result = value.join(', ');
  34291. }
  34292. return result;
  34293. };
  34294. __decorate([
  34295. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  34296. ], ValueFormatterService.prototype, "gridOptionsWrapper", void 0);
  34297. __decorate([
  34298. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('expressionService')
  34299. ], ValueFormatterService.prototype, "expressionService", void 0);
  34300. ValueFormatterService = __decorate([
  34301. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('valueFormatterService')
  34302. ], ValueFormatterService);
  34303. return ValueFormatterService;
  34304. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  34305. /***/ }),
  34306. /* 146 */
  34307. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  34308. "use strict";
  34309. __webpack_require__.r(__webpack_exports__);
  34310. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgRadioButton", function() { return AgRadioButton; });
  34311. /* harmony import */ var _agCheckbox__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(70);
  34312. /* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(44);
  34313. /**
  34314. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  34315. * @version v23.2.1
  34316. * @link http://www.ag-grid.com/
  34317. * @license MIT
  34318. */
  34319. var __extends = (undefined && undefined.__extends) || (function () {
  34320. var extendStatics = function (d, b) {
  34321. extendStatics = Object.setPrototypeOf ||
  34322. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  34323. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  34324. return extendStatics(d, b);
  34325. };
  34326. return function (d, b) {
  34327. extendStatics(d, b);
  34328. function __() { this.constructor = d; }
  34329. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  34330. };
  34331. })();
  34332. var AgRadioButton = /** @class */ (function (_super) {
  34333. __extends(AgRadioButton, _super);
  34334. function AgRadioButton() {
  34335. var _this = _super !== null && _super.apply(this, arguments) || this;
  34336. _this.className = 'ag-radio-button';
  34337. _this.inputType = 'radio';
  34338. return _this;
  34339. }
  34340. AgRadioButton.prototype.isSelected = function () {
  34341. return this.eInput.checked;
  34342. };
  34343. AgRadioButton.prototype.toggle = function () {
  34344. var nextValue = this.getNextValue();
  34345. this.setValue(nextValue);
  34346. };
  34347. AgRadioButton.prototype.addInputListeners = function () {
  34348. _super.prototype.addInputListeners.call(this);
  34349. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CHECKBOX_CHANGED, this.onChange.bind(this));
  34350. };
  34351. /**
  34352. * This ensures that if another radio button in the same named group is selected, we deselect this radio button.
  34353. * By default the browser does this for you, but we are managing classes ourselves in order to ensure input
  34354. * elements are styled correctly in IE11, and the DOM 'changed' event is only fired when a button is selected,
  34355. * not deselected, so we need to use our own event.
  34356. */
  34357. AgRadioButton.prototype.onChange = function (event) {
  34358. if (event.selected &&
  34359. event.name &&
  34360. this.eInput.name &&
  34361. this.eInput.name === event.name &&
  34362. event.id &&
  34363. this.eInput.id !== event.id) {
  34364. this.setValue(false, true);
  34365. }
  34366. };
  34367. return AgRadioButton;
  34368. }(_agCheckbox__WEBPACK_IMPORTED_MODULE_0__["AgCheckbox"]));
  34369. /***/ }),
  34370. /* 147 */
  34371. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  34372. "use strict";
  34373. __webpack_require__.r(__webpack_exports__);
  34374. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "VanillaFrameworkOverrides", function() { return VanillaFrameworkOverrides; });
  34375. /**
  34376. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  34377. * @version v23.2.1
  34378. * @link http://www.ag-grid.com/
  34379. * @license MIT
  34380. */
  34381. /** The base frameworks, eg React & Angular 2, override this bean with implementations specific to their requirement. */
  34382. var VanillaFrameworkOverrides = /** @class */ (function () {
  34383. function VanillaFrameworkOverrides() {
  34384. }
  34385. // for Vanilla JS, we use simple timeout
  34386. VanillaFrameworkOverrides.prototype.setTimeout = function (action, timeout) {
  34387. window.setTimeout(action, timeout);
  34388. };
  34389. // for Vanilla JS, we just add the event to the element
  34390. VanillaFrameworkOverrides.prototype.addEventListenerOutsideAngular = function (element, type, listener, useCapture) {
  34391. element.addEventListener(type, listener, useCapture);
  34392. };
  34393. return VanillaFrameworkOverrides;
  34394. }());
  34395. /***/ }),
  34396. /* 148 */
  34397. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  34398. "use strict";
  34399. __webpack_require__.r(__webpack_exports__);
  34400. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ScrollVisibleService", function() { return ScrollVisibleService; });
  34401. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  34402. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  34403. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43);
  34404. /**
  34405. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  34406. * @version v23.2.1
  34407. * @link http://www.ag-grid.com/
  34408. * @license MIT
  34409. */
  34410. var __extends = (undefined && undefined.__extends) || (function () {
  34411. var extendStatics = function (d, b) {
  34412. extendStatics = Object.setPrototypeOf ||
  34413. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  34414. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  34415. return extendStatics(d, b);
  34416. };
  34417. return function (d, b) {
  34418. extendStatics(d, b);
  34419. function __() { this.constructor = d; }
  34420. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  34421. };
  34422. })();
  34423. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  34424. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  34425. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  34426. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  34427. return c > 3 && r && Object.defineProperty(target, key, r), r;
  34428. };
  34429. var ScrollVisibleService = /** @class */ (function (_super) {
  34430. __extends(ScrollVisibleService, _super);
  34431. function ScrollVisibleService() {
  34432. return _super !== null && _super.apply(this, arguments) || this;
  34433. }
  34434. ScrollVisibleService.prototype.setScrollsVisible = function (params) {
  34435. var atLeastOneDifferent = this.horizontalScrollShowing !== params.horizontalScrollShowing ||
  34436. this.verticalScrollShowing !== params.verticalScrollShowing;
  34437. if (atLeastOneDifferent) {
  34438. this.horizontalScrollShowing = params.horizontalScrollShowing;
  34439. this.verticalScrollShowing = params.verticalScrollShowing;
  34440. var event_1 = {
  34441. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_SCROLL_VISIBILITY_CHANGED,
  34442. api: this.gridApi,
  34443. columnApi: this.columnApi
  34444. };
  34445. this.eventService.dispatchEvent(event_1);
  34446. }
  34447. };
  34448. // used by pagination service - to know page height
  34449. ScrollVisibleService.prototype.isHorizontalScrollShowing = function () {
  34450. return this.horizontalScrollShowing;
  34451. };
  34452. // used by header container
  34453. ScrollVisibleService.prototype.isVerticalScrollShowing = function () {
  34454. return this.verticalScrollShowing;
  34455. };
  34456. __decorate([
  34457. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController')
  34458. ], ScrollVisibleService.prototype, "columnController", void 0);
  34459. __decorate([
  34460. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi')
  34461. ], ScrollVisibleService.prototype, "columnApi", void 0);
  34462. __decorate([
  34463. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi')
  34464. ], ScrollVisibleService.prototype, "gridApi", void 0);
  34465. __decorate([
  34466. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  34467. ], ScrollVisibleService.prototype, "gridOptionsWrapper", void 0);
  34468. ScrollVisibleService = __decorate([
  34469. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('scrollVisibleService')
  34470. ], ScrollVisibleService);
  34471. return ScrollVisibleService;
  34472. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  34473. /***/ }),
  34474. /* 149 */
  34475. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  34476. "use strict";
  34477. __webpack_require__.r(__webpack_exports__);
  34478. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "StylingService", function() { return StylingService; });
  34479. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  34480. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  34481. /**
  34482. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  34483. * @version v23.2.1
  34484. * @link http://www.ag-grid.com/
  34485. * @license MIT
  34486. */
  34487. var __extends = (undefined && undefined.__extends) || (function () {
  34488. var extendStatics = function (d, b) {
  34489. extendStatics = Object.setPrototypeOf ||
  34490. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  34491. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  34492. return extendStatics(d, b);
  34493. };
  34494. return function (d, b) {
  34495. extendStatics(d, b);
  34496. function __() { this.constructor = d; }
  34497. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  34498. };
  34499. })();
  34500. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  34501. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  34502. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  34503. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  34504. return c > 3 && r && Object.defineProperty(target, key, r), r;
  34505. };
  34506. var StylingService = /** @class */ (function (_super) {
  34507. __extends(StylingService, _super);
  34508. function StylingService() {
  34509. return _super !== null && _super.apply(this, arguments) || this;
  34510. }
  34511. StylingService.prototype.processAllCellClasses = function (colDef, params, onApplicableClass, onNotApplicableClass) {
  34512. this.processClassRules(colDef.cellClassRules, params, onApplicableClass, onNotApplicableClass);
  34513. this.processStaticCellClasses(colDef, params, onApplicableClass);
  34514. };
  34515. StylingService.prototype.processClassRules = function (classRules, params, onApplicableClass, onNotApplicableClass) {
  34516. if (typeof classRules === 'object' && classRules !== null) {
  34517. var classNames = Object.keys(classRules);
  34518. for (var i = 0; i < classNames.length; i++) {
  34519. var className = classNames[i];
  34520. var rule = classRules[className];
  34521. var resultOfRule = void 0;
  34522. if (typeof rule === 'string') {
  34523. resultOfRule = this.expressionService.evaluate(rule, params);
  34524. }
  34525. else if (typeof rule === 'function') {
  34526. resultOfRule = rule(params);
  34527. }
  34528. if (resultOfRule) {
  34529. onApplicableClass(className);
  34530. }
  34531. else if (onNotApplicableClass) {
  34532. onNotApplicableClass(className);
  34533. }
  34534. }
  34535. }
  34536. };
  34537. StylingService.prototype.processStaticCellClasses = function (colDef, params, onApplicableClass) {
  34538. var cellClass = colDef.cellClass;
  34539. if (cellClass) {
  34540. var classOrClasses = void 0;
  34541. if (typeof colDef.cellClass === 'function') {
  34542. var cellClassFunc = colDef.cellClass;
  34543. classOrClasses = cellClassFunc(params);
  34544. }
  34545. else {
  34546. classOrClasses = colDef.cellClass;
  34547. }
  34548. if (typeof classOrClasses === 'string') {
  34549. onApplicableClass(classOrClasses);
  34550. }
  34551. else if (Array.isArray(classOrClasses)) {
  34552. classOrClasses.forEach(function (cssClassItem) {
  34553. onApplicableClass(cssClassItem);
  34554. });
  34555. }
  34556. }
  34557. };
  34558. __decorate([
  34559. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('expressionService')
  34560. ], StylingService.prototype, "expressionService", void 0);
  34561. StylingService = __decorate([
  34562. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('stylingService')
  34563. ], StylingService);
  34564. return StylingService;
  34565. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  34566. /***/ }),
  34567. /* 150 */
  34568. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  34569. "use strict";
  34570. __webpack_require__.r(__webpack_exports__);
  34571. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnHoverService", function() { return ColumnHoverService; });
  34572. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  34573. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43);
  34574. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(41);
  34575. /**
  34576. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  34577. * @version v23.2.1
  34578. * @link http://www.ag-grid.com/
  34579. * @license MIT
  34580. */
  34581. var __extends = (undefined && undefined.__extends) || (function () {
  34582. var extendStatics = function (d, b) {
  34583. extendStatics = Object.setPrototypeOf ||
  34584. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  34585. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  34586. return extendStatics(d, b);
  34587. };
  34588. return function (d, b) {
  34589. extendStatics(d, b);
  34590. function __() { this.constructor = d; }
  34591. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  34592. };
  34593. })();
  34594. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  34595. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  34596. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  34597. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  34598. return c > 3 && r && Object.defineProperty(target, key, r), r;
  34599. };
  34600. var ColumnHoverService = /** @class */ (function (_super) {
  34601. __extends(ColumnHoverService, _super);
  34602. function ColumnHoverService() {
  34603. return _super !== null && _super.apply(this, arguments) || this;
  34604. }
  34605. ColumnHoverService.prototype.setMouseOver = function (columns) {
  34606. this.selectedColumns = columns;
  34607. var event = {
  34608. type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_HOVER_CHANGED,
  34609. api: this.gridApi,
  34610. columnApi: this.columnApi
  34611. };
  34612. this.eventService.dispatchEvent(event);
  34613. };
  34614. ColumnHoverService.prototype.clearMouseOver = function () {
  34615. this.selectedColumns = null;
  34616. var event = {
  34617. type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_HOVER_CHANGED,
  34618. api: this.gridApi,
  34619. columnApi: this.columnApi
  34620. };
  34621. this.eventService.dispatchEvent(event);
  34622. };
  34623. ColumnHoverService.prototype.isHovered = function (column) {
  34624. return this.selectedColumns && this.selectedColumns.indexOf(column) >= 0;
  34625. };
  34626. __decorate([
  34627. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi')
  34628. ], ColumnHoverService.prototype, "columnApi", void 0);
  34629. __decorate([
  34630. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi')
  34631. ], ColumnHoverService.prototype, "gridApi", void 0);
  34632. ColumnHoverService = __decorate([
  34633. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('columnHoverService')
  34634. ], ColumnHoverService);
  34635. return ColumnHoverService;
  34636. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"]));
  34637. /***/ }),
  34638. /* 151 */
  34639. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  34640. "use strict";
  34641. __webpack_require__.r(__webpack_exports__);
  34642. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ColumnAnimationService", function() { return ColumnAnimationService; });
  34643. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  34644. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  34645. /**
  34646. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  34647. * @version v23.2.1
  34648. * @link http://www.ag-grid.com/
  34649. * @license MIT
  34650. */
  34651. var __extends = (undefined && undefined.__extends) || (function () {
  34652. var extendStatics = function (d, b) {
  34653. extendStatics = Object.setPrototypeOf ||
  34654. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  34655. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  34656. return extendStatics(d, b);
  34657. };
  34658. return function (d, b) {
  34659. extendStatics(d, b);
  34660. function __() { this.constructor = d; }
  34661. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  34662. };
  34663. })();
  34664. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  34665. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  34666. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  34667. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  34668. return c > 3 && r && Object.defineProperty(target, key, r), r;
  34669. };
  34670. var ColumnAnimationService = /** @class */ (function (_super) {
  34671. __extends(ColumnAnimationService, _super);
  34672. function ColumnAnimationService() {
  34673. var _this = _super !== null && _super.apply(this, arguments) || this;
  34674. _this.executeNextFuncs = [];
  34675. _this.executeLaterFuncs = [];
  34676. _this.active = false;
  34677. _this.animationThreadCount = 0;
  34678. return _this;
  34679. }
  34680. ColumnAnimationService.prototype.registerGridComp = function (gridPanel) {
  34681. this.gridPanel = gridPanel;
  34682. };
  34683. ColumnAnimationService.prototype.isActive = function () {
  34684. return this.active;
  34685. };
  34686. ColumnAnimationService.prototype.start = function () {
  34687. if (this.active) {
  34688. return;
  34689. }
  34690. if (this.gridOptionsWrapper.isSuppressColumnMoveAnimation()) {
  34691. return;
  34692. }
  34693. // if doing RTL, we don't animate open / close as due to how the pixels are inverted,
  34694. // the animation moves all the row the the right rather than to the left (ie it's the static
  34695. // columns that actually get their coordinates updated)
  34696. if (this.gridOptionsWrapper.isEnableRtl()) {
  34697. return;
  34698. }
  34699. this.ensureAnimationCssClassPresent();
  34700. this.active = true;
  34701. };
  34702. ColumnAnimationService.prototype.finish = function () {
  34703. if (!this.active) {
  34704. return;
  34705. }
  34706. this.flush();
  34707. this.active = false;
  34708. };
  34709. ColumnAnimationService.prototype.executeNextVMTurn = function (func) {
  34710. if (this.active) {
  34711. this.executeNextFuncs.push(func);
  34712. }
  34713. else {
  34714. func();
  34715. }
  34716. };
  34717. ColumnAnimationService.prototype.executeLaterVMTurn = function (func) {
  34718. if (this.active) {
  34719. this.executeLaterFuncs.push(func);
  34720. }
  34721. else {
  34722. func();
  34723. }
  34724. };
  34725. ColumnAnimationService.prototype.ensureAnimationCssClassPresent = function () {
  34726. var _this = this;
  34727. // up the count, so we can tell if someone else has updated the count
  34728. // by the time the 'wait' func executes
  34729. this.animationThreadCount++;
  34730. var animationThreadCountCopy = this.animationThreadCount;
  34731. this.gridPanel.setColumnMovingCss(true);
  34732. this.executeLaterFuncs.push(function () {
  34733. // only remove the class if this thread was the last one to update it
  34734. if (_this.animationThreadCount === animationThreadCountCopy) {
  34735. _this.gridPanel.setColumnMovingCss(false);
  34736. }
  34737. });
  34738. };
  34739. ColumnAnimationService.prototype.flush = function () {
  34740. var nowFuncs = this.executeNextFuncs;
  34741. this.executeNextFuncs = [];
  34742. var waitFuncs = this.executeLaterFuncs;
  34743. this.executeLaterFuncs = [];
  34744. if (nowFuncs.length === 0 && waitFuncs.length === 0) {
  34745. return;
  34746. }
  34747. window.setTimeout(function () { return nowFuncs.forEach(function (func) { return func(); }); }, 0);
  34748. window.setTimeout(function () { return waitFuncs.forEach(function (func) { return func(); }); }, 300);
  34749. };
  34750. __decorate([
  34751. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  34752. ], ColumnAnimationService.prototype, "gridOptionsWrapper", void 0);
  34753. ColumnAnimationService = __decorate([
  34754. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('columnAnimationService')
  34755. ], ColumnAnimationService);
  34756. return ColumnAnimationService;
  34757. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  34758. /***/ }),
  34759. /* 152 */
  34760. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  34761. "use strict";
  34762. __webpack_require__.r(__webpack_exports__);
  34763. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AutoGroupColService", function() { return AutoGroupColService; });
  34764. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  34765. /* harmony import */ var _entities_column__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(35);
  34766. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25);
  34767. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(41);
  34768. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7);
  34769. /**
  34770. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  34771. * @version v23.2.1
  34772. * @link http://www.ag-grid.com/
  34773. * @license MIT
  34774. */
  34775. var __extends = (undefined && undefined.__extends) || (function () {
  34776. var extendStatics = function (d, b) {
  34777. extendStatics = Object.setPrototypeOf ||
  34778. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  34779. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  34780. return extendStatics(d, b);
  34781. };
  34782. return function (d, b) {
  34783. extendStatics(d, b);
  34784. function __() { this.constructor = d; }
  34785. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  34786. };
  34787. })();
  34788. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  34789. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  34790. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  34791. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  34792. return c > 3 && r && Object.defineProperty(target, key, r), r;
  34793. };
  34794. var AutoGroupColService = /** @class */ (function (_super) {
  34795. __extends(AutoGroupColService, _super);
  34796. function AutoGroupColService() {
  34797. return _super !== null && _super.apply(this, arguments) || this;
  34798. }
  34799. AutoGroupColService_1 = AutoGroupColService;
  34800. AutoGroupColService.prototype.createAutoGroupColumns = function (rowGroupColumns) {
  34801. var _this = this;
  34802. var groupAutoColumns = [];
  34803. var doingTreeData = this.gridOptionsWrapper.isTreeData();
  34804. var doingMultiAutoColumn = this.gridOptionsWrapper.isGroupMultiAutoColumn();
  34805. if (doingTreeData && doingMultiAutoColumn) {
  34806. console.warn('ag-Grid: you cannot mix groupMultiAutoColumn with treeData, only one column can be used to display groups when doing tree data');
  34807. doingMultiAutoColumn = false;
  34808. }
  34809. // if doing groupMultiAutoColumn, then we call the method multiple times, once
  34810. // for each column we are grouping by
  34811. if (doingMultiAutoColumn) {
  34812. rowGroupColumns.forEach(function (rowGroupCol, index) {
  34813. groupAutoColumns.push(_this.createOneAutoGroupColumn(rowGroupCol, index));
  34814. });
  34815. }
  34816. else {
  34817. groupAutoColumns.push(this.createOneAutoGroupColumn());
  34818. }
  34819. return groupAutoColumns;
  34820. };
  34821. // rowGroupCol and index are missing if groupMultiAutoColumn=false
  34822. AutoGroupColService.prototype.createOneAutoGroupColumn = function (rowGroupCol, index) {
  34823. // if one provided by user, use it, otherwise create one
  34824. var defaultAutoColDef = this.generateDefaultColDef(rowGroupCol);
  34825. // if doing multi, set the field
  34826. var colId;
  34827. if (rowGroupCol) {
  34828. colId = _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].GROUP_AUTO_COLUMN_ID + "-" + rowGroupCol.getId();
  34829. }
  34830. else {
  34831. colId = AutoGroupColService_1.GROUP_AUTO_COLUMN_BUNDLE_ID;
  34832. }
  34833. var userAutoColDef = this.gridOptionsWrapper.getAutoGroupColumnDef();
  34834. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].mergeDeep(defaultAutoColDef, userAutoColDef);
  34835. defaultAutoColDef = this.columnFactory.mergeColDefs(defaultAutoColDef);
  34836. defaultAutoColDef.colId = colId;
  34837. // For tree data the filter is always allowed
  34838. if (!this.gridOptionsWrapper.isTreeData()) {
  34839. // we would only allow filter if the user has provided field or value getter. otherwise the filter
  34840. // would not be able to work.
  34841. var noFieldOrValueGetter = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].missing(defaultAutoColDef.field) && _utils__WEBPACK_IMPORTED_MODULE_4__["_"].missing(defaultAutoColDef.valueGetter) && _utils__WEBPACK_IMPORTED_MODULE_4__["_"].missing(defaultAutoColDef.filterValueGetter);
  34842. if (noFieldOrValueGetter) {
  34843. defaultAutoColDef.filter = false;
  34844. }
  34845. }
  34846. // if showing many cols, we don't want to show more than one with a checkbox for selection
  34847. if (index && index > 0) {
  34848. defaultAutoColDef.headerCheckboxSelection = false;
  34849. }
  34850. var newCol = new _entities_column__WEBPACK_IMPORTED_MODULE_1__["Column"](defaultAutoColDef, null, colId, true);
  34851. this.context.createBean(newCol);
  34852. return newCol;
  34853. };
  34854. AutoGroupColService.prototype.generateDefaultColDef = function (rowGroupCol) {
  34855. var userAutoColDef = this.gridOptionsWrapper.getAutoGroupColumnDef();
  34856. var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();
  34857. var defaultAutoColDef = {
  34858. headerName: localeTextFunc('group', 'Group')
  34859. };
  34860. var userHasProvidedGroupCellRenderer = userAutoColDef && (userAutoColDef.cellRenderer || userAutoColDef.cellRendererFramework);
  34861. // only add the default group cell renderer if user hasn't provided one
  34862. if (!userHasProvidedGroupCellRenderer) {
  34863. defaultAutoColDef.cellRenderer = 'agGroupCellRenderer';
  34864. }
  34865. // we never allow moving the group column
  34866. // defaultAutoColDef.suppressMovable = true;
  34867. if (rowGroupCol) {
  34868. var rowGroupColDef = rowGroupCol.getColDef();
  34869. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].assign(defaultAutoColDef, {
  34870. // cellRendererParams.groupKey: colDefToCopy.field;
  34871. headerName: this.columnController.getDisplayNameForColumn(rowGroupCol, 'header'),
  34872. headerValueGetter: rowGroupColDef.headerValueGetter
  34873. });
  34874. if (rowGroupColDef.cellRenderer) {
  34875. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].assign(defaultAutoColDef, {
  34876. cellRendererParams: {
  34877. innerRenderer: rowGroupColDef.cellRenderer,
  34878. innerRendererParams: rowGroupColDef.cellRendererParams
  34879. }
  34880. });
  34881. }
  34882. defaultAutoColDef.showRowGroup = rowGroupCol.getColId();
  34883. }
  34884. else {
  34885. defaultAutoColDef.showRowGroup = true;
  34886. }
  34887. return defaultAutoColDef;
  34888. };
  34889. var AutoGroupColService_1;
  34890. AutoGroupColService.GROUP_AUTO_COLUMN_BUNDLE_ID = _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].GROUP_AUTO_COLUMN_ID;
  34891. __decorate([
  34892. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  34893. ], AutoGroupColService.prototype, "gridOptionsWrapper", void 0);
  34894. __decorate([
  34895. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController')
  34896. ], AutoGroupColService.prototype, "columnController", void 0);
  34897. __decorate([
  34898. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnFactory')
  34899. ], AutoGroupColService.prototype, "columnFactory", void 0);
  34900. AutoGroupColService = AutoGroupColService_1 = __decorate([
  34901. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('autoGroupColService')
  34902. ], AutoGroupColService);
  34903. return AutoGroupColService;
  34904. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"]));
  34905. /***/ }),
  34906. /* 153 */
  34907. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  34908. "use strict";
  34909. __webpack_require__.r(__webpack_exports__);
  34910. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PaginationProxy", function() { return PaginationProxy; });
  34911. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(41);
  34912. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43);
  34913. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37);
  34914. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  34915. /**
  34916. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  34917. * @version v23.2.1
  34918. * @link http://www.ag-grid.com/
  34919. * @license MIT
  34920. */
  34921. var __extends = (undefined && undefined.__extends) || (function () {
  34922. var extendStatics = function (d, b) {
  34923. extendStatics = Object.setPrototypeOf ||
  34924. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  34925. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  34926. return extendStatics(d, b);
  34927. };
  34928. return function (d, b) {
  34929. extendStatics(d, b);
  34930. function __() { this.constructor = d; }
  34931. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  34932. };
  34933. })();
  34934. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  34935. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  34936. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  34937. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  34938. return c > 3 && r && Object.defineProperty(target, key, r), r;
  34939. };
  34940. var PaginationProxy = /** @class */ (function (_super) {
  34941. __extends(PaginationProxy, _super);
  34942. function PaginationProxy() {
  34943. var _this = _super !== null && _super.apply(this, arguments) || this;
  34944. _this.currentPage = 0;
  34945. _this.topDisplayedRowIndex = 0;
  34946. _this.bottomDisplayedRowIndex = 0;
  34947. _this.pixelOffset = 0;
  34948. _this.masterRowCount = 0;
  34949. return _this;
  34950. }
  34951. PaginationProxy.prototype.postConstruct = function () {
  34952. this.active = this.gridOptionsWrapper.isPagination();
  34953. this.paginateChildRows = this.gridOptionsWrapper.isPaginateChildRows();
  34954. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_MODEL_UPDATED, this.onModelUpdated.bind(this));
  34955. this.addManagedListener(this.gridOptionsWrapper, 'paginationPageSize', this.onModelUpdated.bind(this));
  34956. this.onModelUpdated();
  34957. };
  34958. PaginationProxy.prototype.ensureRowHeightsValid = function (startPixel, endPixel, startLimitIndex, endLimitIndex) {
  34959. var res = this.rowModel.ensureRowHeightsValid(startPixel, endPixel, this.getPageFirstRow(), this.getPageLastRow());
  34960. if (res) {
  34961. this.calculatePages();
  34962. }
  34963. return res;
  34964. };
  34965. PaginationProxy.prototype.onModelUpdated = function (modelUpdatedEvent) {
  34966. this.calculatePages();
  34967. var paginationChangedEvent = {
  34968. type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_PAGINATION_CHANGED,
  34969. animate: modelUpdatedEvent ? modelUpdatedEvent.animate : false,
  34970. newData: modelUpdatedEvent ? modelUpdatedEvent.newData : false,
  34971. newPage: modelUpdatedEvent ? modelUpdatedEvent.newPage : false,
  34972. keepRenderedRows: modelUpdatedEvent ? modelUpdatedEvent.keepRenderedRows : false,
  34973. api: this.gridApi,
  34974. columnApi: this.columnApi
  34975. };
  34976. this.eventService.dispatchEvent(paginationChangedEvent);
  34977. };
  34978. PaginationProxy.prototype.goToPage = function (page) {
  34979. if (!this.active) {
  34980. return;
  34981. }
  34982. if (this.currentPage === page) {
  34983. return;
  34984. }
  34985. this.currentPage = page;
  34986. var event = {
  34987. type: _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_MODEL_UPDATED,
  34988. animate: false,
  34989. keepRenderedRows: false,
  34990. newData: false,
  34991. newPage: true,
  34992. api: this.gridApi,
  34993. columnApi: this.columnApi
  34994. };
  34995. this.onModelUpdated(event);
  34996. };
  34997. PaginationProxy.prototype.getPixelOffset = function () {
  34998. return this.pixelOffset;
  34999. };
  35000. PaginationProxy.prototype.getRow = function (index) {
  35001. return this.rowModel.getRow(index);
  35002. };
  35003. PaginationProxy.prototype.getRowNode = function (id) {
  35004. return this.rowModel.getRowNode(id);
  35005. };
  35006. PaginationProxy.prototype.getRowIndexAtPixel = function (pixel) {
  35007. return this.rowModel.getRowIndexAtPixel(pixel);
  35008. };
  35009. PaginationProxy.prototype.getCurrentPageHeight = function () {
  35010. if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].missing(this.topRowBounds) || _utils__WEBPACK_IMPORTED_MODULE_3__["_"].missing(this.bottomRowBounds)) {
  35011. return 0;
  35012. }
  35013. return Math.max(this.bottomRowBounds.rowTop + this.bottomRowBounds.rowHeight - this.topRowBounds.rowTop, 0);
  35014. };
  35015. PaginationProxy.prototype.isRowPresent = function (rowNode) {
  35016. if (!this.rowModel.isRowPresent(rowNode)) {
  35017. return false;
  35018. }
  35019. var nodeIsInPage = rowNode.rowIndex >= this.topDisplayedRowIndex && rowNode.rowIndex <= this.bottomDisplayedRowIndex;
  35020. return nodeIsInPage;
  35021. };
  35022. PaginationProxy.prototype.isEmpty = function () {
  35023. return this.rowModel.isEmpty();
  35024. };
  35025. PaginationProxy.prototype.isRowsToRender = function () {
  35026. return this.rowModel.isRowsToRender();
  35027. };
  35028. PaginationProxy.prototype.getNodesInRangeForSelection = function (firstInRange, lastInRange) {
  35029. return this.rowModel.getNodesInRangeForSelection(firstInRange, lastInRange);
  35030. };
  35031. PaginationProxy.prototype.forEachNode = function (callback) {
  35032. return this.rowModel.forEachNode(callback);
  35033. };
  35034. PaginationProxy.prototype.getType = function () {
  35035. return this.rowModel.getType();
  35036. };
  35037. PaginationProxy.prototype.getRowBounds = function (index) {
  35038. var res = this.rowModel.getRowBounds(index);
  35039. res.rowIndex = index;
  35040. return res;
  35041. };
  35042. PaginationProxy.prototype.getPageFirstRow = function () {
  35043. return this.topRowBounds ? this.topRowBounds.rowIndex : -1;
  35044. };
  35045. PaginationProxy.prototype.getPageLastRow = function () {
  35046. return this.bottomRowBounds ? this.bottomRowBounds.rowIndex : -1;
  35047. };
  35048. PaginationProxy.prototype.getRowCount = function () {
  35049. return this.rowModel.getRowCount();
  35050. };
  35051. PaginationProxy.prototype.goToPageWithIndex = function (index) {
  35052. if (!this.active) {
  35053. return;
  35054. }
  35055. var pageNumber = Math.floor(index / this.pageSize);
  35056. this.goToPage(pageNumber);
  35057. };
  35058. PaginationProxy.prototype.isLastPageFound = function () {
  35059. return this.rowModel.isLastRowFound();
  35060. };
  35061. PaginationProxy.prototype.getCurrentPage = function () {
  35062. return this.currentPage;
  35063. };
  35064. PaginationProxy.prototype.goToNextPage = function () {
  35065. this.goToPage(this.currentPage + 1);
  35066. };
  35067. PaginationProxy.prototype.goToPreviousPage = function () {
  35068. this.goToPage(this.currentPage - 1);
  35069. };
  35070. PaginationProxy.prototype.goToFirstPage = function () {
  35071. this.goToPage(0);
  35072. };
  35073. PaginationProxy.prototype.goToLastPage = function () {
  35074. var rowCount = this.rowModel.getRowCount();
  35075. var lastPage = Math.floor(rowCount / this.pageSize);
  35076. this.goToPage(lastPage);
  35077. };
  35078. PaginationProxy.prototype.getPageSize = function () {
  35079. return this.pageSize;
  35080. };
  35081. PaginationProxy.prototype.getTotalPages = function () {
  35082. return this.totalPages;
  35083. };
  35084. PaginationProxy.prototype.setPageSize = function () {
  35085. // show put this into super class
  35086. this.pageSize = this.gridOptionsWrapper.getPaginationPageSize();
  35087. if (!(this.pageSize >= 1)) {
  35088. this.pageSize = 100;
  35089. }
  35090. };
  35091. PaginationProxy.prototype.calculatePages = function () {
  35092. if (this.active) {
  35093. this.setPageSize();
  35094. if (this.paginateChildRows) {
  35095. this.calculatePagesAllRows();
  35096. }
  35097. else {
  35098. this.calculatePagesMasterRowsOnly();
  35099. }
  35100. }
  35101. else {
  35102. this.calculatedPagesNotActive();
  35103. }
  35104. this.topRowBounds = this.rowModel.getRowBounds(this.topDisplayedRowIndex);
  35105. if (this.topRowBounds) {
  35106. this.topRowBounds.rowIndex = this.topDisplayedRowIndex;
  35107. }
  35108. this.bottomRowBounds = this.rowModel.getRowBounds(this.bottomDisplayedRowIndex);
  35109. if (this.bottomRowBounds) {
  35110. this.bottomRowBounds.rowIndex = this.bottomDisplayedRowIndex;
  35111. }
  35112. this.pixelOffset = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(this.topRowBounds) ? this.topRowBounds.rowTop : 0;
  35113. };
  35114. PaginationProxy.prototype.setZeroRows = function () {
  35115. this.topDisplayedRowIndex = 0;
  35116. this.bottomDisplayedRowIndex = -1;
  35117. this.currentPage = 0;
  35118. this.totalPages = 0;
  35119. };
  35120. PaginationProxy.prototype.calculatePagesMasterRowsOnly = function () {
  35121. // const csrm = <ClientSideRowModel> this.rowModel;
  35122. // const rootNode = csrm.getRootNode();
  35123. // const masterRows = rootNode.childrenAfterSort;
  35124. this.masterRowCount = this.rowModel.getTopLevelRowCount();
  35125. if (this.masterRowCount === 0) {
  35126. this.setZeroRows();
  35127. return;
  35128. }
  35129. var masterLastRowIndex = this.masterRowCount - 1;
  35130. this.totalPages = Math.floor((masterLastRowIndex) / this.pageSize) + 1;
  35131. if (this.currentPage >= this.totalPages) {
  35132. this.currentPage = this.totalPages - 1;
  35133. }
  35134. if (!_utils__WEBPACK_IMPORTED_MODULE_3__["_"].isNumeric(this.currentPage) || this.currentPage < 0) {
  35135. this.currentPage = 0;
  35136. }
  35137. var masterPageStartIndex = this.pageSize * this.currentPage;
  35138. var masterPageEndIndex = (this.pageSize * (this.currentPage + 1)) - 1;
  35139. if (masterPageEndIndex > masterLastRowIndex) {
  35140. masterPageEndIndex = masterLastRowIndex;
  35141. }
  35142. this.topDisplayedRowIndex = this.rowModel.getTopLevelRowDisplayedIndex(masterPageStartIndex);
  35143. // masterRows[masterPageStartIndex].rowIndex;
  35144. if (masterPageEndIndex === masterLastRowIndex) {
  35145. // if showing the last master row, then we want to show the very last row of the model
  35146. this.bottomDisplayedRowIndex = this.rowModel.getRowCount() - 1;
  35147. }
  35148. else {
  35149. var firstIndexNotToShow = this.rowModel.getTopLevelRowDisplayedIndex(masterPageEndIndex + 1);
  35150. //masterRows[masterPageEndIndex + 1].rowIndex;
  35151. // this gets the index of the last child - eg current row is open, we want to display all children,
  35152. // the index of the last child is one less than the index of the next parent row.
  35153. this.bottomDisplayedRowIndex = firstIndexNotToShow - 1;
  35154. }
  35155. };
  35156. PaginationProxy.prototype.getMasterRowCount = function () {
  35157. return this.masterRowCount;
  35158. };
  35159. PaginationProxy.prototype.calculatePagesAllRows = function () {
  35160. this.masterRowCount = this.rowModel.getRowCount();
  35161. if (this.masterRowCount === 0) {
  35162. this.setZeroRows();
  35163. return;
  35164. }
  35165. var maxRowIndex = this.masterRowCount - 1;
  35166. this.totalPages = Math.floor((maxRowIndex) / this.pageSize) + 1;
  35167. if (this.currentPage >= this.totalPages) {
  35168. this.currentPage = this.totalPages - 1;
  35169. }
  35170. if (!_utils__WEBPACK_IMPORTED_MODULE_3__["_"].isNumeric(this.currentPage) || this.currentPage < 0) {
  35171. this.currentPage = 0;
  35172. }
  35173. this.topDisplayedRowIndex = this.pageSize * this.currentPage;
  35174. this.bottomDisplayedRowIndex = (this.pageSize * (this.currentPage + 1)) - 1;
  35175. if (this.bottomDisplayedRowIndex > maxRowIndex) {
  35176. this.bottomDisplayedRowIndex = maxRowIndex;
  35177. }
  35178. };
  35179. PaginationProxy.prototype.calculatedPagesNotActive = function () {
  35180. this.pageSize = this.rowModel.getRowCount();
  35181. this.totalPages = 1;
  35182. this.currentPage = 0;
  35183. this.topDisplayedRowIndex = 0;
  35184. this.bottomDisplayedRowIndex = this.rowModel.getRowCount() - 1;
  35185. };
  35186. __decorate([
  35187. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('rowModel')
  35188. ], PaginationProxy.prototype, "rowModel", void 0);
  35189. __decorate([
  35190. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper')
  35191. ], PaginationProxy.prototype, "gridOptionsWrapper", void 0);
  35192. __decorate([
  35193. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('selectionController')
  35194. ], PaginationProxy.prototype, "selectionController", void 0);
  35195. __decorate([
  35196. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('columnApi')
  35197. ], PaginationProxy.prototype, "columnApi", void 0);
  35198. __decorate([
  35199. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridApi')
  35200. ], PaginationProxy.prototype, "gridApi", void 0);
  35201. __decorate([
  35202. _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"]
  35203. ], PaginationProxy.prototype, "postConstruct", null);
  35204. PaginationProxy = __decorate([
  35205. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Bean"])('paginationProxy')
  35206. ], PaginationProxy);
  35207. return PaginationProxy;
  35208. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"]));
  35209. /***/ }),
  35210. /* 154 */
  35211. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  35212. "use strict";
  35213. __webpack_require__.r(__webpack_exports__);
  35214. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PaginationAutoPageSizeService", function() { return PaginationAutoPageSizeService; });
  35215. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(41);
  35216. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(43);
  35217. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37);
  35218. /**
  35219. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  35220. * @version v23.2.1
  35221. * @link http://www.ag-grid.com/
  35222. * @license MIT
  35223. */
  35224. var __extends = (undefined && undefined.__extends) || (function () {
  35225. var extendStatics = function (d, b) {
  35226. extendStatics = Object.setPrototypeOf ||
  35227. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  35228. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  35229. return extendStatics(d, b);
  35230. };
  35231. return function (d, b) {
  35232. extendStatics(d, b);
  35233. function __() { this.constructor = d; }
  35234. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  35235. };
  35236. })();
  35237. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  35238. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  35239. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  35240. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  35241. return c > 3 && r && Object.defineProperty(target, key, r), r;
  35242. };
  35243. var PaginationAutoPageSizeService = /** @class */ (function (_super) {
  35244. __extends(PaginationAutoPageSizeService, _super);
  35245. function PaginationAutoPageSizeService() {
  35246. return _super !== null && _super.apply(this, arguments) || this;
  35247. }
  35248. PaginationAutoPageSizeService.prototype.registerGridComp = function (gridPanel) {
  35249. this.gridPanel = gridPanel;
  35250. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_BODY_HEIGHT_CHANGED, this.onBodyHeightChanged.bind(this));
  35251. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_SCROLL_VISIBILITY_CHANGED, this.onScrollVisibilityChanged.bind(this));
  35252. this.checkPageSize();
  35253. };
  35254. PaginationAutoPageSizeService.prototype.notActive = function () {
  35255. return !this.gridOptionsWrapper.isPaginationAutoPageSize();
  35256. };
  35257. PaginationAutoPageSizeService.prototype.onScrollVisibilityChanged = function () {
  35258. this.checkPageSize();
  35259. };
  35260. PaginationAutoPageSizeService.prototype.onBodyHeightChanged = function () {
  35261. this.checkPageSize();
  35262. };
  35263. PaginationAutoPageSizeService.prototype.checkPageSize = function () {
  35264. if (this.notActive()) {
  35265. return;
  35266. }
  35267. var rowHeight = this.gridOptionsWrapper.getRowHeightAsNumber();
  35268. var bodyHeight = this.gridPanel.getBodyHeight();
  35269. if (bodyHeight > 0) {
  35270. var newPageSize = Math.floor(bodyHeight / rowHeight);
  35271. this.gridOptionsWrapper.setProperty('paginationPageSize', newPageSize);
  35272. }
  35273. };
  35274. __decorate([
  35275. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper')
  35276. ], PaginationAutoPageSizeService.prototype, "gridOptionsWrapper", void 0);
  35277. PaginationAutoPageSizeService = __decorate([
  35278. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Bean"])('paginationAutoPageSizeService')
  35279. ], PaginationAutoPageSizeService);
  35280. return PaginationAutoPageSizeService;
  35281. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"]));
  35282. /***/ }),
  35283. /* 155 */
  35284. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  35285. "use strict";
  35286. __webpack_require__.r(__webpack_exports__);
  35287. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ValueCache", function() { return ValueCache; });
  35288. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  35289. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  35290. /**
  35291. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  35292. * @version v23.2.1
  35293. * @link http://www.ag-grid.com/
  35294. * @license MIT
  35295. */
  35296. var __extends = (undefined && undefined.__extends) || (function () {
  35297. var extendStatics = function (d, b) {
  35298. extendStatics = Object.setPrototypeOf ||
  35299. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  35300. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  35301. return extendStatics(d, b);
  35302. };
  35303. return function (d, b) {
  35304. extendStatics(d, b);
  35305. function __() { this.constructor = d; }
  35306. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  35307. };
  35308. })();
  35309. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  35310. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  35311. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  35312. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  35313. return c > 3 && r && Object.defineProperty(target, key, r), r;
  35314. };
  35315. var ValueCache = /** @class */ (function (_super) {
  35316. __extends(ValueCache, _super);
  35317. function ValueCache() {
  35318. var _this = _super !== null && _super.apply(this, arguments) || this;
  35319. _this.cacheVersion = 0;
  35320. return _this;
  35321. }
  35322. ValueCache.prototype.init = function () {
  35323. this.active = this.gridOptionsWrapper.isValueCache();
  35324. this.neverExpires = this.gridOptionsWrapper.isValueCacheNeverExpires();
  35325. };
  35326. ValueCache.prototype.onDataChanged = function () {
  35327. if (this.neverExpires) {
  35328. return;
  35329. }
  35330. this.expire();
  35331. };
  35332. ValueCache.prototype.expire = function () {
  35333. this.cacheVersion++;
  35334. };
  35335. ValueCache.prototype.setValue = function (rowNode, colId, value) {
  35336. if (this.active) {
  35337. if (rowNode.__cacheVersion !== this.cacheVersion) {
  35338. rowNode.__cacheVersion = this.cacheVersion;
  35339. rowNode.__cacheData = {};
  35340. }
  35341. rowNode.__cacheData[colId] = value;
  35342. }
  35343. };
  35344. ValueCache.prototype.getValue = function (rowNode, colId) {
  35345. if (!this.active || rowNode.__cacheVersion !== this.cacheVersion) {
  35346. return undefined;
  35347. }
  35348. return rowNode.__cacheData[colId];
  35349. };
  35350. __decorate([
  35351. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  35352. ], ValueCache.prototype, "gridOptionsWrapper", void 0);
  35353. __decorate([
  35354. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  35355. ], ValueCache.prototype, "init", null);
  35356. ValueCache = __decorate([
  35357. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('valueCache')
  35358. ], ValueCache);
  35359. return ValueCache;
  35360. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  35361. /***/ }),
  35362. /* 156 */
  35363. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  35364. "use strict";
  35365. __webpack_require__.r(__webpack_exports__);
  35366. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ChangeDetectionService", function() { return ChangeDetectionService; });
  35367. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(41);
  35368. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  35369. /* harmony import */ var _utils_changedPath__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(97);
  35370. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25);
  35371. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(43);
  35372. /**
  35373. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  35374. * @version v23.2.1
  35375. * @link http://www.ag-grid.com/
  35376. * @license MIT
  35377. */
  35378. var __extends = (undefined && undefined.__extends) || (function () {
  35379. var extendStatics = function (d, b) {
  35380. extendStatics = Object.setPrototypeOf ||
  35381. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  35382. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  35383. return extendStatics(d, b);
  35384. };
  35385. return function (d, b) {
  35386. extendStatics(d, b);
  35387. function __() { this.constructor = d; }
  35388. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  35389. };
  35390. })();
  35391. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  35392. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  35393. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  35394. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  35395. return c > 3 && r && Object.defineProperty(target, key, r), r;
  35396. };
  35397. var ChangeDetectionService = /** @class */ (function (_super) {
  35398. __extends(ChangeDetectionService, _super);
  35399. function ChangeDetectionService() {
  35400. return _super !== null && _super.apply(this, arguments) || this;
  35401. }
  35402. ChangeDetectionService.prototype.init = function () {
  35403. if (this.rowModel.getType() === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE) {
  35404. this.clientSideRowModel = this.rowModel;
  35405. }
  35406. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_4__["Events"].EVENT_CELL_VALUE_CHANGED, this.onCellValueChanged.bind(this));
  35407. };
  35408. ChangeDetectionService.prototype.onCellValueChanged = function (event) {
  35409. // Clipboard service manages its own change detection, so no need to do it here.
  35410. // The clipboard manages its own as otherwise this would happen once for every cell
  35411. // that got updated as part of a paste operation, so e.g. if 100 cells in a paste operation,
  35412. // this doChangeDetection would get called 100 times (once for each cell), instead clipboard
  35413. // service executes the logic we have here once (in essence batching up all cell changes
  35414. // into one change detection).
  35415. if (event.source === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].SOURCE_PASTE) {
  35416. return;
  35417. }
  35418. this.doChangeDetection(event.node, event.column);
  35419. };
  35420. ChangeDetectionService.prototype.doChangeDetection = function (rowNode, column) {
  35421. if (this.gridOptionsWrapper.isSuppressChangeDetection()) {
  35422. return;
  35423. }
  35424. // step 1 of change detection is to update the aggregated values
  35425. if (this.clientSideRowModel && !rowNode.isRowPinned()) {
  35426. var onlyChangedColumns = this.gridOptionsWrapper.isAggregateOnlyChangedColumns();
  35427. var changedPath = new _utils_changedPath__WEBPACK_IMPORTED_MODULE_2__["ChangedPath"](onlyChangedColumns, this.clientSideRowModel.getRootNode());
  35428. changedPath.addParentNode(rowNode.parent, [column]);
  35429. this.clientSideRowModel.doAggregate(changedPath);
  35430. }
  35431. // step 2 of change detection is to refresh the cells
  35432. this.rowRenderer.refreshCells();
  35433. };
  35434. __decorate([
  35435. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  35436. ], ChangeDetectionService.prototype, "gridOptionsWrapper", void 0);
  35437. __decorate([
  35438. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowModel')
  35439. ], ChangeDetectionService.prototype, "rowModel", void 0);
  35440. __decorate([
  35441. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowRenderer')
  35442. ], ChangeDetectionService.prototype, "rowRenderer", void 0);
  35443. __decorate([
  35444. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  35445. ], ChangeDetectionService.prototype, "init", null);
  35446. ChangeDetectionService = __decorate([
  35447. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('changeDetectionService')
  35448. ], ChangeDetectionService);
  35449. return ChangeDetectionService;
  35450. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"]));
  35451. /***/ }),
  35452. /* 157 */
  35453. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  35454. "use strict";
  35455. __webpack_require__.r(__webpack_exports__);
  35456. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AlignedGridsService", function() { return AlignedGridsService; });
  35457. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(43);
  35458. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  35459. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(41);
  35460. /**
  35461. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  35462. * @version v23.2.1
  35463. * @link http://www.ag-grid.com/
  35464. * @license MIT
  35465. */
  35466. var __extends = (undefined && undefined.__extends) || (function () {
  35467. var extendStatics = function (d, b) {
  35468. extendStatics = Object.setPrototypeOf ||
  35469. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  35470. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  35471. return extendStatics(d, b);
  35472. };
  35473. return function (d, b) {
  35474. extendStatics(d, b);
  35475. function __() { this.constructor = d; }
  35476. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  35477. };
  35478. })();
  35479. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  35480. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  35481. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  35482. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  35483. return c > 3 && r && Object.defineProperty(target, key, r), r;
  35484. };
  35485. var __param = (undefined && undefined.__param) || function (paramIndex, decorator) {
  35486. return function (target, key) { decorator(target, key, paramIndex); }
  35487. };
  35488. var AlignedGridsService = /** @class */ (function (_super) {
  35489. __extends(AlignedGridsService, _super);
  35490. function AlignedGridsService() {
  35491. var _this = _super !== null && _super.apply(this, arguments) || this;
  35492. // flag to mark if we are consuming. to avoid cyclic events (ie other grid firing back to master
  35493. // while processing a master event) we mark this if consuming an event, and if we are, then
  35494. // we don't fire back any events.
  35495. _this.consuming = false;
  35496. return _this;
  35497. }
  35498. AlignedGridsService.prototype.setBeans = function (loggerFactory) {
  35499. this.logger = loggerFactory.create('AlignedGridsService');
  35500. };
  35501. AlignedGridsService.prototype.registerGridComp = function (gridPanel) {
  35502. this.gridPanel = gridPanel;
  35503. };
  35504. AlignedGridsService.prototype.init = function () {
  35505. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_MOVED, this.fireColumnEvent.bind(this));
  35506. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_VISIBLE, this.fireColumnEvent.bind(this));
  35507. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_PINNED, this.fireColumnEvent.bind(this));
  35508. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_GROUP_OPENED, this.fireColumnEvent.bind(this));
  35509. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_RESIZED, this.fireColumnEvent.bind(this));
  35510. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_BODY_SCROLL, this.fireScrollEvent.bind(this));
  35511. };
  35512. // common logic across all the fire methods
  35513. AlignedGridsService.prototype.fireEvent = function (callback) {
  35514. // if we are already consuming, then we are acting on an event from a master,
  35515. // so we don't cause a cyclic firing of events
  35516. if (this.consuming) {
  35517. return;
  35518. }
  35519. // iterate through the aligned grids, and pass each aligned grid service to the callback
  35520. var otherGrids = this.gridOptionsWrapper.getAlignedGrids();
  35521. if (otherGrids) {
  35522. otherGrids.forEach(function (otherGridOptions) {
  35523. if (otherGridOptions.api) {
  35524. var alignedGridService = otherGridOptions.api.__getAlignedGridService();
  35525. callback(alignedGridService);
  35526. }
  35527. });
  35528. }
  35529. };
  35530. // common logic across all consume methods. very little common logic, however extracting
  35531. // guarantees consistency across the methods.
  35532. AlignedGridsService.prototype.onEvent = function (callback) {
  35533. this.consuming = true;
  35534. callback();
  35535. this.consuming = false;
  35536. };
  35537. AlignedGridsService.prototype.fireColumnEvent = function (event) {
  35538. this.fireEvent(function (alignedGridsService) {
  35539. alignedGridsService.onColumnEvent(event);
  35540. });
  35541. };
  35542. AlignedGridsService.prototype.fireScrollEvent = function (event) {
  35543. if (event.direction !== 'horizontal') {
  35544. return;
  35545. }
  35546. this.fireEvent(function (alignedGridsService) {
  35547. alignedGridsService.onScrollEvent(event);
  35548. });
  35549. };
  35550. AlignedGridsService.prototype.onScrollEvent = function (event) {
  35551. var _this = this;
  35552. this.onEvent(function () {
  35553. _this.gridPanel.setHorizontalScrollPosition(event.left);
  35554. });
  35555. };
  35556. AlignedGridsService.prototype.getMasterColumns = function (event) {
  35557. var result = [];
  35558. if (event.columns) {
  35559. event.columns.forEach(function (column) {
  35560. result.push(column);
  35561. });
  35562. }
  35563. else if (event.column) {
  35564. result.push(event.column);
  35565. }
  35566. return result;
  35567. };
  35568. AlignedGridsService.prototype.getColumnIds = function (event) {
  35569. var result = [];
  35570. if (event.columns) {
  35571. event.columns.forEach(function (column) {
  35572. result.push(column.getColId());
  35573. });
  35574. }
  35575. else if (event.column) {
  35576. result.push(event.column.getColId());
  35577. }
  35578. return result;
  35579. };
  35580. AlignedGridsService.prototype.onColumnEvent = function (event) {
  35581. var _this = this;
  35582. this.onEvent(function () {
  35583. switch (event.type) {
  35584. case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_MOVED:
  35585. case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_VISIBLE:
  35586. case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_PINNED:
  35587. case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_RESIZED:
  35588. var colEvent = event;
  35589. _this.processColumnEvent(colEvent);
  35590. break;
  35591. case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_GROUP_OPENED:
  35592. var groupOpenedEvent = event;
  35593. _this.processGroupOpenedEvent(groupOpenedEvent);
  35594. break;
  35595. case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_PIVOT_CHANGED:
  35596. // we cannot support pivoting with aligned grids as the columns will be out of sync as the
  35597. // grids will have columns created based on the row data of the grid.
  35598. console.warn('ag-Grid: pivoting is not supported with aligned grids. ' +
  35599. 'You can only use one of these features at a time in a grid.');
  35600. break;
  35601. }
  35602. });
  35603. };
  35604. AlignedGridsService.prototype.processGroupOpenedEvent = function (groupOpenedEvent) {
  35605. // likewise for column group
  35606. var masterColumnGroup = groupOpenedEvent.columnGroup;
  35607. var otherColumnGroup;
  35608. if (masterColumnGroup) {
  35609. var groupId = masterColumnGroup.getGroupId();
  35610. otherColumnGroup = this.columnController.getOriginalColumnGroup(groupId);
  35611. }
  35612. if (masterColumnGroup && !otherColumnGroup) {
  35613. return;
  35614. }
  35615. this.logger.log('onColumnEvent-> processing ' + groupOpenedEvent + ' expanded = ' + masterColumnGroup.isExpanded());
  35616. this.columnController.setColumnGroupOpened(otherColumnGroup, masterColumnGroup.isExpanded(), "alignedGridChanged");
  35617. };
  35618. AlignedGridsService.prototype.processColumnEvent = function (colEvent) {
  35619. var _this = this;
  35620. // the column in the event is from the master grid. need to
  35621. // look up the equivalent from this (other) grid
  35622. var masterColumn = colEvent.column;
  35623. var otherColumn;
  35624. if (masterColumn) {
  35625. otherColumn = this.columnController.getPrimaryColumn(masterColumn.getColId());
  35626. }
  35627. // if event was with respect to a master column, that is not present in this
  35628. // grid, then we ignore the event
  35629. if (masterColumn && !otherColumn) {
  35630. return;
  35631. }
  35632. // in time, all the methods below should use the column ids, it's a more generic way
  35633. // of handling columns, and also allows for single or multi column events
  35634. var columnIds = this.getColumnIds(colEvent);
  35635. var masterColumns = this.getMasterColumns(colEvent);
  35636. switch (colEvent.type) {
  35637. case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_MOVED:
  35638. var movedEvent = colEvent;
  35639. this.logger.log("onColumnEvent-> processing " + colEvent.type + " toIndex = " + movedEvent.toIndex);
  35640. this.columnController.moveColumns(columnIds, movedEvent.toIndex, "alignedGridChanged");
  35641. break;
  35642. case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_VISIBLE:
  35643. var visibleEvent = colEvent;
  35644. this.logger.log("onColumnEvent-> processing " + colEvent.type + " visible = " + visibleEvent.visible);
  35645. this.columnController.setColumnsVisible(columnIds, visibleEvent.visible, "alignedGridChanged");
  35646. break;
  35647. case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_PINNED:
  35648. var pinnedEvent = colEvent;
  35649. this.logger.log("onColumnEvent-> processing " + colEvent.type + " pinned = " + pinnedEvent.pinned);
  35650. this.columnController.setColumnsPinned(columnIds, pinnedEvent.pinned, "alignedGridChanged");
  35651. break;
  35652. case _events__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_RESIZED:
  35653. var resizedEvent_1 = colEvent;
  35654. masterColumns.forEach(function (column) {
  35655. _this.logger.log("onColumnEvent-> processing " + colEvent.type + " actualWidth = " + column.getActualWidth());
  35656. var columnWidths = [{ key: column.getColId(), newWidth: column.getActualWidth() }];
  35657. _this.columnController.setColumnWidths(columnWidths, false, resizedEvent_1.finished, "alignedGridChanged");
  35658. });
  35659. break;
  35660. }
  35661. var isVerticalScrollShowing = this.gridPanel.isVerticalScrollShowing();
  35662. var alignedGrids = this.gridOptionsWrapper.getAlignedGrids();
  35663. alignedGrids.forEach(function (grid) {
  35664. grid.api.setAlwaysShowVerticalScroll(isVerticalScrollShowing);
  35665. });
  35666. };
  35667. __decorate([
  35668. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  35669. ], AlignedGridsService.prototype, "gridOptionsWrapper", void 0);
  35670. __decorate([
  35671. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController')
  35672. ], AlignedGridsService.prototype, "columnController", void 0);
  35673. __decorate([
  35674. __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Qualifier"])('loggerFactory'))
  35675. ], AlignedGridsService.prototype, "setBeans", null);
  35676. __decorate([
  35677. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  35678. ], AlignedGridsService.prototype, "init", null);
  35679. AlignedGridsService = __decorate([
  35680. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('alignedGridsService')
  35681. ], AlignedGridsService);
  35682. return AlignedGridsService;
  35683. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"]));
  35684. /***/ }),
  35685. /* 158 */
  35686. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  35687. "use strict";
  35688. __webpack_require__.r(__webpack_exports__);
  35689. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgComponentUtils", function() { return AgComponentUtils; });
  35690. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  35691. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  35692. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
  35693. /**
  35694. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  35695. * @version v23.2.1
  35696. * @link http://www.ag-grid.com/
  35697. * @license MIT
  35698. */
  35699. var __extends = (undefined && undefined.__extends) || (function () {
  35700. var extendStatics = function (d, b) {
  35701. extendStatics = Object.setPrototypeOf ||
  35702. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  35703. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  35704. return extendStatics(d, b);
  35705. };
  35706. return function (d, b) {
  35707. extendStatics(d, b);
  35708. function __() { this.constructor = d; }
  35709. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  35710. };
  35711. })();
  35712. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  35713. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  35714. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  35715. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  35716. return c > 3 && r && Object.defineProperty(target, key, r), r;
  35717. };
  35718. var AgComponentUtils = /** @class */ (function (_super) {
  35719. __extends(AgComponentUtils, _super);
  35720. function AgComponentUtils() {
  35721. return _super !== null && _super.apply(this, arguments) || this;
  35722. }
  35723. AgComponentUtils.prototype.adaptFunction = function (propertyName, hardcodedJsFunction, componentFromFramework, source) {
  35724. if (hardcodedJsFunction == null) {
  35725. return {
  35726. component: null,
  35727. componentFromFramework: componentFromFramework,
  35728. source: source,
  35729. paramsFromSelector: null
  35730. };
  35731. }
  35732. var metadata = this.componentMetadataProvider.retrieve(propertyName);
  35733. if (metadata && metadata.functionAdapter) {
  35734. return {
  35735. componentFromFramework: componentFromFramework,
  35736. component: metadata.functionAdapter(hardcodedJsFunction),
  35737. source: source,
  35738. paramsFromSelector: null
  35739. };
  35740. }
  35741. return null;
  35742. };
  35743. AgComponentUtils.prototype.adaptCellRendererFunction = function (callback) {
  35744. var Adapter = /** @class */ (function () {
  35745. function Adapter() {
  35746. }
  35747. Adapter.prototype.refresh = function (params) {
  35748. return false;
  35749. };
  35750. Adapter.prototype.getGui = function () {
  35751. var callbackResult = callback(this.params);
  35752. var type = typeof callbackResult;
  35753. if (type === 'string' || type === 'number' || type === 'boolean') {
  35754. return _utils__WEBPACK_IMPORTED_MODULE_2__["_"].loadTemplate('<span>' + callbackResult + '</span>');
  35755. }
  35756. else {
  35757. return callbackResult;
  35758. }
  35759. };
  35760. Adapter.prototype.init = function (params) {
  35761. this.params = params;
  35762. };
  35763. return Adapter;
  35764. }());
  35765. return Adapter;
  35766. };
  35767. AgComponentUtils.prototype.doesImplementIComponent = function (candidate) {
  35768. if (!candidate) {
  35769. return false;
  35770. }
  35771. return candidate.prototype && 'getGui' in candidate.prototype;
  35772. };
  35773. __decorate([
  35774. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("componentMetadataProvider")
  35775. ], AgComponentUtils.prototype, "componentMetadataProvider", void 0);
  35776. AgComponentUtils = __decorate([
  35777. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])("agComponentUtils")
  35778. ], AgComponentUtils);
  35779. return AgComponentUtils;
  35780. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  35781. /***/ }),
  35782. /* 159 */
  35783. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  35784. "use strict";
  35785. __webpack_require__.r(__webpack_exports__);
  35786. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ComponentMetadataProvider", function() { return ComponentMetadataProvider; });
  35787. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  35788. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  35789. /**
  35790. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  35791. * @version v23.2.1
  35792. * @link http://www.ag-grid.com/
  35793. * @license MIT
  35794. */
  35795. var __extends = (undefined && undefined.__extends) || (function () {
  35796. var extendStatics = function (d, b) {
  35797. extendStatics = Object.setPrototypeOf ||
  35798. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  35799. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  35800. return extendStatics(d, b);
  35801. };
  35802. return function (d, b) {
  35803. extendStatics(d, b);
  35804. function __() { this.constructor = d; }
  35805. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  35806. };
  35807. })();
  35808. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  35809. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  35810. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  35811. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  35812. return c > 3 && r && Object.defineProperty(target, key, r), r;
  35813. };
  35814. var ComponentMetadataProvider = /** @class */ (function (_super) {
  35815. __extends(ComponentMetadataProvider, _super);
  35816. function ComponentMetadataProvider() {
  35817. return _super !== null && _super.apply(this, arguments) || this;
  35818. }
  35819. ComponentMetadataProvider.prototype.postConstruct = function () {
  35820. this.componentMetaData = {
  35821. dateComponent: {
  35822. mandatoryMethodList: ['getDate', 'setDate'],
  35823. optionalMethodList: ['afterGuiAttached', 'setInputPlaceholder']
  35824. },
  35825. detailCellRenderer: {
  35826. mandatoryMethodList: [],
  35827. optionalMethodList: ['refresh']
  35828. },
  35829. headerComponent: {
  35830. mandatoryMethodList: [],
  35831. optionalMethodList: []
  35832. },
  35833. headerGroupComponent: {
  35834. mandatoryMethodList: [],
  35835. optionalMethodList: []
  35836. },
  35837. loadingCellRenderer: {
  35838. mandatoryMethodList: [],
  35839. optionalMethodList: []
  35840. },
  35841. loadingOverlayComponent: {
  35842. mandatoryMethodList: [],
  35843. optionalMethodList: []
  35844. },
  35845. noRowsOverlayComponent: {
  35846. mandatoryMethodList: [],
  35847. optionalMethodList: []
  35848. },
  35849. floatingFilterComponent: {
  35850. mandatoryMethodList: ['onParentModelChanged'],
  35851. optionalMethodList: ['afterGuiAttached']
  35852. },
  35853. floatingFilterWrapperComponent: {
  35854. mandatoryMethodList: [],
  35855. optionalMethodList: []
  35856. },
  35857. cellRenderer: {
  35858. mandatoryMethodList: [],
  35859. optionalMethodList: ['refresh', 'afterGuiAttached'],
  35860. functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)
  35861. },
  35862. cellEditor: {
  35863. mandatoryMethodList: ['getValue'],
  35864. optionalMethodList: ['isPopup', 'isCancelBeforeStart', 'isCancelAfterEnd', 'getPopupPosition', 'focusIn', 'focusOut', 'afterGuiAttached']
  35865. },
  35866. innerRenderer: {
  35867. mandatoryMethodList: [],
  35868. optionalMethodList: ['afterGuiAttached'],
  35869. functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)
  35870. },
  35871. fullWidthCellRenderer: {
  35872. mandatoryMethodList: [],
  35873. optionalMethodList: ['refresh', 'afterGuiAttached'],
  35874. functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)
  35875. },
  35876. pinnedRowCellRenderer: {
  35877. mandatoryMethodList: [],
  35878. optionalMethodList: ['refresh', 'afterGuiAttached'],
  35879. functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)
  35880. },
  35881. groupRowInnerRenderer: {
  35882. mandatoryMethodList: [],
  35883. optionalMethodList: ['afterGuiAttached'],
  35884. functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)
  35885. },
  35886. groupRowRenderer: {
  35887. mandatoryMethodList: [],
  35888. optionalMethodList: ['afterGuiAttached'],
  35889. functionAdapter: this.agComponentUtils.adaptCellRendererFunction.bind(this.agComponentUtils)
  35890. },
  35891. filter: {
  35892. mandatoryMethodList: ['isFilterActive', 'doesFilterPass', 'getModel', 'setModel'],
  35893. optionalMethodList: ['afterGuiAttached', 'onNewRowsLoaded', 'getModelAsString', 'onFloatingFilterChanged']
  35894. },
  35895. filterComponent: {
  35896. mandatoryMethodList: ['isFilterActive', 'doesFilterPass', 'getModel', 'setModel'],
  35897. optionalMethodList: ['afterGuiAttached', 'onNewRowsLoaded', 'getModelAsString', 'onFloatingFilterChanged']
  35898. },
  35899. statusPanel: {
  35900. mandatoryMethodList: [],
  35901. optionalMethodList: ['afterGuiAttached'],
  35902. },
  35903. toolPanel: {
  35904. mandatoryMethodList: [],
  35905. optionalMethodList: ['refresh', 'afterGuiAttached']
  35906. },
  35907. tooltipComponent: {
  35908. mandatoryMethodList: [],
  35909. optionalMethodList: []
  35910. }
  35911. };
  35912. };
  35913. ComponentMetadataProvider.prototype.retrieve = function (name) {
  35914. return this.componentMetaData[name];
  35915. };
  35916. __decorate([
  35917. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("agComponentUtils")
  35918. ], ComponentMetadataProvider.prototype, "agComponentUtils", void 0);
  35919. __decorate([
  35920. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  35921. ], ComponentMetadataProvider.prototype, "postConstruct", null);
  35922. ComponentMetadataProvider = __decorate([
  35923. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])("componentMetadataProvider")
  35924. ], ComponentMetadataProvider);
  35925. return ComponentMetadataProvider;
  35926. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  35927. /***/ }),
  35928. /* 160 */
  35929. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  35930. "use strict";
  35931. __webpack_require__.r(__webpack_exports__);
  35932. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Beans", function() { return Beans; });
  35933. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  35934. /**
  35935. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  35936. * @version v23.2.1
  35937. * @link http://www.ag-grid.com/
  35938. * @license MIT
  35939. */
  35940. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  35941. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  35942. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  35943. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  35944. return c > 3 && r && Object.defineProperty(target, key, r), r;
  35945. };
  35946. /** Using the IoC has a slight performance consideration, which is no problem most of the
  35947. * time, unless we are trashing objects - which is the case when scrolling and rowComp
  35948. * and cellComp. So for performance reasons, RowComp and CellComp do not get autowired
  35949. * with the IoC. Instead they get passed this object which is all the beans the RowComp
  35950. * and CellComp need. Not autowiring all the cells gives performance improvement. */
  35951. var Beans = /** @class */ (function () {
  35952. function Beans() {
  35953. }
  35954. Beans.prototype.registerGridComp = function (gridPanel) {
  35955. this.gridPanel = gridPanel;
  35956. };
  35957. Beans.prototype.postConstruct = function () {
  35958. this.doingMasterDetail = this.gridOptionsWrapper.isMasterDetail();
  35959. };
  35960. __decorate([
  35961. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('paginationProxy')
  35962. ], Beans.prototype, "paginationProxy", void 0);
  35963. __decorate([
  35964. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('context')
  35965. ], Beans.prototype, "context", void 0);
  35966. __decorate([
  35967. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi')
  35968. ], Beans.prototype, "columnApi", void 0);
  35969. __decorate([
  35970. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi')
  35971. ], Beans.prototype, "gridApi", void 0);
  35972. __decorate([
  35973. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  35974. ], Beans.prototype, "gridOptionsWrapper", void 0);
  35975. __decorate([
  35976. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('expressionService')
  35977. ], Beans.prototype, "expressionService", void 0);
  35978. __decorate([
  35979. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer')
  35980. ], Beans.prototype, "rowRenderer", void 0);
  35981. __decorate([
  35982. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('$compile')
  35983. ], Beans.prototype, "$compile", void 0);
  35984. __decorate([
  35985. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('templateService')
  35986. ], Beans.prototype, "templateService", void 0);
  35987. __decorate([
  35988. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueService')
  35989. ], Beans.prototype, "valueService", void 0);
  35990. __decorate([
  35991. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('eventService')
  35992. ], Beans.prototype, "eventService", void 0);
  35993. __decorate([
  35994. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController')
  35995. ], Beans.prototype, "columnController", void 0);
  35996. __decorate([
  35997. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('headerNavigationService')
  35998. ], Beans.prototype, "headerNavigationService", void 0);
  35999. __decorate([
  36000. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnAnimationService')
  36001. ], Beans.prototype, "columnAnimationService", void 0);
  36002. __decorate([
  36003. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])('rangeController')
  36004. ], Beans.prototype, "rangeController", void 0);
  36005. __decorate([
  36006. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusController')
  36007. ], Beans.prototype, "focusController", void 0);
  36008. __decorate([
  36009. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])('contextMenuFactory')
  36010. ], Beans.prototype, "contextMenuFactory", void 0);
  36011. __decorate([
  36012. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('cellRendererFactory')
  36013. ], Beans.prototype, "cellRendererFactory", void 0);
  36014. __decorate([
  36015. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('popupService')
  36016. ], Beans.prototype, "popupService", void 0);
  36017. __decorate([
  36018. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueFormatterService')
  36019. ], Beans.prototype, "valueFormatterService", void 0);
  36020. __decorate([
  36021. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('stylingService')
  36022. ], Beans.prototype, "stylingService", void 0);
  36023. __decorate([
  36024. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnHoverService')
  36025. ], Beans.prototype, "columnHoverService", void 0);
  36026. __decorate([
  36027. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('userComponentFactory')
  36028. ], Beans.prototype, "userComponentFactory", void 0);
  36029. __decorate([
  36030. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('animationFrameService')
  36031. ], Beans.prototype, "taskQueue", void 0);
  36032. __decorate([
  36033. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('dragAndDropService')
  36034. ], Beans.prototype, "dragAndDropService", void 0);
  36035. __decorate([
  36036. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('sortController')
  36037. ], Beans.prototype, "sortController", void 0);
  36038. __decorate([
  36039. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager')
  36040. ], Beans.prototype, "filterManager", void 0);
  36041. __decorate([
  36042. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('maxDivHeightScaler')
  36043. ], Beans.prototype, "maxDivHeightScaler", void 0);
  36044. __decorate([
  36045. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('frameworkOverrides')
  36046. ], Beans.prototype, "frameworkOverrides", void 0);
  36047. __decorate([
  36048. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('detailRowCompCache')
  36049. ], Beans.prototype, "detailRowCompCache", void 0);
  36050. __decorate([
  36051. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('cellPositionUtils')
  36052. ], Beans.prototype, "cellPositionUtils", void 0);
  36053. __decorate([
  36054. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowPositionUtils')
  36055. ], Beans.prototype, "rowPositionUtils", void 0);
  36056. __decorate([
  36057. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('selectionController')
  36058. ], Beans.prototype, "selectionController", void 0);
  36059. __decorate([
  36060. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])('selectionHandleFactory')
  36061. ], Beans.prototype, "selectionHandleFactory", void 0);
  36062. __decorate([
  36063. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  36064. ], Beans.prototype, "postConstruct", null);
  36065. Beans = __decorate([
  36066. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('beans')
  36067. ], Beans);
  36068. return Beans;
  36069. }());
  36070. /***/ }),
  36071. /* 161 */
  36072. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  36073. "use strict";
  36074. __webpack_require__.r(__webpack_exports__);
  36075. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Environment", function() { return Environment; });
  36076. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  36077. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  36078. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
  36079. /**
  36080. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  36081. * @version v23.2.1
  36082. * @link http://www.ag-grid.com/
  36083. * @license MIT
  36084. */
  36085. var __extends = (undefined && undefined.__extends) || (function () {
  36086. var extendStatics = function (d, b) {
  36087. extendStatics = Object.setPrototypeOf ||
  36088. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  36089. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  36090. return extendStatics(d, b);
  36091. };
  36092. return function (d, b) {
  36093. extendStatics(d, b);
  36094. function __() { this.constructor = d; }
  36095. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  36096. };
  36097. })();
  36098. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  36099. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  36100. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  36101. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  36102. return c > 3 && r && Object.defineProperty(target, key, r), r;
  36103. };
  36104. var MAT_GRID_SIZE = 8;
  36105. var BASE_GRID_SIZE = 4;
  36106. var BALHAM_GRID_SIZE = 4;
  36107. var ALPINE_GRID_SIZE = 6;
  36108. var HARD_CODED_SIZES = {
  36109. // this item is required for custom themes
  36110. 'ag-theme-custom': {
  36111. headerHeight: 25,
  36112. headerCellMinWidth: 24,
  36113. listItemHeight: BASE_GRID_SIZE * 5,
  36114. rowHeight: 25,
  36115. chartMenuPanelWidth: 220
  36116. },
  36117. 'ag-theme-material': {
  36118. headerHeight: MAT_GRID_SIZE * 7,
  36119. headerCellMinWidth: 48,
  36120. listItemHeight: MAT_GRID_SIZE * 5,
  36121. rowHeight: MAT_GRID_SIZE * 6,
  36122. chartMenuPanelWidth: 240
  36123. },
  36124. 'ag-theme-balham': {
  36125. headerHeight: BALHAM_GRID_SIZE * 8,
  36126. headerCellMinWidth: 24,
  36127. listItemHeight: BALHAM_GRID_SIZE * 7,
  36128. rowHeight: BALHAM_GRID_SIZE * 7,
  36129. chartMenuPanelWidth: 220
  36130. },
  36131. 'ag-theme-alpine': {
  36132. headerHeight: ALPINE_GRID_SIZE * 8,
  36133. headerCellMinWidth: 36,
  36134. listItemHeight: ALPINE_GRID_SIZE * 5,
  36135. rowHeight: ALPINE_GRID_SIZE * 7,
  36136. chartMenuPanelWidth: 240
  36137. }
  36138. };
  36139. /**
  36140. * this object contains a list of Sass variables and an array
  36141. * of CSS styles required to get the correct value.
  36142. * eg. $virtual-item-height requires a structure, so we can get its height.
  36143. * <div class="ag-theme-balham">
  36144. * <div class="ag-virtual-list-container">
  36145. * <div class="ag-virtual-list-item"></div>
  36146. * </div>
  36147. * </div>
  36148. */
  36149. var SASS_PROPERTY_BUILDER = {
  36150. headerHeight: ['ag-header-row'],
  36151. headerCellMinWidth: ['ag-header-cell'],
  36152. listItemHeight: ['ag-virtual-list-item'],
  36153. rowHeight: ['ag-row'],
  36154. chartMenuPanelWidth: ['ag-chart-docked-container']
  36155. };
  36156. var CALCULATED_SIZES = {};
  36157. var Environment = /** @class */ (function (_super) {
  36158. __extends(Environment, _super);
  36159. function Environment() {
  36160. return _super !== null && _super.apply(this, arguments) || this;
  36161. }
  36162. Environment.prototype.getSassVariable = function (theme, key) {
  36163. var useTheme = 'ag-theme-' + (theme.match('material') ? 'material' : theme.match('balham') ? 'balham' : theme.match('alpine') ? 'alpine' : 'custom');
  36164. var defaultValue = HARD_CODED_SIZES[useTheme][key];
  36165. var calculatedValue = 0;
  36166. if (!CALCULATED_SIZES[theme]) {
  36167. CALCULATED_SIZES[theme] = {};
  36168. }
  36169. if (CALCULATED_SIZES[theme][key]) {
  36170. return CALCULATED_SIZES[theme][key];
  36171. }
  36172. if (SASS_PROPERTY_BUILDER[key]) {
  36173. var classList = SASS_PROPERTY_BUILDER[key];
  36174. var div = document.createElement('div');
  36175. div.style.position = 'absolute';
  36176. var el = classList.reduce(function (el, currentClass, idx) {
  36177. if (idx === 0) {
  36178. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(el, theme);
  36179. }
  36180. var div = document.createElement('div');
  36181. div.style.position = 'static';
  36182. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(div, currentClass);
  36183. el.appendChild(div);
  36184. return div;
  36185. }, div);
  36186. if (document.body) {
  36187. document.body.appendChild(div);
  36188. var sizeName = key.toLowerCase().indexOf('height') !== -1 ? 'height' : 'width';
  36189. calculatedValue = parseInt(window.getComputedStyle(el)[sizeName], 10);
  36190. document.body.removeChild(div);
  36191. }
  36192. }
  36193. CALCULATED_SIZES[theme][key] = calculatedValue || defaultValue;
  36194. return CALCULATED_SIZES[theme][key];
  36195. };
  36196. Environment.prototype.isThemeDark = function () {
  36197. var theme = this.getTheme().theme;
  36198. return !!theme && theme.indexOf('dark') >= 0;
  36199. };
  36200. Environment.prototype.chartMenuPanelWidth = function () {
  36201. var theme = this.getTheme().themeFamily;
  36202. return this.getSassVariable(theme, 'chartMenuPanelWidth');
  36203. };
  36204. Environment.prototype.getTheme = function () {
  36205. var reg = /\bag-(material|(?:theme-([\w\-]*)))\b/;
  36206. var el = this.eGridDiv;
  36207. var themeMatch;
  36208. while (el) {
  36209. themeMatch = reg.exec(el.className);
  36210. if (!themeMatch) {
  36211. el = el.parentElement;
  36212. }
  36213. else {
  36214. break;
  36215. }
  36216. }
  36217. if (!themeMatch) {
  36218. return {};
  36219. }
  36220. var theme = themeMatch[0];
  36221. var usingOldTheme = themeMatch[2] === undefined;
  36222. if (usingOldTheme) {
  36223. var newTheme_1 = theme.replace('ag-', 'ag-theme-');
  36224. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].doOnce(function () { return console.warn("ag-Grid: As of v19 old theme are no longer provided. Please replace " + theme + " with " + newTheme_1 + "."); }, 'using-old-theme');
  36225. }
  36226. return { theme: theme, el: el, themeFamily: theme.replace(/-dark$/, '') };
  36227. };
  36228. __decorate([
  36229. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('eGridDiv')
  36230. ], Environment.prototype, "eGridDiv", void 0);
  36231. Environment = __decorate([
  36232. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('environment')
  36233. ], Environment);
  36234. return Environment;
  36235. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  36236. /***/ }),
  36237. /* 162 */
  36238. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  36239. "use strict";
  36240. __webpack_require__.r(__webpack_exports__);
  36241. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AnimationFrameService", function() { return AnimationFrameService; });
  36242. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  36243. /* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(44);
  36244. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(41);
  36245. /**
  36246. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  36247. * @version v23.2.1
  36248. * @link http://www.ag-grid.com/
  36249. * @license MIT
  36250. */
  36251. var __extends = (undefined && undefined.__extends) || (function () {
  36252. var extendStatics = function (d, b) {
  36253. extendStatics = Object.setPrototypeOf ||
  36254. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  36255. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  36256. return extendStatics(d, b);
  36257. };
  36258. return function (d, b) {
  36259. extendStatics(d, b);
  36260. function __() { this.constructor = d; }
  36261. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  36262. };
  36263. })();
  36264. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  36265. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  36266. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  36267. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  36268. return c > 3 && r && Object.defineProperty(target, key, r), r;
  36269. };
  36270. var AnimationFrameService = /** @class */ (function (_super) {
  36271. __extends(AnimationFrameService, _super);
  36272. function AnimationFrameService() {
  36273. var _this = _super !== null && _super.apply(this, arguments) || this;
  36274. // p1 and p2 are create tasks are to do with row and cell creation.
  36275. // for them we want to execute according to row order, so we use
  36276. // TaskItem so we know what index the item is for.
  36277. _this.createTasksP1 = { list: [], sorted: false }; // eg drawing back-ground of rows
  36278. _this.createTasksP2 = { list: [], sorted: false }; // eg cell renderers, adding hover functionality
  36279. // destroy tasks are to do with row removal. they are done after row creation as the user will need to see new
  36280. // rows first (as blank is scrolled into view), when we remove the old rows (no longer in view) is not as
  36281. // important.
  36282. _this.destroyTasks = [];
  36283. _this.ticking = false;
  36284. // we need to know direction of scroll, to build up rows in the direction of
  36285. // the scroll. eg if user scrolls down, we extend the rows by building down.
  36286. _this.scrollGoingDown = true;
  36287. _this.lastScrollTop = 0;
  36288. _this.taskCount = 0;
  36289. _this.cancelledTasks = new Set();
  36290. return _this;
  36291. }
  36292. AnimationFrameService.prototype.setScrollTop = function (scrollTop) {
  36293. this.scrollGoingDown = scrollTop > this.lastScrollTop;
  36294. this.lastScrollTop = scrollTop;
  36295. };
  36296. AnimationFrameService.prototype.init = function () {
  36297. this.useAnimationFrame = !this.gridOptionsWrapper.isSuppressAnimationFrame();
  36298. };
  36299. // this method is for our ag-Grid sanity only - if animation frames are turned off,
  36300. // then no place in the code should be looking to add any work to be done in animation
  36301. // frames. this stops bugs - where some code is asking for a frame to be executed
  36302. // when it should not.
  36303. AnimationFrameService.prototype.verifyAnimationFrameOn = function (methodName) {
  36304. if (this.useAnimationFrame === false) {
  36305. console.warn("ag-Grid: AnimationFrameService." + methodName + " called but animation frames are off");
  36306. }
  36307. };
  36308. AnimationFrameService.prototype.createTask = function (task, index, list) {
  36309. this.verifyAnimationFrameOn(list);
  36310. var taskItem = { task: task, index: index, createOrder: ++this.taskCount };
  36311. this.addTaskToList(this[list], taskItem);
  36312. this.schedule();
  36313. };
  36314. AnimationFrameService.prototype.cancelTask = function (task) {
  36315. this.cancelledTasks.add(task);
  36316. };
  36317. AnimationFrameService.prototype.addTaskToList = function (taskList, task) {
  36318. taskList.list.push(task);
  36319. taskList.sorted = false;
  36320. };
  36321. AnimationFrameService.prototype.sortTaskList = function (taskList) {
  36322. if (taskList.sorted) {
  36323. return;
  36324. }
  36325. var sortDirection = this.scrollGoingDown ? 1 : -1;
  36326. // sort first by row index (taking into account scroll direction), then by
  36327. // order of task creation (always ascending, so cells will render left-to-right)
  36328. taskList.list.sort(function (a, b) { return a.index !== b.index ? sortDirection * (b.index - a.index) : b.createOrder - a.createOrder; });
  36329. taskList.sorted = true;
  36330. };
  36331. AnimationFrameService.prototype.addDestroyTask = function (task) {
  36332. this.verifyAnimationFrameOn('createTasksP3');
  36333. this.destroyTasks.push(task);
  36334. this.schedule();
  36335. };
  36336. AnimationFrameService.prototype.executeFrame = function (millis) {
  36337. this.verifyAnimationFrameOn('executeFrame');
  36338. var p1TaskList = this.createTasksP1;
  36339. var p1Tasks = p1TaskList.list;
  36340. var p2TaskList = this.createTasksP2;
  36341. var p2Tasks = p2TaskList.list;
  36342. var destroyTasks = this.destroyTasks;
  36343. var frameStart = new Date().getTime();
  36344. var duration = (new Date().getTime()) - frameStart;
  36345. // 16ms is 60 fps
  36346. var noMaxMillis = millis <= 0;
  36347. while (noMaxMillis || duration < millis) {
  36348. var task = void 0;
  36349. if (p1Tasks.length) {
  36350. this.sortTaskList(p1TaskList);
  36351. task = p1Tasks.pop().task;
  36352. }
  36353. else if (p2Tasks.length) {
  36354. this.sortTaskList(p2TaskList);
  36355. task = p2Tasks.pop().task;
  36356. }
  36357. else if (destroyTasks.length) {
  36358. task = destroyTasks.pop();
  36359. }
  36360. else {
  36361. this.cancelledTasks.clear();
  36362. break;
  36363. }
  36364. if (!this.cancelledTasks.has(task)) {
  36365. task();
  36366. }
  36367. duration = (new Date().getTime()) - frameStart;
  36368. }
  36369. if (p1Tasks.length || p2Tasks.length || destroyTasks.length) {
  36370. this.requestFrame();
  36371. }
  36372. else {
  36373. this.stopTicking();
  36374. }
  36375. };
  36376. AnimationFrameService.prototype.stopTicking = function () {
  36377. this.ticking = false;
  36378. var event = {
  36379. type: _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_ANIMATION_QUEUE_EMPTY,
  36380. columnApi: this.gridOptionsWrapper.getColumnApi(),
  36381. api: this.gridOptionsWrapper.getApi()
  36382. };
  36383. this.eventService.dispatchEvent(event);
  36384. };
  36385. AnimationFrameService.prototype.flushAllFrames = function () {
  36386. if (!this.useAnimationFrame) {
  36387. return;
  36388. }
  36389. this.executeFrame(-1);
  36390. };
  36391. AnimationFrameService.prototype.schedule = function () {
  36392. if (!this.useAnimationFrame) {
  36393. return;
  36394. }
  36395. if (!this.ticking) {
  36396. this.ticking = true;
  36397. this.requestFrame();
  36398. }
  36399. };
  36400. AnimationFrameService.prototype.requestFrame = function () {
  36401. // check for the existence of requestAnimationFrame, and if
  36402. // it's missing, then we polyfill it with setTimeout()
  36403. var callback = this.executeFrame.bind(this, 60);
  36404. if (window.requestAnimationFrame) {
  36405. window.requestAnimationFrame(callback);
  36406. }
  36407. else if (window.webkitRequestAnimationFrame) {
  36408. window.webkitRequestAnimationFrame(callback);
  36409. }
  36410. else {
  36411. window.setTimeout(callback, 0);
  36412. }
  36413. };
  36414. AnimationFrameService.prototype.isQueueEmpty = function () {
  36415. return !this.ticking;
  36416. };
  36417. __decorate([
  36418. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  36419. ], AnimationFrameService.prototype, "gridOptionsWrapper", void 0);
  36420. __decorate([
  36421. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  36422. ], AnimationFrameService.prototype, "init", null);
  36423. AnimationFrameService = __decorate([
  36424. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('animationFrameService')
  36425. ], AnimationFrameService);
  36426. return AnimationFrameService;
  36427. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"]));
  36428. /***/ }),
  36429. /* 163 */
  36430. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  36431. "use strict";
  36432. __webpack_require__.r(__webpack_exports__);
  36433. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "NavigationService", function() { return NavigationService; });
  36434. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  36435. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(25);
  36436. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(41);
  36437. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  36438. /**
  36439. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  36440. * @version v23.2.1
  36441. * @link http://www.ag-grid.com/
  36442. * @license MIT
  36443. */
  36444. var __extends = (undefined && undefined.__extends) || (function () {
  36445. var extendStatics = function (d, b) {
  36446. extendStatics = Object.setPrototypeOf ||
  36447. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  36448. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  36449. return extendStatics(d, b);
  36450. };
  36451. return function (d, b) {
  36452. extendStatics(d, b);
  36453. function __() { this.constructor = d; }
  36454. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  36455. };
  36456. })();
  36457. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  36458. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  36459. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  36460. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  36461. return c > 3 && r && Object.defineProperty(target, key, r), r;
  36462. };
  36463. var NavigationService = /** @class */ (function (_super) {
  36464. __extends(NavigationService, _super);
  36465. function NavigationService() {
  36466. var _this = _super !== null && _super.apply(this, arguments) || this;
  36467. _this.timeLastPageEventProcessed = 0;
  36468. return _this;
  36469. }
  36470. NavigationService.prototype.init = function () {
  36471. this.scrollWidth = this.gridOptionsWrapper.getScrollbarWidth();
  36472. };
  36473. NavigationService.prototype.registerGridComp = function (gridPanel) {
  36474. this.gridPanel = gridPanel;
  36475. };
  36476. NavigationService.prototype.handlePageScrollingKey = function (event) {
  36477. var key = event.which || event.keyCode;
  36478. var alt = event.altKey;
  36479. var ctrl = event.ctrlKey;
  36480. var currentCell = this.mouseEventService.getCellPositionForEvent(event);
  36481. if (!currentCell) {
  36482. return false;
  36483. }
  36484. var processed = false;
  36485. switch (key) {
  36486. case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_PAGE_HOME:
  36487. case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_PAGE_END:
  36488. // handle home and end when ctrl & alt are NOT pressed
  36489. if (!ctrl && !alt) {
  36490. this.onHomeOrEndKey(key);
  36491. processed = true;
  36492. }
  36493. break;
  36494. case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_LEFT:
  36495. case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_RIGHT:
  36496. // handle left and right when ctrl is pressed only
  36497. if (ctrl && !alt) {
  36498. this.onCtrlLeftOrRight(key, currentCell);
  36499. processed = true;
  36500. }
  36501. break;
  36502. case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_UP:
  36503. case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_DOWN:
  36504. // handle up and down when ctrl is pressed only
  36505. if (ctrl && !alt) {
  36506. this.onCtrlUpOrDown(key, currentCell);
  36507. processed = true;
  36508. }
  36509. break;
  36510. case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_PAGE_DOWN:
  36511. // handle page up and page down when ctrl & alt are NOT pressed
  36512. if (!ctrl && !alt) {
  36513. this.onPageDown(currentCell);
  36514. processed = true;
  36515. }
  36516. break;
  36517. case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_PAGE_UP:
  36518. // handle page up and page down when ctrl & alt are NOT pressed
  36519. if (!ctrl && !alt) {
  36520. this.onPageUp(currentCell);
  36521. processed = true;
  36522. }
  36523. break;
  36524. }
  36525. if (processed) {
  36526. event.preventDefault();
  36527. }
  36528. return processed;
  36529. };
  36530. // the page up/down keys caused a problem, in that if the user
  36531. // held the page up/down key down, lots of events got generated,
  36532. // which clogged up the event queue (as they take time to process)
  36533. // which in turn froze the grid. Logic below makes sure we wait 100ms
  36534. // between processing the page up/down events, so when user has finger
  36535. // held down on key, we ignore page up/down events until 100ms has passed,
  36536. // which effectively empties the queue of page up/down events.
  36537. NavigationService.prototype.isTimeSinceLastPageEventToRecent = function () {
  36538. var now = new Date().getTime();
  36539. var diff = now - this.timeLastPageEventProcessed;
  36540. return (diff < 100);
  36541. };
  36542. NavigationService.prototype.setTimeLastPageEventProcessed = function () {
  36543. this.timeLastPageEventProcessed = new Date().getTime();
  36544. };
  36545. NavigationService.prototype.onPageDown = function (gridCell) {
  36546. if (this.isTimeSinceLastPageEventToRecent()) {
  36547. return;
  36548. }
  36549. var scrollPosition = this.gridPanel.getVScrollPosition();
  36550. var pixelsInOnePage = scrollPosition.bottom - scrollPosition.top;
  36551. if (this.gridPanel.isHorizontalScrollShowing()) {
  36552. pixelsInOnePage -= this.scrollWidth;
  36553. }
  36554. var pagingPixelOffset = this.paginationProxy.getPixelOffset();
  36555. var currentPageBottomPixel = scrollPosition.top + pixelsInOnePage;
  36556. var currentPageBottomRow = this.paginationProxy.getRowIndexAtPixel(currentPageBottomPixel + pagingPixelOffset);
  36557. var scrollIndex = currentPageBottomRow;
  36558. var currentCellPixel = this.paginationProxy.getRow(gridCell.rowIndex).rowTop;
  36559. var nextCellPixel = currentCellPixel + pixelsInOnePage - pagingPixelOffset;
  36560. var focusIndex = this.paginationProxy.getRowIndexAtPixel(nextCellPixel + pagingPixelOffset);
  36561. var pageLastRow = this.paginationProxy.getPageLastRow();
  36562. if (focusIndex > pageLastRow) {
  36563. focusIndex = pageLastRow;
  36564. }
  36565. if (scrollIndex > pageLastRow) {
  36566. scrollIndex = pageLastRow;
  36567. }
  36568. this.navigateTo(scrollIndex, 'top', null, focusIndex, gridCell.column);
  36569. this.setTimeLastPageEventProcessed();
  36570. };
  36571. NavigationService.prototype.onPageUp = function (gridCell) {
  36572. if (this.isTimeSinceLastPageEventToRecent()) {
  36573. return;
  36574. }
  36575. var scrollPosition = this.gridPanel.getVScrollPosition();
  36576. var pixelsInOnePage = scrollPosition.bottom - scrollPosition.top;
  36577. if (this.gridPanel.isHorizontalScrollShowing()) {
  36578. pixelsInOnePage -= this.scrollWidth;
  36579. }
  36580. var pagingPixelOffset = this.paginationProxy.getPixelOffset();
  36581. var currentPageTopPixel = scrollPosition.top;
  36582. var currentPageTopRow = this.paginationProxy.getRowIndexAtPixel(currentPageTopPixel + pagingPixelOffset);
  36583. var scrollIndex = currentPageTopRow;
  36584. var currentRowNode = this.paginationProxy.getRow(gridCell.rowIndex);
  36585. var nextCellPixel = currentRowNode.rowTop + currentRowNode.rowHeight - pixelsInOnePage - pagingPixelOffset;
  36586. var focusIndex = this.paginationProxy.getRowIndexAtPixel(nextCellPixel + pagingPixelOffset);
  36587. var firstRow = this.paginationProxy.getPageFirstRow();
  36588. if (focusIndex < firstRow) {
  36589. focusIndex = firstRow;
  36590. }
  36591. if (scrollIndex < firstRow) {
  36592. scrollIndex = firstRow;
  36593. }
  36594. this.navigateTo(scrollIndex, 'bottom', null, focusIndex, gridCell.column);
  36595. this.setTimeLastPageEventProcessed();
  36596. };
  36597. // common logic to navigate. takes parameters:
  36598. // scrollIndex - what row to vertically scroll to
  36599. // scrollType - what position to put scroll index ie top/bottom
  36600. // scrollColumn - what column to horizontally scroll to
  36601. // focusIndex / focusColumn - for page up / down, we want to scroll to one row/column, but focus another
  36602. NavigationService.prototype.navigateTo = function (scrollIndex, scrollType, scrollColumn, focusIndex, focusColumn) {
  36603. if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(scrollColumn)) {
  36604. this.gridPanel.ensureColumnVisible(scrollColumn);
  36605. }
  36606. if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(scrollIndex)) {
  36607. this.gridPanel.ensureIndexVisible(scrollIndex, scrollType);
  36608. }
  36609. // make sure the cell is rendered, needed if we are to focus
  36610. this.animationFrameService.flushAllFrames();
  36611. // if we don't do this, the range will be left on the last cell, which will leave the last focused cell
  36612. // highlighted.
  36613. this.focusController.setFocusedCell(focusIndex, focusColumn, null, true);
  36614. if (this.rangeController) {
  36615. var cellPosition = { rowIndex: focusIndex, rowPinned: null, column: focusColumn };
  36616. this.rangeController.setRangeToCell(cellPosition);
  36617. }
  36618. };
  36619. // ctrl + up/down will bring focus to same column, first/last row. no horizontal scrolling.
  36620. NavigationService.prototype.onCtrlUpOrDown = function (key, gridCell) {
  36621. var upKey = key === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_UP;
  36622. var rowIndexToScrollTo = upKey ? 0 : this.paginationProxy.getPageLastRow();
  36623. this.navigateTo(rowIndexToScrollTo, null, gridCell.column, rowIndexToScrollTo, gridCell.column);
  36624. };
  36625. // ctrl + left/right will bring focus to same row, first/last cell. no vertical scrolling.
  36626. NavigationService.prototype.onCtrlLeftOrRight = function (key, gridCell) {
  36627. var leftKey = key === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_LEFT;
  36628. var allColumns = this.columnController.getAllDisplayedColumns();
  36629. var columnToSelect = leftKey ? allColumns[0] : _utils__WEBPACK_IMPORTED_MODULE_3__["_"].last(allColumns);
  36630. this.navigateTo(gridCell.rowIndex, null, columnToSelect, gridCell.rowIndex, columnToSelect);
  36631. };
  36632. // home brings focus to top left cell, end brings focus to bottom right, grid scrolled to bring
  36633. // same cell into view (which means either scroll all the way up, or all the way down).
  36634. NavigationService.prototype.onHomeOrEndKey = function (key) {
  36635. var homeKey = key === _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].KEY_PAGE_HOME;
  36636. var allColumns = this.columnController.getAllDisplayedColumns();
  36637. var columnToSelect = homeKey ? allColumns[0] : _utils__WEBPACK_IMPORTED_MODULE_3__["_"].last(allColumns);
  36638. var rowIndexToScrollTo = homeKey ? 0 : this.paginationProxy.getPageLastRow();
  36639. this.navigateTo(rowIndexToScrollTo, null, columnToSelect, rowIndexToScrollTo, columnToSelect);
  36640. };
  36641. __decorate([
  36642. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('mouseEventService')
  36643. ], NavigationService.prototype, "mouseEventService", void 0);
  36644. __decorate([
  36645. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('paginationProxy')
  36646. ], NavigationService.prototype, "paginationProxy", void 0);
  36647. __decorate([
  36648. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusController')
  36649. ], NavigationService.prototype, "focusController", void 0);
  36650. __decorate([
  36651. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('animationFrameService')
  36652. ], NavigationService.prototype, "animationFrameService", void 0);
  36653. __decorate([
  36654. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Optional"])('rangeController')
  36655. ], NavigationService.prototype, "rangeController", void 0);
  36656. __decorate([
  36657. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController')
  36658. ], NavigationService.prototype, "columnController", void 0);
  36659. __decorate([
  36660. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  36661. ], NavigationService.prototype, "gridOptionsWrapper", void 0);
  36662. __decorate([
  36663. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  36664. ], NavigationService.prototype, "init", null);
  36665. NavigationService = __decorate([
  36666. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('navigationService')
  36667. ], NavigationService);
  36668. return NavigationService;
  36669. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"]));
  36670. /***/ }),
  36671. /* 164 */
  36672. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  36673. "use strict";
  36674. __webpack_require__.r(__webpack_exports__);
  36675. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MaxDivHeightScaler", function() { return MaxDivHeightScaler; });
  36676. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(41);
  36677. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  36678. /* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(44);
  36679. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  36680. /**
  36681. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  36682. * @version v23.2.1
  36683. * @link http://www.ag-grid.com/
  36684. * @license MIT
  36685. */
  36686. var __extends = (undefined && undefined.__extends) || (function () {
  36687. var extendStatics = function (d, b) {
  36688. extendStatics = Object.setPrototypeOf ||
  36689. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  36690. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  36691. return extendStatics(d, b);
  36692. };
  36693. return function (d, b) {
  36694. extendStatics(d, b);
  36695. function __() { this.constructor = d; }
  36696. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  36697. };
  36698. })();
  36699. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  36700. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  36701. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  36702. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  36703. return c > 3 && r && Object.defineProperty(target, key, r), r;
  36704. };
  36705. /**
  36706. * This class solves the 'max height' problem, where the user might want to show more data than
  36707. * the max div height actually allows.
  36708. */
  36709. var MaxDivHeightScaler = /** @class */ (function (_super) {
  36710. __extends(MaxDivHeightScaler, _super);
  36711. function MaxDivHeightScaler() {
  36712. var _this = _super !== null && _super.apply(this, arguments) || this;
  36713. // the scrollY position
  36714. _this.scrollY = 0;
  36715. // how tall the body is
  36716. _this.uiBodyHeight = 0;
  36717. return _this;
  36718. }
  36719. MaxDivHeightScaler.prototype.postConstruct = function () {
  36720. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_BODY_HEIGHT_CHANGED, this.updateOffset.bind(this));
  36721. this.scrollBarWidth = this.gridOptionsWrapper.getScrollbarWidth();
  36722. this.maxDivHeight = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].getMaxDivHeight();
  36723. };
  36724. MaxDivHeightScaler.prototype.registerGridComp = function (gridPanel) {
  36725. this.gridPanel = gridPanel;
  36726. };
  36727. MaxDivHeightScaler.prototype.isScaling = function () {
  36728. return this.scaling;
  36729. };
  36730. MaxDivHeightScaler.prototype.getOffset = function () {
  36731. return this.offset;
  36732. };
  36733. MaxDivHeightScaler.prototype.updateOffset = function () {
  36734. if (!this.scaling) {
  36735. return;
  36736. }
  36737. var newScrollY = this.gridPanel.getVScrollPosition().top;
  36738. var newBodyHeight = this.getUiBodyHeight();
  36739. var atLeastOneChanged = newScrollY !== this.scrollY || newBodyHeight !== this.uiBodyHeight;
  36740. if (atLeastOneChanged) {
  36741. this.scrollY = newScrollY;
  36742. this.uiBodyHeight = newBodyHeight;
  36743. this.calculateOffset();
  36744. }
  36745. };
  36746. MaxDivHeightScaler.prototype.calculateOffset = function () {
  36747. this.uiContainerHeight = this.maxDivHeight;
  36748. this.pixelsToShave = this.modelHeight - this.uiContainerHeight;
  36749. this.maxScrollY = this.uiContainerHeight - this.uiBodyHeight;
  36750. var scrollPercent = this.scrollY / this.maxScrollY;
  36751. this.setOffset(scrollPercent * this.pixelsToShave);
  36752. };
  36753. MaxDivHeightScaler.prototype.clearOffset = function () {
  36754. this.uiContainerHeight = this.modelHeight;
  36755. this.pixelsToShave = 0;
  36756. this.setOffset(0);
  36757. };
  36758. MaxDivHeightScaler.prototype.setOffset = function (newOffset) {
  36759. // because we are talking pixels, no point in confusing things with half numbers
  36760. var newOffsetFloor = typeof newOffset === 'number' ? Math.floor(newOffset) : null;
  36761. if (this.offset === newOffsetFloor) {
  36762. return;
  36763. }
  36764. this.offset = newOffsetFloor;
  36765. this.eventService.dispatchEvent({ type: _eventKeys__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_HEIGHT_SCALE_CHANGED });
  36766. };
  36767. MaxDivHeightScaler.prototype.setModelHeight = function (modelHeight) {
  36768. this.modelHeight = modelHeight;
  36769. this.scaling = this.maxDivHeight > 0 && modelHeight > this.maxDivHeight;
  36770. if (this.scaling) {
  36771. this.calculateOffset();
  36772. }
  36773. else {
  36774. this.clearOffset();
  36775. }
  36776. };
  36777. MaxDivHeightScaler.prototype.getUiContainerHeight = function () {
  36778. return this.uiContainerHeight;
  36779. };
  36780. MaxDivHeightScaler.prototype.getRealPixelPosition = function (modelPixel) {
  36781. return modelPixel - this.offset;
  36782. };
  36783. MaxDivHeightScaler.prototype.getUiBodyHeight = function () {
  36784. var pos = this.gridPanel.getVScrollPosition();
  36785. return pos.bottom - pos.top;
  36786. };
  36787. MaxDivHeightScaler.prototype.getScrollPositionForPixel = function (rowTop) {
  36788. if (this.pixelsToShave <= 0) {
  36789. return rowTop;
  36790. }
  36791. var modelMaxScroll = this.modelHeight - this.getUiBodyHeight();
  36792. var scrollPercent = rowTop / modelMaxScroll;
  36793. var scrollPixel = this.maxScrollY * scrollPercent;
  36794. return scrollPixel;
  36795. };
  36796. __decorate([
  36797. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  36798. ], MaxDivHeightScaler.prototype, "gridOptionsWrapper", void 0);
  36799. __decorate([
  36800. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  36801. ], MaxDivHeightScaler.prototype, "postConstruct", null);
  36802. MaxDivHeightScaler = __decorate([
  36803. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('maxDivHeightScaler')
  36804. ], MaxDivHeightScaler);
  36805. return MaxDivHeightScaler;
  36806. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"]));
  36807. /***/ }),
  36808. /* 165 */
  36809. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  36810. "use strict";
  36811. __webpack_require__.r(__webpack_exports__);
  36812. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SelectableService", function() { return SelectableService; });
  36813. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  36814. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7);
  36815. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(41);
  36816. /**
  36817. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  36818. * @version v23.2.1
  36819. * @link http://www.ag-grid.com/
  36820. * @license MIT
  36821. */
  36822. var __extends = (undefined && undefined.__extends) || (function () {
  36823. var extendStatics = function (d, b) {
  36824. extendStatics = Object.setPrototypeOf ||
  36825. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  36826. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  36827. return extendStatics(d, b);
  36828. };
  36829. return function (d, b) {
  36830. extendStatics(d, b);
  36831. function __() { this.constructor = d; }
  36832. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  36833. };
  36834. })();
  36835. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  36836. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  36837. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  36838. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  36839. return c > 3 && r && Object.defineProperty(target, key, r), r;
  36840. };
  36841. var SelectableService = /** @class */ (function (_super) {
  36842. __extends(SelectableService, _super);
  36843. function SelectableService() {
  36844. return _super !== null && _super.apply(this, arguments) || this;
  36845. }
  36846. SelectableService.prototype.init = function () {
  36847. this.groupSelectsChildren = this.gridOptionsWrapper.isGroupSelectsChildren();
  36848. this.isRowSelectableFunc = this.gridOptionsWrapper.getIsRowSelectableFunc();
  36849. };
  36850. SelectableService.prototype.updateSelectableAfterGrouping = function (rowNode) {
  36851. if (this.isRowSelectableFunc) {
  36852. var nextChildrenFunc = function (rowNode) { return rowNode.childrenAfterGroup; };
  36853. this.recurseDown(rowNode.childrenAfterGroup, nextChildrenFunc);
  36854. }
  36855. };
  36856. SelectableService.prototype.updateSelectableAfterFiltering = function (rowNode) {
  36857. if (this.isRowSelectableFunc) {
  36858. var nextChildrenFunc = function (rowNode) { return rowNode.childrenAfterFilter; };
  36859. this.recurseDown(rowNode.childrenAfterGroup, nextChildrenFunc);
  36860. }
  36861. };
  36862. SelectableService.prototype.recurseDown = function (children, nextChildrenFunc) {
  36863. var _this = this;
  36864. children.forEach(function (child) {
  36865. if (!child.group) {
  36866. return;
  36867. } // only interested in groups
  36868. if (child.hasChildren()) {
  36869. _this.recurseDown(nextChildrenFunc(child), nextChildrenFunc);
  36870. }
  36871. var rowSelectable;
  36872. if (_this.groupSelectsChildren) {
  36873. // have this group selectable if at least one direct child is selectable
  36874. var firstSelectable = _utils__WEBPACK_IMPORTED_MODULE_1__["_"].find(nextChildrenFunc(child), 'selectable', true);
  36875. rowSelectable = _utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(firstSelectable);
  36876. }
  36877. else {
  36878. // directly retrieve selectable value from user callback
  36879. rowSelectable = _this.isRowSelectableFunc ? _this.isRowSelectableFunc(child) : false;
  36880. }
  36881. child.setRowSelectable(rowSelectable);
  36882. });
  36883. };
  36884. __decorate([
  36885. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  36886. ], SelectableService.prototype, "gridOptionsWrapper", void 0);
  36887. __decorate([
  36888. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  36889. ], SelectableService.prototype, "init", null);
  36890. SelectableService = __decorate([
  36891. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('selectableService')
  36892. ], SelectableService);
  36893. return SelectableService;
  36894. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"]));
  36895. /***/ }),
  36896. /* 166 */
  36897. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  36898. "use strict";
  36899. __webpack_require__.r(__webpack_exports__);
  36900. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AutoHeightCalculator", function() { return AutoHeightCalculator; });
  36901. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  36902. /* harmony import */ var _cellComp__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(101);
  36903. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
  36904. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(41);
  36905. /**
  36906. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  36907. * @version v23.2.1
  36908. * @link http://www.ag-grid.com/
  36909. * @license MIT
  36910. */
  36911. var __extends = (undefined && undefined.__extends) || (function () {
  36912. var extendStatics = function (d, b) {
  36913. extendStatics = Object.setPrototypeOf ||
  36914. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  36915. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  36916. return extendStatics(d, b);
  36917. };
  36918. return function (d, b) {
  36919. extendStatics(d, b);
  36920. function __() { this.constructor = d; }
  36921. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  36922. };
  36923. })();
  36924. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  36925. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  36926. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  36927. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  36928. return c > 3 && r && Object.defineProperty(target, key, r), r;
  36929. };
  36930. var AutoHeightCalculator = /** @class */ (function (_super) {
  36931. __extends(AutoHeightCalculator, _super);
  36932. function AutoHeightCalculator() {
  36933. return _super !== null && _super.apply(this, arguments) || this;
  36934. }
  36935. AutoHeightCalculator.prototype.registerGridComp = function (gridPanel) {
  36936. this.gridPanel = gridPanel;
  36937. };
  36938. AutoHeightCalculator.prototype.getPreferredHeightForRow = function (rowNode) {
  36939. var _this = this;
  36940. if (!this.eDummyContainer) {
  36941. this.eDummyContainer = document.createElement('div');
  36942. // so any styles on row also get applied in dummy, otherwise
  36943. // the content in dummy may differ to the real
  36944. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].addCssClass(this.eDummyContainer, 'ag-row ag-row-no-focus');
  36945. }
  36946. // we put the dummy into the body container, so it will inherit all the
  36947. // css styles that the real cells are inheriting
  36948. var eBodyContainer = this.gridPanel.getCenterContainer();
  36949. eBodyContainer.appendChild(this.eDummyContainer);
  36950. var cellComps = [];
  36951. var autoRowHeightCols = this.columnController.getAllAutoRowHeightCols();
  36952. var visibleAutoRowHeightCols = autoRowHeightCols.filter(function (col) { return col.isVisible(); });
  36953. visibleAutoRowHeightCols.forEach(function (col) {
  36954. var cellComp = new _cellComp__WEBPACK_IMPORTED_MODULE_1__["CellComp"](_this.$scope, _this.beans, col, rowNode, null, true, false);
  36955. cellComp.setParentRow(_this.eDummyContainer);
  36956. cellComps.push(cellComp);
  36957. });
  36958. var template = cellComps.map(function (cellComp) { return cellComp.getCreateTemplate(); }).join(' ');
  36959. this.eDummyContainer.innerHTML = template;
  36960. // this gets any cellComps that are using components to put the components in
  36961. cellComps.forEach(function (cellComp) { return cellComp.afterAttached(); });
  36962. // we should be able to just take the height of the row at this point, however
  36963. // the row isn't expanding to cover the cell heights, i don't know why, i couldn't
  36964. // figure it out so instead looking at the individual cells instead
  36965. var maxCellHeight = 0;
  36966. for (var i = 0; i < this.eDummyContainer.children.length; i++) {
  36967. var child = this.eDummyContainer.children[i];
  36968. if (child.offsetHeight > maxCellHeight) {
  36969. maxCellHeight = child.offsetHeight;
  36970. }
  36971. }
  36972. // we are finished with the dummy container, so get rid of it
  36973. eBodyContainer.removeChild(this.eDummyContainer);
  36974. cellComps.forEach(function (cellComp) {
  36975. // dunno why we need to detach first, doing it here to be consistent with code in RowComp
  36976. cellComp.detach();
  36977. cellComp.destroy();
  36978. });
  36979. // in case anything left over from last time
  36980. _utils__WEBPACK_IMPORTED_MODULE_2__["_"].clearElement(this.eDummyContainer);
  36981. return maxCellHeight;
  36982. };
  36983. __decorate([
  36984. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('beans')
  36985. ], AutoHeightCalculator.prototype, "beans", void 0);
  36986. __decorate([
  36987. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("$scope")
  36988. ], AutoHeightCalculator.prototype, "$scope", void 0);
  36989. __decorate([
  36990. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])("columnController")
  36991. ], AutoHeightCalculator.prototype, "columnController", void 0);
  36992. AutoHeightCalculator = __decorate([
  36993. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('autoHeightCalculator')
  36994. ], AutoHeightCalculator);
  36995. return AutoHeightCalculator;
  36996. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"]));
  36997. /***/ }),
  36998. /* 167 */
  36999. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  37000. "use strict";
  37001. __webpack_require__.r(__webpack_exports__);
  37002. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PaginationComp", function() { return PaginationComp; });
  37003. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56);
  37004. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  37005. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57);
  37006. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(43);
  37007. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(25);
  37008. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(7);
  37009. /**
  37010. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  37011. * @version v23.2.1
  37012. * @link http://www.ag-grid.com/
  37013. * @license MIT
  37014. */
  37015. var __extends = (undefined && undefined.__extends) || (function () {
  37016. var extendStatics = function (d, b) {
  37017. extendStatics = Object.setPrototypeOf ||
  37018. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  37019. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  37020. return extendStatics(d, b);
  37021. };
  37022. return function (d, b) {
  37023. extendStatics(d, b);
  37024. function __() { this.constructor = d; }
  37025. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  37026. };
  37027. })();
  37028. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  37029. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  37030. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  37031. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  37032. return c > 3 && r && Object.defineProperty(target, key, r), r;
  37033. };
  37034. var PaginationComp = /** @class */ (function (_super) {
  37035. __extends(PaginationComp, _super);
  37036. function PaginationComp() {
  37037. var _this = _super.call(this) || this;
  37038. _this.previousAndFirstButtonsDisabled = false;
  37039. _this.nextButtonDisabled = false;
  37040. _this.lastButtonDisabled = false;
  37041. return _this;
  37042. }
  37043. PaginationComp.prototype.postConstruct = function () {
  37044. var isRtl = this.gridOptionsWrapper.isEnableRtl();
  37045. this.setTemplate(this.getTemplate());
  37046. this.btFirst.insertAdjacentElement('afterbegin', _utils__WEBPACK_IMPORTED_MODULE_5__["_"].createIconNoSpan(isRtl ? 'last' : 'first', this.gridOptionsWrapper));
  37047. this.btPrevious.insertAdjacentElement('afterbegin', _utils__WEBPACK_IMPORTED_MODULE_5__["_"].createIconNoSpan(isRtl ? 'next' : 'previous', this.gridOptionsWrapper));
  37048. this.btNext.insertAdjacentElement('afterbegin', _utils__WEBPACK_IMPORTED_MODULE_5__["_"].createIconNoSpan(isRtl ? 'previous' : 'next', this.gridOptionsWrapper));
  37049. this.btLast.insertAdjacentElement('afterbegin', _utils__WEBPACK_IMPORTED_MODULE_5__["_"].createIconNoSpan(isRtl ? 'first' : 'last', this.gridOptionsWrapper));
  37050. if (this.rowModel.getType() === _constants__WEBPACK_IMPORTED_MODULE_4__["Constants"].ROW_MODEL_TYPE_SERVER_SIDE) {
  37051. this.serverSideRowModel = this.rowModel;
  37052. }
  37053. var isPaging = this.gridOptionsWrapper.isPagination();
  37054. var paginationPanelEnabled = isPaging && !this.gridOptionsWrapper.isSuppressPaginationPanel();
  37055. if (!paginationPanelEnabled) {
  37056. this.setDisplayed(false);
  37057. return;
  37058. }
  37059. this.addManagedListener(this.eventService, _events__WEBPACK_IMPORTED_MODULE_3__["Events"].EVENT_PAGINATION_CHANGED, this.onPaginationChanged.bind(this));
  37060. this.addManagedListener(this.btFirst, 'click', this.onBtFirst.bind(this));
  37061. this.addManagedListener(this.btLast, 'click', this.onBtLast.bind(this));
  37062. this.addManagedListener(this.btNext, 'click', this.onBtNext.bind(this));
  37063. this.addManagedListener(this.btPrevious, 'click', this.onBtPrevious.bind(this));
  37064. this.onPaginationChanged();
  37065. };
  37066. PaginationComp.prototype.onPaginationChanged = function () {
  37067. this.enableOrDisableButtons();
  37068. this.updateRowLabels();
  37069. this.setCurrentPageLabel();
  37070. this.setTotalLabels();
  37071. };
  37072. PaginationComp.prototype.onBtFirst = function () {
  37073. if (!this.previousAndFirstButtonsDisabled) {
  37074. this.paginationProxy.goToFirstPage();
  37075. }
  37076. };
  37077. PaginationComp.prototype.setCurrentPageLabel = function () {
  37078. var pagesExist = this.paginationProxy.getTotalPages() > 0;
  37079. var currentPage = this.paginationProxy.getCurrentPage();
  37080. var toDisplay = pagesExist ? currentPage + 1 : 0;
  37081. this.lbCurrent.innerHTML = this.formatNumber(toDisplay);
  37082. };
  37083. PaginationComp.prototype.formatNumber = function (value) {
  37084. var userFunc = this.gridOptionsWrapper.getPaginationNumberFormatterFunc();
  37085. if (userFunc) {
  37086. return userFunc({ value: value });
  37087. }
  37088. else {
  37089. return _utils__WEBPACK_IMPORTED_MODULE_5__["_"].formatNumberCommas(value);
  37090. }
  37091. };
  37092. PaginationComp.prototype.getTemplate = function () {
  37093. var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();
  37094. var strPage = localeTextFunc('page', 'Page');
  37095. var strTo = localeTextFunc('to', 'to');
  37096. var strOf = localeTextFunc('of', 'of');
  37097. var strFirst = localeTextFunc('first', 'First');
  37098. var strPrevious = localeTextFunc('previous', 'Previous');
  37099. var strNext = localeTextFunc('next', 'Next');
  37100. var strLast = localeTextFunc('last', 'Last');
  37101. return "<div class=\"ag-paging-panel ag-unselectable\">\n <span ref=\"eSummaryPanel\" class=\"ag-paging-row-summary-panel\">\n <span ref=\"lbFirstRowOnPage\" class=\"ag-paging-row-summary-panel-number\"></span>\n " + strTo + "\n <span ref=\"lbLastRowOnPage\" class=\"ag-paging-row-summary-panel-number\"></span>\n " + strOf + "\n <span ref=\"lbRecordCount\" class=\"ag-paging-row-summary-panel-number\"></span>\n </span>\n <span class=\"ag-paging-page-summary-panel\">\n <div ref=\"btFirst\" class=\"ag-paging-button-wrapper\">\n <button type=\"button\" class=\"ag-paging-button\">" + strFirst + "</button>\n </div>\n <div ref=\"btPrevious\" class=\"ag-paging-button-wrapper\">\n <button type=\"button\" class=\"ag-paging-button\">" + strPrevious + "</button>\n </div>\n <span class=\"ag-paging-description\">\n " + strPage + "\n <span ref=\"lbCurrent\" class=\"ag-paging-number\"></span>\n " + strOf + "\n <span ref=\"lbTotal\" class=\"ag-paging-number\"></span>\n </span>\n <span ref=\"lbTotal\" class=\"ag-paging-number\"></span>\n <div ref=\"btNext\" class=\"ag-paging-button-wrapper\">\n <button type=\"button\" class=\"ag-paging-button\">" + strNext + "</button>\n </div>\n <div ref=\"btLast\" class=\"ag-paging-button-wrapper\">\n <button type=\"button\" class=\"ag-paging-button\">" + strLast + "</button>\n </div>\n </span>\n </div>";
  37102. };
  37103. PaginationComp.prototype.onBtNext = function () {
  37104. if (!this.nextButtonDisabled) {
  37105. this.paginationProxy.goToNextPage();
  37106. }
  37107. };
  37108. PaginationComp.prototype.onBtPrevious = function () {
  37109. if (!this.previousAndFirstButtonsDisabled) {
  37110. this.paginationProxy.goToPreviousPage();
  37111. }
  37112. };
  37113. PaginationComp.prototype.onBtLast = function () {
  37114. if (!this.lastButtonDisabled) {
  37115. this.paginationProxy.goToLastPage();
  37116. }
  37117. };
  37118. PaginationComp.prototype.enableOrDisableButtons = function () {
  37119. var currentPage = this.paginationProxy.getCurrentPage();
  37120. var maxRowFound = this.paginationProxy.isLastPageFound();
  37121. var totalPages = this.paginationProxy.getTotalPages();
  37122. this.previousAndFirstButtonsDisabled = currentPage === 0;
  37123. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].addOrRemoveCssClass(this.btPrevious, 'ag-disabled', this.previousAndFirstButtonsDisabled);
  37124. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].addOrRemoveCssClass(this.btFirst, 'ag-disabled', this.previousAndFirstButtonsDisabled);
  37125. var zeroPagesToDisplay = this.isZeroPagesToDisplay();
  37126. var onLastPage = maxRowFound && currentPage === (totalPages - 1);
  37127. this.nextButtonDisabled = onLastPage || zeroPagesToDisplay;
  37128. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].addOrRemoveCssClass(this.btNext, 'ag-disabled', this.nextButtonDisabled);
  37129. this.lastButtonDisabled = !maxRowFound || zeroPagesToDisplay || currentPage === (totalPages - 1);
  37130. _utils__WEBPACK_IMPORTED_MODULE_5__["_"].addOrRemoveCssClass(this.btLast, 'ag-disabled', this.lastButtonDisabled);
  37131. };
  37132. PaginationComp.prototype.updateRowLabels = function () {
  37133. var currentPage = this.paginationProxy.getCurrentPage();
  37134. var pageSize = this.paginationProxy.getPageSize();
  37135. var maxRowFound = this.paginationProxy.isLastPageFound();
  37136. var rowCount = this.paginationProxy.isLastPageFound() ?
  37137. this.paginationProxy.getMasterRowCount() : null;
  37138. var startRow;
  37139. var endRow;
  37140. if (this.isZeroPagesToDisplay()) {
  37141. startRow = 0;
  37142. endRow = 0;
  37143. }
  37144. else {
  37145. startRow = (pageSize * currentPage) + 1;
  37146. endRow = startRow + pageSize - 1;
  37147. if (maxRowFound && endRow > rowCount) {
  37148. endRow = rowCount;
  37149. }
  37150. }
  37151. this.lbFirstRowOnPage.innerHTML = this.formatNumber(startRow);
  37152. if (this.serverSideRowModel && this.serverSideRowModel.isLoading()) {
  37153. this.lbLastRowOnPage.innerHTML = '?';
  37154. }
  37155. else {
  37156. this.lbLastRowOnPage.innerHTML = this.formatNumber(endRow);
  37157. }
  37158. };
  37159. PaginationComp.prototype.isZeroPagesToDisplay = function () {
  37160. var maxRowFound = this.paginationProxy.isLastPageFound();
  37161. var totalPages = this.paginationProxy.getTotalPages();
  37162. return maxRowFound && totalPages === 0;
  37163. };
  37164. PaginationComp.prototype.setTotalLabels = function () {
  37165. var lastPageFound = this.paginationProxy.isLastPageFound();
  37166. var totalPages = this.paginationProxy.getTotalPages();
  37167. var rowCount = this.paginationProxy.isLastPageFound() ?
  37168. this.paginationProxy.getMasterRowCount() : null;
  37169. if (lastPageFound) {
  37170. this.lbTotal.innerHTML = this.formatNumber(totalPages);
  37171. this.lbRecordCount.innerHTML = this.formatNumber(rowCount);
  37172. }
  37173. else {
  37174. var moreText = this.gridOptionsWrapper.getLocaleTextFunc()('more', 'more');
  37175. this.lbTotal.innerHTML = moreText;
  37176. this.lbRecordCount.innerHTML = moreText;
  37177. }
  37178. };
  37179. __decorate([
  37180. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  37181. ], PaginationComp.prototype, "gridOptionsWrapper", void 0);
  37182. __decorate([
  37183. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('paginationProxy')
  37184. ], PaginationComp.prototype, "paginationProxy", void 0);
  37185. __decorate([
  37186. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowRenderer')
  37187. ], PaginationComp.prototype, "rowRenderer", void 0);
  37188. __decorate([
  37189. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('rowModel')
  37190. ], PaginationComp.prototype, "rowModel", void 0);
  37191. __decorate([
  37192. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('btFirst')
  37193. ], PaginationComp.prototype, "btFirst", void 0);
  37194. __decorate([
  37195. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('btPrevious')
  37196. ], PaginationComp.prototype, "btPrevious", void 0);
  37197. __decorate([
  37198. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('btNext')
  37199. ], PaginationComp.prototype, "btNext", void 0);
  37200. __decorate([
  37201. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('btLast')
  37202. ], PaginationComp.prototype, "btLast", void 0);
  37203. __decorate([
  37204. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('lbRecordCount')
  37205. ], PaginationComp.prototype, "lbRecordCount", void 0);
  37206. __decorate([
  37207. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('lbFirstRowOnPage')
  37208. ], PaginationComp.prototype, "lbFirstRowOnPage", void 0);
  37209. __decorate([
  37210. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('lbLastRowOnPage')
  37211. ], PaginationComp.prototype, "lbLastRowOnPage", void 0);
  37212. __decorate([
  37213. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('eSummaryPanel')
  37214. ], PaginationComp.prototype, "eSummaryPanel", void 0);
  37215. __decorate([
  37216. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('lbCurrent')
  37217. ], PaginationComp.prototype, "lbCurrent", void 0);
  37218. __decorate([
  37219. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('lbTotal')
  37220. ], PaginationComp.prototype, "lbTotal", void 0);
  37221. __decorate([
  37222. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  37223. ], PaginationComp.prototype, "postConstruct", null);
  37224. return PaginationComp;
  37225. }(_widgets_component__WEBPACK_IMPORTED_MODULE_0__["Component"]));
  37226. /***/ }),
  37227. /* 168 */
  37228. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  37229. "use strict";
  37230. __webpack_require__.r(__webpack_exports__);
  37231. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ResizeObserverService", function() { return ResizeObserverService; });
  37232. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  37233. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  37234. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
  37235. /**
  37236. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  37237. * @version v23.2.1
  37238. * @link http://www.ag-grid.com/
  37239. * @license MIT
  37240. */
  37241. var __extends = (undefined && undefined.__extends) || (function () {
  37242. var extendStatics = function (d, b) {
  37243. extendStatics = Object.setPrototypeOf ||
  37244. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  37245. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  37246. return extendStatics(d, b);
  37247. };
  37248. return function (d, b) {
  37249. extendStatics(d, b);
  37250. function __() { this.constructor = d; }
  37251. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  37252. };
  37253. })();
  37254. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  37255. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  37256. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  37257. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  37258. return c > 3 && r && Object.defineProperty(target, key, r), r;
  37259. };
  37260. var ResizeObserverService = /** @class */ (function (_super) {
  37261. __extends(ResizeObserverService, _super);
  37262. function ResizeObserverService() {
  37263. return _super !== null && _super.apply(this, arguments) || this;
  37264. }
  37265. ResizeObserverService.prototype.observeResize = function (element, callback, debounceDelay) {
  37266. if (debounceDelay === void 0) { debounceDelay = 50; }
  37267. // put in variable, so available to usePolyfill() function below
  37268. var frameworkFactory = this.getFrameworkOverrides();
  37269. // this gets fired too often and might cause some relayout issues
  37270. // so we add a debounce to the callback here to avoid the flashing effect.
  37271. var debouncedCallback = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].debounce(callback, debounceDelay);
  37272. var useBrowserResizeObserver = function () {
  37273. var resizeObserver = new window.ResizeObserver(debouncedCallback);
  37274. resizeObserver.observe(element);
  37275. return function () { return resizeObserver.disconnect(); };
  37276. };
  37277. var usePolyfill = function () {
  37278. // initialise to the current width and height, so first call will have no changes
  37279. var widthLastTime = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].offsetWidth(element);
  37280. var heightLastTime = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].offsetHeight(element);
  37281. // when finished, this gets turned to false.
  37282. var running = true;
  37283. var periodicallyCheckWidthAndHeight = function () {
  37284. if (running) {
  37285. var newWidth = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].offsetWidth(element);
  37286. var newHeight = _utils__WEBPACK_IMPORTED_MODULE_2__["_"].offsetHeight(element);
  37287. var changed = newWidth !== widthLastTime || newHeight !== heightLastTime;
  37288. if (changed) {
  37289. widthLastTime = newWidth;
  37290. heightLastTime = newHeight;
  37291. callback();
  37292. }
  37293. frameworkFactory.setTimeout(periodicallyCheckWidthAndHeight, debounceDelay);
  37294. }
  37295. };
  37296. periodicallyCheckWidthAndHeight();
  37297. // the callback function we return sets running to false
  37298. return function () { return running = false; };
  37299. };
  37300. var suppressResize = this.gridOptionsWrapper.isSuppressBrowserResizeObserver();
  37301. var resizeObserverExists = !!window.ResizeObserver;
  37302. if (resizeObserverExists && !suppressResize) {
  37303. return useBrowserResizeObserver();
  37304. }
  37305. else {
  37306. return usePolyfill();
  37307. }
  37308. };
  37309. __decorate([
  37310. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  37311. ], ResizeObserverService.prototype, "gridOptionsWrapper", void 0);
  37312. ResizeObserverService = __decorate([
  37313. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('resizeObserverService')
  37314. ], ResizeObserverService);
  37315. return ResizeObserverService;
  37316. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  37317. /***/ }),
  37318. /* 169 */
  37319. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  37320. "use strict";
  37321. __webpack_require__.r(__webpack_exports__);
  37322. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "OverlayWrapperComponent", function() { return OverlayWrapperComponent; });
  37323. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  37324. /* harmony import */ var _widgets_component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(56);
  37325. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57);
  37326. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  37327. /**
  37328. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  37329. * @version v23.2.1
  37330. * @link http://www.ag-grid.com/
  37331. * @license MIT
  37332. */
  37333. var __extends = (undefined && undefined.__extends) || (function () {
  37334. var extendStatics = function (d, b) {
  37335. extendStatics = Object.setPrototypeOf ||
  37336. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  37337. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  37338. return extendStatics(d, b);
  37339. };
  37340. return function (d, b) {
  37341. extendStatics(d, b);
  37342. function __() { this.constructor = d; }
  37343. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  37344. };
  37345. })();
  37346. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  37347. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  37348. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  37349. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  37350. return c > 3 && r && Object.defineProperty(target, key, r), r;
  37351. };
  37352. var LoadingType;
  37353. (function (LoadingType) {
  37354. LoadingType[LoadingType["Loading"] = 0] = "Loading";
  37355. LoadingType[LoadingType["NoRows"] = 1] = "NoRows";
  37356. })(LoadingType || (LoadingType = {}));
  37357. var OverlayWrapperComponent = /** @class */ (function (_super) {
  37358. __extends(OverlayWrapperComponent, _super);
  37359. function OverlayWrapperComponent() {
  37360. var _this = _super.call(this, OverlayWrapperComponent.TEMPLATE) || this;
  37361. _this.inProgress = false;
  37362. _this.destroyRequested = false;
  37363. return _this;
  37364. }
  37365. OverlayWrapperComponent.prototype.postConstruct = function () {
  37366. this.gridOptionsWrapper.addLayoutElement(this.eOverlayWrapper);
  37367. this.setDisplayed(false);
  37368. };
  37369. OverlayWrapperComponent.prototype.setWrapperTypeClass = function (loadingType) {
  37370. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addOrRemoveCssClass(this.eOverlayWrapper, 'ag-overlay-loading-wrapper', loadingType === LoadingType.Loading);
  37371. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addOrRemoveCssClass(this.eOverlayWrapper, 'ag-overlay-no-rows-wrapper', loadingType === LoadingType.NoRows);
  37372. };
  37373. OverlayWrapperComponent.prototype.showLoadingOverlay = function () {
  37374. var workItem = this.userComponentFactory.newLoadingOverlayComponent({
  37375. api: this.gridOptionsWrapper.getApi()
  37376. });
  37377. this.showOverlay(workItem, LoadingType.Loading);
  37378. };
  37379. OverlayWrapperComponent.prototype.showNoRowsOverlay = function () {
  37380. var workItem = this.userComponentFactory.newNoRowsOverlayComponent({
  37381. api: this.gridOptionsWrapper.getApi()
  37382. });
  37383. this.showOverlay(workItem, LoadingType.NoRows);
  37384. };
  37385. OverlayWrapperComponent.prototype.showOverlay = function (workItem, type) {
  37386. var _this = this;
  37387. if (this.inProgress) {
  37388. return;
  37389. }
  37390. this.setWrapperTypeClass(type);
  37391. this.destroyActiveOverlay();
  37392. this.inProgress = true;
  37393. workItem.then(function (comp) {
  37394. _this.inProgress = false;
  37395. _this.eOverlayWrapper.appendChild(comp.getGui());
  37396. _this.activeOverlay = comp;
  37397. if (_this.destroyRequested) {
  37398. _this.destroyRequested = false;
  37399. _this.destroyActiveOverlay();
  37400. }
  37401. });
  37402. this.setDisplayed(true);
  37403. };
  37404. OverlayWrapperComponent.prototype.destroyActiveOverlay = function () {
  37405. if (this.inProgress) {
  37406. this.destroyRequested = true;
  37407. return;
  37408. }
  37409. if (!this.activeOverlay) {
  37410. return;
  37411. }
  37412. this.activeOverlay = this.getContext().destroyBean(this.activeOverlay);
  37413. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].clearElement(this.eOverlayWrapper);
  37414. };
  37415. OverlayWrapperComponent.prototype.hideOverlay = function () {
  37416. this.destroyActiveOverlay();
  37417. this.setDisplayed(false);
  37418. };
  37419. OverlayWrapperComponent.prototype.destroy = function () {
  37420. this.destroyActiveOverlay();
  37421. _super.prototype.destroy.call(this);
  37422. };
  37423. // wrapping in outer div, and wrapper, is needed to center the loading icon
  37424. // The idea for centering came from here: http://www.vanseodesign.com/css/vertical-centering/
  37425. OverlayWrapperComponent.TEMPLATE = "\n <div class=\"ag-overlay\" aria-hidden=\"true\">\n <div class=\"ag-overlay-panel\">\n <div class=\"ag-overlay-wrapper\" ref=\"eOverlayWrapper\"></div>\n </div>\n </div>";
  37426. __decorate([
  37427. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  37428. ], OverlayWrapperComponent.prototype, "gridOptionsWrapper", void 0);
  37429. __decorate([
  37430. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('userComponentFactory')
  37431. ], OverlayWrapperComponent.prototype, "userComponentFactory", void 0);
  37432. __decorate([
  37433. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('eOverlayWrapper')
  37434. ], OverlayWrapperComponent.prototype, "eOverlayWrapper", void 0);
  37435. __decorate([
  37436. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  37437. ], OverlayWrapperComponent.prototype, "postConstruct", null);
  37438. return OverlayWrapperComponent;
  37439. }(_widgets_component__WEBPACK_IMPORTED_MODULE_1__["Component"]));
  37440. /***/ }),
  37441. /* 170 */
  37442. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  37443. "use strict";
  37444. __webpack_require__.r(__webpack_exports__);
  37445. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgGroupComponent", function() { return AgGroupComponent; });
  37446. /* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56);
  37447. /* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57);
  37448. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37);
  37449. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25);
  37450. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7);
  37451. /**
  37452. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  37453. * @version v23.2.1
  37454. * @link http://www.ag-grid.com/
  37455. * @license MIT
  37456. */
  37457. var __extends = (undefined && undefined.__extends) || (function () {
  37458. var extendStatics = function (d, b) {
  37459. extendStatics = Object.setPrototypeOf ||
  37460. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  37461. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  37462. return extendStatics(d, b);
  37463. };
  37464. return function (d, b) {
  37465. extendStatics(d, b);
  37466. function __() { this.constructor = d; }
  37467. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  37468. };
  37469. })();
  37470. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  37471. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  37472. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  37473. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  37474. return c > 3 && r && Object.defineProperty(target, key, r), r;
  37475. };
  37476. var defaultItemAlign = 'center';
  37477. var defaultDirection = 'vertical';
  37478. var AgGroupComponent = /** @class */ (function (_super) {
  37479. __extends(AgGroupComponent, _super);
  37480. function AgGroupComponent(params) {
  37481. if (params === void 0) { params = {}; }
  37482. var _this = _super.call(this, AgGroupComponent.getTemplate(params)) || this;
  37483. _this.suppressEnabledCheckbox = true;
  37484. _this.suppressOpenCloseIcons = false;
  37485. var title = params.title, enabled = params.enabled, items = params.items, suppressEnabledCheckbox = params.suppressEnabledCheckbox, suppressOpenCloseIcons = params.suppressOpenCloseIcons;
  37486. _this.title = title;
  37487. _this.cssIdentifier = params.cssIdentifier || 'default';
  37488. _this.enabled = enabled != null ? enabled : true;
  37489. _this.items = items || [];
  37490. _this.alignItems = params.alignItems || 'center';
  37491. if (suppressEnabledCheckbox != null) {
  37492. _this.suppressEnabledCheckbox = suppressEnabledCheckbox;
  37493. }
  37494. if (suppressOpenCloseIcons != null) {
  37495. _this.suppressOpenCloseIcons = suppressOpenCloseIcons;
  37496. }
  37497. return _this;
  37498. }
  37499. AgGroupComponent.getTemplate = function (params) {
  37500. var cssIdentifier = params.cssIdentifier || 'default';
  37501. var direction = params.direction || 'vertical';
  37502. return /* html */ "<div class=\"ag-group ag-" + cssIdentifier + "-group\">\n <div class=\"ag-group-title-bar ag-" + cssIdentifier + "-group-title-bar ag-unselectable\" ref=\"eTitleBar\">\n <span class=\"ag-group-title-bar-icon ag-" + cssIdentifier + "-group-title-bar-icon\" ref=\"eGroupOpenedIcon\"></span>\n <span class=\"ag-group-title-bar-icon ag-" + cssIdentifier + "-group-title-bar-icon\" ref=\"eGroupClosedIcon\"></span>\n <span ref=\"eTitle\" class=\"ag-group-title ag-" + cssIdentifier + "-group-title\"></span>\n </div>\n <div ref=\"eToolbar\" class=\"ag-group-toolbar ag-" + cssIdentifier + "-group-toolbar\">\n <ag-checkbox ref=\"cbGroupEnabled\"></ag-checkbox>\n </div>\n <div ref=\"eContainer\" class=\"ag-group-container ag-group-container-" + direction + " ag-" + cssIdentifier + "-group-container\"></div>\n </div>";
  37503. };
  37504. AgGroupComponent.prototype.postConstruct = function () {
  37505. if (this.items.length) {
  37506. var initialItems = this.items;
  37507. this.items = [];
  37508. this.addItems(initialItems);
  37509. }
  37510. var localeTextFunc = this.gridOptionsWrapper.getLocaleTextFunc();
  37511. this.cbGroupEnabled.setLabel(localeTextFunc('enabled', 'Enabled'));
  37512. if (this.title) {
  37513. this.setTitle(this.title);
  37514. }
  37515. if (this.enabled) {
  37516. this.setEnabled(this.enabled);
  37517. }
  37518. this.setAlignItems(this.alignItems);
  37519. this.hideEnabledCheckbox(this.suppressEnabledCheckbox);
  37520. this.hideOpenCloseIcons(this.suppressOpenCloseIcons);
  37521. this.setupExpandContract();
  37522. this.refreshChildDisplay();
  37523. };
  37524. AgGroupComponent.prototype.setupExpandContract = function () {
  37525. var _this = this;
  37526. this.eGroupClosedIcon.appendChild(_utils__WEBPACK_IMPORTED_MODULE_4__["_"].createIcon('columnSelectClosed', this.gridOptionsWrapper, null));
  37527. this.eGroupOpenedIcon.appendChild(_utils__WEBPACK_IMPORTED_MODULE_4__["_"].createIcon('columnSelectOpen', this.gridOptionsWrapper, null));
  37528. this.addManagedListener(this.eTitleBar, 'click', function () { return _this.toggleGroupExpand(); });
  37529. this.addManagedListener(this.eTitleBar, 'keydown', function (e) {
  37530. if (e.keyCode === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_ENTER) {
  37531. _this.toggleGroupExpand();
  37532. }
  37533. });
  37534. };
  37535. AgGroupComponent.prototype.refreshChildDisplay = function () {
  37536. var showIcon = !this.suppressOpenCloseIcons;
  37537. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].setDisplayed(this.eGroupClosedIcon, showIcon && !this.expanded);
  37538. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].setDisplayed(this.eGroupOpenedIcon, showIcon && this.expanded);
  37539. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].setDisplayed(this.eToolbar, this.expanded && !this.suppressEnabledCheckbox);
  37540. };
  37541. AgGroupComponent.prototype.isExpanded = function () {
  37542. return this.expanded;
  37543. };
  37544. AgGroupComponent.prototype.setAlignItems = function (alignment) {
  37545. var eGui = this.getGui();
  37546. if (this.alignItems !== alignment) {
  37547. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].removeCssClass(eGui, "ag-group-item-alignment-" + this.alignItems);
  37548. }
  37549. this.alignItems = alignment;
  37550. var newCls = "ag-group-item-alignment-" + this.alignItems;
  37551. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(eGui, newCls);
  37552. return this;
  37553. };
  37554. AgGroupComponent.prototype.toggleGroupExpand = function (expanded) {
  37555. if (this.suppressOpenCloseIcons) {
  37556. this.expanded = true;
  37557. this.refreshChildDisplay();
  37558. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].setDisplayed(this.eContainer, true);
  37559. return this;
  37560. }
  37561. expanded = expanded != null ? expanded : !this.expanded;
  37562. if (this.expanded === expanded) {
  37563. return this;
  37564. }
  37565. this.expanded = expanded;
  37566. this.refreshChildDisplay();
  37567. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].setDisplayed(this.eContainer, expanded);
  37568. if (this.expanded) {
  37569. this.dispatchEvent({ type: AgGroupComponent.EVENT_EXPANDED });
  37570. }
  37571. else {
  37572. this.dispatchEvent({ type: AgGroupComponent.EVENT_COLLAPSED });
  37573. }
  37574. return this;
  37575. };
  37576. AgGroupComponent.prototype.addItems = function (items) {
  37577. var _this = this;
  37578. items.forEach(function (item) { return _this.addItem(item); });
  37579. };
  37580. AgGroupComponent.prototype.addItem = function (item) {
  37581. var container = this.eContainer;
  37582. var el = item instanceof _component__WEBPACK_IMPORTED_MODULE_0__["Component"] ? item.getGui() : item;
  37583. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(el, 'ag-group-item');
  37584. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(el, "ag-" + this.cssIdentifier + "-group-item");
  37585. container.appendChild(el);
  37586. this.items.push(el);
  37587. };
  37588. AgGroupComponent.prototype.hideItem = function (hide, index) {
  37589. var itemToHide = this.items[index];
  37590. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addOrRemoveCssClass(itemToHide, 'ag-hidden', hide);
  37591. };
  37592. AgGroupComponent.prototype.setTitle = function (title) {
  37593. this.eTitle.innerText = title;
  37594. return this;
  37595. };
  37596. AgGroupComponent.prototype.addCssClassToTitleBar = function (cssClass) {
  37597. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(this.eTitleBar, cssClass);
  37598. };
  37599. AgGroupComponent.prototype.setEnabled = function (enabled, skipToggle) {
  37600. this.enabled = enabled;
  37601. this.refreshDisabledStyles();
  37602. this.toggleGroupExpand(enabled);
  37603. if (!skipToggle) {
  37604. this.cbGroupEnabled.setValue(enabled);
  37605. }
  37606. return this;
  37607. };
  37608. AgGroupComponent.prototype.isEnabled = function () {
  37609. return this.enabled;
  37610. };
  37611. AgGroupComponent.prototype.onEnableChange = function (callbackFn) {
  37612. var _this = this;
  37613. this.cbGroupEnabled.onValueChange(function (newSelection) {
  37614. _this.setEnabled(newSelection, true);
  37615. callbackFn(newSelection);
  37616. });
  37617. return this;
  37618. };
  37619. AgGroupComponent.prototype.hideEnabledCheckbox = function (hide) {
  37620. this.suppressEnabledCheckbox = hide;
  37621. this.refreshChildDisplay();
  37622. this.refreshDisabledStyles();
  37623. return this;
  37624. };
  37625. AgGroupComponent.prototype.hideOpenCloseIcons = function (hide) {
  37626. this.suppressOpenCloseIcons = hide;
  37627. if (hide) {
  37628. this.toggleGroupExpand(true);
  37629. }
  37630. return this;
  37631. };
  37632. AgGroupComponent.prototype.refreshDisabledStyles = function () {
  37633. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addOrRemoveCssClass(this.getGui(), 'ag-disabled', !this.enabled);
  37634. if (this.suppressEnabledCheckbox && !this.enabled) {
  37635. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(this.eTitleBar, 'ag-disabled-group-title-bar');
  37636. this.eTitleBar.removeAttribute('tabindex');
  37637. }
  37638. else {
  37639. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].removeCssClass(this.eTitleBar, 'ag-disabled-group-title-bar');
  37640. this.eTitleBar.setAttribute('tabindex', '0');
  37641. }
  37642. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addOrRemoveCssClass(this.eContainer, 'ag-disabled-group-container', !this.enabled);
  37643. };
  37644. AgGroupComponent.EVENT_EXPANDED = 'expanded';
  37645. AgGroupComponent.EVENT_COLLAPSED = 'collapsed';
  37646. __decorate([
  37647. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])('gridOptionsWrapper')
  37648. ], AgGroupComponent.prototype, "gridOptionsWrapper", void 0);
  37649. __decorate([
  37650. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eTitleBar')
  37651. ], AgGroupComponent.prototype, "eTitleBar", void 0);
  37652. __decorate([
  37653. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eGroupOpenedIcon')
  37654. ], AgGroupComponent.prototype, "eGroupOpenedIcon", void 0);
  37655. __decorate([
  37656. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eGroupClosedIcon')
  37657. ], AgGroupComponent.prototype, "eGroupClosedIcon", void 0);
  37658. __decorate([
  37659. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eToolbar')
  37660. ], AgGroupComponent.prototype, "eToolbar", void 0);
  37661. __decorate([
  37662. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('cbGroupEnabled')
  37663. ], AgGroupComponent.prototype, "cbGroupEnabled", void 0);
  37664. __decorate([
  37665. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eTitle')
  37666. ], AgGroupComponent.prototype, "eTitle", void 0);
  37667. __decorate([
  37668. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eContainer')
  37669. ], AgGroupComponent.prototype, "eContainer", void 0);
  37670. __decorate([
  37671. _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"]
  37672. ], AgGroupComponent.prototype, "postConstruct", null);
  37673. return AgGroupComponent;
  37674. }(_component__WEBPACK_IMPORTED_MODULE_0__["Component"]));
  37675. /***/ }),
  37676. /* 171 */
  37677. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  37678. "use strict";
  37679. __webpack_require__.r(__webpack_exports__);
  37680. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgDialog", function() { return AgDialog; });
  37681. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  37682. /* harmony import */ var _agPanel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(172);
  37683. /* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(56);
  37684. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  37685. /**
  37686. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  37687. * @version v23.2.1
  37688. * @link http://www.ag-grid.com/
  37689. * @license MIT
  37690. */
  37691. var __extends = (undefined && undefined.__extends) || (function () {
  37692. var extendStatics = function (d, b) {
  37693. extendStatics = Object.setPrototypeOf ||
  37694. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  37695. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  37696. return extendStatics(d, b);
  37697. };
  37698. return function (d, b) {
  37699. extendStatics(d, b);
  37700. function __() { this.constructor = d; }
  37701. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  37702. };
  37703. })();
  37704. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  37705. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  37706. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  37707. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  37708. return c > 3 && r && Object.defineProperty(target, key, r), r;
  37709. };
  37710. var AgDialog = /** @class */ (function (_super) {
  37711. __extends(AgDialog, _super);
  37712. function AgDialog(config) {
  37713. var _this = _super.call(this, config) || this;
  37714. _this.RESIZE_TEMPLATE = "<div class=\"ag-resizer-wrapper\">\n <div ref=\"eTopLeftResizer\" class=\"ag-resizer ag-resizer-topLeft\"></div>\n <div ref=\"eTopResizer\" class=\"ag-resizer ag-resizer-top\"></div>\n <div ref=\"eTopRightResizer\" class=\"ag-resizer ag-resizer-topRight\"></div>\n <div ref=\"eRightResizer\" class=\"ag-resizer ag-resizer-right\"></div>\n <div ref=\"eBottomRightResizer\" class=\"ag-resizer ag-resizer-bottomRight\"></div>\n <div ref=\"eBottomResizer\" class=\"ag-resizer ag-resizer-bottom\"></div>\n <div ref=\"eBottomLeftResizer\" class=\"ag-resizer ag-resizer-bottomLeft\"></div>\n <div ref=\"eLeftResizer\" class=\"ag-resizer ag-resizer-left\"></div>\n </div>";
  37715. _this.MAXIMIZE_BTN_TEMPLATE = "<div class=\"ag-dialog-button\"></span>";
  37716. _this.resizable = {};
  37717. _this.movable = false;
  37718. _this.isMoving = false;
  37719. _this.isMaximizable = false;
  37720. _this.isMaximized = false;
  37721. _this.maximizeListeners = [];
  37722. _this.resizeListenerDestroy = null;
  37723. _this.isResizing = false;
  37724. _this.lastPosition = {
  37725. x: 0,
  37726. y: 0,
  37727. width: 0,
  37728. height: 0
  37729. };
  37730. return _this;
  37731. }
  37732. AgDialog.prototype.postConstruct = function () {
  37733. var _this = this;
  37734. var eGui = this.getGui();
  37735. var _a = this.config, movable = _a.movable, resizable = _a.resizable, maximizable = _a.maximizable;
  37736. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addCssClass(eGui, 'ag-dialog');
  37737. this.moveElement = this.eTitleBar;
  37738. _super.prototype.postConstruct.call(this);
  37739. this.addManagedListener(eGui, 'focusin', function (e) {
  37740. if (eGui.contains(e.relatedTarget)) {
  37741. return;
  37742. }
  37743. _this.popupService.bringPopupToFront(eGui);
  37744. });
  37745. if (movable) {
  37746. this.setMovable(movable);
  37747. }
  37748. if (maximizable) {
  37749. this.setMaximizable(maximizable);
  37750. }
  37751. this.addResizers();
  37752. if (resizable) {
  37753. this.setResizable(resizable);
  37754. }
  37755. };
  37756. AgDialog.prototype.renderComponent = function () {
  37757. var eGui = this.getGui();
  37758. var _a = this.config, alwaysOnTop = _a.alwaysOnTop, modal = _a.modal;
  37759. this.close = this.popupService.addPopup(modal, eGui, true, this.destroy.bind(this), undefined, alwaysOnTop);
  37760. eGui.focus();
  37761. };
  37762. AgDialog.prototype.addResizers = function () {
  37763. var eGui = this.getGui();
  37764. if (!eGui) {
  37765. return;
  37766. }
  37767. var parser = new DOMParser();
  37768. var resizers = parser.parseFromString(this.RESIZE_TEMPLATE, 'text/html').body;
  37769. eGui.appendChild(resizers.firstChild);
  37770. this.createMap();
  37771. };
  37772. AgDialog.prototype.createMap = function () {
  37773. var eGui = this.getGui();
  37774. this.resizerMap = {
  37775. topLeft: { element: eGui.querySelector('[ref=eTopLeftResizer]') },
  37776. top: { element: eGui.querySelector('[ref=eTopResizer]') },
  37777. topRight: { element: eGui.querySelector('[ref=eTopRightResizer]') },
  37778. right: { element: eGui.querySelector('[ref=eRightResizer]') },
  37779. bottomRight: { element: eGui.querySelector('[ref=eBottomRightResizer]') },
  37780. bottom: { element: eGui.querySelector('[ref=eBottomResizer]') },
  37781. bottomLeft: { element: eGui.querySelector('[ref=eBottomLeftResizer]') },
  37782. left: { element: eGui.querySelector('[ref=eLeftResizer]') }
  37783. };
  37784. };
  37785. AgDialog.prototype.getResizerElement = function (side) {
  37786. return this.resizerMap[side].element;
  37787. };
  37788. AgDialog.prototype.onResizeStart = function (e) {
  37789. this.isResizing = true;
  37790. this.updateDragStartPosition(e.clientX, e.clientY);
  37791. };
  37792. AgDialog.prototype.onResize = function (e, side) {
  37793. if (!this.isResizing) {
  37794. return;
  37795. }
  37796. var isLeft = !!side.match(/left/i);
  37797. var isRight = !!side.match(/right/i);
  37798. var isTop = !!side.match(/top/i);
  37799. var isBottom = !!side.match(/bottom/i);
  37800. var isHorizontal = isLeft || isRight;
  37801. var isVertical = isTop || isBottom;
  37802. var _a = this.calculateMouseMovement({ e: e, isLeft: isLeft, isTop: isTop }), movementX = _a.movementX, movementY = _a.movementY;
  37803. var offsetLeft = 0;
  37804. var offsetTop = 0;
  37805. if (isHorizontal && movementX) {
  37806. var direction = isLeft ? -1 : 1;
  37807. var oldWidth = this.getWidth();
  37808. var newWidth = oldWidth + (movementX * direction);
  37809. var skipWidth = false;
  37810. if (isLeft) {
  37811. offsetLeft = oldWidth - newWidth;
  37812. if (this.position.x + offsetLeft <= 0 || newWidth <= this.minWidth) {
  37813. skipWidth = true;
  37814. offsetLeft = 0;
  37815. }
  37816. }
  37817. if (!skipWidth) {
  37818. this.setWidth(newWidth);
  37819. }
  37820. }
  37821. if (isVertical && movementY) {
  37822. var direction = isTop ? -1 : 1;
  37823. var oldHeight = this.getHeight();
  37824. var newHeight = oldHeight + (movementY * direction);
  37825. var skipHeight = false;
  37826. if (isTop) {
  37827. offsetTop = oldHeight - newHeight;
  37828. if (this.position.y + offsetTop <= 0 || newHeight <= this.minHeight) {
  37829. skipHeight = true;
  37830. offsetTop = 0;
  37831. }
  37832. }
  37833. if (!skipHeight) {
  37834. this.setHeight(newHeight);
  37835. }
  37836. }
  37837. this.updateDragStartPosition(e.clientX, e.clientY);
  37838. if (offsetLeft || offsetTop) {
  37839. this.offsetElement(this.position.x + offsetLeft, this.position.y + offsetTop);
  37840. }
  37841. };
  37842. AgDialog.prototype.onResizeEnd = function () {
  37843. this.isResizing = false;
  37844. var params = {
  37845. type: 'resize',
  37846. api: this.gridOptionsWrapper.getApi(),
  37847. columnApi: this.gridOptionsWrapper.getColumnApi()
  37848. };
  37849. this.dispatchEvent(params);
  37850. };
  37851. AgDialog.prototype.onMoveStart = function (e) {
  37852. this.isMoving = true;
  37853. this.updateDragStartPosition(e.clientX, e.clientY);
  37854. };
  37855. AgDialog.prototype.onMove = function (e) {
  37856. if (!this.isMoving) {
  37857. return;
  37858. }
  37859. var _a = this.position, x = _a.x, y = _a.y;
  37860. var _b = this.calculateMouseMovement({
  37861. e: e,
  37862. isTop: true,
  37863. anywhereWithin: true,
  37864. topBuffer: this.getHeight() - this.getBodyHeight()
  37865. }), movementX = _b.movementX, movementY = _b.movementY;
  37866. this.offsetElement(x + movementX, y + movementY);
  37867. this.updateDragStartPosition(e.clientX, e.clientY);
  37868. };
  37869. AgDialog.prototype.onMoveEnd = function () {
  37870. this.isMoving = false;
  37871. };
  37872. AgDialog.prototype.toggleMaximize = function () {
  37873. if (this.isMaximized) {
  37874. var _a = this.lastPosition, x = _a.x, y = _a.y, width = _a.width, height = _a.height;
  37875. this.setWidth(width);
  37876. this.setHeight(height);
  37877. this.offsetElement(x, y);
  37878. }
  37879. else {
  37880. this.lastPosition.width = this.getWidth();
  37881. this.lastPosition.height = this.getHeight();
  37882. this.lastPosition.x = this.position.x;
  37883. this.lastPosition.y = this.position.y;
  37884. this.offsetElement(0, 0);
  37885. this.setHeight('100%');
  37886. this.setWidth('100%');
  37887. }
  37888. this.isMaximized = !this.isMaximized;
  37889. this.refreshMaximizeIcon();
  37890. };
  37891. AgDialog.prototype.refreshMaximizeIcon = function () {
  37892. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addOrRemoveCssClass(this.maximizeIcon, 'ag-hidden', this.isMaximized);
  37893. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addOrRemoveCssClass(this.minimizeIcon, 'ag-hidden', !this.isMaximized);
  37894. };
  37895. AgDialog.prototype.clearMaximizebleListeners = function () {
  37896. if (this.maximizeListeners.length) {
  37897. this.maximizeListeners.forEach(function (destroyListener) { return destroyListener(); });
  37898. this.maximizeListeners.length = 0;
  37899. }
  37900. if (this.resizeListenerDestroy) {
  37901. this.resizeListenerDestroy();
  37902. this.resizeListenerDestroy = null;
  37903. }
  37904. };
  37905. AgDialog.prototype.destroy = function () {
  37906. this.setResizable(false);
  37907. this.setMovable(false);
  37908. this.maximizeButtonComp = this.destroyBean(this.maximizeButtonComp);
  37909. this.clearMaximizebleListeners();
  37910. _super.prototype.destroy.call(this);
  37911. };
  37912. AgDialog.prototype.setResizable = function (resizable) {
  37913. var _this = this;
  37914. if (typeof resizable === 'boolean') {
  37915. resizable = {
  37916. topLeft: resizable,
  37917. top: resizable,
  37918. topRight: resizable,
  37919. right: resizable,
  37920. bottomRight: resizable,
  37921. bottom: resizable,
  37922. bottomLeft: resizable,
  37923. left: resizable
  37924. };
  37925. }
  37926. Object.keys(resizable).forEach(function (side) {
  37927. var r = resizable;
  37928. var s = side;
  37929. var val = !!r[s];
  37930. var el = _this.getResizerElement(s);
  37931. var params = _this.resizerMap[s].dragSource || {
  37932. eElement: el,
  37933. onDragStart: _this.onResizeStart.bind(_this),
  37934. onDragging: function (e) { return _this.onResize(e, s); },
  37935. onDragStop: _this.onResizeEnd.bind(_this),
  37936. };
  37937. if (!!_this.resizable[s] !== val || (!_this.isAlive() && !val)) {
  37938. if (val) {
  37939. _this.dragService.addDragSource(params);
  37940. el.style.pointerEvents = 'all';
  37941. }
  37942. else {
  37943. _this.dragService.removeDragSource(params);
  37944. el.style.pointerEvents = 'none';
  37945. }
  37946. _this.resizerMap[s].dragSource = val ? params : undefined;
  37947. }
  37948. });
  37949. };
  37950. AgDialog.prototype.setMovable = function (movable) {
  37951. if (movable === this.movable) {
  37952. return;
  37953. }
  37954. this.movable = movable;
  37955. var params = this.moveElementDragListener || {
  37956. eElement: this.moveElement,
  37957. onDragStart: this.onMoveStart.bind(this),
  37958. onDragging: this.onMove.bind(this),
  37959. onDragStop: this.onMoveEnd.bind(this)
  37960. };
  37961. if (movable) {
  37962. this.dragService.addDragSource(params);
  37963. this.moveElementDragListener = params;
  37964. }
  37965. else {
  37966. this.dragService.removeDragSource(params);
  37967. this.moveElementDragListener = undefined;
  37968. }
  37969. };
  37970. AgDialog.prototype.setMaximizable = function (maximizable) {
  37971. var _this = this;
  37972. if (maximizable === false) {
  37973. this.clearMaximizebleListeners();
  37974. if (this.maximizeButtonComp) {
  37975. this.destroyBean(this.maximizeButtonComp);
  37976. this.maximizeButtonComp = this.maximizeIcon = this.minimizeIcon = undefined;
  37977. }
  37978. return;
  37979. }
  37980. var eTitleBar = this.eTitleBar;
  37981. if (!eTitleBar || maximizable === this.isMaximizable) {
  37982. return;
  37983. }
  37984. var maximizeButtonComp = this.maximizeButtonComp = new _component__WEBPACK_IMPORTED_MODULE_2__["Component"](this.MAXIMIZE_BTN_TEMPLATE);
  37985. this.getContext().createBean(maximizeButtonComp);
  37986. var eGui = maximizeButtonComp.getGui();
  37987. eGui.appendChild(this.maximizeIcon = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].createIconNoSpan('maximize', this.gridOptionsWrapper));
  37988. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addCssClass(this.maximizeIcon, 'ag-panel-title-bar-button-icon');
  37989. eGui.appendChild(this.minimizeIcon = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].createIconNoSpan('minimize', this.gridOptionsWrapper));
  37990. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addCssClass(this.minimizeIcon, 'ag-panel-title-bar-button-icon');
  37991. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addCssClass(this.minimizeIcon, 'ag-hidden');
  37992. maximizeButtonComp.addManagedListener(eGui, 'click', this.toggleMaximize.bind(this));
  37993. this.addTitleBarButton(maximizeButtonComp, 0);
  37994. this.maximizeListeners.push(this.addManagedListener(eTitleBar, 'dblclick', this.toggleMaximize.bind(this)));
  37995. this.resizeListenerDestroy = this.addManagedListener(this, 'resize', function () {
  37996. _this.isMaximized = false;
  37997. _this.refreshMaximizeIcon();
  37998. });
  37999. };
  38000. __decorate([
  38001. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('dragService')
  38002. ], AgDialog.prototype, "dragService", void 0);
  38003. return AgDialog;
  38004. }(_agPanel__WEBPACK_IMPORTED_MODULE_1__["AgPanel"]));
  38005. /***/ }),
  38006. /* 172 */
  38007. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  38008. "use strict";
  38009. __webpack_require__.r(__webpack_exports__);
  38010. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgPanel", function() { return AgPanel; });
  38011. /* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57);
  38012. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  38013. /* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(56);
  38014. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  38015. /**
  38016. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  38017. * @version v23.2.1
  38018. * @link http://www.ag-grid.com/
  38019. * @license MIT
  38020. */
  38021. var __extends = (undefined && undefined.__extends) || (function () {
  38022. var extendStatics = function (d, b) {
  38023. extendStatics = Object.setPrototypeOf ||
  38024. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  38025. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  38026. return extendStatics(d, b);
  38027. };
  38028. return function (d, b) {
  38029. extendStatics(d, b);
  38030. function __() { this.constructor = d; }
  38031. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  38032. };
  38033. })();
  38034. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  38035. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  38036. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  38037. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  38038. return c > 3 && r && Object.defineProperty(target, key, r), r;
  38039. };
  38040. var AgPanel = /** @class */ (function (_super) {
  38041. __extends(AgPanel, _super);
  38042. function AgPanel(config) {
  38043. var _this = _super.call(this, AgPanel.getTemplate(config)) || this;
  38044. _this.closable = true;
  38045. _this.positioned = false;
  38046. _this.dragStartPosition = {
  38047. x: 0,
  38048. y: 0
  38049. };
  38050. _this.position = {
  38051. x: 0,
  38052. y: 0
  38053. };
  38054. _this.size = {
  38055. width: undefined,
  38056. height: undefined
  38057. };
  38058. _this.config = config;
  38059. return _this;
  38060. }
  38061. AgPanel.getTemplate = function (config) {
  38062. var cssIdentifier = (config && config.cssIdentifier) || 'default';
  38063. return /* html */ "<div class=\"ag-panel ag-" + cssIdentifier + "-panel\" tabindex=\"-1\">\n <div ref=\"eTitleBar\" class=\"ag-panel-title-bar ag-" + cssIdentifier + "-panel-title-bar ag-unselectable\">\n <span ref=\"eTitle\" class=\"ag-panel-title-bar-title ag-" + cssIdentifier + "-panel-title-bar-title\"></span>\n <div ref=\"eTitleBarButtons\" class=\"ag-panel-title-bar-buttons ag-" + cssIdentifier + "-panel-title-bar-buttons\"></div>\n </div>\n <div ref=\"eContentWrapper\" class=\"ag-panel-content-wrapper ag-" + cssIdentifier + "-panel-content-wrapper\"></div>\n </div>";
  38064. };
  38065. AgPanel.prototype.postConstruct = function () {
  38066. var _this = this;
  38067. var _a = this.config, component = _a.component, closable = _a.closable, hideTitleBar = _a.hideTitleBar, title = _a.title, minWidth = _a.minWidth, width = _a.width, minHeight = _a.minHeight, height = _a.height, centered = _a.centered, x = _a.x, y = _a.y;
  38068. var eGui = this.getGui();
  38069. if (component) {
  38070. this.setBodyComponent(component);
  38071. }
  38072. if (!hideTitleBar) {
  38073. if (title) {
  38074. this.setTitle(title);
  38075. }
  38076. this.setClosable(closable != null ? closable : this.closable);
  38077. }
  38078. else {
  38079. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addCssClass(this.eTitleBar, 'ag-hidden');
  38080. }
  38081. this.addManagedListener(this.eTitleBar, 'mousedown', function (e) {
  38082. if (eGui.contains(e.relatedTarget) ||
  38083. eGui.contains(document.activeElement) ||
  38084. _this.eTitleBarButtons.contains(e.target)) {
  38085. e.preventDefault();
  38086. return;
  38087. }
  38088. var focusEl = _this.eContentWrapper.querySelector('button, [href], input, select, textarea, [tabindex]');
  38089. if (focusEl) {
  38090. focusEl.focus();
  38091. }
  38092. });
  38093. if (this.positioned) {
  38094. return;
  38095. }
  38096. this.minHeight = minHeight != null ? minHeight : 250;
  38097. this.minWidth = minWidth != null ? minWidth : 250;
  38098. this.popupParent = this.popupService.getPopupParent();
  38099. if (width) {
  38100. this.setWidth(width);
  38101. }
  38102. if (height) {
  38103. this.setHeight(height);
  38104. }
  38105. if (this.renderComponent) {
  38106. this.renderComponent();
  38107. }
  38108. if (!width || !height) {
  38109. this.refreshSize();
  38110. }
  38111. if (centered) {
  38112. this.center();
  38113. }
  38114. else if (x || y) {
  38115. this.offsetElement(x, y);
  38116. }
  38117. this.positioned = true;
  38118. this.eContentWrapper.style.height = '0';
  38119. };
  38120. AgPanel.prototype.renderComponent = function () {
  38121. var _this = this;
  38122. var eGui = this.getGui();
  38123. eGui.focus();
  38124. this.close = function () {
  38125. eGui.parentElement.removeChild(eGui);
  38126. _this.destroy();
  38127. };
  38128. };
  38129. AgPanel.prototype.updateDragStartPosition = function (x, y) {
  38130. this.dragStartPosition = { x: x, y: y };
  38131. };
  38132. AgPanel.prototype.calculateMouseMovement = function (params) {
  38133. var parentRect = this.popupParent.getBoundingClientRect();
  38134. var e = params.e, isLeft = params.isLeft, isTop = params.isTop, anywhereWithin = params.anywhereWithin, topBuffer = params.topBuffer;
  38135. var movementX = e.clientX - this.dragStartPosition.x;
  38136. var movementY = e.clientY - this.dragStartPosition.y;
  38137. var width = this.getWidth();
  38138. var height = this.getHeight();
  38139. // skip if cursor is outside of popupParent horizontally
  38140. var skipX = (parentRect.left >= e.clientX && this.position.x <= 0 ||
  38141. parentRect.right <= e.clientX && parentRect.right <= this.position.x + parentRect.left + width);
  38142. if (!skipX) {
  38143. if (isLeft) {
  38144. skipX = (
  38145. // skip if we are moving to the left and the cursor
  38146. // is positioned to the right of the left side anchor
  38147. (movementX < 0 && e.clientX > this.position.x + parentRect.left) ||
  38148. // skip if we are moving to the right and the cursor
  38149. // is positioned to the left of the dialog
  38150. (movementX > 0 && e.clientX < this.position.x + parentRect.left));
  38151. }
  38152. else {
  38153. if (anywhereWithin) {
  38154. // if anywhereWithin is true, we allow to move
  38155. // as long as the cursor is within the dialog
  38156. skipX = ((movementX < 0 && e.clientX > this.position.x + parentRect.left + width) ||
  38157. (movementX > 0 && e.clientX < this.position.x + parentRect.left));
  38158. }
  38159. else {
  38160. skipX = (
  38161. // if the movement is bound to the right side of the dialog
  38162. // we skip if we are moving to the left and the cursor
  38163. // is to the right of the dialog
  38164. (movementX < 0 && e.clientX > this.position.x + parentRect.left + width) ||
  38165. // or skip if we are moving to the right and the cursor
  38166. // is to the left of the right side anchor
  38167. (movementX > 0 && e.clientX < this.position.x + parentRect.left + width));
  38168. }
  38169. }
  38170. }
  38171. movementX = skipX ? 0 : movementX;
  38172. var skipY = (
  38173. // skip if cursor is outside of popupParent vertically
  38174. parentRect.top >= e.clientY && this.position.y <= 0 ||
  38175. parentRect.bottom <= e.clientY && parentRect.bottom <= this.position.y + parentRect.top + height ||
  38176. isTop && (
  38177. // skip if we are moving to towards top and the cursor is
  38178. // below the top anchor + topBuffer
  38179. // note: topBuffer is used when moving the dialog using the title bar
  38180. (movementY < 0 && e.clientY > this.position.y + parentRect.top + (topBuffer || 0)) ||
  38181. // skip if we are moving to the bottom and the cursor is
  38182. // above the top anchor
  38183. (movementY > 0 && e.clientY < this.position.y + parentRect.top)) ||
  38184. // we are anchored to the bottom of the dialog
  38185. !isTop && (
  38186. // skip if we are moving towards the top and the cursor
  38187. // is below the bottom anchor
  38188. (movementY < 0 && e.clientY > this.position.y + parentRect.top + height) ||
  38189. // skip if we are moving towards the bottom and the cursor
  38190. // is above the bottom anchor
  38191. (movementY > 0 && e.clientY < this.position.y + parentRect.top + height)));
  38192. movementY = skipY ? 0 : movementY;
  38193. return { movementX: movementX, movementY: movementY };
  38194. };
  38195. AgPanel.prototype.refreshSize = function () {
  38196. var _a = this.size, width = _a.width, height = _a.height;
  38197. if (!width) {
  38198. this.setWidth(this.getGui().offsetWidth);
  38199. }
  38200. if (!height) {
  38201. this.setHeight(this.getGui().offsetHeight);
  38202. }
  38203. };
  38204. AgPanel.prototype.offsetElement = function (x, y) {
  38205. if (x === void 0) { x = 0; }
  38206. if (y === void 0) { y = 0; }
  38207. var ePopup = this.getGui();
  38208. this.popupService.positionPopup({
  38209. ePopup: ePopup,
  38210. x: x,
  38211. y: y,
  38212. minWidth: this.minWidth,
  38213. minHeight: this.minHeight,
  38214. keepWithinBounds: true
  38215. });
  38216. this.position.x = parseInt(ePopup.style.left, 10);
  38217. this.position.y = parseInt(ePopup.style.top, 10);
  38218. };
  38219. AgPanel.prototype.getHeight = function () {
  38220. return this.size.height;
  38221. };
  38222. AgPanel.prototype.setHeight = function (height) {
  38223. var eGui = this.getGui();
  38224. var isPercent = false;
  38225. if (typeof height === 'string' && height.indexOf('%') !== -1) {
  38226. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].setFixedHeight(eGui, height);
  38227. height = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].getAbsoluteHeight(eGui);
  38228. isPercent = true;
  38229. }
  38230. else {
  38231. height = Math.max(this.minHeight, height);
  38232. var offsetParent = eGui.offsetParent;
  38233. if (offsetParent && offsetParent.clientHeight && (height + this.position.y > offsetParent.clientHeight)) {
  38234. height = offsetParent.clientHeight - this.position.y;
  38235. }
  38236. }
  38237. if (this.size.height === height) {
  38238. return;
  38239. }
  38240. this.size.height = height;
  38241. if (!isPercent) {
  38242. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].setFixedHeight(eGui, height);
  38243. }
  38244. else {
  38245. eGui.style.maxHeight = 'unset';
  38246. eGui.style.minHeight = 'unset';
  38247. }
  38248. };
  38249. AgPanel.prototype.getWidth = function () {
  38250. return this.size.width;
  38251. };
  38252. AgPanel.prototype.setWidth = function (width) {
  38253. var eGui = this.getGui();
  38254. var isPercent = false;
  38255. if (typeof width === 'string' && width.indexOf('%') !== -1) {
  38256. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].setFixedWidth(eGui, width);
  38257. width = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].getAbsoluteWidth(eGui);
  38258. isPercent = true;
  38259. }
  38260. else {
  38261. width = Math.max(this.minWidth, width);
  38262. var offsetParent = eGui.offsetParent;
  38263. if (offsetParent && offsetParent.clientWidth && (width + this.position.x > offsetParent.clientWidth)) {
  38264. width = offsetParent.clientWidth - this.position.x;
  38265. }
  38266. }
  38267. if (this.size.width === width) {
  38268. return;
  38269. }
  38270. this.size.width = width;
  38271. if (!isPercent) {
  38272. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].setFixedWidth(eGui, width);
  38273. }
  38274. else {
  38275. eGui.style.maxWidth = 'unset';
  38276. eGui.style.minWidth = 'unset';
  38277. }
  38278. };
  38279. AgPanel.prototype.center = function () {
  38280. var eGui = this.getGui();
  38281. var x = (eGui.offsetParent.clientWidth / 2) - (this.getWidth() / 2);
  38282. var y = (eGui.offsetParent.clientHeight / 2) - (this.getHeight() / 2);
  38283. this.offsetElement(x, y);
  38284. };
  38285. AgPanel.prototype.setClosable = function (closable) {
  38286. if (closable !== this.closable) {
  38287. this.closable = closable;
  38288. }
  38289. if (closable) {
  38290. var closeButtonComp = this.closeButtonComp = new _component__WEBPACK_IMPORTED_MODULE_2__["Component"](AgPanel.CLOSE_BTN_TEMPLATE);
  38291. this.getContext().createBean(closeButtonComp);
  38292. var eGui = closeButtonComp.getGui();
  38293. eGui.appendChild(_utils__WEBPACK_IMPORTED_MODULE_3__["_"].addCssClass(_utils__WEBPACK_IMPORTED_MODULE_3__["_"].createIconNoSpan('close', this.gridOptionsWrapper), 'ag-panel-title-bar-button-icon'));
  38294. this.addTitleBarButton(closeButtonComp);
  38295. closeButtonComp.addManagedListener(eGui, 'click', this.onBtClose.bind(this));
  38296. }
  38297. else if (this.closeButtonComp) {
  38298. var eGui = this.closeButtonComp.getGui();
  38299. eGui.parentElement.removeChild(eGui);
  38300. this.closeButtonComp = this.destroyBean(this.closeButtonComp);
  38301. }
  38302. };
  38303. AgPanel.prototype.setBodyComponent = function (bodyComponent) {
  38304. bodyComponent.setParentComponent(this);
  38305. this.eContentWrapper.appendChild(bodyComponent.getGui());
  38306. };
  38307. AgPanel.prototype.addTitleBarButton = function (button, position) {
  38308. var eTitleBarButtons = this.eTitleBarButtons;
  38309. var buttons = eTitleBarButtons.children;
  38310. var len = buttons.length;
  38311. if (position == null) {
  38312. position = len;
  38313. }
  38314. position = Math.max(0, Math.min(position, len));
  38315. var eGui = button.getGui();
  38316. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].addCssClass(eGui, 'ag-panel-title-bar-button');
  38317. if (position === 0) {
  38318. eTitleBarButtons.insertAdjacentElement('afterbegin', eGui);
  38319. }
  38320. else if (position === len) {
  38321. eTitleBarButtons.insertAdjacentElement('beforeend', eGui);
  38322. }
  38323. else {
  38324. buttons[position - 1].insertAdjacentElement('afterend', eGui);
  38325. }
  38326. button.setParentComponent(this);
  38327. };
  38328. AgPanel.prototype.getBodyHeight = function () {
  38329. return _utils__WEBPACK_IMPORTED_MODULE_3__["_"].getInnerHeight(this.eContentWrapper);
  38330. };
  38331. AgPanel.prototype.getBodyWidth = function () {
  38332. return _utils__WEBPACK_IMPORTED_MODULE_3__["_"].getInnerWidth(this.eContentWrapper);
  38333. };
  38334. AgPanel.prototype.setTitle = function (title) {
  38335. this.eTitle.innerText = title;
  38336. };
  38337. // called when user hits the 'x' in the top right
  38338. AgPanel.prototype.onBtClose = function () {
  38339. this.close();
  38340. };
  38341. AgPanel.prototype.destroy = function () {
  38342. if (this.closeButtonComp) {
  38343. this.closeButtonComp = this.destroyBean(this.closeButtonComp);
  38344. }
  38345. var eGui = this.getGui();
  38346. if (eGui && eGui.offsetParent) {
  38347. this.close();
  38348. }
  38349. _super.prototype.destroy.call(this);
  38350. };
  38351. AgPanel.CLOSE_BTN_TEMPLATE = "<div class=\"ag-button\"></div>";
  38352. __decorate([
  38353. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('popupService')
  38354. ], AgPanel.prototype, "popupService", void 0);
  38355. __decorate([
  38356. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  38357. ], AgPanel.prototype, "gridOptionsWrapper", void 0);
  38358. __decorate([
  38359. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eContentWrapper')
  38360. ], AgPanel.prototype, "eContentWrapper", void 0);
  38361. __decorate([
  38362. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eTitleBar')
  38363. ], AgPanel.prototype, "eTitleBar", void 0);
  38364. __decorate([
  38365. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eTitleBarButtons')
  38366. ], AgPanel.prototype, "eTitleBarButtons", void 0);
  38367. __decorate([
  38368. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eTitle')
  38369. ], AgPanel.prototype, "eTitle", void 0);
  38370. __decorate([
  38371. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  38372. ], AgPanel.prototype, "postConstruct", null);
  38373. return AgPanel;
  38374. }(_component__WEBPACK_IMPORTED_MODULE_2__["Component"]));
  38375. /***/ }),
  38376. /* 173 */
  38377. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  38378. "use strict";
  38379. __webpack_require__.r(__webpack_exports__);
  38380. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgInputTextField", function() { return AgInputTextField; });
  38381. /* harmony import */ var _agAbstractInputField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(71);
  38382. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7);
  38383. /**
  38384. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  38385. * @version v23.2.1
  38386. * @link http://www.ag-grid.com/
  38387. * @license MIT
  38388. */
  38389. var __extends = (undefined && undefined.__extends) || (function () {
  38390. var extendStatics = function (d, b) {
  38391. extendStatics = Object.setPrototypeOf ||
  38392. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  38393. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  38394. return extendStatics(d, b);
  38395. };
  38396. return function (d, b) {
  38397. extendStatics(d, b);
  38398. function __() { this.constructor = d; }
  38399. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  38400. };
  38401. })();
  38402. var AgInputTextField = /** @class */ (function (_super) {
  38403. __extends(AgInputTextField, _super);
  38404. function AgInputTextField(config) {
  38405. var _this = _super.call(this) || this;
  38406. _this.className = 'ag-text-field';
  38407. _this.displayTag = 'input';
  38408. _this.inputType = 'text';
  38409. _this.setTemplate(_this.TEMPLATE.replace(/%displayField%/g, _this.displayTag));
  38410. if (config) {
  38411. _this.config = config;
  38412. }
  38413. return _this;
  38414. }
  38415. AgInputTextField.prototype.setValue = function (value, silent) {
  38416. var ret = _super.prototype.setValue.call(this, value, silent);
  38417. if (this.eInput.value !== value) {
  38418. this.eInput.value = _utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(value) ? value : '';
  38419. }
  38420. return ret;
  38421. };
  38422. return AgInputTextField;
  38423. }(_agAbstractInputField__WEBPACK_IMPORTED_MODULE_0__["AgAbstractInputField"]));
  38424. /***/ }),
  38425. /* 174 */
  38426. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  38427. "use strict";
  38428. __webpack_require__.r(__webpack_exports__);
  38429. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgInputTextArea", function() { return AgInputTextArea; });
  38430. /* harmony import */ var _agAbstractInputField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(71);
  38431. /**
  38432. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  38433. * @version v23.2.1
  38434. * @link http://www.ag-grid.com/
  38435. * @license MIT
  38436. */
  38437. var __extends = (undefined && undefined.__extends) || (function () {
  38438. var extendStatics = function (d, b) {
  38439. extendStatics = Object.setPrototypeOf ||
  38440. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  38441. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  38442. return extendStatics(d, b);
  38443. };
  38444. return function (d, b) {
  38445. extendStatics(d, b);
  38446. function __() { this.constructor = d; }
  38447. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  38448. };
  38449. })();
  38450. var AgInputTextArea = /** @class */ (function (_super) {
  38451. __extends(AgInputTextArea, _super);
  38452. function AgInputTextArea(config) {
  38453. var _this = _super.call(this) || this;
  38454. _this.className = 'ag-text-area';
  38455. _this.displayTag = 'textarea';
  38456. _this.inputType = '';
  38457. _this.setTemplate(_this.TEMPLATE.replace(/%displayField%/g, _this.displayTag));
  38458. if (config) {
  38459. _this.config = config;
  38460. }
  38461. return _this;
  38462. }
  38463. AgInputTextArea.prototype.setValue = function (value, silent) {
  38464. var ret = _super.prototype.setValue.call(this, value, silent);
  38465. this.eInput.value = value;
  38466. return ret;
  38467. };
  38468. AgInputTextArea.prototype.setCols = function (cols) {
  38469. this.eInput.cols = cols;
  38470. return this;
  38471. };
  38472. AgInputTextArea.prototype.setRows = function (rows) {
  38473. this.eInput.rows = rows;
  38474. return this;
  38475. };
  38476. return AgInputTextArea;
  38477. }(_agAbstractInputField__WEBPACK_IMPORTED_MODULE_0__["AgAbstractInputField"]));
  38478. /***/ }),
  38479. /* 175 */
  38480. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  38481. "use strict";
  38482. __webpack_require__.r(__webpack_exports__);
  38483. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgSlider", function() { return AgSlider; });
  38484. /* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(57);
  38485. /* harmony import */ var _agAbstractLabel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(73);
  38486. /* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(72);
  38487. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(37);
  38488. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7);
  38489. /**
  38490. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  38491. * @version v23.2.1
  38492. * @link http://www.ag-grid.com/
  38493. * @license MIT
  38494. */
  38495. var __extends = (undefined && undefined.__extends) || (function () {
  38496. var extendStatics = function (d, b) {
  38497. extendStatics = Object.setPrototypeOf ||
  38498. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  38499. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  38500. return extendStatics(d, b);
  38501. };
  38502. return function (d, b) {
  38503. extendStatics(d, b);
  38504. function __() { this.constructor = d; }
  38505. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  38506. };
  38507. })();
  38508. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  38509. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  38510. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  38511. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  38512. return c > 3 && r && Object.defineProperty(target, key, r), r;
  38513. };
  38514. var AgSlider = /** @class */ (function (_super) {
  38515. __extends(AgSlider, _super);
  38516. function AgSlider() {
  38517. var _this = _super.call(this, AgSlider.TEMPLATE) || this;
  38518. _this.labelAlignment = 'top';
  38519. return _this;
  38520. }
  38521. AgSlider.prototype.init = function () {
  38522. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(this.eSlider.getGui(), 'ag-slider-field');
  38523. };
  38524. AgSlider.prototype.onValueChange = function (callbackFn) {
  38525. var _this = this;
  38526. var eventChanged = _agAbstractField__WEBPACK_IMPORTED_MODULE_2__["AgAbstractField"].EVENT_CHANGED;
  38527. this.addManagedListener(this.eText, eventChanged, function () {
  38528. var textValue = parseFloat(_this.eText.getValue());
  38529. _this.eSlider.setValue(textValue.toString(), true);
  38530. callbackFn(textValue || 0);
  38531. });
  38532. this.addManagedListener(this.eSlider, eventChanged, function () {
  38533. var sliderValue = _this.eSlider.getValue();
  38534. _this.eText.setValue(sliderValue, true);
  38535. callbackFn(parseFloat(sliderValue));
  38536. });
  38537. return this;
  38538. };
  38539. AgSlider.prototype.setSliderWidth = function (width) {
  38540. this.eSlider.setWidth(width);
  38541. return this;
  38542. };
  38543. AgSlider.prototype.setTextFieldWidth = function (width) {
  38544. this.eText.setWidth(width);
  38545. return this;
  38546. };
  38547. AgSlider.prototype.setMinValue = function (minValue) {
  38548. this.eSlider.setMinValue(minValue);
  38549. this.eText.setMin(minValue);
  38550. return this;
  38551. };
  38552. AgSlider.prototype.setMaxValue = function (maxValue) {
  38553. this.eSlider.setMaxValue(maxValue);
  38554. this.eText.setMax(maxValue);
  38555. return this;
  38556. };
  38557. AgSlider.prototype.getValue = function () {
  38558. return this.eText.getValue();
  38559. };
  38560. AgSlider.prototype.setValue = function (value) {
  38561. if (this.getValue() === value) {
  38562. return this;
  38563. }
  38564. this.eText.setValue(value, true);
  38565. this.eSlider.setValue(value, true);
  38566. this.dispatchEvent({ type: _agAbstractField__WEBPACK_IMPORTED_MODULE_2__["AgAbstractField"].EVENT_CHANGED });
  38567. return this;
  38568. };
  38569. AgSlider.prototype.setStep = function (step) {
  38570. this.eSlider.setStep(step);
  38571. this.eText.setStep(step);
  38572. return this;
  38573. };
  38574. AgSlider.TEMPLATE = "<div class=\"ag-slider\">\n <label ref=\"eLabel\"></label>\n <div class=\"ag-wrapper ag-slider-wrapper\">\n <ag-input-range ref=\"eSlider\"></ag-input-range>\n <ag-input-number-field ref=\"eText\"></ag-input-number-field>\n </div>\n </div>";
  38575. __decorate([
  38576. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eLabel')
  38577. ], AgSlider.prototype, "eLabel", void 0);
  38578. __decorate([
  38579. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eSlider')
  38580. ], AgSlider.prototype, "eSlider", void 0);
  38581. __decorate([
  38582. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_0__["RefSelector"])('eText')
  38583. ], AgSlider.prototype, "eText", void 0);
  38584. __decorate([
  38585. _context_context__WEBPACK_IMPORTED_MODULE_3__["PostConstruct"]
  38586. ], AgSlider.prototype, "init", null);
  38587. return AgSlider;
  38588. }(_agAbstractLabel__WEBPACK_IMPORTED_MODULE_1__["AgAbstractLabel"]));
  38589. /***/ }),
  38590. /* 176 */
  38591. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  38592. "use strict";
  38593. __webpack_require__.r(__webpack_exports__);
  38594. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgColorPicker", function() { return AgColorPicker; });
  38595. /* harmony import */ var _agColorPanel__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(177);
  38596. /* harmony import */ var _agDialog__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(171);
  38597. /* harmony import */ var _agPickerField__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(178);
  38598. /* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(72);
  38599. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7);
  38600. /**
  38601. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  38602. * @version v23.2.1
  38603. * @link http://www.ag-grid.com/
  38604. * @license MIT
  38605. */
  38606. var __extends = (undefined && undefined.__extends) || (function () {
  38607. var extendStatics = function (d, b) {
  38608. extendStatics = Object.setPrototypeOf ||
  38609. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  38610. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  38611. return extendStatics(d, b);
  38612. };
  38613. return function (d, b) {
  38614. extendStatics(d, b);
  38615. function __() { this.constructor = d; }
  38616. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  38617. };
  38618. })();
  38619. var AgColorPicker = /** @class */ (function (_super) {
  38620. __extends(AgColorPicker, _super);
  38621. function AgColorPicker(config) {
  38622. var _this = _super.call(this) || this;
  38623. _this.displayTag = 'div';
  38624. _this.className = 'ag-color-picker';
  38625. _this.pickerIcon = 'colorPicker';
  38626. _this.setTemplate(_this.TEMPLATE.replace(/%displayField%/g, _this.displayTag));
  38627. if (config && config.color) {
  38628. _this.value = config.color;
  38629. }
  38630. return _this;
  38631. }
  38632. AgColorPicker.prototype.postConstruct = function () {
  38633. _super.prototype.postConstruct.call(this);
  38634. if (this.value) {
  38635. this.setValue(this.value);
  38636. }
  38637. };
  38638. AgColorPicker.prototype.showPicker = function () {
  38639. var _this = this;
  38640. var eGuiRect = this.getGui().getBoundingClientRect();
  38641. var colorDialog = new _agDialog__WEBPACK_IMPORTED_MODULE_1__["AgDialog"]({
  38642. closable: false,
  38643. modal: true,
  38644. hideTitleBar: true,
  38645. minWidth: 190,
  38646. width: 190,
  38647. height: 250,
  38648. x: eGuiRect.right - 190,
  38649. y: eGuiRect.top - 250
  38650. });
  38651. this.createBean(colorDialog);
  38652. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(colorDialog.getGui(), 'ag-color-dialog');
  38653. var colorPanel = new _agColorPanel__WEBPACK_IMPORTED_MODULE_0__["AgColorPanel"]({
  38654. picker: this
  38655. });
  38656. this.createBean(colorPanel);
  38657. colorPanel.addDestroyFunc(function () {
  38658. if (colorDialog.isAlive()) {
  38659. _this.destroyBean(colorDialog);
  38660. }
  38661. });
  38662. colorDialog.setParentComponent(this);
  38663. colorDialog.setBodyComponent(colorPanel);
  38664. colorPanel.setValue(this.getValue());
  38665. colorDialog.addDestroyFunc(function () {
  38666. var wasDestroying = _this.isDestroyingPicker;
  38667. // here we check if the picker was already being
  38668. // destroyed to avoid a stackoverflow
  38669. if (!wasDestroying) {
  38670. _this.isDestroyingPicker = true;
  38671. if (colorPanel.isAlive()) {
  38672. _this.destroyBean(colorPanel);
  38673. }
  38674. }
  38675. else {
  38676. _this.isDestroyingPicker = false;
  38677. }
  38678. if (_this.isAlive()) {
  38679. _this.getFocusableElement().focus();
  38680. }
  38681. });
  38682. return colorDialog;
  38683. };
  38684. AgColorPicker.prototype.setValue = function (color) {
  38685. if (this.value === color) {
  38686. return this;
  38687. }
  38688. this.value = color;
  38689. this.eDisplayField.style.backgroundColor = color;
  38690. this.dispatchEvent({ type: _agAbstractField__WEBPACK_IMPORTED_MODULE_3__["AgAbstractField"].EVENT_CHANGED });
  38691. return this;
  38692. };
  38693. AgColorPicker.prototype.getValue = function () {
  38694. return this.value;
  38695. };
  38696. return AgColorPicker;
  38697. }(_agPickerField__WEBPACK_IMPORTED_MODULE_2__["AgPickerField"]));
  38698. /***/ }),
  38699. /* 177 */
  38700. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  38701. "use strict";
  38702. __webpack_require__.r(__webpack_exports__);
  38703. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgColorPanel", function() { return AgColorPanel; });
  38704. /* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(56);
  38705. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7);
  38706. /* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(57);
  38707. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(37);
  38708. /**
  38709. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  38710. * @version v23.2.1
  38711. * @link http://www.ag-grid.com/
  38712. * @license MIT
  38713. */
  38714. var __extends = (undefined && undefined.__extends) || (function () {
  38715. var extendStatics = function (d, b) {
  38716. extendStatics = Object.setPrototypeOf ||
  38717. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  38718. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  38719. return extendStatics(d, b);
  38720. };
  38721. return function (d, b) {
  38722. extendStatics(d, b);
  38723. function __() { this.constructor = d; }
  38724. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  38725. };
  38726. })();
  38727. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  38728. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  38729. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  38730. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  38731. return c > 3 && r && Object.defineProperty(target, key, r), r;
  38732. };
  38733. var AgColorPanel = /** @class */ (function (_super) {
  38734. __extends(AgColorPanel, _super);
  38735. function AgColorPanel(config) {
  38736. var _this = _super.call(this, AgColorPanel.TEMPLATE) || this;
  38737. _this.H = 1; // in the [0, 1] range
  38738. _this.S = 1; // in the [0, 1] range
  38739. _this.B = 1; // in the [0, 1] range
  38740. _this.A = 1; // in the [0, 1] range
  38741. _this.isSpectrumDragging = false;
  38742. _this.isSpectrumHueDragging = false;
  38743. _this.isSpectrumAlphaDragging = false;
  38744. _this.colorChanged = false;
  38745. _this.picker = config.picker;
  38746. return _this;
  38747. }
  38748. AgColorPanel.prototype.postConstruct = function () {
  38749. var eGui = this.getGui();
  38750. this.initRecentColors();
  38751. this.addManagedListener(this.spectrumVal, 'mousedown', this.onSpectrumDraggerDown.bind(this));
  38752. this.addManagedListener(eGui, 'mousemove', this.onSpectrumDraggerMove.bind(this));
  38753. this.addManagedListener(this.spectrumHue, 'mousedown', this.onSpectrumHueDown.bind(this));
  38754. this.addManagedListener(eGui, 'mousemove', this.onSpectrumHueMove.bind(this));
  38755. this.addManagedListener(this.spectrumAlpha, 'mousedown', this.onSpectrumAlphaDown.bind(this));
  38756. this.addManagedListener(eGui, 'mousemove', this.onSpectrumAlphaMove.bind(this));
  38757. // Listening to `mouseup` on the document on purpose. The user might release the mouse button
  38758. // outside the UI control. When the mouse returns back to the control's area, the dragging
  38759. // of the thumb is not expected and seen as a bug.
  38760. this.addManagedListener(document, 'mouseup', this.onMouseUp.bind(this));
  38761. this.addManagedListener(this.recentColors, 'click', this.onRecentColorClick.bind(this));
  38762. };
  38763. AgColorPanel.prototype.refreshSpectrumRect = function () {
  38764. return this.spectrumValRect = this.spectrumVal.getBoundingClientRect();
  38765. };
  38766. AgColorPanel.prototype.refreshHueRect = function () {
  38767. return this.spectrumHueRect = this.spectrumHue.getBoundingClientRect();
  38768. };
  38769. AgColorPanel.prototype.refreshAlphaRect = function () {
  38770. return this.spectrumAlphaRect = this.spectrumAlpha.getBoundingClientRect();
  38771. };
  38772. AgColorPanel.prototype.onSpectrumDraggerDown = function (e) {
  38773. this.refreshSpectrumRect();
  38774. this.isSpectrumDragging = true;
  38775. this.moveDragger(e);
  38776. };
  38777. AgColorPanel.prototype.onSpectrumDraggerMove = function (e) {
  38778. if (this.isSpectrumDragging) {
  38779. this.moveDragger(e);
  38780. }
  38781. };
  38782. AgColorPanel.prototype.onSpectrumHueDown = function (e) {
  38783. this.refreshHueRect();
  38784. this.isSpectrumHueDragging = true;
  38785. this.moveHueSlider(e);
  38786. };
  38787. AgColorPanel.prototype.onSpectrumHueMove = function (e) {
  38788. if (this.isSpectrumHueDragging) {
  38789. this.moveHueSlider(e);
  38790. }
  38791. };
  38792. AgColorPanel.prototype.onSpectrumAlphaDown = function (e) {
  38793. this.refreshAlphaRect();
  38794. this.isSpectrumAlphaDragging = true;
  38795. this.moveAlphaSlider(e);
  38796. };
  38797. AgColorPanel.prototype.onSpectrumAlphaMove = function (e) {
  38798. if (this.isSpectrumAlphaDragging) {
  38799. this.moveAlphaSlider(e);
  38800. }
  38801. };
  38802. AgColorPanel.prototype.onMouseUp = function () {
  38803. this.isSpectrumDragging = false;
  38804. this.isSpectrumHueDragging = false;
  38805. this.isSpectrumAlphaDragging = false;
  38806. };
  38807. AgColorPanel.prototype.moveDragger = function (e) {
  38808. var valRect = this.spectrumValRect;
  38809. if (valRect) {
  38810. var x = e.clientX - valRect.left;
  38811. var y = e.clientY - valRect.top;
  38812. x = Math.max(x, 0);
  38813. x = Math.min(x, valRect.width);
  38814. y = Math.max(y, 0);
  38815. y = Math.min(y, valRect.height);
  38816. this.setSpectrumValue(x / valRect.width, 1 - y / valRect.height);
  38817. }
  38818. };
  38819. AgColorPanel.prototype.moveHueSlider = function (e) {
  38820. var hueRect = this.spectrumHueRect;
  38821. if (hueRect) {
  38822. var slider = this.spectrumHueSlider;
  38823. var sliderRect = slider.getBoundingClientRect();
  38824. var x = e.clientX - hueRect.left;
  38825. x = Math.max(x, 0);
  38826. x = Math.min(x, hueRect.width);
  38827. this.H = 1 - x / hueRect.width;
  38828. slider.style.left = (x + sliderRect.width / 2) + 'px';
  38829. this.update();
  38830. }
  38831. };
  38832. AgColorPanel.prototype.moveAlphaSlider = function (e) {
  38833. var alphaRect = this.spectrumAlphaRect;
  38834. if (alphaRect) {
  38835. var slider = this.spectrumAlphaSlider;
  38836. var sliderRect = slider.getBoundingClientRect();
  38837. var x = e.clientX - alphaRect.left;
  38838. x = Math.max(x, 0);
  38839. x = Math.min(x, alphaRect.width);
  38840. this.A = x / alphaRect.width;
  38841. slider.style.left = (x + sliderRect.width / 2) + 'px';
  38842. this.update();
  38843. }
  38844. };
  38845. AgColorPanel.prototype.update = function () {
  38846. var color = _utils__WEBPACK_IMPORTED_MODULE_1__["Color"].fromHSB(this.H * 360, this.S, this.B, this.A);
  38847. var spectrumColor = _utils__WEBPACK_IMPORTED_MODULE_1__["Color"].fromHSB(this.H * 360, 1, 1);
  38848. var rgbaColor = color.toRgbaString();
  38849. // the recent color list needs to know color has actually changed
  38850. var colorPicker = this.picker;
  38851. var existingColor = _utils__WEBPACK_IMPORTED_MODULE_1__["Color"].fromString(colorPicker.getValue());
  38852. if (existingColor.toRgbaString() !== rgbaColor) {
  38853. this.colorChanged = true;
  38854. }
  38855. colorPicker.setValue(rgbaColor);
  38856. this.spectrumColor.style.backgroundColor = spectrumColor.toRgbaString();
  38857. this.spectrumDragger.style.backgroundColor = rgbaColor;
  38858. };
  38859. /**
  38860. * @param saturation In the [0, 1] interval.
  38861. * @param brightness In the [0, 1] interval.
  38862. */
  38863. AgColorPanel.prototype.setSpectrumValue = function (saturation, brightness) {
  38864. var valRect = this.spectrumValRect || this.refreshSpectrumRect();
  38865. if (valRect) {
  38866. var dragger = this.spectrumDragger;
  38867. var draggerRect = dragger.getBoundingClientRect();
  38868. saturation = Math.max(0, saturation);
  38869. saturation = Math.min(1, saturation);
  38870. brightness = Math.max(0, brightness);
  38871. brightness = Math.min(1, brightness);
  38872. this.S = saturation;
  38873. this.B = brightness;
  38874. dragger.style.left = (saturation * valRect.width - draggerRect.width / 2) + 'px';
  38875. dragger.style.top = ((1 - brightness) * valRect.height - draggerRect.height / 2) + 'px';
  38876. this.update();
  38877. }
  38878. };
  38879. AgColorPanel.prototype.initRecentColors = function () {
  38880. var recentColors = AgColorPanel.recentColors;
  38881. var innerHtml = recentColors.map(function (color, index) {
  38882. return "<div class=\"ag-recent-color\" id=" + index + " style=\"background-color: " + color + "; width: 15px; height: 15px;\" recent-color=\"" + color + "\"></div>";
  38883. });
  38884. this.recentColors.innerHTML = innerHtml.join('');
  38885. };
  38886. AgColorPanel.prototype.setValue = function (val) {
  38887. var color = _utils__WEBPACK_IMPORTED_MODULE_1__["Color"].fromString(val);
  38888. var _a = color.toHSB(), h = _a[0], s = _a[1], b = _a[2];
  38889. this.H = (isNaN(h) ? 0 : h) / 360;
  38890. this.A = color.a;
  38891. var spectrumHueRect = this.spectrumHueRect || this.refreshHueRect();
  38892. var spectrumAlphaRect = this.spectrumAlphaRect || this.refreshAlphaRect();
  38893. this.spectrumHueSlider.style.left = ((this.H - 1) * -spectrumHueRect.width) + "px";
  38894. this.spectrumAlphaSlider.style.left = (this.A * spectrumAlphaRect.width) + "px";
  38895. this.setSpectrumValue(s, b);
  38896. };
  38897. AgColorPanel.prototype.onRecentColorClick = function (e) {
  38898. var target = e.target;
  38899. if (!_utils__WEBPACK_IMPORTED_MODULE_1__["_"].exists(target.id)) {
  38900. return;
  38901. }
  38902. var id = parseInt(target.id, 10);
  38903. this.setValue(AgColorPanel.recentColors[id]);
  38904. this.destroy();
  38905. };
  38906. AgColorPanel.prototype.addRecentColor = function () {
  38907. var color = _utils__WEBPACK_IMPORTED_MODULE_1__["Color"].fromHSB(this.H * 360, this.S, this.B, this.A);
  38908. var rgbaColor = color.toRgbaString();
  38909. var recentColors = AgColorPanel.recentColors;
  38910. if (!this.colorChanged || recentColors[0] === rgbaColor) {
  38911. return;
  38912. }
  38913. // remove duplicate color
  38914. recentColors = recentColors.filter(function (color) { return color != rgbaColor; });
  38915. // add color to head
  38916. recentColors = [rgbaColor].concat(recentColors);
  38917. // ensure we don't exceed max number of recent colors
  38918. if (recentColors.length > AgColorPanel.maxRecentColors) {
  38919. recentColors = recentColors.slice(0, AgColorPanel.maxRecentColors);
  38920. }
  38921. AgColorPanel.recentColors = recentColors;
  38922. };
  38923. AgColorPanel.prototype.destroy = function () {
  38924. this.addRecentColor();
  38925. _super.prototype.destroy.call(this);
  38926. };
  38927. AgColorPanel.maxRecentColors = 8;
  38928. AgColorPanel.recentColors = [];
  38929. AgColorPanel.TEMPLATE = "<div class=\"ag-color-panel\">\n <div ref=\"spectrumColor\" class=\"ag-spectrum-color\">\n <div class=\"ag-spectrum-sat ag-spectrum-fill\">\n <div ref=\"spectrumVal\" class=\"ag-spectrum-val ag-spectrum-fill\">\n <div ref=\"spectrumDragger\" class=\"ag-spectrum-dragger\"></div>\n </div>\n </div>\n </div>\n <div class=\"ag-spectrum-tools\">\n <div ref=\"spectrumHue\" class=\"ag-spectrum-hue ag-spectrum-tool\">\n <div class=\"ag-spectrum-hue-background\"></div>\n <div ref=\"spectrumHueSlider\" class=\"ag-spectrum-slider\"></div>\n </div>\n <div ref=\"spectrumAlpha\" class=\"ag-spectrum-alpha ag-spectrum-tool\">\n <div class=\"ag-spectrum-alpha-background\"></div>\n <div ref=\"spectrumAlphaSlider\" class=\"ag-spectrum-slider\"></div>\n </div>\n <div ref=\"recentColors\" class=\"ag-recent-colors\"></div>\n </div>\n </div>";
  38930. __decorate([
  38931. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumColor')
  38932. ], AgColorPanel.prototype, "spectrumColor", void 0);
  38933. __decorate([
  38934. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumVal')
  38935. ], AgColorPanel.prototype, "spectrumVal", void 0);
  38936. __decorate([
  38937. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumDragger')
  38938. ], AgColorPanel.prototype, "spectrumDragger", void 0);
  38939. __decorate([
  38940. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumHue')
  38941. ], AgColorPanel.prototype, "spectrumHue", void 0);
  38942. __decorate([
  38943. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumHueSlider')
  38944. ], AgColorPanel.prototype, "spectrumHueSlider", void 0);
  38945. __decorate([
  38946. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumAlpha')
  38947. ], AgColorPanel.prototype, "spectrumAlpha", void 0);
  38948. __decorate([
  38949. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('spectrumAlphaSlider')
  38950. ], AgColorPanel.prototype, "spectrumAlphaSlider", void 0);
  38951. __decorate([
  38952. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_2__["RefSelector"])('recentColors')
  38953. ], AgColorPanel.prototype, "recentColors", void 0);
  38954. __decorate([
  38955. _context_context__WEBPACK_IMPORTED_MODULE_3__["PostConstruct"]
  38956. ], AgColorPanel.prototype, "postConstruct", null);
  38957. return AgColorPanel;
  38958. }(_component__WEBPACK_IMPORTED_MODULE_0__["Component"]));
  38959. /***/ }),
  38960. /* 178 */
  38961. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  38962. "use strict";
  38963. __webpack_require__.r(__webpack_exports__);
  38964. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgPickerField", function() { return AgPickerField; });
  38965. /* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(72);
  38966. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  38967. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25);
  38968. /* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(57);
  38969. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7);
  38970. /**
  38971. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  38972. * @version v23.2.1
  38973. * @link http://www.ag-grid.com/
  38974. * @license MIT
  38975. */
  38976. var __extends = (undefined && undefined.__extends) || (function () {
  38977. var extendStatics = function (d, b) {
  38978. extendStatics = Object.setPrototypeOf ||
  38979. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  38980. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  38981. return extendStatics(d, b);
  38982. };
  38983. return function (d, b) {
  38984. extendStatics(d, b);
  38985. function __() { this.constructor = d; }
  38986. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  38987. };
  38988. })();
  38989. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  38990. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  38991. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  38992. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  38993. return c > 3 && r && Object.defineProperty(target, key, r), r;
  38994. };
  38995. var AgPickerField = /** @class */ (function (_super) {
  38996. __extends(AgPickerField, _super);
  38997. function AgPickerField() {
  38998. var _this = _super !== null && _super.apply(this, arguments) || this;
  38999. _this.TEMPLATE = "<div class=\"ag-picker-field\" role=\"presentation\">\n <label ref=\"eLabel\"></label>\n <div ref=\"eWrapper\" class=\"ag-wrapper ag-picker-field-wrapper\" tabIndex=\"-1\">\n <%displayField% ref=\"eDisplayField\" class=\"ag-picker-field-display\"></%displayField%>\n <div ref=\"eIcon\" class=\"ag-picker-field-icon\"></div>\n </div>\n </div>";
  39000. _this.isDestroyingPicker = false;
  39001. _this.skipClick = false;
  39002. return _this;
  39003. }
  39004. AgPickerField.prototype.postConstruct = function () {
  39005. var _this = this;
  39006. _super.prototype.postConstruct.call(this);
  39007. var clickHandler = function () {
  39008. if (_this.skipClick) {
  39009. _this.skipClick = false;
  39010. return;
  39011. }
  39012. if (_this.isDisabled()) {
  39013. return;
  39014. }
  39015. _this.pickerComponent = _this.showPicker();
  39016. };
  39017. var eGui = this.getGui();
  39018. this.addManagedListener(eGui, 'mousedown', function (e) {
  39019. if (!_this.skipClick &&
  39020. _this.pickerComponent &&
  39021. _this.pickerComponent.isAlive() &&
  39022. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].isVisible(_this.pickerComponent.getGui()) &&
  39023. eGui.contains(e.target)) {
  39024. _this.skipClick = true;
  39025. }
  39026. });
  39027. this.addManagedListener(eGui, 'keydown', function (e) {
  39028. switch (e.keyCode) {
  39029. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_UP:
  39030. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_DOWN:
  39031. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_ENTER:
  39032. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_SPACE:
  39033. clickHandler();
  39034. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_ESCAPE:
  39035. e.preventDefault();
  39036. break;
  39037. }
  39038. });
  39039. this.addManagedListener(this.eWrapper, 'click', clickHandler);
  39040. this.addManagedListener(this.eLabel, 'click', clickHandler);
  39041. if (this.pickerIcon) {
  39042. this.eIcon.appendChild(_utils__WEBPACK_IMPORTED_MODULE_4__["_"].createIconNoSpan(this.pickerIcon, this.gridOptionsWrapper, null));
  39043. }
  39044. };
  39045. AgPickerField.prototype.setInputWidth = function (width) {
  39046. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].setElementWidth(this.eWrapper, width);
  39047. return this;
  39048. };
  39049. AgPickerField.prototype.getFocusableElement = function () {
  39050. return this.eWrapper;
  39051. };
  39052. __decorate([
  39053. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  39054. ], AgPickerField.prototype, "gridOptionsWrapper", void 0);
  39055. __decorate([
  39056. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eLabel')
  39057. ], AgPickerField.prototype, "eLabel", void 0);
  39058. __decorate([
  39059. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eWrapper')
  39060. ], AgPickerField.prototype, "eWrapper", void 0);
  39061. __decorate([
  39062. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eDisplayField')
  39063. ], AgPickerField.prototype, "eDisplayField", void 0);
  39064. __decorate([
  39065. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_3__["RefSelector"])('eIcon')
  39066. ], AgPickerField.prototype, "eIcon", void 0);
  39067. return AgPickerField;
  39068. }(_agAbstractField__WEBPACK_IMPORTED_MODULE_0__["AgAbstractField"]));
  39069. /***/ }),
  39070. /* 179 */
  39071. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  39072. "use strict";
  39073. __webpack_require__.r(__webpack_exports__);
  39074. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgInputNumberField", function() { return AgInputNumberField; });
  39075. /* harmony import */ var _agInputTextField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(173);
  39076. /**
  39077. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  39078. * @version v23.2.1
  39079. * @link http://www.ag-grid.com/
  39080. * @license MIT
  39081. */
  39082. var __extends = (undefined && undefined.__extends) || (function () {
  39083. var extendStatics = function (d, b) {
  39084. extendStatics = Object.setPrototypeOf ||
  39085. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  39086. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  39087. return extendStatics(d, b);
  39088. };
  39089. return function (d, b) {
  39090. extendStatics(d, b);
  39091. function __() { this.constructor = d; }
  39092. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  39093. };
  39094. })();
  39095. var AgInputNumberField = /** @class */ (function (_super) {
  39096. __extends(AgInputNumberField, _super);
  39097. function AgInputNumberField() {
  39098. var _this = _super !== null && _super.apply(this, arguments) || this;
  39099. _this.className = 'ag-number-field';
  39100. _this.inputType = 'number';
  39101. return _this;
  39102. }
  39103. AgInputNumberField.prototype.postConstruct = function () {
  39104. var _this = this;
  39105. _super.prototype.postConstruct.call(this);
  39106. this.addManagedListener(this.eInput, 'blur', function () {
  39107. var floatedValue = parseFloat(_this.eInput.value);
  39108. var value = isNaN(floatedValue) ? '' : _this.normalizeValue(floatedValue.toString());
  39109. if (_this.value !== value) {
  39110. _this.setValue(value);
  39111. }
  39112. });
  39113. };
  39114. AgInputNumberField.prototype.normalizeValue = function (value) {
  39115. if (value === '') {
  39116. return '';
  39117. }
  39118. if (this.precision) {
  39119. value = this.adjustPrecision(value);
  39120. }
  39121. var val = parseFloat(value);
  39122. if (this.min != null && val < this.min) {
  39123. value = this.min.toString();
  39124. }
  39125. else if (this.max != null && val > this.max) {
  39126. value = this.max.toString();
  39127. }
  39128. return value;
  39129. };
  39130. AgInputNumberField.prototype.adjustPrecision = function (value) {
  39131. if (this.precision) {
  39132. var floatString = parseFloat(value).toFixed(this.precision);
  39133. value = parseFloat(floatString).toString();
  39134. }
  39135. return value;
  39136. };
  39137. AgInputNumberField.prototype.setMin = function (min) {
  39138. if (this.min === min) {
  39139. return this;
  39140. }
  39141. this.min = min;
  39142. if (this.min != null) {
  39143. this.eInput.setAttribute('min', min.toString());
  39144. }
  39145. else {
  39146. this.eInput.removeAttribute('min');
  39147. }
  39148. return this;
  39149. };
  39150. AgInputNumberField.prototype.setMax = function (max) {
  39151. if (this.max === max) {
  39152. return this;
  39153. }
  39154. this.max = max;
  39155. if (this.max != null) {
  39156. this.eInput.setAttribute('max', max.toString());
  39157. }
  39158. else {
  39159. this.eInput.removeAttribute('max');
  39160. }
  39161. return this;
  39162. };
  39163. AgInputNumberField.prototype.setPrecision = function (precision) {
  39164. this.precision = precision;
  39165. return this;
  39166. };
  39167. AgInputNumberField.prototype.setStep = function (step) {
  39168. if (this.step === step) {
  39169. return this;
  39170. }
  39171. this.step = step;
  39172. if (step != null) {
  39173. this.eInput.setAttribute('step', step.toString());
  39174. }
  39175. else {
  39176. this.eInput.removeAttribute('step');
  39177. }
  39178. return this;
  39179. };
  39180. AgInputNumberField.prototype.setValue = function (value, silent) {
  39181. value = this.adjustPrecision(value);
  39182. var normalizedValue = this.normalizeValue(value);
  39183. if (value != normalizedValue) {
  39184. return this;
  39185. }
  39186. return _super.prototype.setValue.call(this, value, silent);
  39187. };
  39188. return AgInputNumberField;
  39189. }(_agInputTextField__WEBPACK_IMPORTED_MODULE_0__["AgInputTextField"]));
  39190. /***/ }),
  39191. /* 180 */
  39192. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  39193. "use strict";
  39194. __webpack_require__.r(__webpack_exports__);
  39195. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgInputRange", function() { return AgInputRange; });
  39196. /* harmony import */ var _agAbstractInputField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(71);
  39197. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7);
  39198. /**
  39199. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  39200. * @version v23.2.1
  39201. * @link http://www.ag-grid.com/
  39202. * @license MIT
  39203. */
  39204. var __extends = (undefined && undefined.__extends) || (function () {
  39205. var extendStatics = function (d, b) {
  39206. extendStatics = Object.setPrototypeOf ||
  39207. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  39208. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  39209. return extendStatics(d, b);
  39210. };
  39211. return function (d, b) {
  39212. extendStatics(d, b);
  39213. function __() { this.constructor = d; }
  39214. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  39215. };
  39216. })();
  39217. var AgInputRange = /** @class */ (function (_super) {
  39218. __extends(AgInputRange, _super);
  39219. function AgInputRange(config) {
  39220. var _this = _super.call(this) || this;
  39221. _this.className = 'ag-range-field';
  39222. _this.displayTag = 'input';
  39223. _this.inputType = 'range';
  39224. _this.setTemplate(_this.TEMPLATE.replace(/%displayField%/g, _this.displayTag));
  39225. if (config) {
  39226. _this.config = config;
  39227. }
  39228. return _this;
  39229. }
  39230. AgInputRange.prototype.postConstruct = function () {
  39231. _super.prototype.postConstruct.call(this);
  39232. var _a = this.config, min = _a.min, max = _a.max, step = _a.step;
  39233. if (min != null) {
  39234. this.setMinValue(min);
  39235. }
  39236. if (max != null) {
  39237. this.setMaxValue(max);
  39238. }
  39239. this.setStep(step || 1);
  39240. };
  39241. AgInputRange.prototype.addInputListeners = function () {
  39242. var _this = this;
  39243. var isIE = _utils__WEBPACK_IMPORTED_MODULE_1__["_"].isBrowserIE();
  39244. var eventName = isIE ? 'change' : 'input';
  39245. this.addManagedListener(this.eInput, eventName, function (e) {
  39246. var value = e.target.value;
  39247. _this.setValue(value);
  39248. });
  39249. };
  39250. AgInputRange.prototype.setMinValue = function (value) {
  39251. this.min = value;
  39252. this.eInput.setAttribute('min', value.toString());
  39253. return this;
  39254. };
  39255. AgInputRange.prototype.setMaxValue = function (value) {
  39256. this.max = value;
  39257. this.eInput.setAttribute('max', value.toString());
  39258. return this;
  39259. };
  39260. AgInputRange.prototype.setStep = function (value) {
  39261. this.step = value;
  39262. this.eInput.setAttribute('step', value.toString());
  39263. return this;
  39264. };
  39265. AgInputRange.prototype.setValue = function (value, silent) {
  39266. if (this.min != null) {
  39267. value = Math.max(parseFloat(value), this.min).toString();
  39268. }
  39269. if (this.max != null) {
  39270. value = Math.min(parseFloat(value), this.max).toString();
  39271. }
  39272. var ret = _super.prototype.setValue.call(this, value, silent);
  39273. this.eInput.value = value;
  39274. return ret;
  39275. };
  39276. return AgInputRange;
  39277. }(_agAbstractInputField__WEBPACK_IMPORTED_MODULE_0__["AgAbstractInputField"]));
  39278. /***/ }),
  39279. /* 181 */
  39280. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  39281. "use strict";
  39282. __webpack_require__.r(__webpack_exports__);
  39283. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgSelect", function() { return AgSelect; });
  39284. /* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(72);
  39285. /* harmony import */ var _agPickerField__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(178);
  39286. /* harmony import */ var _agList__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(182);
  39287. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(37);
  39288. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7);
  39289. /**
  39290. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  39291. * @version v23.2.1
  39292. * @link http://www.ag-grid.com/
  39293. * @license MIT
  39294. */
  39295. var __extends = (undefined && undefined.__extends) || (function () {
  39296. var extendStatics = function (d, b) {
  39297. extendStatics = Object.setPrototypeOf ||
  39298. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  39299. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  39300. return extendStatics(d, b);
  39301. };
  39302. return function (d, b) {
  39303. extendStatics(d, b);
  39304. function __() { this.constructor = d; }
  39305. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  39306. };
  39307. })();
  39308. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  39309. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  39310. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  39311. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  39312. return c > 3 && r && Object.defineProperty(target, key, r), r;
  39313. };
  39314. var AgSelect = /** @class */ (function (_super) {
  39315. __extends(AgSelect, _super);
  39316. function AgSelect(config) {
  39317. var _this = _super.call(this) || this;
  39318. _this.displayTag = 'div';
  39319. _this.className = 'ag-select';
  39320. _this.pickerIcon = 'smallDown';
  39321. _this.setTemplate(_this.TEMPLATE.replace(/%displayField%/g, _this.displayTag));
  39322. return _this;
  39323. }
  39324. AgSelect.prototype.init = function () {
  39325. var _this = this;
  39326. this.listComponent = new _agList__WEBPACK_IMPORTED_MODULE_2__["AgList"]('select');
  39327. this.getContext().createBean(this.listComponent);
  39328. this.listComponent.setParentComponent(this);
  39329. this.eWrapper.tabIndex = 0;
  39330. this.listComponent.addManagedListener(this.listComponent, _agList__WEBPACK_IMPORTED_MODULE_2__["AgList"].EVENT_ITEM_SELECTED, function () { if (_this.hideList) {
  39331. _this.hideList();
  39332. } });
  39333. this.listComponent.addManagedListener(this.listComponent, _agAbstractField__WEBPACK_IMPORTED_MODULE_0__["AgAbstractField"].EVENT_CHANGED, function () {
  39334. _this.setValue(_this.listComponent.getValue(), false, true);
  39335. if (_this.hideList) {
  39336. _this.hideList();
  39337. }
  39338. });
  39339. };
  39340. AgSelect.prototype.showPicker = function () {
  39341. var _this = this;
  39342. var listGui = this.listComponent.getGui();
  39343. var mouseWheelFunc = this.addManagedListener(document.body, 'wheel', function (e) {
  39344. if (!listGui.contains(e.target) && _this.hideList) {
  39345. _this.hideList();
  39346. }
  39347. });
  39348. var focusOutFunc = this.addManagedListener(listGui, 'focusout', function (e) {
  39349. if (!listGui.contains(e.relatedTarget) && _this.hideList) {
  39350. _this.hideList();
  39351. }
  39352. });
  39353. this.hideList = this.popupService.addPopup(true, listGui, true, function () {
  39354. _this.hideList = null;
  39355. focusOutFunc();
  39356. mouseWheelFunc();
  39357. if (_this.isAlive()) {
  39358. _this.getFocusableElement().focus();
  39359. }
  39360. });
  39361. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].setElementWidth(listGui, _utils__WEBPACK_IMPORTED_MODULE_4__["_"].getAbsoluteWidth(this.eWrapper));
  39362. listGui.style.maxHeight = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].getInnerHeight(this.popupService.getPopupParent()) + 'px';
  39363. listGui.style.position = 'absolute';
  39364. this.popupService.positionPopupUnderComponent({
  39365. type: 'ag-list',
  39366. eventSource: this.eWrapper,
  39367. ePopup: listGui,
  39368. keepWithinBounds: true
  39369. });
  39370. this.listComponent.refreshHighlighted();
  39371. return this.listComponent;
  39372. };
  39373. AgSelect.prototype.addOptions = function (options) {
  39374. var _this = this;
  39375. options.forEach(function (option) { return _this.addOption(option); });
  39376. return this;
  39377. };
  39378. AgSelect.prototype.addOption = function (option) {
  39379. this.listComponent.addOption(option);
  39380. return this;
  39381. };
  39382. AgSelect.prototype.setValue = function (value, silent, fromPicker) {
  39383. if (this.value === value) {
  39384. return;
  39385. }
  39386. if (!fromPicker) {
  39387. this.listComponent.setValue(value, true);
  39388. }
  39389. var newValue = this.listComponent.getValue();
  39390. if (newValue === this.getValue()) {
  39391. return;
  39392. }
  39393. this.eDisplayField.innerHTML = this.listComponent.getDisplayValue();
  39394. return _super.prototype.setValue.call(this, value, silent);
  39395. };
  39396. AgSelect.prototype.destroy = function () {
  39397. if (this.hideList) {
  39398. this.hideList();
  39399. }
  39400. this.getContext().destroyBean(this.listComponent);
  39401. _super.prototype.destroy.call(this);
  39402. };
  39403. __decorate([
  39404. Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('popupService')
  39405. ], AgSelect.prototype, "popupService", void 0);
  39406. __decorate([
  39407. _context_context__WEBPACK_IMPORTED_MODULE_3__["PostConstruct"]
  39408. ], AgSelect.prototype, "init", null);
  39409. return AgSelect;
  39410. }(_agPickerField__WEBPACK_IMPORTED_MODULE_1__["AgPickerField"]));
  39411. /***/ }),
  39412. /* 182 */
  39413. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  39414. "use strict";
  39415. __webpack_require__.r(__webpack_exports__);
  39416. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgList", function() { return AgList; });
  39417. /* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(72);
  39418. /* harmony import */ var _component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(56);
  39419. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37);
  39420. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25);
  39421. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7);
  39422. /**
  39423. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  39424. * @version v23.2.1
  39425. * @link http://www.ag-grid.com/
  39426. * @license MIT
  39427. */
  39428. var __extends = (undefined && undefined.__extends) || (function () {
  39429. var extendStatics = function (d, b) {
  39430. extendStatics = Object.setPrototypeOf ||
  39431. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  39432. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  39433. return extendStatics(d, b);
  39434. };
  39435. return function (d, b) {
  39436. extendStatics(d, b);
  39437. function __() { this.constructor = d; }
  39438. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  39439. };
  39440. })();
  39441. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  39442. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  39443. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  39444. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  39445. return c > 3 && r && Object.defineProperty(target, key, r), r;
  39446. };
  39447. var AgList = /** @class */ (function (_super) {
  39448. __extends(AgList, _super);
  39449. function AgList(cssIdentifier) {
  39450. if (cssIdentifier === void 0) { cssIdentifier = 'default'; }
  39451. var _this = _super.call(this, AgList.getTemplate(cssIdentifier)) || this;
  39452. _this.cssIdentifier = cssIdentifier;
  39453. _this.options = [];
  39454. _this.itemEls = [];
  39455. return _this;
  39456. }
  39457. AgList.prototype.init = function () {
  39458. this.addManagedListener(this.getGui(), 'keydown', this.handleKeyDown.bind(this));
  39459. };
  39460. AgList.getTemplate = function (cssIdentifier) {
  39461. return "<div class=\"ag-list ag-" + cssIdentifier + "-list\"></div>";
  39462. };
  39463. AgList.prototype.handleKeyDown = function (e) {
  39464. var key = e.keyCode;
  39465. switch (key) {
  39466. case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_ENTER:
  39467. if (!this.highlightedEl) {
  39468. this.setValue(this.getValue());
  39469. }
  39470. else {
  39471. var pos = this.itemEls.indexOf(this.highlightedEl);
  39472. this.setValueByIndex(pos);
  39473. }
  39474. break;
  39475. case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_DOWN:
  39476. case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_UP:
  39477. var isDown = key === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_DOWN;
  39478. var itemToHighlight = void 0;
  39479. e.preventDefault();
  39480. if (!this.highlightedEl) {
  39481. itemToHighlight = this.itemEls[isDown ? 0 : this.itemEls.length - 1];
  39482. }
  39483. else {
  39484. var currentIdx = this.itemEls.indexOf(this.highlightedEl);
  39485. var nextPos = currentIdx + (isDown ? 1 : -1);
  39486. nextPos = Math.min(Math.max(nextPos, 0), this.itemEls.length - 1);
  39487. itemToHighlight = this.itemEls[nextPos];
  39488. }
  39489. this.highlightItem(itemToHighlight);
  39490. break;
  39491. }
  39492. };
  39493. AgList.prototype.addOptions = function (listOptions) {
  39494. var _this = this;
  39495. listOptions.forEach(function (listOption) { return _this.addOption(listOption); });
  39496. return this;
  39497. };
  39498. AgList.prototype.addOption = function (listOption) {
  39499. var value = listOption.value, text = listOption.text;
  39500. var sanitisedText = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].escape(text === undefined ? value : text);
  39501. this.options.push({ value: value, text: sanitisedText });
  39502. this.renderOption(sanitisedText);
  39503. return this;
  39504. };
  39505. AgList.prototype.renderOption = function (innerText) {
  39506. var _this = this;
  39507. var itemEl = document.createElement('div');
  39508. var itemContentEl = document.createElement('span');
  39509. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(itemEl, 'ag-list-item');
  39510. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(itemEl, "ag-" + this.cssIdentifier + "-list-item");
  39511. itemEl.tabIndex = -1;
  39512. itemContentEl.innerHTML = innerText;
  39513. this.itemEls.push(itemEl);
  39514. this.addManagedListener(itemEl, 'mouseover', function (e) { return _this.highlightItem(itemEl); });
  39515. this.addManagedListener(itemEl, 'mouseleave', function () { return _this.clearHighlighted(); });
  39516. this.addManagedListener(itemEl, 'click', function () {
  39517. var idx = _this.itemEls.indexOf(itemEl);
  39518. _this.setValueByIndex(idx);
  39519. });
  39520. itemEl.appendChild(itemContentEl);
  39521. this.getGui().appendChild(itemEl);
  39522. };
  39523. AgList.prototype.setValue = function (value, silent) {
  39524. if (this.value === value) {
  39525. this.fireItemSelected();
  39526. return this;
  39527. }
  39528. if (value == null) {
  39529. this.reset();
  39530. return this;
  39531. }
  39532. var idx = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].findIndex(this.options, function (option) { return option.value === value; });
  39533. if (idx !== -1) {
  39534. var option = this.options[idx];
  39535. this.value = option.value;
  39536. this.displayValue = option.text != null ? option.text : option.value;
  39537. this.highlightItem(this.itemEls[idx]);
  39538. if (!silent) {
  39539. this.fireChangeEvent();
  39540. }
  39541. }
  39542. return this;
  39543. };
  39544. AgList.prototype.setValueByIndex = function (idx) {
  39545. return this.setValue(this.options[idx].value);
  39546. };
  39547. AgList.prototype.getValue = function () {
  39548. return this.value;
  39549. };
  39550. AgList.prototype.getDisplayValue = function () {
  39551. return this.displayValue;
  39552. };
  39553. AgList.prototype.refreshHighlighted = function () {
  39554. var _this = this;
  39555. this.clearHighlighted();
  39556. var idx = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].findIndex(this.options, function (option) { return option.value === _this.value; });
  39557. if (idx !== -1) {
  39558. this.highlightItem(this.itemEls[idx]);
  39559. }
  39560. };
  39561. AgList.prototype.reset = function () {
  39562. this.value = null;
  39563. this.displayValue = null;
  39564. this.clearHighlighted();
  39565. this.fireChangeEvent();
  39566. };
  39567. AgList.prototype.highlightItem = function (el) {
  39568. if (!el.offsetParent) {
  39569. return;
  39570. }
  39571. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].radioCssClass(el, 'ag-active-item');
  39572. this.highlightedEl = el;
  39573. this.highlightedEl.focus();
  39574. };
  39575. AgList.prototype.clearHighlighted = function () {
  39576. if (!this.highlightedEl || !this.highlightedEl.offsetParent) {
  39577. return;
  39578. }
  39579. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].removeCssClass(this.highlightedEl, 'ag-active-item');
  39580. this.highlightedEl = null;
  39581. };
  39582. AgList.prototype.fireChangeEvent = function () {
  39583. this.dispatchEvent({ type: _agAbstractField__WEBPACK_IMPORTED_MODULE_0__["AgAbstractField"].EVENT_CHANGED });
  39584. this.fireItemSelected();
  39585. };
  39586. AgList.prototype.fireItemSelected = function () {
  39587. this.dispatchEvent({ type: AgList.EVENT_ITEM_SELECTED });
  39588. };
  39589. AgList.EVENT_ITEM_SELECTED = 'selectedItem';
  39590. __decorate([
  39591. _context_context__WEBPACK_IMPORTED_MODULE_2__["PostConstruct"]
  39592. ], AgList.prototype, "init", null);
  39593. return AgList;
  39594. }(_component__WEBPACK_IMPORTED_MODULE_1__["Component"]));
  39595. /***/ }),
  39596. /* 183 */
  39597. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  39598. "use strict";
  39599. __webpack_require__.r(__webpack_exports__);
  39600. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgAngleSelect", function() { return AgAngleSelect; });
  39601. /* harmony import */ var _agAbstractLabel__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(73);
  39602. /* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57);
  39603. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37);
  39604. /* harmony import */ var _agAbstractField__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(72);
  39605. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7);
  39606. /**
  39607. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  39608. * @version v23.2.1
  39609. * @link http://www.ag-grid.com/
  39610. * @license MIT
  39611. */
  39612. var __extends = (undefined && undefined.__extends) || (function () {
  39613. var extendStatics = function (d, b) {
  39614. extendStatics = Object.setPrototypeOf ||
  39615. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  39616. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  39617. return extendStatics(d, b);
  39618. };
  39619. return function (d, b) {
  39620. extendStatics(d, b);
  39621. function __() { this.constructor = d; }
  39622. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  39623. };
  39624. })();
  39625. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  39626. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  39627. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  39628. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  39629. return c > 3 && r && Object.defineProperty(target, key, r), r;
  39630. };
  39631. var AgAngleSelect = /** @class */ (function (_super) {
  39632. __extends(AgAngleSelect, _super);
  39633. function AgAngleSelect() {
  39634. var _this = _super.call(this, AgAngleSelect.TEMPLATE) || this;
  39635. _this.radius = 0;
  39636. _this.offsetX = 0;
  39637. _this.offsetY = 0;
  39638. return _this;
  39639. }
  39640. AgAngleSelect.prototype.postConstruct = function () {
  39641. var _this = this;
  39642. _super.prototype.postConstruct.call(this);
  39643. this.dragListener = {
  39644. eElement: this.eParentCircle,
  39645. dragStartPixels: 0,
  39646. onDragStart: function (e) {
  39647. _this.parentCircleRect = _this.eParentCircle.getBoundingClientRect();
  39648. },
  39649. onDragging: function (e) { return _this.calculateAngleDrag(e); },
  39650. onDragStop: function () { }
  39651. };
  39652. this.dragService.addDragSource(this.dragListener);
  39653. this.eAngleValue
  39654. .setLabel('')
  39655. .setLabelWidth(5)
  39656. .setInputWidth(45)
  39657. .setMin(0)
  39658. .setMax(360)
  39659. .setValue("" + this.degrees)
  39660. .onValueChange(function (value) {
  39661. if (value == null || value === '') {
  39662. value = '0';
  39663. }
  39664. value = _this.eAngleValue.normalizeValue(value);
  39665. var floatValue = parseFloat(value);
  39666. if (floatValue > 180) {
  39667. floatValue = floatValue - 360;
  39668. }
  39669. _this.setValue(floatValue);
  39670. });
  39671. this.updateNumberInput();
  39672. if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].exists(this.getValue())) {
  39673. this.eAngleValue.setValue(this.normalizeNegativeValue(this.getValue()).toString());
  39674. }
  39675. this.addManagedListener(this, _agAbstractField__WEBPACK_IMPORTED_MODULE_3__["AgAbstractField"].EVENT_CHANGED, function () {
  39676. if (_this.eAngleValue.getInputElement().contains(document.activeElement)) {
  39677. return;
  39678. }
  39679. _this.updateNumberInput();
  39680. });
  39681. };
  39682. AgAngleSelect.prototype.updateNumberInput = function () {
  39683. var normalizedValue = this.normalizeNegativeValue(this.getValue());
  39684. this.eAngleValue.setValue(normalizedValue.toString());
  39685. };
  39686. AgAngleSelect.prototype.positionChildCircle = function (radians) {
  39687. var rect = this.parentCircleRect || { width: 24, height: 24 };
  39688. var eChildCircle = this.eChildCircle;
  39689. var centerX = rect.width / 2;
  39690. var centerY = rect.height / 2;
  39691. eChildCircle.style.left = centerX + Math.cos(radians) * 8 + "px";
  39692. eChildCircle.style.top = centerY + Math.sin(radians) * 8 + "px";
  39693. };
  39694. AgAngleSelect.prototype.calculatePolar = function () {
  39695. var x = this.offsetX;
  39696. var y = this.offsetY;
  39697. var radians = Math.atan2(y, x);
  39698. this.degrees = this.toDegrees(radians);
  39699. this.radius = Math.sqrt((x * x) + (y * y));
  39700. this.positionChildCircle(radians);
  39701. };
  39702. AgAngleSelect.prototype.calculateCartesian = function () {
  39703. var radians = this.toRadians(this.getValue());
  39704. var radius = this.getRadius();
  39705. this
  39706. .setOffsetX(Math.cos(radians) * radius)
  39707. .setOffsetY(Math.sin(radians) * radius);
  39708. };
  39709. AgAngleSelect.prototype.setOffsetX = function (offset) {
  39710. if (this.offsetX !== offset) {
  39711. this.offsetX = offset;
  39712. this.calculatePolar();
  39713. }
  39714. return this;
  39715. };
  39716. AgAngleSelect.prototype.setOffsetY = function (offset) {
  39717. if (this.offsetY !== offset) {
  39718. this.offsetY = offset;
  39719. this.calculatePolar();
  39720. }
  39721. return this;
  39722. };
  39723. AgAngleSelect.prototype.calculateAngleDrag = function (e) {
  39724. var rect = this.parentCircleRect;
  39725. var centerX = rect.width / 2;
  39726. var centerY = rect.height / 2;
  39727. var x = e.clientX - rect.left;
  39728. var y = e.clientY - rect.top;
  39729. var dx = x - centerX;
  39730. var dy = y - centerY;
  39731. var radians = Math.atan2(dy, dx);
  39732. this.setValue(radians, true);
  39733. };
  39734. AgAngleSelect.prototype.toDegrees = function (radians) {
  39735. return radians / Math.PI * 180;
  39736. };
  39737. AgAngleSelect.prototype.toRadians = function (degrees) {
  39738. return degrees / 180 * Math.PI;
  39739. };
  39740. AgAngleSelect.prototype.normalizeNegativeValue = function (degrees) {
  39741. return degrees < 0 ? 360 + degrees : degrees;
  39742. };
  39743. AgAngleSelect.prototype.normalizeAngle180 = function (radians) {
  39744. radians %= Math.PI * 2;
  39745. if (radians < -Math.PI) {
  39746. radians += Math.PI * 2;
  39747. }
  39748. else if (radians >= Math.PI) {
  39749. radians -= Math.PI * 2;
  39750. }
  39751. return radians;
  39752. };
  39753. AgAngleSelect.prototype.getRadius = function () {
  39754. return this.radius;
  39755. };
  39756. AgAngleSelect.prototype.setRadius = function (r) {
  39757. if (this.radius === r) {
  39758. return this;
  39759. }
  39760. this.radius = r;
  39761. this.calculateCartesian();
  39762. return this;
  39763. };
  39764. AgAngleSelect.prototype.onValueChange = function (callbackFn) {
  39765. var _this = this;
  39766. this.addManagedListener(this, _agAbstractField__WEBPACK_IMPORTED_MODULE_3__["AgAbstractField"].EVENT_CHANGED, function () {
  39767. callbackFn(_this.degrees);
  39768. });
  39769. return this;
  39770. };
  39771. AgAngleSelect.prototype.getValue = function (radians) {
  39772. return radians ? this.toRadians(this.degrees) : this.degrees;
  39773. };
  39774. AgAngleSelect.prototype.setValue = function (degrees, radians) {
  39775. var radiansValue;
  39776. if (!radians) {
  39777. radiansValue = this.normalizeAngle180(this.toRadians(degrees));
  39778. }
  39779. else {
  39780. radiansValue = degrees;
  39781. }
  39782. degrees = this.toDegrees(radiansValue);
  39783. if (this.degrees !== degrees) {
  39784. this.degrees = Math.floor(degrees);
  39785. this.calculateCartesian();
  39786. this.positionChildCircle(radiansValue);
  39787. this.dispatchEvent({ type: _agAbstractField__WEBPACK_IMPORTED_MODULE_3__["AgAbstractField"].EVENT_CHANGED });
  39788. }
  39789. return this;
  39790. };
  39791. AgAngleSelect.prototype.setWidth = function (width) {
  39792. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].setFixedWidth(this.getGui(), width);
  39793. return this;
  39794. };
  39795. AgAngleSelect.prototype.destroy = function () {
  39796. this.dragService.removeDragSource(this.dragListener);
  39797. _super.prototype.destroy.call(this);
  39798. };
  39799. AgAngleSelect.TEMPLATE = "<div class=\"ag-angle-select\">\n <label ref=\"eLabel\"></label>\n <div class=\"ag-wrapper ag-angle-select-wrapper\">\n <div ref=\"eAngleSelectField\" class=\"ag-angle-select-field\">\n <div ref=\"eParentCircle\" class=\"ag-angle-select-parent-circle\">\n <div ref=\"eChildCircle\" class=\"ag-angle-select-child-circle\"></div>\n </div>\n </div>\n <ag-input-number-field ref=\"eAngleValue\"></ag-input-number-field>\n </div>\n </div>";
  39800. __decorate([
  39801. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eLabel')
  39802. ], AgAngleSelect.prototype, "eLabel", void 0);
  39803. __decorate([
  39804. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eParentCircle')
  39805. ], AgAngleSelect.prototype, "eParentCircle", void 0);
  39806. __decorate([
  39807. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eChildCircle')
  39808. ], AgAngleSelect.prototype, "eChildCircle", void 0);
  39809. __decorate([
  39810. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eAngleValue')
  39811. ], AgAngleSelect.prototype, "eAngleValue", void 0);
  39812. __decorate([
  39813. Object(_context_context__WEBPACK_IMPORTED_MODULE_2__["Autowired"])("dragService")
  39814. ], AgAngleSelect.prototype, "dragService", void 0);
  39815. return AgAngleSelect;
  39816. }(_agAbstractLabel__WEBPACK_IMPORTED_MODULE_0__["AgAbstractLabel"]));
  39817. /***/ }),
  39818. /* 184 */
  39819. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  39820. "use strict";
  39821. __webpack_require__.r(__webpack_exports__);
  39822. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgToggleButton", function() { return AgToggleButton; });
  39823. /* harmony import */ var _agRadioButton__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(146);
  39824. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(7);
  39825. /**
  39826. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  39827. * @version v23.2.1
  39828. * @link http://www.ag-grid.com/
  39829. * @license MIT
  39830. */
  39831. var __extends = (undefined && undefined.__extends) || (function () {
  39832. var extendStatics = function (d, b) {
  39833. extendStatics = Object.setPrototypeOf ||
  39834. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  39835. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  39836. return extendStatics(d, b);
  39837. };
  39838. return function (d, b) {
  39839. extendStatics(d, b);
  39840. function __() { this.constructor = d; }
  39841. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  39842. };
  39843. })();
  39844. var AgToggleButton = /** @class */ (function (_super) {
  39845. __extends(AgToggleButton, _super);
  39846. function AgToggleButton() {
  39847. var _this = _super !== null && _super.apply(this, arguments) || this;
  39848. _this.className = 'ag-toggle-button';
  39849. _this.inputType = 'checkbox';
  39850. return _this;
  39851. }
  39852. AgToggleButton.prototype.setValue = function (value, silent) {
  39853. _super.prototype.setValue.call(this, value, silent);
  39854. _utils__WEBPACK_IMPORTED_MODULE_1__["_"].addOrRemoveCssClass(this.getGui(), 'ag-selected', this.getValue());
  39855. return this;
  39856. };
  39857. return AgToggleButton;
  39858. }(_agRadioButton__WEBPACK_IMPORTED_MODULE_0__["AgRadioButton"]));
  39859. /***/ }),
  39860. /* 185 */
  39861. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  39862. "use strict";
  39863. __webpack_require__.r(__webpack_exports__);
  39864. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DetailRowCompCache", function() { return DetailRowCompCache; });
  39865. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  39866. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(25);
  39867. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(41);
  39868. /**
  39869. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  39870. * @version v23.2.1
  39871. * @link http://www.ag-grid.com/
  39872. * @license MIT
  39873. */
  39874. var __extends = (undefined && undefined.__extends) || (function () {
  39875. var extendStatics = function (d, b) {
  39876. extendStatics = Object.setPrototypeOf ||
  39877. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  39878. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  39879. return extendStatics(d, b);
  39880. };
  39881. return function (d, b) {
  39882. extendStatics(d, b);
  39883. function __() { this.constructor = d; }
  39884. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  39885. };
  39886. })();
  39887. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  39888. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  39889. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  39890. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  39891. return c > 3 && r && Object.defineProperty(target, key, r), r;
  39892. };
  39893. /**
  39894. * For Master Detail, it is required to keep components between expanding & collapsing parents.
  39895. * For example a user expands row A (and shows a detail grid for this row), then when row A
  39896. * is closed, we want to keep the detail grid, so next time row A is expanded the detail grid
  39897. * is showed with it's context intact, eg if user sorted in the detail grid, that sort should
  39898. * still be applied after the detail grid is shown for the second time.
  39899. */
  39900. var DetailRowCompCache = /** @class */ (function (_super) {
  39901. __extends(DetailRowCompCache, _super);
  39902. function DetailRowCompCache() {
  39903. var _this = _super !== null && _super.apply(this, arguments) || this;
  39904. _this.cacheItems = [];
  39905. return _this;
  39906. }
  39907. DetailRowCompCache.prototype.postConstruct = function () {
  39908. this.active = this.gridOptionsWrapper.isKeepDetailRows();
  39909. this.maxCacheSize = this.gridOptionsWrapper.getKeepDetailRowsCount();
  39910. };
  39911. DetailRowCompCache.prototype.addOrDestroy = function (rowNode, pinned, comp) {
  39912. // only accept detail rows
  39913. var doNotUseCache = !this.active || !rowNode.detail;
  39914. if (doNotUseCache) {
  39915. this.destroyFullWidthRow(comp);
  39916. return;
  39917. }
  39918. var item = this.getCacheItem(rowNode, true);
  39919. // put the comp in the right location of the item.
  39920. // we also destroy any previous comp - this should never happen
  39921. // as the logic outside of this class shouldn't be adding same item to the
  39922. // cache twice, however we cater for it in case in future releases code
  39923. // outside of this class is changed and this could happen.
  39924. switch (pinned) {
  39925. case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].PINNED_LEFT:
  39926. this.destroyFullWidthRow(item.left);
  39927. item.left = comp;
  39928. break;
  39929. case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].PINNED_RIGHT:
  39930. this.destroyFullWidthRow(item.right);
  39931. item.right = comp;
  39932. break;
  39933. default:
  39934. this.destroyFullWidthRow(item.center);
  39935. item.center = comp;
  39936. break;
  39937. }
  39938. this.cacheItems.sort(function (a, b) {
  39939. return b.lastAccessedTime - a.lastAccessedTime;
  39940. });
  39941. this.purgeCache(this.maxCacheSize);
  39942. };
  39943. DetailRowCompCache.prototype.getCacheItem = function (rowNode, autoCreate) {
  39944. if (autoCreate === void 0) { autoCreate = false; }
  39945. var res;
  39946. for (var i = 0; i < this.cacheItems.length; i++) {
  39947. var item = this.cacheItems[i];
  39948. if (item.rowNode === rowNode) {
  39949. res = item;
  39950. break;
  39951. }
  39952. }
  39953. if (!res && autoCreate) {
  39954. res = {
  39955. rowNode: rowNode
  39956. };
  39957. this.cacheItems.push(res);
  39958. }
  39959. if (res) {
  39960. this.stampCacheItem(res);
  39961. }
  39962. return res;
  39963. };
  39964. DetailRowCompCache.prototype.stampCacheItem = function (item) {
  39965. item.lastAccessedTime = new Date().getTime();
  39966. };
  39967. DetailRowCompCache.prototype.destroyFullWidthRow = function (comp) {
  39968. this.getContext().destroyBean(comp);
  39969. };
  39970. DetailRowCompCache.prototype.purgeCache = function (startIndex) {
  39971. // delete all rows past the index of interest
  39972. for (var i = startIndex; i < this.cacheItems.length; i++) {
  39973. var item = this.cacheItems[i];
  39974. this.destroyFullWidthRow(item.center);
  39975. this.destroyFullWidthRow(item.left);
  39976. this.destroyFullWidthRow(item.right);
  39977. }
  39978. // change the length of the array so it no longer contains the deleted items
  39979. if (this.cacheItems.length > startIndex) {
  39980. this.cacheItems.length = startIndex;
  39981. }
  39982. };
  39983. DetailRowCompCache.prototype.get = function (rowNode, pinned) {
  39984. if (!rowNode.detail) {
  39985. return undefined;
  39986. }
  39987. var item = this.getCacheItem(rowNode);
  39988. var res;
  39989. if (item) {
  39990. switch (pinned) {
  39991. case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].PINNED_LEFT:
  39992. if (item.left) {
  39993. res = item.left;
  39994. item.left = undefined;
  39995. }
  39996. break;
  39997. case _constants__WEBPACK_IMPORTED_MODULE_1__["Constants"].PINNED_RIGHT:
  39998. if (item.right) {
  39999. res = item.right;
  40000. item.right = undefined;
  40001. }
  40002. break;
  40003. default:
  40004. if (item.center) {
  40005. res = item.center;
  40006. item.center = undefined;
  40007. }
  40008. break;
  40009. }
  40010. }
  40011. return res;
  40012. };
  40013. DetailRowCompCache.prototype.destroy = function () {
  40014. _super.prototype.destroy.call(this);
  40015. this.purgeCache(0);
  40016. };
  40017. __decorate([
  40018. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  40019. ], DetailRowCompCache.prototype, "gridOptionsWrapper", void 0);
  40020. __decorate([
  40021. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  40022. ], DetailRowCompCache.prototype, "postConstruct", null);
  40023. __decorate([
  40024. _context_context__WEBPACK_IMPORTED_MODULE_0__["PreDestroy"]
  40025. ], DetailRowCompCache.prototype, "destroy", null);
  40026. DetailRowCompCache = __decorate([
  40027. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('detailRowCompCache')
  40028. ], DetailRowCompCache);
  40029. return DetailRowCompCache;
  40030. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"]));
  40031. /***/ }),
  40032. /* 186 */
  40033. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  40034. "use strict";
  40035. __webpack_require__.r(__webpack_exports__);
  40036. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowPositionUtils", function() { return RowPositionUtils; });
  40037. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  40038. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  40039. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25);
  40040. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  40041. /**
  40042. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  40043. * @version v23.2.1
  40044. * @link http://www.ag-grid.com/
  40045. * @license MIT
  40046. */
  40047. var __extends = (undefined && undefined.__extends) || (function () {
  40048. var extendStatics = function (d, b) {
  40049. extendStatics = Object.setPrototypeOf ||
  40050. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  40051. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  40052. return extendStatics(d, b);
  40053. };
  40054. return function (d, b) {
  40055. extendStatics(d, b);
  40056. function __() { this.constructor = d; }
  40057. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  40058. };
  40059. })();
  40060. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  40061. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  40062. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  40063. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  40064. return c > 3 && r && Object.defineProperty(target, key, r), r;
  40065. };
  40066. var RowPositionUtils = /** @class */ (function (_super) {
  40067. __extends(RowPositionUtils, _super);
  40068. function RowPositionUtils() {
  40069. return _super !== null && _super.apply(this, arguments) || this;
  40070. }
  40071. RowPositionUtils.prototype.getFirstRow = function () {
  40072. var rowIndex = 0;
  40073. var rowPinned;
  40074. if (this.pinnedRowModel.getPinnedTopRowCount()) {
  40075. rowPinned = _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP;
  40076. }
  40077. else if (this.rowModel.getRowCount()) {
  40078. rowPinned = null;
  40079. }
  40080. else if (this.pinnedRowModel.getPinnedBottomRowCount()) {
  40081. rowPinned = _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM;
  40082. }
  40083. return rowPinned === undefined ? null : { rowIndex: rowIndex, rowPinned: rowPinned };
  40084. };
  40085. RowPositionUtils.prototype.getRowNode = function (gridRow) {
  40086. switch (gridRow.rowPinned) {
  40087. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP:
  40088. return this.pinnedRowModel.getPinnedTopRowData()[gridRow.rowIndex];
  40089. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM:
  40090. return this.pinnedRowModel.getPinnedBottomRowData()[gridRow.rowIndex];
  40091. default:
  40092. return this.rowModel.getRow(gridRow.rowIndex);
  40093. }
  40094. };
  40095. RowPositionUtils.prototype.sameRow = function (rowA, rowB) {
  40096. // if both missing
  40097. if (!rowA && !rowB) {
  40098. return true;
  40099. }
  40100. // if only one missing
  40101. if ((rowA && !rowB) || (!rowA && rowB)) {
  40102. return false;
  40103. }
  40104. // otherwise compare (use == to compare rowPinned because it can be null or undefined)
  40105. return rowA.rowIndex === rowB.rowIndex && rowA.rowPinned == rowB.rowPinned;
  40106. };
  40107. // tests if this row selection is before the other row selection
  40108. RowPositionUtils.prototype.before = function (rowA, rowB) {
  40109. switch (rowA.rowPinned) {
  40110. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP:
  40111. // we we are floating top, and other isn't, then we are always before
  40112. if (rowB.rowPinned !== _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP) {
  40113. return true;
  40114. }
  40115. break;
  40116. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM:
  40117. // if we are floating bottom, and the other isn't, then we are never before
  40118. if (rowB.rowPinned !== _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_BOTTOM) {
  40119. return false;
  40120. }
  40121. break;
  40122. default:
  40123. // if we are not floating, but the other one is floating...
  40124. if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(rowB.rowPinned)) {
  40125. return rowB.rowPinned !== _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].PINNED_TOP;
  40126. }
  40127. break;
  40128. }
  40129. return rowA.rowIndex < rowB.rowIndex;
  40130. };
  40131. __decorate([
  40132. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel')
  40133. ], RowPositionUtils.prototype, "rowModel", void 0);
  40134. __decorate([
  40135. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer')
  40136. ], RowPositionUtils.prototype, "rowRenderer", void 0);
  40137. __decorate([
  40138. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('pinnedRowModel')
  40139. ], RowPositionUtils.prototype, "pinnedRowModel", void 0);
  40140. RowPositionUtils = __decorate([
  40141. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('rowPositionUtils')
  40142. ], RowPositionUtils);
  40143. return RowPositionUtils;
  40144. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  40145. /***/ }),
  40146. /* 187 */
  40147. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  40148. "use strict";
  40149. __webpack_require__.r(__webpack_exports__);
  40150. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CellPositionUtils", function() { return CellPositionUtils; });
  40151. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  40152. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  40153. /**
  40154. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  40155. * @version v23.2.1
  40156. * @link http://www.ag-grid.com/
  40157. * @license MIT
  40158. */
  40159. var __extends = (undefined && undefined.__extends) || (function () {
  40160. var extendStatics = function (d, b) {
  40161. extendStatics = Object.setPrototypeOf ||
  40162. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  40163. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  40164. return extendStatics(d, b);
  40165. };
  40166. return function (d, b) {
  40167. extendStatics(d, b);
  40168. function __() { this.constructor = d; }
  40169. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  40170. };
  40171. })();
  40172. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  40173. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  40174. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  40175. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  40176. return c > 3 && r && Object.defineProperty(target, key, r), r;
  40177. };
  40178. var CellPositionUtils = /** @class */ (function (_super) {
  40179. __extends(CellPositionUtils, _super);
  40180. function CellPositionUtils() {
  40181. return _super !== null && _super.apply(this, arguments) || this;
  40182. }
  40183. CellPositionUtils.prototype.createId = function (cellPosition) {
  40184. var rowIndex = cellPosition.rowIndex, rowPinned = cellPosition.rowPinned, column = cellPosition.column;
  40185. return this.createIdFromValues(rowIndex, column, rowPinned);
  40186. };
  40187. CellPositionUtils.prototype.createIdFromValues = function (rowIndex, column, rowPinned) {
  40188. return rowIndex + "." + (rowPinned == null ? 'null' : rowPinned) + "." + column.getId();
  40189. };
  40190. CellPositionUtils.prototype.equals = function (cellA, cellB) {
  40191. var colsMatch = cellA.column === cellB.column;
  40192. var floatingMatch = cellA.rowPinned === cellB.rowPinned;
  40193. var indexMatch = cellA.rowIndex === cellB.rowIndex;
  40194. return colsMatch && floatingMatch && indexMatch;
  40195. };
  40196. CellPositionUtils = __decorate([
  40197. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('cellPositionUtils')
  40198. ], CellPositionUtils);
  40199. return CellPositionUtils;
  40200. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  40201. /***/ }),
  40202. /* 188 */
  40203. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  40204. "use strict";
  40205. __webpack_require__.r(__webpack_exports__);
  40206. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "PinnedRowModel", function() { return PinnedRowModel; });
  40207. /* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(68);
  40208. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  40209. /* harmony import */ var _events__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(43);
  40210. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25);
  40211. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7);
  40212. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(41);
  40213. /**
  40214. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  40215. * @version v23.2.1
  40216. * @link http://www.ag-grid.com/
  40217. * @license MIT
  40218. */
  40219. var __extends = (undefined && undefined.__extends) || (function () {
  40220. var extendStatics = function (d, b) {
  40221. extendStatics = Object.setPrototypeOf ||
  40222. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  40223. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  40224. return extendStatics(d, b);
  40225. };
  40226. return function (d, b) {
  40227. extendStatics(d, b);
  40228. function __() { this.constructor = d; }
  40229. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  40230. };
  40231. })();
  40232. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  40233. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  40234. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  40235. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  40236. return c > 3 && r && Object.defineProperty(target, key, r), r;
  40237. };
  40238. var PinnedRowModel = /** @class */ (function (_super) {
  40239. __extends(PinnedRowModel, _super);
  40240. function PinnedRowModel() {
  40241. return _super !== null && _super.apply(this, arguments) || this;
  40242. }
  40243. PinnedRowModel.prototype.init = function () {
  40244. this.setPinnedTopRowData(this.gridOptionsWrapper.getPinnedTopRowData());
  40245. this.setPinnedBottomRowData(this.gridOptionsWrapper.getPinnedBottomRowData());
  40246. };
  40247. PinnedRowModel.prototype.isEmpty = function (floating) {
  40248. var rows = floating === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_TOP ? this.pinnedTopRows : this.pinnedBottomRows;
  40249. return _utils__WEBPACK_IMPORTED_MODULE_4__["_"].missingOrEmpty(rows);
  40250. };
  40251. PinnedRowModel.prototype.isRowsToRender = function (floating) {
  40252. return !this.isEmpty(floating);
  40253. };
  40254. PinnedRowModel.prototype.getRowAtPixel = function (pixel, floating) {
  40255. var rows = floating === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_TOP ? this.pinnedTopRows : this.pinnedBottomRows;
  40256. if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].missingOrEmpty(rows)) {
  40257. return 0; // this should never happen, just in case, 0 is graceful failure
  40258. }
  40259. for (var i = 0; i < rows.length; i++) {
  40260. var rowNode = rows[i];
  40261. var rowTopPixel = rowNode.rowTop + rowNode.rowHeight - 1;
  40262. // only need to range check against the top pixel, as we are going through the list
  40263. // in order, first row to hit the pixel wins
  40264. if (rowTopPixel >= pixel) {
  40265. return i;
  40266. }
  40267. }
  40268. return rows.length - 1;
  40269. };
  40270. PinnedRowModel.prototype.setPinnedTopRowData = function (rowData) {
  40271. this.pinnedTopRows = this.createNodesFromData(rowData, true);
  40272. var event = {
  40273. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_PINNED_ROW_DATA_CHANGED,
  40274. api: this.gridApi,
  40275. columnApi: this.columnApi
  40276. };
  40277. this.eventService.dispatchEvent(event);
  40278. };
  40279. PinnedRowModel.prototype.setPinnedBottomRowData = function (rowData) {
  40280. this.pinnedBottomRows = this.createNodesFromData(rowData, false);
  40281. var event = {
  40282. type: _events__WEBPACK_IMPORTED_MODULE_2__["Events"].EVENT_PINNED_ROW_DATA_CHANGED,
  40283. api: this.gridApi,
  40284. columnApi: this.columnApi
  40285. };
  40286. this.eventService.dispatchEvent(event);
  40287. };
  40288. PinnedRowModel.prototype.createNodesFromData = function (allData, isTop) {
  40289. var _this = this;
  40290. var rowNodes = [];
  40291. if (allData) {
  40292. var nextRowTop_1 = 0;
  40293. allData.forEach(function (dataItem, index) {
  40294. var rowNode = new _entities_rowNode__WEBPACK_IMPORTED_MODULE_0__["RowNode"]();
  40295. _this.context.createBean(rowNode);
  40296. rowNode.data = dataItem;
  40297. var idPrefix = isTop ? _entities_rowNode__WEBPACK_IMPORTED_MODULE_0__["RowNode"].ID_PREFIX_TOP_PINNED : _entities_rowNode__WEBPACK_IMPORTED_MODULE_0__["RowNode"].ID_PREFIX_BOTTOM_PINNED;
  40298. rowNode.id = idPrefix + index;
  40299. rowNode.rowPinned = isTop ? _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_TOP : _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_BOTTOM;
  40300. rowNode.setRowTop(nextRowTop_1);
  40301. rowNode.setRowHeight(_this.gridOptionsWrapper.getRowHeightForNode(rowNode).height);
  40302. rowNode.setRowIndex(index);
  40303. nextRowTop_1 += rowNode.rowHeight;
  40304. rowNodes.push(rowNode);
  40305. });
  40306. }
  40307. return rowNodes;
  40308. };
  40309. PinnedRowModel.prototype.getPinnedTopRowData = function () {
  40310. return this.pinnedTopRows;
  40311. };
  40312. PinnedRowModel.prototype.getPinnedBottomRowData = function () {
  40313. return this.pinnedBottomRows;
  40314. };
  40315. PinnedRowModel.prototype.getPinnedTopTotalHeight = function () {
  40316. return this.getTotalHeight(this.pinnedTopRows);
  40317. };
  40318. PinnedRowModel.prototype.getPinnedTopRowCount = function () {
  40319. return this.pinnedTopRows ? this.pinnedTopRows.length : 0;
  40320. };
  40321. PinnedRowModel.prototype.getPinnedBottomRowCount = function () {
  40322. return this.pinnedBottomRows ? this.pinnedBottomRows.length : 0;
  40323. };
  40324. PinnedRowModel.prototype.getPinnedTopRow = function (index) {
  40325. return this.pinnedTopRows[index];
  40326. };
  40327. PinnedRowModel.prototype.getPinnedBottomRow = function (index) {
  40328. return this.pinnedBottomRows[index];
  40329. };
  40330. PinnedRowModel.prototype.forEachPinnedTopRow = function (callback) {
  40331. if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].missingOrEmpty(this.pinnedTopRows)) {
  40332. return;
  40333. }
  40334. this.pinnedTopRows.forEach(callback);
  40335. };
  40336. PinnedRowModel.prototype.forEachPinnedBottomRow = function (callback) {
  40337. if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].missingOrEmpty(this.pinnedBottomRows)) {
  40338. return;
  40339. }
  40340. this.pinnedBottomRows.forEach(callback);
  40341. };
  40342. PinnedRowModel.prototype.getPinnedBottomTotalHeight = function () {
  40343. return this.getTotalHeight(this.pinnedBottomRows);
  40344. };
  40345. PinnedRowModel.prototype.getTotalHeight = function (rowNodes) {
  40346. if (!rowNodes || rowNodes.length === 0) {
  40347. return 0;
  40348. }
  40349. else {
  40350. var lastNode = _utils__WEBPACK_IMPORTED_MODULE_4__["_"].last(rowNodes);
  40351. return lastNode.rowTop + lastNode.rowHeight;
  40352. }
  40353. };
  40354. __decorate([
  40355. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridOptionsWrapper')
  40356. ], PinnedRowModel.prototype, "gridOptionsWrapper", void 0);
  40357. __decorate([
  40358. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnApi')
  40359. ], PinnedRowModel.prototype, "columnApi", void 0);
  40360. __decorate([
  40361. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('gridApi')
  40362. ], PinnedRowModel.prototype, "gridApi", void 0);
  40363. __decorate([
  40364. _context_context__WEBPACK_IMPORTED_MODULE_1__["PostConstruct"]
  40365. ], PinnedRowModel.prototype, "init", null);
  40366. PinnedRowModel = __decorate([
  40367. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('pinnedRowModel')
  40368. ], PinnedRowModel);
  40369. return PinnedRowModel;
  40370. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_5__["BeanStub"]));
  40371. /***/ }),
  40372. /* 189 */
  40373. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  40374. "use strict";
  40375. __webpack_require__.r(__webpack_exports__);
  40376. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "UndoRedoService", function() { return UndoRedoService; });
  40377. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  40378. /* harmony import */ var _eventKeys__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(44);
  40379. /* harmony import */ var _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(190);
  40380. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25);
  40381. /* harmony import */ var _modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(38);
  40382. /* harmony import */ var _modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(39);
  40383. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(41);
  40384. /**
  40385. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  40386. * @version v23.2.1
  40387. * @link http://www.ag-grid.com/
  40388. * @license MIT
  40389. */
  40390. var __extends = (undefined && undefined.__extends) || (function () {
  40391. var extendStatics = function (d, b) {
  40392. extendStatics = Object.setPrototypeOf ||
  40393. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  40394. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  40395. return extendStatics(d, b);
  40396. };
  40397. return function (d, b) {
  40398. extendStatics(d, b);
  40399. function __() { this.constructor = d; }
  40400. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  40401. };
  40402. })();
  40403. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  40404. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  40405. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  40406. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  40407. return c > 3 && r && Object.defineProperty(target, key, r), r;
  40408. };
  40409. var UndoRedoService = /** @class */ (function (_super) {
  40410. __extends(UndoRedoService, _super);
  40411. function UndoRedoService() {
  40412. var _this = _super !== null && _super.apply(this, arguments) || this;
  40413. _this.cellValueChanges = [];
  40414. _this.isCellEditing = false;
  40415. _this.isRowEditing = false;
  40416. _this.isPasting = false;
  40417. _this.isFilling = false;
  40418. _this.onCellValueChanged = function (event) {
  40419. var shouldCaptureAction = _this.isCellEditing || _this.isRowEditing || _this.isPasting || _this.isFilling;
  40420. if (!shouldCaptureAction) {
  40421. return;
  40422. }
  40423. var rowPinned = event.rowPinned, rowIndex = event.rowIndex, column = event.column, oldValue = event.oldValue, value = event.value;
  40424. var cellValueChange = {
  40425. rowPinned: rowPinned,
  40426. rowIndex: rowIndex,
  40427. columnId: column.getColId(),
  40428. oldValue: oldValue,
  40429. newValue: value
  40430. };
  40431. _this.cellValueChanges.push(cellValueChange);
  40432. };
  40433. _this.clearStacks = function () {
  40434. _this.undoStack.clear();
  40435. _this.redoStack.clear();
  40436. };
  40437. return _this;
  40438. }
  40439. UndoRedoService.prototype.init = function () {
  40440. if (!this.gridOptionsWrapper.isUndoRedoCellEditing()) {
  40441. return;
  40442. }
  40443. var undoRedoLimit = this.gridOptionsWrapper.getUndoRedoCellEditingLimit();
  40444. if (undoRedoLimit <= 0) {
  40445. return;
  40446. }
  40447. this.undoStack = new _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["UndoRedoStack"](undoRedoLimit);
  40448. this.redoStack = new _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["UndoRedoStack"](undoRedoLimit);
  40449. this.addRowEditingListeners();
  40450. this.addCellEditingListeners();
  40451. this.addPasteListeners();
  40452. this.addFillListeners();
  40453. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_VALUE_CHANGED, this.onCellValueChanged);
  40454. // undo / redo is restricted to actual editing so we clear the stacks when other operations are
  40455. // performed that change the order of the row / cols.
  40456. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_MODEL_UPDATED, this.clearStacks);
  40457. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_PIVOT_MODE_CHANGED, this.clearStacks);
  40458. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_EVERYTHING_CHANGED, this.clearStacks);
  40459. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_GROUP_OPENED, this.clearStacks);
  40460. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, this.clearStacks);
  40461. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_MOVED, this.clearStacks);
  40462. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_PINNED, this.clearStacks);
  40463. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_COLUMN_VISIBLE, this.clearStacks);
  40464. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_ROW_DRAG_END, this.clearStacks);
  40465. };
  40466. UndoRedoService.prototype.undo = function () {
  40467. if (!this.undoStack) {
  40468. return;
  40469. }
  40470. var undoAction = this.undoStack.pop();
  40471. if (!undoAction || !undoAction.cellValueChanges) {
  40472. return;
  40473. }
  40474. this.processAction(undoAction, function (cellValueChange) { return cellValueChange.oldValue; });
  40475. if (undoAction instanceof _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["FillUndoRedoAction"]) {
  40476. this.processRangeAndCellFocus(undoAction.cellValueChanges, undoAction.initialRange);
  40477. }
  40478. else {
  40479. this.processRangeAndCellFocus(undoAction.cellValueChanges);
  40480. }
  40481. this.redoStack.push(undoAction);
  40482. };
  40483. UndoRedoService.prototype.redo = function () {
  40484. if (!this.redoStack) {
  40485. return;
  40486. }
  40487. var redoAction = this.redoStack.pop();
  40488. if (!redoAction || !redoAction.cellValueChanges) {
  40489. return;
  40490. }
  40491. this.processAction(redoAction, function (cellValueChange) { return cellValueChange.newValue; });
  40492. if (redoAction instanceof _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["FillUndoRedoAction"]) {
  40493. this.processRangeAndCellFocus(redoAction.cellValueChanges, redoAction.finalRange);
  40494. }
  40495. else {
  40496. this.processRangeAndCellFocus(redoAction.cellValueChanges);
  40497. }
  40498. this.undoStack.push(redoAction);
  40499. };
  40500. UndoRedoService.prototype.processAction = function (action, valueExtractor) {
  40501. var _this = this;
  40502. action.cellValueChanges.forEach(function (cellValueChange) {
  40503. var rowIndex = cellValueChange.rowIndex, rowPinned = cellValueChange.rowPinned, columnId = cellValueChange.columnId;
  40504. var rowPosition = { rowIndex: rowIndex, rowPinned: rowPinned };
  40505. var currentRow = _this.getRowNode(rowPosition);
  40506. // checks if the row has been filtered out
  40507. if (currentRow.rowTop == null) {
  40508. return;
  40509. }
  40510. currentRow.setDataValue(columnId, valueExtractor(cellValueChange));
  40511. });
  40512. };
  40513. UndoRedoService.prototype.processRangeAndCellFocus = function (cellValueChanges, range) {
  40514. if (range) {
  40515. var startRow = range.startRow;
  40516. var endRow = range.endRow;
  40517. var lastFocusedCell_1 = {
  40518. rowPinned: startRow.rowPinned,
  40519. rowIndex: startRow.rowIndex,
  40520. columnId: range.startColumn.getColId()
  40521. };
  40522. this.setLastFocusedCell(lastFocusedCell_1);
  40523. var cellRangeParams = {
  40524. rowStartIndex: startRow.rowIndex,
  40525. rowStartPinned: startRow.rowPinned,
  40526. rowEndIndex: endRow.rowIndex,
  40527. rowEndPinned: endRow.rowPinned,
  40528. columnStart: range.startColumn,
  40529. columns: range.columns
  40530. };
  40531. this.gridApi.addCellRange(cellRangeParams);
  40532. return;
  40533. }
  40534. var cellValueChange = cellValueChanges[0];
  40535. var rowIndex = cellValueChange.rowIndex, rowPinned = cellValueChange.rowPinned;
  40536. var rowPosition = { rowIndex: rowIndex, rowPinned: rowPinned };
  40537. var row = this.getRowNode(rowPosition);
  40538. var lastFocusedCell = {
  40539. rowPinned: cellValueChange.rowPinned,
  40540. rowIndex: row.rowIndex,
  40541. columnId: cellValueChange.columnId
  40542. };
  40543. this.setLastFocusedCell(lastFocusedCell);
  40544. };
  40545. UndoRedoService.prototype.setLastFocusedCell = function (lastFocusedCell) {
  40546. var rowIndex = lastFocusedCell.rowIndex, columnId = lastFocusedCell.columnId, rowPinned = lastFocusedCell.rowPinned;
  40547. this.gridApi.ensureIndexVisible(rowIndex);
  40548. this.gridApi.ensureColumnVisible(columnId);
  40549. if (_modules_moduleRegistry__WEBPACK_IMPORTED_MODULE_5__["ModuleRegistry"].isRegistered(_modules_moduleNames__WEBPACK_IMPORTED_MODULE_4__["ModuleNames"].RangeSelectionModule)) {
  40550. this.gridApi.clearRangeSelection();
  40551. }
  40552. this.focusController.setFocusedCell(rowIndex, columnId, rowPinned, true);
  40553. };
  40554. UndoRedoService.prototype.addRowEditingListeners = function () {
  40555. var _this = this;
  40556. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_ROW_EDITING_STARTED, function () {
  40557. _this.isRowEditing = true;
  40558. });
  40559. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_ROW_EDITING_STOPPED, function () {
  40560. var action = new _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["UndoRedoAction"](_this.cellValueChanges);
  40561. _this.pushActionsToUndoStack(action);
  40562. _this.isRowEditing = false;
  40563. });
  40564. };
  40565. UndoRedoService.prototype.addCellEditingListeners = function () {
  40566. var _this = this;
  40567. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_EDITING_STARTED, function () {
  40568. _this.isCellEditing = true;
  40569. });
  40570. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_CELL_EDITING_STOPPED, function () {
  40571. _this.isCellEditing = false;
  40572. var shouldPushAction = !_this.isRowEditing && !_this.isPasting && !_this.isFilling;
  40573. if (shouldPushAction) {
  40574. var action = new _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["UndoRedoAction"](_this.cellValueChanges);
  40575. _this.pushActionsToUndoStack(action);
  40576. }
  40577. });
  40578. };
  40579. UndoRedoService.prototype.addPasteListeners = function () {
  40580. var _this = this;
  40581. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_PASTE_START, function () {
  40582. _this.isPasting = true;
  40583. });
  40584. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_PASTE_END, function () {
  40585. var action = new _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["UndoRedoAction"](_this.cellValueChanges);
  40586. _this.pushActionsToUndoStack(action);
  40587. _this.isPasting = false;
  40588. });
  40589. };
  40590. UndoRedoService.prototype.addFillListeners = function () {
  40591. var _this = this;
  40592. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_FILL_START, function () {
  40593. _this.isFilling = true;
  40594. });
  40595. this.addManagedListener(this.eventService, _eventKeys__WEBPACK_IMPORTED_MODULE_1__["Events"].EVENT_FILL_END, function (event) {
  40596. var action = new _undoRedoStack__WEBPACK_IMPORTED_MODULE_2__["FillUndoRedoAction"](_this.cellValueChanges, event.initialRange, event.finalRange);
  40597. _this.pushActionsToUndoStack(action);
  40598. _this.isFilling = false;
  40599. });
  40600. };
  40601. UndoRedoService.prototype.pushActionsToUndoStack = function (action) {
  40602. this.undoStack.push(action);
  40603. this.cellValueChanges = [];
  40604. this.redoStack.clear();
  40605. };
  40606. UndoRedoService.prototype.getRowNode = function (gridRow) {
  40607. switch (gridRow.rowPinned) {
  40608. case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_TOP:
  40609. return this.pinnedRowModel.getPinnedTopRowData()[gridRow.rowIndex];
  40610. case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].PINNED_BOTTOM:
  40611. return this.pinnedRowModel.getPinnedBottomRowData()[gridRow.rowIndex];
  40612. default:
  40613. return this.rowModel.getRow(gridRow.rowIndex);
  40614. }
  40615. };
  40616. __decorate([
  40617. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  40618. ], UndoRedoService.prototype, "gridOptionsWrapper", void 0);
  40619. __decorate([
  40620. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('focusController')
  40621. ], UndoRedoService.prototype, "focusController", void 0);
  40622. __decorate([
  40623. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi')
  40624. ], UndoRedoService.prototype, "gridApi", void 0);
  40625. __decorate([
  40626. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel')
  40627. ], UndoRedoService.prototype, "rowModel", void 0);
  40628. __decorate([
  40629. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('pinnedRowModel')
  40630. ], UndoRedoService.prototype, "pinnedRowModel", void 0);
  40631. __decorate([
  40632. _context_context__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  40633. ], UndoRedoService.prototype, "init", null);
  40634. UndoRedoService = __decorate([
  40635. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('undoRedoService')
  40636. ], UndoRedoService);
  40637. return UndoRedoService;
  40638. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_6__["BeanStub"]));
  40639. /***/ }),
  40640. /* 190 */
  40641. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  40642. "use strict";
  40643. __webpack_require__.r(__webpack_exports__);
  40644. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "UndoRedoAction", function() { return UndoRedoAction; });
  40645. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FillUndoRedoAction", function() { return FillUndoRedoAction; });
  40646. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "UndoRedoStack", function() { return UndoRedoStack; });
  40647. /**
  40648. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  40649. * @version v23.2.1
  40650. * @link http://www.ag-grid.com/
  40651. * @license MIT
  40652. */
  40653. var __extends = (undefined && undefined.__extends) || (function () {
  40654. var extendStatics = function (d, b) {
  40655. extendStatics = Object.setPrototypeOf ||
  40656. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  40657. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  40658. return extendStatics(d, b);
  40659. };
  40660. return function (d, b) {
  40661. extendStatics(d, b);
  40662. function __() { this.constructor = d; }
  40663. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  40664. };
  40665. })();
  40666. var UndoRedoAction = /** @class */ (function () {
  40667. function UndoRedoAction(cellValueChanges) {
  40668. this.cellValueChanges = cellValueChanges;
  40669. }
  40670. return UndoRedoAction;
  40671. }());
  40672. var FillUndoRedoAction = /** @class */ (function (_super) {
  40673. __extends(FillUndoRedoAction, _super);
  40674. function FillUndoRedoAction(cellValueChanges, initialRange, finalRange) {
  40675. var _this = _super.call(this, cellValueChanges) || this;
  40676. _this.initialRange = initialRange;
  40677. _this.finalRange = finalRange;
  40678. return _this;
  40679. }
  40680. return FillUndoRedoAction;
  40681. }(UndoRedoAction));
  40682. var UndoRedoStack = /** @class */ (function () {
  40683. function UndoRedoStack(maxStackSize) {
  40684. this.actionStack = [];
  40685. this.maxStackSize = maxStackSize ? maxStackSize : UndoRedoStack.DEFAULT_STACK_SIZE;
  40686. this.actionStack = new Array(this.maxStackSize);
  40687. }
  40688. UndoRedoStack.prototype.pop = function () {
  40689. return this.actionStack.pop();
  40690. };
  40691. UndoRedoStack.prototype.push = function (item) {
  40692. var shouldAddActions = item.cellValueChanges && item.cellValueChanges.length > 0;
  40693. if (!shouldAddActions) {
  40694. return;
  40695. }
  40696. if (this.actionStack.length === this.maxStackSize) {
  40697. this.actionStack.shift();
  40698. }
  40699. this.actionStack.push(item);
  40700. };
  40701. UndoRedoStack.prototype.clear = function () {
  40702. this.actionStack = [];
  40703. };
  40704. UndoRedoStack.DEFAULT_STACK_SIZE = 10;
  40705. return UndoRedoStack;
  40706. }());
  40707. /***/ }),
  40708. /* 191 */
  40709. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  40710. "use strict";
  40711. __webpack_require__.r(__webpack_exports__);
  40712. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AgStackComponentsRegistry", function() { return AgStackComponentsRegistry; });
  40713. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  40714. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(41);
  40715. /**
  40716. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  40717. * @version v23.2.1
  40718. * @link http://www.ag-grid.com/
  40719. * @license MIT
  40720. */
  40721. var __extends = (undefined && undefined.__extends) || (function () {
  40722. var extendStatics = function (d, b) {
  40723. extendStatics = Object.setPrototypeOf ||
  40724. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  40725. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  40726. return extendStatics(d, b);
  40727. };
  40728. return function (d, b) {
  40729. extendStatics(d, b);
  40730. function __() { this.constructor = d; }
  40731. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  40732. };
  40733. })();
  40734. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  40735. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  40736. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  40737. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  40738. return c > 3 && r && Object.defineProperty(target, key, r), r;
  40739. };
  40740. var AgStackComponentsRegistry = /** @class */ (function (_super) {
  40741. __extends(AgStackComponentsRegistry, _super);
  40742. function AgStackComponentsRegistry() {
  40743. var _this = _super !== null && _super.apply(this, arguments) || this;
  40744. _this.componentsMappedByName = {};
  40745. return _this;
  40746. }
  40747. AgStackComponentsRegistry.prototype.setupComponents = function (components) {
  40748. var _this = this;
  40749. if (components) {
  40750. components.forEach(function (componentMeta) { return _this.addComponent(componentMeta); });
  40751. }
  40752. };
  40753. AgStackComponentsRegistry.prototype.addComponent = function (componentMeta) {
  40754. // get name of the class as a string
  40755. // let className = _.getNameOfClass(ComponentClass);
  40756. // insert a dash after every capital letter
  40757. // let classEscaped = className.replace(/([A-Z])/g, "-$1").toLowerCase();
  40758. var classEscaped = componentMeta.componentName.replace(/([a-z])([A-Z])/g, "$1-$2").toLowerCase();
  40759. // put all to upper case
  40760. var classUpperCase = classEscaped.toUpperCase();
  40761. // finally store
  40762. this.componentsMappedByName[classUpperCase] = componentMeta.componentClass;
  40763. };
  40764. AgStackComponentsRegistry.prototype.getComponentClass = function (htmlTag) {
  40765. return this.componentsMappedByName[htmlTag];
  40766. };
  40767. AgStackComponentsRegistry = __decorate([
  40768. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Bean"])('agStackComponentsRegistry')
  40769. ], AgStackComponentsRegistry);
  40770. return AgStackComponentsRegistry;
  40771. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_1__["BeanStub"]));
  40772. /***/ }),
  40773. /* 192 */
  40774. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  40775. "use strict";
  40776. __webpack_require__.r(__webpack_exports__);
  40777. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "HeaderPositionUtils", function() { return HeaderPositionUtils; });
  40778. /* harmony import */ var _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(34);
  40779. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  40780. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(41);
  40781. /* harmony import */ var _headerRowComp__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(110);
  40782. /**
  40783. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  40784. * @version v23.2.1
  40785. * @link http://www.ag-grid.com/
  40786. * @license MIT
  40787. */
  40788. var __extends = (undefined && undefined.__extends) || (function () {
  40789. var extendStatics = function (d, b) {
  40790. extendStatics = Object.setPrototypeOf ||
  40791. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  40792. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  40793. return extendStatics(d, b);
  40794. };
  40795. return function (d, b) {
  40796. extendStatics(d, b);
  40797. function __() { this.constructor = d; }
  40798. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  40799. };
  40800. })();
  40801. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  40802. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  40803. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  40804. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  40805. return c > 3 && r && Object.defineProperty(target, key, r), r;
  40806. };
  40807. var HeaderPositionUtils = /** @class */ (function (_super) {
  40808. __extends(HeaderPositionUtils, _super);
  40809. function HeaderPositionUtils() {
  40810. return _super !== null && _super.apply(this, arguments) || this;
  40811. }
  40812. HeaderPositionUtils.prototype.findHeader = function (focusedHeader, direction) {
  40813. var nextColumn;
  40814. var getGroupMethod;
  40815. var getColMethod;
  40816. if (focusedHeader.column instanceof _entities_columnGroup__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) {
  40817. getGroupMethod = "getDisplayedGroup" + direction;
  40818. nextColumn = this.columnController[getGroupMethod](focusedHeader.column);
  40819. }
  40820. else {
  40821. getColMethod = "getDisplayedCol" + direction;
  40822. nextColumn = this.columnController[getColMethod](focusedHeader.column);
  40823. }
  40824. if (nextColumn) {
  40825. return {
  40826. column: nextColumn,
  40827. headerRowIndex: focusedHeader.headerRowIndex
  40828. };
  40829. }
  40830. };
  40831. HeaderPositionUtils.prototype.findColAtEdgeForHeaderRow = function (level, position) {
  40832. var displayedColumns = this.columnController.getAllDisplayedColumns();
  40833. var column = displayedColumns[position === 'start' ? 0 : displayedColumns.length - 1];
  40834. if (!column) {
  40835. return;
  40836. }
  40837. var childContainer = this.headerNavigationService.getHeaderContainer(column.getPinned());
  40838. var headerRowComp = childContainer.getRowComps()[level];
  40839. var type = headerRowComp && headerRowComp.getType();
  40840. if (type == _headerRowComp__WEBPACK_IMPORTED_MODULE_3__["HeaderRowType"].COLUMN_GROUP) {
  40841. var columnGroup = this.columnController.getColumnGroupAtLevel(column, level);
  40842. return {
  40843. headerRowIndex: level,
  40844. column: columnGroup
  40845. };
  40846. }
  40847. return {
  40848. headerRowIndex: !headerRowComp ? -1 : level,
  40849. column: column
  40850. };
  40851. };
  40852. __decorate([
  40853. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('columnController')
  40854. ], HeaderPositionUtils.prototype, "columnController", void 0);
  40855. __decorate([
  40856. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Autowired"])('headerNavigationService')
  40857. ], HeaderPositionUtils.prototype, "headerNavigationService", void 0);
  40858. HeaderPositionUtils = __decorate([
  40859. Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Bean"])('headerPositionUtils')
  40860. ], HeaderPositionUtils);
  40861. return HeaderPositionUtils;
  40862. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"]));
  40863. /***/ }),
  40864. /* 193 */
  40865. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  40866. "use strict";
  40867. __webpack_require__.r(__webpack_exports__);
  40868. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "initialiseAgGridWithWebComponents", function() { return initialiseAgGridWithWebComponents; });
  40869. /* harmony import */ var _componentUtil__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(48);
  40870. /* harmony import */ var _grid__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(95);
  40871. /**
  40872. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  40873. * @version v23.2.1
  40874. * @link http://www.ag-grid.com/
  40875. * @license MIT
  40876. */
  40877. var registered = false;
  40878. function initialiseAgGridWithWebComponents() {
  40879. console.warn('ag-grid: initialiseAgGridWithWebComponents is deprecated. Please use the ag-grid-webcomponent dependency instead. ');
  40880. // only register to WebComponents once
  40881. if (registered) {
  40882. return;
  40883. }
  40884. registered = true;
  40885. if (typeof document === 'undefined' || !document.registerElement) {
  40886. console.error('ag-Grid: unable to find document.registerElement() function, unable to initialise ag-Grid as a Web Component');
  40887. }
  40888. // i don't think this type of extension is possible in TypeScript, so back to
  40889. // plain Javascript to create this object
  40890. var AgileGridProto = Object.create(HTMLElement.prototype);
  40891. // wrap each property with a get and set method, so we can track when changes are done
  40892. _componentUtil__WEBPACK_IMPORTED_MODULE_0__["ComponentUtil"].ALL_PROPERTIES.forEach(function (key) {
  40893. Object.defineProperty(AgileGridProto, key, {
  40894. set: function (v) {
  40895. this.__agGridSetProperty(key, v);
  40896. },
  40897. get: function () {
  40898. return this.__agGridGetProperty(key);
  40899. },
  40900. enumerable: true,
  40901. configurable: true
  40902. });
  40903. });
  40904. var agGridProtoNoType = AgileGridProto;
  40905. agGridProtoNoType.__agGridSetProperty = function (key, value) {
  40906. if (!this.__attributes) {
  40907. this.__attributes = {};
  40908. }
  40909. this.__attributes[key] = value;
  40910. // keeping this consistent with the ng2 onChange, so I can reuse the handling code
  40911. var changeObject = {};
  40912. changeObject[key] = { currentValue: value };
  40913. this.onChange(changeObject);
  40914. };
  40915. agGridProtoNoType.onChange = function (changes) {
  40916. if (this._initialised) {
  40917. _componentUtil__WEBPACK_IMPORTED_MODULE_0__["ComponentUtil"].processOnChange(changes, this._gridOptions, this.api, this.columnApi);
  40918. }
  40919. };
  40920. agGridProtoNoType.__agGridGetProperty = function (key) {
  40921. if (!this.__attributes) {
  40922. this.__attributes = {};
  40923. }
  40924. return this.__attributes[key];
  40925. };
  40926. agGridProtoNoType.setGridOptions = function (options) {
  40927. var globalEventListener = this.globalEventListener.bind(this);
  40928. this._gridOptions = _componentUtil__WEBPACK_IMPORTED_MODULE_0__["ComponentUtil"].copyAttributesToGridOptions(options, this);
  40929. var gridParams = {
  40930. globalEventListener: globalEventListener
  40931. };
  40932. this._agGrid = new _grid__WEBPACK_IMPORTED_MODULE_1__["Grid"](this, this._gridOptions, gridParams);
  40933. this.api = options.api;
  40934. this.columnApi = options.columnApi;
  40935. this._initialised = true;
  40936. };
  40937. // copies all the attributes into this object
  40938. agGridProtoNoType.createdCallback = function () {
  40939. for (var i = 0; i < this.attributes.length; i++) {
  40940. var attribute = this.attributes[i];
  40941. this.setPropertyFromAttribute(attribute);
  40942. }
  40943. };
  40944. agGridProtoNoType.setPropertyFromAttribute = function (attribute) {
  40945. var name = toCamelCase(attribute.nodeName);
  40946. var value = attribute.nodeValue;
  40947. if (_componentUtil__WEBPACK_IMPORTED_MODULE_0__["ComponentUtil"].ALL_PROPERTIES.indexOf(name) >= 0) {
  40948. this[name] = value;
  40949. }
  40950. };
  40951. agGridProtoNoType.attachedCallback = function (params) { };
  40952. agGridProtoNoType.detachedCallback = function (params) { };
  40953. agGridProtoNoType.attributeChangedCallback = function (attributeName) {
  40954. var attribute = this.attributes[attributeName];
  40955. this.setPropertyFromAttribute(attribute);
  40956. };
  40957. agGridProtoNoType.globalEventListener = function (eventType, event) {
  40958. var eventLowerCase = eventType.toLowerCase();
  40959. var browserEvent = new Event(eventLowerCase);
  40960. var browserEventNoType = browserEvent;
  40961. browserEventNoType.agGridDetails = event;
  40962. this.dispatchEvent(browserEvent);
  40963. var callbackMethod = 'on' + eventLowerCase;
  40964. if (typeof this[callbackMethod] === 'function') {
  40965. this[callbackMethod](browserEvent);
  40966. }
  40967. };
  40968. // finally, register
  40969. document.registerElement('ag-grid', { prototype: AgileGridProto });
  40970. }
  40971. function toCamelCase(myString) {
  40972. if (typeof myString === 'string') {
  40973. var result = myString.replace(/-([a-z])/g, function (g) {
  40974. return g[1].toUpperCase();
  40975. });
  40976. return result;
  40977. }
  40978. else {
  40979. return myString;
  40980. }
  40981. }
  40982. /***/ }),
  40983. /* 194 */
  40984. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  40985. "use strict";
  40986. __webpack_require__.r(__webpack_exports__);
  40987. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "TabbedLayout", function() { return TabbedLayout; });
  40988. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7);
  40989. /* harmony import */ var _widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57);
  40990. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(25);
  40991. /* harmony import */ var _widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(117);
  40992. /**
  40993. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  40994. * @version v23.2.1
  40995. * @link http://www.ag-grid.com/
  40996. * @license MIT
  40997. */
  40998. var __extends = (undefined && undefined.__extends) || (function () {
  40999. var extendStatics = function (d, b) {
  41000. extendStatics = Object.setPrototypeOf ||
  41001. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  41002. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  41003. return extendStatics(d, b);
  41004. };
  41005. return function (d, b) {
  41006. extendStatics(d, b);
  41007. function __() { this.constructor = d; }
  41008. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  41009. };
  41010. })();
  41011. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  41012. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  41013. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  41014. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  41015. return c > 3 && r && Object.defineProperty(target, key, r), r;
  41016. };
  41017. var TabbedLayout = /** @class */ (function (_super) {
  41018. __extends(TabbedLayout, _super);
  41019. function TabbedLayout(params) {
  41020. var _this = _super.call(this, TabbedLayout.getTemplate(params.cssClass)) || this;
  41021. _this.items = [];
  41022. _this.params = params;
  41023. if (params.items) {
  41024. params.items.forEach(function (item) { return _this.addItem(item); });
  41025. }
  41026. return _this;
  41027. }
  41028. TabbedLayout.getTemplate = function (cssClass) {
  41029. return /* html */ "<div class=\"ag-tabs " + cssClass + "\">\n <div ref=\"eHeader\" class=\"ag-tabs-header " + (cssClass ? cssClass + "-header" : '') + "\"></div>\n <div ref=\"eBody\" class=\"ag-tabs-body " + (cssClass ? cssClass + "-body" : '') + "\"></div>\n </div>";
  41030. };
  41031. TabbedLayout.prototype.handleKeyDown = function (e) {
  41032. switch (e.keyCode) {
  41033. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_RIGHT:
  41034. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_LEFT:
  41035. if (!this.eHeader.contains(document.activeElement)) {
  41036. return;
  41037. }
  41038. var currentPosition = this.items.indexOf(this.activeItem);
  41039. var nextPosition = e.keyCode === _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_RIGHT ? Math.min(currentPosition + 1, this.items.length - 1) : Math.max(currentPosition - 1, 0);
  41040. if (currentPosition === nextPosition) {
  41041. return;
  41042. }
  41043. e.preventDefault();
  41044. var nextItem = this.items[nextPosition];
  41045. this.showItemWrapper(nextItem);
  41046. nextItem.eHeaderButton.focus();
  41047. break;
  41048. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_UP:
  41049. case _constants__WEBPACK_IMPORTED_MODULE_2__["Constants"].KEY_DOWN:
  41050. e.stopPropagation();
  41051. break;
  41052. }
  41053. };
  41054. TabbedLayout.prototype.onTabKeyDown = function (e) {
  41055. var _a = this, focusController = _a.focusController, eHeader = _a.eHeader, eBody = _a.eBody, activeItem = _a.activeItem;
  41056. var activeElement = document.activeElement;
  41057. var focusInHeader = eHeader.contains(activeElement);
  41058. e.preventDefault();
  41059. if (focusInHeader) {
  41060. if (e.shiftKey) {
  41061. focusController.focusLastFocusableElement(eBody);
  41062. }
  41063. else {
  41064. focusController.focusFirstFocusableElement(eBody);
  41065. }
  41066. }
  41067. else {
  41068. var isFocusManaged = focusController.isFocusUnderManagedComponent(eBody);
  41069. if (isFocusManaged) {
  41070. activeItem.eHeaderButton.focus();
  41071. }
  41072. else {
  41073. var nextEl = focusController.findNextFocusableElement(eBody, false, e.shiftKey);
  41074. if (nextEl) {
  41075. nextEl.focus();
  41076. }
  41077. else {
  41078. activeItem.eHeaderButton.focus();
  41079. }
  41080. }
  41081. }
  41082. };
  41083. TabbedLayout.prototype.setAfterAttachedParams = function (params) {
  41084. this.afterAttachedParams = params;
  41085. };
  41086. TabbedLayout.prototype.getMinDimensions = function () {
  41087. var eDummyContainer = this.getGui().cloneNode(true);
  41088. var eDummyBody = eDummyContainer.querySelector('[ref="eBody"]');
  41089. // position fixed, so it isn't restricted to the boundaries of the parent
  41090. eDummyContainer.style.position = 'fixed';
  41091. // we put the dummy into the body container, so it will inherit all the
  41092. // css styles that the real cells are inheriting
  41093. this.getGui().appendChild(eDummyContainer);
  41094. var minWidth = 0;
  41095. var minHeight = 0;
  41096. this.items.forEach(function (itemWrapper) {
  41097. _utils__WEBPACK_IMPORTED_MODULE_0__["_"].clearElement(eDummyBody);
  41098. var eClone = itemWrapper.tabbedItem.bodyPromise.resolveNow(null, function (body) { return body.cloneNode(true); });
  41099. if (eClone == null) {
  41100. return;
  41101. }
  41102. eDummyBody.appendChild(eClone);
  41103. if (minWidth < eDummyContainer.offsetWidth) {
  41104. minWidth = eDummyContainer.offsetWidth;
  41105. }
  41106. if (minHeight < eDummyContainer.offsetHeight) {
  41107. minHeight = eDummyContainer.offsetHeight;
  41108. }
  41109. });
  41110. this.getGui().removeChild(eDummyContainer);
  41111. return { height: minHeight, width: minWidth };
  41112. };
  41113. TabbedLayout.prototype.showFirstItem = function () {
  41114. if (this.items.length > 0) {
  41115. this.showItemWrapper(this.items[0]);
  41116. }
  41117. };
  41118. TabbedLayout.prototype.addItem = function (item) {
  41119. var eHeaderButton = document.createElement('span');
  41120. eHeaderButton.tabIndex = -1;
  41121. eHeaderButton.appendChild(item.title);
  41122. _utils__WEBPACK_IMPORTED_MODULE_0__["_"].addCssClass(eHeaderButton, 'ag-tab');
  41123. this.eHeader.appendChild(eHeaderButton);
  41124. eHeaderButton.setAttribute('aria-label', item.titleLabel);
  41125. var wrapper = {
  41126. tabbedItem: item,
  41127. eHeaderButton: eHeaderButton
  41128. };
  41129. this.items.push(wrapper);
  41130. eHeaderButton.addEventListener('click', this.showItemWrapper.bind(this, wrapper));
  41131. };
  41132. TabbedLayout.prototype.showItem = function (tabbedItem) {
  41133. var itemWrapper = _utils__WEBPACK_IMPORTED_MODULE_0__["_"].find(this.items, function (wrapper) {
  41134. return wrapper.tabbedItem === tabbedItem;
  41135. });
  41136. if (itemWrapper) {
  41137. this.showItemWrapper(itemWrapper);
  41138. }
  41139. };
  41140. TabbedLayout.prototype.showItemWrapper = function (wrapper) {
  41141. var _this = this;
  41142. if (this.params.onItemClicked) {
  41143. this.params.onItemClicked({ item: wrapper.tabbedItem });
  41144. }
  41145. if (this.activeItem === wrapper) {
  41146. _utils__WEBPACK_IMPORTED_MODULE_0__["_"].callIfPresent(this.params.onActiveItemClicked);
  41147. return;
  41148. }
  41149. _utils__WEBPACK_IMPORTED_MODULE_0__["_"].clearElement(this.eBody);
  41150. wrapper.tabbedItem.bodyPromise.then(function (body) {
  41151. _this.eBody.appendChild(body);
  41152. var onlyUnmanaged = !_this.focusController.isKeyboardFocus();
  41153. _this.focusController.focusFirstFocusableElement(_this.eBody, onlyUnmanaged);
  41154. });
  41155. if (this.activeItem) {
  41156. _utils__WEBPACK_IMPORTED_MODULE_0__["_"].removeCssClass(this.activeItem.eHeaderButton, 'ag-tab-selected');
  41157. }
  41158. _utils__WEBPACK_IMPORTED_MODULE_0__["_"].addCssClass(wrapper.eHeaderButton, 'ag-tab-selected');
  41159. this.activeItem = wrapper;
  41160. if (wrapper.tabbedItem.afterAttachedCallback) {
  41161. wrapper.tabbedItem.afterAttachedCallback(this.afterAttachedParams);
  41162. }
  41163. };
  41164. __decorate([
  41165. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eHeader')
  41166. ], TabbedLayout.prototype, "eHeader", void 0);
  41167. __decorate([
  41168. Object(_widgets_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eBody')
  41169. ], TabbedLayout.prototype, "eBody", void 0);
  41170. return TabbedLayout;
  41171. }(_widgets_managedFocusComponent__WEBPACK_IMPORTED_MODULE_3__["ManagedFocusComponent"]));
  41172. /***/ }),
  41173. /* 195 */
  41174. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  41175. "use strict";
  41176. __webpack_require__.r(__webpack_exports__);
  41177. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "simpleHttpRequest", function() { return simpleHttpRequest; });
  41178. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7);
  41179. /**
  41180. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  41181. * @version v23.2.1
  41182. * @link http://www.ag-grid.com/
  41183. * @license MIT
  41184. */
  41185. function simpleHttpRequest(params) {
  41186. return new _utils__WEBPACK_IMPORTED_MODULE_0__["Promise"](function (resolve) {
  41187. var httpRequest = new XMLHttpRequest();
  41188. httpRequest.open('GET', params.url);
  41189. httpRequest.send();
  41190. httpRequest.onreadystatechange = function () {
  41191. if (httpRequest.readyState === 4 && httpRequest.status === 200) {
  41192. resolve(JSON.parse(httpRequest.responseText));
  41193. }
  41194. };
  41195. });
  41196. }
  41197. /***/ }),
  41198. /* 196 */
  41199. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  41200. "use strict";
  41201. __webpack_require__.r(__webpack_exports__);
  41202. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowNodeBlock", function() { return RowNodeBlock; });
  41203. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7);
  41204. /* harmony import */ var _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(68);
  41205. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(37);
  41206. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(41);
  41207. /**
  41208. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  41209. * @version v23.2.1
  41210. * @link http://www.ag-grid.com/
  41211. * @license MIT
  41212. */
  41213. var __extends = (undefined && undefined.__extends) || (function () {
  41214. var extendStatics = function (d, b) {
  41215. extendStatics = Object.setPrototypeOf ||
  41216. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  41217. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  41218. return extendStatics(d, b);
  41219. };
  41220. return function (d, b) {
  41221. extendStatics(d, b);
  41222. function __() { this.constructor = d; }
  41223. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  41224. };
  41225. })();
  41226. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  41227. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  41228. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  41229. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  41230. return c > 3 && r && Object.defineProperty(target, key, r), r;
  41231. };
  41232. var RowNodeBlock = /** @class */ (function (_super) {
  41233. __extends(RowNodeBlock, _super);
  41234. function RowNodeBlock(blockNumber, rowNodeCacheParams) {
  41235. var _this = _super.call(this) || this;
  41236. _this.version = 0;
  41237. _this.state = RowNodeBlock.STATE_DIRTY;
  41238. _this.rowNodeCacheParams = rowNodeCacheParams;
  41239. _this.blockNumber = blockNumber;
  41240. // we don't need to calculate these now, as the inputs don't change,
  41241. // however it makes the code easier to read if we work them out up front
  41242. _this.startRow = blockNumber * rowNodeCacheParams.blockSize;
  41243. _this.endRow = _this.startRow + rowNodeCacheParams.blockSize;
  41244. return _this;
  41245. }
  41246. RowNodeBlock.prototype.isAnyNodeOpen = function (rowCount) {
  41247. var result = false;
  41248. this.forEachNodeCallback(function (rowNode) {
  41249. if (rowNode.expanded) {
  41250. result = true;
  41251. }
  41252. }, rowCount);
  41253. return result;
  41254. };
  41255. RowNodeBlock.prototype.forEachNodeCallback = function (callback, rowCount) {
  41256. for (var rowIndex = this.startRow; rowIndex < this.endRow; rowIndex++) {
  41257. // we check against rowCount as this page may be the last one, and if it is, then
  41258. // the last rows are not part of the set
  41259. if (rowIndex < rowCount) {
  41260. var rowNode = this.getRowUsingLocalIndex(rowIndex);
  41261. callback(rowNode, rowIndex);
  41262. }
  41263. }
  41264. };
  41265. RowNodeBlock.prototype.forEachNode = function (callback, sequence, rowCount, deep) {
  41266. this.forEachNodeCallback(function (rowNode) {
  41267. callback(rowNode, sequence.next());
  41268. // this will only every happen for server side row model, as infinite
  41269. // row model doesn't have groups
  41270. if (deep && rowNode.childrenCache) {
  41271. rowNode.childrenCache.forEachNodeDeep(callback, sequence);
  41272. }
  41273. }, rowCount);
  41274. };
  41275. RowNodeBlock.prototype.forEachNodeDeep = function (callback, sequence, rowCount) {
  41276. this.forEachNode(callback, sequence, rowCount, true);
  41277. };
  41278. RowNodeBlock.prototype.forEachNodeShallow = function (callback, sequence, rowCount) {
  41279. this.forEachNode(callback, sequence, rowCount, false);
  41280. };
  41281. RowNodeBlock.prototype.getVersion = function () {
  41282. return this.version;
  41283. };
  41284. RowNodeBlock.prototype.getLastAccessed = function () {
  41285. return this.lastAccessed;
  41286. };
  41287. RowNodeBlock.prototype.getRowUsingLocalIndex = function (rowIndex, dontTouchLastAccessed) {
  41288. if (dontTouchLastAccessed === void 0) { dontTouchLastAccessed = false; }
  41289. if (!dontTouchLastAccessed) {
  41290. this.lastAccessed = this.rowNodeCacheParams.lastAccessedSequence.next();
  41291. }
  41292. var localIndex = rowIndex - this.startRow;
  41293. return this.rowNodes[localIndex];
  41294. };
  41295. RowNodeBlock.prototype.init = function (beans) {
  41296. this.beans = beans;
  41297. this.createRowNodes();
  41298. };
  41299. RowNodeBlock.prototype.getStartRow = function () {
  41300. return this.startRow;
  41301. };
  41302. RowNodeBlock.prototype.getEndRow = function () {
  41303. return this.endRow;
  41304. };
  41305. RowNodeBlock.prototype.getBlockNumber = function () {
  41306. return this.blockNumber;
  41307. };
  41308. RowNodeBlock.prototype.setDirty = function () {
  41309. // in case any current loads in progress, this will have their results ignored
  41310. this.version++;
  41311. this.state = RowNodeBlock.STATE_DIRTY;
  41312. };
  41313. RowNodeBlock.prototype.setDirtyAndPurge = function () {
  41314. this.setDirty();
  41315. this.rowNodes.forEach(function (rowNode) {
  41316. rowNode.setData(null);
  41317. });
  41318. };
  41319. RowNodeBlock.prototype.getState = function () {
  41320. return this.state;
  41321. };
  41322. RowNodeBlock.prototype.setRowNode = function (rowIndex, rowNode) {
  41323. var localIndex = rowIndex - this.startRow;
  41324. this.rowNodes[localIndex] = rowNode;
  41325. };
  41326. RowNodeBlock.prototype.setBlankRowNode = function (rowIndex) {
  41327. var localIndex = rowIndex - this.startRow;
  41328. var newRowNode = this.createBlankRowNode(rowIndex);
  41329. this.rowNodes[localIndex] = newRowNode;
  41330. return newRowNode;
  41331. };
  41332. RowNodeBlock.prototype.setNewData = function (rowIndex, dataItem) {
  41333. var newRowNode = this.setBlankRowNode(rowIndex);
  41334. this.setDataAndId(newRowNode, dataItem, this.startRow + rowIndex);
  41335. return newRowNode;
  41336. };
  41337. RowNodeBlock.prototype.createBlankRowNode = function (rowIndex) {
  41338. var rowNode = new _entities_rowNode__WEBPACK_IMPORTED_MODULE_1__["RowNode"]();
  41339. this.beans.context.createBean(rowNode);
  41340. rowNode.setRowHeight(this.rowNodeCacheParams.rowHeight);
  41341. return rowNode;
  41342. };
  41343. // creates empty row nodes, data is missing as not loaded yet
  41344. RowNodeBlock.prototype.createRowNodes = function () {
  41345. this.rowNodes = [];
  41346. for (var i = 0; i < this.rowNodeCacheParams.blockSize; i++) {
  41347. var rowIndex = this.startRow + i;
  41348. var rowNode = this.createBlankRowNode(rowIndex);
  41349. this.rowNodes.push(rowNode);
  41350. }
  41351. };
  41352. RowNodeBlock.prototype.load = function () {
  41353. this.state = RowNodeBlock.STATE_LOADING;
  41354. this.loadFromDatasource();
  41355. };
  41356. RowNodeBlock.prototype.pageLoadFailed = function () {
  41357. this.state = RowNodeBlock.STATE_FAILED;
  41358. var event = {
  41359. type: RowNodeBlock.EVENT_LOAD_COMPLETE,
  41360. success: false,
  41361. page: this,
  41362. lastRow: null
  41363. };
  41364. this.dispatchEvent(event);
  41365. };
  41366. RowNodeBlock.prototype.populateWithRowData = function (rows) {
  41367. var _this = this;
  41368. var rowNodesToRefresh = [];
  41369. this.rowNodes.forEach(function (rowNode, index) {
  41370. var data = rows[index];
  41371. if (rowNode.stub) {
  41372. rowNodesToRefresh.push(rowNode);
  41373. }
  41374. _this.setDataAndId(rowNode, data, _this.startRow + index);
  41375. });
  41376. if (rowNodesToRefresh.length > 0) {
  41377. this.beans.rowRenderer.redrawRows(rowNodesToRefresh);
  41378. }
  41379. };
  41380. RowNodeBlock.prototype.destroyRowNodes = function () {
  41381. var _this = this;
  41382. this.rowNodes.forEach(function (rowNode) {
  41383. if (rowNode.childrenCache) {
  41384. _this.destroyBean(rowNode.childrenCache);
  41385. rowNode.childrenCache = null;
  41386. }
  41387. // this is needed, so row render knows to fade out the row, otherwise it
  41388. // sees row top is present, and thinks the row should be shown. maybe
  41389. // rowNode should have a flag on whether it is visible???
  41390. rowNode.clearRowTop();
  41391. });
  41392. };
  41393. RowNodeBlock.prototype.pageLoaded = function (version, rows, lastRow) {
  41394. // we need to check the version, in case there was an old request
  41395. // from the server that was sent before we refreshed the cache,
  41396. // if the load was done as a result of a cache refresh
  41397. if (version === this.version) {
  41398. this.state = RowNodeBlock.STATE_LOADED;
  41399. this.populateWithRowData(rows);
  41400. }
  41401. lastRow = _utils__WEBPACK_IMPORTED_MODULE_0__["_"].cleanNumber(lastRow);
  41402. // check here if lastRow should be set
  41403. var event = {
  41404. type: RowNodeBlock.EVENT_LOAD_COMPLETE,
  41405. success: true,
  41406. page: this,
  41407. lastRow: lastRow
  41408. };
  41409. this.dispatchEvent(event);
  41410. };
  41411. RowNodeBlock.EVENT_LOAD_COMPLETE = 'loadComplete';
  41412. RowNodeBlock.STATE_DIRTY = 'dirty';
  41413. RowNodeBlock.STATE_LOADING = 'loading';
  41414. RowNodeBlock.STATE_LOADED = 'loaded';
  41415. RowNodeBlock.STATE_FAILED = 'failed';
  41416. __decorate([
  41417. _context_context__WEBPACK_IMPORTED_MODULE_2__["PreDestroy"]
  41418. ], RowNodeBlock.prototype, "destroyRowNodes", null);
  41419. return RowNodeBlock;
  41420. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_3__["BeanStub"]));
  41421. /***/ }),
  41422. /* 197 */
  41423. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  41424. "use strict";
  41425. __webpack_require__.r(__webpack_exports__);
  41426. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowNodeBlockLoader", function() { return RowNodeBlockLoader; });
  41427. /* harmony import */ var _rowNodeBlock__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(196);
  41428. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(37);
  41429. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(41);
  41430. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(7);
  41431. /**
  41432. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  41433. * @version v23.2.1
  41434. * @link http://www.ag-grid.com/
  41435. * @license MIT
  41436. */
  41437. var __extends = (undefined && undefined.__extends) || (function () {
  41438. var extendStatics = function (d, b) {
  41439. extendStatics = Object.setPrototypeOf ||
  41440. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  41441. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  41442. return extendStatics(d, b);
  41443. };
  41444. return function (d, b) {
  41445. extendStatics(d, b);
  41446. function __() { this.constructor = d; }
  41447. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  41448. };
  41449. })();
  41450. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  41451. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  41452. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  41453. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  41454. return c > 3 && r && Object.defineProperty(target, key, r), r;
  41455. };
  41456. var __param = (undefined && undefined.__param) || function (paramIndex, decorator) {
  41457. return function (target, key) { decorator(target, key, paramIndex); }
  41458. };
  41459. var RowNodeBlockLoader = /** @class */ (function (_super) {
  41460. __extends(RowNodeBlockLoader, _super);
  41461. function RowNodeBlockLoader(maxConcurrentRequests, blockLoadDebounceMillis) {
  41462. var _this = _super.call(this) || this;
  41463. _this.activeBlockLoadsCount = 0;
  41464. _this.blocks = [];
  41465. _this.active = true;
  41466. _this.maxConcurrentRequests = maxConcurrentRequests;
  41467. if (blockLoadDebounceMillis && blockLoadDebounceMillis > 0) {
  41468. _this.checkBlockToLoadDebounce = _utils__WEBPACK_IMPORTED_MODULE_3__["_"].debounce(_this.performCheckBlocksToLoad.bind(_this), blockLoadDebounceMillis);
  41469. }
  41470. return _this;
  41471. }
  41472. RowNodeBlockLoader.prototype.setBeans = function (loggerFactory) {
  41473. this.logger = loggerFactory.create('RowNodeBlockLoader');
  41474. };
  41475. RowNodeBlockLoader.prototype.addBlock = function (block) {
  41476. this.blocks.push(block);
  41477. };
  41478. RowNodeBlockLoader.prototype.removeBlock = function (block) {
  41479. _utils__WEBPACK_IMPORTED_MODULE_3__["_"].removeFromArray(this.blocks, block);
  41480. };
  41481. RowNodeBlockLoader.prototype.destroy = function () {
  41482. _super.prototype.destroy.call(this);
  41483. this.active = false;
  41484. };
  41485. RowNodeBlockLoader.prototype.loadComplete = function () {
  41486. this.activeBlockLoadsCount--;
  41487. };
  41488. RowNodeBlockLoader.prototype.checkBlockToLoad = function () {
  41489. if (this.checkBlockToLoadDebounce) {
  41490. this.checkBlockToLoadDebounce();
  41491. }
  41492. else {
  41493. this.performCheckBlocksToLoad();
  41494. }
  41495. };
  41496. RowNodeBlockLoader.prototype.performCheckBlocksToLoad = function () {
  41497. if (!this.active) {
  41498. return;
  41499. }
  41500. this.printCacheStatus();
  41501. if (this.activeBlockLoadsCount >= this.maxConcurrentRequests) {
  41502. this.logger.log("checkBlockToLoad: max loads exceeded");
  41503. return;
  41504. }
  41505. var blockToLoad = null;
  41506. this.blocks.forEach(function (block) {
  41507. if (block.getState() === _rowNodeBlock__WEBPACK_IMPORTED_MODULE_0__["RowNodeBlock"].STATE_DIRTY) {
  41508. blockToLoad = block;
  41509. }
  41510. });
  41511. if (blockToLoad) {
  41512. blockToLoad.load();
  41513. this.activeBlockLoadsCount++;
  41514. this.logger.log("checkBlockToLoad: loading page " + blockToLoad.getBlockNumber());
  41515. this.printCacheStatus();
  41516. }
  41517. else {
  41518. this.logger.log("checkBlockToLoad: no pages to load");
  41519. }
  41520. };
  41521. RowNodeBlockLoader.prototype.getBlockState = function () {
  41522. var result = {};
  41523. this.blocks.forEach(function (block) {
  41524. var nodeIdPrefix = block.getNodeIdPrefix();
  41525. var stateItem = {
  41526. blockNumber: block.getBlockNumber(),
  41527. startRow: block.getStartRow(),
  41528. endRow: block.getEndRow(),
  41529. pageStatus: block.getState()
  41530. };
  41531. if (_utils__WEBPACK_IMPORTED_MODULE_3__["_"].exists(nodeIdPrefix)) {
  41532. result[nodeIdPrefix + block.getBlockNumber()] = stateItem;
  41533. }
  41534. else {
  41535. result[block.getBlockNumber()] = stateItem;
  41536. }
  41537. });
  41538. return result;
  41539. };
  41540. RowNodeBlockLoader.prototype.printCacheStatus = function () {
  41541. if (this.logger.isLogging()) {
  41542. this.logger.log("printCacheStatus: activePageLoadsCount = " + this.activeBlockLoadsCount + ","
  41543. + (" blocks = " + JSON.stringify(this.getBlockState())));
  41544. }
  41545. };
  41546. RowNodeBlockLoader.prototype.isLoading = function () {
  41547. return this.activeBlockLoadsCount > 0;
  41548. };
  41549. __decorate([
  41550. __param(0, Object(_context_context__WEBPACK_IMPORTED_MODULE_1__["Qualifier"])('loggerFactory'))
  41551. ], RowNodeBlockLoader.prototype, "setBeans", null);
  41552. return RowNodeBlockLoader;
  41553. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_2__["BeanStub"]));
  41554. /***/ }),
  41555. /* 198 */
  41556. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  41557. "use strict";
  41558. __webpack_require__.r(__webpack_exports__);
  41559. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowNodeCache", function() { return RowNodeCache; });
  41560. /* harmony import */ var _context_beanStub__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(41);
  41561. /* harmony import */ var _rowNodeBlock__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(196);
  41562. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
  41563. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(37);
  41564. /**
  41565. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  41566. * @version v23.2.1
  41567. * @link http://www.ag-grid.com/
  41568. * @license MIT
  41569. */
  41570. var __extends = (undefined && undefined.__extends) || (function () {
  41571. var extendStatics = function (d, b) {
  41572. extendStatics = Object.setPrototypeOf ||
  41573. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  41574. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  41575. return extendStatics(d, b);
  41576. };
  41577. return function (d, b) {
  41578. extendStatics(d, b);
  41579. function __() { this.constructor = d; }
  41580. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  41581. };
  41582. })();
  41583. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  41584. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  41585. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  41586. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  41587. return c > 3 && r && Object.defineProperty(target, key, r), r;
  41588. };
  41589. var RowNodeCache = /** @class */ (function (_super) {
  41590. __extends(RowNodeCache, _super);
  41591. function RowNodeCache(cacheParams) {
  41592. var _this = _super.call(this) || this;
  41593. _this.maxRowFound = false;
  41594. _this.blocks = {};
  41595. _this.blockCount = 0;
  41596. _this.virtualRowCount = cacheParams.initialRowCount;
  41597. _this.cacheParams = cacheParams;
  41598. return _this;
  41599. }
  41600. RowNodeCache.prototype.destroyAllBlocks = function () {
  41601. var _this = this;
  41602. this.forEachBlockInOrder(function (block) { return _this.destroyBlock(block); });
  41603. };
  41604. RowNodeCache.prototype.init = function () {
  41605. var _this = this;
  41606. this.active = true;
  41607. this.addDestroyFunc(function () { return _this.active = false; });
  41608. };
  41609. RowNodeCache.prototype.isActive = function () {
  41610. return this.active;
  41611. };
  41612. RowNodeCache.prototype.getVirtualRowCount = function () {
  41613. return this.virtualRowCount;
  41614. };
  41615. RowNodeCache.prototype.hack_setVirtualRowCount = function (virtualRowCount) {
  41616. this.virtualRowCount = virtualRowCount;
  41617. };
  41618. RowNodeCache.prototype.isMaxRowFound = function () {
  41619. return this.maxRowFound;
  41620. };
  41621. // listener on EVENT_LOAD_COMPLETE
  41622. RowNodeCache.prototype.onPageLoaded = function (event) {
  41623. this.cacheParams.rowNodeBlockLoader.loadComplete();
  41624. this.checkBlockToLoad();
  41625. // if we are not active, then we ignore all events, otherwise we could end up getting the
  41626. // grid to refresh even though we are no longer the active cache
  41627. if (!this.isActive()) {
  41628. return;
  41629. }
  41630. this.logger.log("onPageLoaded: page = " + event.page.getBlockNumber() + ", lastRow = " + event.lastRow);
  41631. if (event.success) {
  41632. this.checkVirtualRowCount(event.page, event.lastRow);
  41633. }
  41634. };
  41635. RowNodeCache.prototype.purgeBlocksIfNeeded = function (blockToExclude) {
  41636. var _this = this;
  41637. // put all candidate blocks into a list for sorting
  41638. var blocksForPurging = [];
  41639. this.forEachBlockInOrder(function (block) {
  41640. // we exclude checking for the page just created, as this has yet to be accessed and hence
  41641. // the lastAccessed stamp will not be updated for the first time yet
  41642. if (block === blockToExclude) {
  41643. return;
  41644. }
  41645. blocksForPurging.push(block);
  41646. });
  41647. // note: need to verify that this sorts items in the right order
  41648. blocksForPurging.sort(function (a, b) { return b.getLastAccessed() - a.getLastAccessed(); });
  41649. // we remove (maxBlocksInCache - 1) as we already excluded the 'just created' page.
  41650. // in other words, after the splice operation below, we have taken out the blocks
  41651. // we want to keep, which means we are left with blocks that we can potentially purge
  41652. var maxBlocksProvided = this.cacheParams.maxBlocksInCache > 0;
  41653. var blocksToKeep = maxBlocksProvided ? this.cacheParams.maxBlocksInCache - 1 : null;
  41654. var emptyBlocksToKeep = RowNodeCache.MAX_EMPTY_BLOCKS_TO_KEEP - 1;
  41655. blocksForPurging.forEach(function (block, index) {
  41656. var purgeBecauseBlockEmpty = block.getState() === _rowNodeBlock__WEBPACK_IMPORTED_MODULE_1__["RowNodeBlock"].STATE_DIRTY && index >= emptyBlocksToKeep;
  41657. var purgeBecauseCacheFull = maxBlocksProvided ? index >= blocksToKeep : false;
  41658. if (purgeBecauseBlockEmpty || purgeBecauseCacheFull) {
  41659. // we never purge blocks if they are open, as purging them would mess up with
  41660. // our indexes, it would be very messy to restore the purged block to it's
  41661. // previous state if it had open children (and what if open children of open
  41662. // children, jeeeesus, just thinking about it freaks me out) so best is have a
  41663. // rule, if block is open, we never purge.
  41664. if (block.isAnyNodeOpen(_this.virtualRowCount)) {
  41665. return;
  41666. }
  41667. // if the block currently has rows been displayed, then don't remove it either.
  41668. // this can happen if user has maxBlocks=2, and blockSize=5 (thus 10 max rows in cache)
  41669. // but the screen is showing 20 rows, so at least 4 blocks are needed.
  41670. if (_this.isBlockCurrentlyDisplayed(block)) {
  41671. return;
  41672. }
  41673. // at this point, block is not needed, and no open nodes, so burn baby burn
  41674. _this.removeBlockFromCache(block);
  41675. }
  41676. });
  41677. };
  41678. RowNodeCache.prototype.isBlockCurrentlyDisplayed = function (block) {
  41679. var firstViewportRow = this.rowRenderer.getFirstVirtualRenderedRow();
  41680. var lastViewportRow = this.rowRenderer.getLastVirtualRenderedRow();
  41681. var firstRowIndex = block.getDisplayIndexStart();
  41682. var lastRowIndex = block.getDisplayIndexEnd() - 1;
  41683. // parent closed means the parent node is not expanded, thus these blocks are not visible
  41684. var parentClosed = firstRowIndex == null || lastRowIndex == null;
  41685. if (parentClosed) {
  41686. return false;
  41687. }
  41688. var blockBeforeViewport = firstRowIndex > lastViewportRow;
  41689. var blockAfterViewport = lastRowIndex < firstViewportRow;
  41690. var blockInsideViewport = !blockBeforeViewport && !blockAfterViewport;
  41691. return blockInsideViewport;
  41692. };
  41693. RowNodeCache.prototype.postCreateBlock = function (newBlock) {
  41694. newBlock.addEventListener(_rowNodeBlock__WEBPACK_IMPORTED_MODULE_1__["RowNodeBlock"].EVENT_LOAD_COMPLETE, this.onPageLoaded.bind(this));
  41695. this.setBlock(newBlock.getBlockNumber(), newBlock);
  41696. this.purgeBlocksIfNeeded(newBlock);
  41697. this.checkBlockToLoad();
  41698. };
  41699. RowNodeCache.prototype.removeBlockFromCache = function (blockToRemove) {
  41700. if (!blockToRemove) {
  41701. return;
  41702. }
  41703. this.destroyBlock(blockToRemove);
  41704. // we do not want to remove the 'loaded' event listener, as the
  41705. // concurrent loads count needs to be updated when the load is complete
  41706. // if the purged page is in loading state
  41707. };
  41708. // gets called after: 1) block loaded 2) block created 3) cache refresh
  41709. RowNodeCache.prototype.checkBlockToLoad = function () {
  41710. this.cacheParams.rowNodeBlockLoader.checkBlockToLoad();
  41711. };
  41712. RowNodeCache.prototype.checkVirtualRowCount = function (block, lastRow) {
  41713. // if client provided a last row, we always use it, as it could change between server calls
  41714. // if user deleted data and then called refresh on the grid.
  41715. if (typeof lastRow === 'number' && lastRow >= 0) {
  41716. this.virtualRowCount = lastRow;
  41717. this.maxRowFound = true;
  41718. this.onCacheUpdated();
  41719. }
  41720. else if (!this.maxRowFound) {
  41721. // otherwise, see if we need to add some virtual rows
  41722. var lastRowIndex = (block.getBlockNumber() + 1) * this.cacheParams.blockSize;
  41723. var lastRowIndexPlusOverflow = lastRowIndex + this.cacheParams.overflowSize;
  41724. if (this.virtualRowCount < lastRowIndexPlusOverflow) {
  41725. this.virtualRowCount = lastRowIndexPlusOverflow;
  41726. this.onCacheUpdated();
  41727. }
  41728. else if (this.cacheParams.dynamicRowHeight) {
  41729. // the only other time is if dynamic row height, as loading rows
  41730. // will change the height of the block, given the height of the rows
  41731. // is only known after the row is loaded.
  41732. this.onCacheUpdated();
  41733. }
  41734. }
  41735. };
  41736. RowNodeCache.prototype.setVirtualRowCount = function (rowCount, maxRowFound) {
  41737. this.virtualRowCount = rowCount;
  41738. // if undefined is passed, we do not set this value, if one of {true,false}
  41739. // is passed, we do set the value.
  41740. if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].exists(maxRowFound)) {
  41741. this.maxRowFound = maxRowFound;
  41742. }
  41743. // if we are still searching, then the row count must not end at the end
  41744. // of a particular page, otherwise the searching will not pop into the
  41745. // next page
  41746. if (!this.maxRowFound) {
  41747. if (this.virtualRowCount % this.cacheParams.blockSize === 0) {
  41748. this.virtualRowCount++;
  41749. }
  41750. }
  41751. this.onCacheUpdated();
  41752. };
  41753. RowNodeCache.prototype.forEachNodeDeep = function (callback, sequence) {
  41754. var _this = this;
  41755. if (sequence === void 0) { sequence = new _utils__WEBPACK_IMPORTED_MODULE_2__["NumberSequence"](); }
  41756. this.forEachBlockInOrder(function (block) {
  41757. block.forEachNodeDeep(callback, sequence, _this.virtualRowCount);
  41758. });
  41759. };
  41760. RowNodeCache.prototype.forEachBlockInOrder = function (callback) {
  41761. var ids = this.getBlockIdsSorted();
  41762. this.forEachBlockId(ids, callback);
  41763. };
  41764. RowNodeCache.prototype.forEachBlockInReverseOrder = function (callback) {
  41765. var ids = this.getBlockIdsSorted().reverse();
  41766. this.forEachBlockId(ids, callback);
  41767. };
  41768. RowNodeCache.prototype.forEachBlockId = function (ids, callback) {
  41769. var _this = this;
  41770. ids.forEach(function (id) {
  41771. var block = _this.blocks[id];
  41772. callback(block, id);
  41773. });
  41774. };
  41775. RowNodeCache.prototype.getBlockIdsSorted = function () {
  41776. // get all page id's as NUMBERS (not strings, as we need to sort as numbers) and in descending order
  41777. var numberComparator = function (a, b) { return a - b; }; // default comparator for array is string comparison
  41778. var blockIds = Object.keys(this.blocks).map(function (idStr) { return parseInt(idStr, 10); }).sort(numberComparator);
  41779. return blockIds;
  41780. };
  41781. RowNodeCache.prototype.getBlock = function (blockId) {
  41782. return this.blocks[blockId];
  41783. };
  41784. RowNodeCache.prototype.setBlock = function (id, block) {
  41785. this.blocks[id] = block;
  41786. this.blockCount++;
  41787. this.cacheParams.rowNodeBlockLoader.addBlock(block);
  41788. };
  41789. RowNodeCache.prototype.destroyBlock = function (block) {
  41790. delete this.blocks[block.getBlockNumber()];
  41791. this.destroyBean(block);
  41792. this.blockCount--;
  41793. this.cacheParams.rowNodeBlockLoader.removeBlock(block);
  41794. };
  41795. // gets called 1) row count changed 2) cache purged 3) items inserted
  41796. RowNodeCache.prototype.onCacheUpdated = function () {
  41797. if (this.isActive()) {
  41798. // if the virtualRowCount is shortened, then it's possible blocks exist that are no longer
  41799. // in the valid range. so we must remove these. this can happen if user explicitly sets
  41800. // the virtual row count, or the datasource returns a result and sets lastRow to something
  41801. // less than virtualRowCount (can happen if user scrolls down, server reduces dataset size).
  41802. this.destroyAllBlocksPastVirtualRowCount();
  41803. // this results in both row models (infinite and server side) firing ModelUpdated,
  41804. // however server side row model also updates the row indexes first
  41805. var event_1 = {
  41806. type: RowNodeCache.EVENT_CACHE_UPDATED
  41807. };
  41808. this.dispatchEvent(event_1);
  41809. }
  41810. };
  41811. RowNodeCache.prototype.destroyAllBlocksPastVirtualRowCount = function () {
  41812. var _this = this;
  41813. var blocksToDestroy = [];
  41814. this.forEachBlockInOrder(function (block, id) {
  41815. var startRow = id * _this.cacheParams.blockSize;
  41816. if (startRow >= _this.virtualRowCount) {
  41817. blocksToDestroy.push(block);
  41818. }
  41819. });
  41820. if (blocksToDestroy.length > 0) {
  41821. blocksToDestroy.forEach(function (block) { return _this.destroyBlock(block); });
  41822. }
  41823. };
  41824. RowNodeCache.prototype.purgeCache = function () {
  41825. var _this = this;
  41826. this.forEachBlockInOrder(function (block) { return _this.removeBlockFromCache(block); });
  41827. this.maxRowFound = false;
  41828. // if zero rows in the cache, we need to get the SSRM to start asking for rows again.
  41829. // otherwise if set to zero rows last time, and we don't update the row count, then after
  41830. // the purge there will still be zero rows, meaning the SRRM won't request any rows.
  41831. // to kick things off, at lest one row needs to be asked for.
  41832. if (this.virtualRowCount === 0) {
  41833. this.virtualRowCount = this.cacheParams.initialRowCount;
  41834. }
  41835. this.onCacheUpdated();
  41836. };
  41837. RowNodeCache.prototype.getRowNodesInRange = function (firstInRange, lastInRange) {
  41838. var _this = this;
  41839. var result = [];
  41840. var lastBlockId = -1;
  41841. var inActiveRange = false;
  41842. var numberSequence = new _utils__WEBPACK_IMPORTED_MODULE_2__["NumberSequence"]();
  41843. // if only one node passed, we start the selection at the top
  41844. if (_utils__WEBPACK_IMPORTED_MODULE_2__["_"].missing(firstInRange)) {
  41845. inActiveRange = true;
  41846. }
  41847. var foundGapInSelection = false;
  41848. this.forEachBlockInOrder(function (block, id) {
  41849. if (foundGapInSelection) {
  41850. return;
  41851. }
  41852. if (inActiveRange && (lastBlockId + 1 !== id)) {
  41853. foundGapInSelection = true;
  41854. return;
  41855. }
  41856. lastBlockId = id;
  41857. block.forEachNodeShallow(function (rowNode) {
  41858. var hitFirstOrLast = rowNode === firstInRange || rowNode === lastInRange;
  41859. if (inActiveRange || hitFirstOrLast) {
  41860. result.push(rowNode);
  41861. }
  41862. if (hitFirstOrLast) {
  41863. inActiveRange = !inActiveRange;
  41864. }
  41865. }, numberSequence, _this.virtualRowCount);
  41866. });
  41867. // inActiveRange will be still true if we never hit the second rowNode
  41868. var invalidRange = foundGapInSelection || inActiveRange;
  41869. return invalidRange ? [] : result;
  41870. };
  41871. RowNodeCache.EVENT_CACHE_UPDATED = 'cacheUpdated';
  41872. // this property says how many empty blocks should be in a cache, eg if scrolls down fast and creates 10
  41873. // blocks all for loading, the grid will only load the last 2 - it will assume the blocks the user quickly
  41874. // scrolled over are not needed to be loaded.
  41875. RowNodeCache.MAX_EMPTY_BLOCKS_TO_KEEP = 2;
  41876. __decorate([
  41877. Object(_context_context__WEBPACK_IMPORTED_MODULE_3__["Autowired"])('rowRenderer')
  41878. ], RowNodeCache.prototype, "rowRenderer", void 0);
  41879. __decorate([
  41880. _context_context__WEBPACK_IMPORTED_MODULE_3__["PreDestroy"]
  41881. ], RowNodeCache.prototype, "destroyAllBlocks", null);
  41882. __decorate([
  41883. _context_context__WEBPACK_IMPORTED_MODULE_3__["PostConstruct"]
  41884. ], RowNodeCache.prototype, "init", null);
  41885. return RowNodeCache;
  41886. }(_context_beanStub__WEBPACK_IMPORTED_MODULE_0__["BeanStub"]));
  41887. /***/ }),
  41888. /* 199 */
  41889. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  41890. "use strict";
  41891. __webpack_require__.r(__webpack_exports__);
  41892. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "VirtualList", function() { return VirtualList; });
  41893. /* harmony import */ var _context_context__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(37);
  41894. /* harmony import */ var _componentAnnotations__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(57);
  41895. /* harmony import */ var _managedFocusComponent__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(117);
  41896. /* harmony import */ var _constants__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(25);
  41897. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(7);
  41898. /**
  41899. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  41900. * @version v23.2.1
  41901. * @link http://www.ag-grid.com/
  41902. * @license MIT
  41903. */
  41904. var __extends = (undefined && undefined.__extends) || (function () {
  41905. var extendStatics = function (d, b) {
  41906. extendStatics = Object.setPrototypeOf ||
  41907. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  41908. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  41909. return extendStatics(d, b);
  41910. };
  41911. return function (d, b) {
  41912. extendStatics(d, b);
  41913. function __() { this.constructor = d; }
  41914. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  41915. };
  41916. })();
  41917. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  41918. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  41919. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  41920. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  41921. return c > 3 && r && Object.defineProperty(target, key, r), r;
  41922. };
  41923. var VirtualList = /** @class */ (function (_super) {
  41924. __extends(VirtualList, _super);
  41925. function VirtualList(cssIdentifier) {
  41926. if (cssIdentifier === void 0) { cssIdentifier = 'default'; }
  41927. var _this = _super.call(this, VirtualList.getTemplate(cssIdentifier)) || this;
  41928. _this.cssIdentifier = cssIdentifier;
  41929. _this.renderedRows = new Map();
  41930. _this.rowHeight = 20;
  41931. return _this;
  41932. }
  41933. VirtualList.prototype.postConstruct = function () {
  41934. this.addScrollListener();
  41935. this.rowHeight = this.getItemHeight();
  41936. _super.prototype.postConstruct.call(this);
  41937. };
  41938. VirtualList.prototype.isFocusableContainer = function () {
  41939. return true;
  41940. };
  41941. VirtualList.prototype.focusInnerElement = function (fromBottom) {
  41942. var rowCount = this.model.getRowCount();
  41943. this.focusRow(fromBottom ? rowCount - 1 : 0);
  41944. };
  41945. VirtualList.prototype.onFocusIn = function (e) {
  41946. _super.prototype.onFocusIn.call(this, e);
  41947. var target = e.target;
  41948. if (_utils__WEBPACK_IMPORTED_MODULE_4__["_"].containsClass(target, 'ag-virtual-list-item')) {
  41949. this.lastFocusedRow = parseInt(target.getAttribute('aria-rowindex'), 10) - 1;
  41950. }
  41951. };
  41952. VirtualList.prototype.onFocusOut = function (e) {
  41953. _super.prototype.onFocusOut.call(this, e);
  41954. if (!this.getFocusableElement().contains(e.relatedTarget)) {
  41955. this.lastFocusedRow = null;
  41956. }
  41957. };
  41958. VirtualList.prototype.handleKeyDown = function (e) {
  41959. switch (e.keyCode) {
  41960. case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_UP:
  41961. case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_DOWN:
  41962. case _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_TAB:
  41963. if (this.navigate(e.keyCode === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_UP ||
  41964. (e.keyCode === _constants__WEBPACK_IMPORTED_MODULE_3__["Constants"].KEY_TAB && e.shiftKey))) {
  41965. e.preventDefault();
  41966. }
  41967. break;
  41968. }
  41969. };
  41970. VirtualList.prototype.navigate = function (up) {
  41971. if (!_utils__WEBPACK_IMPORTED_MODULE_4__["_"].exists(this.lastFocusedRow)) {
  41972. return false;
  41973. }
  41974. var nextRow = this.lastFocusedRow + (up ? -1 : 1);
  41975. if (nextRow < 0 || nextRow >= this.model.getRowCount()) {
  41976. return false;
  41977. }
  41978. this.focusRow(nextRow);
  41979. return true;
  41980. };
  41981. VirtualList.prototype.getLastFocusedRow = function () {
  41982. return this.lastFocusedRow;
  41983. };
  41984. VirtualList.prototype.focusRow = function (rowNumber) {
  41985. var _this = this;
  41986. this.ensureIndexVisible(rowNumber);
  41987. window.setTimeout(function () {
  41988. var renderedRow = _this.renderedRows.get(rowNumber);
  41989. if (renderedRow) {
  41990. renderedRow.eDiv.focus();
  41991. }
  41992. }, 10);
  41993. };
  41994. VirtualList.prototype.getComponentAt = function (rowIndex) {
  41995. var comp = this.renderedRows.get(rowIndex);
  41996. return comp && comp.rowComponent;
  41997. };
  41998. VirtualList.getTemplate = function (cssIdentifier) {
  41999. return /* html */ "\n <div class=\"ag-virtual-list-viewport ag-" + cssIdentifier + "-virtual-list-viewport\">\n <div class=\"ag-virtual-list-container ag-" + cssIdentifier + "-virtual-list-container\" ref=\"eContainer\"></div>\n </div>";
  42000. };
  42001. VirtualList.prototype.getItemHeight = function () {
  42002. return this.gridOptionsWrapper.getListItemHeight();
  42003. };
  42004. VirtualList.prototype.ensureIndexVisible = function (index) {
  42005. var lastRow = this.model.getRowCount();
  42006. if (typeof index !== 'number' || index < 0 || index >= lastRow) {
  42007. console.warn('invalid row index for ensureIndexVisible: ' + index);
  42008. return;
  42009. }
  42010. var rowTopPixel = index * this.rowHeight;
  42011. var rowBottomPixel = rowTopPixel + this.rowHeight;
  42012. var eGui = this.getGui();
  42013. var viewportTopPixel = eGui.scrollTop;
  42014. var viewportHeight = eGui.offsetHeight;
  42015. var viewportBottomPixel = viewportTopPixel + viewportHeight;
  42016. var viewportScrolledPastRow = viewportTopPixel > rowTopPixel;
  42017. var viewportScrolledBeforeRow = viewportBottomPixel < rowBottomPixel;
  42018. if (viewportScrolledPastRow) {
  42019. // if row is before, scroll up with row at top
  42020. eGui.scrollTop = rowTopPixel;
  42021. }
  42022. else if (viewportScrolledBeforeRow) {
  42023. // if row is below, scroll down with row at bottom
  42024. var newScrollPosition = rowBottomPixel - viewportHeight;
  42025. eGui.scrollTop = newScrollPosition;
  42026. }
  42027. };
  42028. VirtualList.prototype.setComponentCreator = function (componentCreator) {
  42029. this.componentCreator = componentCreator;
  42030. };
  42031. VirtualList.prototype.getRowHeight = function () {
  42032. return this.rowHeight;
  42033. };
  42034. VirtualList.prototype.getScrollTop = function () {
  42035. return this.getGui().scrollTop;
  42036. };
  42037. VirtualList.prototype.setRowHeight = function (rowHeight) {
  42038. this.rowHeight = rowHeight;
  42039. this.refresh();
  42040. };
  42041. VirtualList.prototype.refresh = function () {
  42042. var _this = this;
  42043. if (this.model == null) {
  42044. return;
  42045. }
  42046. var rowCount = this.model.getRowCount();
  42047. this.eContainer.style.height = rowCount * this.rowHeight + "px";
  42048. this.eContainer.setAttribute('aria-rowcount', rowCount.toString());
  42049. // ensure height is applied before attempting to redraw rows
  42050. setTimeout(function () {
  42051. _this.clearVirtualRows();
  42052. _this.drawVirtualRows();
  42053. }, 0);
  42054. };
  42055. VirtualList.prototype.clearVirtualRows = function () {
  42056. var _this = this;
  42057. this.renderedRows.forEach(function (_, rowIndex) { return _this.removeRow(rowIndex); });
  42058. };
  42059. VirtualList.prototype.drawVirtualRows = function () {
  42060. var gui = this.getGui();
  42061. var topPixel = gui.scrollTop;
  42062. var bottomPixel = topPixel + gui.offsetHeight;
  42063. var firstRow = Math.floor(topPixel / this.rowHeight);
  42064. var lastRow = Math.floor(bottomPixel / this.rowHeight);
  42065. this.ensureRowsRendered(firstRow, lastRow);
  42066. };
  42067. VirtualList.prototype.ensureRowsRendered = function (start, finish) {
  42068. var _this = this;
  42069. // remove any rows that are no longer required
  42070. this.renderedRows.forEach(function (_, rowIndex) {
  42071. if ((rowIndex < start || rowIndex > finish) && rowIndex !== _this.lastFocusedRow) {
  42072. _this.removeRow(rowIndex);
  42073. }
  42074. });
  42075. // insert any required new rows
  42076. for (var rowIndex = start; rowIndex <= finish; rowIndex++) {
  42077. if (this.renderedRows.has(rowIndex)) {
  42078. continue;
  42079. }
  42080. // check this row actually exists (in case overflow buffer window exceeds real data)
  42081. if (rowIndex < this.model.getRowCount()) {
  42082. var value = this.model.getRow(rowIndex);
  42083. this.insertRow(value, rowIndex);
  42084. }
  42085. }
  42086. };
  42087. VirtualList.prototype.insertRow = function (value, rowIndex) {
  42088. var eDiv = document.createElement('div');
  42089. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(eDiv, 'ag-virtual-list-item');
  42090. _utils__WEBPACK_IMPORTED_MODULE_4__["_"].addCssClass(eDiv, "ag-" + this.cssIdentifier + "-virtual-list-item");
  42091. eDiv.setAttribute('aria-rowindex', (rowIndex + 1).toString());
  42092. eDiv.setAttribute('tabindex', '-1');
  42093. eDiv.style.height = this.rowHeight + "px";
  42094. eDiv.style.top = this.rowHeight * rowIndex + "px";
  42095. var rowComponent = this.componentCreator(value);
  42096. eDiv.appendChild(rowComponent.getGui());
  42097. this.eContainer.appendChild(eDiv);
  42098. this.renderedRows.set(rowIndex, { rowComponent: rowComponent, eDiv: eDiv });
  42099. };
  42100. VirtualList.prototype.removeRow = function (rowIndex) {
  42101. var component = this.renderedRows.get(rowIndex);
  42102. this.eContainer.removeChild(component.eDiv);
  42103. this.destroyBean(component.rowComponent);
  42104. this.renderedRows.delete(rowIndex);
  42105. };
  42106. VirtualList.prototype.addScrollListener = function () {
  42107. var _this = this;
  42108. this.addGuiEventListener('scroll', function () { return _this.drawVirtualRows(); });
  42109. };
  42110. VirtualList.prototype.setModel = function (model) {
  42111. this.model = model;
  42112. };
  42113. __decorate([
  42114. Object(_context_context__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  42115. ], VirtualList.prototype, "gridOptionsWrapper", void 0);
  42116. __decorate([
  42117. Object(_componentAnnotations__WEBPACK_IMPORTED_MODULE_1__["RefSelector"])('eContainer')
  42118. ], VirtualList.prototype, "eContainer", void 0);
  42119. return VirtualList;
  42120. }(_managedFocusComponent__WEBPACK_IMPORTED_MODULE_2__["ManagedFocusComponent"]));
  42121. /***/ }),
  42122. /* 200 */
  42123. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  42124. "use strict";
  42125. __webpack_require__.r(__webpack_exports__);
  42126. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "defaultGroupComparator", function() { return defaultGroupComparator; });
  42127. /* harmony import */ var _utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(7);
  42128. /**
  42129. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  42130. * @version v23.2.1
  42131. * @link http://www.ag-grid.com/
  42132. * @license MIT
  42133. */
  42134. function defaultGroupComparator(valueA, valueB, nodeA, nodeB, accentedCompare) {
  42135. if (accentedCompare === void 0) { accentedCompare = false; }
  42136. console.warn('ag-Grid: Since ag-grid 11.0.0 defaultGroupComparator is not necessary. You can remove this from your colDef');
  42137. var nodeAIsGroup = _utils__WEBPACK_IMPORTED_MODULE_0__["_"].exists(nodeA) && nodeA.group;
  42138. var nodeBIsGroup = _utils__WEBPACK_IMPORTED_MODULE_0__["_"].exists(nodeB) && nodeB.group;
  42139. var bothAreGroups = nodeAIsGroup && nodeBIsGroup;
  42140. var bothAreNormal = !nodeAIsGroup && !nodeBIsGroup;
  42141. if (bothAreGroups) {
  42142. return _utils__WEBPACK_IMPORTED_MODULE_0__["_"].defaultComparator(nodeA.key, nodeB.key, accentedCompare);
  42143. }
  42144. if (bothAreNormal) {
  42145. return _utils__WEBPACK_IMPORTED_MODULE_0__["_"].defaultComparator(valueA, valueB, accentedCompare);
  42146. }
  42147. if (nodeAIsGroup) {
  42148. return 1;
  42149. }
  42150. return -1;
  42151. }
  42152. /***/ }),
  42153. /* 201 */
  42154. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  42155. "use strict";
  42156. __webpack_require__.r(__webpack_exports__);
  42157. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BaseComponentWrapper", function() { return BaseComponentWrapper; });
  42158. /**
  42159. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  42160. * @version v23.2.1
  42161. * @link http://www.ag-grid.com/
  42162. * @license MIT
  42163. */
  42164. var BaseComponentWrapper = /** @class */ (function () {
  42165. function BaseComponentWrapper() {
  42166. }
  42167. BaseComponentWrapper.prototype.wrap = function (OriginalConstructor, mandatoryMethodList, optionalMethodList, componentType, componentName) {
  42168. var _this = this;
  42169. if (optionalMethodList === void 0) { optionalMethodList = []; }
  42170. var wrapper = this.createWrapper(OriginalConstructor, componentType, componentName);
  42171. mandatoryMethodList.forEach((function (methodName) {
  42172. _this.createMethod(wrapper, methodName, true);
  42173. }));
  42174. optionalMethodList.forEach((function (methodName) {
  42175. _this.createMethod(wrapper, methodName, false);
  42176. }));
  42177. return wrapper;
  42178. };
  42179. BaseComponentWrapper.prototype.createMethod = function (wrapper, methodName, mandatory) {
  42180. wrapper.addMethod(methodName, this.createMethodProxy(wrapper, methodName, mandatory));
  42181. };
  42182. BaseComponentWrapper.prototype.createMethodProxy = function (wrapper, methodName, mandatory) {
  42183. return function () {
  42184. if (wrapper.hasMethod(methodName)) {
  42185. return wrapper.callMethod(methodName, arguments);
  42186. }
  42187. if (mandatory) {
  42188. console.warn('ag-Grid: Framework component is missing the method ' + methodName + '()');
  42189. }
  42190. return null;
  42191. };
  42192. };
  42193. return BaseComponentWrapper;
  42194. }());
  42195. /***/ }),
  42196. /* 202 */
  42197. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  42198. "use strict";
  42199. __webpack_require__.r(__webpack_exports__);
  42200. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ChartType", function() { return ChartType; });
  42201. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "LegendPosition", function() { return LegendPosition; });
  42202. /**
  42203. * @ag-grid-community/core - Advanced Data Grid / Data Table supporting Javascript / React / AngularJS / Web Components
  42204. * @version v23.2.1
  42205. * @link http://www.ag-grid.com/
  42206. * @license MIT
  42207. */
  42208. var ChartType;
  42209. (function (ChartType) {
  42210. ChartType["GroupedColumn"] = "groupedColumn";
  42211. ChartType["StackedColumn"] = "stackedColumn";
  42212. ChartType["NormalizedColumn"] = "normalizedColumn";
  42213. ChartType["GroupedBar"] = "groupedBar";
  42214. ChartType["StackedBar"] = "stackedBar";
  42215. ChartType["NormalizedBar"] = "normalizedBar";
  42216. ChartType["Line"] = "line";
  42217. ChartType["Scatter"] = "scatter";
  42218. ChartType["Bubble"] = "bubble";
  42219. ChartType["Pie"] = "pie";
  42220. ChartType["Doughnut"] = "doughnut";
  42221. ChartType["Area"] = "area";
  42222. ChartType["StackedArea"] = "stackedArea";
  42223. ChartType["NormalizedArea"] = "normalizedArea";
  42224. ChartType["Histogram"] = "histogram";
  42225. })(ChartType || (ChartType = {}));
  42226. var LegendPosition;
  42227. (function (LegendPosition) {
  42228. LegendPosition["Top"] = "top";
  42229. LegendPosition["Right"] = "right";
  42230. LegendPosition["Bottom"] = "bottom";
  42231. LegendPosition["Left"] = "left";
  42232. })(LegendPosition || (LegendPosition = {}));
  42233. /***/ }),
  42234. /* 203 */
  42235. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  42236. "use strict";
  42237. __webpack_require__.r(__webpack_exports__);
  42238. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ClientSideRowModel", function() { return ClientSideRowModel; });
  42239. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
  42240. /* harmony import */ var _clientSideNodeManager__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(204);
  42241. var __extends = (undefined && undefined.__extends) || (function () {
  42242. var extendStatics = function (d, b) {
  42243. extendStatics = Object.setPrototypeOf ||
  42244. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  42245. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  42246. return extendStatics(d, b);
  42247. };
  42248. return function (d, b) {
  42249. extendStatics(d, b);
  42250. function __() { this.constructor = d; }
  42251. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  42252. };
  42253. })();
  42254. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  42255. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  42256. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  42257. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  42258. return c > 3 && r && Object.defineProperty(target, key, r), r;
  42259. };
  42260. var RecursionType;
  42261. (function (RecursionType) {
  42262. RecursionType[RecursionType["Normal"] = 0] = "Normal";
  42263. RecursionType[RecursionType["AfterFilter"] = 1] = "AfterFilter";
  42264. RecursionType[RecursionType["AfterFilterAndSort"] = 2] = "AfterFilterAndSort";
  42265. RecursionType[RecursionType["PivotNodes"] = 3] = "PivotNodes";
  42266. })(RecursionType || (RecursionType = {}));
  42267. var ClientSideRowModel = /** @class */ (function (_super) {
  42268. __extends(ClientSideRowModel, _super);
  42269. function ClientSideRowModel() {
  42270. return _super !== null && _super.apply(this, arguments) || this;
  42271. }
  42272. ClientSideRowModel.prototype.init = function () {
  42273. var refreshEverythingFunc = this.refreshModel.bind(this, { step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_EVERYTHING });
  42274. var refreshEverythingAfterColsChangedFunc = this.refreshModel.bind(this, { step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_EVERYTHING, afterColumnsChanged: true, keepRenderedRows: true });
  42275. this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_EVERYTHING_CHANGED, refreshEverythingAfterColsChangedFunc);
  42276. this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_ROW_GROUP_CHANGED, refreshEverythingFunc);
  42277. this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_VALUE_CHANGED, this.onValueChanged.bind(this));
  42278. this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_PIVOT_CHANGED, this.refreshModel.bind(this, { step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_PIVOT }));
  42279. this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_ROW_GROUP_OPENED, this.onRowGroupOpened.bind(this));
  42280. this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_FILTER_CHANGED, this.onFilterChanged.bind(this));
  42281. this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_SORT_CHANGED, this.onSortChanged.bind(this));
  42282. this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_PIVOT_MODE_CHANGED, refreshEverythingFunc);
  42283. var refreshMapListener = this.refreshModel.bind(this, {
  42284. step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_MAP,
  42285. keepRenderedRows: true,
  42286. animate: true
  42287. });
  42288. this.addManagedListener(this.gridOptionsWrapper, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GROUP_REMOVE_SINGLE_CHILDREN, refreshMapListener);
  42289. this.addManagedListener(this.gridOptionsWrapper, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["GridOptionsWrapper"].PROP_GROUP_REMOVE_LOWEST_SINGLE_CHILDREN, refreshMapListener);
  42290. this.rootNode = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNode"]();
  42291. this.nodeManager = new _clientSideNodeManager__WEBPACK_IMPORTED_MODULE_1__["ClientSideNodeManager"](this.rootNode, this.gridOptionsWrapper, this.getContext(), this.eventService, this.columnController, this.gridApi, this.columnApi, this.selectionController);
  42292. this.createBean(this.rootNode);
  42293. };
  42294. ClientSideRowModel.prototype.start = function () {
  42295. var rowData = this.gridOptionsWrapper.getRowData();
  42296. if (rowData) {
  42297. this.setRowData(rowData);
  42298. }
  42299. };
  42300. ClientSideRowModel.prototype.ensureRowHeightsValid = function (startPixel, endPixel, startLimitIndex, endLimitIndex) {
  42301. var atLeastOneChange;
  42302. var res = false;
  42303. // we do this multiple times as changing the row heights can also change the first and last rows,
  42304. // so the first pass can make lots of rows smaller, which means the second pass we end up changing
  42305. // more rows.
  42306. do {
  42307. atLeastOneChange = false;
  42308. var rowAtStartPixel = this.getRowIndexAtPixel(startPixel);
  42309. var rowAtEndPixel = this.getRowIndexAtPixel(endPixel);
  42310. // keep check to current page if doing pagination
  42311. var firstRow = Math.max(rowAtStartPixel, startLimitIndex);
  42312. var lastRow = Math.min(rowAtEndPixel, endLimitIndex);
  42313. for (var rowIndex = firstRow; rowIndex <= lastRow; rowIndex++) {
  42314. var rowNode = this.getRow(rowIndex);
  42315. if (rowNode.rowHeightEstimated) {
  42316. var rowHeight = this.gridOptionsWrapper.getRowHeightForNode(rowNode);
  42317. rowNode.setRowHeight(rowHeight.height);
  42318. atLeastOneChange = true;
  42319. res = true;
  42320. }
  42321. }
  42322. if (atLeastOneChange) {
  42323. this.setRowTops();
  42324. }
  42325. } while (atLeastOneChange);
  42326. return res;
  42327. };
  42328. ClientSideRowModel.prototype.setRowTops = function () {
  42329. var nextRowTop = 0;
  42330. for (var i = 0; i < this.rowsToDisplay.length; i++) {
  42331. // we don't estimate if doing fullHeight or autoHeight, as all rows get rendered all the time
  42332. // with these two layouts.
  42333. var allowEstimate = this.gridOptionsWrapper.getDomLayout() === _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].DOM_LAYOUT_NORMAL;
  42334. var rowNode = this.rowsToDisplay[i];
  42335. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(rowNode.rowHeight)) {
  42336. var rowHeight = this.gridOptionsWrapper.getRowHeightForNode(rowNode, allowEstimate);
  42337. rowNode.setRowHeight(rowHeight.height, rowHeight.estimated);
  42338. }
  42339. rowNode.setRowTop(nextRowTop);
  42340. rowNode.setRowIndex(i);
  42341. nextRowTop += rowNode.rowHeight;
  42342. }
  42343. };
  42344. ClientSideRowModel.prototype.resetRowTops = function (rowNode, changedPath) {
  42345. rowNode.clearRowTop();
  42346. if (rowNode.hasChildren()) {
  42347. if (rowNode.childrenAfterGroup) {
  42348. // if a changedPath is active, it means we are here because of a transaction update or
  42349. // a change detection. neither of these impacts the open/closed state of groups. so if
  42350. // a group is not open this time, it was not open last time. so we know all closed groups
  42351. // already have their top positions cleared. so there is no need to traverse all the way
  42352. // when changedPath is active and the rowNode is not expanded.
  42353. var skipChildren = changedPath.isActive() && !rowNode.expanded;
  42354. if (!skipChildren) {
  42355. for (var i = 0; i < rowNode.childrenAfterGroup.length; i++) {
  42356. this.resetRowTops(rowNode.childrenAfterGroup[i], changedPath);
  42357. }
  42358. }
  42359. }
  42360. if (rowNode.sibling) {
  42361. rowNode.sibling.clearRowTop();
  42362. }
  42363. }
  42364. if (rowNode.detailNode) {
  42365. rowNode.detailNode.clearRowTop();
  42366. }
  42367. };
  42368. // returns false if row was moved, otherwise true
  42369. ClientSideRowModel.prototype.ensureRowsAtPixel = function (rowNodes, pixel, increment) {
  42370. var _this = this;
  42371. if (increment === void 0) { increment = 0; }
  42372. var indexAtPixelNow = this.getRowIndexAtPixel(pixel);
  42373. var rowNodeAtPixelNow = this.getRow(indexAtPixelNow);
  42374. if (rowNodeAtPixelNow === rowNodes[0]) {
  42375. return false;
  42376. }
  42377. rowNodes.forEach(function (rowNode) {
  42378. _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].removeFromArray(_this.rootNode.allLeafChildren, rowNode);
  42379. });
  42380. rowNodes.forEach(function (rowNode, idx) {
  42381. _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].insertIntoArray(_this.rootNode.allLeafChildren, rowNode, indexAtPixelNow + increment + idx);
  42382. });
  42383. this.refreshModel({
  42384. step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_EVERYTHING,
  42385. keepRenderedRows: true,
  42386. animate: true,
  42387. keepEditingRows: true
  42388. });
  42389. return true;
  42390. };
  42391. ClientSideRowModel.prototype.highlightRowAtPixel = function (rowNode, pixel) {
  42392. var indexAtPixelNow = pixel != null ? this.getRowIndexAtPixel(pixel) : null;
  42393. var rowNodeAtPixelNow = indexAtPixelNow != null ? this.getRow(indexAtPixelNow) : null;
  42394. if (!rowNodeAtPixelNow || !rowNode || rowNodeAtPixelNow === rowNode || pixel == null) {
  42395. if (this.lastHighlightedRow) {
  42396. this.lastHighlightedRow.setHighlighted(null);
  42397. this.lastHighlightedRow = null;
  42398. }
  42399. return;
  42400. }
  42401. var highlight = this.getHighlightPosition(pixel, rowNodeAtPixelNow);
  42402. if (this.lastHighlightedRow && this.lastHighlightedRow !== rowNodeAtPixelNow) {
  42403. this.lastHighlightedRow.setHighlighted(null);
  42404. this.lastHighlightedRow = null;
  42405. }
  42406. rowNodeAtPixelNow.setHighlighted(highlight);
  42407. this.lastHighlightedRow = rowNodeAtPixelNow;
  42408. };
  42409. ClientSideRowModel.prototype.getHighlightPosition = function (pixel, rowNode) {
  42410. if (!rowNode) {
  42411. var index = this.getRowIndexAtPixel(pixel);
  42412. rowNode = this.getRow(index || 0);
  42413. if (!rowNode) {
  42414. return 'below';
  42415. }
  42416. }
  42417. var rowTop = rowNode.rowTop, rowHeight = rowNode.rowHeight;
  42418. return pixel - rowTop < rowHeight / 2 ? 'above' : 'below';
  42419. };
  42420. ClientSideRowModel.prototype.getLastHighlightedRowNode = function () {
  42421. return this.lastHighlightedRow;
  42422. };
  42423. ClientSideRowModel.prototype.isLastRowFound = function () {
  42424. return true;
  42425. };
  42426. ClientSideRowModel.prototype.getRowCount = function () {
  42427. if (this.rowsToDisplay) {
  42428. return this.rowsToDisplay.length;
  42429. }
  42430. return 0;
  42431. };
  42432. ClientSideRowModel.prototype.getTopLevelRowCount = function () {
  42433. var showingRootNode = this.rowsToDisplay && this.rowsToDisplay[0] === this.rootNode;
  42434. if (showingRootNode) {
  42435. return 1;
  42436. }
  42437. return this.rootNode.childrenAfterFilter ? this.rootNode.childrenAfterFilter.length : 0;
  42438. };
  42439. ClientSideRowModel.prototype.getTopLevelRowDisplayedIndex = function (topLevelIndex) {
  42440. var showingRootNode = this.rowsToDisplay && this.rowsToDisplay[0] === this.rootNode;
  42441. if (showingRootNode) {
  42442. return topLevelIndex;
  42443. }
  42444. var rowNode = this.rootNode.childrenAfterSort[topLevelIndex];
  42445. if (this.gridOptionsWrapper.isGroupHideOpenParents()) {
  42446. // if hideOpenParents, and this row open, then this row is now displayed at this index, first child is
  42447. while (rowNode.expanded && rowNode.childrenAfterSort && rowNode.childrenAfterSort.length > 0) {
  42448. rowNode = rowNode.childrenAfterSort[0];
  42449. }
  42450. }
  42451. return rowNode.rowIndex;
  42452. };
  42453. ClientSideRowModel.prototype.getRowBounds = function (index) {
  42454. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(this.rowsToDisplay)) {
  42455. return null;
  42456. }
  42457. var rowNode = this.rowsToDisplay[index];
  42458. if (rowNode) {
  42459. return {
  42460. rowTop: rowNode.rowTop,
  42461. rowHeight: rowNode.rowHeight
  42462. };
  42463. }
  42464. return null;
  42465. };
  42466. ClientSideRowModel.prototype.onRowGroupOpened = function () {
  42467. var animate = this.gridOptionsWrapper.isAnimateRows();
  42468. this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_MAP, keepRenderedRows: true, animate: animate });
  42469. };
  42470. ClientSideRowModel.prototype.onFilterChanged = function (event) {
  42471. if (event.afterDataChange) {
  42472. return;
  42473. }
  42474. var animate = this.gridOptionsWrapper.isAnimateRows();
  42475. this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_FILTER, keepRenderedRows: true, animate: animate });
  42476. };
  42477. ClientSideRowModel.prototype.onSortChanged = function () {
  42478. var animate = this.gridOptionsWrapper.isAnimateRows();
  42479. this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_SORT, keepRenderedRows: true, animate: animate, keepEditingRows: true });
  42480. };
  42481. ClientSideRowModel.prototype.getType = function () {
  42482. return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE;
  42483. };
  42484. ClientSideRowModel.prototype.onValueChanged = function () {
  42485. if (this.columnController.isPivotActive()) {
  42486. this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_PIVOT });
  42487. }
  42488. else {
  42489. this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_AGGREGATE });
  42490. }
  42491. };
  42492. ClientSideRowModel.prototype.createChangePath = function (rowNodeTransactions) {
  42493. // for updates, if the row is updated at all, then we re-calc all the values
  42494. // in that row. we could compare each value to each old value, however if we
  42495. // did this, we would be calling the valueService twice, once on the old value
  42496. // and once on the new value. so it's less valueGetter calls if we just assume
  42497. // each column is different. that way the changedPath is used so that only
  42498. // the impacted parent rows are recalculated, parents who's children have
  42499. // not changed are not impacted.
  42500. var noTransactions = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missingOrEmpty(rowNodeTransactions);
  42501. var changedPath = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ChangedPath"](false, this.rootNode);
  42502. if (noTransactions || this.gridOptionsWrapper.isTreeData()) {
  42503. changedPath.setInactive();
  42504. }
  42505. return changedPath;
  42506. };
  42507. ClientSideRowModel.prototype.refreshModel = function (params) {
  42508. // this goes through the pipeline of stages. what's in my head is similar
  42509. // to the diagram on this page:
  42510. // http://commons.apache.org/sandbox/commons-pipeline/pipeline_basics.html
  42511. // however we want to keep the results of each stage, hence we manually call
  42512. // each step rather than have them chain each other.
  42513. var _this = this;
  42514. // fallthrough in below switch is on purpose,
  42515. // eg if STEP_FILTER, then all steps below this
  42516. // step get done
  42517. // let start: number;
  42518. // console.log('======= start =======');
  42519. var changedPath = this.createChangePath(params.rowNodeTransactions);
  42520. switch (params.step) {
  42521. case _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_EVERYTHING:
  42522. // start = new Date().getTime();
  42523. this.doRowGrouping(params.groupState, params.rowNodeTransactions, params.rowNodeOrder, changedPath, params.afterColumnsChanged);
  42524. // console.log('rowGrouping = ' + (new Date().getTime() - start));
  42525. case _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_FILTER:
  42526. // start = new Date().getTime();
  42527. this.doFilter(changedPath);
  42528. // console.log('filter = ' + (new Date().getTime() - start));
  42529. case _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_PIVOT:
  42530. this.doPivot(changedPath);
  42531. case _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_AGGREGATE: // depends on agg fields
  42532. // start = new Date().getTime();
  42533. this.doAggregate(changedPath);
  42534. // console.log('aggregation = ' + (new Date().getTime() - start));
  42535. case _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_SORT:
  42536. // start = new Date().getTime();
  42537. this.doSort(params.rowNodeTransactions, changedPath);
  42538. // console.log('sort = ' + (new Date().getTime() - start));
  42539. case _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_MAP:
  42540. // start = new Date().getTime();
  42541. this.doRowsToDisplay();
  42542. // console.log('rowsToDisplay = ' + (new Date().getTime() - start));
  42543. }
  42544. // set all row tops to null, then set row tops on all visible rows. if we don't
  42545. // do this, then the algorithm below only sets row tops, old row tops from old rows
  42546. // will still lie around
  42547. this.resetRowTops(this.rootNode, changedPath);
  42548. this.setRowTops();
  42549. var event = {
  42550. type: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_MODEL_UPDATED,
  42551. api: this.gridApi,
  42552. columnApi: this.columnApi,
  42553. animate: params.animate,
  42554. keepRenderedRows: params.keepRenderedRows,
  42555. newData: params.newData,
  42556. newPage: false
  42557. };
  42558. this.eventService.dispatchEvent(event);
  42559. if (this.$scope) {
  42560. window.setTimeout(function () {
  42561. _this.$scope.$apply();
  42562. }, 0);
  42563. }
  42564. };
  42565. ClientSideRowModel.prototype.isEmpty = function () {
  42566. var rowsMissing;
  42567. var doingLegacyTreeData = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(this.gridOptionsWrapper.getNodeChildDetailsFunc());
  42568. if (doingLegacyTreeData) {
  42569. rowsMissing = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(this.rootNode.childrenAfterGroup) || this.rootNode.childrenAfterGroup.length === 0;
  42570. }
  42571. else {
  42572. rowsMissing = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(this.rootNode.allLeafChildren) || this.rootNode.allLeafChildren.length === 0;
  42573. }
  42574. var empty = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(this.rootNode) || rowsMissing || !this.columnController.isReady();
  42575. return empty;
  42576. };
  42577. ClientSideRowModel.prototype.isRowsToRender = function () {
  42578. return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(this.rowsToDisplay) && this.rowsToDisplay.length > 0;
  42579. };
  42580. ClientSideRowModel.prototype.getNodesInRangeForSelection = function (firstInRange, lastInRange) {
  42581. // if lastSelectedNode is missing, we start at the first row
  42582. var firstRowHit = !lastInRange;
  42583. var lastRowHit = false;
  42584. var lastRow;
  42585. var result = [];
  42586. var groupsSelectChildren = this.gridOptionsWrapper.isGroupSelectsChildren();
  42587. this.forEachNodeAfterFilterAndSort(function (rowNode) {
  42588. var lookingForLastRow = firstRowHit && !lastRowHit;
  42589. // check if we need to flip the select switch
  42590. if (!firstRowHit) {
  42591. if (rowNode === lastInRange || rowNode === firstInRange) {
  42592. firstRowHit = true;
  42593. }
  42594. }
  42595. var skipThisGroupNode = rowNode.group && groupsSelectChildren;
  42596. if (!skipThisGroupNode) {
  42597. var inRange = firstRowHit && !lastRowHit;
  42598. var childOfLastRow = rowNode.isParentOfNode(lastRow);
  42599. if (inRange || childOfLastRow) {
  42600. result.push(rowNode);
  42601. }
  42602. }
  42603. if (lookingForLastRow) {
  42604. if (rowNode === lastInRange || rowNode === firstInRange) {
  42605. lastRowHit = true;
  42606. if (rowNode === lastInRange) {
  42607. lastRow = lastInRange;
  42608. }
  42609. else {
  42610. lastRow = firstInRange;
  42611. }
  42612. }
  42613. }
  42614. });
  42615. return result;
  42616. };
  42617. ClientSideRowModel.prototype.setDatasource = function (datasource) {
  42618. console.error('ag-Grid: should never call setDatasource on clientSideRowController');
  42619. };
  42620. ClientSideRowModel.prototype.getTopLevelNodes = function () {
  42621. return this.rootNode ? this.rootNode.childrenAfterGroup : null;
  42622. };
  42623. ClientSideRowModel.prototype.getRootNode = function () {
  42624. return this.rootNode;
  42625. };
  42626. ClientSideRowModel.prototype.getRow = function (index) {
  42627. return this.rowsToDisplay[index];
  42628. };
  42629. ClientSideRowModel.prototype.isRowPresent = function (rowNode) {
  42630. return this.rowsToDisplay.indexOf(rowNode) >= 0;
  42631. };
  42632. ClientSideRowModel.prototype.getRowIndexAtPixel = function (pixelToMatch) {
  42633. if (this.isEmpty()) {
  42634. return -1;
  42635. }
  42636. // do binary search of tree
  42637. // http://oli.me.uk/2013/06/08/searching-javascript-arrays-with-a-binary-search/
  42638. var bottomPointer = 0;
  42639. var topPointer = this.rowsToDisplay.length - 1;
  42640. // quick check, if the pixel is out of bounds, then return last row
  42641. if (pixelToMatch <= 0) {
  42642. // if pixel is less than or equal zero, it's always the first row
  42643. return 0;
  42644. }
  42645. var lastNode = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].last(this.rowsToDisplay);
  42646. if (lastNode.rowTop <= pixelToMatch) {
  42647. return this.rowsToDisplay.length - 1;
  42648. }
  42649. while (true) {
  42650. var midPointer = Math.floor((bottomPointer + topPointer) / 2);
  42651. var currentRowNode = this.rowsToDisplay[midPointer];
  42652. if (this.isRowInPixel(currentRowNode, pixelToMatch)) {
  42653. return midPointer;
  42654. }
  42655. if (currentRowNode.rowTop < pixelToMatch) {
  42656. bottomPointer = midPointer + 1;
  42657. }
  42658. else if (currentRowNode.rowTop > pixelToMatch) {
  42659. topPointer = midPointer - 1;
  42660. }
  42661. }
  42662. };
  42663. ClientSideRowModel.prototype.isRowInPixel = function (rowNode, pixelToMatch) {
  42664. var topPixel = rowNode.rowTop;
  42665. var bottomPixel = rowNode.rowTop + rowNode.rowHeight;
  42666. var pixelInRow = topPixel <= pixelToMatch && bottomPixel > pixelToMatch;
  42667. return pixelInRow;
  42668. };
  42669. ClientSideRowModel.prototype.getCurrentPageHeight = function () {
  42670. if (this.rowsToDisplay && this.rowsToDisplay.length > 0) {
  42671. var lastRow = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].last(this.rowsToDisplay);
  42672. var lastPixel = lastRow.rowTop + lastRow.rowHeight;
  42673. return lastPixel;
  42674. }
  42675. return 0;
  42676. };
  42677. ClientSideRowModel.prototype.forEachLeafNode = function (callback) {
  42678. if (this.rootNode.allLeafChildren) {
  42679. this.rootNode.allLeafChildren.forEach(function (rowNode, index) { return callback(rowNode, index); });
  42680. }
  42681. };
  42682. ClientSideRowModel.prototype.forEachNode = function (callback) {
  42683. this.recursivelyWalkNodesAndCallback(this.rootNode.childrenAfterGroup, callback, RecursionType.Normal, 0);
  42684. };
  42685. ClientSideRowModel.prototype.forEachNodeAfterFilter = function (callback) {
  42686. this.recursivelyWalkNodesAndCallback(this.rootNode.childrenAfterFilter, callback, RecursionType.AfterFilter, 0);
  42687. };
  42688. ClientSideRowModel.prototype.forEachNodeAfterFilterAndSort = function (callback) {
  42689. this.recursivelyWalkNodesAndCallback(this.rootNode.childrenAfterSort, callback, RecursionType.AfterFilterAndSort, 0);
  42690. };
  42691. ClientSideRowModel.prototype.forEachPivotNode = function (callback) {
  42692. this.recursivelyWalkNodesAndCallback([this.rootNode], callback, RecursionType.PivotNodes, 0);
  42693. };
  42694. // iterates through each item in memory, and calls the callback function
  42695. // nodes - the rowNodes to traverse
  42696. // callback - the user provided callback
  42697. // recursion type - need this to know what child nodes to recurse, eg if looking at all nodes, or filtered notes etc
  42698. // index - works similar to the index in forEach in javascript's array function
  42699. ClientSideRowModel.prototype.recursivelyWalkNodesAndCallback = function (nodes, callback, recursionType, index) {
  42700. if (!nodes) {
  42701. return index;
  42702. }
  42703. for (var i = 0; i < nodes.length; i++) {
  42704. var node = nodes[i];
  42705. callback(node, index++);
  42706. // go to the next level if it is a group
  42707. if (node.hasChildren()) {
  42708. // depending on the recursion type, we pick a difference set of children
  42709. var nodeChildren = null;
  42710. switch (recursionType) {
  42711. case RecursionType.Normal:
  42712. nodeChildren = node.childrenAfterGroup;
  42713. break;
  42714. case RecursionType.AfterFilter:
  42715. nodeChildren = node.childrenAfterFilter;
  42716. break;
  42717. case RecursionType.AfterFilterAndSort:
  42718. nodeChildren = node.childrenAfterSort;
  42719. break;
  42720. case RecursionType.PivotNodes:
  42721. // for pivot, we don't go below leafGroup levels
  42722. nodeChildren = !node.leafGroup ? node.childrenAfterSort : null;
  42723. break;
  42724. }
  42725. if (nodeChildren) {
  42726. index = this.recursivelyWalkNodesAndCallback(nodeChildren, callback, recursionType, index);
  42727. }
  42728. }
  42729. }
  42730. return index;
  42731. };
  42732. // it's possible to recompute the aggregate without doing the other parts
  42733. // + gridApi.recomputeAggregates()
  42734. ClientSideRowModel.prototype.doAggregate = function (changedPath) {
  42735. if (this.aggregationStage) {
  42736. this.aggregationStage.execute({ rowNode: this.rootNode, changedPath: changedPath });
  42737. }
  42738. };
  42739. // + gridApi.expandAll()
  42740. // + gridApi.collapseAll()
  42741. ClientSideRowModel.prototype.expandOrCollapseAll = function (expand) {
  42742. var usingTreeData = this.gridOptionsWrapper.isTreeData();
  42743. if (this.rootNode) {
  42744. recursiveExpandOrCollapse(this.rootNode.childrenAfterGroup);
  42745. }
  42746. function recursiveExpandOrCollapse(rowNodes) {
  42747. if (!rowNodes) {
  42748. return;
  42749. }
  42750. rowNodes.forEach(function (rowNode) {
  42751. var shouldExpandOrCollapse = usingTreeData ? _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(rowNode.childrenAfterGroup) : rowNode.group;
  42752. if (shouldExpandOrCollapse) {
  42753. rowNode.expanded = expand;
  42754. recursiveExpandOrCollapse(rowNode.childrenAfterGroup);
  42755. }
  42756. });
  42757. }
  42758. this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_MAP });
  42759. var eventSource = expand ? 'expandAll' : 'collapseAll';
  42760. var event = {
  42761. api: this.gridApi,
  42762. columnApi: this.columnApi,
  42763. type: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_EXPAND_COLLAPSE_ALL,
  42764. source: eventSource
  42765. };
  42766. this.eventService.dispatchEvent(event);
  42767. };
  42768. ClientSideRowModel.prototype.doSort = function (rowNodeTransactions, changedPath) {
  42769. this.sortStage.execute({
  42770. rowNode: this.rootNode,
  42771. rowNodeTransactions: rowNodeTransactions,
  42772. changedPath: changedPath
  42773. });
  42774. };
  42775. ClientSideRowModel.prototype.doRowGrouping = function (groupState, rowNodeTransactions, rowNodeOrder, changedPath, afterColumnsChanged) {
  42776. // grouping is enterprise only, so if service missing, skip the step
  42777. var doingLegacyTreeData = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(this.gridOptionsWrapper.getNodeChildDetailsFunc());
  42778. if (doingLegacyTreeData) {
  42779. return;
  42780. }
  42781. if (this.groupStage) {
  42782. if (rowNodeTransactions) {
  42783. this.groupStage.execute({
  42784. rowNode: this.rootNode,
  42785. rowNodeTransactions: rowNodeTransactions,
  42786. rowNodeOrder: rowNodeOrder,
  42787. changedPath: changedPath
  42788. });
  42789. }
  42790. else {
  42791. // groups are about to get disposed, so need to deselect any that are selected
  42792. this.selectionController.removeGroupsFromSelection();
  42793. this.groupStage.execute({
  42794. rowNode: this.rootNode,
  42795. changedPath: changedPath,
  42796. afterColumnsChanged: afterColumnsChanged
  42797. });
  42798. // set open/closed state on groups
  42799. this.restoreGroupState(groupState);
  42800. }
  42801. if (this.gridOptionsWrapper.isGroupSelectsChildren()) {
  42802. this.selectionController.updateGroupsFromChildrenSelections(changedPath);
  42803. }
  42804. }
  42805. else {
  42806. this.rootNode.childrenAfterGroup = this.rootNode.allLeafChildren;
  42807. }
  42808. };
  42809. ClientSideRowModel.prototype.restoreGroupState = function (groupState) {
  42810. if (!groupState) {
  42811. return;
  42812. }
  42813. _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].traverseNodesWithKey(this.rootNode.childrenAfterGroup, function (node, key) {
  42814. // if the group was open last time, then open it this time. however
  42815. // if was not open last time, then don't touch the group, so the 'groupDefaultExpanded'
  42816. // setting will take effect.
  42817. if (typeof groupState[key] === 'boolean') {
  42818. node.expanded = groupState[key];
  42819. }
  42820. });
  42821. };
  42822. ClientSideRowModel.prototype.doFilter = function (changedPath) {
  42823. this.filterStage.execute({ rowNode: this.rootNode, changedPath: changedPath });
  42824. };
  42825. ClientSideRowModel.prototype.doPivot = function (changedPath) {
  42826. if (this.pivotStage) {
  42827. this.pivotStage.execute({ rowNode: this.rootNode, changedPath: changedPath });
  42828. }
  42829. };
  42830. ClientSideRowModel.prototype.getGroupState = function () {
  42831. if (!this.rootNode.childrenAfterGroup || !this.gridOptionsWrapper.isRememberGroupStateWhenNewData()) {
  42832. return null;
  42833. }
  42834. var result = {};
  42835. _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].traverseNodesWithKey(this.rootNode.childrenAfterGroup, function (node, key) { return result[key] = node.expanded; });
  42836. return result;
  42837. };
  42838. ClientSideRowModel.prototype.getCopyOfNodesMap = function () {
  42839. return this.nodeManager.getCopyOfNodesMap();
  42840. };
  42841. ClientSideRowModel.prototype.getRowNode = function (id) {
  42842. return this.nodeManager.getRowNode(id);
  42843. };
  42844. // rows: the rows to put into the model
  42845. ClientSideRowModel.prototype.setRowData = function (rowData) {
  42846. // no need to invalidate cache, as the cache is stored on the rowNode,
  42847. // so new rowNodes means the cache is wiped anyway.
  42848. // remember group state, so we can expand groups that should be expanded
  42849. var groupState = this.getGroupState();
  42850. this.nodeManager.setRowData(rowData);
  42851. // this event kicks off:
  42852. // - clears selection
  42853. // - updates filters
  42854. // - shows 'no rows' overlay if needed
  42855. var rowDataChangedEvent = {
  42856. type: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_ROW_DATA_CHANGED,
  42857. api: this.gridApi,
  42858. columnApi: this.columnApi
  42859. };
  42860. this.eventService.dispatchEvent(rowDataChangedEvent);
  42861. this.refreshModel({
  42862. step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_EVERYTHING,
  42863. groupState: groupState,
  42864. newData: true
  42865. });
  42866. };
  42867. ClientSideRowModel.prototype.batchUpdateRowData = function (rowDataTransaction, callback) {
  42868. var _this = this;
  42869. if (!this.rowDataTransactionBatch) {
  42870. this.rowDataTransactionBatch = [];
  42871. var waitMillis = this.gridOptionsWrapper.getAsyncTransactionWaitMillis();
  42872. window.setTimeout(function () {
  42873. _this.executeBatchUpdateRowData();
  42874. _this.rowDataTransactionBatch = null;
  42875. }, waitMillis);
  42876. }
  42877. this.rowDataTransactionBatch.push({ rowDataTransaction: rowDataTransaction, callback: callback });
  42878. };
  42879. ClientSideRowModel.prototype.executeBatchUpdateRowData = function () {
  42880. var _this = this;
  42881. this.valueCache.onDataChanged();
  42882. var callbackFuncsBound = [];
  42883. var rowNodeTrans = [];
  42884. if (this.rowDataTransactionBatch) {
  42885. this.rowDataTransactionBatch.forEach(function (tranItem) {
  42886. var rowNodeTran = _this.nodeManager.updateRowData(tranItem.rowDataTransaction, null);
  42887. rowNodeTrans.push(rowNodeTran);
  42888. if (tranItem.callback) {
  42889. callbackFuncsBound.push(tranItem.callback.bind(null, rowNodeTran));
  42890. }
  42891. });
  42892. }
  42893. this.commonUpdateRowData(rowNodeTrans);
  42894. // do callbacks in next VM turn so it's async
  42895. if (callbackFuncsBound.length > 0) {
  42896. window.setTimeout(function () {
  42897. callbackFuncsBound.forEach(function (func) { return func(); });
  42898. }, 0);
  42899. }
  42900. };
  42901. ClientSideRowModel.prototype.updateRowData = function (rowDataTran, rowNodeOrder) {
  42902. this.valueCache.onDataChanged();
  42903. var rowNodeTran = this.nodeManager.updateRowData(rowDataTran, rowNodeOrder);
  42904. this.commonUpdateRowData([rowNodeTran], rowNodeOrder);
  42905. return rowNodeTran;
  42906. };
  42907. // common to updateRowData and batchUpdateRowData
  42908. ClientSideRowModel.prototype.commonUpdateRowData = function (rowNodeTrans, rowNodeOrder) {
  42909. this.refreshModel({
  42910. step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_EVERYTHING,
  42911. rowNodeTransactions: rowNodeTrans,
  42912. rowNodeOrder: rowNodeOrder,
  42913. keepRenderedRows: true,
  42914. animate: true,
  42915. keepEditingRows: true
  42916. });
  42917. var event = {
  42918. type: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_ROW_DATA_UPDATED,
  42919. api: this.gridApi,
  42920. columnApi: this.columnApi
  42921. };
  42922. this.eventService.dispatchEvent(event);
  42923. };
  42924. ClientSideRowModel.prototype.doRowsToDisplay = function () {
  42925. this.rowsToDisplay = this.flattenStage.execute({ rowNode: this.rootNode });
  42926. };
  42927. ClientSideRowModel.prototype.onRowHeightChanged = function () {
  42928. this.refreshModel({ step: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].STEP_MAP, keepRenderedRows: true, keepEditingRows: true });
  42929. };
  42930. ClientSideRowModel.prototype.resetRowHeights = function () {
  42931. this.forEachNode(function (rowNode) {
  42932. rowNode.setRowHeight(null);
  42933. // forEachNode doesn't go through detail rows, so need to check
  42934. // for detail nodes explicitly.
  42935. if (rowNode.detailNode) {
  42936. rowNode.detailNode.setRowHeight(null);
  42937. }
  42938. });
  42939. this.onRowHeightChanged();
  42940. };
  42941. __decorate([
  42942. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  42943. ], ClientSideRowModel.prototype, "gridOptionsWrapper", void 0);
  42944. __decorate([
  42945. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController')
  42946. ], ClientSideRowModel.prototype, "columnController", void 0);
  42947. __decorate([
  42948. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager')
  42949. ], ClientSideRowModel.prototype, "filterManager", void 0);
  42950. __decorate([
  42951. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('$scope')
  42952. ], ClientSideRowModel.prototype, "$scope", void 0);
  42953. __decorate([
  42954. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('selectionController')
  42955. ], ClientSideRowModel.prototype, "selectionController", void 0);
  42956. __decorate([
  42957. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueService')
  42958. ], ClientSideRowModel.prototype, "valueService", void 0);
  42959. __decorate([
  42960. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueCache')
  42961. ], ClientSideRowModel.prototype, "valueCache", void 0);
  42962. __decorate([
  42963. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi')
  42964. ], ClientSideRowModel.prototype, "columnApi", void 0);
  42965. __decorate([
  42966. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi')
  42967. ], ClientSideRowModel.prototype, "gridApi", void 0);
  42968. __decorate([
  42969. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterStage')
  42970. ], ClientSideRowModel.prototype, "filterStage", void 0);
  42971. __decorate([
  42972. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('sortStage')
  42973. ], ClientSideRowModel.prototype, "sortStage", void 0);
  42974. __decorate([
  42975. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('flattenStage')
  42976. ], ClientSideRowModel.prototype, "flattenStage", void 0);
  42977. __decorate([
  42978. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Optional"])('groupStage')
  42979. ], ClientSideRowModel.prototype, "groupStage", void 0);
  42980. __decorate([
  42981. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Optional"])('aggregationStage')
  42982. ], ClientSideRowModel.prototype, "aggregationStage", void 0);
  42983. __decorate([
  42984. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Optional"])('pivotStage')
  42985. ], ClientSideRowModel.prototype, "pivotStage", void 0);
  42986. __decorate([
  42987. _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  42988. ], ClientSideRowModel.prototype, "init", null);
  42989. ClientSideRowModel = __decorate([
  42990. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])('rowModel')
  42991. ], ClientSideRowModel);
  42992. return ClientSideRowModel;
  42993. }(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["BeanStub"]));
  42994. /***/ }),
  42995. /* 204 */
  42996. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  42997. "use strict";
  42998. __webpack_require__.r(__webpack_exports__);
  42999. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ClientSideNodeManager", function() { return ClientSideNodeManager; });
  43000. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
  43001. var ClientSideNodeManager = /** @class */ (function () {
  43002. function ClientSideNodeManager(rootNode, gridOptionsWrapper, context, eventService, columnController, gridApi, columnApi, selectionController) {
  43003. this.nextId = 0;
  43004. // when user is provide the id's, we also keep a map of ids to row nodes for convenience
  43005. this.allNodesMap = {};
  43006. this.rootNode = rootNode;
  43007. this.gridOptionsWrapper = gridOptionsWrapper;
  43008. this.context = context;
  43009. this.eventService = eventService;
  43010. this.columnController = columnController;
  43011. this.gridApi = gridApi;
  43012. this.columnApi = columnApi;
  43013. this.selectionController = selectionController;
  43014. this.rootNode.group = true;
  43015. this.rootNode.level = -1;
  43016. this.rootNode.id = ClientSideNodeManager.ROOT_NODE_ID;
  43017. this.rootNode.allLeafChildren = [];
  43018. this.rootNode.childrenAfterGroup = [];
  43019. this.rootNode.childrenAfterSort = [];
  43020. this.rootNode.childrenAfterFilter = [];
  43021. // if we make this class a bean, then can annotate postConstruct
  43022. this.postConstruct();
  43023. }
  43024. // @PostConstruct - this is not a bean, so postConstruct called by constructor
  43025. ClientSideNodeManager.prototype.postConstruct = function () {
  43026. // func below doesn't have 'this' pointer, so need to pull out these bits
  43027. this.getNodeChildDetails = this.gridOptionsWrapper.getNodeChildDetailsFunc();
  43028. this.suppressParentsInRowNodes = this.gridOptionsWrapper.isSuppressParentsInRowNodes();
  43029. this.doesDataFlower = this.gridOptionsWrapper.getDoesDataFlowerFunc();
  43030. this.isRowMasterFunc = this.gridOptionsWrapper.getIsRowMasterFunc();
  43031. this.doingTreeData = this.gridOptionsWrapper.isTreeData();
  43032. this.doingLegacyTreeData = !this.doingTreeData && _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(this.getNodeChildDetails);
  43033. this.doingMasterDetail = this.gridOptionsWrapper.isMasterDetail();
  43034. if (this.getNodeChildDetails) {
  43035. console.warn("ag-Grid: the callback nodeChildDetailsFunc() is now deprecated. The new way of doing\n tree data in ag-Grid was introduced in v14 (released November 2017). In the next\n major release of ag-Grid we will be dropping support for the old version of\n tree data. If you are reading this message, please go to the docs to see how\n to implement Tree Data without using nodeChildDetailsFunc().");
  43036. }
  43037. };
  43038. ClientSideNodeManager.prototype.getCopyOfNodesMap = function () {
  43039. var result = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].cloneObject(this.allNodesMap);
  43040. return result;
  43041. };
  43042. ClientSideNodeManager.prototype.getRowNode = function (id) {
  43043. return this.allNodesMap[id];
  43044. };
  43045. ClientSideNodeManager.prototype.setRowData = function (rowData) {
  43046. this.rootNode.childrenAfterFilter = null;
  43047. this.rootNode.childrenAfterGroup = null;
  43048. this.rootNode.childrenAfterSort = null;
  43049. this.rootNode.childrenMapped = null;
  43050. this.nextId = 0;
  43051. this.allNodesMap = {};
  43052. if (!rowData) {
  43053. this.rootNode.allLeafChildren = [];
  43054. this.rootNode.childrenAfterGroup = [];
  43055. return;
  43056. }
  43057. // kick off recursion
  43058. // we add rootNode as the parent, however if using ag-grid-enterprise, the grouping stage
  43059. // sets the parent node on each row (even if we are not grouping). so setting parent node
  43060. // here is for benefit of ag-grid-community users
  43061. var result = this.recursiveFunction(rowData, this.rootNode, ClientSideNodeManager.TOP_LEVEL);
  43062. if (this.doingLegacyTreeData) {
  43063. this.rootNode.childrenAfterGroup = result;
  43064. this.setLeafChildren(this.rootNode);
  43065. }
  43066. else {
  43067. this.rootNode.allLeafChildren = result;
  43068. }
  43069. };
  43070. ClientSideNodeManager.prototype.updateRowData = function (rowDataTran, rowNodeOrder) {
  43071. if (this.isLegacyTreeData()) {
  43072. return null;
  43073. }
  43074. var rowNodeTransaction = {
  43075. remove: [],
  43076. update: [],
  43077. add: []
  43078. };
  43079. var nodesToUnselect = [];
  43080. this.executeAdd(rowDataTran, rowNodeTransaction);
  43081. this.executeRemove(rowDataTran, rowNodeTransaction, nodesToUnselect);
  43082. this.executeUpdate(rowDataTran, rowNodeTransaction, nodesToUnselect);
  43083. this.updateSelection(nodesToUnselect);
  43084. if (rowNodeOrder) {
  43085. _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].sortRowNodesByOrder(this.rootNode.allLeafChildren, rowNodeOrder);
  43086. }
  43087. return rowNodeTransaction;
  43088. };
  43089. ClientSideNodeManager.prototype.updateSelection = function (nodesToUnselect) {
  43090. var selectionChanged = nodesToUnselect.length > 0;
  43091. if (selectionChanged) {
  43092. nodesToUnselect.forEach(function (rowNode) {
  43093. rowNode.setSelected(false, false, true);
  43094. });
  43095. }
  43096. // we do this regardless of nodes to unselect or not, as it's possible
  43097. // a new node was inserted, so a parent that was previously selected (as all
  43098. // children were selected) should not be tri-state (as new one unselected against
  43099. // all other selected children).
  43100. this.selectionController.updateGroupsFromChildrenSelections();
  43101. if (selectionChanged) {
  43102. var event_1 = {
  43103. type: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_SELECTION_CHANGED,
  43104. api: this.gridApi,
  43105. columnApi: this.columnApi
  43106. };
  43107. this.eventService.dispatchEvent(event_1);
  43108. }
  43109. };
  43110. ClientSideNodeManager.prototype.executeAdd = function (rowDataTran, rowNodeTransaction) {
  43111. var _this = this;
  43112. var add = rowDataTran.add, addIndex = rowDataTran.addIndex;
  43113. if (!add) {
  43114. return;
  43115. }
  43116. var useIndex = typeof addIndex === 'number' && addIndex >= 0;
  43117. if (useIndex) {
  43118. // items get inserted in reverse order for index insertion
  43119. add.reverse().forEach(function (item) {
  43120. var newRowNode = _this.addRowNode(item, addIndex);
  43121. rowNodeTransaction.add.push(newRowNode);
  43122. });
  43123. }
  43124. else {
  43125. add.forEach(function (item) {
  43126. var newRowNode = _this.addRowNode(item);
  43127. rowNodeTransaction.add.push(newRowNode);
  43128. });
  43129. }
  43130. };
  43131. ClientSideNodeManager.prototype.executeRemove = function (rowDataTran, rowNodeTransaction, nodesToUnselect) {
  43132. var _this = this;
  43133. var remove = rowDataTran.remove;
  43134. if (!remove) {
  43135. return;
  43136. }
  43137. var rowIdsRemoved = {};
  43138. remove.forEach(function (item) {
  43139. var rowNode = _this.lookupRowNode(item);
  43140. if (!rowNode) {
  43141. return;
  43142. }
  43143. // do delete - setting 'suppressFinishActions = true' to ensure EVENT_SELECTION_CHANGED is not raised for
  43144. // each row node updated, instead it is raised once by the calling code if any selected nodes exist.
  43145. if (rowNode.isSelected()) {
  43146. nodesToUnselect.push(rowNode);
  43147. }
  43148. // so row renderer knows to fade row out (and not reposition it)
  43149. rowNode.clearRowTop();
  43150. // NOTE: were we could remove from allLeaveChildren, however _.removeFromArray() is expensive, especially
  43151. // if called multiple times (eg deleting lots of rows) and if allLeafChildren is a large list
  43152. rowIdsRemoved[rowNode.id] = true;
  43153. // _.removeFromArray(this.rootNode.allLeafChildren, rowNode);
  43154. delete _this.allNodesMap[rowNode.id];
  43155. rowNodeTransaction.remove.push(rowNode);
  43156. });
  43157. this.rootNode.allLeafChildren = this.rootNode.allLeafChildren.filter(function (rowNode) { return !rowIdsRemoved[rowNode.id]; });
  43158. };
  43159. ClientSideNodeManager.prototype.executeUpdate = function (rowDataTran, rowNodeTransaction, nodesToUnselect) {
  43160. var _this = this;
  43161. var update = rowDataTran.update;
  43162. if (!update) {
  43163. return;
  43164. }
  43165. update.forEach(function (item) {
  43166. var rowNode = _this.lookupRowNode(item);
  43167. if (!rowNode) {
  43168. return;
  43169. }
  43170. rowNode.updateData(item);
  43171. if (!rowNode.selectable && rowNode.isSelected()) {
  43172. nodesToUnselect.push(rowNode);
  43173. }
  43174. _this.setMasterForRow(rowNode, item, ClientSideNodeManager.TOP_LEVEL, false);
  43175. rowNodeTransaction.update.push(rowNode);
  43176. });
  43177. };
  43178. ClientSideNodeManager.prototype.addRowNode = function (data, index) {
  43179. var newNode = this.createNode(data, this.rootNode, ClientSideNodeManager.TOP_LEVEL);
  43180. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(index)) {
  43181. _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].insertIntoArray(this.rootNode.allLeafChildren, newNode, index);
  43182. }
  43183. else {
  43184. this.rootNode.allLeafChildren.push(newNode);
  43185. }
  43186. return newNode;
  43187. };
  43188. ClientSideNodeManager.prototype.lookupRowNode = function (data) {
  43189. var rowNodeIdFunc = this.gridOptionsWrapper.getRowNodeIdFunc();
  43190. var rowNode;
  43191. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(rowNodeIdFunc)) {
  43192. // find rowNode using id
  43193. var id = rowNodeIdFunc(data);
  43194. rowNode = this.allNodesMap[id];
  43195. if (!rowNode) {
  43196. console.error("ag-Grid: could not find row id=" + id + ", data item was not found for this id");
  43197. return null;
  43198. }
  43199. }
  43200. else {
  43201. // find rowNode using object references
  43202. rowNode = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].find(this.rootNode.allLeafChildren, function (rowNode) { return rowNode.data === data; });
  43203. if (!rowNode) {
  43204. console.error("ag-Grid: could not find data item as object was not found", data);
  43205. return null;
  43206. }
  43207. }
  43208. return rowNode;
  43209. };
  43210. ClientSideNodeManager.prototype.recursiveFunction = function (rowData, parent, level) {
  43211. var _this = this;
  43212. // make sure the rowData is an array and not a string of json - this was a commonly reported problem on the forum
  43213. if (typeof rowData === 'string') {
  43214. console.warn('ag-Grid: rowData must be an array, however you passed in a string. If you are loading JSON, make sure you convert the JSON string to JavaScript objects first');
  43215. return;
  43216. }
  43217. var rowNodes = [];
  43218. rowData.forEach(function (dataItem) {
  43219. var node = _this.createNode(dataItem, parent, level);
  43220. rowNodes.push(node);
  43221. });
  43222. return rowNodes;
  43223. };
  43224. ClientSideNodeManager.prototype.createNode = function (dataItem, parent, level) {
  43225. var node = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNode"]();
  43226. this.context.createBean(node);
  43227. var nodeChildDetails = this.doingLegacyTreeData ? this.getNodeChildDetails(dataItem) : null;
  43228. if (nodeChildDetails && nodeChildDetails.group) {
  43229. node.group = true;
  43230. node.childrenAfterGroup = this.recursiveFunction(nodeChildDetails.children, node, level + 1);
  43231. node.expanded = nodeChildDetails.expanded === true;
  43232. node.field = nodeChildDetails.field;
  43233. node.key = nodeChildDetails.key;
  43234. // pull out all the leaf children and add to our node
  43235. this.setLeafChildren(node);
  43236. }
  43237. else {
  43238. node.group = false;
  43239. this.setMasterForRow(node, dataItem, level, true);
  43240. }
  43241. // support for backwards compatibility, canFlow is now called 'master'
  43242. /** @deprecated is now 'master' */
  43243. node.canFlower = node.master;
  43244. if (parent && !this.suppressParentsInRowNodes) {
  43245. node.parent = parent;
  43246. }
  43247. node.level = level;
  43248. node.setDataAndId(dataItem, this.nextId.toString());
  43249. if (this.allNodesMap[node.id]) {
  43250. console.warn("ag-grid: duplicate node id '" + node.id + "' detected from getRowNodeId callback, this could cause issues in your grid.");
  43251. }
  43252. this.allNodesMap[node.id] = node;
  43253. this.nextId++;
  43254. return node;
  43255. };
  43256. ClientSideNodeManager.prototype.setMasterForRow = function (rowNode, data, level, setExpanded) {
  43257. if (this.doingTreeData) {
  43258. rowNode.setMaster(false);
  43259. if (setExpanded) {
  43260. rowNode.expanded = false;
  43261. }
  43262. }
  43263. else {
  43264. // this is the default, for when doing grid data
  43265. if (this.doesDataFlower) {
  43266. rowNode.setMaster(this.doesDataFlower(data));
  43267. }
  43268. else if (this.doingMasterDetail) {
  43269. // if we are doing master detail, then the
  43270. // default is that everything can be a Master Row.
  43271. if (this.isRowMasterFunc) {
  43272. rowNode.setMaster(this.isRowMasterFunc(data));
  43273. }
  43274. else {
  43275. rowNode.setMaster(true);
  43276. }
  43277. }
  43278. else {
  43279. rowNode.setMaster(false);
  43280. }
  43281. if (setExpanded) {
  43282. var rowGroupColumns = this.columnController.getRowGroupColumns();
  43283. var numRowGroupColumns = rowGroupColumns ? rowGroupColumns.length : 0;
  43284. // need to take row group into account when determining level
  43285. var masterRowLevel = level + numRowGroupColumns;
  43286. rowNode.expanded = rowNode.master ? this.isExpanded(masterRowLevel) : false;
  43287. }
  43288. }
  43289. };
  43290. ClientSideNodeManager.prototype.isExpanded = function (level) {
  43291. var expandByDefault = this.gridOptionsWrapper.getGroupDefaultExpanded();
  43292. if (expandByDefault === -1) {
  43293. return true;
  43294. }
  43295. else {
  43296. return level < expandByDefault;
  43297. }
  43298. };
  43299. // this is only used for doing legacy tree data
  43300. ClientSideNodeManager.prototype.setLeafChildren = function (node) {
  43301. node.allLeafChildren = [];
  43302. if (node.childrenAfterGroup) {
  43303. node.childrenAfterGroup.forEach(function (childAfterGroup) {
  43304. if (childAfterGroup.group) {
  43305. if (childAfterGroup.allLeafChildren) {
  43306. childAfterGroup.allLeafChildren.forEach(function (leafChild) { return node.allLeafChildren.push(leafChild); });
  43307. }
  43308. }
  43309. else {
  43310. node.allLeafChildren.push(childAfterGroup);
  43311. }
  43312. });
  43313. }
  43314. };
  43315. ClientSideNodeManager.prototype.isLegacyTreeData = function () {
  43316. var rowsAlreadyGrouped = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(this.gridOptionsWrapper.getNodeChildDetailsFunc());
  43317. if (rowsAlreadyGrouped) {
  43318. console.warn('ag-Grid: adding and removing rows is not supported when using nodeChildDetailsFunc, ie it is not ' +
  43319. 'supported for legacy tree data. Please see the docs on the new preferred way of providing tree data that works with delta updates.');
  43320. return true;
  43321. }
  43322. else {
  43323. return false;
  43324. }
  43325. };
  43326. ClientSideNodeManager.TOP_LEVEL = 0;
  43327. ClientSideNodeManager.ROOT_NODE_ID = 'ROOT_NODE_ID';
  43328. return ClientSideNodeManager;
  43329. }());
  43330. /***/ }),
  43331. /* 205 */
  43332. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  43333. "use strict";
  43334. __webpack_require__.r(__webpack_exports__);
  43335. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FilterStage", function() { return FilterStage; });
  43336. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
  43337. var __extends = (undefined && undefined.__extends) || (function () {
  43338. var extendStatics = function (d, b) {
  43339. extendStatics = Object.setPrototypeOf ||
  43340. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  43341. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  43342. return extendStatics(d, b);
  43343. };
  43344. return function (d, b) {
  43345. extendStatics(d, b);
  43346. function __() { this.constructor = d; }
  43347. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  43348. };
  43349. })();
  43350. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  43351. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  43352. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  43353. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  43354. return c > 3 && r && Object.defineProperty(target, key, r), r;
  43355. };
  43356. var FilterStage = /** @class */ (function (_super) {
  43357. __extends(FilterStage, _super);
  43358. function FilterStage() {
  43359. return _super !== null && _super.apply(this, arguments) || this;
  43360. }
  43361. FilterStage.prototype.execute = function (params) {
  43362. var rowNode = params.rowNode, changedPath = params.changedPath;
  43363. this.filterService.filter(changedPath);
  43364. this.selectableService.updateSelectableAfterFiltering(rowNode);
  43365. };
  43366. __decorate([
  43367. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  43368. ], FilterStage.prototype, "gridOptionsWrapper", void 0);
  43369. __decorate([
  43370. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('selectableService')
  43371. ], FilterStage.prototype, "selectableService", void 0);
  43372. __decorate([
  43373. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterService')
  43374. ], FilterStage.prototype, "filterService", void 0);
  43375. FilterStage = __decorate([
  43376. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])('filterStage')
  43377. ], FilterStage);
  43378. return FilterStage;
  43379. }(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["BeanStub"]));
  43380. /***/ }),
  43381. /* 206 */
  43382. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  43383. "use strict";
  43384. __webpack_require__.r(__webpack_exports__);
  43385. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SortStage", function() { return SortStage; });
  43386. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
  43387. var __extends = (undefined && undefined.__extends) || (function () {
  43388. var extendStatics = function (d, b) {
  43389. extendStatics = Object.setPrototypeOf ||
  43390. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  43391. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  43392. return extendStatics(d, b);
  43393. };
  43394. return function (d, b) {
  43395. extendStatics(d, b);
  43396. function __() { this.constructor = d; }
  43397. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  43398. };
  43399. })();
  43400. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  43401. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  43402. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  43403. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  43404. return c > 3 && r && Object.defineProperty(target, key, r), r;
  43405. };
  43406. var SortStage = /** @class */ (function (_super) {
  43407. __extends(SortStage, _super);
  43408. function SortStage() {
  43409. return _super !== null && _super.apply(this, arguments) || this;
  43410. }
  43411. SortStage.prototype.execute = function (params) {
  43412. var sortOptions = this.sortController.getSortForRowController();
  43413. var sortActive = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(sortOptions) && sortOptions.length > 0;
  43414. var deltaSort = sortActive
  43415. && _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(params.rowNodeTransactions)
  43416. // in time we can remove this check, so that delta sort is always
  43417. // on if transactions are present. it's off for now so that we can
  43418. // selectively turn it on and test it with some select users before
  43419. // rolling out to everyone.
  43420. && this.gridOptionsWrapper.isDeltaSort();
  43421. // we only need dirty nodes if doing delta sort
  43422. var dirtyLeafNodes = deltaSort ? this.calculateDirtyNodes(params.rowNodeTransactions) : null;
  43423. var valueColumns = this.columnController.getValueColumns();
  43424. var noAggregations = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missingOrEmpty(valueColumns);
  43425. this.sortService.sort(sortOptions, sortActive, deltaSort, dirtyLeafNodes, params.changedPath, noAggregations);
  43426. };
  43427. SortStage.prototype.calculateDirtyNodes = function (rowNodeTransactions) {
  43428. var dirtyNodes = {};
  43429. var addNodesFunc = function (rowNodes) {
  43430. if (rowNodes) {
  43431. rowNodes.forEach(function (rowNode) { return dirtyNodes[rowNode.id] = true; });
  43432. }
  43433. };
  43434. // all leaf level nodes in the transaction were impacted
  43435. rowNodeTransactions.forEach(function (tran) {
  43436. addNodesFunc(tran.add);
  43437. addNodesFunc(tran.update);
  43438. addNodesFunc(tran.remove);
  43439. });
  43440. return dirtyNodes;
  43441. };
  43442. __decorate([
  43443. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  43444. ], SortStage.prototype, "gridOptionsWrapper", void 0);
  43445. __decorate([
  43446. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('sortService')
  43447. ], SortStage.prototype, "sortService", void 0);
  43448. __decorate([
  43449. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('sortController')
  43450. ], SortStage.prototype, "sortController", void 0);
  43451. __decorate([
  43452. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController')
  43453. ], SortStage.prototype, "columnController", void 0);
  43454. SortStage = __decorate([
  43455. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])('sortStage')
  43456. ], SortStage);
  43457. return SortStage;
  43458. }(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["BeanStub"]));
  43459. /***/ }),
  43460. /* 207 */
  43461. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  43462. "use strict";
  43463. __webpack_require__.r(__webpack_exports__);
  43464. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FlattenStage", function() { return FlattenStage; });
  43465. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
  43466. var __extends = (undefined && undefined.__extends) || (function () {
  43467. var extendStatics = function (d, b) {
  43468. extendStatics = Object.setPrototypeOf ||
  43469. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  43470. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  43471. return extendStatics(d, b);
  43472. };
  43473. return function (d, b) {
  43474. extendStatics(d, b);
  43475. function __() { this.constructor = d; }
  43476. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  43477. };
  43478. })();
  43479. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  43480. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  43481. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  43482. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  43483. return c > 3 && r && Object.defineProperty(target, key, r), r;
  43484. };
  43485. var FlattenStage = /** @class */ (function (_super) {
  43486. __extends(FlattenStage, _super);
  43487. function FlattenStage() {
  43488. return _super !== null && _super.apply(this, arguments) || this;
  43489. }
  43490. FlattenStage.prototype.execute = function (params) {
  43491. var rootNode = params.rowNode;
  43492. // even if not doing grouping, we do the mapping, as the client might
  43493. // of passed in data that already has a grouping in it somewhere
  43494. var result = [];
  43495. // putting value into a wrapper so it's passed by reference
  43496. var nextRowTop = { value: 0 };
  43497. var skipLeafNodes = this.columnController.isPivotMode();
  43498. // if we are reducing, and not grouping, then we want to show the root node, as that
  43499. // is where the pivot values are
  43500. var showRootNode = skipLeafNodes && rootNode.leafGroup;
  43501. var topList = showRootNode ? [rootNode] : rootNode.childrenAfterSort;
  43502. this.recursivelyAddToRowsToDisplay(topList, result, nextRowTop, skipLeafNodes, 0);
  43503. // we do not want the footer total if the gris is empty
  43504. var atLeastOneRowPresent = result.length > 0;
  43505. var includeGroupTotalFooter = !showRootNode
  43506. // don't show total footer when showRootNode is true (i.e. in pivot mode and no groups)
  43507. && atLeastOneRowPresent
  43508. && this.gridOptionsWrapper.isGroupIncludeTotalFooter();
  43509. if (includeGroupTotalFooter) {
  43510. this.ensureFooterNodeExists(rootNode);
  43511. this.addRowNodeToRowsToDisplay(rootNode.sibling, result, nextRowTop, 0);
  43512. }
  43513. return result;
  43514. };
  43515. FlattenStage.prototype.recursivelyAddToRowsToDisplay = function (rowsToFlatten, result, nextRowTop, skipLeafNodes, uiLevel) {
  43516. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missingOrEmpty(rowsToFlatten)) {
  43517. return;
  43518. }
  43519. var groupSuppressRow = this.gridOptionsWrapper.isGroupSuppressRow();
  43520. var hideOpenParents = this.gridOptionsWrapper.isGroupHideOpenParents();
  43521. // these two are mutually exclusive, so if first set, we don't set the second
  43522. var groupRemoveSingleChildren = this.gridOptionsWrapper.isGroupRemoveSingleChildren();
  43523. var groupRemoveLowestSingleChildren = !groupRemoveSingleChildren && this.gridOptionsWrapper.isGroupRemoveLowestSingleChildren();
  43524. for (var i = 0; i < rowsToFlatten.length; i++) {
  43525. var rowNode = rowsToFlatten[i];
  43526. // check all these cases, for working out if this row should be included in the final mapped list
  43527. var isParent = rowNode.hasChildren();
  43528. var isGroupSuppressedNode = groupSuppressRow && isParent;
  43529. var isSkippedLeafNode = skipLeafNodes && !isParent;
  43530. var isRemovedSingleChildrenGroup = groupRemoveSingleChildren &&
  43531. isParent &&
  43532. rowNode.childrenAfterGroup.length === 1;
  43533. var isRemovedLowestSingleChildrenGroup = groupRemoveLowestSingleChildren &&
  43534. isParent &&
  43535. rowNode.leafGroup &&
  43536. rowNode.childrenAfterGroup.length === 1;
  43537. // hide open parents means when group is open, we don't show it. we also need to make sure the
  43538. // group is expandable in the first place (as leaf groups are not expandable if pivot mode is on).
  43539. // the UI will never allow expanding leaf groups, however the user might via the API (or menu option 'expand all')
  43540. var neverAllowToExpand = skipLeafNodes && rowNode.leafGroup;
  43541. var isHiddenOpenParent = hideOpenParents && rowNode.expanded && (!neverAllowToExpand);
  43542. var thisRowShouldBeRendered = !isSkippedLeafNode &&
  43543. !isGroupSuppressedNode &&
  43544. !isHiddenOpenParent &&
  43545. !isRemovedSingleChildrenGroup &&
  43546. !isRemovedLowestSingleChildrenGroup;
  43547. if (thisRowShouldBeRendered) {
  43548. this.addRowNodeToRowsToDisplay(rowNode, result, nextRowTop, uiLevel);
  43549. }
  43550. // if we are pivoting, we never map below the leaf group
  43551. if (skipLeafNodes && rowNode.leafGroup) {
  43552. continue;
  43553. }
  43554. if (isParent) {
  43555. var excludedParent = isRemovedSingleChildrenGroup || isRemovedLowestSingleChildrenGroup;
  43556. // we traverse the group if it is expended, however we always traverse if the parent node
  43557. // was removed (as the group will never be opened if it is not displayed, we show the children instead)
  43558. if (rowNode.expanded || excludedParent) {
  43559. // if the parent was excluded, then ui level is that of the parent
  43560. var uiLevelForChildren = excludedParent ? uiLevel : uiLevel + 1;
  43561. this.recursivelyAddToRowsToDisplay(rowNode.childrenAfterSort, result, nextRowTop, skipLeafNodes, uiLevelForChildren);
  43562. // put a footer in if user is looking for it
  43563. if (this.gridOptionsWrapper.isGroupIncludeFooter()) {
  43564. this.ensureFooterNodeExists(rowNode);
  43565. this.addRowNodeToRowsToDisplay(rowNode.sibling, result, nextRowTop, uiLevel);
  43566. }
  43567. }
  43568. }
  43569. else if (rowNode.master && rowNode.expanded) {
  43570. var detailNode = this.createDetailNode(rowNode);
  43571. this.addRowNodeToRowsToDisplay(detailNode, result, nextRowTop, uiLevel);
  43572. }
  43573. }
  43574. };
  43575. // duplicated method, it's also in floatingRowModel
  43576. FlattenStage.prototype.addRowNodeToRowsToDisplay = function (rowNode, result, nextRowTop, uiLevel) {
  43577. var isGroupMultiAutoColumn = this.gridOptionsWrapper.isGroupMultiAutoColumn();
  43578. result.push(rowNode);
  43579. rowNode.setUiLevel(isGroupMultiAutoColumn ? 0 : uiLevel);
  43580. };
  43581. FlattenStage.prototype.ensureFooterNodeExists = function (groupNode) {
  43582. // only create footer node once, otherwise we have daemons and
  43583. // the animate screws up with the daemons hanging around
  43584. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(groupNode.sibling)) {
  43585. return;
  43586. }
  43587. var footerNode = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNode"]();
  43588. this.context.createBean(footerNode);
  43589. Object.keys(groupNode).forEach(function (key) {
  43590. footerNode[key] = groupNode[key];
  43591. });
  43592. footerNode.footer = true;
  43593. footerNode.rowTop = null;
  43594. footerNode.oldRowTop = null;
  43595. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(footerNode.id)) {
  43596. footerNode.id = 'rowGroupFooter_' + footerNode.id;
  43597. }
  43598. // get both header and footer to reference each other as siblings. this is never undone,
  43599. // only overwritten. so if a group is expanded, then contracted, it will have a ghost
  43600. // sibling - but that's fine, as we can ignore this if the header is contracted.
  43601. footerNode.sibling = groupNode;
  43602. groupNode.sibling = footerNode;
  43603. };
  43604. FlattenStage.prototype.createDetailNode = function (masterNode) {
  43605. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(masterNode.detailNode)) {
  43606. return masterNode.detailNode;
  43607. }
  43608. var detailNode = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNode"]();
  43609. this.context.createBean(detailNode);
  43610. detailNode.detail = true;
  43611. detailNode.selectable = false;
  43612. // flower was renamed to 'detail', but keeping for backwards compatibility
  43613. detailNode.flower = detailNode.detail;
  43614. detailNode.parent = masterNode;
  43615. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(masterNode.id)) {
  43616. detailNode.id = 'detail_' + masterNode.id;
  43617. }
  43618. detailNode.data = masterNode.data;
  43619. detailNode.level = masterNode.level + 1;
  43620. masterNode.detailNode = detailNode;
  43621. masterNode.childFlower = masterNode.detailNode; // for backwards compatibility
  43622. return detailNode;
  43623. };
  43624. __decorate([
  43625. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  43626. ], FlattenStage.prototype, "gridOptionsWrapper", void 0);
  43627. __decorate([
  43628. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('selectionController')
  43629. ], FlattenStage.prototype, "selectionController", void 0);
  43630. __decorate([
  43631. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController')
  43632. ], FlattenStage.prototype, "columnController", void 0);
  43633. FlattenStage = __decorate([
  43634. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])('flattenStage')
  43635. ], FlattenStage);
  43636. return FlattenStage;
  43637. }(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["BeanStub"]));
  43638. /***/ }),
  43639. /* 208 */
  43640. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  43641. "use strict";
  43642. __webpack_require__.r(__webpack_exports__);
  43643. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SortService", function() { return SortService; });
  43644. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
  43645. var __extends = (undefined && undefined.__extends) || (function () {
  43646. var extendStatics = function (d, b) {
  43647. extendStatics = Object.setPrototypeOf ||
  43648. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  43649. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  43650. return extendStatics(d, b);
  43651. };
  43652. return function (d, b) {
  43653. extendStatics(d, b);
  43654. function __() { this.constructor = d; }
  43655. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  43656. };
  43657. })();
  43658. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  43659. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  43660. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  43661. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  43662. return c > 3 && r && Object.defineProperty(target, key, r), r;
  43663. };
  43664. var SortService = /** @class */ (function (_super) {
  43665. __extends(SortService, _super);
  43666. function SortService() {
  43667. return _super !== null && _super.apply(this, arguments) || this;
  43668. }
  43669. SortService.prototype.init = function () {
  43670. this.postSortFunc = this.gridOptionsWrapper.getPostSortFunc();
  43671. };
  43672. SortService.prototype.sort = function (sortOptions, sortActive, deltaSort, dirtyLeafNodes, changedPath, noAggregations) {
  43673. var _this = this;
  43674. var callback = function (rowNode) {
  43675. // we clear out the 'pull down open parents' first, as the values mix up the sorting
  43676. _this.pullDownGroupDataForHideOpenParents(rowNode.childrenAfterFilter, true);
  43677. // Javascript sort is non deterministic when all the array items are equals, ie Comparator always returns 0,
  43678. // so to ensure the array keeps its order, add an additional sorting condition manually, in this case we
  43679. // are going to inspect the original array position. This is what sortedRowNodes is for.
  43680. if (sortActive) {
  43681. var sortedRowNodes = deltaSort ?
  43682. _this.doDeltaSort(rowNode, sortOptions, dirtyLeafNodes, changedPath, noAggregations)
  43683. : _this.doFullSort(rowNode, sortOptions);
  43684. rowNode.childrenAfterSort = sortedRowNodes.map(function (sorted) { return sorted.rowNode; });
  43685. }
  43686. else {
  43687. rowNode.childrenAfterSort = rowNode.childrenAfterFilter.slice(0);
  43688. }
  43689. _this.updateChildIndexes(rowNode);
  43690. if (_this.postSortFunc) {
  43691. _this.postSortFunc(rowNode.childrenAfterSort);
  43692. }
  43693. };
  43694. changedPath.forEachChangedNodeDepthFirst(callback);
  43695. this.updateGroupDataForHiddenOpenParents(changedPath);
  43696. };
  43697. SortService.prototype.doFullSort = function (rowNode, sortOptions) {
  43698. var sortedRowNodes = rowNode.childrenAfterFilter
  43699. .map(this.mapNodeToSortedNode.bind(this));
  43700. sortedRowNodes.sort(this.compareRowNodes.bind(this, sortOptions));
  43701. return sortedRowNodes;
  43702. };
  43703. SortService.prototype.mapNodeToSortedNode = function (rowNode, pos) {
  43704. return { currentPos: pos, rowNode: rowNode };
  43705. };
  43706. SortService.prototype.doDeltaSort = function (rowNode, sortOptions, dirtyLeafNodes, changedPath, noAggregations) {
  43707. // clean nodes will be a list of all row nodes that remain in the set
  43708. // and ordered. we start with the old sorted set and take out any nodes
  43709. // that were removed or changed (but not added, added doesn't make sense,
  43710. // if a node was added, there is no way it could be here from last time).
  43711. var cleanNodes = rowNode.childrenAfterSort
  43712. .filter(function (rowNode) {
  43713. // take out all nodes that were changed as part of the current transaction.
  43714. // a changed node could a) be in a different sort position or b) may
  43715. // no longer be in this set as the changed node may not pass filtering,
  43716. // or be in a different group.
  43717. var passesDirtyNodesCheck = !dirtyLeafNodes[rowNode.id];
  43718. // also remove group nodes in the changed path, as they can have different aggregate
  43719. // values which could impact the sort order.
  43720. // note: changed path is not active if a) no value columns or b) no transactions. it is never
  43721. // (b) in deltaSort as we only do deltaSort for transactions. for (a) if no value columns, then
  43722. // there is no value in the group that could of changed (ie no aggregate values)
  43723. var passesChangedPathCheck = noAggregations || changedPath.canSkip(rowNode);
  43724. return passesDirtyNodesCheck && passesChangedPathCheck;
  43725. })
  43726. .map(this.mapNodeToSortedNode.bind(this));
  43727. // for fast access below, we map them
  43728. var cleanNodesMapped = {};
  43729. cleanNodes.forEach(function (sortedRowNode) { return cleanNodesMapped[sortedRowNode.rowNode.id] = sortedRowNode.rowNode; });
  43730. // these are all nodes that need to be placed
  43731. var changedNodes = rowNode.childrenAfterFilter
  43732. // ignore nodes in the clean list
  43733. .filter(function (rowNode) { return !cleanNodesMapped[rowNode.id]; })
  43734. .map(this.mapNodeToSortedNode.bind(this));
  43735. // sort changed nodes. note that we don't need to sort cleanNodes as they are
  43736. // already sorted from last time.
  43737. changedNodes.sort(this.compareRowNodes.bind(this, sortOptions));
  43738. if (changedNodes.length === 0) {
  43739. return cleanNodes;
  43740. }
  43741. else if (cleanNodes.length === 0) {
  43742. return changedNodes;
  43743. }
  43744. else {
  43745. return this.mergeSortedArrays(sortOptions, cleanNodes, changedNodes);
  43746. }
  43747. };
  43748. // Merge two sorted arrays into each other
  43749. SortService.prototype.mergeSortedArrays = function (sortOptions, arr1, arr2) {
  43750. var res = [];
  43751. var i = 0;
  43752. var j = 0;
  43753. // Traverse both array, adding them in order
  43754. while (i < arr1.length && j < arr2.length) {
  43755. // Check if current element of first
  43756. // array is smaller than current element
  43757. // of second array. If yes, store first
  43758. // array element and increment first array
  43759. // index. Otherwise do same with second array
  43760. var compareResult = this.compareRowNodes(sortOptions, arr1[i], arr2[j]);
  43761. if (compareResult < 0) {
  43762. res.push(arr1[i++]);
  43763. }
  43764. else {
  43765. res.push(arr2[j++]);
  43766. }
  43767. }
  43768. // add remaining from arr1
  43769. while (i < arr1.length) {
  43770. res.push(arr1[i++]);
  43771. }
  43772. // add remaining from arr2
  43773. while (j < arr2.length) {
  43774. res.push(arr2[j++]);
  43775. }
  43776. return res;
  43777. };
  43778. SortService.prototype.compareRowNodes = function (sortOptions, sortedNodeA, sortedNodeB) {
  43779. var nodeA = sortedNodeA.rowNode;
  43780. var nodeB = sortedNodeB.rowNode;
  43781. // Iterate columns, return the first that doesn't match
  43782. for (var i = 0, len = sortOptions.length; i < len; i++) {
  43783. var sortOption = sortOptions[i];
  43784. // let compared = compare(nodeA, nodeB, sortOption.column, sortOption.inverter === -1);
  43785. var isInverted = sortOption.inverter === -1;
  43786. var valueA = this.getValue(nodeA, sortOption.column);
  43787. var valueB = this.getValue(nodeB, sortOption.column);
  43788. var comparatorResult = void 0;
  43789. if (sortOption.column.getColDef().comparator) {
  43790. //if comparator provided, use it
  43791. comparatorResult = sortOption.column.getColDef().comparator(valueA, valueB, nodeA, nodeB, isInverted);
  43792. }
  43793. else {
  43794. //otherwise do our own comparison
  43795. comparatorResult = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].defaultComparator(valueA, valueB, this.gridOptionsWrapper.isAccentedSort());
  43796. }
  43797. if (comparatorResult !== 0) {
  43798. return comparatorResult * sortOption.inverter;
  43799. }
  43800. }
  43801. // All matched, we make is so that the original sort order is kept:
  43802. return sortedNodeA.currentPos - sortedNodeB.currentPos;
  43803. };
  43804. SortService.prototype.getValue = function (nodeA, column) {
  43805. return this.valueService.getValue(column, nodeA);
  43806. };
  43807. SortService.prototype.updateChildIndexes = function (rowNode) {
  43808. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(rowNode.childrenAfterSort)) {
  43809. return;
  43810. }
  43811. var listToSort = rowNode.childrenAfterSort;
  43812. for (var i = 0; i < listToSort.length; i++) {
  43813. var child = listToSort[i];
  43814. var firstChild = i === 0;
  43815. var lastChild = i === rowNode.childrenAfterSort.length - 1;
  43816. child.setFirstChild(firstChild);
  43817. child.setLastChild(lastChild);
  43818. child.setChildIndex(i);
  43819. }
  43820. };
  43821. SortService.prototype.updateGroupDataForHiddenOpenParents = function (changedPath) {
  43822. var _this = this;
  43823. if (!this.gridOptionsWrapper.isGroupHideOpenParents()) {
  43824. return;
  43825. }
  43826. // recurse breadth first over group nodes after sort to 'pull down' group data to child groups
  43827. var callback = function (rowNode) {
  43828. _this.pullDownGroupDataForHideOpenParents(rowNode.childrenAfterSort, false);
  43829. rowNode.childrenAfterSort.forEach(function (child) {
  43830. if (child.hasChildren()) {
  43831. callback(child);
  43832. }
  43833. });
  43834. };
  43835. changedPath.executeFromRootNode(function (rowNode) { return callback(rowNode); });
  43836. };
  43837. SortService.prototype.pullDownGroupDataForHideOpenParents = function (rowNodes, clearOperation) {
  43838. var _this = this;
  43839. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(rowNodes)) {
  43840. return;
  43841. }
  43842. if (!this.gridOptionsWrapper.isGroupHideOpenParents()) {
  43843. return;
  43844. }
  43845. rowNodes.forEach(function (childRowNode) {
  43846. var groupDisplayCols = _this.columnController.getGroupDisplayColumns();
  43847. groupDisplayCols.forEach(function (groupDisplayCol) {
  43848. var showRowGroup = groupDisplayCol.getColDef().showRowGroup;
  43849. if (typeof showRowGroup !== 'string') {
  43850. console.error('ag-Grid: groupHideOpenParents only works when specifying specific columns for colDef.showRowGroup');
  43851. return;
  43852. }
  43853. var displayingGroupKey = showRowGroup;
  43854. var rowGroupColumn = _this.columnController.getPrimaryColumn(displayingGroupKey);
  43855. var thisRowNodeMatches = rowGroupColumn === childRowNode.rowGroupColumn;
  43856. if (thisRowNodeMatches) {
  43857. return;
  43858. }
  43859. if (clearOperation) {
  43860. // if doing a clear operation, we clear down the value for every possible group column
  43861. childRowNode.setGroupValue(groupDisplayCol.getId(), null);
  43862. }
  43863. else {
  43864. // if doing a set operation, we set only where the pull down is to occur
  43865. var parentToStealFrom = childRowNode.getFirstChildOfFirstChild(rowGroupColumn);
  43866. if (parentToStealFrom) {
  43867. childRowNode.setGroupValue(groupDisplayCol.getId(), parentToStealFrom.key);
  43868. }
  43869. }
  43870. });
  43871. });
  43872. };
  43873. __decorate([
  43874. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('sortController')
  43875. ], SortService.prototype, "sortController", void 0);
  43876. __decorate([
  43877. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController')
  43878. ], SortService.prototype, "columnController", void 0);
  43879. __decorate([
  43880. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueService')
  43881. ], SortService.prototype, "valueService", void 0);
  43882. __decorate([
  43883. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  43884. ], SortService.prototype, "gridOptionsWrapper", void 0);
  43885. __decorate([
  43886. _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  43887. ], SortService.prototype, "init", null);
  43888. SortService = __decorate([
  43889. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])('sortService')
  43890. ], SortService);
  43891. return SortService;
  43892. }(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["BeanStub"]));
  43893. /***/ }),
  43894. /* 209 */
  43895. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  43896. "use strict";
  43897. __webpack_require__.r(__webpack_exports__);
  43898. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "FilterService", function() { return FilterService; });
  43899. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
  43900. var __extends = (undefined && undefined.__extends) || (function () {
  43901. var extendStatics = function (d, b) {
  43902. extendStatics = Object.setPrototypeOf ||
  43903. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  43904. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  43905. return extendStatics(d, b);
  43906. };
  43907. return function (d, b) {
  43908. extendStatics(d, b);
  43909. function __() { this.constructor = d; }
  43910. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  43911. };
  43912. })();
  43913. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  43914. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  43915. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  43916. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  43917. return c > 3 && r && Object.defineProperty(target, key, r), r;
  43918. };
  43919. var FilterService = /** @class */ (function (_super) {
  43920. __extends(FilterService, _super);
  43921. function FilterService() {
  43922. return _super !== null && _super.apply(this, arguments) || this;
  43923. }
  43924. FilterService.prototype.postConstruct = function () {
  43925. this.doingTreeData = this.gridOptionsWrapper.isTreeData();
  43926. };
  43927. FilterService.prototype.filter = function (changedPath) {
  43928. var filterActive = this.filterManager.isAnyFilterPresent();
  43929. this.filterNodes(filterActive, changedPath);
  43930. };
  43931. FilterService.prototype.filterNodes = function (filterActive, changedPath) {
  43932. var _this = this;
  43933. var filterCallback = function (rowNode, includeChildNodes) {
  43934. // recursively get all children that are groups to also filter
  43935. if (rowNode.hasChildren()) {
  43936. // result of filter for this node. when filtering tree data, includeChildNodes = true when parent passes
  43937. if (filterActive && !includeChildNodes) {
  43938. rowNode.childrenAfterFilter = rowNode.childrenAfterGroup.filter(function (childNode) {
  43939. // a group is included in the result if it has any children of it's own.
  43940. // by this stage, the child groups are already filtered
  43941. var passBecauseChildren = childNode.childrenAfterFilter && childNode.childrenAfterFilter.length > 0;
  43942. // both leaf level nodes and tree data nodes have data. these get added if
  43943. // the data passes the filter
  43944. var passBecauseDataPasses = childNode.data && _this.filterManager.doesRowPassFilter(childNode);
  43945. // note - tree data nodes pass either if a) they pass themselves or b) any children of that node pass
  43946. return passBecauseChildren || passBecauseDataPasses;
  43947. });
  43948. }
  43949. else {
  43950. // if not filtering, the result is the original list
  43951. rowNode.childrenAfterFilter = rowNode.childrenAfterGroup;
  43952. }
  43953. _this.setAllChildrenCount(rowNode);
  43954. }
  43955. else {
  43956. rowNode.childrenAfterFilter = rowNode.childrenAfterGroup;
  43957. rowNode.setAllChildrenCount(null);
  43958. }
  43959. };
  43960. if (this.doingTreeDataFiltering()) {
  43961. var treeDataDepthFirstFilter_1 = function (rowNode, alreadyFoundInParent) {
  43962. // tree data filter traverses the hierarchy depth first and includes child nodes if parent passes
  43963. // filter, and parent nodes will be include if any children exist.
  43964. if (rowNode.childrenAfterGroup) {
  43965. for (var i = 0; i < rowNode.childrenAfterGroup.length; i++) {
  43966. var childNode = rowNode.childrenAfterGroup[i];
  43967. // first check if current node passes filter before invoking child nodes
  43968. var foundInParent = alreadyFoundInParent || _this.filterManager.doesRowPassFilter(childNode);
  43969. if (childNode.childrenAfterGroup) {
  43970. treeDataDepthFirstFilter_1(rowNode.childrenAfterGroup[i], foundInParent);
  43971. }
  43972. else {
  43973. filterCallback(childNode, foundInParent);
  43974. }
  43975. }
  43976. }
  43977. filterCallback(rowNode, alreadyFoundInParent);
  43978. };
  43979. var treeDataFilterCallback = function (rowNode) { return treeDataDepthFirstFilter_1(rowNode, false); };
  43980. changedPath.executeFromRootNode(treeDataFilterCallback);
  43981. }
  43982. else {
  43983. var defaultFilterCallback = function (rowNode) { return filterCallback(rowNode, false); };
  43984. changedPath.forEachChangedNodeDepthFirst(defaultFilterCallback, true);
  43985. }
  43986. };
  43987. FilterService.prototype.setAllChildrenCountTreeData = function (rowNode) {
  43988. // for tree data, we include all children, groups and leafs
  43989. var allChildrenCount = 0;
  43990. rowNode.childrenAfterFilter.forEach(function (child) {
  43991. // include child itself
  43992. allChildrenCount++;
  43993. // include children of children
  43994. allChildrenCount += child.allChildrenCount;
  43995. });
  43996. rowNode.setAllChildrenCount(allChildrenCount);
  43997. };
  43998. FilterService.prototype.setAllChildrenCountGridGrouping = function (rowNode) {
  43999. // for grid data, we only count the leafs
  44000. var allChildrenCount = 0;
  44001. rowNode.childrenAfterFilter.forEach(function (child) {
  44002. if (child.group) {
  44003. allChildrenCount += child.allChildrenCount;
  44004. }
  44005. else {
  44006. allChildrenCount++;
  44007. }
  44008. });
  44009. rowNode.setAllChildrenCount(allChildrenCount);
  44010. };
  44011. FilterService.prototype.setAllChildrenCount = function (rowNode) {
  44012. if (this.doingTreeData) {
  44013. this.setAllChildrenCountTreeData(rowNode);
  44014. }
  44015. else {
  44016. this.setAllChildrenCountGridGrouping(rowNode);
  44017. }
  44018. };
  44019. FilterService.prototype.doingTreeDataFiltering = function () {
  44020. return this.gridOptionsWrapper.isTreeData() && !this.gridOptionsWrapper.isExcludeChildrenWhenTreeDataFiltering();
  44021. };
  44022. __decorate([
  44023. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager')
  44024. ], FilterService.prototype, "filterManager", void 0);
  44025. __decorate([
  44026. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  44027. ], FilterService.prototype, "gridOptionsWrapper", void 0);
  44028. __decorate([
  44029. _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  44030. ], FilterService.prototype, "postConstruct", null);
  44031. FilterService = __decorate([
  44032. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])("filterService")
  44033. ], FilterService);
  44034. return FilterService;
  44035. }(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["BeanStub"]));
  44036. /***/ }),
  44037. /* 210 */
  44038. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  44039. "use strict";
  44040. __webpack_require__.r(__webpack_exports__);
  44041. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ImmutableService", function() { return ImmutableService; });
  44042. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
  44043. var __extends = (undefined && undefined.__extends) || (function () {
  44044. var extendStatics = function (d, b) {
  44045. extendStatics = Object.setPrototypeOf ||
  44046. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  44047. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  44048. return extendStatics(d, b);
  44049. };
  44050. return function (d, b) {
  44051. extendStatics(d, b);
  44052. function __() { this.constructor = d; }
  44053. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  44054. };
  44055. })();
  44056. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  44057. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  44058. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  44059. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  44060. return c > 3 && r && Object.defineProperty(target, key, r), r;
  44061. };
  44062. var ImmutableService = /** @class */ (function (_super) {
  44063. __extends(ImmutableService, _super);
  44064. function ImmutableService() {
  44065. return _super !== null && _super.apply(this, arguments) || this;
  44066. }
  44067. ImmutableService.prototype.postConstruct = function () {
  44068. if (this.rowModel.getType() === _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE) {
  44069. this.clientSideRowModel = this.rowModel;
  44070. }
  44071. };
  44072. // converts the setRowData() command to a transaction
  44073. ImmutableService.prototype.createTransactionForRowData = function (data) {
  44074. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(this.clientSideRowModel)) {
  44075. console.error('ag-Grid: ImmutableService only works with ClientSideRowModel');
  44076. return;
  44077. }
  44078. var getRowNodeIdFunc = this.gridOptionsWrapper.getRowNodeIdFunc();
  44079. if (!getRowNodeIdFunc || _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(getRowNodeIdFunc)) {
  44080. console.error('ag-Grid: ImmutableService requires getRowNodeId() callback to be implemented, your row data need IDs!');
  44081. return;
  44082. }
  44083. // convert the data into a transaction object by working out adds, removes and updates
  44084. var transaction = {
  44085. remove: [],
  44086. update: [],
  44087. add: []
  44088. };
  44089. var existingNodesMap = this.clientSideRowModel.getCopyOfNodesMap();
  44090. var suppressSortOrder = this.gridOptionsWrapper.isSuppressMaintainUnsortedOrder();
  44091. var orderMap = suppressSortOrder ? null : {};
  44092. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(data)) {
  44093. // split all the new data in the following:
  44094. // if new, push to 'add'
  44095. // if update, push to 'update'
  44096. // if not changed, do not include in the transaction
  44097. data.forEach(function (dataItem, index) {
  44098. var id = getRowNodeIdFunc(dataItem);
  44099. var existingNode = existingNodesMap[id];
  44100. if (orderMap) {
  44101. orderMap[id] = index;
  44102. }
  44103. if (existingNode) {
  44104. var dataHasChanged = existingNode.data !== dataItem;
  44105. if (dataHasChanged) {
  44106. transaction.update.push(dataItem);
  44107. }
  44108. // otherwise, if data not changed, we just don't include it anywhere, as it's not a delta
  44109. // remove from list, so we know the item is not to be removed
  44110. existingNodesMap[id] = undefined;
  44111. }
  44112. else {
  44113. transaction.add.push(dataItem);
  44114. }
  44115. });
  44116. }
  44117. // at this point, all rows that are left, should be removed
  44118. _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].iterateObject(existingNodesMap, function (id, rowNode) {
  44119. if (rowNode) {
  44120. transaction.remove.push(rowNode.data);
  44121. }
  44122. });
  44123. return [transaction, orderMap];
  44124. };
  44125. __decorate([
  44126. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel')
  44127. ], ImmutableService.prototype, "rowModel", void 0);
  44128. __decorate([
  44129. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  44130. ], ImmutableService.prototype, "gridOptionsWrapper", void 0);
  44131. __decorate([
  44132. _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  44133. ], ImmutableService.prototype, "postConstruct", null);
  44134. ImmutableService = __decorate([
  44135. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])('immutableService')
  44136. ], ImmutableService);
  44137. return ImmutableService;
  44138. }(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["BeanStub"]));
  44139. /***/ }),
  44140. /* 211 */
  44141. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  44142. "use strict";
  44143. __webpack_require__.r(__webpack_exports__);
  44144. /* harmony import */ var _csvExportModule__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(212);
  44145. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CsvExportModule", function() { return _csvExportModule__WEBPACK_IMPORTED_MODULE_0__["CsvExportModule"]; });
  44146. /* harmony import */ var _csvExport_csvCreator__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(213);
  44147. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BaseCreator", function() { return _csvExport_csvCreator__WEBPACK_IMPORTED_MODULE_1__["BaseCreator"]; });
  44148. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CsvCreator", function() { return _csvExport_csvCreator__WEBPACK_IMPORTED_MODULE_1__["CsvCreator"]; });
  44149. /* harmony import */ var _csvExport_downloader__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(215);
  44150. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Downloader", function() { return _csvExport_downloader__WEBPACK_IMPORTED_MODULE_2__["Downloader"]; });
  44151. /* harmony import */ var _csvExport_gridSerializer__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(214);
  44152. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridSerializer", function() { return _csvExport_gridSerializer__WEBPACK_IMPORTED_MODULE_3__["GridSerializer"]; });
  44153. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowType", function() { return _csvExport_gridSerializer__WEBPACK_IMPORTED_MODULE_3__["RowType"]; });
  44154. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BaseGridSerializingSession", function() { return _csvExport_gridSerializer__WEBPACK_IMPORTED_MODULE_3__["BaseGridSerializingSession"]; });
  44155. /* harmony import */ var _csvExport_zipContainer__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(217);
  44156. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ZipContainer", function() { return _csvExport_zipContainer__WEBPACK_IMPORTED_MODULE_4__["ZipContainer"]; });
  44157. /* harmony import */ var _csvExport_xmlFactory__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(216);
  44158. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "XmlFactory", function() { return _csvExport_xmlFactory__WEBPACK_IMPORTED_MODULE_5__["XmlFactory"]; });
  44159. /***/ }),
  44160. /* 212 */
  44161. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  44162. "use strict";
  44163. __webpack_require__.r(__webpack_exports__);
  44164. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CsvExportModule", function() { return CsvExportModule; });
  44165. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
  44166. /* harmony import */ var _csvExport_csvCreator__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(213);
  44167. /* harmony import */ var _csvExport_downloader__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(215);
  44168. /* harmony import */ var _csvExport_xmlFactory__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(216);
  44169. /* harmony import */ var _csvExport_gridSerializer__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(214);
  44170. /* harmony import */ var _csvExport_zipContainer__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(217);
  44171. var CsvExportModule = {
  44172. moduleName: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ModuleNames"].CsvExportModule,
  44173. beans: [_csvExport_csvCreator__WEBPACK_IMPORTED_MODULE_1__["CsvCreator"], _csvExport_downloader__WEBPACK_IMPORTED_MODULE_2__["Downloader"], _csvExport_xmlFactory__WEBPACK_IMPORTED_MODULE_3__["XmlFactory"], _csvExport_gridSerializer__WEBPACK_IMPORTED_MODULE_4__["GridSerializer"], _csvExport_zipContainer__WEBPACK_IMPORTED_MODULE_5__["ZipContainer"]]
  44174. };
  44175. /***/ }),
  44176. /* 213 */
  44177. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  44178. "use strict";
  44179. __webpack_require__.r(__webpack_exports__);
  44180. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CsvSerializingSession", function() { return CsvSerializingSession; });
  44181. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BaseCreator", function() { return BaseCreator; });
  44182. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "CsvCreator", function() { return CsvCreator; });
  44183. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
  44184. /* harmony import */ var _gridSerializer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(214);
  44185. var __extends = (undefined && undefined.__extends) || (function () {
  44186. var extendStatics = function (d, b) {
  44187. extendStatics = Object.setPrototypeOf ||
  44188. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  44189. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  44190. return extendStatics(d, b);
  44191. };
  44192. return function (d, b) {
  44193. extendStatics(d, b);
  44194. function __() { this.constructor = d; }
  44195. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  44196. };
  44197. })();
  44198. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  44199. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  44200. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  44201. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  44202. return c > 3 && r && Object.defineProperty(target, key, r), r;
  44203. };
  44204. var LINE_SEPARATOR = '\r\n';
  44205. var CsvSerializingSession = /** @class */ (function (_super) {
  44206. __extends(CsvSerializingSession, _super);
  44207. function CsvSerializingSession(config) {
  44208. var _this = _super.call(this, config) || this;
  44209. _this.isFirstLine = true;
  44210. _this.result = '';
  44211. var suppressQuotes = config.suppressQuotes, columnSeparator = config.columnSeparator;
  44212. _this.suppressQuotes = suppressQuotes;
  44213. _this.columnSeparator = columnSeparator;
  44214. return _this;
  44215. }
  44216. CsvSerializingSession.prototype.addCustomContent = function (content) {
  44217. var _this = this;
  44218. if (!content) {
  44219. return;
  44220. }
  44221. if (typeof content === 'string') {
  44222. // we used to require the customFooter to be prefixed with a newline but no longer do,
  44223. // so only add the newline if the user has not supplied one
  44224. if (!/^\s*\n/.test(content)) {
  44225. this.beginNewLine();
  44226. }
  44227. // replace whatever newlines are supplied with the style we're using
  44228. content = content.replace(/\r?\n/g, LINE_SEPARATOR);
  44229. this.result += content;
  44230. }
  44231. else {
  44232. content.forEach(function (row) {
  44233. _this.beginNewLine();
  44234. row.forEach(function (cell, index) {
  44235. if (index !== 0) {
  44236. _this.result += _this.columnSeparator;
  44237. }
  44238. _this.result += _this.putInQuotes(cell.data.value || '');
  44239. if (cell.mergeAcross) {
  44240. _this.appendEmptyCells(cell.mergeAcross);
  44241. }
  44242. });
  44243. });
  44244. }
  44245. };
  44246. CsvSerializingSession.prototype.onNewHeaderGroupingRow = function () {
  44247. this.beginNewLine();
  44248. return {
  44249. onColumn: this.onNewHeaderGroupingRowColumn.bind(this)
  44250. };
  44251. };
  44252. CsvSerializingSession.prototype.onNewHeaderGroupingRowColumn = function (header, index, span) {
  44253. if (index != 0) {
  44254. this.result += this.columnSeparator;
  44255. }
  44256. this.result += this.putInQuotes(header);
  44257. this.appendEmptyCells(span);
  44258. };
  44259. CsvSerializingSession.prototype.appendEmptyCells = function (count) {
  44260. for (var i = 1; i <= count; i++) {
  44261. this.result += this.columnSeparator + this.putInQuotes("");
  44262. }
  44263. };
  44264. CsvSerializingSession.prototype.onNewHeaderRow = function () {
  44265. this.beginNewLine();
  44266. return {
  44267. onColumn: this.onNewHeaderRowColumn.bind(this)
  44268. };
  44269. };
  44270. CsvSerializingSession.prototype.onNewHeaderRowColumn = function (column, index, node) {
  44271. if (index != 0) {
  44272. this.result += this.columnSeparator;
  44273. }
  44274. this.result += this.putInQuotes(this.extractHeaderValue(column));
  44275. };
  44276. CsvSerializingSession.prototype.onNewBodyRow = function () {
  44277. this.beginNewLine();
  44278. return {
  44279. onColumn: this.onNewBodyRowColumn.bind(this)
  44280. };
  44281. };
  44282. CsvSerializingSession.prototype.onNewBodyRowColumn = function (column, index, node) {
  44283. if (index != 0) {
  44284. this.result += this.columnSeparator;
  44285. }
  44286. this.result += this.putInQuotes(this.extractRowCellValue(column, index, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].EXPORT_TYPE_CSV, node));
  44287. };
  44288. CsvSerializingSession.prototype.putInQuotes = function (value) {
  44289. if (this.suppressQuotes) {
  44290. return value;
  44291. }
  44292. if (value === null || value === undefined) {
  44293. return '""';
  44294. }
  44295. var stringValue;
  44296. if (typeof value === 'string') {
  44297. stringValue = value;
  44298. }
  44299. else if (typeof value.toString === 'function') {
  44300. stringValue = value.toString();
  44301. }
  44302. else {
  44303. console.warn('unknown value type during csv conversion');
  44304. stringValue = '';
  44305. }
  44306. // replace each " with "" (ie two sets of double quotes is how to do double quotes in csv)
  44307. var valueEscaped = stringValue.replace(/"/g, "\"\"");
  44308. return '"' + valueEscaped + '"';
  44309. };
  44310. CsvSerializingSession.prototype.parse = function () {
  44311. return this.result;
  44312. };
  44313. CsvSerializingSession.prototype.beginNewLine = function () {
  44314. if (!this.isFirstLine) {
  44315. this.result += LINE_SEPARATOR;
  44316. }
  44317. this.isFirstLine = false;
  44318. };
  44319. return CsvSerializingSession;
  44320. }(_gridSerializer__WEBPACK_IMPORTED_MODULE_1__["BaseGridSerializingSession"]));
  44321. var BaseCreator = /** @class */ (function () {
  44322. function BaseCreator() {
  44323. }
  44324. BaseCreator.prototype.setBeans = function (beans) {
  44325. this.beans = beans;
  44326. };
  44327. BaseCreator.prototype.export = function (userParams) {
  44328. if (this.isExportSuppressed()) {
  44329. console.warn("ag-grid: Export cancelled. Export is not allowed as per your configuration.");
  44330. return '';
  44331. }
  44332. var _a = this.getMergedParamsAndData(userParams), mergedParams = _a.mergedParams, data = _a.data;
  44333. var fileNamePresent = mergedParams && mergedParams.fileName && mergedParams.fileName.length !== 0;
  44334. var fileName = fileNamePresent ? mergedParams.fileName : this.getDefaultFileName();
  44335. if (fileName.indexOf(".") === -1) {
  44336. fileName = fileName + "." + this.getDefaultFileExtension();
  44337. }
  44338. this.beans.downloader.download(fileName, this.packageFile(data));
  44339. return data;
  44340. };
  44341. BaseCreator.prototype.getData = function (params) {
  44342. return this.getMergedParamsAndData(params).data;
  44343. };
  44344. BaseCreator.prototype.getMergedParamsAndData = function (userParams) {
  44345. var mergedParams = this.mergeDefaultParams(userParams);
  44346. var data = this.beans.gridSerializer.serialize(this.createSerializingSession(mergedParams), mergedParams);
  44347. return { mergedParams: mergedParams, data: data };
  44348. };
  44349. BaseCreator.prototype.mergeDefaultParams = function (userParams) {
  44350. var baseParams = this.beans.gridOptionsWrapper.getDefaultExportParams();
  44351. var params = {};
  44352. _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].assign(params, baseParams);
  44353. _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].assign(params, userParams);
  44354. return params;
  44355. };
  44356. BaseCreator.prototype.packageFile = function (data) {
  44357. return new Blob(["\ufeff", data], {
  44358. type: window.navigator.msSaveOrOpenBlob ? this.getMimeType() : 'octet/stream'
  44359. });
  44360. };
  44361. return BaseCreator;
  44362. }());
  44363. var CsvCreator = /** @class */ (function (_super) {
  44364. __extends(CsvCreator, _super);
  44365. function CsvCreator() {
  44366. return _super !== null && _super.apply(this, arguments) || this;
  44367. }
  44368. CsvCreator.prototype.postConstruct = function () {
  44369. this.setBeans({
  44370. downloader: this.downloader,
  44371. gridSerializer: this.gridSerializer,
  44372. gridOptionsWrapper: this.gridOptionsWrapper
  44373. });
  44374. };
  44375. CsvCreator.prototype.exportDataAsCsv = function (params) {
  44376. return this.export(params);
  44377. };
  44378. CsvCreator.prototype.getDataAsCsv = function (params) {
  44379. return this.getData(params);
  44380. };
  44381. CsvCreator.prototype.getMimeType = function () {
  44382. return 'text/csv;charset=utf-8;';
  44383. };
  44384. CsvCreator.prototype.getDefaultFileName = function () {
  44385. return 'export.csv';
  44386. };
  44387. CsvCreator.prototype.getDefaultFileExtension = function () {
  44388. return 'csv';
  44389. };
  44390. CsvCreator.prototype.createSerializingSession = function (params) {
  44391. var _a = this, columnController = _a.columnController, valueService = _a.valueService, gridOptionsWrapper = _a.gridOptionsWrapper;
  44392. var processCellCallback = params.processCellCallback, processHeaderCallback = params.processHeaderCallback, processGroupHeaderCallback = params.processGroupHeaderCallback, processRowGroupCallback = params.processRowGroupCallback, suppressQuotes = params.suppressQuotes, columnSeparator = params.columnSeparator;
  44393. return new CsvSerializingSession({
  44394. columnController: columnController,
  44395. valueService: valueService,
  44396. gridOptionsWrapper: gridOptionsWrapper,
  44397. processCellCallback: processCellCallback || undefined,
  44398. processHeaderCallback: processHeaderCallback || undefined,
  44399. processGroupHeaderCallback: processGroupHeaderCallback || undefined,
  44400. processRowGroupCallback: processRowGroupCallback || undefined,
  44401. suppressQuotes: suppressQuotes || false,
  44402. columnSeparator: columnSeparator || ','
  44403. });
  44404. };
  44405. CsvCreator.prototype.isExportSuppressed = function () {
  44406. return this.gridOptionsWrapper.isSuppressCsvExport();
  44407. };
  44408. __decorate([
  44409. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController')
  44410. ], CsvCreator.prototype, "columnController", void 0);
  44411. __decorate([
  44412. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('valueService')
  44413. ], CsvCreator.prototype, "valueService", void 0);
  44414. __decorate([
  44415. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('downloader')
  44416. ], CsvCreator.prototype, "downloader", void 0);
  44417. __decorate([
  44418. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridSerializer')
  44419. ], CsvCreator.prototype, "gridSerializer", void 0);
  44420. __decorate([
  44421. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  44422. ], CsvCreator.prototype, "gridOptionsWrapper", void 0);
  44423. __decorate([
  44424. _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  44425. ], CsvCreator.prototype, "postConstruct", null);
  44426. CsvCreator = __decorate([
  44427. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])('csvCreator')
  44428. ], CsvCreator);
  44429. return CsvCreator;
  44430. }(BaseCreator));
  44431. /***/ }),
  44432. /* 214 */
  44433. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  44434. "use strict";
  44435. __webpack_require__.r(__webpack_exports__);
  44436. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BaseGridSerializingSession", function() { return BaseGridSerializingSession; });
  44437. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GridSerializer", function() { return GridSerializer; });
  44438. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RowType", function() { return RowType; });
  44439. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
  44440. var __extends = (undefined && undefined.__extends) || (function () {
  44441. var extendStatics = function (d, b) {
  44442. extendStatics = Object.setPrototypeOf ||
  44443. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  44444. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  44445. return extendStatics(d, b);
  44446. };
  44447. return function (d, b) {
  44448. extendStatics(d, b);
  44449. function __() { this.constructor = d; }
  44450. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  44451. };
  44452. })();
  44453. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  44454. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  44455. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  44456. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  44457. return c > 3 && r && Object.defineProperty(target, key, r), r;
  44458. };
  44459. var BaseGridSerializingSession = /** @class */ (function () {
  44460. function BaseGridSerializingSession(config) {
  44461. var columnController = config.columnController, valueService = config.valueService, gridOptionsWrapper = config.gridOptionsWrapper, processCellCallback = config.processCellCallback, processHeaderCallback = config.processHeaderCallback, processGroupHeaderCallback = config.processGroupHeaderCallback, processRowGroupCallback = config.processRowGroupCallback;
  44462. this.columnController = columnController;
  44463. this.valueService = valueService;
  44464. this.gridOptionsWrapper = gridOptionsWrapper;
  44465. this.processCellCallback = processCellCallback;
  44466. this.processHeaderCallback = processHeaderCallback;
  44467. this.processGroupHeaderCallback = processGroupHeaderCallback;
  44468. this.processRowGroupCallback = processRowGroupCallback;
  44469. }
  44470. BaseGridSerializingSession.prototype.prepare = function (columnsToExport) {
  44471. this.firstGroupColumn = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].find(columnsToExport, function (col) { return !!col.getColDef().showRowGroup; });
  44472. };
  44473. BaseGridSerializingSession.prototype.extractHeaderValue = function (column) {
  44474. var value = this.getHeaderName(this.processHeaderCallback, column);
  44475. return value != null ? value : '';
  44476. };
  44477. BaseGridSerializingSession.prototype.extractRowCellValue = function (column, index, type, node) {
  44478. // we render the group summary text e.g. "-> Parent -> Child"...
  44479. var renderGroupSummaryCell =
  44480. // on group rows
  44481. node && node.group
  44482. && (
  44483. // in the first group column if groups appear in regular grid cells
  44484. column === this.firstGroupColumn
  44485. // or the first cell in the row, if we're doing full width rows
  44486. || (index === 0 && this.gridOptionsWrapper.isGroupUseEntireRow(this.columnController.isPivotMode())));
  44487. var valueForCell;
  44488. if (renderGroupSummaryCell) {
  44489. valueForCell = this.createValueForGroupNode(node);
  44490. }
  44491. else {
  44492. valueForCell = this.valueService.getValue(column, node);
  44493. }
  44494. var value = this.processCell(node, column, valueForCell, this.processCellCallback, type);
  44495. return value != null ? value : '';
  44496. };
  44497. BaseGridSerializingSession.prototype.getHeaderName = function (callback, column) {
  44498. if (callback) {
  44499. return callback({
  44500. column: column,
  44501. api: this.gridOptionsWrapper.getApi(),
  44502. columnApi: this.gridOptionsWrapper.getColumnApi(),
  44503. context: this.gridOptionsWrapper.getContext()
  44504. });
  44505. }
  44506. else {
  44507. return this.columnController.getDisplayNameForColumn(column, 'csv', true);
  44508. }
  44509. };
  44510. BaseGridSerializingSession.prototype.createValueForGroupNode = function (node) {
  44511. if (this.processRowGroupCallback) {
  44512. return this.processRowGroupCallback({
  44513. node: node,
  44514. api: this.gridOptionsWrapper.getApi(),
  44515. columnApi: this.gridOptionsWrapper.getColumnApi(),
  44516. context: this.gridOptionsWrapper.getContext(),
  44517. });
  44518. }
  44519. var keys = [node.key];
  44520. while (node.parent) {
  44521. node = node.parent;
  44522. keys.push(node.key);
  44523. }
  44524. return keys.reverse().join(' -> ');
  44525. };
  44526. BaseGridSerializingSession.prototype.processCell = function (rowNode, column, value, processCellCallback, type) {
  44527. if (processCellCallback) {
  44528. return processCellCallback({
  44529. column: column,
  44530. node: rowNode,
  44531. value: value,
  44532. api: this.gridOptionsWrapper.getApi(),
  44533. columnApi: this.gridOptionsWrapper.getColumnApi(),
  44534. context: this.gridOptionsWrapper.getContext(),
  44535. type: type
  44536. });
  44537. }
  44538. else {
  44539. return value;
  44540. }
  44541. };
  44542. return BaseGridSerializingSession;
  44543. }());
  44544. var GridSerializer = /** @class */ (function (_super) {
  44545. __extends(GridSerializer, _super);
  44546. function GridSerializer() {
  44547. return _super !== null && _super.apply(this, arguments) || this;
  44548. }
  44549. GridSerializer.prototype.serialize = function (gridSerializingSession, params) {
  44550. if (params === void 0) { params = {}; }
  44551. var rowSkipper = params.shouldRowBeSkipped || (function () { return false; });
  44552. var api = this.gridOptionsWrapper.getApi();
  44553. var columnApi = this.gridOptionsWrapper.getColumnApi();
  44554. var skipSingleChildrenGroup = this.gridOptionsWrapper.isGroupRemoveSingleChildren();
  44555. var skipLowestSingleChildrenGroup = this.gridOptionsWrapper.isGroupRemoveLowestSingleChildren();
  44556. var context = this.gridOptionsWrapper.getContext();
  44557. // when in pivot mode, we always render cols on screen, never 'all columns'
  44558. var isPivotMode = this.columnController.isPivotMode();
  44559. var rowModelNormal = this.rowModel.getType() === _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].ROW_MODEL_TYPE_CLIENT_SIDE;
  44560. var onlySelectedNonStandardModel = !rowModelNormal && params.onlySelected;
  44561. var columnsToExport = [];
  44562. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].existsAndNotEmpty(params.columnKeys)) {
  44563. columnsToExport = this.columnController.getGridColumns(params.columnKeys);
  44564. }
  44565. else if (params.allColumns && !isPivotMode) {
  44566. // add auto group column for tree data
  44567. columnsToExport = this.gridOptionsWrapper.isTreeData() ?
  44568. this.columnController.getGridColumns([_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].GROUP_AUTO_COLUMN_ID]) : [];
  44569. columnsToExport = columnsToExport.concat(this.columnController.getAllPrimaryColumns() || []);
  44570. }
  44571. else {
  44572. columnsToExport = this.columnController.getAllDisplayedColumns();
  44573. }
  44574. if (params.customHeader) {
  44575. gridSerializingSession.addCustomContent(params.customHeader);
  44576. }
  44577. gridSerializingSession.prepare(columnsToExport);
  44578. // first pass, put in the header names of the cols
  44579. if (params.columnGroups) {
  44580. var groupInstanceIdCreator = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["GroupInstanceIdCreator"]();
  44581. var displayedGroups = this.displayedGroupCreator.createDisplayedGroups(columnsToExport, this.columnController.getGridBalancedTree(), groupInstanceIdCreator, null);
  44582. this.recursivelyAddHeaderGroups(displayedGroups, gridSerializingSession, params.processGroupHeaderCallback);
  44583. }
  44584. if (!params.skipHeader) {
  44585. var gridRowIterator_1 = gridSerializingSession.onNewHeaderRow();
  44586. columnsToExport.forEach(function (column, index) {
  44587. gridRowIterator_1.onColumn(column, index, undefined);
  44588. });
  44589. }
  44590. this.pinnedRowModel.forEachPinnedTopRow(processRow);
  44591. if (isPivotMode) {
  44592. if (this.rowModel.forEachPivotNode) {
  44593. this.rowModel.forEachPivotNode(processRow);
  44594. }
  44595. else {
  44596. //Must be enterprise, so we can just loop through all the nodes
  44597. this.rowModel.forEachNode(processRow);
  44598. }
  44599. }
  44600. else {
  44601. // onlySelectedAllPages: user doing pagination and wants selected items from
  44602. // other pages, so cannot use the standard row model as it won't have rows from
  44603. // other pages.
  44604. // onlySelectedNonStandardModel: if user wants selected in non standard row model
  44605. // (eg viewport) then again rowmodel cannot be used, so need to use selected instead.
  44606. if (params.onlySelectedAllPages || onlySelectedNonStandardModel) {
  44607. var selectedNodes = this.selectionController.getSelectedNodes();
  44608. selectedNodes.forEach(function (node) {
  44609. processRow(node);
  44610. });
  44611. }
  44612. else {
  44613. // here is everything else - including standard row model and selected. we don't use
  44614. // the selection model even when just using selected, so that the result is the order
  44615. // of the rows appearing on the screen.
  44616. if (rowModelNormal) {
  44617. this.rowModel.forEachNodeAfterFilterAndSort(processRow);
  44618. }
  44619. else {
  44620. this.rowModel.forEachNode(processRow);
  44621. }
  44622. }
  44623. }
  44624. this.pinnedRowModel.forEachPinnedBottomRow(processRow);
  44625. if (params.customFooter) {
  44626. gridSerializingSession.addCustomContent(params.customFooter);
  44627. }
  44628. function processRow(node) {
  44629. var shouldSkipLowestGroup = skipLowestSingleChildrenGroup && node.leafGroup;
  44630. var shouldSkipCurrentGroup = node.allChildrenCount === 1 && (skipSingleChildrenGroup || shouldSkipLowestGroup);
  44631. if (node.group && (params.skipGroups || shouldSkipCurrentGroup)) {
  44632. return;
  44633. }
  44634. if (params.skipFooters && node.footer) {
  44635. return;
  44636. }
  44637. if (params.onlySelected && !node.isSelected()) {
  44638. return;
  44639. }
  44640. if (params.skipPinnedTop && node.rowPinned === 'top') {
  44641. return;
  44642. }
  44643. if (params.skipPinnedBottom && node.rowPinned === 'bottom') {
  44644. return;
  44645. }
  44646. // if we are in pivotMode, then the grid will show the root node only
  44647. // if it's not a leaf group
  44648. var nodeIsRootNode = node.level === -1;
  44649. if (nodeIsRootNode && !node.leafGroup) {
  44650. return;
  44651. }
  44652. var shouldRowBeSkipped = rowSkipper({ node: node, api: api, context: context });
  44653. if (shouldRowBeSkipped) {
  44654. return;
  44655. }
  44656. var rowAccumulator = gridSerializingSession.onNewBodyRow();
  44657. columnsToExport.forEach(function (column, index) {
  44658. rowAccumulator.onColumn(column, index, node);
  44659. });
  44660. if (params.getCustomContentBelowRow) {
  44661. var content = params.getCustomContentBelowRow({ node: node, api: api, columnApi: columnApi, context: context });
  44662. if (content) {
  44663. gridSerializingSession.addCustomContent(content);
  44664. }
  44665. }
  44666. }
  44667. return gridSerializingSession.parse();
  44668. };
  44669. GridSerializer.prototype.recursivelyAddHeaderGroups = function (displayedGroups, gridSerializingSession, processGroupHeaderCallback) {
  44670. var directChildrenHeaderGroups = [];
  44671. displayedGroups.forEach(function (columnGroupChild) {
  44672. var columnGroup = columnGroupChild;
  44673. if (!columnGroup.getChildren) {
  44674. return;
  44675. }
  44676. columnGroup.getChildren().forEach(function (it) { return directChildrenHeaderGroups.push(it); });
  44677. });
  44678. if (displayedGroups.length > 0 && displayedGroups[0] instanceof _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ColumnGroup"]) {
  44679. this.doAddHeaderHeader(gridSerializingSession, displayedGroups, processGroupHeaderCallback);
  44680. }
  44681. if (directChildrenHeaderGroups && directChildrenHeaderGroups.length > 0) {
  44682. this.recursivelyAddHeaderGroups(directChildrenHeaderGroups, gridSerializingSession, processGroupHeaderCallback);
  44683. }
  44684. };
  44685. GridSerializer.prototype.doAddHeaderHeader = function (gridSerializingSession, displayedGroups, processGroupHeaderCallback) {
  44686. var _this = this;
  44687. var gridRowIterator = gridSerializingSession.onNewHeaderGroupingRow();
  44688. var columnIndex = 0;
  44689. displayedGroups.forEach(function (columnGroupChild) {
  44690. var columnGroup = columnGroupChild;
  44691. var name;
  44692. if (processGroupHeaderCallback) {
  44693. name = processGroupHeaderCallback({
  44694. columnGroup: columnGroup,
  44695. api: _this.gridOptionsWrapper.getApi(),
  44696. columnApi: _this.gridOptionsWrapper.getColumnApi(),
  44697. context: _this.gridOptionsWrapper.getContext()
  44698. });
  44699. }
  44700. else {
  44701. name = _this.columnController.getDisplayNameForColumnGroup(columnGroup, 'header');
  44702. }
  44703. gridRowIterator.onColumn(name || '', columnIndex++, columnGroup.getLeafColumns().length - 1);
  44704. });
  44705. };
  44706. __decorate([
  44707. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('displayedGroupCreator')
  44708. ], GridSerializer.prototype, "displayedGroupCreator", void 0);
  44709. __decorate([
  44710. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnController')
  44711. ], GridSerializer.prototype, "columnController", void 0);
  44712. __decorate([
  44713. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowModel')
  44714. ], GridSerializer.prototype, "rowModel", void 0);
  44715. __decorate([
  44716. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('pinnedRowModel')
  44717. ], GridSerializer.prototype, "pinnedRowModel", void 0);
  44718. __decorate([
  44719. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('selectionController')
  44720. ], GridSerializer.prototype, "selectionController", void 0);
  44721. __decorate([
  44722. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnFactory')
  44723. ], GridSerializer.prototype, "columnFactory", void 0);
  44724. __decorate([
  44725. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  44726. ], GridSerializer.prototype, "gridOptionsWrapper", void 0);
  44727. GridSerializer = __decorate([
  44728. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])("gridSerializer")
  44729. ], GridSerializer);
  44730. return GridSerializer;
  44731. }(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["BeanStub"]));
  44732. var RowType;
  44733. (function (RowType) {
  44734. RowType[RowType["HEADER_GROUPING"] = 0] = "HEADER_GROUPING";
  44735. RowType[RowType["HEADER"] = 1] = "HEADER";
  44736. RowType[RowType["BODY"] = 2] = "BODY";
  44737. })(RowType || (RowType = {}));
  44738. /***/ }),
  44739. /* 215 */
  44740. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  44741. "use strict";
  44742. __webpack_require__.r(__webpack_exports__);
  44743. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Downloader", function() { return Downloader; });
  44744. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
  44745. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  44746. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  44747. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  44748. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  44749. return c > 3 && r && Object.defineProperty(target, key, r), r;
  44750. };
  44751. var Downloader = /** @class */ (function () {
  44752. function Downloader() {
  44753. }
  44754. Downloader.prototype.download = function (fileName, content) {
  44755. // Internet Explorer
  44756. if (window.navigator.msSaveOrOpenBlob) {
  44757. window.navigator.msSaveOrOpenBlob(content, fileName);
  44758. }
  44759. else {
  44760. // Other Browsers
  44761. var element = document.createElement("a");
  44762. var url_1 = window.URL.createObjectURL(content);
  44763. element.setAttribute("href", url_1);
  44764. element.setAttribute("download", fileName);
  44765. element.style.display = "none";
  44766. document.body.appendChild(element);
  44767. element.dispatchEvent(new MouseEvent('click', {
  44768. bubbles: false,
  44769. cancelable: true,
  44770. view: window
  44771. }));
  44772. document.body.removeChild(element);
  44773. window.setTimeout(function () {
  44774. window.URL.revokeObjectURL(url_1);
  44775. }, 0);
  44776. }
  44777. };
  44778. Downloader = __decorate([
  44779. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])("downloader")
  44780. ], Downloader);
  44781. return Downloader;
  44782. }());
  44783. /***/ }),
  44784. /* 216 */
  44785. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  44786. "use strict";
  44787. __webpack_require__.r(__webpack_exports__);
  44788. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "XmlFactory", function() { return XmlFactory; });
  44789. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
  44790. var __extends = (undefined && undefined.__extends) || (function () {
  44791. var extendStatics = function (d, b) {
  44792. extendStatics = Object.setPrototypeOf ||
  44793. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  44794. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  44795. return extendStatics(d, b);
  44796. };
  44797. return function (d, b) {
  44798. extendStatics(d, b);
  44799. function __() { this.constructor = d; }
  44800. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  44801. };
  44802. })();
  44803. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  44804. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  44805. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  44806. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  44807. return c > 3 && r && Object.defineProperty(target, key, r), r;
  44808. };
  44809. var LINE_SEPARATOR = '\r\n';
  44810. var XmlFactory = /** @class */ (function (_super) {
  44811. __extends(XmlFactory, _super);
  44812. function XmlFactory() {
  44813. return _super !== null && _super.apply(this, arguments) || this;
  44814. }
  44815. XmlFactory.prototype.createHeader = function (headerElement) {
  44816. if (headerElement === void 0) { headerElement = {}; }
  44817. var headerStart = '<?';
  44818. var headerEnd = '?>';
  44819. var keys = ['version'];
  44820. if (!headerElement.version) {
  44821. headerElement.version = "1.0";
  44822. }
  44823. if (headerElement.encoding) {
  44824. keys.push('encoding');
  44825. }
  44826. if (headerElement.standalone) {
  44827. keys.push('standalone');
  44828. }
  44829. var att = keys.map(function (key) { return key + "=\"" + headerElement[key] + "\""; }).join(' ');
  44830. return headerStart + "xml " + att + " " + headerEnd;
  44831. };
  44832. XmlFactory.prototype.createXml = function (xmlElement, booleanTransformer) {
  44833. var _this = this;
  44834. var props = '';
  44835. if (xmlElement.properties) {
  44836. if (xmlElement.properties.prefixedAttributes) {
  44837. xmlElement.properties.prefixedAttributes.forEach(function (prefixedSet) {
  44838. Object.keys(prefixedSet.map).forEach(function (key) {
  44839. props += _this.returnAttributeIfPopulated(prefixedSet.prefix + key, prefixedSet.map[key], booleanTransformer);
  44840. });
  44841. });
  44842. }
  44843. if (xmlElement.properties.rawMap) {
  44844. Object.keys(xmlElement.properties.rawMap).forEach(function (key) {
  44845. props += _this.returnAttributeIfPopulated(key, xmlElement.properties.rawMap[key], booleanTransformer);
  44846. });
  44847. }
  44848. }
  44849. var result = '<' + xmlElement.name + props;
  44850. if (!xmlElement.children && xmlElement.textNode == null) {
  44851. return result + '/>' + LINE_SEPARATOR;
  44852. }
  44853. if (xmlElement.textNode != null) {
  44854. return result + '>' + xmlElement.textNode + '</' + xmlElement.name + '>' + LINE_SEPARATOR;
  44855. }
  44856. result += '>' + LINE_SEPARATOR;
  44857. if (xmlElement.children) {
  44858. xmlElement.children.forEach(function (it) {
  44859. result += _this.createXml(it, booleanTransformer);
  44860. });
  44861. }
  44862. return result + '</' + xmlElement.name + '>' + LINE_SEPARATOR;
  44863. };
  44864. XmlFactory.prototype.returnAttributeIfPopulated = function (key, value, booleanTransformer) {
  44865. if (!value && value !== '' && value !== 0) {
  44866. return '';
  44867. }
  44868. var xmlValue = value;
  44869. if ((typeof (value) === 'boolean')) {
  44870. if (booleanTransformer) {
  44871. xmlValue = booleanTransformer(value);
  44872. }
  44873. }
  44874. return " " + key + "=\"" + xmlValue + "\"";
  44875. };
  44876. XmlFactory = __decorate([
  44877. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])('xmlFactory')
  44878. ], XmlFactory);
  44879. return XmlFactory;
  44880. }(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["BeanStub"]));
  44881. /***/ }),
  44882. /* 217 */
  44883. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  44884. "use strict";
  44885. __webpack_require__.r(__webpack_exports__);
  44886. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ZipContainer", function() { return ZipContainer; });
  44887. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
  44888. var __extends = (undefined && undefined.__extends) || (function () {
  44889. var extendStatics = function (d, b) {
  44890. extendStatics = Object.setPrototypeOf ||
  44891. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  44892. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  44893. return extendStatics(d, b);
  44894. };
  44895. return function (d, b) {
  44896. extendStatics(d, b);
  44897. function __() { this.constructor = d; }
  44898. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  44899. };
  44900. })();
  44901. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  44902. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  44903. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  44904. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  44905. return c > 3 && r && Object.defineProperty(target, key, r), r;
  44906. };
  44907. // table for crc calculation
  44908. // from: https://referencesource.microsoft.com/#System/sys/System/IO/compression/Crc32Helper.cs,3b31978c7d7f7246,references
  44909. var crcTable = [
  44910. 0, 1996959894, -301047508, -1727442502, 124634137, 1886057615, -379345611, -1637575261, 249268274,
  44911. 2044508324, -522852066, -1747789432, 162941995, 2125561021, -407360249, -1866523247, 498536548,
  44912. 1789927666, -205950648, -2067906082, 450548861, 1843258603, -187386543, -2083289657, 325883990,
  44913. 1684777152, -43845254, -1973040660, 335633487, 1661365465, -99664541, -1928851979, 997073096,
  44914. 1281953886, -715111964, -1570279054, 1006888145, 1258607687, -770865667, -1526024853, 901097722,
  44915. 1119000684, -608450090, -1396901568, 853044451, 1172266101, -589951537, -1412350631, 651767980,
  44916. 1373503546, -925412992, -1076862698, 565507253, 1454621731, -809855591, -1195530993, 671266974,
  44917. 1594198024, -972236366, -1324619484, 795835527, 1483230225, -1050600021, -1234817731, 1994146192,
  44918. 31158534, -1731059524, -271249366, 1907459465, 112637215, -1614814043, -390540237, 2013776290,
  44919. 251722036, -1777751922, -519137256, 2137656763, 141376813, -1855689577, -429695999, 1802195444,
  44920. 476864866, -2056965928, -228458418, 1812370925, 453092731, -2113342271, -183516073, 1706088902,
  44921. 314042704, -1950435094, -54949764, 1658658271, 366619977, -1932296973, -69972891, 1303535960,
  44922. 984961486, -1547960204, -725929758, 1256170817, 1037604311, -1529756563, -740887301, 1131014506,
  44923. 879679996, -1385723834, -631195440, 1141124467, 855842277, -1442165665, -586318647, 1342533948,
  44924. 654459306, -1106571248, -921952122, 1466479909, 544179635, -1184443383, -832445281, 1591671054,
  44925. 702138776, -1328506846, -942167884, 1504918807, 783551873, -1212326853, -1061524307, -306674912,
  44926. -1698712650, 62317068, 1957810842, -355121351, -1647151185, 81470997, 1943803523, -480048366,
  44927. -1805370492, 225274430, 2053790376, -468791541, -1828061283, 167816743, 2097651377, -267414716,
  44928. -2029476910, 503444072, 1762050814, -144550051, -2140837941, 426522225, 1852507879, -19653770,
  44929. -1982649376, 282753626, 1742555852, -105259153, -1900089351, 397917763, 1622183637, -690576408,
  44930. -1580100738, 953729732, 1340076626, -776247311, -1497606297, 1068828381, 1219638859, -670225446,
  44931. -1358292148, 906185462, 1090812512, -547295293, -1469587627, 829329135, 1181335161, -882789492,
  44932. -1134132454, 628085408, 1382605366, -871598187, -1156888829, 570562233, 1426400815, -977650754,
  44933. -1296233688, 733239954, 1555261956, -1026031705, -1244606671, 752459403, 1541320221, -1687895376,
  44934. -328994266, 1969922972, 40735498, -1677130071, -351390145, 1913087877, 83908371, -1782625662,
  44935. -491226604, 2075208622, 213261112, -1831694693, -438977011, 2094854071, 198958881, -2032938284,
  44936. -237706686, 1759359992, 534414190, -2118248755, -155638181, 1873836001, 414664567, -2012718362,
  44937. -15766928, 1711684554, 285281116, -1889165569, -127750551, 1634467795, 376229701, -1609899400,
  44938. -686959890, 1308918612, 956543938, -1486412191, -799009033, 1231636301, 1047427035, -1362007478,
  44939. -640263460, 1088359270, 936918000, -1447252397, -558129467, 1202900863, 817233897, -1111625188,
  44940. -893730166, 1404277552, 615818150, -1160759803, -841546093, 1423857449, 601450431, -1285129682,
  44941. -1000256840, 1567103746, 711928724, -1274298825, -1022587231, 1510334235, 755167117
  44942. ];
  44943. var ZipContainer = /** @class */ (function (_super) {
  44944. __extends(ZipContainer, _super);
  44945. function ZipContainer() {
  44946. var _this = _super !== null && _super.apply(this, arguments) || this;
  44947. _this.folders = [];
  44948. _this.files = [];
  44949. _this.addFolder = function (path) {
  44950. _this.folders.push({
  44951. path: path,
  44952. created: new Date()
  44953. });
  44954. };
  44955. return _this;
  44956. }
  44957. ZipContainer.prototype.addFolders = function (paths) {
  44958. paths.forEach(this.addFolder);
  44959. };
  44960. ZipContainer.prototype.addFile = function (path, content) {
  44961. this.files.push({
  44962. path: path,
  44963. created: new Date(),
  44964. content: content
  44965. });
  44966. };
  44967. ZipContainer.prototype.clearStream = function () {
  44968. this.folders = [];
  44969. this.files = [];
  44970. };
  44971. ZipContainer.prototype.getContent = function (mimeType) {
  44972. if (mimeType === void 0) { mimeType = 'application/zip'; }
  44973. var textOutput = this.buildFileStream();
  44974. var uInt8Output = this.buildUint8Array(textOutput);
  44975. this.clearStream();
  44976. return new Blob([uInt8Output], { type: mimeType });
  44977. };
  44978. ZipContainer.prototype.buildFileStream = function (fData) {
  44979. if (fData === void 0) { fData = ''; }
  44980. var totalFiles = this.folders.concat(this.files);
  44981. var len = totalFiles.length;
  44982. var foData = '';
  44983. var lL = 0;
  44984. var cL = 0;
  44985. for (var _i = 0, totalFiles_1 = totalFiles; _i < totalFiles_1.length; _i++) {
  44986. var currentFile = totalFiles_1[_i];
  44987. var _a = this.getHeader(currentFile, lL), fileHeader = _a.fileHeader, folderHeader = _a.folderHeader, content = _a.content;
  44988. lL += fileHeader.length + content.length;
  44989. cL += folderHeader.length;
  44990. fData += fileHeader + content;
  44991. foData += folderHeader;
  44992. }
  44993. var foEnd = this.buildFolderEnd(len, cL, lL);
  44994. return fData + foData + foEnd;
  44995. };
  44996. ZipContainer.prototype.getHeader = function (currentFile, offset) {
  44997. var content = currentFile.content, path = currentFile.path, created = currentFile.created;
  44998. var utf8_encode = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].utf8_encode, decToHex = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].decToHex;
  44999. var utfPath = utf8_encode(path);
  45000. var isUTF8 = utfPath !== path;
  45001. var time = this.convertTime(created);
  45002. var dt = this.convertDate(created);
  45003. var extraFields = '';
  45004. if (isUTF8) {
  45005. var uExtraFieldPath = decToHex(1, 1) + decToHex(this.getFromCrc32Table(utfPath), 4) + utfPath;
  45006. extraFields = "\x75\x70" + decToHex(uExtraFieldPath.length, 2) + uExtraFieldPath;
  45007. }
  45008. var header = '\x0A\x00' +
  45009. (isUTF8 ? '\x00\x08' : '\x00\x00') +
  45010. '\x00\x00' +
  45011. decToHex(time, 2) + // last modified time
  45012. decToHex(dt, 2) + // last modified date
  45013. decToHex(content ? this.getFromCrc32Table(content) : 0, 4) +
  45014. decToHex(content ? content.length : 0, 4) + // compressed size
  45015. decToHex(content ? content.length : 0, 4) + // uncompressed size
  45016. decToHex(utfPath.length, 2) + // file name length
  45017. decToHex(extraFields.length, 2); // extra field length
  45018. var fileHeader = 'PK\x03\x04' + header + utfPath + extraFields;
  45019. var folderHeader = 'PK\x01\x02' + // central header
  45020. '\x14\x00' +
  45021. header + // file header
  45022. '\x00\x00' +
  45023. '\x00\x00' +
  45024. '\x00\x00' +
  45025. (content ? '\x00\x00\x00\x00' : '\x10\x00\x00\x00') + // external file attributes
  45026. decToHex(offset, 4) + // relative offset of local header
  45027. utfPath + // file name
  45028. extraFields; // extra field
  45029. return { fileHeader: fileHeader, folderHeader: folderHeader, content: content || '' };
  45030. };
  45031. ZipContainer.prototype.buildFolderEnd = function (tLen, cLen, lLen) {
  45032. var decToHex = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].decToHex;
  45033. return 'PK\x05\x06' + // central folder end
  45034. '\x00\x00' +
  45035. '\x00\x00' +
  45036. decToHex(tLen, 2) + // total number of entries in the central folder
  45037. decToHex(tLen, 2) + // total number of entries in the central folder
  45038. decToHex(cLen, 4) + // size of the central folder
  45039. decToHex(lLen, 4) + // central folder start offset
  45040. '\x00\x00';
  45041. };
  45042. ZipContainer.prototype.buildUint8Array = function (content) {
  45043. var uint8 = new Uint8Array(content.length);
  45044. for (var i = 0; i < uint8.length; i++) {
  45045. uint8[i] = content.charCodeAt(i);
  45046. }
  45047. return uint8;
  45048. };
  45049. ZipContainer.prototype.getFromCrc32Table = function (content, crc) {
  45050. if (crc === void 0) { crc = 0; }
  45051. if (!content.length) {
  45052. return 0;
  45053. }
  45054. crc ^= (-1);
  45055. var j = 0;
  45056. var k = 0;
  45057. var l = 0;
  45058. for (var i = 0; i < content.length; i++) {
  45059. j = content.charCodeAt(i);
  45060. k = (crc ^ j) & 0xFF;
  45061. l = crcTable[k];
  45062. crc = (crc >>> 8) ^ l;
  45063. }
  45064. return crc ^ (-1);
  45065. };
  45066. ZipContainer.prototype.convertTime = function (date) {
  45067. var time = date.getHours();
  45068. time <<= 6;
  45069. time = time | date.getMinutes();
  45070. time <<= 5;
  45071. time = time | date.getSeconds() / 2;
  45072. return time;
  45073. };
  45074. ZipContainer.prototype.convertDate = function (date) {
  45075. var dt = date.getFullYear() - 1980;
  45076. dt <<= 4;
  45077. dt = dt | (date.getMonth() + 1);
  45078. dt <<= 5;
  45079. dt = dt | date.getDate();
  45080. return dt;
  45081. };
  45082. ZipContainer = __decorate([
  45083. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])('zipContainer')
  45084. ], ZipContainer);
  45085. return ZipContainer;
  45086. }(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["BeanStub"]));
  45087. /***/ }),
  45088. /* 218 */
  45089. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  45090. "use strict";
  45091. __webpack_require__.r(__webpack_exports__);
  45092. /* harmony import */ var _infiniteRowModelModule__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(219);
  45093. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "InfiniteRowModelModule", function() { return _infiniteRowModelModule__WEBPACK_IMPORTED_MODULE_0__["InfiniteRowModelModule"]; });
  45094. /***/ }),
  45095. /* 219 */
  45096. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  45097. "use strict";
  45098. __webpack_require__.r(__webpack_exports__);
  45099. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "InfiniteRowModelModule", function() { return InfiniteRowModelModule; });
  45100. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
  45101. /* harmony import */ var _infiniteRowModel_infiniteRowModel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(220);
  45102. var InfiniteRowModelModule = {
  45103. moduleName: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["ModuleNames"].InfiniteRowModelModule,
  45104. rowModels: { 'infinite': _infiniteRowModel_infiniteRowModel__WEBPACK_IMPORTED_MODULE_1__["InfiniteRowModel"] }
  45105. };
  45106. /***/ }),
  45107. /* 220 */
  45108. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  45109. "use strict";
  45110. __webpack_require__.r(__webpack_exports__);
  45111. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "InfiniteRowModel", function() { return InfiniteRowModel; });
  45112. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
  45113. /* harmony import */ var _infiniteCache__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(221);
  45114. var __extends = (undefined && undefined.__extends) || (function () {
  45115. var extendStatics = function (d, b) {
  45116. extendStatics = Object.setPrototypeOf ||
  45117. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  45118. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  45119. return extendStatics(d, b);
  45120. };
  45121. return function (d, b) {
  45122. extendStatics(d, b);
  45123. function __() { this.constructor = d; }
  45124. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  45125. };
  45126. })();
  45127. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  45128. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  45129. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  45130. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  45131. return c > 3 && r && Object.defineProperty(target, key, r), r;
  45132. };
  45133. var InfiniteRowModel = /** @class */ (function (_super) {
  45134. __extends(InfiniteRowModel, _super);
  45135. function InfiniteRowModel() {
  45136. return _super !== null && _super.apply(this, arguments) || this;
  45137. }
  45138. InfiniteRowModel.prototype.getRowBounds = function (index) {
  45139. return {
  45140. rowHeight: this.rowHeight,
  45141. rowTop: this.rowHeight * index
  45142. };
  45143. };
  45144. // we don't implement as lazy row heights is not supported in this row model
  45145. InfiniteRowModel.prototype.ensureRowHeightsValid = function (startPixel, endPixel, startLimitIndex, endLimitIndex) {
  45146. return false;
  45147. };
  45148. InfiniteRowModel.prototype.init = function () {
  45149. var _this = this;
  45150. if (!this.gridOptionsWrapper.isRowModelInfinite()) {
  45151. return;
  45152. }
  45153. this.rowHeight = this.gridOptionsWrapper.getRowHeightAsNumber();
  45154. this.addEventListeners();
  45155. this.addDestroyFunc(function () { return _this.destroyCache(); });
  45156. };
  45157. InfiniteRowModel.prototype.start = function () {
  45158. this.setDatasource(this.gridOptionsWrapper.getDatasource());
  45159. };
  45160. InfiniteRowModel.prototype.destroyDatasource = function () {
  45161. if (this.datasource) {
  45162. this.getContext().destroyBean(this.datasource);
  45163. this.rowRenderer.datasourceChanged();
  45164. this.datasource = null;
  45165. }
  45166. };
  45167. InfiniteRowModel.prototype.isLastRowFound = function () {
  45168. return this.infiniteCache ? this.infiniteCache.isMaxRowFound() : false;
  45169. };
  45170. InfiniteRowModel.prototype.addEventListeners = function () {
  45171. this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_FILTER_CHANGED, this.onFilterChanged.bind(this));
  45172. this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_SORT_CHANGED, this.onSortChanged.bind(this));
  45173. this.addManagedListener(this.eventService, _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_COLUMN_EVERYTHING_CHANGED, this.onColumnEverything.bind(this));
  45174. };
  45175. InfiniteRowModel.prototype.onFilterChanged = function () {
  45176. this.reset();
  45177. };
  45178. InfiniteRowModel.prototype.onSortChanged = function () {
  45179. this.reset();
  45180. };
  45181. InfiniteRowModel.prototype.onColumnEverything = function () {
  45182. var resetRequired;
  45183. // if cache params, we require reset only if sort model has changed. we don't need to check
  45184. // for filter model, as the filter manager will fire an event when columns change that result
  45185. // in the filter changing.
  45186. if (this.cacheParams) {
  45187. resetRequired = this.isSortModelDifferent();
  45188. }
  45189. else {
  45190. // if no cacheParams, means first time creating the cache, so always create one
  45191. resetRequired = true;
  45192. }
  45193. if (resetRequired) {
  45194. this.reset();
  45195. }
  45196. };
  45197. InfiniteRowModel.prototype.isSortModelDifferent = function () {
  45198. return !_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].jsonEquals(this.cacheParams.sortModel, this.sortController.getSortModel());
  45199. };
  45200. InfiniteRowModel.prototype.getType = function () {
  45201. return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Constants"].ROW_MODEL_TYPE_INFINITE;
  45202. };
  45203. InfiniteRowModel.prototype.setDatasource = function (datasource) {
  45204. this.destroyDatasource();
  45205. this.datasource = datasource;
  45206. // only reset if we have a valid datasource to working with
  45207. if (datasource) {
  45208. this.checkForDeprecated();
  45209. this.reset();
  45210. }
  45211. };
  45212. InfiniteRowModel.prototype.checkForDeprecated = function () {
  45213. var ds = this.datasource;
  45214. // the number of concurrent loads we are allowed to the server
  45215. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(ds.maxConcurrentRequests)) {
  45216. console.error('ag-Grid: since version 5.1.x, maxConcurrentRequests is replaced with grid property maxConcurrentDatasourceRequests');
  45217. }
  45218. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(ds.maxPagesInCache)) {
  45219. console.error('ag-Grid: since version 5.1.x, maxPagesInCache is replaced with grid property maxPagesInPaginationCache');
  45220. }
  45221. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(ds.overflowSize)) {
  45222. console.error('ag-Grid: since version 5.1.x, overflowSize is replaced with grid property paginationOverflowSize');
  45223. }
  45224. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(ds.blockSize)) {
  45225. console.error('ag-Grid: since version 5.1.x, pageSize/blockSize is replaced with grid property infinitePageSize');
  45226. }
  45227. };
  45228. InfiniteRowModel.prototype.isEmpty = function () {
  45229. return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(this.infiniteCache);
  45230. };
  45231. InfiniteRowModel.prototype.isRowsToRender = function () {
  45232. return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(this.infiniteCache);
  45233. };
  45234. InfiniteRowModel.prototype.getNodesInRangeForSelection = function (firstInRange, lastInRange) {
  45235. return this.infiniteCache ? this.infiniteCache.getRowNodesInRange(firstInRange, lastInRange) : [];
  45236. };
  45237. InfiniteRowModel.prototype.reset = function () {
  45238. // important to return here, as the user could be setting filter or sort before
  45239. // data-source is set
  45240. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(this.datasource)) {
  45241. return;
  45242. }
  45243. // if user is providing id's, then this means we can keep the selection between datasource hits,
  45244. // as the rows will keep their unique id's even if, for example, server side sorting or filtering
  45245. // is done.
  45246. var userGeneratingIds = _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(this.gridOptionsWrapper.getRowNodeIdFunc());
  45247. if (!userGeneratingIds) {
  45248. this.selectionController.reset();
  45249. }
  45250. this.resetCache();
  45251. var event = this.createModelUpdatedEvent();
  45252. this.eventService.dispatchEvent(event);
  45253. };
  45254. InfiniteRowModel.prototype.createModelUpdatedEvent = function () {
  45255. return {
  45256. type: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_MODEL_UPDATED,
  45257. api: this.gridApi,
  45258. columnApi: this.columnApi,
  45259. // not sure if these should all be false - noticed if after implementing,
  45260. // maybe they should be true?
  45261. newPage: false,
  45262. newData: false,
  45263. keepRenderedRows: false,
  45264. animate: false
  45265. };
  45266. };
  45267. InfiniteRowModel.prototype.resetCache = function () {
  45268. // if not first time creating a cache, need to destroy the old one
  45269. this.destroyCache();
  45270. var maxConcurrentRequests = this.gridOptionsWrapper.getMaxConcurrentDatasourceRequests();
  45271. var blockLoadDebounceMillis = this.gridOptionsWrapper.getBlockLoadDebounceMillis();
  45272. // there is a bi-directional dependency between the loader and the cache,
  45273. // so we create loader here, and then pass dependencies in setDependencies() method later
  45274. this.rowNodeBlockLoader = new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNodeBlockLoader"](maxConcurrentRequests, blockLoadDebounceMillis);
  45275. this.getContext().createBean(this.rowNodeBlockLoader);
  45276. this.cacheParams = {
  45277. // the user provided datasource
  45278. datasource: this.datasource,
  45279. // sort and filter model
  45280. filterModel: this.filterManager.getFilterModel(),
  45281. sortModel: this.sortController.getSortModel(),
  45282. rowNodeBlockLoader: this.rowNodeBlockLoader,
  45283. // properties - this way we take a snapshot of them, so if user changes any, they will be
  45284. // used next time we create a new cache, which is generally after a filter or sort change,
  45285. // or a new datasource is set
  45286. maxConcurrentRequests: maxConcurrentRequests,
  45287. overflowSize: this.gridOptionsWrapper.getCacheOverflowSize(),
  45288. initialRowCount: this.gridOptionsWrapper.getInfiniteInitialRowCount(),
  45289. maxBlocksInCache: this.gridOptionsWrapper.getMaxBlocksInCache(),
  45290. blockSize: this.gridOptionsWrapper.getCacheBlockSize(),
  45291. rowHeight: this.gridOptionsWrapper.getRowHeightAsNumber(),
  45292. // the cache could create this, however it is also used by the pages, so handy to create it
  45293. // here as the settings are also passed to the pages
  45294. lastAccessedSequence: new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["NumberSequence"]()
  45295. };
  45296. // set defaults
  45297. if (!this.cacheParams.maxConcurrentRequests || !(this.cacheParams.maxConcurrentRequests >= 1)) {
  45298. this.cacheParams.maxConcurrentRequests = 2;
  45299. }
  45300. // page size needs to be 1 or greater. having it at 1 would be silly, as you would be hitting the
  45301. // server for one page at a time. so the default if not specified is 100.
  45302. if (!this.cacheParams.blockSize || !(this.cacheParams.blockSize >= 1)) {
  45303. this.cacheParams.blockSize = 100;
  45304. }
  45305. // if user doesn't give initial rows to display, we assume one
  45306. if (!(this.cacheParams.initialRowCount >= 1)) {
  45307. this.cacheParams.initialRowCount = 1;
  45308. }
  45309. // if user doesn't provide overflow, we use default overflow of 1, so user can scroll past
  45310. // the current page and request first row of next page
  45311. if (!(this.cacheParams.overflowSize >= 1)) {
  45312. this.cacheParams.overflowSize = 1;
  45313. }
  45314. this.infiniteCache = new _infiniteCache__WEBPACK_IMPORTED_MODULE_1__["InfiniteCache"](this.cacheParams);
  45315. this.getContext().createBean(this.infiniteCache);
  45316. this.infiniteCache.addEventListener(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNodeCache"].EVENT_CACHE_UPDATED, this.onCacheUpdated.bind(this));
  45317. };
  45318. InfiniteRowModel.prototype.destroyCache = function () {
  45319. if (this.infiniteCache) {
  45320. this.infiniteCache = this.destroyBean(this.infiniteCache);
  45321. }
  45322. if (this.rowNodeBlockLoader) {
  45323. this.rowNodeBlockLoader = this.destroyBean(this.rowNodeBlockLoader);
  45324. }
  45325. };
  45326. InfiniteRowModel.prototype.onCacheUpdated = function () {
  45327. var event = this.createModelUpdatedEvent();
  45328. this.eventService.dispatchEvent(event);
  45329. };
  45330. InfiniteRowModel.prototype.getRow = function (rowIndex) {
  45331. return this.infiniteCache ? this.infiniteCache.getRow(rowIndex) : null;
  45332. };
  45333. InfiniteRowModel.prototype.getRowNode = function (id) {
  45334. var result = null;
  45335. this.forEachNode(function (rowNode) {
  45336. if (rowNode.id === id) {
  45337. result = rowNode;
  45338. }
  45339. });
  45340. return result;
  45341. };
  45342. InfiniteRowModel.prototype.forEachNode = function (callback) {
  45343. if (this.infiniteCache) {
  45344. this.infiniteCache.forEachNodeDeep(callback, new _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["NumberSequence"]());
  45345. }
  45346. };
  45347. InfiniteRowModel.prototype.getCurrentPageHeight = function () {
  45348. return this.getRowCount() * this.rowHeight;
  45349. };
  45350. InfiniteRowModel.prototype.getTopLevelRowCount = function () {
  45351. return this.getRowCount();
  45352. };
  45353. InfiniteRowModel.prototype.getTopLevelRowDisplayedIndex = function (topLevelIndex) {
  45354. return topLevelIndex;
  45355. };
  45356. InfiniteRowModel.prototype.getRowIndexAtPixel = function (pixel) {
  45357. if (this.rowHeight !== 0) { // avoid divide by zero error
  45358. var rowIndexForPixel = Math.floor(pixel / this.rowHeight);
  45359. var lastRowIndex = this.getRowCount() - 1;
  45360. if (rowIndexForPixel > lastRowIndex) {
  45361. return lastRowIndex;
  45362. }
  45363. else {
  45364. return rowIndexForPixel;
  45365. }
  45366. }
  45367. else {
  45368. return 0;
  45369. }
  45370. };
  45371. InfiniteRowModel.prototype.getRowCount = function () {
  45372. return this.infiniteCache ? this.infiniteCache.getVirtualRowCount() : 0;
  45373. };
  45374. InfiniteRowModel.prototype.updateRowData = function (transaction) {
  45375. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(transaction.remove) || _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(transaction.update)) {
  45376. console.warn('ag-Grid: updateRowData for InfiniteRowModel does not support remove or update, only add');
  45377. return;
  45378. }
  45379. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(transaction.addIndex)) {
  45380. console.warn('ag-Grid: updateRowData for InfiniteRowModel requires add and addIndex to be set');
  45381. return;
  45382. }
  45383. if (this.infiniteCache) {
  45384. this.infiniteCache.insertItemsAtIndex(transaction.addIndex, transaction.add);
  45385. }
  45386. };
  45387. InfiniteRowModel.prototype.isRowPresent = function (rowNode) {
  45388. return false;
  45389. };
  45390. InfiniteRowModel.prototype.refreshCache = function () {
  45391. if (this.infiniteCache) {
  45392. this.infiniteCache.refreshCache();
  45393. }
  45394. };
  45395. InfiniteRowModel.prototype.purgeCache = function () {
  45396. if (this.infiniteCache) {
  45397. this.infiniteCache.purgeCache();
  45398. }
  45399. };
  45400. InfiniteRowModel.prototype.getVirtualRowCount = function () {
  45401. if (this.infiniteCache) {
  45402. return this.infiniteCache.getVirtualRowCount();
  45403. }
  45404. else {
  45405. return null;
  45406. }
  45407. };
  45408. InfiniteRowModel.prototype.isMaxRowFound = function () {
  45409. if (this.infiniteCache) {
  45410. return this.infiniteCache.isMaxRowFound();
  45411. }
  45412. };
  45413. InfiniteRowModel.prototype.setVirtualRowCount = function (rowCount, maxRowFound) {
  45414. if (this.infiniteCache) {
  45415. this.infiniteCache.setVirtualRowCount(rowCount, maxRowFound);
  45416. }
  45417. };
  45418. InfiniteRowModel.prototype.getBlockState = function () {
  45419. if (this.rowNodeBlockLoader) {
  45420. return this.rowNodeBlockLoader.getBlockState();
  45421. }
  45422. else {
  45423. return null;
  45424. }
  45425. };
  45426. __decorate([
  45427. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  45428. ], InfiniteRowModel.prototype, "gridOptionsWrapper", void 0);
  45429. __decorate([
  45430. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('filterManager')
  45431. ], InfiniteRowModel.prototype, "filterManager", void 0);
  45432. __decorate([
  45433. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('sortController')
  45434. ], InfiniteRowModel.prototype, "sortController", void 0);
  45435. __decorate([
  45436. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('selectionController')
  45437. ], InfiniteRowModel.prototype, "selectionController", void 0);
  45438. __decorate([
  45439. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi')
  45440. ], InfiniteRowModel.prototype, "gridApi", void 0);
  45441. __decorate([
  45442. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi')
  45443. ], InfiniteRowModel.prototype, "columnApi", void 0);
  45444. __decorate([
  45445. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer')
  45446. ], InfiniteRowModel.prototype, "rowRenderer", void 0);
  45447. __decorate([
  45448. _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  45449. ], InfiniteRowModel.prototype, "init", null);
  45450. __decorate([
  45451. _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["PreDestroy"]
  45452. ], InfiniteRowModel.prototype, "destroyDatasource", null);
  45453. InfiniteRowModel = __decorate([
  45454. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Bean"])('rowModel')
  45455. ], InfiniteRowModel);
  45456. return InfiniteRowModel;
  45457. }(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["BeanStub"]));
  45458. /***/ }),
  45459. /* 221 */
  45460. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  45461. "use strict";
  45462. __webpack_require__.r(__webpack_exports__);
  45463. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "InfiniteCache", function() { return InfiniteCache; });
  45464. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
  45465. /* harmony import */ var _infiniteBlock__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(222);
  45466. var __extends = (undefined && undefined.__extends) || (function () {
  45467. var extendStatics = function (d, b) {
  45468. extendStatics = Object.setPrototypeOf ||
  45469. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  45470. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  45471. return extendStatics(d, b);
  45472. };
  45473. return function (d, b) {
  45474. extendStatics(d, b);
  45475. function __() { this.constructor = d; }
  45476. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  45477. };
  45478. })();
  45479. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  45480. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  45481. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  45482. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  45483. return c > 3 && r && Object.defineProperty(target, key, r), r;
  45484. };
  45485. var __param = (undefined && undefined.__param) || function (paramIndex, decorator) {
  45486. return function (target, key) { decorator(target, key, paramIndex); }
  45487. };
  45488. var InfiniteCache = /** @class */ (function (_super) {
  45489. __extends(InfiniteCache, _super);
  45490. function InfiniteCache(params) {
  45491. return _super.call(this, params) || this;
  45492. }
  45493. InfiniteCache.prototype.setBeans = function (loggerFactory) {
  45494. this.logger = loggerFactory.create('InfiniteCache');
  45495. };
  45496. InfiniteCache.prototype.moveItemsDown = function (block, moveFromIndex, moveCount) {
  45497. var startRow = block.getStartRow();
  45498. var endRow = block.getEndRow();
  45499. var indexOfLastRowToMove = moveFromIndex + moveCount;
  45500. // all rows need to be moved down below the insertion index
  45501. for (var currentRowIndex = endRow - 1; currentRowIndex >= startRow; currentRowIndex--) {
  45502. // don't move rows at or before the insertion index
  45503. if (currentRowIndex < indexOfLastRowToMove) {
  45504. continue;
  45505. }
  45506. var indexOfNodeWeWant = currentRowIndex - moveCount;
  45507. var nodeForThisIndex = this.getRow(indexOfNodeWeWant, true);
  45508. if (nodeForThisIndex) {
  45509. block.setRowNode(currentRowIndex, nodeForThisIndex);
  45510. }
  45511. else {
  45512. block.setBlankRowNode(currentRowIndex);
  45513. block.setDirty();
  45514. }
  45515. }
  45516. };
  45517. InfiniteCache.prototype.insertItems = function (block, indexToInsert, items) {
  45518. var pageStartRow = block.getStartRow();
  45519. var pageEndRow = block.getEndRow();
  45520. var newRowNodes = [];
  45521. // next stage is insert the rows into this page, if applicable
  45522. for (var index = 0; index < items.length; index++) {
  45523. var rowIndex = indexToInsert + index;
  45524. var currentRowInThisPage = rowIndex >= pageStartRow && rowIndex < pageEndRow;
  45525. if (currentRowInThisPage) {
  45526. var dataItem = items[index];
  45527. var newRowNode = block.setNewData(rowIndex, dataItem);
  45528. newRowNodes.push(newRowNode);
  45529. }
  45530. }
  45531. return newRowNodes;
  45532. };
  45533. InfiniteCache.prototype.insertItemsAtIndex = function (indexToInsert, items) {
  45534. // get all page id's as NUMBERS (not strings, as we need to sort as numbers) and in descending order
  45535. var _this = this;
  45536. var newNodes = [];
  45537. this.forEachBlockInReverseOrder(function (block) {
  45538. var pageEndRow = block.getEndRow();
  45539. // if the insertion is after this page, then this page is not impacted
  45540. if (pageEndRow <= indexToInsert) {
  45541. return;
  45542. }
  45543. _this.moveItemsDown(block, indexToInsert, items.length);
  45544. var newNodesThisPage = _this.insertItems(block, indexToInsert, items);
  45545. newNodesThisPage.forEach(function (rowNode) { return newNodes.push(rowNode); });
  45546. });
  45547. if (this.isMaxRowFound()) {
  45548. this.hack_setVirtualRowCount(this.getVirtualRowCount() + items.length);
  45549. }
  45550. this.onCacheUpdated();
  45551. var event = {
  45552. type: _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Events"].EVENT_ROW_DATA_UPDATED,
  45553. api: this.gridApi,
  45554. columnApi: this.columnApi
  45555. };
  45556. this.eventService.dispatchEvent(event);
  45557. };
  45558. // the rowRenderer will not pass dontCreatePage, meaning when rendering the grid,
  45559. // it will want new pages in the cache as it asks for rows. only when we are inserting /
  45560. // removing rows via the api is dontCreatePage set, where we move rows between the pages.
  45561. InfiniteCache.prototype.getRow = function (rowIndex, dontCreatePage) {
  45562. if (dontCreatePage === void 0) { dontCreatePage = false; }
  45563. var blockId = Math.floor(rowIndex / this.cacheParams.blockSize);
  45564. var block = this.getBlock(blockId);
  45565. if (!block) {
  45566. if (dontCreatePage) {
  45567. return null;
  45568. }
  45569. else {
  45570. block = this.createBlock(blockId);
  45571. }
  45572. }
  45573. return block.getRow(rowIndex);
  45574. };
  45575. InfiniteCache.prototype.createBlock = function (blockNumber) {
  45576. var newBlock = new _infiniteBlock__WEBPACK_IMPORTED_MODULE_1__["InfiniteBlock"](blockNumber, this.cacheParams);
  45577. this.getContext().createBean(newBlock);
  45578. this.postCreateBlock(newBlock);
  45579. return newBlock;
  45580. };
  45581. // we have this on infinite row model only, not server side row model,
  45582. // because for server side, it would leave the children in inconsistent
  45583. // state - eg if a node had children, but after the refresh it had data
  45584. // for a different row, then the children would be with the wrong row node.
  45585. InfiniteCache.prototype.refreshCache = function () {
  45586. this.forEachBlockInOrder(function (block) { return block.setDirty(); });
  45587. this.checkBlockToLoad();
  45588. };
  45589. __decorate([
  45590. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('columnApi')
  45591. ], InfiniteCache.prototype, "columnApi", void 0);
  45592. __decorate([
  45593. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridApi')
  45594. ], InfiniteCache.prototype, "gridApi", void 0);
  45595. __decorate([
  45596. __param(0, Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Qualifier"])('loggerFactory'))
  45597. ], InfiniteCache.prototype, "setBeans", null);
  45598. return InfiniteCache;
  45599. }(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNodeCache"]));
  45600. /***/ }),
  45601. /* 222 */
  45602. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  45603. "use strict";
  45604. __webpack_require__.r(__webpack_exports__);
  45605. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "InfiniteBlock", function() { return InfiniteBlock; });
  45606. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
  45607. var __extends = (undefined && undefined.__extends) || (function () {
  45608. var extendStatics = function (d, b) {
  45609. extendStatics = Object.setPrototypeOf ||
  45610. ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
  45611. function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
  45612. return extendStatics(d, b);
  45613. };
  45614. return function (d, b) {
  45615. extendStatics(d, b);
  45616. function __() { this.constructor = d; }
  45617. d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
  45618. };
  45619. })();
  45620. var __decorate = (undefined && undefined.__decorate) || function (decorators, target, key, desc) {
  45621. var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
  45622. if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
  45623. else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
  45624. return c > 3 && r && Object.defineProperty(target, key, r), r;
  45625. };
  45626. var InfiniteBlock = /** @class */ (function (_super) {
  45627. __extends(InfiniteBlock, _super);
  45628. function InfiniteBlock(pageNumber, params) {
  45629. var _this = _super.call(this, pageNumber, params) || this;
  45630. _this.cacheParams = params;
  45631. return _this;
  45632. }
  45633. InfiniteBlock.prototype.getDisplayIndexStart = function () {
  45634. return this.getBlockNumber() * this.cacheParams.blockSize;
  45635. };
  45636. // this is an estimate, as the last block will probably only be partially full. however
  45637. // this method is used to know if this block is been rendered, before destroying, so
  45638. // and this estimate works in that use case.
  45639. InfiniteBlock.prototype.getDisplayIndexEnd = function () {
  45640. return this.getDisplayIndexStart() + this.cacheParams.blockSize;
  45641. };
  45642. InfiniteBlock.prototype.createBlankRowNode = function (rowIndex) {
  45643. var rowNode = _super.prototype.createBlankRowNode.call(this, rowIndex);
  45644. rowNode.uiLevel = 0;
  45645. this.setIndexAndTopOnRowNode(rowNode, rowIndex);
  45646. return rowNode;
  45647. };
  45648. InfiniteBlock.prototype.setDataAndId = function (rowNode, data, index) {
  45649. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].exists(data)) {
  45650. // this means if the user is not providing id's we just use the
  45651. // index for the row. this will allow selection to work (that is based
  45652. // on index) as long user is not inserting or deleting rows,
  45653. // or wanting to keep selection between server side sorting or filtering
  45654. rowNode.setDataAndId(data, index.toString());
  45655. }
  45656. else {
  45657. rowNode.setDataAndId(undefined, undefined);
  45658. }
  45659. };
  45660. InfiniteBlock.prototype.setRowNode = function (rowIndex, rowNode) {
  45661. _super.prototype.setRowNode.call(this, rowIndex, rowNode);
  45662. this.setIndexAndTopOnRowNode(rowNode, rowIndex);
  45663. };
  45664. InfiniteBlock.prototype.init = function () {
  45665. _super.prototype.init.call(this, {
  45666. context: this.getContext(),
  45667. rowRenderer: this.rowRenderer
  45668. });
  45669. };
  45670. InfiniteBlock.prototype.getNodeIdPrefix = function () {
  45671. return null;
  45672. };
  45673. InfiniteBlock.prototype.getRow = function (displayIndex) {
  45674. return this.getRowUsingLocalIndex(displayIndex);
  45675. };
  45676. InfiniteBlock.prototype.setIndexAndTopOnRowNode = function (rowNode, rowIndex) {
  45677. rowNode.setRowIndex(rowIndex);
  45678. rowNode.rowTop = this.cacheParams.rowHeight * rowIndex;
  45679. };
  45680. InfiniteBlock.prototype.loadFromDatasource = function () {
  45681. var _this = this;
  45682. // PROBLEM . . . . when the user sets sort via colDef.sort, then this code
  45683. // is executing before the sort is set up, so server is not getting the sort
  45684. // model. need to change with regards order - so the server side request is
  45685. // AFTER thus it gets the right sort model.
  45686. var params = {
  45687. startRow: this.getStartRow(),
  45688. endRow: this.getEndRow(),
  45689. successCallback: this.pageLoaded.bind(this, this.getVersion()),
  45690. failCallback: this.pageLoadFailed.bind(this),
  45691. sortModel: this.cacheParams.sortModel,
  45692. filterModel: this.cacheParams.filterModel,
  45693. context: this.gridOptionsWrapper.getContext()
  45694. };
  45695. if (_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["_"].missing(this.cacheParams.datasource.getRows)) {
  45696. console.warn("ag-Grid: datasource is missing getRows method");
  45697. return;
  45698. }
  45699. // put in timeout, to force result to be async
  45700. window.setTimeout(function () {
  45701. _this.cacheParams.datasource.getRows(params);
  45702. }, 0);
  45703. };
  45704. __decorate([
  45705. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('gridOptionsWrapper')
  45706. ], InfiniteBlock.prototype, "gridOptionsWrapper", void 0);
  45707. __decorate([
  45708. Object(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["Autowired"])('rowRenderer')
  45709. ], InfiniteBlock.prototype, "rowRenderer", void 0);
  45710. __decorate([
  45711. _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["PostConstruct"]
  45712. ], InfiniteBlock.prototype, "init", null);
  45713. return InfiniteBlock;
  45714. }(_ag_grid_community_core__WEBPACK_IMPORTED_MODULE_0__["RowNodeBlock"]));
  45715. /***/ }),
  45716. /* 223 */
  45717. /***/ (function(module, __webpack_exports__, __webpack_require__) {
  45718. "use strict";
  45719. __webpack_require__.r(__webpack_exports__);
  45720. /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AllCommunityModules", function() { return AllCommunityModules; });
  45721. /* harmony import */ var _ag_grid_community_client_side_row_model__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(1);
  45722. /* harmony import */ var _ag_grid_community_infinite_row_model__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(218);
  45723. /* harmony import */ var _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(211);
  45724. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ClientSideRowModelModule", function() { return _ag_grid_community_client_side_row_model__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelModule"]; });
  45725. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CsvExportModule", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["CsvExportModule"]; });
  45726. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BaseCreator", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["BaseCreator"]; });
  45727. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CsvCreator", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["CsvCreator"]; });
  45728. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Downloader", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["Downloader"]; });
  45729. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridSerializer", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["GridSerializer"]; });
  45730. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowType", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["RowType"]; });
  45731. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BaseGridSerializingSession", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["BaseGridSerializingSession"]; });
  45732. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ZipContainer", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["ZipContainer"]; });
  45733. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "XmlFactory", function() { return _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["XmlFactory"]; });
  45734. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "InfiniteRowModelModule", function() { return _ag_grid_community_infinite_row_model__WEBPACK_IMPORTED_MODULE_1__["InfiniteRowModelModule"]; });
  45735. /* harmony import */ var _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(3);
  45736. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnFactory", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ColumnFactory"]; });
  45737. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnController", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ColumnController"]; });
  45738. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnKeyCreator", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ColumnKeyCreator"]; });
  45739. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnUtils", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ColumnUtils"]; });
  45740. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DisplayedGroupCreator", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["DisplayedGroupCreator"]; });
  45741. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GroupInstanceIdCreator", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GroupInstanceIdCreator"]; });
  45742. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ComponentUtil", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ComponentUtil"]; });
  45743. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColDefUtil", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ColDefUtil"]; });
  45744. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "UserComponentRegistry", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["UserComponentRegistry"]; });
  45745. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "UserComponentFactory", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["UserComponentFactory"]; });
  45746. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "initialiseAgGridWithAngular1", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["initialiseAgGridWithAngular1"]; });
  45747. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "initialiseAgGridWithWebComponents", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["initialiseAgGridWithWebComponents"]; });
  45748. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BeanStub", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["BeanStub"]; });
  45749. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Context", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Context"]; });
  45750. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Autowired", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Autowired"]; });
  45751. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PostConstruct", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["PostConstruct"]; });
  45752. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PreConstruct", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["PreConstruct"]; });
  45753. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Optional", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Optional"]; });
  45754. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Bean", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Bean"]; });
  45755. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Qualifier", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Qualifier"]; });
  45756. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PreDestroy", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["PreDestroy"]; });
  45757. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "QuerySelector", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["QuerySelector"]; });
  45758. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GuiListener", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GuiListener"]; });
  45759. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RefSelector", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RefSelector"]; });
  45760. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridListener", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GridListener"]; });
  45761. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DragAndDropService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["DragAndDropService"]; });
  45762. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DragSourceType", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["DragSourceType"]; });
  45763. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HorizontalDirection", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HorizontalDirection"]; });
  45764. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "VerticalDirection", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["VerticalDirection"]; });
  45765. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DragService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["DragService"]; });
  45766. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Column", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Column"]; });
  45767. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnGroup", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ColumnGroup"]; });
  45768. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "OriginalColumnGroup", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["OriginalColumnGroup"]; });
  45769. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNode", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowNode"]; });
  45770. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "FilterManager", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["FilterManager"]; });
  45771. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ProvidedFilter", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ProvidedFilter"]; });
  45772. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SimpleFilter", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["SimpleFilter"]; });
  45773. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ScalarFilter", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ScalarFilter"]; });
  45774. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "NumberFilter", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["NumberFilter"]; });
  45775. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TextFilter", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["TextFilter"]; });
  45776. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DateFilter", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["DateFilter"]; });
  45777. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridPanel", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GridPanel"]; });
  45778. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ScrollVisibleService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ScrollVisibleService"]; });
  45779. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MouseEventService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["MouseEventService"]; });
  45780. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BodyDropPivotTarget", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["BodyDropPivotTarget"]; });
  45781. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BodyDropTarget", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["BodyDropTarget"]; });
  45782. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CssClassApplier", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["CssClassApplier"]; });
  45783. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderContainer", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HeaderContainer"]; });
  45784. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderRootComp", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HeaderRootComp"]; });
  45785. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderRowComp", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HeaderRowComp"]; });
  45786. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HorizontalResizeService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HorizontalResizeService"]; });
  45787. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MoveColumnController", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["MoveColumnController"]; });
  45788. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "StandardMenuFactory", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["StandardMenuFactory"]; });
  45789. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TabbedLayout", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["TabbedLayout"]; });
  45790. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "simpleHttpRequest", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["simpleHttpRequest"]; });
  45791. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ResizeObserverService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ResizeObserverService"]; });
  45792. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "LargeTextCellEditor", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["LargeTextCellEditor"]; });
  45793. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupEditorWrapper", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["PopupEditorWrapper"]; });
  45794. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupSelectCellEditor", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["PopupSelectCellEditor"]; });
  45795. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupTextCellEditor", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["PopupTextCellEditor"]; });
  45796. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectCellEditor", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["SelectCellEditor"]; });
  45797. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TextCellEditor", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["TextCellEditor"]; });
  45798. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AnimateShowChangeCellRenderer", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AnimateShowChangeCellRenderer"]; });
  45799. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AnimateSlideCellRenderer", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AnimateSlideCellRenderer"]; });
  45800. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GroupCellRenderer", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GroupCellRenderer"]; });
  45801. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SetLeftFeature", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["SetLeftFeature"]; });
  45802. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AutoWidthCalculator", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AutoWidthCalculator"]; });
  45803. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellRendererFactory", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["CellRendererFactory"]; });
  45804. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CheckboxSelectionComponent", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["CheckboxSelectionComponent"]; });
  45805. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellComp", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["CellComp"]; });
  45806. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowComp", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowComp"]; });
  45807. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowRenderer", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowRenderer"]; });
  45808. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ValueFormatterService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ValueFormatterService"]; });
  45809. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PinnedRowModel", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["PinnedRowModel"]; });
  45810. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ChangedPath", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ChangedPath"]; });
  45811. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNodeBlock", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowNodeBlock"]; });
  45812. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNodeBlockLoader", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowNodeBlockLoader"]; });
  45813. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowNodeCache", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowNodeCache"]; });
  45814. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PaginationProxy", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["PaginationProxy"]; });
  45815. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "StylingService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["StylingService"]; });
  45816. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgAbstractField", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgAbstractField"]; });
  45817. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgCheckbox", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgCheckbox"]; });
  45818. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgRadioButton", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgRadioButton"]; });
  45819. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgToggleButton", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgToggleButton"]; });
  45820. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgInputTextField", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgInputTextField"]; });
  45821. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgInputTextArea", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgInputTextArea"]; });
  45822. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgInputNumberField", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgInputNumberField"]; });
  45823. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgInputRange", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgInputRange"]; });
  45824. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgSelect", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgSelect"]; });
  45825. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgSlider", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgSlider"]; });
  45826. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgAngleSelect", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgAngleSelect"]; });
  45827. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgColorPicker", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgColorPicker"]; });
  45828. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgGroupComponent", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgGroupComponent"]; });
  45829. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgDialog", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgDialog"]; });
  45830. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AgPanel", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AgPanel"]; });
  45831. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Component", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Component"]; });
  45832. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ManagedFocusComponent", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ManagedFocusComponent"]; });
  45833. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupComponent", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["PopupComponent"]; });
  45834. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PopupService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["PopupService"]; });
  45835. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TouchListener", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["TouchListener"]; });
  45836. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "VirtualList", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["VirtualList"]; });
  45837. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellRangeType", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["CellRangeType"]; });
  45838. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectionHandleType", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["SelectionHandleType"]; });
  45839. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "VanillaFrameworkOverrides", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["VanillaFrameworkOverrides"]; });
  45840. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellNavigationService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["CellNavigationService"]; });
  45841. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AlignedGridsService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["AlignedGridsService"]; });
  45842. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Constants", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Constants"]; });
  45843. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Grid", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Grid"]; });
  45844. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridApi", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GridApi"]; });
  45845. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Events", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Events"]; });
  45846. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "FocusController", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["FocusController"]; });
  45847. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "defaultGroupComparator", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["defaultGroupComparator"]; });
  45848. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridOptionsWrapper", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GridOptionsWrapper"]; });
  45849. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "EventService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["EventService"]; });
  45850. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectableService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["SelectableService"]; });
  45851. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GridCore", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["GridCore"]; });
  45852. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Logger", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Logger"]; });
  45853. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "LoggerFactory", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["LoggerFactory"]; });
  45854. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SelectionController", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["SelectionController"]; });
  45855. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SortController", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["SortController"]; });
  45856. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TemplateService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["TemplateService"]; });
  45857. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Color", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Color"]; });
  45858. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "stringToArray", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["stringToArray"]; });
  45859. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "_", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["_"]; });
  45860. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "NumberSequence", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["NumberSequence"]; });
  45861. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PromiseStatus", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["PromiseStatus"]; });
  45862. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Promise", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Promise"]; });
  45863. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Timer", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Timer"]; });
  45864. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ValueService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ValueService"]; });
  45865. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ValueCache", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ValueCache"]; });
  45866. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ExpressionService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ExpressionService"]; });
  45867. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "CellPositionUtils", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["CellPositionUtils"]; });
  45868. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RowPositionUtils", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["RowPositionUtils"]; });
  45869. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderPositionUtils", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HeaderPositionUtils"]; });
  45870. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderNavigationService", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HeaderNavigationService"]; });
  45871. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "HeaderNavigationDirection", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["HeaderNavigationDirection"]; });
  45872. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "PropertyKeys", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["PropertyKeys"]; });
  45873. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ColumnApi", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ColumnApi"]; });
  45874. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "BaseComponentWrapper", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["BaseComponentWrapper"]; });
  45875. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Environment", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["Environment"]; });
  45876. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "TooltipFeature", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["TooltipFeature"]; });
  45877. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ChartType", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ChartType"]; });
  45878. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "LegendPosition", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["LegendPosition"]; });
  45879. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ModuleNames", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ModuleNames"]; });
  45880. /* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ModuleRegistry", function() { return _ag_grid_community_core__WEBPACK_IMPORTED_MODULE_3__["ModuleRegistry"]; });
  45881. var AllCommunityModules = [_ag_grid_community_client_side_row_model__WEBPACK_IMPORTED_MODULE_0__["ClientSideRowModelModule"], _ag_grid_community_infinite_row_model__WEBPACK_IMPORTED_MODULE_1__["InfiniteRowModelModule"], _ag_grid_community_csv_export__WEBPACK_IMPORTED_MODULE_2__["CsvExportModule"]];
  45882. /***/ }),
  45883. /* 224 */
  45884. /***/ (function(module, exports, __webpack_require__) {
  45885. var api = __webpack_require__(225);
  45886. var content = __webpack_require__(226);
  45887. content = content.__esModule ? content.default : content;
  45888. if (typeof content === 'string') {
  45889. content = [[module.i, content, '']];
  45890. }
  45891. var options = {};
  45892. options.insert = "head";
  45893. options.singleton = false;
  45894. var update = api(content, options);
  45895. module.exports = content.locals || {};
  45896. /***/ }),
  45897. /* 225 */
  45898. /***/ (function(module, exports, __webpack_require__) {
  45899. "use strict";
  45900. var isOldIE = function isOldIE() {
  45901. var memo;
  45902. return function memorize() {
  45903. if (typeof memo === 'undefined') {
  45904. // Test for IE <= 9 as proposed by Browserhacks
  45905. // @see http://browserhacks.com/#hack-e71d8692f65334173fee715c222cb805
  45906. // Tests for existence of standard globals is to allow style-loader
  45907. // to operate correctly into non-standard environments
  45908. // @see https://github.com/webpack-contrib/style-loader/issues/177
  45909. memo = Boolean(window && document && document.all && !window.atob);
  45910. }
  45911. return memo;
  45912. };
  45913. }();
  45914. var getTarget = function getTarget() {
  45915. var memo = {};
  45916. return function memorize(target) {
  45917. if (typeof memo[target] === 'undefined') {
  45918. var styleTarget = document.querySelector(target); // Special case to return head of iframe instead of iframe itself
  45919. if (window.HTMLIFrameElement && styleTarget instanceof window.HTMLIFrameElement) {
  45920. try {
  45921. // This will throw an exception if access to iframe is blocked
  45922. // due to cross-origin restrictions
  45923. styleTarget = styleTarget.contentDocument.head;
  45924. } catch (e) {
  45925. // istanbul ignore next
  45926. styleTarget = null;
  45927. }
  45928. }
  45929. memo[target] = styleTarget;
  45930. }
  45931. return memo[target];
  45932. };
  45933. }();
  45934. var stylesInDom = [];
  45935. function getIndexByIdentifier(identifier) {
  45936. var result = -1;
  45937. for (var i = 0; i < stylesInDom.length; i++) {
  45938. if (stylesInDom[i].identifier === identifier) {
  45939. result = i;
  45940. break;
  45941. }
  45942. }
  45943. return result;
  45944. }
  45945. function modulesToDom(list, options) {
  45946. var idCountMap = {};
  45947. var identifiers = [];
  45948. for (var i = 0; i < list.length; i++) {
  45949. var item = list[i];
  45950. var id = options.base ? item[0] + options.base : item[0];
  45951. var count = idCountMap[id] || 0;
  45952. var identifier = "".concat(id, " ").concat(count);
  45953. idCountMap[id] = count + 1;
  45954. var index = getIndexByIdentifier(identifier);
  45955. var obj = {
  45956. css: item[1],
  45957. media: item[2],
  45958. sourceMap: item[3]
  45959. };
  45960. if (index !== -1) {
  45961. stylesInDom[index].references++;
  45962. stylesInDom[index].updater(obj);
  45963. } else {
  45964. stylesInDom.push({
  45965. identifier: identifier,
  45966. updater: addStyle(obj, options),
  45967. references: 1
  45968. });
  45969. }
  45970. identifiers.push(identifier);
  45971. }
  45972. return identifiers;
  45973. }
  45974. function insertStyleElement(options) {
  45975. var style = document.createElement('style');
  45976. var attributes = options.attributes || {};
  45977. if (typeof attributes.nonce === 'undefined') {
  45978. var nonce = true ? __webpack_require__.nc : undefined;
  45979. if (nonce) {
  45980. attributes.nonce = nonce;
  45981. }
  45982. }
  45983. Object.keys(attributes).forEach(function (key) {
  45984. style.setAttribute(key, attributes[key]);
  45985. });
  45986. if (typeof options.insert === 'function') {
  45987. options.insert(style);
  45988. } else {
  45989. var target = getTarget(options.insert || 'head');
  45990. if (!target) {
  45991. throw new Error("Couldn't find a style target. This probably means that the value for the 'insert' parameter is invalid.");
  45992. }
  45993. target.appendChild(style);
  45994. }
  45995. return style;
  45996. }
  45997. function removeStyleElement(style) {
  45998. // istanbul ignore if
  45999. if (style.parentNode === null) {
  46000. return false;
  46001. }
  46002. style.parentNode.removeChild(style);
  46003. }
  46004. /* istanbul ignore next */
  46005. var replaceText = function replaceText() {
  46006. var textStore = [];
  46007. return function replace(index, replacement) {
  46008. textStore[index] = replacement;
  46009. return textStore.filter(Boolean).join('\n');
  46010. };
  46011. }();
  46012. function applyToSingletonTag(style, index, remove, obj) {
  46013. var css = remove ? '' : obj.media ? "@media ".concat(obj.media, " {").concat(obj.css, "}") : obj.css; // For old IE
  46014. /* istanbul ignore if */
  46015. if (style.styleSheet) {
  46016. style.styleSheet.cssText = replaceText(index, css);
  46017. } else {
  46018. var cssNode = document.createTextNode(css);
  46019. var childNodes = style.childNodes;
  46020. if (childNodes[index]) {
  46021. style.removeChild(childNodes[index]);
  46022. }
  46023. if (childNodes.length) {
  46024. style.insertBefore(cssNode, childNodes[index]);
  46025. } else {
  46026. style.appendChild(cssNode);
  46027. }
  46028. }
  46029. }
  46030. function applyToTag(style, options, obj) {
  46031. var css = obj.css;
  46032. var media = obj.media;
  46033. var sourceMap = obj.sourceMap;
  46034. if (media) {
  46035. style.setAttribute('media', media);
  46036. } else {
  46037. style.removeAttribute('media');
  46038. }
  46039. if (sourceMap && btoa) {
  46040. css += "\n/*# sourceMappingURL=data:application/json;base64,".concat(btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))), " */");
  46041. } // For old IE
  46042. /* istanbul ignore if */
  46043. if (style.styleSheet) {
  46044. style.styleSheet.cssText = css;
  46045. } else {
  46046. while (style.firstChild) {
  46047. style.removeChild(style.firstChild);
  46048. }
  46049. style.appendChild(document.createTextNode(css));
  46050. }
  46051. }
  46052. var singleton = null;
  46053. var singletonCounter = 0;
  46054. function addStyle(obj, options) {
  46055. var style;
  46056. var update;
  46057. var remove;
  46058. if (options.singleton) {
  46059. var styleIndex = singletonCounter++;
  46060. style = singleton || (singleton = insertStyleElement(options));
  46061. update = applyToSingletonTag.bind(null, style, styleIndex, false);
  46062. remove = applyToSingletonTag.bind(null, style, styleIndex, true);
  46063. } else {
  46064. style = insertStyleElement(options);
  46065. update = applyToTag.bind(null, style, options);
  46066. remove = function remove() {
  46067. removeStyleElement(style);
  46068. };
  46069. }
  46070. update(obj);
  46071. return function updateStyle(newObj) {
  46072. if (newObj) {
  46073. if (newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap) {
  46074. return;
  46075. }
  46076. update(obj = newObj);
  46077. } else {
  46078. remove();
  46079. }
  46080. };
  46081. }
  46082. module.exports = function (list, options) {
  46083. options = options || {}; // Force single-tag solution on IE6-9, which has a hard limit on the # of <style>
  46084. // tags it will allow on a page
  46085. if (!options.singleton && typeof options.singleton !== 'boolean') {
  46086. options.singleton = isOldIE();
  46087. }
  46088. list = list || [];
  46089. var lastIdentifiers = modulesToDom(list, options);
  46090. return function update(newList) {
  46091. newList = newList || [];
  46092. if (Object.prototype.toString.call(newList) !== '[object Array]') {
  46093. return;
  46094. }
  46095. for (var i = 0; i < lastIdentifiers.length; i++) {
  46096. var identifier = lastIdentifiers[i];
  46097. var index = getIndexByIdentifier(identifier);
  46098. stylesInDom[index].references--;
  46099. }
  46100. var newLastIdentifiers = modulesToDom(newList, options);
  46101. for (var _i = 0; _i < lastIdentifiers.length; _i++) {
  46102. var _identifier = lastIdentifiers[_i];
  46103. var _index = getIndexByIdentifier(_identifier);
  46104. if (stylesInDom[_index].references === 0) {
  46105. stylesInDom[_index].updater();
  46106. stylesInDom.splice(_index, 1);
  46107. }
  46108. }
  46109. lastIdentifiers = newLastIdentifiers;
  46110. };
  46111. };
  46112. /***/ }),
  46113. /* 226 */
  46114. /***/ (function(module, exports, __webpack_require__) {
  46115. // Imports
  46116. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227);
  46117. exports = ___CSS_LOADER_API_IMPORT___(false);
  46118. // Module
  46119. exports.push([module.i, "/**\n ****************************\n * Generic Styles\n ****************************\n*/\nag-grid, ag-grid-angular, ag-grid-ng2, ag-grid-polymer, ag-grid-aurelia {\n display: block; }\n\n.ag-hidden {\n display: none !important; }\n\n.ag-invisible {\n visibility: hidden !important; }\n\n.ag-drag-handle {\n cursor: move;\n cursor: -webkit-grab;\n cursor: grab; }\n\n.ag-column-drop-wrapper {\n display: flex; }\n\n.ag-column-drop-horizontal-half-width {\n display: inline-block;\n width: 50% !important; }\n\n.ag-unselectable {\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n\n.ag-selectable {\n -moz-user-select: text;\n -webkit-user-select: text;\n -ms-user-select: text;\n user-select: text; }\n\n.ag-tab {\n position: relative; }\n\n.ag-tab-guard {\n position: absolute;\n width: 0;\n height: 0;\n display: block; }\n\n.ag-select-agg-func-popup {\n position: absolute; }\n\n.ag-input-wrapper, .ag-picker-field-wrapper {\n display: flex;\n flex: 1 1 auto;\n align-items: center;\n line-height: normal;\n position: relative; }\n\n.ag-shake-left-to-right {\n -webkit-animation-direction: alternate;\n animation-direction: alternate;\n -webkit-animation-duration: 0.2s;\n animation-duration: 0.2s;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-name: ag-shake-left-to-right;\n animation-name: ag-shake-left-to-right; }\n\n@-webkit-keyframes ag-shake-left-to-right {\n from {\n padding-left: 6px;\n padding-right: 2px; }\n to {\n padding-left: 2px;\n padding-right: 6px; } }\n\n@keyframes ag-shake-left-to-right {\n from {\n padding-left: 6px;\n padding-right: 2px; }\n to {\n padding-left: 2px;\n padding-right: 6px; } }\n\n.ag-root-wrapper {\n cursor: default;\n position: relative;\n display: flex;\n flex-direction: column;\n overflow: hidden; }\n .ag-root-wrapper.ag-layout-normal {\n height: 100%; }\n\n.ag-watermark {\n position: absolute;\n bottom: 10px;\n right: 25px;\n opacity: 0.5;\n transition: opacity 1s ease-out 3s; }\n .ag-watermark:before {\n content: '';\n background-image: url(data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iVVRGLTgiPz4KPHN2ZyB3aWR0aD0iNDk0cHgiIGhlaWdodD0iMjM5cHgiIHZpZXdCb3g9IjAgMCA0OTQgMjM5IiB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiPgogICAgPCEtLSBHZW5lcmF0b3I6IFNrZXRjaCA0Ny4xICg0NTQyMikgLSBodHRwOi8vd3d3LmJvaGVtaWFuY29kaW5nLmNvbS9za2V0Y2ggLS0+CiAgICA8dGl0bGU+TG9nbzwvdGl0bGU+CiAgICA8ZGVzYz5DcmVhdGVkIHdpdGggU2tldGNoLjwvZGVzYz4KICAgIDxkZWZzPgogICAgICAgIDxwYXRoIGQ9Ik0wLjYxMjg0OTkzMSwxMDggTDAuNjEyODQ5OTMxLDY3LjQ1OTYzNzQgTDAuNjEyODQ5OTMxLDY3LjQ1OTYzNzQgQzAuNjEyODQ5OTMxLDYyLjEwMDY1MzYgMy40NzE4MzM3OCw1Ny4xNDg3NDgzIDguMTEyODQ5OTMsNTQuNDY5MjU2NCBMOTguMzA2NDI1LDIuMzk1OTcxNTcgTDk4LjMwNjQyNSwyLjM5NTk3MTU3IEMxMDIuOTQ3NDQxLC0wLjI4MzUyMDM1OCAxMDguNjY1NDA5LC0wLjI4MzUyMDM1OCAxMTMuMzA2NDI1LDIuMzk1OTcxNTcgTDExMy4zMDY0MjUsMi4zOTU5NzE1NyBMMjAzLjUsNTQuNDY5MjU2NCBMMjAzLjUsNTQuNDY5MjU2NCBDMjA4LjE0MTAxNiw1Ny4xNDg3NDgzIDIxMSw2Mi4xMDA2NTM2IDIxMSw2Ny40NTk2Mzc0IEwyMTEsMTM4IEwxODEsMTM4IEwxODAuOTk3MDQxLDkzLjk5OTk5OTggTDE4MC45OTYwMzIsOTMuOTk5OTk5OSBDMTgwLjk5NTQ3NSw4NS43MTYxMjI2IDE3NC4yNzk5MDksNzkuMDAxMDA4NyAxNjUuOTk2MDMyLDc5LjAwMTAwODcgTDEyMiw3OC45OTk5OTk5IEMxMTMuNzE1NzI5LDc4Ljk5OTk5OTkgMTA3LDg1LjcxNTcyODYgMTA3LDkzLjk5OTk5OTkgTDEwNywxMzYuMDE1NjIzIEwxMDcsMTM2LjAxNTYyMyBDMTA3LDE0NC4yOTk4OTUgMTEzLjcxNTcyOSwxNTEuMDE1NjIzIDEyMiwxNTEuMDE1NjIzIEwxNjgsMTUxLjAxNTYyMyBMMTY4LDE2MyBDMTY4LDE2NC42NTY4NTQgMTY2LjY1Njg1NCwxNjYgMTY1LDE2NiBMMTIwLDE2NiBMMTIwLDE3OSBMMTY1Ljk5NjAzMiwxNzkgTDE2NS45OTYwMzIsMTc4Ljk5Nzg3NyBDMTc0LjI3OTQ3NCwxNzguOTk3ODc3IDE4MC45OTQ4NiwxNzIuMjgzNDQyIDE4MC45OTYwMzIsMTY0IEwxODEsMTUwLjk2MDU1NCBMMjExLDE1MC45NjA1NTQgTDIxMSwxNzEuNjA2MjA3IEwyMTEsMTcxLjYwNjIwNyBDMjExLDE3Ni45NjUxOTEgMjA4LjE0MTAxNiwxODEuOTE3MDk2IDIwMy41LDE4NC41OTY1ODggTDExMy4zMDY0MjUsMjM2LjY2OTg3MyBMMTEzLjMwNjQyNSwyMzYuNjY5ODczIEMxMDguNjY1NDA5LDIzOS4zNDkzNjUgMTAyLjk0NzQ0MSwyMzkuMzQ5MzY1IDk4LjMwNjQyNSwyMzYuNjY5ODczIEw4LjExMjg0OTkzLDE4NC41OTY1ODggTDguMTEyODQ5OTMsMTg0LjU5NjU4OCBDMy40NzE4MzM3OCwxODEuOTE3MDk2IDAuNjEyODQ5OTMxLDE3Ni45NjUxOTEgMC42MTI4NDk5MzEsMTcxLjYwNjIwNyBMMC42MTI4NDk5MzEsMTIxIEwyNywxMjEgTDI3LDEzNiBDMjcsMTQ0LjI4NDI3MSAzMy43MTU3Mjg3LDE1MSA0MiwxNTEgTDQyLDE1MSBMMTAwLDE1MSBMMTAwLDk0IEMxMDAsODUuNzE1NzI4OCA5My4yODQyNzEyLDc5IDg1LDc5IEwyNyw3OSBMMjcsOTIgTDg0LDkyIEM4NS42NTY4NTQyLDkyIDg3LDkzLjM0MzE0NTggODcsOTUgTDg3LDk1IEw4NywxMDggTDAuNjEyODQ5OTMxLDEwOCBaIiBpZD0icGF0aC0xIj48L3BhdGg+CiAgICA8L2RlZnM+CiAgICA8ZyBpZD0iU3ltYm9scyIgc3Ryb2tlPSJub25lIiBzdHJva2Utd2lkdGg9IjEiIGZpbGw9Im5vbmUiIGZpbGwtcnVsZT0iZXZlbm9kZCI+CiAgICAgICAgPGcgaWQ9IkxvZ28iPgogICAgICAgICAgICA8cGF0aCBkPSJNNDc3LDU1IEw0OTQsNTUgTDQ5NCwxNTEgTDQzNSwxNTEgQzQyNi43MTU3MjksMTUxIDQyMCwxNDQuMjg0MjcxIDQyMCwxMzYgTDQyMCw5NiBDNDIwLDg3LjcxNTcyODggNDI2LjcxNTcyOSw4MSA0MzUsODEgTDQzNSw4MSBMNDc3LDgxIEw0NzcsNTUgWiBNNDQwLDk4IEM0MzguMzQzMTQ2LDk4IDQzNyw5OS4zNDMxNDU4IDQzNywxMDEgTDQzNywxMzEgQzQzNywxMzIuNjU2ODU0IDQzOC4zNDMxNDYsMTM0IDQ0MCwxMzQgTDQ3NywxMzQgTDQ3Nyw5OCBMNDQwLDk4IFoiIGlkPSJkIiBmaWxsPSIjRkZGRkZGIj48L3BhdGg+CiAgICAgICAgICAgIDxnIGlkPSJpIiB0cmFuc2Zvcm09InRyYW5zbGF0ZSgzOTYuMDAwMDAwLCA1NS4wMDAwMDApIj4KICAgICAgICAgICAgICAgIDxwb2x5Z29uIGlkPSJQYXRoLTYiIGZpbGw9IiNGRkZGRkYiIHBvaW50cz0iMCAyNiAxNyAyNiAxNyA5NiAwIDk2Ij48L3BvbHlnb24+CiAgICAgICAgICAgICAgICA8cG9seWdvbiBpZD0iUGF0aC03IiBmaWxsPSIjRTExRjIyIiBwb2ludHM9IjAgMS4xMzY4NjgzOGUtMTMgMTcgMS4xMzY4NjgzOGUtMTMgMTcgMTcgMCAxNyI+PC9wb2x5Z29uPgogICAgICAgICAgICA8L2c+CiAgICAgICAgICAgIDxwYXRoIGQ9Ik0zMzEsMTUxIEwzNDgsMTUxIEwzNDgsMTAxIEwzNDgsMTAxIEMzNDgsOTkuMzQzMTQ1OCAzNDkuMzQzMTQ2LDk4IDM1MSw5OCBMMzg5LDk4IEwzODksODEgTDM0Niw4MSBMMzQ2LDgxIEMzMzcuNzE1NzI5LDgxIDMzMSw4Ny43MTU3Mjg4IDMzMSw5NiBMMzMxLDE1MSBaIiBpZD0iciIgZmlsbD0iI0ZGRkZGRiI+PC9wYXRoPgogICAgICAgICAgICA8cGF0aCBkPSJNMzI0LDg2IEwzMjQsNzYgTDMyNCw3NiBDMzI0LDY3LjcxNTcyODggMzE3LjI4NDI3MSw2MSAzMDksNjEgTDI0OSw2MSBMMjQ5LDYxIEMyNDAuNzE1NzI5LDYxIDIzNCw2Ny43MTU3Mjg4IDIzNCw3NiBMMjM0LDEzNiBMMjM0LDEzNiBDMjM0LDE0NC4yODQyNzEgMjQwLjcxNTcyOSwxNTEgMjQ5LDE1MSBMMzA5LDE1MSBMMzA5LDE1MSBDMzE3LjI4NDI3MSwxNTEgMzI0LDE0NC4yODQyNzEgMzI0LDEzNiBMMzI0LDEwMCBMMjg3LDEwMCBMMjg3LDExNyBMMzA3LDExNyBMMzA3LDEzMSBMMzA3LDEzMSBDMzA3LDEzMi42NTY4NTQgMzA1LjY1Njg1NCwxMzQgMzA0LDEzNCBMMjU0LDEzNCBMMjU0LDEzNCBDMjUyLjM0MzE0NiwxMzQgMjUxLDEzMi42NTY4NTQgMjUxLDEzMSBMMjUxLDgxIEwyNTEsODEgQzI1MSw3OS4zNDMxNDU4IDI1Mi4zNDMxNDYsNzggMjU0LDc4IEwzMDQsNzggTDMwNCw3OCBDMzA1LjY1Njg1NCw3OCAzMDcsNzkuMzQzMTQ1OCAzMDcsODEgTDMwNyw4NiBMMzI0LDg2IFoiIGlkPSJHIiBmaWxsPSIjRkZGRkZGIj48L3BhdGg+CiAgICAgICAgICAgIDxnIGlkPSJhZyI+CiAgICAgICAgICAgICAgICA8ZyBpZD0iQ29tYmluZWQtU2hhcGUiPgogICAgICAgICAgICAgICAgICAgIDxtYXNrIGlkPSJtYXNrLTIiIGZpbGw9IndoaXRlIj4KICAgICAgICAgICAgICAgICAgICAgICAgPHVzZSB4bGluazpocmVmPSIjcGF0aC0xIj48L3VzZT4KICAgICAgICAgICAgICAgICAgICA8L21hc2s+CiAgICAgICAgICAgICAgICAgICAgPHVzZSBmaWxsPSIjRTExRjIyIiB4bGluazpocmVmPSIjcGF0aC0xIj48L3VzZT4KICAgICAgICAgICAgICAgIDwvZz4KICAgICAgICAgICAgICAgIDxyZWN0IGlkPSJnIiBmaWxsPSIjRTExRjIyIiB4PSIxMjAiIHk9IjkyIiB3aWR0aD0iNDgiIGhlaWdodD0iNDYiIHJ4PSIzIj48L3JlY3Q+CiAgICAgICAgICAgICAgICA8cGF0aCBkPSJNNDAsMTIxIEw4NywxMjEgTDg3LDEzOCBMNDMsMTM4IEw0MywxMzggQzQxLjM0MzE0NTgsMTM4IDQwLDEzNi42NTY4NTQgNDAsMTM1IEw0MCwxMjEgWiIgaWQ9IkNvbWJpbmVkLVNoYXBlIiBmaWxsPSIjRTExRjIyIj48L3BhdGg+CiAgICAgICAgICAgIDwvZz4KICAgICAgICA8L2c+CiAgICA8L2c+Cjwvc3ZnPg==);\n -webkit-filter: invert(50%);\n filter: invert(50%);\n background-repeat: no-repeat;\n background-size: 110px 60px;\n display: block;\n height: 60px;\n width: 110px; }\n\n.ag-watermark-text {\n opacity: 0.5;\n font-weight: bold;\n font-family: Impact, sans-serif;\n font-size: 19px; }\n\n.ag-root-wrapper-body {\n display: flex;\n flex-direction: row; }\n .ag-root-wrapper-body.ag-layout-normal {\n flex: 1 1 auto;\n height: 0;\n min-height: 0; }\n\n.ag-root {\n position: relative;\n display: flex;\n flex-direction: column; }\n .ag-root.ag-layout-normal, .ag-root.ag-layout-auto-height {\n overflow: hidden;\n flex: 1 1 auto;\n width: 0; }\n .ag-root.ag-layout-normal {\n height: 100%; }\n\n/**\n ****************************\n * Viewports\n ****************************\n*/\n.ag-header-viewport,\n.ag-floating-top-viewport,\n.ag-body-viewport,\n.ag-center-cols-viewport,\n.ag-floating-bottom-viewport,\n.ag-body-horizontal-scroll-viewport,\n.ag-virtual-list-viewport {\n position: relative;\n height: 100%;\n min-width: 0px;\n overflow: hidden;\n flex: 1 1 auto; }\n\n.ag-body-viewport.ag-layout-print {\n flex: none; }\n\n@media print {\n .ag-layout-normal {\n display: none; }\n .ag-root-wrapper,\n .ag-root-wrapper-body,\n .ag-root,\n .ag-body-viewport,\n .ag-center-cols-container,\n .ag-center-cols-viewport,\n .ag-center-cols-clipper,\n .ag-body-horizontal-scroll-viewport,\n .ag-virtual-list-viewport {\n height: auto !important;\n overflow: hidden !important;\n display: block !important; }\n .ag-row {\n page-break-inside: avoid; } }\n\n.ag-body-viewport {\n display: flex; }\n .ag-body-viewport.ag-layout-normal {\n overflow-y: auto;\n -webkit-overflow-scrolling: touch; }\n\n.ag-center-cols-viewport {\n width: 100%;\n overflow-x: auto; }\n\n.ag-body-horizontal-scroll-viewport {\n overflow-x: scroll; }\n\n.ag-virtual-list-viewport {\n overflow: auto;\n width: 100%; }\n\n/**\n ****************************\n * Containers\n ****************************\n*/\n.ag-header-container,\n.ag-floating-top-container,\n.ag-body-container,\n.ag-pinned-right-cols-container,\n.ag-center-cols-container,\n.ag-pinned-left-cols-container,\n.ag-floating-bottom-container,\n.ag-body-horizontal-scroll-container,\n.ag-full-width-container,\n.ag-floating-bottom-full-width-container,\n.ag-virtual-list-container {\n position: relative; }\n\n.ag-header-container, .ag-floating-top-container, .ag-floating-bottom-container {\n height: 100%;\n white-space: nowrap; }\n\n.ag-center-cols-clipper {\n min-height: 100%; }\n\n.ag-center-cols-container {\n display: block; }\n\n.ag-layout-print .ag-center-cols-clipper {\n min-width: 100%; }\n\n.ag-layout-auto-height .ag-center-cols-clipper,\n.ag-layout-auto-height .ag-center-cols-container {\n min-height: 50px; }\n\n.ag-pinned-right-cols-container {\n display: block; }\n\n.ag-body-horizontal-scroll-container {\n height: 100%; }\n\n.ag-full-width-container,\n.ag-floating-top-full-width-container,\n.ag-floating-bottom-full-width-container {\n position: absolute;\n top: 0px;\n left: 0px;\n pointer-events: none; }\n\n.ag-full-width-container {\n width: 100%; }\n\n.ag-floating-bottom-full-width-container, .ag-floating-top-full-width-container {\n display: inline-block;\n overflow: hidden;\n height: 100%;\n width: 100%; }\n\n.ag-virtual-list-container {\n overflow: hidden; }\n\n/**\n ****************************\n * Scrollers\n ****************************\n*/\n.ag-center-cols-clipper {\n flex: 1;\n min-width: 0;\n overflow: hidden; }\n\n.ag-body-horizontal-scroll {\n min-height: 0;\n min-width: 0;\n width: 100%;\n display: flex;\n position: relative; }\n\n.ag-layout-print .ag-body-horizontal-scroll {\n display: none; }\n\n.ag-force-vertical-scroll {\n overflow-y: scroll !important; }\n .ag-force-vertical-scroll.ag-layout-print {\n overflow-y: visible !important; }\n\n.ag-horizontal-left-spacer, .ag-horizontal-right-spacer {\n height: 100%;\n min-width: 0;\n overflow-x: scroll; }\n .ag-horizontal-left-spacer.ag-scroller-corner, .ag-horizontal-right-spacer.ag-scroller-corner {\n overflow-x: hidden; }\n\n/**\n ****************************\n * Headers\n ****************************\n*/\n.ag-header, .ag-pinned-left-header, .ag-pinned-right-header {\n display: inline-block;\n overflow: hidden;\n position: relative; }\n\n.ag-header-cell-sortable {\n cursor: pointer; }\n\n.ag-header {\n display: flex;\n width: 100%;\n white-space: nowrap; }\n\n.ag-pinned-left-header {\n height: 100%; }\n\n.ag-pinned-right-header {\n height: 100%; }\n\n.ag-header-row {\n position: absolute;\n overflow: hidden; }\n\n.ag-header-cell {\n display: inline-flex;\n align-items: center;\n position: absolute;\n height: 100%; }\n\n.ag-header-group-cell-label, .ag-header-cell-label {\n display: flex;\n flex: 1 1 auto;\n overflow: hidden;\n align-items: center;\n text-overflow: ellipsis;\n align-self: stretch; }\n\n.ag-header-cell-text {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap; }\n\n.ag-right-aligned-header .ag-header-cell-label {\n flex-direction: row-reverse; }\n\n.ag-header-group-text {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap; }\n\n.ag-header-cell-resize {\n position: absolute;\n z-index: 2;\n height: 100%;\n width: 8px;\n top: 0;\n cursor: ew-resize; }\n .ag-ltr .ag-header-cell-resize {\n right: -4px; }\n .ag-rtl .ag-header-cell-resize {\n left: -4px; }\n\n.ag-pinned-left-header .ag-header-cell-resize {\n right: -4px; }\n\n.ag-pinned-right-header .ag-header-cell-resize {\n left: -4px; }\n\n.ag-header-select-all {\n display: flex; }\n\n/**\n ****************************\n * Columns\n ****************************\n*/\n.ag-column-moving .ag-cell {\n transition: left 0.2s; }\n\n.ag-column-moving .ag-header-cell {\n transition: left 0.2s; }\n\n.ag-column-moving .ag-header-group-cell {\n transition: left 0.2s, width 0.2s; }\n\n/**\n ****************************\n * Column Panel\n ****************************\n*/\n.ag-column-panel {\n display: flex;\n flex-direction: column;\n overflow: hidden;\n flex: 1 1 auto; }\n\n.ag-column-select {\n display: flex;\n flex-direction: column;\n overflow: hidden;\n flex-grow: 3;\n flex-shrink: 1;\n flex-basis: 0; }\n\n.ag-column-select-header {\n position: relative;\n display: flex;\n flex: none; }\n\n.ag-column-select-header-icon {\n position: relative; }\n\n.ag-column-select-header-filter-wrapper {\n flex: 1 1 auto; }\n\n.ag-column-select-header-filter {\n width: 100%; }\n\n.ag-column-select-list {\n flex: 1 1 auto;\n overflow: auto; }\n\n.ag-column-drop {\n display: inline-flex;\n align-items: center;\n overflow: auto;\n width: 100%; }\n\n.ag-column-drop-list {\n display: flex;\n align-items: center; }\n\n.ag-column-drop-cell {\n display: flex;\n align-items: center; }\n\n.ag-column-drop-cell-text {\n overflow: hidden;\n flex: 1 1 auto;\n text-overflow: ellipsis;\n white-space: nowrap; }\n\n.ag-column-drop-vertical {\n display: flex;\n flex-direction: column;\n overflow: hidden;\n flex: 1 1 0;\n align-items: stretch; }\n\n.ag-column-drop-vertical-title-bar {\n display: flex;\n align-items: center; }\n\n.ag-column-drop-vertical-list {\n align-items: stretch;\n flex-grow: 1;\n flex-direction: column;\n overflow-x: auto; }\n .ag-column-drop-vertical-list > * {\n flex: none; }\n\n.ag-column-drop-empty .ag-column-drop-vertical-list {\n overflow: hidden; }\n\n.ag-column-drop-vertical-empty-message {\n display: block; }\n\n.ag-column-drop.ag-column-drop-horizontal {\n white-space: nowrap;\n overflow: hidden; }\n\n.ag-column-drop-cell-button {\n cursor: pointer; }\n\n.ag-filter-toolpanel {\n flex: 1 1 0px;\n min-width: 0; }\n\n.ag-filter-toolpanel-header {\n position: relative; }\n\n.ag-filter-toolpanel-header, .ag-filter-toolpanel-search {\n display: flex;\n align-items: center; }\n .ag-filter-toolpanel-header > *, .ag-filter-toolpanel-search > * {\n display: flex;\n align-items: center; }\n\n.ag-filter-apply-panel {\n display: flex;\n justify-content: flex-end;\n overflow: hidden; }\n\n/**\n ****************************\n * Rows\n ****************************\n*/\n.ag-row-animation .ag-row {\n transition: top 0.4s, height 0.4s, background-color 0.1s, opacity 0.2s, -webkit-transform 0.4s;\n transition: transform 0.4s, top 0.4s, height 0.4s, background-color 0.1s, opacity 0.2s;\n transition: transform 0.4s, top 0.4s, height 0.4s, background-color 0.1s, opacity 0.2s, -webkit-transform 0.4s; }\n\n.ag-row-no-animation .ag-row {\n transition: background-color 0.1s; }\n\n.ag-row {\n white-space: nowrap;\n width: 100%; }\n\n.ag-row-loading {\n display: flex;\n align-items: center; }\n\n.ag-row-position-absolute {\n position: absolute; }\n\n.ag-row-position-relative {\n position: relative; }\n\n.ag-full-width-row {\n overflow: hidden;\n pointer-events: all; }\n\n.ag-row-inline-editing {\n z-index: 1; }\n\n.ag-row-dragging {\n z-index: 2; }\n\n.ag-stub-cell {\n display: flex;\n align-items: center; }\n\n/**\n ****************************\n * Cells\n ****************************\n*/\n.ag-cell {\n display: inline-block;\n position: absolute;\n white-space: nowrap; }\n\n.ag-cell-value, .ag-group-value {\n overflow: hidden;\n text-overflow: ellipsis; }\n\n.ag-cell-wrapper {\n display: flex;\n align-items: center;\n height: 100%; }\n .ag-cell-wrapper.ag-row-group {\n align-items: flex-start; }\n\n.ag-full-width-row .ag-cell-wrapper.ag-row-group {\n align-items: center; }\n\n.ag-cell-auto-height {\n height: 100%; }\n\n.ag-cell-inline-editing {\n z-index: 1; }\n .ag-cell-inline-editing .ag-cell-edit-wrapper,\n .ag-cell-inline-editing .ag-cell-editor,\n .ag-cell-inline-editing .ag-cell-editor .ag-wrapper,\n .ag-cell-inline-editing .ag-cell-editor input {\n height: 100%;\n width: 100%;\n line-height: normal; }\n\n.ag-cell .ag-icon {\n display: inline-block;\n vertical-align: middle; }\n\n/**\n ****************************\n * Filters\n ****************************\n*/\n.ag-set-filter-item {\n display: flex;\n align-items: center;\n height: 100%; }\n\n.ag-set-filter-item-value {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap; }\n\n.ag-set-filter-item-checkbox {\n display: flex;\n pointer-events: none; }\n\n.ag-filter-body-wrapper {\n display: flex;\n flex-direction: column; }\n\n.ag-filter-filter {\n flex: 1 1 auto;\n overflow: hidden; }\n\n.ag-filter-condition {\n display: flex; }\n\n/**\n ****************************\n * Floating Filter\n ****************************\n*/\n.ag-floating-filter-body {\n position: relative;\n display: flex;\n flex: 1 1 auto;\n height: 100%; }\n\n.ag-floating-filter-full-body {\n display: flex;\n flex: 1 1 auto;\n height: 100%;\n width: 100%;\n align-items: center;\n overflow: hidden; }\n\n.ag-floating-filter-full-body > div {\n flex: 1 1 auto; }\n\n.ag-floating-filter {\n display: inline-block;\n position: absolute; }\n\n.ag-floating-filter-input {\n align-items: center;\n display: flex;\n width: 100%; }\n .ag-floating-filter-input > * {\n flex: 1 1 auto; }\n\n.ag-floating-filter-button {\n display: flex;\n flex: none; }\n\n/**\n ****************************\n * Drag & Drop\n ****************************\n*/\n.ag-dnd-ghost {\n position: absolute;\n display: inline-flex;\n align-items: center;\n cursor: move;\n white-space: nowrap; }\n\n/**\n ****************************\n * Overlay\n ****************************\n*/\n.ag-overlay {\n height: 100%;\n left: 0;\n pointer-events: none;\n position: absolute;\n top: 0;\n width: 100%; }\n\n.ag-overlay-panel {\n display: flex;\n height: 100%;\n width: 100%; }\n\n.ag-overlay-wrapper {\n display: flex;\n flex: none;\n width: 100%;\n height: 100%;\n align-items: center;\n justify-content: center;\n text-align: center; }\n\n.ag-overlay-loading-wrapper {\n pointer-events: all; }\n\n/**\n ****************************\n * Popup\n ****************************\n*/\n.ag-popup-child {\n z-index: 5; }\n\n.ag-popup-editor {\n position: absolute;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n z-index: 1; }\n\n.ag-large-text-input {\n display: block; }\n\n/**\n ****************************\n * Virtual Lists\n ****************************\n*/\n.ag-virtual-list-item {\n position: absolute;\n width: 100%; }\n\n/**\n ****************************\n * Floating Top and Bottom\n ****************************\n*/\n.ag-floating-top {\n overflow: hidden;\n white-space: nowrap;\n width: 100%;\n position: relative;\n display: flex; }\n\n.ag-pinned-left-floating-top {\n display: inline-block;\n overflow: hidden;\n position: relative;\n min-width: 0px; }\n\n.ag-pinned-right-floating-top {\n display: inline-block;\n overflow: hidden;\n position: relative;\n min-width: 0px; }\n\n.ag-floating-bottom {\n overflow: hidden;\n white-space: nowrap;\n width: 100%;\n position: relative;\n display: flex; }\n\n.ag-pinned-left-floating-bottom {\n display: inline-block;\n overflow: hidden;\n position: relative;\n min-width: 0px; }\n\n.ag-pinned-right-floating-bottom {\n display: inline-block;\n overflow: hidden;\n position: relative;\n min-width: 0px; }\n\n/**\n ****************************\n * Dialog\n ****************************\n*/\n.ag-dialog, .ag-panel {\n display: flex;\n flex-direction: column;\n position: relative;\n overflow: hidden; }\n\n.ag-panel-title-bar {\n display: flex;\n flex: none;\n align-items: center;\n cursor: default; }\n\n.ag-panel-title-bar-title {\n flex: 1 1 auto; }\n\n.ag-panel-title-bar-buttons {\n display: flex; }\n\n.ag-panel-title-bar-button {\n cursor: pointer; }\n\n.ag-panel-content-wrapper {\n display: flex;\n flex: 1 1 auto;\n position: relative;\n overflow: hidden; }\n\n.ag-dialog {\n position: absolute; }\n\n.ag-resizer {\n position: absolute;\n pointer-events: none;\n z-index: 1; }\n .ag-resizer.ag-resizer-topLeft {\n top: 0;\n left: 0;\n height: 5px;\n width: 5px;\n cursor: nwse-resize; }\n .ag-resizer.ag-resizer-top {\n top: 0;\n left: 5px;\n right: 5px;\n height: 5px;\n cursor: ns-resize; }\n .ag-resizer.ag-resizer-topRight {\n top: 0;\n right: 0;\n height: 5px;\n width: 5px;\n cursor: nesw-resize; }\n .ag-resizer.ag-resizer-right {\n top: 5px;\n right: 0;\n bottom: 5px;\n width: 5px;\n cursor: ew-resize; }\n .ag-resizer.ag-resizer-bottomRight {\n bottom: 0;\n right: 0;\n height: 5px;\n width: 5px;\n cursor: nwse-resize; }\n .ag-resizer.ag-resizer-bottom {\n bottom: 0;\n left: 5px;\n right: 5px;\n height: 5px;\n cursor: ns-resize; }\n .ag-resizer.ag-resizer-bottomLeft {\n bottom: 0;\n left: 0;\n height: 5px;\n width: 5px;\n cursor: nesw-resize; }\n .ag-resizer.ag-resizer-left {\n left: 0;\n top: 5px;\n bottom: 5px;\n width: 5px;\n cursor: ew-resize; }\n\n/**\n ****************************\n * Tooltip\n ****************************\n*/\n.ag-tooltip {\n position: absolute;\n pointer-events: none;\n z-index: 99999; }\n\n/**\n ****************************\n * Animations\n ****************************\n*/\n.ag-value-slide-out {\n margin-right: 5px;\n opacity: 1;\n transition: opacity 3s, margin-right 3s;\n transition-timing-function: linear; }\n\n.ag-value-slide-out-end {\n margin-right: 10px;\n opacity: 0; }\n\n.ag-opacity-zero {\n opacity: 0 !important; }\n\n/**\n ****************************\n * Menu\n ****************************\n*/\n.ag-menu {\n max-height: 100%;\n overflow-y: auto;\n position: absolute;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n\n.ag-menu-column-select-wrapper {\n height: 265px;\n overflow: auto; }\n\n.ag-menu-list {\n display: table; }\n\n.ag-menu-option, .ag-menu-separator {\n display: table-row; }\n\n.ag-menu-separator-cell, .ag-menu-option-part {\n display: table-cell;\n vertical-align: middle; }\n\n.ag-menu-option-text {\n white-space: nowrap; }\n\n.ag-menu-column-select-wrapper .ag-column-select {\n height: 100%; }\n\n/**\n ****************************\n * Rich Select\n ****************************\n*/\n.ag-rich-select {\n cursor: default;\n outline: none; }\n\n.ag-rich-select-value {\n display: flex;\n align-items: center; }\n\n.ag-rich-select-value-icon {\n flex: 1 1 auto;\n order: 1; }\n .ag-ltr .ag-rich-select-value-icon {\n text-align: right; }\n .ag-rtl .ag-rich-select-value-icon {\n text-align: left; }\n\n.ag-rich-select-list {\n position: relative; }\n\n.ag-rich-select-virtual-list-item {\n display: flex; }\n\n.ag-rich-select-row {\n display: flex;\n flex: 1 1 auto;\n align-items: center;\n white-space: nowrap; }\n\n/**\n ****************************\n * Pagination\n ****************************\n*/\n.ag-paging-panel {\n align-items: center;\n display: flex;\n justify-content: flex-end; }\n\n.ag-paging-page-summary-panel {\n display: flex;\n align-items: center; }\n\n.ag-paging-button-wrapper {\n position: relative;\n overflow: hidden; }\n\n.ag-paging-button {\n position: absolute; }\n\n.ag-disabled .ag-paging-page-summary-panel {\n pointer-events: none; }\n\n/**\n ****************************\n * Tool Panel\n ****************************\n*/\n.ag-tool-panel-wrapper {\n display: flex;\n overflow-y: auto;\n overflow-x: hidden;\n cursor: default;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n width: 200px; }\n\n.ag-column-select-column,\n.ag-column-select-column-group {\n position: relative;\n align-items: center;\n display: flex;\n flex-direction: row;\n flex-wrap: nowrap;\n text-overflow: ellipsis;\n white-space: nowrap; }\n .ag-column-select-column > *,\n .ag-column-select-column-group > * {\n flex: none; }\n\n.ag-column-select-checkbox {\n display: flex; }\n\n.ag-tool-panel-horizontal-resize {\n cursor: ew-resize;\n height: 100%;\n position: absolute;\n top: 0;\n width: 5px;\n z-index: 1; }\n\n.ag-ltr .ag-side-bar-left .ag-tool-panel-horizontal-resize {\n right: -3px; }\n\n.ag-rtl .ag-side-bar-left .ag-tool-panel-horizontal-resize {\n left: -3px; }\n\n.ag-ltr .ag-side-bar-right .ag-tool-panel-horizontal-resize {\n left: -3px; }\n\n.ag-rtl .ag-side-bar-right .ag-tool-panel-horizontal-resize {\n right: -3px; }\n\n.ag-details-row {\n width: 100%; }\n\n.ag-details-row-fixed-height {\n height: 100%; }\n\n.ag-details-grid {\n width: 100%; }\n\n.ag-details-grid-fixed-height {\n height: 100%; }\n\n.ag-header-group-cell {\n display: flex;\n align-items: center;\n height: 100%;\n position: absolute; }\n\n.ag-cell-label-container {\n display: flex;\n justify-content: space-between;\n flex-direction: row-reverse;\n align-items: center;\n width: 100%;\n height: 100%; }\n\n.ag-right-aligned-header .ag-cell-label-container {\n flex-direction: row; }\n\n/**\n ****************************\n * Side Bar\n ****************************\n*/\n.ag-side-bar {\n display: flex;\n flex-direction: row-reverse; }\n\n.ag-side-bar-left {\n order: -1;\n flex-direction: row; }\n\n.ag-side-button-button {\n position: relative;\n display: flex;\n flex-direction: column;\n align-items: center;\n justify-content: center;\n flex-wrap: nowrap;\n white-space: nowrap;\n outline: none;\n cursor: pointer; }\n\n.ag-side-button-label {\n -webkit-writing-mode: vertical-lr;\n -ms-writing-mode: tb-lr;\n writing-mode: vertical-lr; }\n\n/**\n ****************************\n * Status Bar\n ****************************\n*/\n.ag-status-bar {\n display: flex;\n justify-content: space-between;\n overflow: hidden; }\n\n.ag-status-panel {\n display: inline-flex; }\n\n.ag-status-name-value {\n white-space: nowrap; }\n\n.ag-status-bar-left {\n display: inline-flex; }\n\n.ag-status-bar-center {\n display: inline-flex; }\n\n.ag-status-bar-right {\n display: inline-flex; }\n\n/**\n ****************************\n * Widgets\n ****************************\n*/\n.ag-icon {\n display: block;\n speak: none; }\n\n.ag-group {\n position: relative;\n width: 100%; }\n\n.ag-group-title-bar {\n display: flex;\n align-items: center; }\n\n.ag-group-title {\n display: block;\n flex: 1 1 auto;\n min-width: 0;\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis; }\n\n.ag-group-title-bar\n.ag-group-title {\n cursor: default; }\n\n.ag-group-toolbar {\n display: flex;\n align-items: center; }\n\n.ag-group-container {\n display: flex; }\n\n.ag-disabled .ag-group-container {\n pointer-events: none; }\n\n.ag-group-container-horizontal {\n flex-direction: row;\n flex-wrap: wrap; }\n\n.ag-group-container-vertical {\n flex-direction: column; }\n\n.ag-charts-font-size-color {\n display: flex;\n align-self: stretch;\n justify-content: space-between; }\n\n.ag-column-group-icons {\n display: block; }\n .ag-column-group-icons > * {\n cursor: pointer; }\n\n.ag-group-item-alignment-stretch .ag-group-item {\n align-items: stretch; }\n\n.ag-group-item-alignment-start .ag-group-item {\n align-items: flex-start; }\n\n.ag-group-item-alignment-end .ag-group-item {\n align-items: flex-end; }\n\n.ag-toggle-button-icon {\n transition: right 0.3s;\n position: absolute;\n top: -1px; }\n\n.ag-input-field, .ag-select {\n display: flex;\n flex-direction: row;\n align-items: center; }\n\n.ag-input-field-input {\n flex: 1 1 auto;\n width: 100%;\n min-width: 0; }\n\n.ag-floating-filter-input .ag-input-field-input[type='date'] {\n width: 1px; }\n\n.ag-range-field {\n display: flex;\n align-items: center; }\n\n.ag-angle-select {\n display: flex;\n align-items: center; }\n\n.ag-angle-select-wrapper {\n display: flex; }\n\n.ag-angle-select-parent-circle {\n display: block;\n position: relative; }\n\n.ag-angle-select-child-circle {\n position: absolute; }\n\n.ag-slider-wrapper {\n display: flex; }\n\n.ag-slider-wrapper .ag-input-field {\n flex: 1 1 auto; }\n\n.ag-picker-field-display {\n flex: 1 1 auto; }\n\n.ag-picker-field {\n display: flex;\n align-items: center; }\n\n.ag-picker-field-icon {\n display: flex;\n border: 0;\n padding: 0;\n margin: 0;\n cursor: pointer; }\n\n.ag-picker-field-wrapper {\n overflow: hidden; }\n\n.ag-label-align-right .ag-label {\n order: 1; }\n\n.ag-label-align-right > * {\n flex: none; }\n\n.ag-label-align-top {\n flex-direction: column;\n align-items: flex-start; }\n .ag-label-align-top > * {\n align-self: stretch; }\n\n.ag-color-panel {\n width: 100%;\n display: flex;\n flex-direction: column;\n text-align: center; }\n\n.ag-spectrum-color {\n flex: 1 1 auto;\n position: relative;\n overflow: hidden;\n cursor: default; }\n\n.ag-spectrum-fill {\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0; }\n\n.ag-spectrum-val {\n cursor: pointer; }\n\n.ag-spectrum-dragger {\n position: absolute;\n pointer-events: none;\n cursor: pointer; }\n\n.ag-spectrum-hue {\n cursor: default;\n background: linear-gradient(to left, #ff0000 3%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%); }\n\n.ag-spectrum-alpha {\n cursor: default; }\n\n.ag-spectrum-hue-background {\n width: 100%;\n height: 100%; }\n\n.ag-spectrum-alpha-background {\n background-image: linear-gradient(to right, rgba(0, 0, 0, 0), black);\n width: 100%;\n height: 100%; }\n\n.ag-spectrum-tool {\n cursor: pointer; }\n\n.ag-spectrum-slider {\n position: absolute;\n pointer-events: none; }\n\n.ag-recent-colors {\n display: flex; }\n\n.ag-recent-color {\n cursor: pointer; }\n\n.ag-ltr .ag-column-select-indent-1 {\n padding-left: 20px; }\n\n.ag-rtl .ag-column-select-indent-1 {\n padding-right: 20px; }\n\n.ag-ltr .ag-row-group-indent-1 {\n padding-left: 20px; }\n\n.ag-rtl .ag-row-group-indent-1 {\n padding-right: 20px; }\n\n.ag-ltr .ag-column-select-indent-2 {\n padding-left: 40px; }\n\n.ag-rtl .ag-column-select-indent-2 {\n padding-right: 40px; }\n\n.ag-ltr .ag-row-group-indent-2 {\n padding-left: 40px; }\n\n.ag-rtl .ag-row-group-indent-2 {\n padding-right: 40px; }\n\n.ag-ltr .ag-column-select-indent-3 {\n padding-left: 60px; }\n\n.ag-rtl .ag-column-select-indent-3 {\n padding-right: 60px; }\n\n.ag-ltr .ag-row-group-indent-3 {\n padding-left: 60px; }\n\n.ag-rtl .ag-row-group-indent-3 {\n padding-right: 60px; }\n\n.ag-ltr .ag-column-select-indent-4 {\n padding-left: 80px; }\n\n.ag-rtl .ag-column-select-indent-4 {\n padding-right: 80px; }\n\n.ag-ltr .ag-row-group-indent-4 {\n padding-left: 80px; }\n\n.ag-rtl .ag-row-group-indent-4 {\n padding-right: 80px; }\n\n.ag-ltr .ag-column-select-indent-5 {\n padding-left: 100px; }\n\n.ag-rtl .ag-column-select-indent-5 {\n padding-right: 100px; }\n\n.ag-ltr .ag-row-group-indent-5 {\n padding-left: 100px; }\n\n.ag-rtl .ag-row-group-indent-5 {\n padding-right: 100px; }\n\n.ag-ltr .ag-column-select-indent-6 {\n padding-left: 120px; }\n\n.ag-rtl .ag-column-select-indent-6 {\n padding-right: 120px; }\n\n.ag-ltr .ag-row-group-indent-6 {\n padding-left: 120px; }\n\n.ag-rtl .ag-row-group-indent-6 {\n padding-right: 120px; }\n\n.ag-ltr .ag-column-select-indent-7 {\n padding-left: 140px; }\n\n.ag-rtl .ag-column-select-indent-7 {\n padding-right: 140px; }\n\n.ag-ltr .ag-row-group-indent-7 {\n padding-left: 140px; }\n\n.ag-rtl .ag-row-group-indent-7 {\n padding-right: 140px; }\n\n.ag-ltr .ag-column-select-indent-8 {\n padding-left: 160px; }\n\n.ag-rtl .ag-column-select-indent-8 {\n padding-right: 160px; }\n\n.ag-ltr .ag-row-group-indent-8 {\n padding-left: 160px; }\n\n.ag-rtl .ag-row-group-indent-8 {\n padding-right: 160px; }\n\n.ag-ltr .ag-column-select-indent-9 {\n padding-left: 180px; }\n\n.ag-rtl .ag-column-select-indent-9 {\n padding-right: 180px; }\n\n.ag-ltr .ag-row-group-indent-9 {\n padding-left: 180px; }\n\n.ag-rtl .ag-row-group-indent-9 {\n padding-right: 180px; }\n\n.ag-ltr {\n direction: ltr; }\n .ag-ltr .ag-body, .ag-ltr .ag-floating-top, .ag-ltr .ag-floating-bottom, .ag-ltr .ag-header, .ag-ltr .ag-body-viewport, .ag-ltr .ag-body-horizontal-scroll {\n flex-direction: row; }\n\n.ag-rtl {\n direction: rtl; }\n .ag-rtl .ag-body, .ag-rtl .ag-floating-top, .ag-rtl .ag-floating-bottom, .ag-rtl .ag-header, .ag-rtl .ag-body-viewport, .ag-rtl .ag-body-horizontal-scroll {\n flex-direction: row-reverse; }\n .ag-rtl .ag-icon-contracted,\n .ag-rtl .ag-icon-tree-closed {\n display: block;\n -webkit-transform: rotate(180deg);\n transform: rotate(180deg); }\n\n.ag-body .ag-body-viewport {\n -webkit-overflow-scrolling: touch; }\n\n.ag-chart {\n position: relative;\n display: flex;\n overflow: hidden;\n width: 100%;\n height: 100%; }\n\n.ag-chart-components-wrapper {\n position: relative;\n display: flex;\n flex: 1 1 auto;\n overflow: hidden; }\n\n.ag-chart-title-edit {\n position: absolute;\n display: none;\n top: 0;\n left: 0;\n text-align: center; }\n\n.ag-chart-title-edit.currently-editing {\n display: inline-block; }\n\n.ag-chart-canvas-wrapper {\n position: relative;\n flex: 1 1 auto;\n overflow: hidden; }\n\n.ag-charts-canvas {\n display: block; }\n\n.ag-chart-menu {\n position: absolute;\n top: 10px;\n width: 24px;\n overflow: hidden;\n display: flex;\n flex-direction: column; }\n .ag-ltr .ag-chart-menu {\n right: 20px; }\n .ag-rtl .ag-chart-menu {\n left: 20px; }\n\n.ag-chart-docked-container {\n position: relative;\n width: 0;\n min-width: 0;\n transition: min-width 0.4s; }\n\n.ag-chart-menu-hidden ~ .ag-chart-docked-container {\n max-width: 0;\n overflow: hidden; }\n\n.ag-chart-tabbed-menu {\n width: 100%;\n height: 100%;\n display: flex;\n flex-direction: column;\n overflow: hidden; }\n\n.ag-chart-tabbed-menu-header {\n flex: none;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none;\n cursor: default; }\n\n.ag-chart-tabbed-menu-body {\n display: flex;\n flex: 1 1 auto;\n align-items: stretch;\n overflow: hidden; }\n\n.ag-chart-tab {\n width: 100%;\n overflow: hidden;\n overflow-y: auto; }\n\n.ag-chart-settings {\n overflow-x: hidden; }\n\n.ag-chart-settings-wrapper {\n position: relative;\n flex-direction: column;\n width: 100%;\n height: 100%;\n display: flex;\n overflow: hidden; }\n\n.ag-chart-settings-nav-bar {\n width: 100%;\n display: flex;\n height: 30px;\n align-items: center; }\n\n.ag-chart-settings-card-selector {\n display: flex;\n align-items: center;\n justify-content: space-around;\n flex: 1 1 auto;\n height: 100%;\n padding: 0 10px; }\n\n.ag-chart-settings-card-item {\n cursor: pointer;\n width: 10px;\n height: 10px;\n background-color: #000;\n position: relative; }\n .ag-chart-settings-card-item.ag-not-selected {\n opacity: 0.2; }\n .ag-chart-settings-card-item:before {\n content: \" \";\n display: block;\n position: absolute;\n background-color: transparent;\n left: 50%;\n top: 50%;\n margin-left: -10px;\n margin-top: -10px;\n width: 20px;\n height: 20px; }\n\n.ag-chart-settings-prev,\n.ag-chart-settings-next {\n position: relative;\n flex: none; }\n\n.ag-chart-settings-prev-button,\n.ag-chart-settings-next-button {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n cursor: pointer;\n opacity: 0; }\n\n.ag-chart-settings-mini-charts-container {\n position: relative;\n flex: 1 1 auto;\n overflow-x: hidden;\n overflow-y: auto; }\n\n.ag-chart-settings-mini-wrapper {\n position: absolute;\n top: 0;\n left: 0;\n display: flex;\n flex-direction: column;\n width: 100%;\n min-height: 100%;\n overflow: hidden; }\n .ag-chart-settings-mini-wrapper.ag-animating {\n transition: left 0.3s;\n transition-timing-function: ease-in-out; }\n\n.ag-chart-mini-thumbnail {\n cursor: pointer; }\n\n.ag-chart-mini-thumbnail-canvas {\n display: block; }\n\n.ag-chart-data-wrapper,\n.ag-chart-format-wrapper {\n display: flex;\n flex-direction: column;\n position: relative;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n\n.ag-chart-data-section,\n.ag-chart-format-section {\n display: flex;\n margin: 0; }\n\n.ag-charts-font-panel-controls {\n justify-content: space-between; }\n\n.ag-chart-empty-text {\n display: flex;\n top: 0;\n width: 100%;\n height: 100%;\n align-items: center;\n justify-content: center; }\n\n.ag-chart .ag-chart-menu {\n opacity: 0;\n pointer-events: none; }\n\n.ag-chart-menu-hidden:hover .ag-chart-menu {\n opacity: 1;\n pointer-events: all; }\n\n.ag-chart-settings-nav-bar {\n padding: 0 10px;\n -webkit-user-select: none;\n -moz-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n\n.ag-date-time-list-page-title-bar {\n display: flex; }\n\n.ag-date-time-list-page-column-labels-row,\n.ag-date-time-list-page-entries-row {\n display: flex; }\n\n.ag-date-time-list-page-column-label,\n.ag-date-time-list-page-entry {\n flex-basis: 0;\n flex-grow: 1; }\n\n.ag-date-time-list-page-entry {\n cursor: pointer; }\n\n", ""]);
  46120. // Exports
  46121. module.exports = exports;
  46122. /***/ }),
  46123. /* 227 */
  46124. /***/ (function(module, exports, __webpack_require__) {
  46125. "use strict";
  46126. /*
  46127. MIT License http://www.opensource.org/licenses/mit-license.php
  46128. Author Tobias Koppers @sokra
  46129. */
  46130. // css base code, injected by the css-loader
  46131. // eslint-disable-next-line func-names
  46132. module.exports = function (useSourceMap) {
  46133. var list = []; // return the list of modules as css string
  46134. list.toString = function toString() {
  46135. return this.map(function (item) {
  46136. var content = cssWithMappingToString(item, useSourceMap);
  46137. if (item[2]) {
  46138. return "@media ".concat(item[2], " {").concat(content, "}");
  46139. }
  46140. return content;
  46141. }).join('');
  46142. }; // import a list of modules into the list
  46143. // eslint-disable-next-line func-names
  46144. list.i = function (modules, mediaQuery, dedupe) {
  46145. if (typeof modules === 'string') {
  46146. // eslint-disable-next-line no-param-reassign
  46147. modules = [[null, modules, '']];
  46148. }
  46149. var alreadyImportedModules = {};
  46150. if (dedupe) {
  46151. for (var i = 0; i < this.length; i++) {
  46152. // eslint-disable-next-line prefer-destructuring
  46153. var id = this[i][0];
  46154. if (id != null) {
  46155. alreadyImportedModules[id] = true;
  46156. }
  46157. }
  46158. }
  46159. for (var _i = 0; _i < modules.length; _i++) {
  46160. var item = [].concat(modules[_i]);
  46161. if (dedupe && alreadyImportedModules[item[0]]) {
  46162. // eslint-disable-next-line no-continue
  46163. continue;
  46164. }
  46165. if (mediaQuery) {
  46166. if (!item[2]) {
  46167. item[2] = mediaQuery;
  46168. } else {
  46169. item[2] = "".concat(mediaQuery, " and ").concat(item[2]);
  46170. }
  46171. }
  46172. list.push(item);
  46173. }
  46174. };
  46175. return list;
  46176. };
  46177. function cssWithMappingToString(item, useSourceMap) {
  46178. var content = item[1] || ''; // eslint-disable-next-line prefer-destructuring
  46179. var cssMapping = item[3];
  46180. if (!cssMapping) {
  46181. return content;
  46182. }
  46183. if (useSourceMap && typeof btoa === 'function') {
  46184. var sourceMapping = toComment(cssMapping);
  46185. var sourceURLs = cssMapping.sources.map(function (source) {
  46186. return "/*# sourceURL=".concat(cssMapping.sourceRoot || '').concat(source, " */");
  46187. });
  46188. return [content].concat(sourceURLs).concat([sourceMapping]).join('\n');
  46189. }
  46190. return [content].join('\n');
  46191. } // Adapted from convert-source-map (MIT)
  46192. function toComment(sourceMap) {
  46193. // eslint-disable-next-line no-undef
  46194. var base64 = btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap))));
  46195. var data = "sourceMappingURL=data:application/json;charset=utf-8;base64,".concat(base64);
  46196. return "/*# ".concat(data, " */");
  46197. }
  46198. /***/ }),
  46199. /* 228 */
  46200. /***/ (function(module, exports, __webpack_require__) {
  46201. var api = __webpack_require__(225);
  46202. var content = __webpack_require__(229);
  46203. content = content.__esModule ? content.default : content;
  46204. if (typeof content === 'string') {
  46205. content = [[module.i, content, '']];
  46206. }
  46207. var options = {};
  46208. options.insert = "head";
  46209. options.singleton = false;
  46210. var update = api(content, options);
  46211. module.exports = content.locals || {};
  46212. /***/ }),
  46213. /* 229 */
  46214. /***/ (function(module, exports, __webpack_require__) {
  46215. // Imports
  46216. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227);
  46217. exports = ___CSS_LOADER_API_IMPORT___(false);
  46218. // Module
  46219. exports.push([module.i, ".ag-theme-alpine-dark {\n -webkit-font-smoothing: antialiased;\n color: #fff;\n color: var(--ag-foreground-color, #fff);\n font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n font-size: 13px;\n line-height: normal; }\n\n@font-face {\n font-family: \"agGridAlpine\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABNkAAsAAAAAIqAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlMAAAReYc5joU9TLzIAAANcAAAAQAAAAFZWUVJ5Y21hcAAAA5wAAAHqAAAFgHCsDfxnbHlmAAAFiAAACesAABCUC9Ir6mhlYWQAAA90AAAANAAAADZ2zsSBaGhlYQAAD6gAAAAeAAAAJAfSBC5obXR4AAAPyAAAABcAAAEou4D/+2xvY2EAAA/gAAAAbwAAAJbPsst2bWF4cAAAEFAAAAAfAAAAIAFgAHNuYW1lAAAQcAAAATUAAAJG5xgJvXBvc3QAABGoAAABuQAAApPSPvKNeJx9k81SE1EQhc9kQgwJBkREjREU//GPYX4yJiGQMAFisXDhwoUbXGhpUa54Atc+gOUD+BQ+geXSlQ/gA1g+gN/tTAyyIFOZubf79Onuc/vKk1TRmroqZDv7z1U7PDh6r7qKGv2c//jaO3z75kDl8Q5f0b5lef4f1bSiFzrSN0/ea+9zoeQX/K6/73/wP/k/5IO6pkegq1rnCRXxDhQrUVOpCiphC1k/UQu0z7tt1nktaso8mQa6QM6QmIExruqpbmkOnr7x9LQJKuZxnD3euzy3NXsKItUd+BOq2cDqWBvUeU7T2qHGHnV0iG7hncO3ReaAmD6+PrX5hiqajnt6SeS89eYikxwX8w+1bfvAdkuoMEa14W/C7/gek3Vsb5IpIuIh7Amobq7hKv8q3hhMQGzHNHPRSyAjKoy1zMp1FtHZjG7C/kyvdJ+47TymZyqOer5H9RN73/hS8hy3duDaBfuAGiZWdyJ3yRVoiL/CSWV6p4/6oq/6rp/6pd/gF8kSWQebcG+dqsw0+p1EZ3jb/6yu0zOcxUnU/4gKfTdNmxDfIFfQZZvB57SJWQdYY8NX4XT4jGpS9Jpi8gLLG2Etsd9gH4Ku5dPY4jlrOg+YATcBdbRY5+2YRvOWsr9MtFuN6rpoarXguWSn5TR1N2nWdm7m3SnX0fkK34DOEtNnD+9VLI5pYmlYVErVjmMNf0q1k2yuqgZVRcxA2SZraLcgI9N1+hhVEumG3YChTdUKFST5jVzQeau+k5/UguFCi/JQIshvcmyauUnuU5ubit2/LKNqzAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMb0GmMDCC5ADUogpqeJy11IdSWkEYxfE/RdNM79X0jgJiQIogIMhjmO6Y4pju5CnzJt8LxJzlnjyAmcnO/Fh2udy9O3fPB8wABXkqRcgXyZHab83mpvMFjk7ni/zSeI7D5PW9xBY77EV5f1+zJTbZZjdy09HfltPVc1zjPs80WqNClxZ9aoyp0tHsKm0GNKizzhJNlhkyYYUeIzb0/7xWLzLLIa16RM9xTPc7zglOcorTnOEs5zjPBS5yictc4apWu84N5rnJLW5zh7vc0/oPeMgjHvNE+ynp9wUWKesBZzlYWzvg9alVuq1+bVztaLftQaOujTaXh5OV3mjjH272H9pc+ij89GhCepuZtNtNq8hz68oLa8lL68srq8lrG8sbq8pb68iWpROybavyztry3gbywRry0eqyY+uya0vyyZry2Zbliw3lq6W9f7MV+W49+WEj2TO9wMhlUlYinyH1hUzKVhQzKV8xk9GZJkynmzCdc8J04glLGQxTCghLby9MySBMGSFMaSFMuSFMCSJMWSJMqSJM+SJMSSNMmSNM6SNMOSRMiSRM2SRMKSVMeSVMySVMGSVMaSZMuSZMCSdMWSdMqSdM+SdMlYAw1QTCVB0IU50gTBWDMNUOwlRFCEt1MyxlJmz6/AsZUr+YIfXlDOU/rrOgigAAeJzFF21sU9f1nntjvzgJSRx/vJgQg/3ivNSxwxL7+dkx2JAEEmhIqWpYCqMhMCbWdFppM7EBbsd+dEVV1apS6A/yY9O2oFVaQEOb+sFKtZaRqh/qVLQf/fixdkxkXbNRodIZ3mXnXttpApnW/Zr93rnn3nt8zrnnni8TIPihcyxKqgmBgEdVPAEjYOoBOsdrCgW4yu9HeJxFs4VCJlMoCHLbzes3r7NP2afEhr+qIx7SRIhLURXdtJkChhAwVaAuXcBPnn028uqrNIMg8iwfHR4eXidXInKBPrFgMnzv8DD/YiE9qiWEsh7WQypRjmo6Y07VhJPds7nLaX4GrqZnuQ2uz6ZhCx5F0k6wCeImq/CnQcWu2N2qV/V2mQkzEddb9VaXoqOSqBnqBlcPjI6YqZQ5MvpRGRnpPn68e2JCQjaxaEsi1uvlXYTk/yOTle6tFjFF3l3MqekxjyZG+G0+fzafh4P5PFtmvY0XeJAfK+t5mV0mLuITtx2sBY/T7YdYoCsDhjPeAQ4wVVDZD2587o/58WFVcrTm+N+GZmBqiF3G+aLNG5+Dd+gCTN21mL+6NH+GznUb9yetizRyO2fr4oMLeTLJ0xlwhpbiizxZ1S18i4vfvZVv0Xbs++yb6L+VpJEQByiqA5i5Euzi6jxub1fCENdGP+Ej3Xu5BZmZmQunq6t9dd7ODZ3eOh/8Hn6axg3+KqydmcksW+ZvavUFOzuDvtAKv2BfIWVEMa6K91NHSCjgDNg0Z8ylOdPg1Jwsaj1FD/DN8q5eyhdoLM+PiZsq3lbJ7+lp5GFDHSm6DxyEFL+AYcii/AKfKcVj8Tw/ZOfwND7SLC1v92CUBFSJuL1oqATaqVVzoQ70NK/ROnNwNc8NoTK8gVADbsAb7OXOoPUC7b+nU7NeEHu0X+u09tH+Ugw+zZ4WvuYANJfiAB3dBa7Cvb18Cnb08pN8qhd2IKCJRVPYgSTkljgGXUEb6Aqw9TKQYYsIZLjObbMY1IvPHkKBioq2moEk5qGzkIRUduHZn8A4aCIdZK3ga6qJWJcfVoJSCyIp2ZUOuhrMDKg499NYl6nbtWAHGHFTVxNI6VbUhNlBg9C4NjKwfWT75HgzY+6+aDRi7hr7+uT4iooKz9BotM+9fPTowN2b0mGjfVM4UJlsuWdT2D0w1OLbc/RJ+nP87R19h7dWVZu7tI5IIgbQd2hrddWafY7me7rW7zVbuleG+9uN9t1Jd3gg1zKQ3omLC/SvxdwRRf3RpYUyUtdQhpZOQlHh1WDDTfR23ETvpxX9R/f4UPhTR0eXo2r8/IrxyV9J5ZslsqICfhzeFA5v2iYA+My961FkEV7aerhPaFtVGidRp4GwBKWYG0PbK2QZaqR4FKduBGyqxzRMNlZ4qUBPWdPvZ9+jc4XJszBcyGbffy8z+T4p50J6jc7hvTnkbeiKKnISvfbKK+lCgRu5HBjnzqVlbakhNcU4QfpynIjc0URWEo3opJ2sJsTUjJi64A39lznWqbPZ7EsSWm/9p0khX/xkS2OmNKI6lfPnv1UnAlgdQ/i6UI6Br46vWFNwDODIxoSPWm9LViiCnuIziMFv+Aw9IOXyzVmUleXHUIVMJrOEzVzo61iA0WZXpMngYC5Hz0iT8RpyWxxhscYw1ANsfTF0YIsII+qf7eZn+Jnu2XKMTNDzWJ8aSQQlxDOQBkMr+pHEOkDF1BzSPBg6tBbaARHpaz8LrtGmplK7k8ndqakpbU3wORjiv4aDEgdtfhOuamntruTIQyPJu7S0kptCuFGs7D4wkpQ2vXmTzco8fotNA5gTRXG0ic4BlbCJBqQ0F/mSLh8cPHbNvEbbzWsmJpQ3IW4NCrgL5/QT3OFvDg5CvBUxfMy1g4OD4zjic+2PEC/XkOfYc6iFU+bhmAfQKTEZagbogPWSHxsG2sP5h1g07+W8B+gHWTj4oVxjLn7sA7k2n2++9Fe0vzH/LWb08gspvOd8piz/HfZOUf682HlFsvNC0X/KmgilimL/VNZkviZMF/OiSG8qwPfSnKchxaI4dkOy5E+XWL3sz0SmVbG0KaL5oJeuXImcPx+RkPrl8JiE82cr9jEBzKZLdzIQF2isy6tCB0CwVQc/eNyCcKm+hvdEI4Nbdqb2t/NosAW2IALvBlvE4lJtDh/ZuWUwEm0J8mj7fv73liC8274/JdfK+j2Adc6LfqOjfhrmQrui3VLkAl1etz3YGk+AMHDAiLHGU8vWbV237JQsaQMC8g+cPl/Q5wPDej4HP8mxsVBHRwir3z5JcyLY2ag14mM10BMiKRTv8Ag7TIKlKpMoflWzVQxZAMWOhkZTKfY6NLkuegm0eitaBgQFliDVG/MiqsPdz2D2tjmau1ebeyvranwNqhv8nnUb9gNQ5vZE1eN/icAll6Omsn4y0dblhOWVKoVKOlFZVV1X21B/ER55xlFdXVfTVu2oHl3ub2xyNdTyj1Zsq9lnt/mM9q+p1ciBPlVf76r1TtYy1sT/anfrjfGG4xUVoFQ2XBTHqZJnmmbTGImrSBtZTzaSO0mO7CSj5Ft4Rj9VG1gtVSpCHVSnrgw1W2wBpxcrqZmwuVVRmAzpVorucWO90lQ58UrDhNxqzMDaGzPMMKBFYpioPTG9A/SQXVM8MbMVcw1ztm0IA6oU3tDGP+YffzmDZjhkXfjHnBanDqsSaFxbBS9WRbblIo7wxrZxR2TbtkjVupau5X6wXocjhwHy2fidSYBDWfjdIUGP5kiFHz2X7H+U/XJJ/s1ydsN63e5A8rm3nPUoDA5DnWTueLCtv506IjmUAzbF5Q37NyYfeXmz8ei/EqGR7JEjQaRmAEfy8MhtcSkzMp1O8wuQSnP6WVp0a92cLOxn3eSOcoTVC7dZJcxWLyKMBQWUYdYldkrB9fj4gd6+vt4D41Bfxh7/zq4dhmkaO3a9V0bYZbHB/7mY+MaRRUQSKcWT0KUG4z0htJEFoZj49f9Btb6He3sfflyAvq+mJZ0r0SMofGWFb6t9iopFV6TABf8BZT85241/BovnG2Rjsq7KTkbkQPyXG5AdSTEXWh/T09ZWTNYZmJUL/GSWzllvl2UxekLcmssBl6AO6ugJrH5Dpfs+wZjYc9DiKmP8Cr+yeA97V2xtsWTKXy/Ns0hQ2vsFc8l+X/TYJtwPX/Ra5/mfe6BJYH+AlT0luijtFSd04WnOyoLTc9+8faJ0ulgfdOzS6WeyLECKTmOdEC65INePYUXykC6RS0XpB4/Xrqj4pwodAOM5Jnpmz5c9ghFPmCoSqviYQF8rNgFmeG08m9y95xu5Suv5H3UPlDuFns7tKx8aGTgZt/rpa9gOaJEN1Wub9qxJjSSncvDA0cZvr0vJbkHr3GzbnrsPKemLhPwbDwYCEQB4nGNgZGBgAOLsD0FR8fw2Xxm4mV8ABaI4H+9rgNH/f///zfyW+S1QJQcDE5BkAACRug+HeJxjYGRgYH7BwAAi///+/5v5LQMjAyrwAgCe2QcHAAB4nGNgYGBgfgHC/39D6KGH6QEAIHUuCwB4nGNgAAIphiCGDIZFDHcYvjGqMQYwVjGuYTzH+IhJhMmMyYcpgekAMxezBrMDcxfzIeZbzJ9YTFiKWGawbGK5wfKKlY01jHUK6z+2JWw72P6xR7Dnsfexz2Ffxb6D/Rj7LfYX7H84vEiHANyaI6IAeJxjYGRgYPBiSGfgYQABJiDmAkIGhv9gPgMAGzsB1AB4nHWRPU7DQBCFnxMniBghJCREx1Y0SM5PQZEuFHGfIgWdE68dR7bXWm8ipeMYnIBjUHIETsEheDFTREjZ1a6/+fbNNAZwgy94OC4PV+19XB1csPrjLulW2Cc/CPcQ4Em4T/8sPKB9EQ7YWXKC51/S3ONNuINrvAt36T+EffKncA93+Bbu0/8ID7D0fOEAj95rnEU2T2ZFnVd6obNdEdtTdcpLbZvcVGocjk51pCttY6cTtTqoZp9NnEtVak2p5qZyuiiMqq3Z6rULN87V0+EwFR+uTYkYGSJY5EgwQ4GaVEFjwZNhRxPz9VzqnF/yWDSsDGuFMUKMzqYjnqrtiOH4TdixwoF3gz17JrQOKeuUGcO/ojBvJx/TBbehqdu3Lc2aPsSm7aoxxZA7/ZcPmeKkXwK+aWkAAAB4nG2S6W7bMBCE/cWSI9tpk7ptet/3obbpfaf3kT4FQ9EyEYkUSMp28vRl4yBAgO4fzgwWs7MLdpY6ixp0/l9bLNElIaXHMhl9BgxZ4RjHWWWNE4w4ySlOs84ZznKO81zgIpe4zBWuco3r3OAmt7jNHe5yj/s84CE5j3jMEzZ4yjOe84KXvOI1b3jLO97zgY9s8onPfOEr3/jOD37yi99s8aczFGXpVCmCtqYnnLMz3xVe9qQwUlXZ4sk3UjkRLqzJiZI723ae7wNVrB8K2hQqKFdrI4IaHcqtOehckbayLm90JG45krY2fiCtCU7IoIpE2mY3lc56nxTKy0zNGxE9i77aVbmvhJ90I+qNdRXHpGPtfEhKp5u0dLZtktgQkkqNQ6/SJs5brqwotCmzWsx1rfdUUivTZjHfghk1D4mxRg2NDbmoKjtTRdpEF9VttEkbPbUha5yaatv6NRfNbL7dhmBNbsfj1aOCSZ0uJyHxYqoGvo52eWFn5gD+izVcwP22bIFj6hDPMQpOqaP36+9LtlEma81iHwQlDkVAYzHM8EgqJuywzTx+g4KaloZdxuwx7XT+AvL3sQsAAAA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n .ag-theme-alpine-dark .ag-icon {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n .ag-theme-alpine-dark .ag-icon-aggregation:before {\n content: \"\\f101\"; }\n .ag-theme-alpine-dark .ag-icon-arrows:before {\n content: \"\\f102\"; }\n .ag-theme-alpine-dark .ag-icon-asc:before {\n content: \"\\f103\"; }\n .ag-theme-alpine-dark .ag-icon-cancel:before {\n content: \"\\f104\"; }\n .ag-theme-alpine-dark .ag-icon-chart:before {\n content: \"\\f105\"; }\n .ag-theme-alpine-dark .ag-icon-color-picker:before {\n content: \"\\f109\"; }\n .ag-theme-alpine-dark .ag-icon-columns:before {\n content: \"\\f10a\"; }\n .ag-theme-alpine-dark .ag-icon-contracted:before {\n content: \"\\f10b\"; }\n .ag-theme-alpine-dark .ag-icon-copy:before {\n content: \"\\f10c\"; }\n .ag-theme-alpine-dark .ag-icon-cross:before {\n content: \"\\f10d\"; }\n .ag-theme-alpine-dark .ag-icon-desc:before {\n content: \"\\f10e\"; }\n .ag-theme-alpine-dark .ag-icon-expanded:before {\n content: \"\\f10f\"; }\n .ag-theme-alpine-dark .ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n .ag-theme-alpine-dark .ag-icon-eye:before {\n content: \"\\f111\"; }\n .ag-theme-alpine-dark .ag-icon-filter:before {\n content: \"\\f112\"; }\n .ag-theme-alpine-dark .ag-icon-first:before {\n content: \"\\f113\"; }\n .ag-theme-alpine-dark .ag-icon-grip:before {\n content: \"\\f114\"; }\n .ag-theme-alpine-dark .ag-icon-group:before {\n content: \"\\f115\"; }\n .ag-theme-alpine-dark .ag-icon-last:before {\n content: \"\\f116\"; }\n .ag-theme-alpine-dark .ag-icon-left:before {\n content: \"\\f117\"; }\n .ag-theme-alpine-dark .ag-icon-linked:before {\n content: \"\\f118\"; }\n .ag-theme-alpine-dark .ag-icon-loading:before {\n content: \"\\f119\"; }\n .ag-theme-alpine-dark .ag-icon-maximize:before {\n content: \"\\f11a\"; }\n .ag-theme-alpine-dark .ag-icon-menu:before {\n content: \"\\f11b\"; }\n .ag-theme-alpine-dark .ag-icon-minimize:before {\n content: \"\\f11c\"; }\n .ag-theme-alpine-dark .ag-icon-next:before {\n content: \"\\f11d\"; }\n .ag-theme-alpine-dark .ag-icon-none:before {\n content: \"\\f11e\"; }\n .ag-theme-alpine-dark .ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n .ag-theme-alpine-dark .ag-icon-paste:before {\n content: \"\\f120\"; }\n .ag-theme-alpine-dark .ag-icon-pin:before {\n content: \"\\f121\"; }\n .ag-theme-alpine-dark .ag-icon-pivot:before {\n content: \"\\f122\"; }\n .ag-theme-alpine-dark .ag-icon-previous:before {\n content: \"\\f123\"; }\n .ag-theme-alpine-dark .ag-icon-right:before {\n content: \"\\f126\"; }\n .ag-theme-alpine-dark .ag-icon-save:before {\n content: \"\\f127\"; }\n .ag-theme-alpine-dark .ag-icon-small-down:before {\n content: \"\\f128\"; }\n .ag-theme-alpine-dark .ag-icon-small-left:before {\n content: \"\\f129\"; }\n .ag-theme-alpine-dark .ag-icon-small-right:before {\n content: \"\\f12a\"; }\n .ag-theme-alpine-dark .ag-icon-small-up:before {\n content: \"\\f12b\"; }\n .ag-theme-alpine-dark .ag-icon-tick:before {\n content: \"\\f12c\"; }\n .ag-theme-alpine-dark .ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n .ag-theme-alpine-dark .ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n .ag-theme-alpine-dark .ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n .ag-theme-alpine-dark .ag-icon-unlinked:before {\n content: \"\\f130\"; }\n .ag-theme-alpine-dark .ag-icon-row-drag:before {\n content: \"\\f114\"; }\n .ag-theme-alpine-dark .ag-right-arrow:before {\n content: \"\\f117\"; }\n .ag-theme-alpine-dark .ag-right-arrow:before {\n content: \"\\f126\"; }\n .ag-theme-alpine-dark .ag-root-wrapper {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f); }\n .ag-theme-alpine-dark [class^='ag-'], .ag-theme-alpine-dark [class^='ag-']:focus, .ag-theme-alpine-dark [class^='ag-']:after, .ag-theme-alpine-dark [class^='ag-']:before {\n box-sizing: border-box;\n outline: none; }\n .ag-theme-alpine-dark [class^='ag-']::-ms-clear {\n display: none; }\n .ag-theme-alpine-dark .ag-checkbox .ag-input-wrapper,\n .ag-theme-alpine-dark .ag-radio-button .ag-input-wrapper {\n overflow: visible; }\n .ag-theme-alpine-dark .ag-range-field .ag-input-wrapper {\n height: 100%; }\n .ag-theme-alpine-dark .ag-toggle-button {\n flex: none;\n width: unset;\n min-width: unset; }\n .ag-theme-alpine-dark .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 6px; }\n .ag-theme-alpine-dark input[class^='ag-'] {\n margin: 0;\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f); }\n .ag-theme-alpine-dark textarea[class^='ag-'],\n .ag-theme-alpine-dark select[class^='ag-'] {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f); }\n .ag-theme-alpine-dark input[class^='ag-']:not([type]),\n .ag-theme-alpine-dark input[class^='ag-'][type='text'],\n .ag-theme-alpine-dark input[class^='ag-'][type='number'],\n .ag-theme-alpine-dark input[class^='ag-'][type='tel'],\n .ag-theme-alpine-dark input[class^='ag-'][type='date'],\n .ag-theme-alpine-dark input[class^='ag-'][type='datetime-local'],\n .ag-theme-alpine-dark textarea[class^='ag-'] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #68686e;\n border-color: var(--ag-input-border-color, var(--ag-border-color, #68686e)); }\n .ag-theme-alpine-dark input[class^='ag-']:not([type]):disabled,\n .ag-theme-alpine-dark input[class^='ag-'][type='text']:disabled,\n .ag-theme-alpine-dark input[class^='ag-'][type='number']:disabled,\n .ag-theme-alpine-dark input[class^='ag-'][type='tel']:disabled,\n .ag-theme-alpine-dark input[class^='ag-'][type='date']:disabled,\n .ag-theme-alpine-dark input[class^='ag-'][type='datetime-local']:disabled,\n .ag-theme-alpine-dark textarea[class^='ag-']:disabled {\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5));\n background-color: #282c2f;\n background-color: var(--ag-input-disabled-background-color, #282c2f);\n border-color: rgba(104, 104, 110, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(104, 104, 110, 0.3)); }\n .ag-theme-alpine-dark input[class^='ag-']:not([type]):focus,\n .ag-theme-alpine-dark input[class^='ag-'][type='text']:focus,\n .ag-theme-alpine-dark input[class^='ag-'][type='number']:focus,\n .ag-theme-alpine-dark input[class^='ag-'][type='tel']:focus,\n .ag-theme-alpine-dark input[class^='ag-'][type='date']:focus,\n .ag-theme-alpine-dark input[class^='ag-'][type='datetime-local']:focus,\n .ag-theme-alpine-dark textarea[class^='ag-']:focus {\n outline: none;\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark input[class^='ag-'][type='number'] {\n -moz-appearance: textfield; }\n .ag-theme-alpine-dark input[class^='ag-'][type='number']::-webkit-outer-spin-button, .ag-theme-alpine-dark input[class^='ag-'][type='number']::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0; }\n .ag-theme-alpine-dark input[class^='ag-'][type='range'] {\n padding: 0; }\n .ag-theme-alpine-dark input[class^='ag-'][type='button']:focus, .ag-theme-alpine-dark button[class^='ag-']:focus {\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6); }\n .ag-theme-alpine-dark .ag-drag-handle {\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-list-item, .ag-theme-alpine-dark .ag-virtual-list-item {\n height: 30px; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-virtual-list-item:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-select-list {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n overflow-y: auto;\n overflow-x: hidden; }\n .ag-theme-alpine-dark .ag-list-item {\n display: flex;\n align-items: center; }\n .ag-theme-alpine-dark .ag-list-item.ag-active-item {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine-dark .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n .ag-theme-alpine-dark .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden; }\n .ag-theme-alpine-dark .ag-select .ag-picker-field-wrapper {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n min-height: 30px;\n cursor: default; }\n .ag-theme-alpine-dark .ag-select:not(.ag-cell-editor) {\n height: 30px; }\n .ag-theme-alpine-dark .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis; }\n .ag-theme-alpine-dark .ag-select .ag-picker-field-icon {\n display: flex;\n align-items: center; }\n .ag-theme-alpine-dark .ag-select.ag-disabled {\n opacity: 0.5; }\n .ag-theme-alpine-dark .ag-rich-select {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628); }\n .ag-theme-alpine-dark .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 273px; }\n .ag-theme-alpine-dark .ag-rich-select-value {\n padding: 0 6px 0 18px;\n height: 42px;\n border-bottom: solid 1px;\n border-bottom-color: rgba(88, 86, 82, 0.5);\n border-bottom-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5)); }\n .ag-theme-alpine-dark .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 30px; }\n .ag-theme-alpine-dark .ag-rich-select-virtual-list-item:hover {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine-dark .ag-rich-select-row {\n padding-left: 18px; }\n .ag-theme-alpine-dark .ag-rich-select-row-selected {\n background-color: rgba(33, 150, 243, 0.3);\n background-color: var(--ag-selected-row-background-color, rgba(33, 150, 243, 0.3)); }\n .ag-theme-alpine-dark .ag-row-drag,\n .ag-theme-alpine-dark .ag-selection-checkbox,\n .ag-theme-alpine-dark .ag-group-expanded,\n .ag-theme-alpine-dark .ag-group-contracted {\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-ltr .ag-row-drag, .ag-theme-alpine-dark .ag-ltr .ag-selection-checkbox, .ag-theme-alpine-dark .ag-ltr .ag-group-expanded, .ag-theme-alpine-dark .ag-ltr .ag-group-contracted {\n margin-right: 12px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-drag, .ag-theme-alpine-dark .ag-rtl .ag-selection-checkbox, .ag-theme-alpine-dark .ag-rtl .ag-group-expanded, .ag-theme-alpine-dark .ag-rtl .ag-group-contracted {\n margin-left: 12px; }\n .ag-theme-alpine-dark .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: 40px;\n display: flex;\n align-items: center;\n flex: none; }\n .ag-theme-alpine-dark .ag-group-expanded,\n .ag-theme-alpine-dark .ag-group-contracted {\n cursor: pointer; }\n .ag-theme-alpine-dark .ag-group-title-bar-icon {\n cursor: pointer;\n flex: none;\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-ltr .ag-group-child-count {\n margin-left: 2px; }\n .ag-theme-alpine-dark .ag-rtl .ag-group-child-count {\n margin-right: 2px; }\n .ag-theme-alpine-dark .ag-group-title-bar {\n background-color: #000;\n background-color: var(--ag-subheader-background-color, #000);\n padding: 6px; }\n .ag-theme-alpine-dark .ag-group-toolbar {\n padding: 6px; }\n .ag-theme-alpine-dark .ag-disabled-group-title-bar, .ag-theme-alpine-dark .ag-disabled-group-container {\n opacity: 0.5; }\n .ag-theme-alpine-dark .group-item {\n margin: 3px 0; }\n .ag-theme-alpine-dark .ag-label {\n white-space: nowrap; }\n .ag-theme-alpine-dark .ag-ltr .ag-label {\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-label {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-label-align-top .ag-label {\n margin-bottom: 3px; }\n .ag-theme-alpine-dark .ag-ltr .ag-slider-field, .ag-theme-alpine-dark .ag-ltr .ag-angle-select-field {\n margin-right: 12px; }\n .ag-theme-alpine-dark .ag-rtl .ag-slider-field, .ag-theme-alpine-dark .ag-rtl .ag-angle-select-field {\n margin-left: 12px; }\n .ag-theme-alpine-dark .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f); }\n .ag-theme-alpine-dark .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #fff;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n border-radius: 5px; }\n .ag-theme-alpine-dark .ag-picker-field-wrapper:focus {\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6); }\n .ag-theme-alpine-dark .ag-picker-field-button {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-dialog.ag-color-dialog {\n border-radius: 5px; }\n .ag-theme-alpine-dark .ag-color-picker .ag-picker-field-display {\n height: 16px; }\n .ag-theme-alpine-dark .ag-color-panel {\n padding: 6px; }\n .ag-theme-alpine-dark .ag-spectrum-color {\n background-color: red;\n border-radius: 2px; }\n .ag-theme-alpine-dark .ag-spectrum-tools {\n padding: 10px; }\n .ag-theme-alpine-dark .ag-spectrum-sat {\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0)); }\n .ag-theme-alpine-dark .ag-spectrum-val {\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0)); }\n .ag-theme-alpine-dark .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24); }\n .ag-theme-alpine-dark .ag-spectrum-hue-background {\n border-radius: 2px; }\n .ag-theme-alpine-dark .ag-spectrum-alpha-background {\n border-radius: 2px; }\n .ag-theme-alpine-dark .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px; }\n .ag-theme-alpine-dark .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37); }\n .ag-theme-alpine-dark .ag-recent-color {\n margin: 0 3px; }\n .ag-theme-alpine-dark .ag-recent-color:first-child {\n margin-left: 0; }\n .ag-theme-alpine-dark .ag-recent-color:last-child {\n margin-right: 0; }\n .ag-theme-alpine-dark.ag-dnd-ghost {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n border-radius: 3px;\n box-shadow: 0 1px 20px 1px black;\n padding: 6px;\n overflow: hidden;\n text-overflow: ellipsis;\n z-index: 10;\n border: solid 1px;\n border-color: rgba(88, 86, 82, 0.5);\n border-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5));\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n height: 48px !important;\n line-height: 48px;\n margin: 0;\n padding: 0 12px;\n -webkit-transform: translateY(12px);\n transform: translateY(12px); }\n .ag-theme-alpine-dark .ag-dnd-ghost-icon {\n margin-right: 6px;\n color: #fff;\n color: var(--ag-foreground-color, #fff); }\n .ag-theme-alpine-dark .ag-popup-child:not(.ag-tooltip-custom) {\n box-shadow: 0 1px 20px 1px black; }\n .ag-dragging-range-handle .ag-theme-alpine-dark .ag-dialog,\n .ag-dragging-fill-handle .ag-theme-alpine-dark .ag-dialog {\n opacity: 0.7;\n pointer-events: none; }\n .ag-theme-alpine-dark .ag-dialog {\n border-radius: 3px;\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-panel {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f); }\n .ag-theme-alpine-dark .ag-panel-title-bar {\n background-color: #222628;\n background-color: var(--ag-header-background-color, #222628);\n color: #fff;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)));\n height: 48px;\n padding: 6px 18px;\n border-bottom: solid 1px;\n border-bottom-color: #68686e;\n border-bottom-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-ltr .ag-panel-title-bar-button {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-panel-title-bar-button {\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-tooltip {\n background-color: #222628;\n background-color: var(--ag-header-background-color, #222628);\n color: #fff;\n color: var(--ag-foreground-color, #fff);\n padding: 6px;\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n border-radius: 3px;\n transition: opacity 1s; }\n .ag-theme-alpine-dark .ag-tooltip.ag-tooltip-hiding {\n opacity: 0; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-1 {\n padding-left: 16px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-1 {\n padding-right: 16px; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-2 {\n padding-left: 32px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-2 {\n padding-right: 32px; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-3 {\n padding-left: 48px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-3 {\n padding-right: 48px; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-4 {\n padding-left: 64px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-4 {\n padding-right: 64px; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-5 {\n padding-left: 80px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-5 {\n padding-right: 80px; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-6 {\n padding-left: 96px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-6 {\n padding-right: 96px; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-7 {\n padding-left: 112px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-7 {\n padding-right: 112px; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-8 {\n padding-left: 128px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-8 {\n padding-right: 128px; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-indent-9 {\n padding-left: 144px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-indent-9 {\n padding-right: 144px; }\n .ag-theme-alpine-dark .ag-column-select-header-icon {\n cursor: pointer; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-header-icon:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-alpine-dark .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 12px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-alpine-dark .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 12px; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-column-group:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-column-group:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -3px;\n left: -3px;\n display: block;\n width: calc(100% - -6px);\n height: calc(100% - -6px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-column:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-column:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -3px;\n left: -3px;\n display: block;\n width: calc(100% - -6px);\n height: calc(100% - -6px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-column-select-column-group:not(:last-child),\n .ag-theme-alpine-dark .ag-column-select-column:not(:last-child) {\n margin-bottom: 9px; }\n .ag-theme-alpine-dark .ag-column-select-column-readonly,\n .ag-theme-alpine-dark .ag-column-select-column-group-readonly {\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5));\n pointer-events: none; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-column-select-list {\n padding: 12px 12px; }\n .ag-theme-alpine-dark .ag-rtl {\n text-align: right; }\n .ag-theme-alpine-dark .ag-root-wrapper {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n border-radius: 3px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 46px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 46px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-1 {\n padding-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-1 {\n padding-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 74px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 74px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-2 {\n padding-left: 56px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-2 {\n padding-right: 56px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 102px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 102px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-3 {\n padding-left: 84px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-3 {\n padding-right: 84px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 130px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 130px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-4 {\n padding-left: 112px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-4 {\n padding-right: 112px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 158px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 158px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-5 {\n padding-left: 140px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-5 {\n padding-right: 140px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 186px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 186px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-6 {\n padding-left: 168px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-6 {\n padding-right: 168px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 214px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 214px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-7 {\n padding-left: 196px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-7 {\n padding-right: 196px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 242px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 242px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-8 {\n padding-left: 224px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-8 {\n padding-right: 224px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 270px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 270px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-9 {\n padding-left: 252px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-9 {\n padding-right: 252px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 298px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 298px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-10 {\n padding-left: 280px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-10 {\n padding-right: 280px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 326px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 326px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-11 {\n padding-left: 308px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-11 {\n padding-right: 308px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 354px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 354px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-12 {\n padding-left: 336px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-12 {\n padding-right: 336px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 382px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 382px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-13 {\n padding-left: 364px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-13 {\n padding-right: 364px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 410px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 410px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-14 {\n padding-left: 392px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-14 {\n padding-right: 392px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 438px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 438px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-15 {\n padding-left: 420px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-15 {\n padding-right: 420px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 466px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 466px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-16 {\n padding-left: 448px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-16 {\n padding-right: 448px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 494px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 494px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-17 {\n padding-left: 476px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-17 {\n padding-right: 476px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 522px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 522px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-18 {\n padding-left: 504px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-18 {\n padding-right: 504px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 550px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 550px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-group-indent-19 {\n padding-left: 532px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-group-indent-19 {\n padding-right: 532px; }\n .ag-theme-alpine-dark .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine-dark .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine-dark .ag-cell {\n -webkit-font-smoothing: subpixel-antialiased; }\n .ag-theme-alpine-dark .ag-value-change-delta {\n padding-right: 2px; }\n .ag-theme-alpine-dark .ag-value-change-delta-up {\n color: #43a047;\n color: var(--ag-value-change-delta-up-color, #43a047); }\n .ag-theme-alpine-dark .ag-value-change-delta-down {\n color: #e53935;\n color: var(--ag-value-change-delta-down-color, #e53935); }\n .ag-theme-alpine-dark .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n transition: background-color 1s; }\n .ag-theme-alpine-dark .ag-value-change-value-highlight {\n background-color: rgba(22, 160, 133, 0.5);\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5));\n transition: background-color 0.1s; }\n .ag-theme-alpine-dark .ag-cell-data-changed {\n background-color: rgba(22, 160, 133, 0.5) !important;\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5)) !important; }\n .ag-theme-alpine-dark .ag-cell-data-changed-animation {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-cell-highlight {\n background-color: #2196f3 !important;\n background-color: var(--ag-range-selection-highlight-color, var(--ag-range-selection-border-color, #2196f3)) !important; }\n .ag-theme-alpine-dark .ag-row {\n height: 42px;\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n color: #fff;\n color: var(--ag-data-color, var(--ag-foreground-color, #fff));\n border-width: 1px;\n border-color: rgba(88, 86, 82, 0.5);\n border-color: var(--ag-row-border-color, var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5))); }\n .ag-theme-alpine-dark .ag-row:not(.ag-row-first) {\n border-top-style: solid; }\n .ag-theme-alpine-dark .ag-row.ag-row-last {\n border-bottom-style: solid; }\n .ag-theme-alpine-dark .ag-row-highlight-above::after, .ag-theme-alpine-dark .ag-row-highlight-below::after {\n content: '';\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #2196f3;\n background-color: var(--ag-range-selection-border-color, #2196f3);\n left: 1px; }\n .ag-theme-alpine-dark .ag-row-highlight-above::after {\n top: -1px; }\n .ag-theme-alpine-dark .ag-row-highlight-above.ag-row-first::after {\n top: 0; }\n .ag-theme-alpine-dark .ag-row-highlight-below::after {\n bottom: 0px; }\n .ag-theme-alpine-dark .ag-row-odd {\n background-color: #222628;\n background-color: var(--ag-odd-row-background-color, #222628); }\n .ag-theme-alpine-dark .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-row-hover {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine-dark .ag-ltr .ag-right-aligned-cell {\n text-align: right; }\n .ag-theme-alpine-dark .ag-rtl .ag-right-aligned-cell {\n text-align: left; }\n .ag-theme-alpine-dark .ag-ltr .ag-right-aligned-cell .ag-cell-value {\n margin-left: auto; }\n .ag-theme-alpine-dark .ag-rtl .ag-right-aligned-cell .ag-cell-value {\n margin-right: auto; }\n .ag-theme-alpine-dark .ag-cell {\n border: 1px solid transparent;\n line-height: 40px;\n padding-left: 17px;\n padding-right: 17px; }\n .ag-theme-alpine-dark .ag-row > .ag-cell-wrapper {\n padding-left: 17px;\n padding-right: 17px; }\n .ag-theme-alpine-dark .ag-row-dragging {\n cursor: move; }\n .ag-theme-alpine-dark .ag-row-dragging {\n opacity: 0.5; }\n .ag-theme-alpine-dark .ag-cell-inline-editing {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n border-radius: 3px;\n box-shadow: 0 1px 20px 1px black;\n padding: 6px;\n padding: 0;\n height: 42px;\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628); }\n .ag-theme-alpine-dark .ag-popup-editor {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n border-radius: 3px;\n box-shadow: 0 1px 20px 1px black;\n padding: 6px;\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n padding: 0; }\n .ag-theme-alpine-dark .ag-large-text-input {\n height: auto;\n padding: 18px; }\n .ag-theme-alpine-dark .ag-details-row {\n padding: 30px;\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f); }\n .ag-theme-alpine-dark .ag-overlay-loading-wrapper {\n background-color: rgba(24, 29, 31, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(24, 29, 31, 0.66)); }\n .ag-theme-alpine-dark .ag-overlay-loading-center {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n border-radius: 3px;\n box-shadow: 0 1px 20px 1px black;\n padding: 6px; }\n .ag-theme-alpine-dark .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px; }\n .ag-theme-alpine-dark .ag-loading {\n padding-left: 18px;\n display: flex;\n height: 100%;\n align-items: center; }\n .ag-theme-alpine-dark .ag-loading-icon {\n padding-right: 12px; }\n .ag-theme-alpine-dark .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear; }\n\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n .ag-theme-alpine-dark .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: #68686e;\n border-bottom-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: #68686e;\n border-top-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-ltr .ag-cell {\n border-right: solid transparent; }\n .ag-theme-alpine-dark .ag-rtl .ag-cell {\n border-left: solid transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-cell {\n border-right-width: 1px; }\n .ag-theme-alpine-dark .ag-rtl .ag-cell {\n border-left-width: 1px; }\n .ag-theme-alpine-dark .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-row-selected {\n background-color: rgba(33, 150, 243, 0.3);\n background-color: var(--ag-selected-row-background-color, rgba(33, 150, 243, 0.3)); }\n .ag-theme-alpine-dark .ag-cell-range-selected:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(33, 150, 243, 0.2)); }\n .ag-theme-alpine-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1);\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)); }\n .ag-theme-alpine-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1);\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)); }\n .ag-theme-alpine-dark .ag-cell-range-selected-1:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(33, 150, 243, 0.2))); }\n .ag-theme-alpine-dark .ag-cell-range-selected-2:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(33, 150, 243, 0.36)); }\n .ag-theme-alpine-dark .ag-cell-range-selected-3:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(33, 150, 243, 0.488)); }\n .ag-theme-alpine-dark .ag-cell-range-selected-4:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(33, 150, 243, 0.5904)); }\n .ag-theme-alpine-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #2196f3;\n border-top-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #2196f3;\n border-right-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #2196f3;\n border-bottom-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #2196f3;\n border-left-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-alpine-dark .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-alpine-dark .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-alpine-dark .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-alpine-dark .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-alpine-dark .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #2196f3;\n border-color: var(--ag-range-selection-border-color, #2196f3);\n outline: initial; }\n .ag-theme-alpine-dark .ag-cell.ag-selection-fill-top,\n .ag-theme-alpine-dark .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #2196f3;\n border-top-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-alpine-dark .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #2196f3;\n border-right-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-alpine-dark .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #2196f3;\n border-left-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-cell.ag-selection-fill-bottom,\n .ag-theme-alpine-dark .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #2196f3;\n border-bottom-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-alpine-dark .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #2196f3;\n border-left-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-alpine-dark .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #2196f3;\n border-right-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-fill-handle, .ag-theme-alpine-dark .ag-range-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #2196f3;\n background-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine-dark .ag-ltr .ag-fill-handle, .ag-theme-alpine-dark .ag-ltr .ag-range-handle {\n right: -1px; }\n .ag-theme-alpine-dark .ag-rtl .ag-fill-handle, .ag-theme-alpine-dark .ag-rtl .ag-range-handle {\n left: -1px; }\n .ag-theme-alpine-dark .ag-fill-handle {\n cursor: cell; }\n .ag-theme-alpine-dark .ag-range-handle {\n cursor: nwse-resize; }\n .ag-theme-alpine-dark .ag-cell-inline-editing {\n border-color: rgba(33, 150, 243, 0.4) !important;\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)) !important; }\n .ag-theme-alpine-dark .ag-menu {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n border-radius: 3px;\n box-shadow: 0 1px 20px 1px black;\n padding: 6px;\n padding: 0; }\n .ag-theme-alpine-dark .ag-menu-list {\n cursor: default;\n width: 100%;\n padding-top: 6px;\n padding-bottom: 6px; }\n .ag-theme-alpine-dark .ag-menu-option-part {\n padding-top: 8px;\n padding-bottom: 8px;\n line-height: 16px; }\n .ag-theme-alpine-dark .ag-menu-option-active {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine-dark .ag-menu-option-disabled {\n opacity: 0.5; }\n .ag-theme-alpine-dark .ag-menu-option-text {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-menu-option-icon {\n padding-left: 12px;\n padding-right: 6px;\n min-width: 28px; }\n .ag-theme-alpine-dark .ag-menu-option-shortcut {\n padding-left: 12px; }\n .ag-theme-alpine-dark .ag-menu-separator {\n height: 12px; }\n .ag-theme-alpine-dark .ag-menu-separator-cell:after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: #68686e;\n border-top-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-menu-option-popup-pointer {\n width: 28px;\n text-align: center; }\n .ag-theme-alpine-dark .ag-tabs-header {\n min-width: 220px;\n width: 100%;\n display: flex; }\n .ag-theme-alpine-dark .ag-tab {\n border-bottom: 2px solid transparent;\n display: flex;\n flex: none;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n flex: 1 1 auto;\n transition: border-bottom 0.3s; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-tab:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-tab:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-tab-selected {\n border-bottom-color: #2196f3;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine-dark .ag-menu-header {\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-filter-condition-operator {\n height: 17px; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 12px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 12px; }\n .ag-theme-alpine-dark .ag-set-filter-select-all {\n padding-top: 12px; }\n .ag-theme-alpine-dark .ag-set-filter-list {\n height: 180px; }\n .ag-theme-alpine-dark .ag-set-filter-filter {\n margin-top: 12px;\n margin-left: 12px;\n margin-right: 12px; }\n .ag-theme-alpine-dark .ag-filter-to {\n margin-top: 9px; }\n .ag-theme-alpine-dark .ag-mini-filter {\n margin: 12px 12px;\n margin-bottom: 0; }\n .ag-theme-alpine-dark .ag-set-filter-item {\n margin: 0px 12px; }\n .ag-theme-alpine-dark .ag-ltr .ag-set-filter-item-value {\n margin-left: 12px; }\n .ag-theme-alpine-dark .ag-rtl .ag-set-filter-item-value {\n margin-right: 12px; }\n .ag-theme-alpine-dark .ag-filter-header-container {\n padding-bottom: 12px;\n border-bottom: solid 1px;\n border-bottom-color: rgba(88, 86, 82, 0.5);\n border-bottom-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5)); }\n .ag-theme-alpine-dark .ag-filter-apply-panel {\n padding: 12px 12px;\n border-top: solid 1px;\n border-top-color: rgba(88, 86, 82, 0.5);\n border-top-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5)); }\n .ag-theme-alpine-dark .ag-filter-apply-panel-button {\n line-height: 1.5; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 12px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 12px; }\n .ag-theme-alpine-dark .ag-simple-filter-body-wrapper {\n padding: 12px 12px;\n padding-bottom: 3px; }\n .ag-theme-alpine-dark .ag-simple-filter-body-wrapper > * {\n margin-bottom: 9px; }\n .ag-theme-alpine-dark .ag-filter-no-matches {\n margin: 12px 12px; }\n .ag-theme-alpine-dark .ag-side-bar {\n position: relative; }\n .ag-theme-alpine-dark .ag-tool-panel-wrapper {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628); }\n .ag-theme-alpine-dark .ag-side-buttons {\n padding-top: 24px;\n width: 20px;\n position: relative;\n color: #fff;\n color: var(--ag-foreground-color, #fff);\n overflow: hidden; }\n .ag-theme-alpine-dark button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 12px 0 12px 0;\n width: 100%;\n margin: 0;\n min-height: 108px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none; }\n .ag-theme-alpine-dark button.ag-side-button-button:focus {\n box-shadow: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-side-button-button:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-side-button-icon-wrapper {\n margin-bottom: 3px; }\n .ag-theme-alpine-dark .ag-ltr .ag-side-bar-left,\n .ag-theme-alpine-dark .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-alpine-dark .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-ltr .ag-side-bar-left .ag-side-button-button,\n .ag-theme-alpine-dark .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 2px solid transparent;\n transition: border-right 0.3s; }\n .ag-theme-alpine-dark .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-alpine-dark .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #2196f3;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine-dark .ag-rtl .ag-side-bar-left,\n .ag-theme-alpine-dark .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-alpine-dark .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-rtl .ag-side-bar-left .ag-side-button-button,\n .ag-theme-alpine-dark .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 2px solid transparent;\n transition: border-left 0.3s; }\n .ag-theme-alpine-dark .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-alpine-dark .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #2196f3;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine-dark .ag-filter-toolpanel-header {\n height: 36px; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-header, .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-header, .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 6px; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f112\";\n position: absolute; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-left: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-right: 6px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-0-header {\n height: 48px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-item {\n margin-top: 3px;\n margin-bottom: 3px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-search {\n height: 48px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-search-input {\n flex-grow: 1;\n height: 24px; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: rgba(88, 86, 82, 0.5);\n border-top-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5)); }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 22px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 22px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 38px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 38px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 54px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 54px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 70px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 70px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 86px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 86px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 102px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 102px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 118px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 118px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 134px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 134px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 150px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 150px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 166px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 166px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 6px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: #68686e;\n border-top-color: var(--ag-border-color, #68686e);\n border-bottom: solid 1px;\n border-bottom-color: #68686e;\n border-bottom-color: var(--ag-border-color, #68686e);\n padding-top: 6px; }\n .ag-theme-alpine-dark .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-pivot-mode-panel {\n height: 48px;\n display: flex; }\n .ag-theme-alpine-dark .ag-pivot-mode-select {\n display: flex;\n align-items: center; }\n .ag-theme-alpine-dark .ag-ltr .ag-pivot-mode-select {\n margin-left: 12px; }\n .ag-theme-alpine-dark .ag-rtl .ag-pivot-mode-select {\n margin-right: 12px; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-column-select-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-column-select-header {\n height: 48px;\n align-items: center;\n padding: 0 12px;\n border-bottom: solid 1px;\n border-bottom-color: rgba(88, 86, 82, 0.5);\n border-bottom-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5)); }\n .ag-theme-alpine-dark .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: rgba(88, 86, 82, 0.5);\n border-bottom-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5));\n border-top: solid 1px;\n border-top-color: rgba(88, 86, 82, 0.5);\n border-top-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5)); }\n .ag-theme-alpine-dark .ag-column-group-icons,\n .ag-theme-alpine-dark .ag-column-select-header-icon {\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-header {\n background-color: #222628;\n background-color: var(--ag-header-background-color, #222628);\n border-bottom: solid 1px;\n border-bottom-color: #68686e;\n border-bottom-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-header-row {\n color: #fff;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff))); }\n .ag-theme-alpine-dark .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-header-row {\n height: 48px; }\n .ag-theme-alpine-dark .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-header-cell,\n .ag-theme-alpine-dark .ag-header-group-cell {\n padding-left: 18px;\n padding-right: 18px; }\n .ag-theme-alpine-dark .ag-header-cell.ag-header-cell-moving,\n .ag-theme-alpine-dark .ag-header-group-cell.ag-header-cell-moving {\n background-color: #181d1f;\n background-color: var(--ag-header-cell-moving-background-color, var(--ag-background-color, #181d1f)); }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-header-cell:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-header-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none; }\n .ag-theme-alpine-dark .ag-keyboard-focus .ag-header-group-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark .ag-header-icon {\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-header-expand-icon {\n cursor: pointer; }\n .ag-theme-alpine-dark .ag-ltr .ag-header-expand-icon {\n padding-left: 4px; }\n .ag-theme-alpine-dark .ag-rtl .ag-header-expand-icon {\n padding-right: 4px; }\n .ag-theme-alpine-dark .ag-header-row:not(:first-child) .ag-header-cell,\n .ag-theme-alpine-dark .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: #68686e;\n border-top-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-header-cell-resize {\n display: flex;\n align-items: center; }\n .ag-theme-alpine-dark .ag-header-cell-resize::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n left: calc(50% - 1px);\n width: 2px;\n height: 30%;\n top: calc(50% - 15%);\n background-color: rgba(104, 104, 110, 0.5);\n background-color: var(--ag-header-column-resize-handle-color, rgba(104, 104, 110, 0.5)); }\n .ag-theme-alpine-dark .ag-pinned-right-header .ag-header-cell-resize::after {\n left: calc(50% - 2px); }\n .ag-theme-alpine-dark .ag-ltr .ag-header-select-all {\n margin-right: 18px; }\n .ag-theme-alpine-dark .ag-rtl .ag-header-select-all {\n margin-left: 18px; }\n .ag-theme-alpine-dark .ag-ltr .ag-floating-filter-button {\n margin-left: 18px; }\n .ag-theme-alpine-dark .ag-rtl .ag-floating-filter-button {\n margin-right: 18px; }\n .ag-theme-alpine-dark .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 16px;\n padding: 0;\n width: 16px; }\n .ag-theme-alpine-dark .ag-filter-loading {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n height: 100%;\n padding: 12px 12px;\n position: absolute;\n width: 100%;\n z-index: 1; }\n .ag-theme-alpine-dark .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: #68686e;\n border-top-color: var(--ag-border-color, #68686e);\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n height: 48px; }\n .ag-theme-alpine-dark .ag-paging-panel > * {\n margin: 0 18px; }\n .ag-theme-alpine-dark .ag-paging-button {\n cursor: pointer;\n opacity: 0;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n padding: 0;\n width: 16px; }\n .ag-theme-alpine-dark .ag-disabled .ag-paging-button {\n cursor: default; }\n .ag-theme-alpine-dark .ag-paging-button-wrapper.ag-disabled {\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5));\n cursor: default; }\n .ag-theme-alpine-dark .ag-paging-button-wrapper, .ag-theme-alpine-dark .ag-paging-description {\n margin: 0 6px; }\n .ag-theme-alpine-dark .ag-status-bar {\n border-top: solid 1px;\n border-top-color: #68686e;\n border-top-color: var(--ag-border-color, #68686e);\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5));\n padding-right: 24px;\n padding-left: 24px;\n line-height: 1.5; }\n .ag-theme-alpine-dark .ag-status-name-value-value {\n color: #fff;\n color: var(--ag-foreground-color, #fff); }\n .ag-theme-alpine-dark .ag-status-bar-center {\n text-align: center; }\n .ag-theme-alpine-dark .ag-status-name-value {\n margin-left: 6px;\n margin-right: 6px;\n padding-top: 12px;\n padding-bottom: 12px; }\n .ag-theme-alpine-dark .ag-column-drop-cell {\n background: rgba(255, 255, 255, 0.07);\n background: var(--ag-chip-background-color, rgba(255, 255, 255, 0.07));\n border-radius: 24px;\n height: 24px;\n padding: 0 3px; }\n .ag-theme-alpine-dark .ag-column-drop-cell-text {\n margin: 0 6px; }\n .ag-theme-alpine-dark .ag-column-drop-cell-button {\n min-width: 24px;\n margin: 0 3px;\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-column-drop-cell-drag-handle {\n margin-left: 12px; }\n .ag-theme-alpine-dark .ag-column-drop-cell-ghost {\n opacity: 0.5; }\n .ag-theme-alpine-dark .ag-column-drop-horizontal {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff));\n height: 42px;\n border-bottom: solid 1px;\n border-bottom-color: #68686e;\n border-bottom-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-ltr .ag-column-drop-horizontal {\n padding-left: 18px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-drop-horizontal {\n padding-right: 18px; }\n .ag-theme-alpine-dark .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-column-drop-horizontal-cell-separator {\n margin: 0 6px;\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-column-drop-horizontal-empty-message {\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5)); }\n .ag-theme-alpine-dark .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 18px; }\n .ag-theme-alpine-dark .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 18px; }\n .ag-theme-alpine-dark .ag-column-drop-vertical-list {\n padding-bottom: 6px;\n padding-right: 6px;\n padding-left: 6px; }\n .ag-theme-alpine-dark .ag-column-drop-vertical-cell {\n margin-top: 6px; }\n .ag-theme-alpine-dark .ag-column-drop-vertical {\n min-height: 50px;\n max-height: 150px;\n border-bottom: solid 1px;\n border-bottom-color: rgba(88, 86, 82, 0.5);\n border-bottom-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5)); }\n .ag-theme-alpine-dark .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none; }\n .ag-theme-alpine-dark .ag-column-drop-vertical-icon {\n margin-left: 6px;\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-column-drop-vertical-list {\n position: relative; }\n .ag-theme-alpine-dark .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5));\n margin-top: 6px; }\n .ag-theme-alpine-dark .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n border-radius: 3px;\n box-shadow: 0 1px 20px 1px black;\n padding: 6px;\n background: #181d1f;\n background: var(--ag-background-color, #181d1f);\n height: 105px;\n padding: 0; }\n .ag-theme-alpine-dark .ag-select-agg-func-virtual-list-item {\n cursor: default;\n line-height: 30px;\n padding-left: 12px; }\n .ag-theme-alpine-dark .ag-select-agg-func-virtual-list-item:hover {\n background-color: rgba(33, 150, 243, 0.3);\n background-color: var(--ag-selected-row-background-color, rgba(33, 150, 243, 0.3)); }\n .ag-theme-alpine-dark .ag-chart-menu {\n border-radius: 3px;\n background: #181d1f;\n background: var(--ag-background-color, #181d1f); }\n .ag-theme-alpine-dark .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 3px;\n color: #fff;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff)); }\n .ag-theme-alpine-dark .ag-chart-menu-icon:hover {\n opacity: 1; }\n .ag-theme-alpine-dark .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: rgba(88, 86, 82, 0.5);\n border-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5));\n border-radius: 5px;\n margin: 5px; }\n .ag-theme-alpine-dark .ag-chart-mini-thumbnail:nth-last-child(3),\n .ag-theme-alpine-dark .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto; }\n .ag-theme-alpine-dark .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0; }\n .ag-theme-alpine-dark .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0; }\n .ag-theme-alpine-dark .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0; }\n .ag-theme-alpine-dark .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0; }\n .ag-theme-alpine-dark .ag-chart-mini-thumbnail.ag-selected {\n border-color: #2196f3;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3))); }\n .ag-theme-alpine-dark .ag-chart-settings-card-item {\n background: #fff;\n background: var(--ag-foreground-color, #fff);\n width: 8px;\n height: 8px;\n border-radius: 4px; }\n .ag-theme-alpine-dark .ag-chart-settings-card-item.ag-selected {\n background-color: #2196f3;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3))); }\n .ag-theme-alpine-dark .ag-chart-data-column-drag-handle {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-charts-settings-group-title-bar,\n .ag-theme-alpine-dark .ag-charts-data-group-title-bar,\n .ag-theme-alpine-dark .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: rgba(88, 86, 82, 0.5);\n border-top-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5)); }\n .ag-theme-alpine-dark .ag-charts-settings-group-container {\n padding: 6px; }\n .ag-theme-alpine-dark .ag-charts-data-group-container {\n padding: 12px 12px;\n padding-bottom: 3px; }\n .ag-theme-alpine-dark .ag-charts-data-group-container > * {\n margin-bottom: 9px; }\n .ag-theme-alpine-dark .ag-charts-format-top-level-group-container {\n margin-left: 12px;\n padding: 6px; }\n .ag-theme-alpine-dark .ag-charts-format-top-level-group-item {\n margin: 6px 0; }\n .ag-theme-alpine-dark .ag-charts-format-sub-level-group-container {\n padding: 12px 12px;\n padding-bottom: 3px; }\n .ag-theme-alpine-dark .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 9px; }\n .ag-theme-alpine-dark .ag-charts-group-container.ag-group-container-horizontal {\n padding: 6px; }\n .ag-theme-alpine-dark .ag-chart-data-section,\n .ag-theme-alpine-dark .ag-chart-format-section {\n display: flex;\n margin: 0; }\n .ag-theme-alpine-dark .ag-chart-menu-panel {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628); }\n .ag-theme-alpine-dark .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: #68686e;\n border-right-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-date-time-list-page-title {\n flex-grow: 1;\n text-align: center; }\n .ag-theme-alpine-dark .ag-date-time-list-page-column-label {\n text-align: center; }\n .ag-theme-alpine-dark .ag-date-time-list-page-entry {\n text-align: center; }\n .ag-theme-alpine-dark .ag-checkbox-input-wrapper {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: #181d1f;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, #181d1f));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n flex: none; }\n .ag-theme-alpine-dark .ag-checkbox-input-wrapper input, .ag-theme-alpine-dark .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-alpine-dark .ag-checkbox-input-wrapper:focus-within, .ag-theme-alpine-dark .ag-checkbox-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6); }\n .ag-theme-alpine-dark .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-alpine-dark .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #999;\n color: var(--ag-checkbox-unchecked-color, #999);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine-dark .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #2196f3;\n color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine-dark .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #999;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, #999));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine-dark .ag-toggle-button-input-wrapper {\n box-sizing: border-box;\n width: 28px;\n height: 18px;\n background-color: #999;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, #999));\n border-radius: 9px;\n position: relative;\n flex: none;\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #999)); }\n .ag-theme-alpine-dark .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%; }\n .ag-theme-alpine-dark .ag-toggle-button-input-wrapper:focus-within {\n outline: none;\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6); }\n .ag-theme-alpine-dark .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-alpine-dark .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #2196f3;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)));\n border-color: #2196f3;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3))); }\n .ag-theme-alpine-dark .ag-toggle-button-input-wrapper::before {\n content: ' ';\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n box-sizing: border-box;\n height: 18px;\n width: 18px;\n background-color: #181d1f;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #181d1f));\n border-radius: 9px;\n transition: left 100ms;\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #999))); }\n .ag-theme-alpine-dark .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 18px);\n border-color: #2196f3;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3))); }\n .ag-theme-alpine-dark .ag-radio-button-input-wrapper {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: #181d1f;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, #181d1f));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n flex: none;\n border-radius: 16px; }\n .ag-theme-alpine-dark .ag-radio-button-input-wrapper input, .ag-theme-alpine-dark .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-alpine-dark .ag-radio-button-input-wrapper:focus-within, .ag-theme-alpine-dark .ag-radio-button-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6); }\n .ag-theme-alpine-dark .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-alpine-dark .ag-radio-button-input-wrapper::after {\n content: \"\\f124\";\n color: #999;\n color: var(--ag-checkbox-unchecked-color, #999);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine-dark .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f125\";\n color: #2196f3;\n color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine-dark input[class^='ag-'][type='range'] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible; }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #68686e;\n background-color: var(--ag-border-color, #68686e);\n border-radius: 3px;\n border-radius: 3px; }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #68686e;\n background-color: var(--ag-border-color, #68686e);\n border-radius: 3px;\n border-radius: 3px; }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #68686e;\n background-color: var(--ag-border-color, #68686e);\n border-radius: 3px;\n border-radius: 3px;\n color: transparent;\n width: calc(100% - 2px); }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-checkbox-unchecked-color, #999);\n border-radius: 16px;\n -webkit-transform: translateY(-6.5px);\n transform: translateY(-6.5px); }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-checkbox-unchecked-color, #999);\n border-radius: 16px; }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-checkbox-unchecked-color, #999);\n border-radius: 16px; }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']:focus {\n outline: none; }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']:focus::-webkit-slider-thumb {\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n border-color: #2196f3;\n border-color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']:focus::-ms-thumb {\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n border-color: #2196f3;\n border-color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']:focus::-moz-ag-range-thumb {\n box-shadow: 0 0 2px 0.5px rgba(255, 255, 255, 0.5), 0 0 4px 3px rgba(33, 150, 243, 0.6);\n border-color: #2196f3;\n border-color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']:active::-webkit-slider-runnable-track {\n background-color: rgba(33, 150, 243, 0.4);\n background-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']:active::-moz-ag-range-track {\n background-color: rgba(33, 150, 243, 0.4);\n background-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']:active::-ms-track {\n background-color: rgba(33, 150, 243, 0.4);\n background-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine-dark input[class^='ag-'][type='range']:disabled {\n opacity: 0.5; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-header,\n .ag-theme-alpine-dark .ag-filter-toolpanel-search,\n .ag-theme-alpine-dark .ag-status-bar,\n .ag-theme-alpine-dark .ag-header-row,\n .ag-theme-alpine-dark .ag-panel-title-bar-title {\n font-weight: 700;\n color: #fff;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #fff))); }\n .ag-theme-alpine-dark .ag-ltr .ag-pinned-right-header .ag-header-row:after, .ag-theme-alpine-dark .ag-rtl .ag-pinned-left-header .ag-header-row:before {\n content: '';\n position: absolute;\n height: calc(100% - 20px);\n top: 10px;\n width: 1px;\n background-color: #68686e;\n background-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-ltr .ag-pinned-right-header .ag-header-row:after {\n right: 0; }\n .ag-theme-alpine-dark .ag-rtl .ag-pinned-left-header .ag-header-row:before {\n left: 0; }\n .ag-theme-alpine-dark .ag-row {\n font-size: 14px; }\n .ag-theme-alpine-dark input[class^='ag-']:not([type]),\n .ag-theme-alpine-dark input[class^='ag-'][type='text'],\n .ag-theme-alpine-dark input[class^='ag-'][type='number'],\n .ag-theme-alpine-dark input[class^='ag-'][type='tel'],\n .ag-theme-alpine-dark input[class^='ag-'][type='date'],\n .ag-theme-alpine-dark input[class^='ag-'][type='datetime-local'],\n .ag-theme-alpine-dark textarea[class^='ag-'] {\n min-height: 24px;\n border-radius: 3px; }\n .ag-theme-alpine-dark .ag-ltr input[class^='ag-']:not([type]),\n .ag-theme-alpine-dark .ag-ltr input[class^='ag-'][type='text'],\n .ag-theme-alpine-dark .ag-ltr input[class^='ag-'][type='number'],\n .ag-theme-alpine-dark .ag-ltr input[class^='ag-'][type='tel'],\n .ag-theme-alpine-dark .ag-ltr input[class^='ag-'][type='date'],\n .ag-theme-alpine-dark .ag-ltr input[class^='ag-'][type='datetime-local'],\n .ag-theme-alpine-dark .ag-ltr textarea[class^='ag-'] {\n padding-left: 6px; }\n .ag-theme-alpine-dark .ag-rtl input[class^='ag-']:not([type]),\n .ag-theme-alpine-dark .ag-rtl input[class^='ag-'][type='text'],\n .ag-theme-alpine-dark .ag-rtl input[class^='ag-'][type='number'],\n .ag-theme-alpine-dark .ag-rtl input[class^='ag-'][type='tel'],\n .ag-theme-alpine-dark .ag-rtl input[class^='ag-'][type='date'],\n .ag-theme-alpine-dark .ag-rtl input[class^='ag-'][type='datetime-local'],\n .ag-theme-alpine-dark .ag-rtl textarea[class^='ag-'] {\n padding-right: 6px; }\n .ag-theme-alpine-dark .ag-tab {\n padding: 9px;\n transition: color 0.4s; }\n .ag-theme-alpine-dark .ag-tab-selected {\n color: #2196f3;\n color: var(--ag-alpine-active-color, #2196f3); }\n .ag-theme-alpine-dark .ag-menu {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628); }\n .ag-theme-alpine-dark .ag-menu-header {\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n padding-top: 1px; }\n .ag-theme-alpine-dark .ag-tabs-header {\n border-bottom: solid 1px;\n border-bottom-color: #68686e;\n border-bottom-color: var(--ag-border-color, #68686e); }\n .ag-theme-alpine-dark .ag-charts-settings-group-title-bar,\n .ag-theme-alpine-dark .ag-charts-data-group-title-bar,\n .ag-theme-alpine-dark .ag-charts-format-top-level-group-title-bar {\n padding: 6px 12px;\n line-height: 20px; }\n .ag-theme-alpine-dark .ag-chart-mini-thumbnail {\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f); }\n .ag-theme-alpine-dark .ag-chart-settings-nav-bar {\n border-top: solid 1px;\n border-top-color: rgba(88, 86, 82, 0.5);\n border-top-color: var(--ag-secondary-border-color, rgba(88, 86, 82, 0.5)); }\n .ag-theme-alpine-dark .ag-ltr .ag-group-title-bar-icon {\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-group-title-bar-icon {\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-charts-format-top-level-group-toolbar {\n margin-top: 6px; }\n .ag-theme-alpine-dark .ag-ltr .ag-charts-format-top-level-group-toolbar {\n padding-left: 20px; }\n .ag-theme-alpine-dark .ag-rtl .ag-charts-format-top-level-group-toolbar {\n padding-right: 20px; }\n .ag-theme-alpine-dark .ag-charts-format-sub-level-group {\n border-left: dashed 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e);\n padding-left: 6px;\n margin-bottom: 12px; }\n .ag-theme-alpine-dark .ag-charts-format-sub-level-group-title-bar {\n padding-top: 0;\n padding-bottom: 0;\n background: none;\n font-weight: 700; }\n .ag-theme-alpine-dark .ag-charts-format-sub-level-group-container {\n padding-bottom: 0; }\n .ag-theme-alpine-dark .ag-charts-format-sub-level-group-item:last-child {\n margin-bottom: 0; }\n .ag-theme-alpine-dark .ag-dnd-ghost {\n font-size: 12px;\n font-weight: 700; }\n .ag-theme-alpine-dark .ag-side-buttons {\n width: 30px; }\n .ag-theme-alpine-dark .ag-standard-button {\n -moz-appearance: none;\n appearance: none;\n -webkit-appearance: none;\n border-radius: 3px;\n border: 1px solid;\n border-color: #2196f3;\n border-color: var(--ag-alpine-active-color, #2196f3);\n color: #2196f3;\n color: var(--ag-alpine-active-color, #2196f3);\n background-color: #181d1f;\n background-color: var(--ag-background-color, #181d1f);\n font-weight: 600;\n padding: 6px 12px; }\n .ag-theme-alpine-dark .ag-standard-button:hover {\n border-color: #2196f3;\n border-color: var(--ag-alpine-active-color, #2196f3);\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine-dark .ag-standard-button:active {\n border-color: #2196f3;\n border-color: var(--ag-alpine-active-color, #2196f3);\n background-color: #2196f3;\n background-color: var(--ag-alpine-active-color, #2196f3);\n color: #181d1f;\n color: var(--ag-background-color, #181d1f); }\n .ag-theme-alpine-dark .ag-standard-button:disabled {\n color: rgba(255, 255, 255, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(255, 255, 255, 0.5));\n background-color: #282c2f;\n background-color: var(--ag-input-disabled-background-color, #282c2f);\n border-color: rgba(104, 104, 110, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(104, 104, 110, 0.3)); }\n .ag-theme-alpine-dark .ag-menu-header {\n min-width: 240px; }\n .ag-theme-alpine-dark .ag-column-drop-vertical {\n min-height: 75px;\n max-height: 175px; }\n .ag-theme-alpine-dark .ag-tool-panel-wrapper {\n width: 250px; }\n .ag-theme-alpine-dark .ag-column-drop-vertical-title-bar {\n padding: 12px;\n padding-bottom: 0px; }\n .ag-theme-alpine-dark .ag-column-drop-vertical-empty-message {\n display: flex;\n align-items: center;\n border: dashed 1px;\n border-color: #68686e;\n border-color: var(--ag-border-color, #68686e);\n margin: 12px;\n padding: 12px; }\n .ag-theme-alpine-dark .ag-column-drop-empty-message {\n color: #fff;\n color: var(--ag-foreground-color, #fff);\n opacity: 0.75; }\n .ag-theme-alpine-dark .ag-status-bar {\n font-weight: normal; }\n .ag-theme-alpine-dark .ag-status-name-value-value {\n font-weight: 700; }\n .ag-theme-alpine-dark .ag-paging-number, .ag-theme-alpine-dark .ag-paging-row-summary-panel-number {\n font-weight: 700; }\n .ag-theme-alpine-dark .ag-column-drop-cell-button {\n opacity: 0.5; }\n .ag-theme-alpine-dark .ag-column-drop-cell-button:hover {\n opacity: 0.75; }\n .ag-theme-alpine-dark .ag-header-cell-menu-button:hover,\n .ag-theme-alpine-dark .ag-side-button-button:hover,\n .ag-theme-alpine-dark .ag-tab:hover,\n .ag-theme-alpine-dark .ag-panel-title-bar-button:hover,\n .ag-theme-alpine-dark .ag-header-expand-icon:hover,\n .ag-theme-alpine-dark .ag-column-group-icons:hover,\n .ag-theme-alpine-dark .ag-group-expanded .ag-icon:hover,\n .ag-theme-alpine-dark .ag-group-contracted .ag-icon:hover,\n .ag-theme-alpine-dark .ag-chart-settings-prev:hover,\n .ag-theme-alpine-dark .ag-chart-settings-next:hover,\n .ag-theme-alpine-dark .ag-group-title-bar-icon:hover,\n .ag-theme-alpine-dark .ag-column-select-header-icon:hover,\n .ag-theme-alpine-dark .ag-floating-filter-button-button:hover,\n .ag-theme-alpine-dark .ag-filter-toolpanel-expand:hover,\n .ag-theme-alpine-dark .ag-chart-menu-icon:hover {\n color: #2196f3;\n color: var(--ag-alpine-active-color, #2196f3); }\n .ag-theme-alpine-dark .ag-chart-settings-card-item.ag-not-selected:hover {\n opacity: 0.35; }\n .ag-theme-alpine-dark .ag-ltr .ag-panel-title-bar-button {\n margin-left: 12px;\n margin-right: 6px; }\n .ag-theme-alpine-dark .ag-rtl .ag-panel-title-bar-button {\n margin-right: 12px;\n margin-left: 6px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-group-container {\n padding-left: 6px; }\n .ag-theme-alpine-dark .ag-filter-toolpanel-instance-filter {\n border: none;\n background-color: #222628;\n background-color: var(--ag-control-panel-background-color, #222628);\n border-left: dashed 1px;\n border-left-color: #68686e;\n border-left-color: var(--ag-border-color, #68686e);\n margin-left: 13px;\n padding-left: 8px;\n margin-right: 12px; }\n .ag-theme-alpine-dark .ag-set-filter-list {\n padding-top: 3px;\n padding-bottom: 3px; }\n .ag-theme-alpine-dark .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 60px; }\n .ag-theme-alpine-dark .ag-date-time-list-page-entry-is-current {\n background-color: #2196f3;\n background-color: var(--ag-alpine-active-color, #2196f3); }\n\n", ""]);
  46220. // Exports
  46221. module.exports = exports;
  46222. /***/ }),
  46223. /* 230 */
  46224. /***/ (function(module, exports, __webpack_require__) {
  46225. var api = __webpack_require__(225);
  46226. var content = __webpack_require__(231);
  46227. content = content.__esModule ? content.default : content;
  46228. if (typeof content === 'string') {
  46229. content = [[module.i, content, '']];
  46230. }
  46231. var options = {};
  46232. options.insert = "head";
  46233. options.singleton = false;
  46234. var update = api(content, options);
  46235. module.exports = content.locals || {};
  46236. /***/ }),
  46237. /* 231 */
  46238. /***/ (function(module, exports, __webpack_require__) {
  46239. // Imports
  46240. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227);
  46241. exports = ___CSS_LOADER_API_IMPORT___(false);
  46242. // Module
  46243. exports.push([module.i, ".ag-theme-alpine {\n -webkit-font-smoothing: antialiased;\n color: #181d1f;\n color: var(--ag-foreground-color, #181d1f);\n font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n font-size: 13px;\n line-height: normal; }\n\n@font-face {\n font-family: \"agGridAlpine\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABNkAAsAAAAAIqAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlMAAAReYc5joU9TLzIAAANcAAAAQAAAAFZWUVJ5Y21hcAAAA5wAAAHqAAAFgHCsDfxnbHlmAAAFiAAACesAABCUC9Ir6mhlYWQAAA90AAAANAAAADZ2zsSBaGhlYQAAD6gAAAAeAAAAJAfSBC5obXR4AAAPyAAAABcAAAEou4D/+2xvY2EAAA/gAAAAbwAAAJbPsst2bWF4cAAAEFAAAAAfAAAAIAFgAHNuYW1lAAAQcAAAATUAAAJG5xgJvXBvc3QAABGoAAABuQAAApPSPvKNeJx9k81SE1EQhc9kQgwJBkREjREU//GPYX4yJiGQMAFisXDhwoUbXGhpUa54Atc+gOUD+BQ+geXSlQ/gA1g+gN/tTAyyIFOZubf79Onuc/vKk1TRmroqZDv7z1U7PDh6r7qKGv2c//jaO3z75kDl8Q5f0b5lef4f1bSiFzrSN0/ea+9zoeQX/K6/73/wP/k/5IO6pkegq1rnCRXxDhQrUVOpCiphC1k/UQu0z7tt1nktaso8mQa6QM6QmIExruqpbmkOnr7x9LQJKuZxnD3euzy3NXsKItUd+BOq2cDqWBvUeU7T2qHGHnV0iG7hncO3ReaAmD6+PrX5hiqajnt6SeS89eYikxwX8w+1bfvAdkuoMEa14W/C7/gek3Vsb5IpIuIh7Amobq7hKv8q3hhMQGzHNHPRSyAjKoy1zMp1FtHZjG7C/kyvdJ+47TymZyqOer5H9RN73/hS8hy3duDaBfuAGiZWdyJ3yRVoiL/CSWV6p4/6oq/6rp/6pd/gF8kSWQebcG+dqsw0+p1EZ3jb/6yu0zOcxUnU/4gKfTdNmxDfIFfQZZvB57SJWQdYY8NX4XT4jGpS9Jpi8gLLG2Etsd9gH4Ku5dPY4jlrOg+YATcBdbRY5+2YRvOWsr9MtFuN6rpoarXguWSn5TR1N2nWdm7m3SnX0fkK34DOEtNnD+9VLI5pYmlYVErVjmMNf0q1k2yuqgZVRcxA2SZraLcgI9N1+hhVEumG3YChTdUKFST5jVzQeau+k5/UguFCi/JQIshvcmyauUnuU5ubit2/LKNqzAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMb0GmMDCC5ADUogpqeJy11IdSWkEYxfE/RdNM79X0jgJiQIogIMhjmO6Y4pju5CnzJt8LxJzlnjyAmcnO/Fh2udy9O3fPB8wABXkqRcgXyZHab83mpvMFjk7ni/zSeI7D5PW9xBY77EV5f1+zJTbZZjdy09HfltPVc1zjPs80WqNClxZ9aoyp0tHsKm0GNKizzhJNlhkyYYUeIzb0/7xWLzLLIa16RM9xTPc7zglOcorTnOEs5zjPBS5yictc4apWu84N5rnJLW5zh7vc0/oPeMgjHvNE+ynp9wUWKesBZzlYWzvg9alVuq1+bVztaLftQaOujTaXh5OV3mjjH272H9pc+ij89GhCepuZtNtNq8hz68oLa8lL68srq8lrG8sbq8pb68iWpROybavyztry3gbywRry0eqyY+uya0vyyZry2Zbliw3lq6W9f7MV+W49+WEj2TO9wMhlUlYinyH1hUzKVhQzKV8xk9GZJkynmzCdc8J04glLGQxTCghLby9MySBMGSFMaSFMuSFMCSJMWSJMqSJM+SJMSSNMmSNM6SNMOSRMiSRM2SRMKSVMeSVMySVMGSVMaSZMuSZMCSdMWSdMqSdM+SdMlYAw1QTCVB0IU50gTBWDMNUOwlRFCEt1MyxlJmz6/AsZUr+YIfXlDOU/rrOgigAAeJzFF21sU9f1nntjvzgJSRx/vJgQg/3ivNSxwxL7+dkx2JAEEmhIqWpYCqMhMCbWdFppM7EBbsd+dEVV1apS6A/yY9O2oFVaQEOb+sFKtZaRqh/qVLQf/fixdkxkXbNRodIZ3mXnXttpApnW/Zr93rnn3nt8zrnnni8TIPihcyxKqgmBgEdVPAEjYOoBOsdrCgW4yu9HeJxFs4VCJlMoCHLbzes3r7NP2afEhr+qIx7SRIhLURXdtJkChhAwVaAuXcBPnn028uqrNIMg8iwfHR4eXidXInKBPrFgMnzv8DD/YiE9qiWEsh7WQypRjmo6Y07VhJPds7nLaX4GrqZnuQ2uz6ZhCx5F0k6wCeImq/CnQcWu2N2qV/V2mQkzEddb9VaXoqOSqBnqBlcPjI6YqZQ5MvpRGRnpPn68e2JCQjaxaEsi1uvlXYTk/yOTle6tFjFF3l3MqekxjyZG+G0+fzafh4P5PFtmvY0XeJAfK+t5mV0mLuITtx2sBY/T7YdYoCsDhjPeAQ4wVVDZD2587o/58WFVcrTm+N+GZmBqiF3G+aLNG5+Dd+gCTN21mL+6NH+GznUb9yetizRyO2fr4oMLeTLJ0xlwhpbiizxZ1S18i4vfvZVv0Xbs++yb6L+VpJEQByiqA5i5Euzi6jxub1fCENdGP+Ej3Xu5BZmZmQunq6t9dd7ODZ3eOh/8Hn6axg3+KqydmcksW+ZvavUFOzuDvtAKv2BfIWVEMa6K91NHSCjgDNg0Z8ylOdPg1Jwsaj1FD/DN8q5eyhdoLM+PiZsq3lbJ7+lp5GFDHSm6DxyEFL+AYcii/AKfKcVj8Tw/ZOfwND7SLC1v92CUBFSJuL1oqATaqVVzoQ70NK/ROnNwNc8NoTK8gVADbsAb7OXOoPUC7b+nU7NeEHu0X+u09tH+Ugw+zZ4WvuYANJfiAB3dBa7Cvb18Cnb08pN8qhd2IKCJRVPYgSTkljgGXUEb6Aqw9TKQYYsIZLjObbMY1IvPHkKBioq2moEk5qGzkIRUduHZn8A4aCIdZK3ga6qJWJcfVoJSCyIp2ZUOuhrMDKg499NYl6nbtWAHGHFTVxNI6VbUhNlBg9C4NjKwfWT75HgzY+6+aDRi7hr7+uT4iooKz9BotM+9fPTowN2b0mGjfVM4UJlsuWdT2D0w1OLbc/RJ+nP87R19h7dWVZu7tI5IIgbQd2hrddWafY7me7rW7zVbuleG+9uN9t1Jd3gg1zKQ3omLC/SvxdwRRf3RpYUyUtdQhpZOQlHh1WDDTfR23ETvpxX9R/f4UPhTR0eXo2r8/IrxyV9J5ZslsqICfhzeFA5v2iYA+My961FkEV7aerhPaFtVGidRp4GwBKWYG0PbK2QZaqR4FKduBGyqxzRMNlZ4qUBPWdPvZ9+jc4XJszBcyGbffy8z+T4p50J6jc7hvTnkbeiKKnISvfbKK+lCgRu5HBjnzqVlbakhNcU4QfpynIjc0URWEo3opJ2sJsTUjJi64A39lznWqbPZ7EsSWm/9p0khX/xkS2OmNKI6lfPnv1UnAlgdQ/i6UI6Br46vWFNwDODIxoSPWm9LViiCnuIziMFv+Aw9IOXyzVmUleXHUIVMJrOEzVzo61iA0WZXpMngYC5Hz0iT8RpyWxxhscYw1ANsfTF0YIsII+qf7eZn+Jnu2XKMTNDzWJ8aSQQlxDOQBkMr+pHEOkDF1BzSPBg6tBbaARHpaz8LrtGmplK7k8ndqakpbU3wORjiv4aDEgdtfhOuamntruTIQyPJu7S0kptCuFGs7D4wkpQ2vXmTzco8fotNA5gTRXG0ic4BlbCJBqQ0F/mSLh8cPHbNvEbbzWsmJpQ3IW4NCrgL5/QT3OFvDg5CvBUxfMy1g4OD4zjic+2PEC/XkOfYc6iFU+bhmAfQKTEZagbogPWSHxsG2sP5h1g07+W8B+gHWTj4oVxjLn7sA7k2n2++9Fe0vzH/LWb08gspvOd8piz/HfZOUf682HlFsvNC0X/KmgilimL/VNZkviZMF/OiSG8qwPfSnKchxaI4dkOy5E+XWL3sz0SmVbG0KaL5oJeuXImcPx+RkPrl8JiE82cr9jEBzKZLdzIQF2isy6tCB0CwVQc/eNyCcKm+hvdEI4Nbdqb2t/NosAW2IALvBlvE4lJtDh/ZuWUwEm0J8mj7fv73liC8274/JdfK+j2Adc6LfqOjfhrmQrui3VLkAl1etz3YGk+AMHDAiLHGU8vWbV237JQsaQMC8g+cPl/Q5wPDej4HP8mxsVBHRwir3z5JcyLY2ag14mM10BMiKRTv8Ag7TIKlKpMoflWzVQxZAMWOhkZTKfY6NLkuegm0eitaBgQFliDVG/MiqsPdz2D2tjmau1ebeyvranwNqhv8nnUb9gNQ5vZE1eN/icAll6Omsn4y0dblhOWVKoVKOlFZVV1X21B/ER55xlFdXVfTVu2oHl3ub2xyNdTyj1Zsq9lnt/mM9q+p1ciBPlVf76r1TtYy1sT/anfrjfGG4xUVoFQ2XBTHqZJnmmbTGImrSBtZTzaSO0mO7CSj5Ft4Rj9VG1gtVSpCHVSnrgw1W2wBpxcrqZmwuVVRmAzpVorucWO90lQ58UrDhNxqzMDaGzPMMKBFYpioPTG9A/SQXVM8MbMVcw1ztm0IA6oU3tDGP+YffzmDZjhkXfjHnBanDqsSaFxbBS9WRbblIo7wxrZxR2TbtkjVupau5X6wXocjhwHy2fidSYBDWfjdIUGP5kiFHz2X7H+U/XJJ/s1ydsN63e5A8rm3nPUoDA5DnWTueLCtv506IjmUAzbF5Q37NyYfeXmz8ei/EqGR7JEjQaRmAEfy8MhtcSkzMp1O8wuQSnP6WVp0a92cLOxn3eSOcoTVC7dZJcxWLyKMBQWUYdYldkrB9fj4gd6+vt4D41Bfxh7/zq4dhmkaO3a9V0bYZbHB/7mY+MaRRUQSKcWT0KUG4z0htJEFoZj49f9Btb6He3sfflyAvq+mJZ0r0SMofGWFb6t9iopFV6TABf8BZT85241/BovnG2Rjsq7KTkbkQPyXG5AdSTEXWh/T09ZWTNYZmJUL/GSWzllvl2UxekLcmssBl6AO6ugJrH5Dpfs+wZjYc9DiKmP8Cr+yeA97V2xtsWTKXy/Ns0hQ2vsFc8l+X/TYJtwPX/Ra5/mfe6BJYH+AlT0luijtFSd04WnOyoLTc9+8faJ0ulgfdOzS6WeyLECKTmOdEC65INePYUXykC6RS0XpB4/Xrqj4pwodAOM5Jnpmz5c9ghFPmCoSqviYQF8rNgFmeG08m9y95xu5Suv5H3UPlDuFns7tKx8aGTgZt/rpa9gOaJEN1Wub9qxJjSSncvDA0cZvr0vJbkHr3GzbnrsPKemLhPwbDwYCEQB4nGNgZGBgAOLsD0FR8fw2Xxm4mV8ABaI4H+9rgNH/f///zfyW+S1QJQcDE5BkAACRug+HeJxjYGRgYH7BwAAi///+/5v5LQMjAyrwAgCe2QcHAAB4nGNgYGBgfgHC/39D6KGH6QEAIHUuCwB4nGNgAAIphiCGDIZFDHcYvjGqMQYwVjGuYTzH+IhJhMmMyYcpgekAMxezBrMDcxfzIeZbzJ9YTFiKWGawbGK5wfKKlY01jHUK6z+2JWw72P6xR7Dnsfexz2Ffxb6D/Rj7LfYX7H84vEiHANyaI6IAeJxjYGRgYPBiSGfgYQABJiDmAkIGhv9gPgMAGzsB1AB4nHWRPU7DQBCFnxMniBghJCREx1Y0SM5PQZEuFHGfIgWdE68dR7bXWm8ipeMYnIBjUHIETsEheDFTREjZ1a6/+fbNNAZwgy94OC4PV+19XB1csPrjLulW2Cc/CPcQ4Em4T/8sPKB9EQ7YWXKC51/S3ONNuINrvAt36T+EffKncA93+Bbu0/8ID7D0fOEAj95rnEU2T2ZFnVd6obNdEdtTdcpLbZvcVGocjk51pCttY6cTtTqoZp9NnEtVak2p5qZyuiiMqq3Z6rULN87V0+EwFR+uTYkYGSJY5EgwQ4GaVEFjwZNhRxPz9VzqnF/yWDSsDGuFMUKMzqYjnqrtiOH4TdixwoF3gz17JrQOKeuUGcO/ojBvJx/TBbehqdu3Lc2aPsSm7aoxxZA7/ZcPmeKkXwK+aWkAAAB4nG2S6W7bMBCE/cWSI9tpk7ptet/3obbpfaf3kT4FQ9EyEYkUSMp28vRl4yBAgO4fzgwWs7MLdpY6ixp0/l9bLNElIaXHMhl9BgxZ4RjHWWWNE4w4ySlOs84ZznKO81zgIpe4zBWuco3r3OAmt7jNHe5yj/s84CE5j3jMEzZ4yjOe84KXvOI1b3jLO97zgY9s8onPfOEr3/jOD37yi99s8aczFGXpVCmCtqYnnLMz3xVe9qQwUlXZ4sk3UjkRLqzJiZI723ae7wNVrB8K2hQqKFdrI4IaHcqtOehckbayLm90JG45krY2fiCtCU7IoIpE2mY3lc56nxTKy0zNGxE9i77aVbmvhJ90I+qNdRXHpGPtfEhKp5u0dLZtktgQkkqNQ6/SJs5brqwotCmzWsx1rfdUUivTZjHfghk1D4mxRg2NDbmoKjtTRdpEF9VttEkbPbUha5yaatv6NRfNbL7dhmBNbsfj1aOCSZ0uJyHxYqoGvo52eWFn5gD+izVcwP22bIFj6hDPMQpOqaP36+9LtlEma81iHwQlDkVAYzHM8EgqJuywzTx+g4KaloZdxuwx7XT+AvL3sQsAAAA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n .ag-theme-alpine .ag-icon {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n .ag-theme-alpine .ag-icon-aggregation:before {\n content: \"\\f101\"; }\n .ag-theme-alpine .ag-icon-arrows:before {\n content: \"\\f102\"; }\n .ag-theme-alpine .ag-icon-asc:before {\n content: \"\\f103\"; }\n .ag-theme-alpine .ag-icon-cancel:before {\n content: \"\\f104\"; }\n .ag-theme-alpine .ag-icon-chart:before {\n content: \"\\f105\"; }\n .ag-theme-alpine .ag-icon-color-picker:before {\n content: \"\\f109\"; }\n .ag-theme-alpine .ag-icon-columns:before {\n content: \"\\f10a\"; }\n .ag-theme-alpine .ag-icon-contracted:before {\n content: \"\\f10b\"; }\n .ag-theme-alpine .ag-icon-copy:before {\n content: \"\\f10c\"; }\n .ag-theme-alpine .ag-icon-cross:before {\n content: \"\\f10d\"; }\n .ag-theme-alpine .ag-icon-desc:before {\n content: \"\\f10e\"; }\n .ag-theme-alpine .ag-icon-expanded:before {\n content: \"\\f10f\"; }\n .ag-theme-alpine .ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n .ag-theme-alpine .ag-icon-eye:before {\n content: \"\\f111\"; }\n .ag-theme-alpine .ag-icon-filter:before {\n content: \"\\f112\"; }\n .ag-theme-alpine .ag-icon-first:before {\n content: \"\\f113\"; }\n .ag-theme-alpine .ag-icon-grip:before {\n content: \"\\f114\"; }\n .ag-theme-alpine .ag-icon-group:before {\n content: \"\\f115\"; }\n .ag-theme-alpine .ag-icon-last:before {\n content: \"\\f116\"; }\n .ag-theme-alpine .ag-icon-left:before {\n content: \"\\f117\"; }\n .ag-theme-alpine .ag-icon-linked:before {\n content: \"\\f118\"; }\n .ag-theme-alpine .ag-icon-loading:before {\n content: \"\\f119\"; }\n .ag-theme-alpine .ag-icon-maximize:before {\n content: \"\\f11a\"; }\n .ag-theme-alpine .ag-icon-menu:before {\n content: \"\\f11b\"; }\n .ag-theme-alpine .ag-icon-minimize:before {\n content: \"\\f11c\"; }\n .ag-theme-alpine .ag-icon-next:before {\n content: \"\\f11d\"; }\n .ag-theme-alpine .ag-icon-none:before {\n content: \"\\f11e\"; }\n .ag-theme-alpine .ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n .ag-theme-alpine .ag-icon-paste:before {\n content: \"\\f120\"; }\n .ag-theme-alpine .ag-icon-pin:before {\n content: \"\\f121\"; }\n .ag-theme-alpine .ag-icon-pivot:before {\n content: \"\\f122\"; }\n .ag-theme-alpine .ag-icon-previous:before {\n content: \"\\f123\"; }\n .ag-theme-alpine .ag-icon-right:before {\n content: \"\\f126\"; }\n .ag-theme-alpine .ag-icon-save:before {\n content: \"\\f127\"; }\n .ag-theme-alpine .ag-icon-small-down:before {\n content: \"\\f128\"; }\n .ag-theme-alpine .ag-icon-small-left:before {\n content: \"\\f129\"; }\n .ag-theme-alpine .ag-icon-small-right:before {\n content: \"\\f12a\"; }\n .ag-theme-alpine .ag-icon-small-up:before {\n content: \"\\f12b\"; }\n .ag-theme-alpine .ag-icon-tick:before {\n content: \"\\f12c\"; }\n .ag-theme-alpine .ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n .ag-theme-alpine .ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n .ag-theme-alpine .ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n .ag-theme-alpine .ag-icon-unlinked:before {\n content: \"\\f130\"; }\n .ag-theme-alpine .ag-icon-row-drag:before {\n content: \"\\f114\"; }\n .ag-theme-alpine .ag-right-arrow:before {\n content: \"\\f117\"; }\n .ag-theme-alpine .ag-right-arrow:before {\n content: \"\\f126\"; }\n .ag-theme-alpine .ag-root-wrapper {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-alpine [class^='ag-'], .ag-theme-alpine [class^='ag-']:focus, .ag-theme-alpine [class^='ag-']:after, .ag-theme-alpine [class^='ag-']:before {\n box-sizing: border-box;\n outline: none; }\n .ag-theme-alpine [class^='ag-']::-ms-clear {\n display: none; }\n .ag-theme-alpine .ag-checkbox .ag-input-wrapper,\n .ag-theme-alpine .ag-radio-button .ag-input-wrapper {\n overflow: visible; }\n .ag-theme-alpine .ag-range-field .ag-input-wrapper {\n height: 100%; }\n .ag-theme-alpine .ag-toggle-button {\n flex: none;\n width: unset;\n min-width: unset; }\n .ag-theme-alpine .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 6px; }\n .ag-theme-alpine .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 6px; }\n .ag-theme-alpine input[class^='ag-'] {\n margin: 0;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-alpine textarea[class^='ag-'],\n .ag-theme-alpine select[class^='ag-'] {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-alpine input[class^='ag-']:not([type]),\n .ag-theme-alpine input[class^='ag-'][type='text'],\n .ag-theme-alpine input[class^='ag-'][type='number'],\n .ag-theme-alpine input[class^='ag-'][type='tel'],\n .ag-theme-alpine input[class^='ag-'][type='date'],\n .ag-theme-alpine input[class^='ag-'][type='datetime-local'],\n .ag-theme-alpine textarea[class^='ag-'] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #babfc7;\n border-color: var(--ag-input-border-color, var(--ag-border-color, #babfc7)); }\n .ag-theme-alpine input[class^='ag-']:not([type]):disabled,\n .ag-theme-alpine input[class^='ag-'][type='text']:disabled,\n .ag-theme-alpine input[class^='ag-'][type='number']:disabled,\n .ag-theme-alpine input[class^='ag-'][type='tel']:disabled,\n .ag-theme-alpine input[class^='ag-'][type='date']:disabled,\n .ag-theme-alpine input[class^='ag-'][type='datetime-local']:disabled,\n .ag-theme-alpine textarea[class^='ag-']:disabled {\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5));\n background-color: #f1f2f4;\n background-color: var(--ag-input-disabled-background-color, #f1f2f4);\n border-color: rgba(186, 191, 199, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(186, 191, 199, 0.3)); }\n .ag-theme-alpine input[class^='ag-']:not([type]):focus,\n .ag-theme-alpine input[class^='ag-'][type='text']:focus,\n .ag-theme-alpine input[class^='ag-'][type='number']:focus,\n .ag-theme-alpine input[class^='ag-'][type='tel']:focus,\n .ag-theme-alpine input[class^='ag-'][type='date']:focus,\n .ag-theme-alpine input[class^='ag-'][type='datetime-local']:focus,\n .ag-theme-alpine textarea[class^='ag-']:focus {\n outline: none;\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine input[class^='ag-'][type='number'] {\n -moz-appearance: textfield; }\n .ag-theme-alpine input[class^='ag-'][type='number']::-webkit-outer-spin-button, .ag-theme-alpine input[class^='ag-'][type='number']::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0; }\n .ag-theme-alpine input[class^='ag-'][type='range'] {\n padding: 0; }\n .ag-theme-alpine input[class^='ag-'][type='button']:focus, .ag-theme-alpine button[class^='ag-']:focus {\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4); }\n .ag-theme-alpine .ag-drag-handle {\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-list-item, .ag-theme-alpine .ag-virtual-list-item {\n height: 30px; }\n .ag-theme-alpine .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-virtual-list-item:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-select-list {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n overflow-y: auto;\n overflow-x: hidden; }\n .ag-theme-alpine .ag-list-item {\n display: flex;\n align-items: center; }\n .ag-theme-alpine .ag-list-item.ag-active-item {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n .ag-theme-alpine .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden; }\n .ag-theme-alpine .ag-select .ag-picker-field-wrapper {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n min-height: 30px;\n cursor: default; }\n .ag-theme-alpine .ag-select:not(.ag-cell-editor) {\n height: 30px; }\n .ag-theme-alpine .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis; }\n .ag-theme-alpine .ag-select .ag-picker-field-icon {\n display: flex;\n align-items: center; }\n .ag-theme-alpine .ag-select.ag-disabled {\n opacity: 0.5; }\n .ag-theme-alpine .ag-rich-select {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8); }\n .ag-theme-alpine .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 273px; }\n .ag-theme-alpine .ag-rich-select-value {\n padding: 0 6px 0 18px;\n height: 42px;\n border-bottom: solid 1px;\n border-bottom-color: #dde2eb;\n border-bottom-color: var(--ag-secondary-border-color, #dde2eb); }\n .ag-theme-alpine .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 30px; }\n .ag-theme-alpine .ag-rich-select-virtual-list-item:hover {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine .ag-rich-select-row {\n padding-left: 18px; }\n .ag-theme-alpine .ag-rich-select-row-selected {\n background-color: rgba(33, 150, 243, 0.3);\n background-color: var(--ag-selected-row-background-color, rgba(33, 150, 243, 0.3)); }\n .ag-theme-alpine .ag-row-drag,\n .ag-theme-alpine .ag-selection-checkbox,\n .ag-theme-alpine .ag-group-expanded,\n .ag-theme-alpine .ag-group-contracted {\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-ltr .ag-row-drag, .ag-theme-alpine .ag-ltr .ag-selection-checkbox, .ag-theme-alpine .ag-ltr .ag-group-expanded, .ag-theme-alpine .ag-ltr .ag-group-contracted {\n margin-right: 12px; }\n .ag-theme-alpine .ag-rtl .ag-row-drag, .ag-theme-alpine .ag-rtl .ag-selection-checkbox, .ag-theme-alpine .ag-rtl .ag-group-expanded, .ag-theme-alpine .ag-rtl .ag-group-contracted {\n margin-left: 12px; }\n .ag-theme-alpine .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: 40px;\n display: flex;\n align-items: center;\n flex: none; }\n .ag-theme-alpine .ag-group-expanded,\n .ag-theme-alpine .ag-group-contracted {\n cursor: pointer; }\n .ag-theme-alpine .ag-group-title-bar-icon {\n cursor: pointer;\n flex: none;\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-ltr .ag-group-child-count {\n margin-left: 2px; }\n .ag-theme-alpine .ag-rtl .ag-group-child-count {\n margin-right: 2px; }\n .ag-theme-alpine .ag-group-title-bar {\n background-color: #fff;\n background-color: var(--ag-subheader-background-color, #fff);\n padding: 6px; }\n .ag-theme-alpine .ag-group-toolbar {\n padding: 6px; }\n .ag-theme-alpine .ag-disabled-group-title-bar, .ag-theme-alpine .ag-disabled-group-container {\n opacity: 0.5; }\n .ag-theme-alpine .group-item {\n margin: 3px 0; }\n .ag-theme-alpine .ag-label {\n white-space: nowrap; }\n .ag-theme-alpine .ag-ltr .ag-label {\n margin-right: 6px; }\n .ag-theme-alpine .ag-rtl .ag-label {\n margin-left: 6px; }\n .ag-theme-alpine .ag-label-align-top .ag-label {\n margin-bottom: 3px; }\n .ag-theme-alpine .ag-ltr .ag-slider-field, .ag-theme-alpine .ag-ltr .ag-angle-select-field {\n margin-right: 12px; }\n .ag-theme-alpine .ag-rtl .ag-slider-field, .ag-theme-alpine .ag-rtl .ag-angle-select-field {\n margin-left: 12px; }\n .ag-theme-alpine .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-alpine .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #181d1f;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n border-radius: 5px; }\n .ag-theme-alpine .ag-picker-field-wrapper:focus {\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4); }\n .ag-theme-alpine .ag-picker-field-button {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-dialog.ag-color-dialog {\n border-radius: 5px; }\n .ag-theme-alpine .ag-color-picker .ag-picker-field-display {\n height: 16px; }\n .ag-theme-alpine .ag-color-panel {\n padding: 6px; }\n .ag-theme-alpine .ag-spectrum-color {\n background-color: red;\n border-radius: 2px; }\n .ag-theme-alpine .ag-spectrum-tools {\n padding: 10px; }\n .ag-theme-alpine .ag-spectrum-sat {\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0)); }\n .ag-theme-alpine .ag-spectrum-val {\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0)); }\n .ag-theme-alpine .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24); }\n .ag-theme-alpine .ag-spectrum-hue-background {\n border-radius: 2px; }\n .ag-theme-alpine .ag-spectrum-alpha-background {\n border-radius: 2px; }\n .ag-theme-alpine .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px; }\n .ag-theme-alpine .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37); }\n .ag-theme-alpine .ag-recent-color {\n margin: 0 3px; }\n .ag-theme-alpine .ag-recent-color:first-child {\n margin-left: 0; }\n .ag-theme-alpine .ag-recent-color:last-child {\n margin-right: 0; }\n .ag-theme-alpine.ag-dnd-ghost {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 3px;\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n padding: 6px;\n overflow: hidden;\n text-overflow: ellipsis;\n z-index: 10;\n border: solid 1px;\n border-color: #dde2eb;\n border-color: var(--ag-secondary-border-color, #dde2eb);\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n height: 48px !important;\n line-height: 48px;\n margin: 0;\n padding: 0 12px;\n -webkit-transform: translateY(12px);\n transform: translateY(12px); }\n .ag-theme-alpine .ag-dnd-ghost-icon {\n margin-right: 6px;\n color: #181d1f;\n color: var(--ag-foreground-color, #181d1f); }\n .ag-theme-alpine .ag-popup-child:not(.ag-tooltip-custom) {\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4); }\n .ag-dragging-range-handle .ag-theme-alpine .ag-dialog,\n .ag-dragging-fill-handle .ag-theme-alpine .ag-dialog {\n opacity: 0.7;\n pointer-events: none; }\n .ag-theme-alpine .ag-dialog {\n border-radius: 3px;\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-panel {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-alpine .ag-panel-title-bar {\n background-color: #f8f8f8;\n background-color: var(--ag-header-background-color, #f8f8f8);\n color: #181d1f;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)));\n height: 48px;\n padding: 6px 18px;\n border-bottom: solid 1px;\n border-bottom-color: #babfc7;\n border-bottom-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-ltr .ag-panel-title-bar-button {\n margin-left: 6px; }\n .ag-theme-alpine .ag-rtl .ag-panel-title-bar-button {\n margin-right: 6px; }\n .ag-theme-alpine .ag-tooltip {\n background-color: #f8f8f8;\n background-color: var(--ag-header-background-color, #f8f8f8);\n color: #181d1f;\n color: var(--ag-foreground-color, #181d1f);\n padding: 6px;\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n border-radius: 3px;\n transition: opacity 1s; }\n .ag-theme-alpine .ag-tooltip.ag-tooltip-hiding {\n opacity: 0; }\n .ag-theme-alpine .ag-ltr .ag-column-select-indent-1 {\n padding-left: 16px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-indent-1 {\n padding-right: 16px; }\n .ag-theme-alpine .ag-ltr .ag-column-select-indent-2 {\n padding-left: 32px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-indent-2 {\n padding-right: 32px; }\n .ag-theme-alpine .ag-ltr .ag-column-select-indent-3 {\n padding-left: 48px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-indent-3 {\n padding-right: 48px; }\n .ag-theme-alpine .ag-ltr .ag-column-select-indent-4 {\n padding-left: 64px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-indent-4 {\n padding-right: 64px; }\n .ag-theme-alpine .ag-ltr .ag-column-select-indent-5 {\n padding-left: 80px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-indent-5 {\n padding-right: 80px; }\n .ag-theme-alpine .ag-ltr .ag-column-select-indent-6 {\n padding-left: 96px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-indent-6 {\n padding-right: 96px; }\n .ag-theme-alpine .ag-ltr .ag-column-select-indent-7 {\n padding-left: 112px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-indent-7 {\n padding-right: 112px; }\n .ag-theme-alpine .ag-ltr .ag-column-select-indent-8 {\n padding-left: 128px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-indent-8 {\n padding-right: 128px; }\n .ag-theme-alpine .ag-ltr .ag-column-select-indent-9 {\n padding-left: 144px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-indent-9 {\n padding-right: 144px; }\n .ag-theme-alpine .ag-column-select-header-icon {\n cursor: pointer; }\n .ag-theme-alpine .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-column-select-header-icon:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-alpine .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 12px; }\n .ag-theme-alpine .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-alpine .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 12px; }\n .ag-theme-alpine .ag-keyboard-focus .ag-column-select-column-group:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-column-select-column-group:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -3px;\n left: -3px;\n display: block;\n width: calc(100% - -6px);\n height: calc(100% - -6px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-keyboard-focus .ag-column-select-column:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-column-select-column:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -3px;\n left: -3px;\n display: block;\n width: calc(100% - -6px);\n height: calc(100% - -6px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-column-select-column-group:not(:last-child),\n .ag-theme-alpine .ag-column-select-column:not(:last-child) {\n margin-bottom: 9px; }\n .ag-theme-alpine .ag-column-select-column-readonly,\n .ag-theme-alpine .ag-column-select-column-group-readonly {\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5));\n pointer-events: none; }\n .ag-theme-alpine .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-column-select-list {\n padding: 12px 12px; }\n .ag-theme-alpine .ag-rtl {\n text-align: right; }\n .ag-theme-alpine .ag-root-wrapper {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n border-radius: 3px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 46px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 46px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-1 {\n padding-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-1 {\n padding-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 74px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 74px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-2 {\n padding-left: 56px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-2 {\n padding-right: 56px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 102px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 102px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-3 {\n padding-left: 84px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-3 {\n padding-right: 84px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 130px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 130px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-4 {\n padding-left: 112px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-4 {\n padding-right: 112px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 158px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 158px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-5 {\n padding-left: 140px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-5 {\n padding-right: 140px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 186px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 186px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-6 {\n padding-left: 168px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-6 {\n padding-right: 168px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 214px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 214px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-7 {\n padding-left: 196px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-7 {\n padding-right: 196px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 242px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 242px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-8 {\n padding-left: 224px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-8 {\n padding-right: 224px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 270px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 270px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-9 {\n padding-left: 252px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-9 {\n padding-right: 252px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 298px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 298px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-10 {\n padding-left: 280px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-10 {\n padding-right: 280px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 326px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 326px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-11 {\n padding-left: 308px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-11 {\n padding-right: 308px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 354px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 354px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-12 {\n padding-left: 336px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-12 {\n padding-right: 336px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 382px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 382px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-13 {\n padding-left: 364px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-13 {\n padding-right: 364px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 410px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 410px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-14 {\n padding-left: 392px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-14 {\n padding-right: 392px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 438px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 438px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-15 {\n padding-left: 420px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-15 {\n padding-right: 420px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 466px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 466px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-16 {\n padding-left: 448px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-16 {\n padding-right: 448px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 494px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 494px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-17 {\n padding-left: 476px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-17 {\n padding-right: 476px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 522px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 522px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-18 {\n padding-left: 504px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-18 {\n padding-right: 504px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 550px; }\n .ag-theme-alpine .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 550px; }\n .ag-theme-alpine .ag-ltr .ag-row-group-indent-19 {\n padding-left: 532px; }\n .ag-theme-alpine .ag-rtl .ag-row-group-indent-19 {\n padding-right: 532px; }\n .ag-theme-alpine .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-alpine .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-alpine .ag-cell {\n -webkit-font-smoothing: subpixel-antialiased; }\n .ag-theme-alpine .ag-value-change-delta {\n padding-right: 2px; }\n .ag-theme-alpine .ag-value-change-delta-up {\n color: #43a047;\n color: var(--ag-value-change-delta-up-color, #43a047); }\n .ag-theme-alpine .ag-value-change-delta-down {\n color: #e53935;\n color: var(--ag-value-change-delta-down-color, #e53935); }\n .ag-theme-alpine .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n transition: background-color 1s; }\n .ag-theme-alpine .ag-value-change-value-highlight {\n background-color: rgba(22, 160, 133, 0.5);\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5));\n transition: background-color 0.1s; }\n .ag-theme-alpine .ag-cell-data-changed {\n background-color: rgba(22, 160, 133, 0.5) !important;\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5)) !important; }\n .ag-theme-alpine .ag-cell-data-changed-animation {\n background-color: transparent; }\n .ag-theme-alpine .ag-cell-highlight {\n background-color: #2196f3 !important;\n background-color: var(--ag-range-selection-highlight-color, var(--ag-range-selection-border-color, #2196f3)) !important; }\n .ag-theme-alpine .ag-row {\n height: 42px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n color: #181d1f;\n color: var(--ag-data-color, var(--ag-foreground-color, #181d1f));\n border-width: 1px;\n border-color: #dde2eb;\n border-color: var(--ag-row-border-color, var(--ag-secondary-border-color, #dde2eb)); }\n .ag-theme-alpine .ag-row:not(.ag-row-first) {\n border-top-style: solid; }\n .ag-theme-alpine .ag-row.ag-row-last {\n border-bottom-style: solid; }\n .ag-theme-alpine .ag-row-highlight-above::after, .ag-theme-alpine .ag-row-highlight-below::after {\n content: '';\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #2196f3;\n background-color: var(--ag-range-selection-border-color, #2196f3);\n left: 1px; }\n .ag-theme-alpine .ag-row-highlight-above::after {\n top: -1px; }\n .ag-theme-alpine .ag-row-highlight-above.ag-row-first::after {\n top: 0; }\n .ag-theme-alpine .ag-row-highlight-below::after {\n bottom: 0px; }\n .ag-theme-alpine .ag-row-odd {\n background-color: #fcfcfc;\n background-color: var(--ag-odd-row-background-color, #fcfcfc); }\n .ag-theme-alpine .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-row-hover {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine .ag-ltr .ag-right-aligned-cell {\n text-align: right; }\n .ag-theme-alpine .ag-rtl .ag-right-aligned-cell {\n text-align: left; }\n .ag-theme-alpine .ag-ltr .ag-right-aligned-cell .ag-cell-value {\n margin-left: auto; }\n .ag-theme-alpine .ag-rtl .ag-right-aligned-cell .ag-cell-value {\n margin-right: auto; }\n .ag-theme-alpine .ag-cell {\n border: 1px solid transparent;\n line-height: 40px;\n padding-left: 17px;\n padding-right: 17px; }\n .ag-theme-alpine .ag-row > .ag-cell-wrapper {\n padding-left: 17px;\n padding-right: 17px; }\n .ag-theme-alpine .ag-row-dragging {\n cursor: move; }\n .ag-theme-alpine .ag-row-dragging {\n opacity: 0.5; }\n .ag-theme-alpine .ag-cell-inline-editing {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 3px;\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n padding: 6px;\n padding: 0;\n height: 42px;\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8); }\n .ag-theme-alpine .ag-popup-editor {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 3px;\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n padding: 6px;\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n padding: 0; }\n .ag-theme-alpine .ag-large-text-input {\n height: auto;\n padding: 18px; }\n .ag-theme-alpine .ag-details-row {\n padding: 30px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-alpine .ag-overlay-loading-wrapper {\n background-color: rgba(255, 255, 255, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(255, 255, 255, 0.66)); }\n .ag-theme-alpine .ag-overlay-loading-center {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 3px;\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n padding: 6px; }\n .ag-theme-alpine .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px; }\n .ag-theme-alpine .ag-loading {\n padding-left: 18px;\n display: flex;\n height: 100%;\n align-items: center; }\n .ag-theme-alpine .ag-loading-icon {\n padding-right: 12px; }\n .ag-theme-alpine .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear; }\n\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n .ag-theme-alpine .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: #babfc7;\n border-bottom-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: #babfc7;\n border-top-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-ltr .ag-cell {\n border-right: solid transparent; }\n .ag-theme-alpine .ag-rtl .ag-cell {\n border-left: solid transparent; }\n .ag-theme-alpine .ag-ltr .ag-cell {\n border-right-width: 1px; }\n .ag-theme-alpine .ag-rtl .ag-cell {\n border-left-width: 1px; }\n .ag-theme-alpine .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-row-selected {\n background-color: rgba(33, 150, 243, 0.3);\n background-color: var(--ag-selected-row-background-color, rgba(33, 150, 243, 0.3)); }\n .ag-theme-alpine .ag-cell-range-selected:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(33, 150, 243, 0.2)); }\n .ag-theme-alpine .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1);\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)); }\n .ag-theme-alpine .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1);\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)); }\n .ag-theme-alpine .ag-cell-range-selected-1:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(33, 150, 243, 0.2))); }\n .ag-theme-alpine .ag-cell-range-selected-2:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(33, 150, 243, 0.36)); }\n .ag-theme-alpine .ag-cell-range-selected-3:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(33, 150, 243, 0.488)); }\n .ag-theme-alpine .ag-cell-range-selected-4:not(.ag-cell-focus) {\n background-color: rgba(33, 150, 243, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(33, 150, 243, 0.5904)); }\n .ag-theme-alpine .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #2196f3;\n border-top-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #2196f3;\n border-right-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #2196f3;\n border-bottom-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #2196f3;\n border-left-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-alpine .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-alpine .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-alpine .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-alpine .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-alpine .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #2196f3;\n border-color: var(--ag-range-selection-border-color, #2196f3);\n outline: initial; }\n .ag-theme-alpine .ag-cell.ag-selection-fill-top,\n .ag-theme-alpine .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #2196f3;\n border-top-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-alpine .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #2196f3;\n border-right-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-alpine .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #2196f3;\n border-left-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-cell.ag-selection-fill-bottom,\n .ag-theme-alpine .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #2196f3;\n border-bottom-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-alpine .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #2196f3;\n border-left-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-alpine .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #2196f3;\n border-right-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-fill-handle, .ag-theme-alpine .ag-range-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #2196f3;\n background-color: var(--ag-range-selection-border-color, #2196f3); }\n .ag-theme-alpine .ag-ltr .ag-fill-handle, .ag-theme-alpine .ag-ltr .ag-range-handle {\n right: -1px; }\n .ag-theme-alpine .ag-rtl .ag-fill-handle, .ag-theme-alpine .ag-rtl .ag-range-handle {\n left: -1px; }\n .ag-theme-alpine .ag-fill-handle {\n cursor: cell; }\n .ag-theme-alpine .ag-range-handle {\n cursor: nwse-resize; }\n .ag-theme-alpine .ag-cell-inline-editing {\n border-color: rgba(33, 150, 243, 0.4) !important;\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)) !important; }\n .ag-theme-alpine .ag-menu {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 3px;\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n padding: 6px;\n padding: 0; }\n .ag-theme-alpine .ag-menu-list {\n cursor: default;\n width: 100%;\n padding-top: 6px;\n padding-bottom: 6px; }\n .ag-theme-alpine .ag-menu-option-part {\n padding-top: 8px;\n padding-bottom: 8px;\n line-height: 16px; }\n .ag-theme-alpine .ag-menu-option-active {\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine .ag-menu-option-disabled {\n opacity: 0.5; }\n .ag-theme-alpine .ag-menu-option-text {\n margin-left: 6px; }\n .ag-theme-alpine .ag-menu-option-icon {\n padding-left: 12px;\n padding-right: 6px;\n min-width: 28px; }\n .ag-theme-alpine .ag-menu-option-shortcut {\n padding-left: 12px; }\n .ag-theme-alpine .ag-menu-separator {\n height: 12px; }\n .ag-theme-alpine .ag-menu-separator-cell:after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: #babfc7;\n border-top-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-menu-option-popup-pointer {\n width: 28px;\n text-align: center; }\n .ag-theme-alpine .ag-tabs-header {\n min-width: 220px;\n width: 100%;\n display: flex; }\n .ag-theme-alpine .ag-tab {\n border-bottom: 2px solid transparent;\n display: flex;\n flex: none;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n flex: 1 1 auto;\n transition: border-bottom 0.3s; }\n .ag-theme-alpine .ag-keyboard-focus .ag-tab:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-tab:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-tab-selected {\n border-bottom-color: #2196f3;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine .ag-menu-header {\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-filter-condition-operator {\n height: 17px; }\n .ag-theme-alpine .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 12px; }\n .ag-theme-alpine .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 12px; }\n .ag-theme-alpine .ag-set-filter-select-all {\n padding-top: 12px; }\n .ag-theme-alpine .ag-set-filter-list {\n height: 180px; }\n .ag-theme-alpine .ag-set-filter-filter {\n margin-top: 12px;\n margin-left: 12px;\n margin-right: 12px; }\n .ag-theme-alpine .ag-filter-to {\n margin-top: 9px; }\n .ag-theme-alpine .ag-mini-filter {\n margin: 12px 12px;\n margin-bottom: 0; }\n .ag-theme-alpine .ag-set-filter-item {\n margin: 0px 12px; }\n .ag-theme-alpine .ag-ltr .ag-set-filter-item-value {\n margin-left: 12px; }\n .ag-theme-alpine .ag-rtl .ag-set-filter-item-value {\n margin-right: 12px; }\n .ag-theme-alpine .ag-filter-header-container {\n padding-bottom: 12px;\n border-bottom: solid 1px;\n border-bottom-color: #dde2eb;\n border-bottom-color: var(--ag-secondary-border-color, #dde2eb); }\n .ag-theme-alpine .ag-filter-apply-panel {\n padding: 12px 12px;\n border-top: solid 1px;\n border-top-color: #dde2eb;\n border-top-color: var(--ag-secondary-border-color, #dde2eb); }\n .ag-theme-alpine .ag-filter-apply-panel-button {\n line-height: 1.5; }\n .ag-theme-alpine .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 12px; }\n .ag-theme-alpine .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 12px; }\n .ag-theme-alpine .ag-simple-filter-body-wrapper {\n padding: 12px 12px;\n padding-bottom: 3px; }\n .ag-theme-alpine .ag-simple-filter-body-wrapper > * {\n margin-bottom: 9px; }\n .ag-theme-alpine .ag-filter-no-matches {\n margin: 12px 12px; }\n .ag-theme-alpine .ag-side-bar {\n position: relative; }\n .ag-theme-alpine .ag-tool-panel-wrapper {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8); }\n .ag-theme-alpine .ag-side-buttons {\n padding-top: 24px;\n width: 20px;\n position: relative;\n color: #181d1f;\n color: var(--ag-foreground-color, #181d1f);\n overflow: hidden; }\n .ag-theme-alpine button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 12px 0 12px 0;\n width: 100%;\n margin: 0;\n min-height: 108px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none; }\n .ag-theme-alpine button.ag-side-button-button:focus {\n box-shadow: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-side-button-button:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-side-button-icon-wrapper {\n margin-bottom: 3px; }\n .ag-theme-alpine .ag-ltr .ag-side-bar-left,\n .ag-theme-alpine .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-alpine .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-ltr .ag-side-bar-left .ag-side-button-button,\n .ag-theme-alpine .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 2px solid transparent;\n transition: border-right 0.3s; }\n .ag-theme-alpine .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-alpine .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #2196f3;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine .ag-rtl .ag-side-bar-left,\n .ag-theme-alpine .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-alpine .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-rtl .ag-side-bar-left .ag-side-button-button,\n .ag-theme-alpine .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 2px solid transparent;\n transition: border-left 0.3s; }\n .ag-theme-alpine .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-alpine .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #2196f3;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine .ag-filter-toolpanel-header {\n height: 36px; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-header, .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 6px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-header, .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 6px; }\n .ag-theme-alpine .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f112\";\n position: absolute; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-left: 6px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-right: 6px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-0-header {\n height: 48px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-item {\n margin-top: 3px;\n margin-bottom: 3px; }\n .ag-theme-alpine .ag-filter-toolpanel-search {\n height: 48px; }\n .ag-theme-alpine .ag-filter-toolpanel-search-input {\n flex-grow: 1;\n height: 24px; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 6px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 6px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: #dde2eb;\n border-top-color: var(--ag-secondary-border-color, #dde2eb); }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 6px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 6px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 22px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 22px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 38px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 38px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 54px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 54px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 70px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 70px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 86px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 86px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 102px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 102px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 118px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 118px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 134px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 134px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 150px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 150px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 166px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 166px; }\n .ag-theme-alpine .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 6px; }\n .ag-theme-alpine .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: #babfc7;\n border-top-color: var(--ag-border-color, #babfc7);\n border-bottom: solid 1px;\n border-bottom-color: #babfc7;\n border-bottom-color: var(--ag-border-color, #babfc7);\n padding-top: 6px; }\n .ag-theme-alpine .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 6px; }\n .ag-theme-alpine .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 6px; }\n .ag-theme-alpine .ag-pivot-mode-panel {\n height: 48px;\n display: flex; }\n .ag-theme-alpine .ag-pivot-mode-select {\n display: flex;\n align-items: center; }\n .ag-theme-alpine .ag-ltr .ag-pivot-mode-select {\n margin-left: 12px; }\n .ag-theme-alpine .ag-rtl .ag-pivot-mode-select {\n margin-right: 12px; }\n .ag-theme-alpine .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-column-select-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-column-select-header {\n height: 48px;\n align-items: center;\n padding: 0 12px;\n border-bottom: solid 1px;\n border-bottom-color: #dde2eb;\n border-bottom-color: var(--ag-secondary-border-color, #dde2eb); }\n .ag-theme-alpine .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: #dde2eb;\n border-bottom-color: var(--ag-secondary-border-color, #dde2eb);\n border-top: solid 1px;\n border-top-color: #dde2eb;\n border-top-color: var(--ag-secondary-border-color, #dde2eb); }\n .ag-theme-alpine .ag-column-group-icons,\n .ag-theme-alpine .ag-column-select-header-icon {\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-header {\n background-color: #f8f8f8;\n background-color: var(--ag-header-background-color, #f8f8f8);\n border-bottom: solid 1px;\n border-bottom-color: #babfc7;\n border-bottom-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-header-row {\n color: #181d1f;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f))); }\n .ag-theme-alpine .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-header-row {\n height: 48px; }\n .ag-theme-alpine .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 6px; }\n .ag-theme-alpine .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 6px; }\n .ag-theme-alpine .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 6px; }\n .ag-theme-alpine .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 6px; }\n .ag-theme-alpine .ag-header-cell,\n .ag-theme-alpine .ag-header-group-cell {\n padding-left: 18px;\n padding-right: 18px; }\n .ag-theme-alpine .ag-header-cell.ag-header-cell-moving,\n .ag-theme-alpine .ag-header-group-cell.ag-header-cell-moving {\n background-color: #fff;\n background-color: var(--ag-header-cell-moving-background-color, var(--ag-background-color, #fff)); }\n .ag-theme-alpine .ag-keyboard-focus .ag-header-cell:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-header-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none; }\n .ag-theme-alpine .ag-keyboard-focus .ag-header-group-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: rgba(33, 150, 243, 0.4);\n border-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine .ag-header-icon {\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-header-expand-icon {\n cursor: pointer; }\n .ag-theme-alpine .ag-ltr .ag-header-expand-icon {\n padding-left: 4px; }\n .ag-theme-alpine .ag-rtl .ag-header-expand-icon {\n padding-right: 4px; }\n .ag-theme-alpine .ag-header-row:not(:first-child) .ag-header-cell,\n .ag-theme-alpine .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: #babfc7;\n border-top-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-header-cell-resize {\n display: flex;\n align-items: center; }\n .ag-theme-alpine .ag-header-cell-resize::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n left: calc(50% - 1px);\n width: 2px;\n height: 30%;\n top: calc(50% - 15%);\n background-color: rgba(186, 191, 199, 0.5);\n background-color: var(--ag-header-column-resize-handle-color, rgba(186, 191, 199, 0.5)); }\n .ag-theme-alpine .ag-pinned-right-header .ag-header-cell-resize::after {\n left: calc(50% - 2px); }\n .ag-theme-alpine .ag-ltr .ag-header-select-all {\n margin-right: 18px; }\n .ag-theme-alpine .ag-rtl .ag-header-select-all {\n margin-left: 18px; }\n .ag-theme-alpine .ag-ltr .ag-floating-filter-button {\n margin-left: 18px; }\n .ag-theme-alpine .ag-rtl .ag-floating-filter-button {\n margin-right: 18px; }\n .ag-theme-alpine .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 16px;\n padding: 0;\n width: 16px; }\n .ag-theme-alpine .ag-filter-loading {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n height: 100%;\n padding: 12px 12px;\n position: absolute;\n width: 100%;\n z-index: 1; }\n .ag-theme-alpine .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: #babfc7;\n border-top-color: var(--ag-border-color, #babfc7);\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n height: 48px; }\n .ag-theme-alpine .ag-paging-panel > * {\n margin: 0 18px; }\n .ag-theme-alpine .ag-paging-button {\n cursor: pointer;\n opacity: 0;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n padding: 0;\n width: 16px; }\n .ag-theme-alpine .ag-disabled .ag-paging-button {\n cursor: default; }\n .ag-theme-alpine .ag-paging-button-wrapper.ag-disabled {\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5));\n cursor: default; }\n .ag-theme-alpine .ag-paging-button-wrapper, .ag-theme-alpine .ag-paging-description {\n margin: 0 6px; }\n .ag-theme-alpine .ag-status-bar {\n border-top: solid 1px;\n border-top-color: #babfc7;\n border-top-color: var(--ag-border-color, #babfc7);\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5));\n padding-right: 24px;\n padding-left: 24px;\n line-height: 1.5; }\n .ag-theme-alpine .ag-status-name-value-value {\n color: #181d1f;\n color: var(--ag-foreground-color, #181d1f); }\n .ag-theme-alpine .ag-status-bar-center {\n text-align: center; }\n .ag-theme-alpine .ag-status-name-value {\n margin-left: 6px;\n margin-right: 6px;\n padding-top: 12px;\n padding-bottom: 12px; }\n .ag-theme-alpine .ag-column-drop-cell {\n background: rgba(24, 29, 31, 0.07);\n background: var(--ag-chip-background-color, rgba(24, 29, 31, 0.07));\n border-radius: 24px;\n height: 24px;\n padding: 0 3px; }\n .ag-theme-alpine .ag-column-drop-cell-text {\n margin: 0 6px; }\n .ag-theme-alpine .ag-column-drop-cell-button {\n min-width: 24px;\n margin: 0 3px;\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-column-drop-cell-drag-handle {\n margin-left: 12px; }\n .ag-theme-alpine .ag-column-drop-cell-ghost {\n opacity: 0.5; }\n .ag-theme-alpine .ag-column-drop-horizontal {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f));\n height: 42px;\n border-bottom: solid 1px;\n border-bottom-color: #babfc7;\n border-bottom-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-ltr .ag-column-drop-horizontal {\n padding-left: 18px; }\n .ag-theme-alpine .ag-rtl .ag-column-drop-horizontal {\n padding-right: 18px; }\n .ag-theme-alpine .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-column-drop-horizontal-cell-separator {\n margin: 0 6px;\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-column-drop-horizontal-empty-message {\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5)); }\n .ag-theme-alpine .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 18px; }\n .ag-theme-alpine .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 18px; }\n .ag-theme-alpine .ag-column-drop-vertical-list {\n padding-bottom: 6px;\n padding-right: 6px;\n padding-left: 6px; }\n .ag-theme-alpine .ag-column-drop-vertical-cell {\n margin-top: 6px; }\n .ag-theme-alpine .ag-column-drop-vertical {\n min-height: 50px;\n max-height: 150px;\n border-bottom: solid 1px;\n border-bottom-color: #dde2eb;\n border-bottom-color: var(--ag-secondary-border-color, #dde2eb); }\n .ag-theme-alpine .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none; }\n .ag-theme-alpine .ag-column-drop-vertical-icon {\n margin-left: 6px;\n margin-right: 6px; }\n .ag-theme-alpine .ag-column-drop-vertical-list {\n position: relative; }\n .ag-theme-alpine .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5));\n margin-top: 6px; }\n .ag-theme-alpine .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 3px;\n box-shadow: 0 1px 4px 1px rgba(186, 191, 199, 0.4);\n padding: 6px;\n background: #fff;\n background: var(--ag-background-color, #fff);\n height: 105px;\n padding: 0; }\n .ag-theme-alpine .ag-select-agg-func-virtual-list-item {\n cursor: default;\n line-height: 30px;\n padding-left: 12px; }\n .ag-theme-alpine .ag-select-agg-func-virtual-list-item:hover {\n background-color: rgba(33, 150, 243, 0.3);\n background-color: var(--ag-selected-row-background-color, rgba(33, 150, 243, 0.3)); }\n .ag-theme-alpine .ag-chart-menu {\n border-radius: 3px;\n background: #fff;\n background: var(--ag-background-color, #fff); }\n .ag-theme-alpine .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 3px;\n color: #181d1f;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f)); }\n .ag-theme-alpine .ag-chart-menu-icon:hover {\n opacity: 1; }\n .ag-theme-alpine .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: #dde2eb;\n border-color: var(--ag-secondary-border-color, #dde2eb);\n border-radius: 5px;\n margin: 5px; }\n .ag-theme-alpine .ag-chart-mini-thumbnail:nth-last-child(3),\n .ag-theme-alpine .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto; }\n .ag-theme-alpine .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0; }\n .ag-theme-alpine .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0; }\n .ag-theme-alpine .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0; }\n .ag-theme-alpine .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0; }\n .ag-theme-alpine .ag-chart-mini-thumbnail.ag-selected {\n border-color: #2196f3;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3))); }\n .ag-theme-alpine .ag-chart-settings-card-item {\n background: #181d1f;\n background: var(--ag-foreground-color, #181d1f);\n width: 8px;\n height: 8px;\n border-radius: 4px; }\n .ag-theme-alpine .ag-chart-settings-card-item.ag-selected {\n background-color: #2196f3;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3))); }\n .ag-theme-alpine .ag-chart-data-column-drag-handle {\n margin-left: 6px; }\n .ag-theme-alpine .ag-charts-settings-group-title-bar,\n .ag-theme-alpine .ag-charts-data-group-title-bar,\n .ag-theme-alpine .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: #dde2eb;\n border-top-color: var(--ag-secondary-border-color, #dde2eb); }\n .ag-theme-alpine .ag-charts-settings-group-container {\n padding: 6px; }\n .ag-theme-alpine .ag-charts-data-group-container {\n padding: 12px 12px;\n padding-bottom: 3px; }\n .ag-theme-alpine .ag-charts-data-group-container > * {\n margin-bottom: 9px; }\n .ag-theme-alpine .ag-charts-format-top-level-group-container {\n margin-left: 12px;\n padding: 6px; }\n .ag-theme-alpine .ag-charts-format-top-level-group-item {\n margin: 6px 0; }\n .ag-theme-alpine .ag-charts-format-sub-level-group-container {\n padding: 12px 12px;\n padding-bottom: 3px; }\n .ag-theme-alpine .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 9px; }\n .ag-theme-alpine .ag-charts-group-container.ag-group-container-horizontal {\n padding: 6px; }\n .ag-theme-alpine .ag-chart-data-section,\n .ag-theme-alpine .ag-chart-format-section {\n display: flex;\n margin: 0; }\n .ag-theme-alpine .ag-chart-menu-panel {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8); }\n .ag-theme-alpine .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: #babfc7;\n border-right-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-date-time-list-page-title {\n flex-grow: 1;\n text-align: center; }\n .ag-theme-alpine .ag-date-time-list-page-column-label {\n text-align: center; }\n .ag-theme-alpine .ag-date-time-list-page-entry {\n text-align: center; }\n .ag-theme-alpine .ag-checkbox-input-wrapper {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: #fff;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, #fff));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n flex: none; }\n .ag-theme-alpine .ag-checkbox-input-wrapper input, .ag-theme-alpine .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-alpine .ag-checkbox-input-wrapper:focus-within, .ag-theme-alpine .ag-checkbox-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4); }\n .ag-theme-alpine .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-alpine .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #999;\n color: var(--ag-checkbox-unchecked-color, #999);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #2196f3;\n color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #999;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, #999));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine .ag-toggle-button-input-wrapper {\n box-sizing: border-box;\n width: 28px;\n height: 18px;\n background-color: #999;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, #999));\n border-radius: 9px;\n position: relative;\n flex: none;\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #999)); }\n .ag-theme-alpine .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%; }\n .ag-theme-alpine .ag-toggle-button-input-wrapper:focus-within {\n outline: none;\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4); }\n .ag-theme-alpine .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-alpine .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #2196f3;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)));\n border-color: #2196f3;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3))); }\n .ag-theme-alpine .ag-toggle-button-input-wrapper::before {\n content: ' ';\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n box-sizing: border-box;\n height: 18px;\n width: 18px;\n background-color: #fff;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #fff));\n border-radius: 9px;\n transition: left 100ms;\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #999))); }\n .ag-theme-alpine .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 18px);\n border-color: #2196f3;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3))); }\n .ag-theme-alpine .ag-radio-button-input-wrapper {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: #fff;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, #fff));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n flex: none;\n border-radius: 16px; }\n .ag-theme-alpine .ag-radio-button-input-wrapper input, .ag-theme-alpine .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-alpine .ag-radio-button-input-wrapper:focus-within, .ag-theme-alpine .ag-radio-button-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4); }\n .ag-theme-alpine .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-alpine .ag-radio-button-input-wrapper::after {\n content: \"\\f124\";\n color: #999;\n color: var(--ag-checkbox-unchecked-color, #999);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f125\";\n color: #2196f3;\n color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-alpine input[class^='ag-'][type='range'] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible; }\n .ag-theme-alpine input[class^='ag-'][type='range']::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #babfc7;\n background-color: var(--ag-border-color, #babfc7);\n border-radius: 3px;\n border-radius: 3px; }\n .ag-theme-alpine input[class^='ag-'][type='range']::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #babfc7;\n background-color: var(--ag-border-color, #babfc7);\n border-radius: 3px;\n border-radius: 3px; }\n .ag-theme-alpine input[class^='ag-'][type='range']::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #babfc7;\n background-color: var(--ag-border-color, #babfc7);\n border-radius: 3px;\n border-radius: 3px;\n color: transparent;\n width: calc(100% - 2px); }\n .ag-theme-alpine input[class^='ag-'][type='range']::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-checkbox-unchecked-color, #999);\n border-radius: 16px;\n -webkit-transform: translateY(-6.5px);\n transform: translateY(-6.5px); }\n .ag-theme-alpine input[class^='ag-'][type='range']::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-checkbox-unchecked-color, #999);\n border-radius: 16px; }\n .ag-theme-alpine input[class^='ag-'][type='range']::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #999;\n border-color: var(--ag-checkbox-unchecked-color, #999);\n border-radius: 16px; }\n .ag-theme-alpine input[class^='ag-'][type='range']:focus {\n outline: none; }\n .ag-theme-alpine input[class^='ag-'][type='range']:focus::-webkit-slider-thumb {\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n border-color: #2196f3;\n border-color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine input[class^='ag-'][type='range']:focus::-ms-thumb {\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n border-color: #2196f3;\n border-color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine input[class^='ag-'][type='range']:focus::-moz-ag-range-thumb {\n box-shadow: 0 0 2px 0.1rem rgba(33, 150, 243, 0.4);\n border-color: #2196f3;\n border-color: var(--ag-checkbox-checked-color, var(--ag-alpine-active-color, #2196f3)); }\n .ag-theme-alpine input[class^='ag-'][type='range']:active::-webkit-slider-runnable-track {\n background-color: rgba(33, 150, 243, 0.4);\n background-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine input[class^='ag-'][type='range']:active::-moz-ag-range-track {\n background-color: rgba(33, 150, 243, 0.4);\n background-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine input[class^='ag-'][type='range']:active::-ms-track {\n background-color: rgba(33, 150, 243, 0.4);\n background-color: var(--ag-input-focus-border-color, rgba(33, 150, 243, 0.4)); }\n .ag-theme-alpine input[class^='ag-'][type='range']:disabled {\n opacity: 0.5; }\n .ag-theme-alpine .ag-filter-toolpanel-header,\n .ag-theme-alpine .ag-filter-toolpanel-search,\n .ag-theme-alpine .ag-status-bar,\n .ag-theme-alpine .ag-header-row,\n .ag-theme-alpine .ag-panel-title-bar-title {\n font-weight: 700;\n color: #181d1f;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #181d1f))); }\n .ag-theme-alpine .ag-ltr .ag-pinned-right-header .ag-header-row:after, .ag-theme-alpine .ag-rtl .ag-pinned-left-header .ag-header-row:before {\n content: '';\n position: absolute;\n height: calc(100% - 20px);\n top: 10px;\n width: 1px;\n background-color: #babfc7;\n background-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-ltr .ag-pinned-right-header .ag-header-row:after {\n right: 0; }\n .ag-theme-alpine .ag-rtl .ag-pinned-left-header .ag-header-row:before {\n left: 0; }\n .ag-theme-alpine .ag-row {\n font-size: 14px; }\n .ag-theme-alpine input[class^='ag-']:not([type]),\n .ag-theme-alpine input[class^='ag-'][type='text'],\n .ag-theme-alpine input[class^='ag-'][type='number'],\n .ag-theme-alpine input[class^='ag-'][type='tel'],\n .ag-theme-alpine input[class^='ag-'][type='date'],\n .ag-theme-alpine input[class^='ag-'][type='datetime-local'],\n .ag-theme-alpine textarea[class^='ag-'] {\n min-height: 24px;\n border-radius: 3px; }\n .ag-theme-alpine .ag-ltr input[class^='ag-']:not([type]),\n .ag-theme-alpine .ag-ltr input[class^='ag-'][type='text'],\n .ag-theme-alpine .ag-ltr input[class^='ag-'][type='number'],\n .ag-theme-alpine .ag-ltr input[class^='ag-'][type='tel'],\n .ag-theme-alpine .ag-ltr input[class^='ag-'][type='date'],\n .ag-theme-alpine .ag-ltr input[class^='ag-'][type='datetime-local'],\n .ag-theme-alpine .ag-ltr textarea[class^='ag-'] {\n padding-left: 6px; }\n .ag-theme-alpine .ag-rtl input[class^='ag-']:not([type]),\n .ag-theme-alpine .ag-rtl input[class^='ag-'][type='text'],\n .ag-theme-alpine .ag-rtl input[class^='ag-'][type='number'],\n .ag-theme-alpine .ag-rtl input[class^='ag-'][type='tel'],\n .ag-theme-alpine .ag-rtl input[class^='ag-'][type='date'],\n .ag-theme-alpine .ag-rtl input[class^='ag-'][type='datetime-local'],\n .ag-theme-alpine .ag-rtl textarea[class^='ag-'] {\n padding-right: 6px; }\n .ag-theme-alpine .ag-tab {\n padding: 9px;\n transition: color 0.4s; }\n .ag-theme-alpine .ag-tab-selected {\n color: #2196f3;\n color: var(--ag-alpine-active-color, #2196f3); }\n .ag-theme-alpine .ag-menu {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8); }\n .ag-theme-alpine .ag-menu-header {\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n padding-top: 1px; }\n .ag-theme-alpine .ag-tabs-header {\n border-bottom: solid 1px;\n border-bottom-color: #babfc7;\n border-bottom-color: var(--ag-border-color, #babfc7); }\n .ag-theme-alpine .ag-charts-settings-group-title-bar,\n .ag-theme-alpine .ag-charts-data-group-title-bar,\n .ag-theme-alpine .ag-charts-format-top-level-group-title-bar {\n padding: 6px 12px;\n line-height: 20px; }\n .ag-theme-alpine .ag-chart-mini-thumbnail {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-alpine .ag-chart-settings-nav-bar {\n border-top: solid 1px;\n border-top-color: #dde2eb;\n border-top-color: var(--ag-secondary-border-color, #dde2eb); }\n .ag-theme-alpine .ag-ltr .ag-group-title-bar-icon {\n margin-right: 6px; }\n .ag-theme-alpine .ag-rtl .ag-group-title-bar-icon {\n margin-left: 6px; }\n .ag-theme-alpine .ag-charts-format-top-level-group-toolbar {\n margin-top: 6px; }\n .ag-theme-alpine .ag-ltr .ag-charts-format-top-level-group-toolbar {\n padding-left: 20px; }\n .ag-theme-alpine .ag-rtl .ag-charts-format-top-level-group-toolbar {\n padding-right: 20px; }\n .ag-theme-alpine .ag-charts-format-sub-level-group {\n border-left: dashed 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7);\n padding-left: 6px;\n margin-bottom: 12px; }\n .ag-theme-alpine .ag-charts-format-sub-level-group-title-bar {\n padding-top: 0;\n padding-bottom: 0;\n background: none;\n font-weight: 700; }\n .ag-theme-alpine .ag-charts-format-sub-level-group-container {\n padding-bottom: 0; }\n .ag-theme-alpine .ag-charts-format-sub-level-group-item:last-child {\n margin-bottom: 0; }\n .ag-theme-alpine .ag-dnd-ghost {\n font-size: 12px;\n font-weight: 700; }\n .ag-theme-alpine .ag-side-buttons {\n width: 30px; }\n .ag-theme-alpine .ag-standard-button {\n -moz-appearance: none;\n appearance: none;\n -webkit-appearance: none;\n border-radius: 3px;\n border: 1px solid;\n border-color: #2196f3;\n border-color: var(--ag-alpine-active-color, #2196f3);\n color: #2196f3;\n color: var(--ag-alpine-active-color, #2196f3);\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n font-weight: 600;\n padding: 6px 12px; }\n .ag-theme-alpine .ag-standard-button:hover {\n border-color: #2196f3;\n border-color: var(--ag-alpine-active-color, #2196f3);\n background-color: rgba(33, 150, 243, 0.1);\n background-color: var(--ag-row-hover-color, rgba(33, 150, 243, 0.1)); }\n .ag-theme-alpine .ag-standard-button:active {\n border-color: #2196f3;\n border-color: var(--ag-alpine-active-color, #2196f3);\n background-color: #2196f3;\n background-color: var(--ag-alpine-active-color, #2196f3);\n color: #fff;\n color: var(--ag-background-color, #fff); }\n .ag-theme-alpine .ag-standard-button:disabled {\n color: rgba(24, 29, 31, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(24, 29, 31, 0.5));\n background-color: #f1f2f4;\n background-color: var(--ag-input-disabled-background-color, #f1f2f4);\n border-color: rgba(186, 191, 199, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(186, 191, 199, 0.3)); }\n .ag-theme-alpine .ag-menu-header {\n min-width: 240px; }\n .ag-theme-alpine .ag-column-drop-vertical {\n min-height: 75px;\n max-height: 175px; }\n .ag-theme-alpine .ag-tool-panel-wrapper {\n width: 250px; }\n .ag-theme-alpine .ag-column-drop-vertical-title-bar {\n padding: 12px;\n padding-bottom: 0px; }\n .ag-theme-alpine .ag-column-drop-vertical-empty-message {\n display: flex;\n align-items: center;\n border: dashed 1px;\n border-color: #babfc7;\n border-color: var(--ag-border-color, #babfc7);\n margin: 12px;\n padding: 12px; }\n .ag-theme-alpine .ag-column-drop-empty-message {\n color: #181d1f;\n color: var(--ag-foreground-color, #181d1f);\n opacity: 0.75; }\n .ag-theme-alpine .ag-status-bar {\n font-weight: normal; }\n .ag-theme-alpine .ag-status-name-value-value {\n font-weight: 700; }\n .ag-theme-alpine .ag-paging-number, .ag-theme-alpine .ag-paging-row-summary-panel-number {\n font-weight: 700; }\n .ag-theme-alpine .ag-column-drop-cell-button {\n opacity: 0.5; }\n .ag-theme-alpine .ag-column-drop-cell-button:hover {\n opacity: 0.75; }\n .ag-theme-alpine .ag-header-cell-menu-button:hover,\n .ag-theme-alpine .ag-side-button-button:hover,\n .ag-theme-alpine .ag-tab:hover,\n .ag-theme-alpine .ag-panel-title-bar-button:hover,\n .ag-theme-alpine .ag-header-expand-icon:hover,\n .ag-theme-alpine .ag-column-group-icons:hover,\n .ag-theme-alpine .ag-group-expanded .ag-icon:hover,\n .ag-theme-alpine .ag-group-contracted .ag-icon:hover,\n .ag-theme-alpine .ag-chart-settings-prev:hover,\n .ag-theme-alpine .ag-chart-settings-next:hover,\n .ag-theme-alpine .ag-group-title-bar-icon:hover,\n .ag-theme-alpine .ag-column-select-header-icon:hover,\n .ag-theme-alpine .ag-floating-filter-button-button:hover,\n .ag-theme-alpine .ag-filter-toolpanel-expand:hover,\n .ag-theme-alpine .ag-chart-menu-icon:hover {\n color: #2196f3;\n color: var(--ag-alpine-active-color, #2196f3); }\n .ag-theme-alpine .ag-chart-settings-card-item.ag-not-selected:hover {\n opacity: 0.35; }\n .ag-theme-alpine .ag-ltr .ag-panel-title-bar-button {\n margin-left: 12px;\n margin-right: 6px; }\n .ag-theme-alpine .ag-rtl .ag-panel-title-bar-button {\n margin-right: 12px;\n margin-left: 6px; }\n .ag-theme-alpine .ag-filter-toolpanel-group-container {\n padding-left: 6px; }\n .ag-theme-alpine .ag-filter-toolpanel-instance-filter {\n border: none;\n background-color: #f8f8f8;\n background-color: var(--ag-control-panel-background-color, #f8f8f8);\n border-left: dashed 1px;\n border-left-color: #babfc7;\n border-left-color: var(--ag-border-color, #babfc7);\n margin-left: 13px;\n padding-left: 8px;\n margin-right: 12px; }\n .ag-theme-alpine .ag-set-filter-list {\n padding-top: 3px;\n padding-bottom: 3px; }\n .ag-theme-alpine .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 60px; }\n .ag-theme-alpine .ag-date-time-list-page-entry-is-current {\n background-color: #2196f3;\n background-color: var(--ag-alpine-active-color, #2196f3); }\n\n", ""]);
  46244. // Exports
  46245. module.exports = exports;
  46246. /***/ }),
  46247. /* 232 */
  46248. /***/ (function(module, exports, __webpack_require__) {
  46249. var api = __webpack_require__(225);
  46250. var content = __webpack_require__(233);
  46251. content = content.__esModule ? content.default : content;
  46252. if (typeof content === 'string') {
  46253. content = [[module.i, content, '']];
  46254. }
  46255. var options = {};
  46256. options.insert = "head";
  46257. options.singleton = false;
  46258. var update = api(content, options);
  46259. module.exports = content.locals || {};
  46260. /***/ }),
  46261. /* 233 */
  46262. /***/ (function(module, exports, __webpack_require__) {
  46263. // Imports
  46264. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227);
  46265. exports = ___CSS_LOADER_API_IMPORT___(false);
  46266. // Module
  46267. exports.push([module.i, ".ag-theme-balham-dark {\n -webkit-font-smoothing: antialiased;\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5);\n font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n font-size: 12px;\n line-height: normal; }\n\n@font-face {\n font-family: \"agGridBalham\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABX4AAsAAAAAJ8wAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlEAAAReXgFf/09TLzIAAANcAAAAPgAAAFZWTFJaY21hcAAAA5wAAAHtAAAFgFIH7gFnbHlmAAAFjAAADLgAABYYNphscGhlYWQAABJEAAAALwAAADZ2zsSBaGhlYQAAEnQAAAAbAAAAJAfTBC1obXR4AAASkAAAABIAAAEUp/gAAGxvY2EAABKkAAAAZAAAAIwBFQakbWF4cAAAEwgAAAAfAAAAIAFbAHNuYW1lAAATKAAAATUAAAJG0OP3eXBvc3QAABRgAAABlwAAAlqez14KeJx9k09yElEQxr9hCBKISYwxloga/0bjOAwM/yQQCFKWZWXhwoULN3GhpZVylRO49gCWB/AUnsBy6coDeADLA/jrZpCYRXjFzJvur7/+ul8/BZJKSrSr3OTx/nMtHx4cvVdFeU1/5j++Dw7fvjlQcfaFL+/vooLwj5Z1Qy90pG+BgtfB51whzIW74X74IfwU/lAIalMx6LIesGLVeEZkr6uhVDkVsMXsm2qBDnm23bqmC1pwz1AjrZMzJmbkjNt6qptahWfgPH31QCUs4+zzHLNuaeUURKrb8NdR08VqrFUyrGpRe2jso6NDdAvvCr4dMkfEDPANdA68ofLexyd6iaI1r80i6xku4R/TZfuO/KvMmqHa8DfgN74tss7sDTLViLgHex3Uw6yH27pGdAOePmwdj256dBlkDYWJrrKzympUtkT9PT3TK8+6m8X0vYvTmrdQP7cPnC+l2uPWDlxjsHfRMLfaidwhV6QJ/pI2eL/TR33RV33XT/3Sb53B2sVrFfTg3jm1M0X6dxI9xNv+Z7VKC5zPSdT/iEXqbnhvYnyjrIOWrYxO603CPsKaOL6ETsMPUZNyGnlyRJ63hnWB1eU7Bn02m8YWa8n7PGIGbAIqdKfB05im85bS4Usw2W6qa8O71YLnop+W9dRu0rJ/2czbKVfAXOYdUVnd+/MI7xUsxjS3VD0qRbVx3MefonaezVRVUdX02bXJmvgtGJJpkzqmSmrcXLsBE5+q6yioZzdyndMw9Z3spM47LvaoAM1RdpMT75lN8gBtNhXjv2nbY10AAAB4nGNgZMpnnMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVFgEqgRRAAAy9AKRgAAeJy102dSWzEUhuHXhW56TaN3Y2wwvRkb/rAM0hlSGNKZrDI70QZCvnPPyQLITDTz+Ls6o6srjSygDSjImhQhXySHtd+q5rJ6ge6sXuSX+iU6yeu5whU33KXa/b2qFS655jblst7fltPoEk9ZZEe9I811oKdjqrT0xh4b7LPLCXU2OWWdbWo0OGeLQ5qc6f28vl7UGtvp0He7tJIezdhLH/0MMMgQw4wwyhjjTPCYJ/raM42ZZIppZpjVuDnmWdAalvTcwzIr+l1Vr6wFtvOwdvTA8dbWDnaOq63Knna7e1Lf1Ea3a43zrcPm2T9M9h9ayX4KP6N3gZ2ms91eBvt/PA8H8iLYyb4Mx/IqVOV1aMmbYPO+DXtyFTbkOuzLu7Ar78OJfAh1+Rg25Sacym1Yl09hWz6HmnwJDfkazuVb2JLv4VB+hKbcBR1gyjm7KynvsCw4u1up6Ox+pTZn9y61Oyw7HJadDssuh2W3s/uYehyWJWcnmXodln0Oy36H5YDDctBhOeSwHHZYjjgsRx2WYw7LcYflhMPykdPdJAXdUlLQfSUF3VxSyPY16bCcclhOOyxnHJazDss5l+133mG1BYfVFh1WW3JYbdlhtRWXzbPqsrWVHTZ2zWFjKy4bs+6w96oum7PmKP8BU32drwAAAHic7RhpcBvVeb+3lmRZsm5pJdk6V4ety9YdS/Zu7MTGdu7DCRlC0jQHDTFH0tAwIYJCaCAhDDSZcEwzFDoDGZgpw7TTDNMmpUMZMFNi0hQ6JTD9AbQNaRtCyXQGFy393molxybl+l1pd9/33vve9773ve96j2EZ/LHPss8yHJNm1jMMeAlnYQ1E0xROkSixCqQYUgXVRlDbbZwXuKawAEULm4JohA+qVXyetzs45a/WyH97Np+1B6K5YqGIuIViIRKl/3yANXcMxqCpCWKDHdJ70nvTNfBIfwvPAWCbSI4HL3j5HNHpEF65de5/4CFxCqw6v9fg0JlanEZ/xMBNidJ+aNLYDf0Gu1rt9XVbPAC72KevRBo8cm2gEF77+JIfXF8nrUzDslMia7ToHQ691dI+4Gh1egycSazouuwhm75bbzWa250hm5+fR0UFsrweYR9hfAxj5TTRIqcJmOUiag7IRTFglgvOPDGcOHw4MQytM0vpY6X+5pXbG/2tynzkZdbGNGNFmYeHN/clz5xJ7hPI0X2JM2cS+6Q5lC2Zt23sNsbGdDJ5xA/S7bDRrcnQfcjRfdBkaN1Ge+R9KdAeK9JFykg/WoRLW1aPZbLZzNjq1+rAlrGRoVg8HhsaeYYCEENo7MnkU08ln5S/7LYZ6DIgzESXIenj+gj8Mg2enawTIQ2jQ5lmzTx9i1k7f7pSOb9z5we33EK2SteR4erzU1PTYz5gzzFWJsogmU4IpiBvzgmQDWS8YDfbDMAGggYKeWmbQHtToAGUH7C56vfTK7q7V6RJreyqVjwZDz5kr1x2SOteyz4KN01jpOUR7E88aU91D37wIXfj5yPEzDwKN8/mKf7VeWIDaBdfxlF/9SXS++XsSKlhWV1m8MJAfXo+0GBJdSVOcpcRp5PdNYsL9tzlvbQcms2BIodb2U2MCjXWyTBa0HBaYIs+qPkGmyNTyFNFJH+X1pc2SlUQJiZeeU6ncxkd6cG0w+iCF+GJMnZIv4W+iQmhtdXbFnEF0+mgK9zupeSb5DmSrEHRGSPDhHlz1qq8QN/jovgrQTghitVTgvA2yVQnp9+GHZPDrAr5RB6p3pND0sXE++8n4FKtVNayCO3JyvBMN52lLsByQ6gsekEEHNhSwK4Izi7vuT2A7eSnl+Ij8dhIghbxkcinkUJB/khNc2MjcTgiXRfOV7APsjJCXDqFH5IpRKSXKCr0RgqSnljiw3ExH57m+2XyMrUVmGG1l5kj8V9uZjN9iOKbssSq+BBYWPMhMDFbLrh1Gi2QQygM6SKYyJ+odExgQhSVLJtjbAkl08MsZMaYdYhfKGYxfNSiAOXMANGa7y/KXgbZ5AxgBDlY0KpaFmiuCAKIkCI4ppClgrVpwqgpqJwZEVBbUsAHNcCv32pZ+/SdoVazpc3tj/QlRhY8s2zl/GVpk1Wr05lMCbE3IXQv5CCybMmGzWsdtvbSSO+mcgLu6V7AgXfnkR8v4Esj5c2luDTpjl8V74om3LHhWFeUfJRm2cX3Xt0e9MbaAy4kHLbY7N3lVW0pm9PutffF+xIP+67OkzVCn83uVbe0x8ubyiMl6ff+NXkyfGMfGwxiS+9I6WxHF1J0J6JdcSymdfUYyzNtTIopo6TkCKuISH25eDBWcgZSl05NIhqUBioZSgmViqOSQLv1AIqGWi1UG/JYcMP1N+1YszSjyEL8zTgsvP9GnyKLZXfyVADDpQ2l0oadG3p6NvwxNrxyOCZ/WL6x+MUh3mCcW1qtLHxsU5NI+sYHawv3uG9ZQlfr60ESNTp/gBglEiO1ouF7kmwS8wn0gqCs0wOaYkFZbKQPAiqbkjPYi/maahTybBI6nQNFZ/MJAAIaZ2HA1Um2V081yxCqSK2XnIt2e8rdbq3+uwfHdpR0za50n7c7NCiate50n6c7tLdrRUe3p5R2a80KP2RK1mdtXaNVZt5MPlG0WvqW0FBsh6SHS4y+tgZyoeFfrLiaNoz4vOzbuximyOez3GVv+EvqU7IvmvZIV65MVWo/USkFpUR2mmfkaXm0uT6mnxlkRr5uxmZFblQYc8Kzym+Ymx2tVGCX9Ar0SPsbkB6hS9IoHP9m6Vj1n4IgiMrbiGfTe1jz1tTLk7jisf8sCHWvXf037mBdD3ewbSg5M913dMh061muGMXVFqMkKsJ+aZd4QDoLkcnJdAXelbyVNHlQOCEcgAhEpLOTGdyBTJ3WdowDMWa1rNMoVg0KGN0blWpBhHwkmkY9NwCqtBdzXhHVFVXdGpSxsJF6u5TSQUfbsAOb07Ldy1R44sRYGWhraWkf96zoCOU0aofLomctYVO70WDi43t6Yr7xpNPDxTbFFnm2dXHtXNzbDJqwy66z0CHxInA2C+hYC29ot7Xo5qUinWRQq1e1Le+MeLZ5rK2tfRF+yG1h+bAlZI9u7E6H4m2c0b8tdU855QOtH6neXe72e7U6lW9TkkOqVoNxScqTt8ljAtbQtcn0Eqvp/zK5kkxqNnofe9/n/AZDrYzGaRW+ssXhW1TqGoTRaoWbJxIT8GJiIgGuqanq5NTUAoTJOmxF77FuyocAPokMWsU6LPGZeHpq2j6qpMqoGTwyWH3UQDThLsDsoPgP9q2hHct2wO+UcuIsS8vHaoWS4yTJ6/X8G9A66n82WX0APbDygktEexDrex/EmCbPp0ykTAuvN8kT/bA237/easJiO7zwFju0ffkOZewzmLvV7LKejaA51w43UDqYevts6mA//KIfobe7DsLSvfFTp+J74WR1Ek7WYJyZ0rmL3cU4mAQzh5kr5yAMUFXjHLLaoa5R7SoKhKNVjVrRQwxEsm4hGm2NRrpACw45BnWBwwcgjyoUOTlyccUITF27atkNLfpYZNHI81dfO69vLiFh/4339S8dnn+NVhuOLF98cvFYjG9uXjM0uvqCX61e0jcwmktHYbf0YXa8M2Y0W08O9HRI+0I6p7tQWq4Vchm7w/KZj/0eyaWPrdt8zdI5+bDdIfQ8tnL1aP/GgkgSsfuXji1akoqrYslVI2PLHownX+0bGaoEQxqV2wG3SQ+b2sKRXKn8GvE6pH3iof55nUmVwHZ29Arlz1qUfR1nb0Pt62B6UTLy4U8+ENr5zyf/vCbjsKmDkVwBAsEINhXKYA/ksxkHIqrJdr3B5Vvlcxn0lWBPEB+4VCunzC5X0OUCnaR3h0JuEXYJ7nCY9VhsToPFYnDaLIgkjSqDjuPH7PQ78ak+HnbBcXeoUgm5pVFXuOGz9yDPQYxuDNSzxgLuAS1EoNuloXkD9TRoTzS98IEmgquC2v4VOUdWTi1h2SEgTSqtp9RV3Nhs1LssnA289rmD38HsgrXZk9xDGDj+YtXqm01HCx0ZM7ibOQLN5Ehzi85osJjegNsPYS5l1HfotLoNbq+zzWoxSO+2j+k3q1WufLyb0yEF8oDJZDU4jhpYtk36q9oWdeYsD2Gk0zRb3qDLabksbvtxJ/qZIWYBs5K5htnAbPkfsTtgdsgXJyoavn2Y5tUsw46JoIavXTk4ZMGEbVw2H1VrsvliDFAiWUw87Fmq3WE1r7FnixHenv2iwA67q698eAGjrrbaDBiD/fDLlsTYyoQ2NtSxU5sYG0u0zA1l3F6ovgp7bgOoiLkFmAnsFuHkboqP4uiJ3fHCnKvu+MJQ/2n1VbUW0S+cMptwMrgNjDJx7c0dV8WJNrES5wGVxuqIeYfm3P7r0fwdnxTC68U9e4I0IQDYU4HbG/pxDs+19H5Dud0wUXXwU3GYZt1uBGmdXkIV4NK9O7fPmz9/3vadYKpD9+7asrHU21vauOUCAuUyAuw52iFdnIkszMChQG/9vF/nRfha3My6e5FxviqL8NwVblW+Mt/S6NjMkZTY7FyJ5lfo/DEwcZg0oWePstulswdEaRfsFw+kK5IX3q2kJycx4zp7gGZLB2iaNDmp0BnHnKAVvTID5gDm2TYHOhk8Gavqnp51Vp9fkQ6S4WBa+vl46fTp0vhKJPUOhKR36CkfQu3j5dOny+NwuHHfpiKH5XM6KXJFtkm6KKd6ZAtN3xFgZuMBPRNjvpqopfV31coGzov1Mz+HONKhn+HRd4AcQSB5Dww0aCWJje6yFWVwQg6AVqFx93QDO477Hsf8m7EGMdHG0wxGHXpYRS+LscWK+Y2XoMOKaqbzoSjQzIeTTZteltZgGqT4Y4SECPkRzDlPVDIkTZwnphTncSz/9saQkBT4rTFnQNNsdwtJeKJzsQebzElX1yqL2exD2OdXO9o2zmG34WAVOSpNfIAEQU2OQvE8kW7FVAbxfTIhfZsp1R4abUNCo36ZjoNVZRIda5CO6Fu1tiNdxhX+FyXYf3Z4nGNgZGBgAOJNb47Mjue3+crAzfwCKBDF+XhfA4JmYGB+CRJn4GBgAvEAeqIMgAB4nGNgZGBgfsHAACH//2d+ycDIgApcAXBnBQgAeJxjYGBgYH4xdDA9AADYnCd6AAB4nGNgAIIZDBcYnjE6MEYxLmF8xaTBFMVUw9THdIPpEzMHswzzBhYNlgKWLpYrrEGsOayT2GTYlrE9Ymdgl2K3YI9hf8PhxrGBM4xzDhcTlxpXAFcKVxlXF9cMbh7SIQDoHxaseJxjYGRgYHBlSGfgYQABJiDmAkIGhv9gPgMAGrQBzwB4nHWPP07DMBjFX2haRIsQEhJiwxMLUvpnYOjYodk7dGBzGydtlcSR41bqxjE4Acdg5AicgkPwEr6hQqotOT///N4nBcAtvhCgWQGu27NZF7jk7Y87pDvhkPwo3MUAz8I9+hfhPu1MeMBmwQlBeEXzgDfhC9zgXbhD/yEckj+Fu7jHt3CP/ke4j2UQCg/wFLzqLHbbZKbzjS4WJtvn2p2qU14aV29tqcbR6FTHpjROe5Oo1VHVh2zifapSZws1t6U3eW5V5ezOrH208b6aDoep+GhtC2hkiOGwRcI/18ix4VlgAcOXPe+ar+dS5/ySbYea3qKEwhgRRmfTMdNl29Dw/CZsrHDkWePAzoTWI+U9ZcayoTBvJzfpnNvSVO3bjmZNH3F206owxZA7/ZePmOKkX1qXaMkAAAB4nG2R6W7bMBCE/cWSrThp47ptet/3obbpfadX+h40RclEJFIgKR95+hJ1ESBA9w9nBsvZWbK30VvXqPf/OmCDPgkpA4ZkbDJii21OcZodxpxhwlnOcZ5dLnCRS1zmCle5xnVucJNb3OYOd7nHfR7wkEc85glPyXnGc16wx0te8Zo3vOUd7/nARz7xmS98ZZ9vfOcHP/nFAb97W6KqnKpE0NYMhHN24fvCy4EURqo6lTPhwljOlDyc2mX+F6hi91jQplBBuUYbEdTkWO7Mv85taWvr8lZH4oaRdI3xI2lNcEIGVSTStqtUOut9UigvM7VsRfQsNtVK5b4WftaPaFDqOo5JS+18SCqn27RytmuT2BCSWpVhUGsT52XrI98b1lYU2lRZI5a60UcqaZTpshh0zYw1asvYkIu6tgtVpG10Uv1Wm7TVcxvGLl63+bQLwZrcluXOScGkTlezkHgxVyPfRJe8sAuTrWFMFuLKk+CUOvlGWWfWERFUOBQBjcWwwCOpmXHIlGX8zYKGjpYVJUfMe70/6zKeWwA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n .ag-theme-balham-dark .ag-icon {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n .ag-theme-balham-dark .ag-icon-aggregation:before {\n content: \"\\f101\"; }\n .ag-theme-balham-dark .ag-icon-arrows:before {\n content: \"\\f102\"; }\n .ag-theme-balham-dark .ag-icon-asc:before {\n content: \"\\f103\"; }\n .ag-theme-balham-dark .ag-icon-cancel:before {\n content: \"\\f104\"; }\n .ag-theme-balham-dark .ag-icon-chart:before {\n content: \"\\f105\"; }\n .ag-theme-balham-dark .ag-icon-color-picker:before {\n content: \"\\f109\"; }\n .ag-theme-balham-dark .ag-icon-columns:before {\n content: \"\\f10a\"; }\n .ag-theme-balham-dark .ag-icon-contracted:before {\n content: \"\\f10b\"; }\n .ag-theme-balham-dark .ag-icon-copy:before {\n content: \"\\f10c\"; }\n .ag-theme-balham-dark .ag-icon-cross:before {\n content: \"\\f10d\"; }\n .ag-theme-balham-dark .ag-icon-desc:before {\n content: \"\\f10e\"; }\n .ag-theme-balham-dark .ag-icon-expanded:before {\n content: \"\\f10f\"; }\n .ag-theme-balham-dark .ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n .ag-theme-balham-dark .ag-icon-eye:before {\n content: \"\\f111\"; }\n .ag-theme-balham-dark .ag-icon-filter:before {\n content: \"\\f112\"; }\n .ag-theme-balham-dark .ag-icon-first:before {\n content: \"\\f113\"; }\n .ag-theme-balham-dark .ag-icon-grip:before {\n content: \"\\f114\"; }\n .ag-theme-balham-dark .ag-icon-group:before {\n content: \"\\f115\"; }\n .ag-theme-balham-dark .ag-icon-last:before {\n content: \"\\f116\"; }\n .ag-theme-balham-dark .ag-icon-left:before {\n content: \"\\f117\"; }\n .ag-theme-balham-dark .ag-icon-linked:before {\n content: \"\\f118\"; }\n .ag-theme-balham-dark .ag-icon-loading:before {\n content: \"\\f119\"; }\n .ag-theme-balham-dark .ag-icon-maximize:before {\n content: \"\\f11a\"; }\n .ag-theme-balham-dark .ag-icon-menu:before {\n content: \"\\f11b\"; }\n .ag-theme-balham-dark .ag-icon-minimize:before {\n content: \"\\f11c\"; }\n .ag-theme-balham-dark .ag-icon-next:before {\n content: \"\\f11d\"; }\n .ag-theme-balham-dark .ag-icon-none:before {\n content: \"\\f11e\"; }\n .ag-theme-balham-dark .ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n .ag-theme-balham-dark .ag-icon-paste:before {\n content: \"\\f120\"; }\n .ag-theme-balham-dark .ag-icon-pin:before {\n content: \"\\f121\"; }\n .ag-theme-balham-dark .ag-icon-pivot:before {\n content: \"\\f122\"; }\n .ag-theme-balham-dark .ag-icon-previous:before {\n content: \"\\f123\"; }\n .ag-theme-balham-dark .ag-icon-right:before {\n content: \"\\f126\"; }\n .ag-theme-balham-dark .ag-icon-save:before {\n content: \"\\f127\"; }\n .ag-theme-balham-dark .ag-icon-small-down:before {\n content: \"\\f128\"; }\n .ag-theme-balham-dark .ag-icon-small-left:before {\n content: \"\\f129\"; }\n .ag-theme-balham-dark .ag-icon-small-right:before {\n content: \"\\f12a\"; }\n .ag-theme-balham-dark .ag-icon-small-up:before {\n content: \"\\f12b\"; }\n .ag-theme-balham-dark .ag-icon-tick:before {\n content: \"\\f12c\"; }\n .ag-theme-balham-dark .ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n .ag-theme-balham-dark .ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n .ag-theme-balham-dark .ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n .ag-theme-balham-dark .ag-icon-unlinked:before {\n content: \"\\f130\"; }\n .ag-theme-balham-dark .ag-icon-row-drag:before {\n content: \"\\f114\"; }\n .ag-theme-balham-dark .ag-right-arrow:before {\n content: \"\\f117\"; }\n .ag-theme-balham-dark .ag-right-arrow:before {\n content: \"\\f126\"; }\n .ag-theme-balham-dark .ag-root-wrapper {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436); }\n .ag-theme-balham-dark [class^='ag-'], .ag-theme-balham-dark [class^='ag-']:focus, .ag-theme-balham-dark [class^='ag-']:after, .ag-theme-balham-dark [class^='ag-']:before {\n box-sizing: border-box;\n outline: none; }\n .ag-theme-balham-dark [class^='ag-']::-ms-clear {\n display: none; }\n .ag-theme-balham-dark .ag-checkbox .ag-input-wrapper,\n .ag-theme-balham-dark .ag-radio-button .ag-input-wrapper {\n overflow: visible; }\n .ag-theme-balham-dark .ag-range-field .ag-input-wrapper {\n height: 100%; }\n .ag-theme-balham-dark .ag-toggle-button {\n flex: none;\n width: unset;\n min-width: unset; }\n .ag-theme-balham-dark .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 4px; }\n .ag-theme-balham-dark input[class^='ag-'] {\n margin: 0;\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436); }\n .ag-theme-balham-dark textarea[class^='ag-'],\n .ag-theme-balham-dark select[class^='ag-'] {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436); }\n .ag-theme-balham-dark input[class^='ag-']:not([type]),\n .ag-theme-balham-dark input[class^='ag-'][type='text'],\n .ag-theme-balham-dark input[class^='ag-'][type='number'],\n .ag-theme-balham-dark input[class^='ag-'][type='tel'],\n .ag-theme-balham-dark input[class^='ag-'][type='date'],\n .ag-theme-balham-dark input[class^='ag-'][type='datetime-local'],\n .ag-theme-balham-dark textarea[class^='ag-'] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #f0f0f0;\n border-color: var(--ag-input-border-color, #f0f0f0); }\n .ag-theme-balham-dark input[class^='ag-']:not([type]):disabled,\n .ag-theme-balham-dark input[class^='ag-'][type='text']:disabled,\n .ag-theme-balham-dark input[class^='ag-'][type='number']:disabled,\n .ag-theme-balham-dark input[class^='ag-'][type='tel']:disabled,\n .ag-theme-balham-dark input[class^='ag-'][type='date']:disabled,\n .ag-theme-balham-dark input[class^='ag-'][type='datetime-local']:disabled,\n .ag-theme-balham-dark textarea[class^='ag-']:disabled {\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38));\n background-color: rgba(48, 46, 46, 0.3);\n background-color: var(--ag-input-disabled-background-color, rgba(48, 46, 46, 0.3));\n border-color: rgba(240, 240, 240, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(240, 240, 240, 0.3)); }\n .ag-theme-balham-dark input[class^='ag-']:not([type]):focus,\n .ag-theme-balham-dark input[class^='ag-'][type='text']:focus,\n .ag-theme-balham-dark input[class^='ag-'][type='number']:focus,\n .ag-theme-balham-dark input[class^='ag-'][type='tel']:focus,\n .ag-theme-balham-dark input[class^='ag-'][type='date']:focus,\n .ag-theme-balham-dark input[class^='ag-'][type='datetime-local']:focus,\n .ag-theme-balham-dark textarea[class^='ag-']:focus {\n outline: none;\n box-shadow: 0 0 4px 1.5px #719ECE;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark input[class^='ag-'][type='number'] {\n -moz-appearance: textfield; }\n .ag-theme-balham-dark input[class^='ag-'][type='number']::-webkit-outer-spin-button, .ag-theme-balham-dark input[class^='ag-'][type='number']::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0; }\n .ag-theme-balham-dark input[class^='ag-'][type='range'] {\n padding: 0; }\n .ag-theme-balham-dark input[class^='ag-'][type='button']:focus, .ag-theme-balham-dark button[class^='ag-']:focus {\n box-shadow: 0 0 4px 1.5px #719ECE; }\n .ag-theme-balham-dark .ag-drag-handle {\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-list-item, .ag-theme-balham-dark .ag-virtual-list-item {\n height: 28px; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-virtual-list-item:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-select-list {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n overflow-y: auto;\n overflow-x: hidden; }\n .ag-theme-balham-dark .ag-list-item {\n display: flex;\n align-items: center; }\n .ag-theme-balham-dark .ag-list-item.ag-active-item {\n background-color: #3d4749;\n background-color: var(--ag-row-hover-color, #3d4749); }\n .ag-theme-balham-dark .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n .ag-theme-balham-dark .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden; }\n .ag-theme-balham-dark .ag-select .ag-picker-field-wrapper {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n min-height: 28px;\n cursor: default; }\n .ag-theme-balham-dark .ag-select:not(.ag-cell-editor) {\n height: 28px; }\n .ag-theme-balham-dark .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis; }\n .ag-theme-balham-dark .ag-select .ag-picker-field-icon {\n display: flex;\n align-items: center; }\n .ag-theme-balham-dark .ag-select.ag-disabled {\n opacity: 0.5; }\n .ag-theme-balham-dark .ag-rich-select {\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020); }\n .ag-theme-balham-dark .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 182px; }\n .ag-theme-balham-dark .ag-rich-select-value {\n padding: 0 4px 0 12px;\n height: 28px;\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242)); }\n .ag-theme-balham-dark .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 28px; }\n .ag-theme-balham-dark .ag-rich-select-virtual-list-item:hover {\n background-color: #3d4749;\n background-color: var(--ag-row-hover-color, #3d4749); }\n .ag-theme-balham-dark .ag-rich-select-row {\n padding-left: 12px; }\n .ag-theme-balham-dark .ag-rich-select-row-selected {\n background-color: #005880;\n background-color: var(--ag-selected-row-background-color, #005880); }\n .ag-theme-balham-dark .ag-row-drag,\n .ag-theme-balham-dark .ag-selection-checkbox,\n .ag-theme-balham-dark .ag-group-expanded,\n .ag-theme-balham-dark .ag-group-contracted {\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-ltr .ag-row-drag, .ag-theme-balham-dark .ag-ltr .ag-selection-checkbox, .ag-theme-balham-dark .ag-ltr .ag-group-expanded, .ag-theme-balham-dark .ag-ltr .ag-group-contracted {\n margin-right: 12px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-drag, .ag-theme-balham-dark .ag-rtl .ag-selection-checkbox, .ag-theme-balham-dark .ag-rtl .ag-group-expanded, .ag-theme-balham-dark .ag-rtl .ag-group-contracted {\n margin-left: 12px; }\n .ag-theme-balham-dark .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: 26px;\n display: flex;\n align-items: center;\n flex: none; }\n .ag-theme-balham-dark .ag-group-expanded,\n .ag-theme-balham-dark .ag-group-contracted {\n cursor: pointer; }\n .ag-theme-balham-dark .ag-group-title-bar-icon {\n cursor: pointer;\n flex: none;\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-ltr .ag-group-child-count {\n margin-left: 2px; }\n .ag-theme-balham-dark .ag-rtl .ag-group-child-count {\n margin-right: 2px; }\n .ag-theme-balham-dark .ag-group-title-bar {\n background-color: #111;\n background-color: var(--ag-subheader-background-color, #111);\n padding: 4px; }\n .ag-theme-balham-dark .ag-group-toolbar {\n padding: 4px; }\n .ag-theme-balham-dark .ag-disabled-group-title-bar, .ag-theme-balham-dark .ag-disabled-group-container {\n opacity: 0.5; }\n .ag-theme-balham-dark .group-item {\n margin: 2px 0; }\n .ag-theme-balham-dark .ag-label {\n white-space: nowrap; }\n .ag-theme-balham-dark .ag-ltr .ag-label {\n margin-right: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-label {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-label-align-top .ag-label {\n margin-bottom: 2px; }\n .ag-theme-balham-dark .ag-ltr .ag-slider-field, .ag-theme-balham-dark .ag-ltr .ag-angle-select-field {\n margin-right: 8px; }\n .ag-theme-balham-dark .ag-rtl .ag-slider-field, .ag-theme-balham-dark .ag-rtl .ag-angle-select-field {\n margin-left: 8px; }\n .ag-theme-balham-dark .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436); }\n .ag-theme-balham-dark .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #F5F5F5;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n border-radius: 5px; }\n .ag-theme-balham-dark .ag-picker-field-wrapper:focus {\n box-shadow: 0 0 4px 1.5px #719ECE; }\n .ag-theme-balham-dark .ag-picker-field-button {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-dialog.ag-color-dialog {\n border-radius: 5px; }\n .ag-theme-balham-dark .ag-color-picker .ag-picker-field-display {\n height: 16px; }\n .ag-theme-balham-dark .ag-color-panel {\n padding: 4px; }\n .ag-theme-balham-dark .ag-spectrum-color {\n background-color: red;\n border-radius: 2px; }\n .ag-theme-balham-dark .ag-spectrum-tools {\n padding: 10px; }\n .ag-theme-balham-dark .ag-spectrum-sat {\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0)); }\n .ag-theme-balham-dark .ag-spectrum-val {\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0)); }\n .ag-theme-balham-dark .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24); }\n .ag-theme-balham-dark .ag-spectrum-hue-background {\n border-radius: 2px; }\n .ag-theme-balham-dark .ag-spectrum-alpha-background {\n border-radius: 2px; }\n .ag-theme-balham-dark .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px; }\n .ag-theme-balham-dark .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37); }\n .ag-theme-balham-dark .ag-recent-color {\n margin: 0 3px; }\n .ag-theme-balham-dark .ag-recent-color:first-child {\n margin-left: 0; }\n .ag-theme-balham-dark .ag-recent-color:last-child {\n margin-right: 0; }\n .ag-theme-balham-dark.ag-dnd-ghost {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n overflow: hidden;\n text-overflow: ellipsis;\n z-index: 10;\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242));\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n height: 32px !important;\n line-height: 32px;\n margin: 0;\n padding: 0 8px;\n -webkit-transform: translateY(8px);\n transform: translateY(8px); }\n .ag-theme-balham-dark .ag-dnd-ghost-icon {\n margin-right: 4px;\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5); }\n .ag-theme-balham-dark .ag-popup-child:not(.ag-tooltip-custom) {\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3); }\n .ag-dragging-range-handle .ag-theme-balham-dark .ag-dialog,\n .ag-dragging-fill-handle .ag-theme-balham-dark .ag-dialog {\n opacity: 0.7;\n pointer-events: none; }\n .ag-theme-balham-dark .ag-dialog {\n border-radius: 2px;\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-panel {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436); }\n .ag-theme-balham-dark .ag-panel-title-bar {\n background-color: #1c1c1c;\n background-color: var(--ag-header-background-color, #1c1c1c);\n color: rgba(245, 245, 245, 0.64);\n color: var(--ag-header-foreground-color, rgba(245, 245, 245, 0.64));\n height: 32px;\n padding: 4px 12px;\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-ltr .ag-panel-title-bar-button {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-panel-title-bar-button {\n margin-right: 4px; }\n .ag-theme-balham-dark .ag-tooltip {\n background-color: #1c1c1c;\n background-color: var(--ag-header-background-color, #1c1c1c);\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5);\n padding: 4px;\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n border-radius: 2px;\n transition: opacity 1s; }\n .ag-theme-balham-dark .ag-tooltip.ag-tooltip-hiding {\n opacity: 0; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-indent-1 {\n padding-left: 20px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-indent-1 {\n padding-right: 20px; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-indent-2 {\n padding-left: 40px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-indent-2 {\n padding-right: 40px; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-indent-3 {\n padding-left: 60px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-indent-3 {\n padding-right: 60px; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-indent-4 {\n padding-left: 80px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-indent-4 {\n padding-right: 80px; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-indent-5 {\n padding-left: 100px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-indent-5 {\n padding-right: 100px; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-indent-6 {\n padding-left: 120px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-indent-6 {\n padding-right: 120px; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-indent-7 {\n padding-left: 140px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-indent-7 {\n padding-right: 140px; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-indent-8 {\n padding-left: 160px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-indent-8 {\n padding-right: 160px; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-indent-9 {\n padding-left: 180px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-indent-9 {\n padding-right: 180px; }\n .ag-theme-balham-dark .ag-column-select-header-icon {\n cursor: pointer; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-header-icon:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-balham-dark .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 6px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-balham-dark .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 6px; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-column-group:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-column-group:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-column:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-column:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-column-select-column-group:not(:last-child),\n .ag-theme-balham-dark .ag-column-select-column:not(:last-child) {\n margin-bottom: 4px; }\n .ag-theme-balham-dark .ag-column-select-column-readonly,\n .ag-theme-balham-dark .ag-column-select-column-group-readonly {\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38));\n pointer-events: none; }\n .ag-theme-balham-dark .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 24px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 24px; }\n .ag-theme-balham-dark .ag-column-select-list {\n padding: 6px 6px; }\n .ag-theme-balham-dark .ag-rtl {\n text-align: right; }\n .ag-theme-balham-dark .ag-root-wrapper {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n border-radius: 2px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 40px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 40px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-1 {\n padding-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-1 {\n padding-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 68px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 68px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-2 {\n padding-left: 56px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-2 {\n padding-right: 56px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 96px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 96px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-3 {\n padding-left: 84px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-3 {\n padding-right: 84px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 124px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 124px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-4 {\n padding-left: 112px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-4 {\n padding-right: 112px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 152px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 152px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-5 {\n padding-left: 140px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-5 {\n padding-right: 140px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 180px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 180px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-6 {\n padding-left: 168px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-6 {\n padding-right: 168px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 208px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 208px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-7 {\n padding-left: 196px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-7 {\n padding-right: 196px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 236px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 236px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-8 {\n padding-left: 224px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-8 {\n padding-right: 224px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 264px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 264px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-9 {\n padding-left: 252px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-9 {\n padding-right: 252px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 292px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 292px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-10 {\n padding-left: 280px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-10 {\n padding-right: 280px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 320px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 320px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-11 {\n padding-left: 308px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-11 {\n padding-right: 308px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 348px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 348px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-12 {\n padding-left: 336px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-12 {\n padding-right: 336px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 376px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 376px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-13 {\n padding-left: 364px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-13 {\n padding-right: 364px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 404px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 404px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-14 {\n padding-left: 392px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-14 {\n padding-right: 392px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 432px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 432px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-15 {\n padding-left: 420px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-15 {\n padding-right: 420px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 460px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 460px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-16 {\n padding-left: 448px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-16 {\n padding-right: 448px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 488px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 488px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-17 {\n padding-left: 476px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-17 {\n padding-right: 476px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 516px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 516px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-18 {\n padding-left: 504px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-18 {\n padding-right: 504px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 544px; }\n .ag-theme-balham-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 544px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-group-indent-19 {\n padding-left: 532px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-group-indent-19 {\n padding-right: 532px; }\n .ag-theme-balham-dark .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham-dark .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham-dark .ag-cell {\n -webkit-font-smoothing: subpixel-antialiased; }\n .ag-theme-balham-dark .ag-value-change-delta {\n padding-right: 2px; }\n .ag-theme-balham-dark .ag-value-change-delta-up {\n color: #43a047;\n color: var(--ag-value-change-delta-up-color, #43a047); }\n .ag-theme-balham-dark .ag-value-change-delta-down {\n color: #e53935;\n color: var(--ag-value-change-delta-down-color, #e53935); }\n .ag-theme-balham-dark .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n transition: background-color 1s; }\n .ag-theme-balham-dark .ag-value-change-value-highlight {\n background-color: rgba(22, 160, 133, 0.5);\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5));\n transition: background-color 0.1s; }\n .ag-theme-balham-dark .ag-cell-data-changed {\n background-color: rgba(22, 160, 133, 0.5) !important;\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5)) !important; }\n .ag-theme-balham-dark .ag-cell-data-changed-animation {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-cell-highlight {\n background-color: #00B0FF !important;\n background-color: var(--ag-range-selection-highlight-color, var(--ag-balham-active-color, #00B0FF)) !important; }\n .ag-theme-balham-dark .ag-row {\n height: 28px;\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n color: #F5F5F5;\n color: var(--ag-data-color, var(--ag-foreground-color, #F5F5F5));\n border-width: 1px;\n border-color: #5c5c5c;\n border-color: var(--ag-row-border-color, #5c5c5c); }\n .ag-theme-balham-dark .ag-row:not(.ag-row-first) {\n border-top-style: solid; }\n .ag-theme-balham-dark .ag-row.ag-row-last {\n border-bottom-style: solid; }\n .ag-theme-balham-dark .ag-row-highlight-above::after, .ag-theme-balham-dark .ag-row-highlight-below::after {\n content: '';\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #00B0FF;\n background-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF));\n left: 1px; }\n .ag-theme-balham-dark .ag-row-highlight-above::after {\n top: -1px; }\n .ag-theme-balham-dark .ag-row-highlight-above.ag-row-first::after {\n top: 0; }\n .ag-theme-balham-dark .ag-row-highlight-below::after {\n bottom: 0px; }\n .ag-theme-balham-dark .ag-row-odd {\n background-color: #262c2e;\n background-color: var(--ag-odd-row-background-color, #262c2e); }\n .ag-theme-balham-dark .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-row-hover {\n background-color: #3d4749;\n background-color: var(--ag-row-hover-color, #3d4749); }\n .ag-theme-balham-dark .ag-ltr .ag-right-aligned-cell {\n text-align: right; }\n .ag-theme-balham-dark .ag-rtl .ag-right-aligned-cell {\n text-align: left; }\n .ag-theme-balham-dark .ag-ltr .ag-right-aligned-cell .ag-cell-value {\n margin-left: auto; }\n .ag-theme-balham-dark .ag-rtl .ag-right-aligned-cell .ag-cell-value {\n margin-right: auto; }\n .ag-theme-balham-dark .ag-cell {\n border: 1px solid transparent;\n line-height: 26px;\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-balham-dark .ag-row > .ag-cell-wrapper {\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-balham-dark .ag-row-dragging {\n cursor: move; }\n .ag-theme-balham-dark .ag-row-dragging {\n opacity: 0.5; }\n .ag-theme-balham-dark .ag-cell-inline-editing {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n height: 28px;\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020); }\n .ag-theme-balham-dark .ag-popup-editor {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020);\n padding: 0; }\n .ag-theme-balham-dark .ag-large-text-input {\n height: auto;\n padding: 12px; }\n .ag-theme-balham-dark .ag-details-row {\n padding: 20px;\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436); }\n .ag-theme-balham-dark .ag-overlay-loading-wrapper {\n background-color: rgba(45, 52, 54, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(45, 52, 54, 0.66)); }\n .ag-theme-balham-dark .ag-overlay-loading-center {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px; }\n .ag-theme-balham-dark .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px; }\n .ag-theme-balham-dark .ag-loading {\n padding-left: 12px;\n display: flex;\n height: 100%;\n align-items: center; }\n .ag-theme-balham-dark .ag-loading-icon {\n padding-right: 12px; }\n .ag-theme-balham-dark .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear; }\n\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n .ag-theme-balham-dark .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-ltr .ag-cell {\n border-right: solid transparent; }\n .ag-theme-balham-dark .ag-rtl .ag-cell {\n border-left: solid transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-cell {\n border-right-width: 1px; }\n .ag-theme-balham-dark .ag-rtl .ag-cell {\n border-left-width: 1px; }\n .ag-theme-balham-dark .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-row-selected {\n background-color: #005880;\n background-color: var(--ag-selected-row-background-color, #005880); }\n .ag-theme-balham-dark .ag-cell-range-selected:not(.ag-cell-focus) {\n background-color: rgba(0, 176, 255, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(0, 176, 255, 0.2)); }\n .ag-theme-balham-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart {\n background-color: rgba(45, 166, 255, 0.5);\n background-color: var(--ag-range-selection-chart-background-color, rgba(45, 166, 255, 0.5)); }\n .ag-theme-balham-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(26, 177, 74, 0.5);\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(26, 177, 74, 0.5)); }\n .ag-theme-balham-dark .ag-cell-range-selected-1:not(.ag-cell-focus) {\n background-color: rgba(0, 176, 255, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(0, 176, 255, 0.2))); }\n .ag-theme-balham-dark .ag-cell-range-selected-2:not(.ag-cell-focus) {\n background-color: rgba(0, 176, 255, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(0, 176, 255, 0.36)); }\n .ag-theme-balham-dark .ag-cell-range-selected-3:not(.ag-cell-focus) {\n background-color: rgba(0, 176, 255, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(0, 176, 255, 0.488)); }\n .ag-theme-balham-dark .ag-cell-range-selected-4:not(.ag-cell-focus) {\n background-color: rgba(0, 176, 255, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(0, 176, 255, 0.5904)); }\n .ag-theme-balham-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #00B0FF;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #00B0FF;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #00B0FF;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #00B0FF;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-balham-dark .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-balham-dark .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-balham-dark .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-balham-dark .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-balham-dark .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #00B0FF;\n border-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF));\n outline: initial; }\n .ag-theme-balham-dark .ag-cell.ag-selection-fill-top,\n .ag-theme-balham-dark .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #00B0FF;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-balham-dark .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #00B0FF;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-balham-dark .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #00B0FF;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-cell.ag-selection-fill-bottom,\n .ag-theme-balham-dark .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #00B0FF;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-balham-dark .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #00B0FF;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-balham-dark .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #00B0FF;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-fill-handle, .ag-theme-balham-dark .ag-range-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #00B0FF;\n background-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark .ag-ltr .ag-fill-handle, .ag-theme-balham-dark .ag-ltr .ag-range-handle {\n right: -1px; }\n .ag-theme-balham-dark .ag-rtl .ag-fill-handle, .ag-theme-balham-dark .ag-rtl .ag-range-handle {\n left: -1px; }\n .ag-theme-balham-dark .ag-fill-handle {\n cursor: cell; }\n .ag-theme-balham-dark .ag-range-handle {\n cursor: nwse-resize; }\n .ag-theme-balham-dark .ag-cell-inline-editing {\n border-color: #719ECE !important;\n border-color: var(--ag-input-focus-border-color, #719ECE) !important; }\n .ag-theme-balham-dark .ag-menu {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n padding: 0; }\n .ag-theme-balham-dark .ag-menu-list {\n cursor: default;\n width: 100%;\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-balham-dark .ag-menu-option-part {\n padding-top: 6px;\n padding-bottom: 6px;\n line-height: 16px; }\n .ag-theme-balham-dark .ag-menu-option-active {\n background-color: #3d4749;\n background-color: var(--ag-row-hover-color, #3d4749); }\n .ag-theme-balham-dark .ag-menu-option-disabled {\n opacity: 0.5; }\n .ag-theme-balham-dark .ag-menu-option-text {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-menu-option-icon {\n padding-left: 8px;\n padding-right: 4px;\n min-width: 24px; }\n .ag-theme-balham-dark .ag-menu-option-shortcut {\n padding-left: 8px; }\n .ag-theme-balham-dark .ag-menu-separator {\n height: 8px; }\n .ag-theme-balham-dark .ag-menu-separator-cell:after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-menu-option-popup-pointer {\n width: 24px;\n text-align: center; }\n .ag-theme-balham-dark .ag-tabs-header {\n min-width: 220px;\n width: 100%;\n display: flex; }\n .ag-theme-balham-dark .ag-tab {\n border-bottom: 0 solid transparent;\n display: flex;\n flex: none;\n align-items: center;\n justify-content: center;\n cursor: pointer; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-tab:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-tab:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-tab-selected {\n border-bottom-color: #00B0FF;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF))); }\n .ag-theme-balham-dark .ag-menu-header {\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-filter-condition-operator {\n height: 17px; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 8px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 8px; }\n .ag-theme-balham-dark .ag-set-filter-select-all {\n padding-top: 6px; }\n .ag-theme-balham-dark .ag-set-filter-list {\n height: 168px; }\n .ag-theme-balham-dark .ag-set-filter-filter {\n margin-top: 6px;\n margin-left: 6px;\n margin-right: 6px; }\n .ag-theme-balham-dark .ag-filter-to {\n margin-top: 4px; }\n .ag-theme-balham-dark .ag-mini-filter {\n margin: 6px 6px;\n margin-bottom: 0; }\n .ag-theme-balham-dark .ag-set-filter-item {\n margin: 0px 6px; }\n .ag-theme-balham-dark .ag-ltr .ag-set-filter-item-value {\n margin-left: 6px; }\n .ag-theme-balham-dark .ag-rtl .ag-set-filter-item-value {\n margin-right: 6px; }\n .ag-theme-balham-dark .ag-filter-header-container {\n padding-bottom: 6px;\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242)); }\n .ag-theme-balham-dark .ag-filter-apply-panel {\n padding: 6px 6px;\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242)); }\n .ag-theme-balham-dark .ag-filter-apply-panel-button {\n line-height: 1.5; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 8px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 8px; }\n .ag-theme-balham-dark .ag-simple-filter-body-wrapper {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-balham-dark .ag-simple-filter-body-wrapper > * {\n margin-bottom: 4px; }\n .ag-theme-balham-dark .ag-filter-no-matches {\n margin: 6px 6px; }\n .ag-theme-balham-dark .ag-side-bar {\n position: relative; }\n .ag-theme-balham-dark .ag-tool-panel-wrapper {\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020); }\n .ag-theme-balham-dark .ag-side-buttons {\n padding-top: 16px;\n width: 20px;\n position: relative;\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5);\n overflow: hidden; }\n .ag-theme-balham-dark button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 8px 0 8px 0;\n width: calc(100% + 1px);\n margin: 0;\n min-height: 72px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none;\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242);\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark button.ag-side-button-button:focus {\n box-shadow: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-side-button-button:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-selected .ag-side-button-button {\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020);\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242);\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-side-button-icon-wrapper {\n margin-bottom: 3px; }\n .ag-theme-balham-dark .ag-ltr .ag-side-bar-left,\n .ag-theme-balham-dark .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-balham-dark .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-ltr .ag-side-bar-left .ag-side-button-button,\n .ag-theme-balham-dark .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 0 solid transparent;\n margin-right: -1px;\n padding-right: 1px; }\n .ag-theme-balham-dark .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-balham-dark .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #00B0FF;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF))); }\n .ag-theme-balham-dark .ag-rtl .ag-side-bar-left,\n .ag-theme-balham-dark .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-balham-dark .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-rtl .ag-side-bar-left .ag-side-button-button,\n .ag-theme-balham-dark .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 0 solid transparent;\n margin-left: -1px;\n padding-left: 1px; }\n .ag-theme-balham-dark .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-balham-dark .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #00B0FF;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-balham-active-color, #00B0FF))); }\n .ag-theme-balham-dark .ag-filter-toolpanel-header {\n height: 24px; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-header, .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-header, .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 4px; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f112\";\n position: absolute; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-left: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-right: 4px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-0-header {\n height: 32px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-item {\n margin-top: 2px;\n margin-bottom: 2px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-search {\n height: 32px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-search-input {\n flex-grow: 1;\n height: 16px; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242)); }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 20px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 20px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 36px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 36px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 52px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 52px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 68px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 68px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 84px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 84px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 100px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 100px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 116px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 116px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 132px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 132px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 148px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 148px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 164px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 164px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 4px; }\n .ag-theme-balham-dark .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242);\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242);\n padding-top: 4px; }\n .ag-theme-balham-dark .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 4px; }\n .ag-theme-balham-dark .ag-pivot-mode-panel {\n height: 32px;\n display: flex; }\n .ag-theme-balham-dark .ag-pivot-mode-select {\n display: flex;\n align-items: center; }\n .ag-theme-balham-dark .ag-ltr .ag-pivot-mode-select {\n margin-left: 6px; }\n .ag-theme-balham-dark .ag-rtl .ag-pivot-mode-select {\n margin-right: 6px; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-column-select-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-column-select-header {\n height: 32px;\n align-items: center;\n padding: 0 6px;\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242)); }\n .ag-theme-balham-dark .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242));\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242)); }\n .ag-theme-balham-dark .ag-column-group-icons,\n .ag-theme-balham-dark .ag-column-select-header-icon {\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-header {\n background-color: #1c1c1c;\n background-color: var(--ag-header-background-color, #1c1c1c);\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-header-row {\n color: rgba(245, 245, 245, 0.64);\n color: var(--ag-header-foreground-color, rgba(245, 245, 245, 0.64)); }\n .ag-theme-balham-dark .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-header-row {\n height: 32px; }\n .ag-theme-balham-dark .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-balham-dark .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-header-cell,\n .ag-theme-balham-dark .ag-header-group-cell {\n padding-left: 12px;\n padding-right: 12px; }\n .ag-theme-balham-dark .ag-header-cell.ag-header-cell-moving,\n .ag-theme-balham-dark .ag-header-group-cell.ag-header-cell-moving {\n background-color: #2d3436;\n background-color: var(--ag-header-cell-moving-background-color, var(--ag-background-color, #2d3436)); }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-header-cell:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-header-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none; }\n .ag-theme-balham-dark .ag-keyboard-focus .ag-header-group-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark .ag-header-icon {\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-header-expand-icon {\n cursor: pointer; }\n .ag-theme-balham-dark .ag-ltr .ag-header-expand-icon {\n padding-left: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-header-expand-icon {\n padding-right: 4px; }\n .ag-theme-balham-dark .ag-header-row:not(:first-child) .ag-header-cell,\n .ag-theme-balham-dark .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-header-cell::after,\n .ag-theme-balham-dark .ag-header-group-cell::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n width: 1px;\n height: 50%;\n top: calc(50% - 25%);\n background-color: rgba(66, 66, 66, 0.5);\n background-color: var(--ag-header-column-separator-color, rgba(66, 66, 66, 0.5)); }\n .ag-theme-balham-dark .ag-ltr .ag-header-cell::after, .ag-theme-balham-dark .ag-ltr .ag-header-group-cell::after {\n right: 0; }\n .ag-theme-balham-dark .ag-rtl .ag-header-cell::after, .ag-theme-balham-dark .ag-rtl .ag-header-group-cell::after {\n left: 0; }\n .ag-theme-balham-dark .ag-ltr .ag-header-select-all {\n margin-right: 12px; }\n .ag-theme-balham-dark .ag-rtl .ag-header-select-all {\n margin-left: 12px; }\n .ag-theme-balham-dark .ag-ltr .ag-floating-filter-button {\n margin-left: 12px; }\n .ag-theme-balham-dark .ag-rtl .ag-floating-filter-button {\n margin-right: 12px; }\n .ag-theme-balham-dark .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 16px;\n padding: 0;\n width: 16px; }\n .ag-theme-balham-dark .ag-filter-loading {\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020);\n height: 100%;\n padding: 6px 6px;\n position: absolute;\n width: 100%;\n z-index: 1; }\n .ag-theme-balham-dark .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242);\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n height: 32px; }\n .ag-theme-balham-dark .ag-paging-panel > * {\n margin: 0 12px; }\n .ag-theme-balham-dark .ag-paging-button {\n cursor: pointer;\n opacity: 0;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n padding: 0;\n width: 16px; }\n .ag-theme-balham-dark .ag-disabled .ag-paging-button {\n cursor: default; }\n .ag-theme-balham-dark .ag-paging-button-wrapper.ag-disabled {\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38));\n cursor: default; }\n .ag-theme-balham-dark .ag-paging-button-wrapper, .ag-theme-balham-dark .ag-paging-description {\n margin: 0 4px; }\n .ag-theme-balham-dark .ag-status-bar {\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-border-color, #424242);\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38));\n padding-right: 16px;\n padding-left: 16px;\n line-height: 1.5; }\n .ag-theme-balham-dark .ag-status-name-value-value {\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5); }\n .ag-theme-balham-dark .ag-status-bar-center {\n text-align: center; }\n .ag-theme-balham-dark .ag-status-name-value {\n margin-left: 4px;\n margin-right: 4px;\n padding-top: 8px;\n padding-bottom: 8px; }\n .ag-theme-balham-dark .ag-column-drop-cell {\n background: #353535;\n background: var(--ag-chip-background-color, #353535);\n border-radius: 16px;\n height: 16px;\n padding: 0 2px; }\n .ag-theme-balham-dark .ag-column-drop-cell-text {\n margin: 0 4px; }\n .ag-theme-balham-dark .ag-column-drop-cell-button {\n min-width: 16px;\n margin: 0 2px;\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-column-drop-cell-drag-handle {\n margin-left: 8px; }\n .ag-theme-balham-dark .ag-column-drop-cell-ghost {\n opacity: 0.5; }\n .ag-theme-balham-dark .ag-column-drop-horizontal {\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020);\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5));\n height: 28px;\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-ltr .ag-column-drop-horizontal {\n padding-left: 12px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-drop-horizontal {\n padding-right: 12px; }\n .ag-theme-balham-dark .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-column-drop-horizontal-cell-separator {\n margin: 0 4px;\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-column-drop-horizontal-empty-message {\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38)); }\n .ag-theme-balham-dark .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 12px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 12px; }\n .ag-theme-balham-dark .ag-column-drop-vertical-list {\n padding-bottom: 4px;\n padding-right: 4px;\n padding-left: 4px; }\n .ag-theme-balham-dark .ag-column-drop-vertical-cell {\n margin-top: 4px; }\n .ag-theme-balham-dark .ag-column-drop-vertical {\n min-height: 50px;\n max-height: 150px;\n border-bottom: solid 1px;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242)); }\n .ag-theme-balham-dark .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none; }\n .ag-theme-balham-dark .ag-column-drop-vertical-icon {\n margin-left: 4px;\n margin-right: 4px; }\n .ag-theme-balham-dark .ag-column-drop-vertical-list {\n position: relative; }\n .ag-theme-balham-dark .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38));\n margin-top: 4px; }\n .ag-theme-balham-dark .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n background: #2d3436;\n background: var(--ag-background-color, #2d3436);\n height: 70px;\n padding: 0; }\n .ag-theme-balham-dark .ag-select-agg-func-virtual-list-item {\n cursor: default;\n line-height: 20px;\n padding-left: 8px; }\n .ag-theme-balham-dark .ag-select-agg-func-virtual-list-item:hover {\n background-color: #005880;\n background-color: var(--ag-selected-row-background-color, #005880); }\n .ag-theme-balham-dark .ag-chart-menu {\n border-radius: 2px;\n background: #2d3436;\n background: var(--ag-background-color, #2d3436); }\n .ag-theme-balham-dark .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 2px;\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-chart-menu-icon:hover {\n opacity: 1; }\n .ag-theme-balham-dark .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: #424242;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242));\n border-radius: 5px;\n margin: 5px; }\n .ag-theme-balham-dark .ag-chart-mini-thumbnail:nth-last-child(3),\n .ag-theme-balham-dark .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto; }\n .ag-theme-balham-dark .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0; }\n .ag-theme-balham-dark .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0; }\n .ag-theme-balham-dark .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0; }\n .ag-theme-balham-dark .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0; }\n .ag-theme-balham-dark .ag-chart-mini-thumbnail.ag-selected {\n border-color: #00B0FF;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF))); }\n .ag-theme-balham-dark .ag-chart-settings-card-item {\n background: #F5F5F5;\n background: var(--ag-foreground-color, #F5F5F5);\n width: 8px;\n height: 8px;\n border-radius: 4px; }\n .ag-theme-balham-dark .ag-chart-settings-card-item.ag-selected {\n background-color: #00B0FF;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF))); }\n .ag-theme-balham-dark .ag-chart-data-column-drag-handle {\n margin-left: 4px; }\n .ag-theme-balham-dark .ag-charts-settings-group-title-bar,\n .ag-theme-balham-dark .ag-charts-data-group-title-bar,\n .ag-theme-balham-dark .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: #424242;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #424242)); }\n .ag-theme-balham-dark .ag-charts-settings-group-container {\n padding: 4px; }\n .ag-theme-balham-dark .ag-charts-data-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-balham-dark .ag-charts-data-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-balham-dark .ag-charts-format-top-level-group-container {\n margin-left: 8px;\n padding: 4px; }\n .ag-theme-balham-dark .ag-charts-format-top-level-group-item {\n margin: 4px 0; }\n .ag-theme-balham-dark .ag-charts-format-sub-level-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-balham-dark .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-balham-dark .ag-charts-group-container.ag-group-container-horizontal {\n padding: 4px; }\n .ag-theme-balham-dark .ag-chart-data-section,\n .ag-theme-balham-dark .ag-chart-format-section {\n display: flex;\n margin: 0; }\n .ag-theme-balham-dark .ag-chart-menu-panel {\n background-color: #202020;\n background-color: var(--ag-control-panel-background-color, #202020); }\n .ag-theme-balham-dark .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: #424242;\n border-left-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: #424242;\n border-right-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-date-time-list-page-title {\n flex-grow: 1;\n text-align: center; }\n .ag-theme-balham-dark .ag-date-time-list-page-column-label {\n text-align: center; }\n .ag-theme-balham-dark .ag-date-time-list-page-entry {\n text-align: center; }\n .ag-theme-balham-dark .ag-checkbox-input-wrapper {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: #2d3436;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, #2d3436));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n flex: none; }\n .ag-theme-balham-dark .ag-checkbox-input-wrapper input, .ag-theme-balham-dark .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-balham-dark .ag-checkbox-input-wrapper:focus-within, .ag-theme-balham-dark .ag-checkbox-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 4px 1.5px #719ECE; }\n .ag-theme-balham-dark .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-balham-dark .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #ecf0f1;\n color: var(--ag-checkbox-unchecked-color, #ecf0f1);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham-dark .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #00B0FF;\n color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham-dark .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #ecf0f1;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, #ecf0f1));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham-dark .ag-toggle-button-input-wrapper {\n box-sizing: border-box;\n width: 32px;\n height: 16px;\n background-color: transparent;\n background-color: var(--ag-toggle-button-off-background-color, transparent);\n border-radius: 8px;\n position: relative;\n flex: none;\n border: 1px solid;\n border-color: #F5F5F5;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%; }\n .ag-theme-balham-dark .ag-toggle-button-input-wrapper:focus-within {\n outline: none;\n box-shadow: 0 0 4px 1.5px #719ECE; }\n .ag-theme-balham-dark .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-balham-dark .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #00B0FF;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF)));\n border-color: #00B0FF;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF))); }\n .ag-theme-balham-dark .ag-toggle-button-input-wrapper::before {\n content: ' ';\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n box-sizing: border-box;\n height: 16px;\n width: 16px;\n background-color: #2d3436;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #2d3436));\n border-radius: 8px;\n transition: left 100ms;\n border: 1px solid;\n border-color: #F5F5F5;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-foreground-color, #F5F5F5))); }\n .ag-theme-balham-dark .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 16px);\n border-color: #00B0FF;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF))); }\n .ag-theme-balham-dark .ag-radio-button-input-wrapper {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: #2d3436;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, #2d3436));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n flex: none;\n border-radius: 16px; }\n .ag-theme-balham-dark .ag-radio-button-input-wrapper input, .ag-theme-balham-dark .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-balham-dark .ag-radio-button-input-wrapper:focus-within, .ag-theme-balham-dark .ag-radio-button-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 4px 1.5px #719ECE; }\n .ag-theme-balham-dark .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-balham-dark .ag-radio-button-input-wrapper::after {\n content: \"\\f124\";\n color: #ecf0f1;\n color: var(--ag-checkbox-unchecked-color, #ecf0f1);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham-dark .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f125\";\n color: #00B0FF;\n color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham-dark input[class^='ag-'][type='range'] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible; }\n .ag-theme-balham-dark input[class^='ag-'][type='range']::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #424242;\n background-color: var(--ag-border-color, #424242);\n border-radius: 2px;\n border-radius: 3px; }\n .ag-theme-balham-dark input[class^='ag-'][type='range']::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #424242;\n background-color: var(--ag-border-color, #424242);\n border-radius: 2px;\n border-radius: 3px; }\n .ag-theme-balham-dark input[class^='ag-'][type='range']::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #424242;\n background-color: var(--ag-border-color, #424242);\n border-radius: 2px;\n border-radius: 3px;\n color: transparent;\n width: calc(100% - 2px); }\n .ag-theme-balham-dark input[class^='ag-'][type='range']::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n border: 1px solid;\n border-color: #ecf0f1;\n border-color: var(--ag-checkbox-unchecked-color, #ecf0f1);\n border-radius: 16px;\n -webkit-transform: translateY(-6.5px);\n transform: translateY(-6.5px); }\n .ag-theme-balham-dark input[class^='ag-'][type='range']::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n border: 1px solid;\n border-color: #ecf0f1;\n border-color: var(--ag-checkbox-unchecked-color, #ecf0f1);\n border-radius: 16px; }\n .ag-theme-balham-dark input[class^='ag-'][type='range']::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n border: 1px solid;\n border-color: #ecf0f1;\n border-color: var(--ag-checkbox-unchecked-color, #ecf0f1);\n border-radius: 16px; }\n .ag-theme-balham-dark input[class^='ag-'][type='range']:focus {\n outline: none; }\n .ag-theme-balham-dark input[class^='ag-'][type='range']:focus::-webkit-slider-thumb {\n box-shadow: 0 0 4px 1.5px #719ECE;\n border-color: #00B0FF;\n border-color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark input[class^='ag-'][type='range']:focus::-ms-thumb {\n box-shadow: 0 0 4px 1.5px #719ECE;\n border-color: #00B0FF;\n border-color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark input[class^='ag-'][type='range']:focus::-moz-ag-range-thumb {\n box-shadow: 0 0 4px 1.5px #719ECE;\n border-color: #00B0FF;\n border-color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #00B0FF)); }\n .ag-theme-balham-dark input[class^='ag-'][type='range']:active::-webkit-slider-runnable-track {\n background-color: #719ECE;\n background-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark input[class^='ag-'][type='range']:active::-moz-ag-range-track {\n background-color: #719ECE;\n background-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark input[class^='ag-'][type='range']:active::-ms-track {\n background-color: #719ECE;\n background-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham-dark input[class^='ag-'][type='range']:disabled {\n opacity: 0.5; }\n .ag-theme-balham-dark .ag-filter-toolpanel-header,\n .ag-theme-balham-dark .ag-filter-toolpanel-search,\n .ag-theme-balham-dark .ag-status-bar,\n .ag-theme-balham-dark .ag-header-row {\n font-weight: 600;\n color: rgba(245, 245, 245, 0.64);\n color: var(--ag-header-foreground-color, rgba(245, 245, 245, 0.64)); }\n .ag-theme-balham-dark .ag-ltr input[class^='ag-']:not([type]),\n .ag-theme-balham-dark .ag-ltr input[class^='ag-'][type='text'],\n .ag-theme-balham-dark .ag-ltr input[class^='ag-'][type='number'],\n .ag-theme-balham-dark .ag-ltr input[class^='ag-'][type='tel'],\n .ag-theme-balham-dark .ag-ltr input[class^='ag-'][type='date'],\n .ag-theme-balham-dark .ag-ltr input[class^='ag-'][type='datetime-local'],\n .ag-theme-balham-dark .ag-ltr textarea[class^='ag-'] {\n padding-left: 4px; }\n .ag-theme-balham-dark .ag-rtl input[class^='ag-']:not([type]),\n .ag-theme-balham-dark .ag-rtl input[class^='ag-'][type='text'],\n .ag-theme-balham-dark .ag-rtl input[class^='ag-'][type='number'],\n .ag-theme-balham-dark .ag-rtl input[class^='ag-'][type='tel'],\n .ag-theme-balham-dark .ag-rtl input[class^='ag-'][type='date'],\n .ag-theme-balham-dark .ag-rtl input[class^='ag-'][type='datetime-local'],\n .ag-theme-balham-dark .ag-rtl textarea[class^='ag-'] {\n padding-right: 4px; }\n .ag-theme-balham-dark .ag-column-drop-vertical-empty-message, .ag-theme-balham-dark .ag-status-bar {\n font-weight: 600;\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38)); }\n .ag-theme-balham-dark .ag-dnd-ghost {\n font-weight: 600; }\n .ag-theme-balham-dark .ag-tab {\n border: 1px solid transparent;\n padding: 4px 8px;\n margin: 4px;\n margin-bottom: -1px; }\n .ag-theme-balham-dark .ag-tab-selected {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n border-bottom-color: transparent; }\n .ag-theme-balham-dark .ag-tabs-header {\n border-bottom: 1px solid;\n border-bottom-color: #424242;\n border-bottom-color: var(--ag-border-color, #424242); }\n .ag-theme-balham-dark .ag-column-drop-cell {\n height: 24px; }\n .ag-theme-balham-dark .ag-column-drop-vertical-title {\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5); }\n .ag-theme-balham-dark .ag-column-drop-vertical-cell {\n margin-left: 8px;\n margin-right: 8px; }\n .ag-theme-balham-dark .ag-column-drop-vertical-cell-text {\n margin-left: 8px; }\n .ag-theme-balham-dark .ag-column-drop-vertical-icon {\n color: #F5F5F5;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #F5F5F5)); }\n .ag-theme-balham-dark .ag-ltr .ag-column-drop-vertical-empty-message {\n padding-left: 24px;\n padding-right: 4px; }\n .ag-theme-balham-dark .ag-rtl .ag-column-drop-vertical-empty-message {\n padding-right: 24px;\n padding-left: 4px; }\n .ag-theme-balham-dark .ag-column-drop-horizontal {\n height: 32px; }\n .ag-theme-balham-dark .ag-column-drop-empty {\n color: rgba(245, 245, 245, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(245, 245, 245, 0.38)); }\n .ag-theme-balham-dark .ag-column-drop-horizontal-cell-text {\n margin-left: 8px; }\n .ag-theme-balham-dark .ag-column-drop-vertical {\n padding-top: 8px; }\n .ag-theme-balham-dark .ag-menu-header {\n background-color: #1c1c1c;\n background-color: var(--ag-header-background-color, #1c1c1c); }\n .ag-theme-balham-dark .ag-overlay-loading-center {\n background-color: #2d3436;\n background-color: var(--ag-background-color, #2d3436);\n border: 1px solid;\n border-color: #424242;\n border-color: var(--ag-border-color, #424242);\n color: #F5F5F5;\n color: var(--ag-foreground-color, #F5F5F5);\n padding: 16px; }\n .ag-theme-balham-dark .ag-tooltip {\n border: none;\n background-color: #cbd0d3; }\n .ag-theme-balham-dark .ag-panel-title-bar-button-icon {\n font-size: 20px; }\n .ag-theme-balham-dark .ag-chart-data-section,\n .ag-theme-balham-dark .ag-chart-format-section {\n padding-bottom: 2px; }\n .ag-theme-balham-dark .ag-group-toolbar {\n background-color: rgba(17, 17, 17, 0.5);\n background-color: var(--ag-subheader-toolbar-background-color, rgba(17, 17, 17, 0.5)); }\n .ag-theme-balham-dark .ag-chart-tab {\n padding-top: 2px; }\n .ag-theme-balham-dark .ag-charts-format-sub-level-group-item {\n margin-bottom: 6px; }\n .ag-theme-balham-dark .ag-tooltip {\n background-color: #1c1f20; }\n\n", ""]);
  46268. // Exports
  46269. module.exports = exports;
  46270. /***/ }),
  46271. /* 234 */
  46272. /***/ (function(module, exports, __webpack_require__) {
  46273. var api = __webpack_require__(225);
  46274. var content = __webpack_require__(235);
  46275. content = content.__esModule ? content.default : content;
  46276. if (typeof content === 'string') {
  46277. content = [[module.i, content, '']];
  46278. }
  46279. var options = {};
  46280. options.insert = "head";
  46281. options.singleton = false;
  46282. var update = api(content, options);
  46283. module.exports = content.locals || {};
  46284. /***/ }),
  46285. /* 235 */
  46286. /***/ (function(module, exports, __webpack_require__) {
  46287. // Imports
  46288. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227);
  46289. exports = ___CSS_LOADER_API_IMPORT___(false);
  46290. // Module
  46291. exports.push([module.i, ".ag-theme-balham {\n -webkit-font-smoothing: antialiased;\n color: #000;\n color: var(--ag-foreground-color, #000);\n font-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Oxygen-Sans, Ubuntu, Cantarell, \"Helvetica Neue\", sans-serif;\n font-size: 12px;\n line-height: normal; }\n\n@font-face {\n font-family: \"agGridBalham\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABX4AAsAAAAAJ8wAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlEAAAReXgFf/09TLzIAAANcAAAAPgAAAFZWTFJaY21hcAAAA5wAAAHtAAAFgFIH7gFnbHlmAAAFjAAADLgAABYYNphscGhlYWQAABJEAAAALwAAADZ2zsSBaGhlYQAAEnQAAAAbAAAAJAfTBC1obXR4AAASkAAAABIAAAEUp/gAAGxvY2EAABKkAAAAZAAAAIwBFQakbWF4cAAAEwgAAAAfAAAAIAFbAHNuYW1lAAATKAAAATUAAAJG0OP3eXBvc3QAABRgAAABlwAAAlqez14KeJx9k09yElEQxr9hCBKISYwxloga/0bjOAwM/yQQCFKWZWXhwoULN3GhpZVylRO49gCWB/AUnsBy6coDeADLA/jrZpCYRXjFzJvur7/+ul8/BZJKSrSr3OTx/nMtHx4cvVdFeU1/5j++Dw7fvjlQcfaFL+/vooLwj5Z1Qy90pG+BgtfB51whzIW74X74IfwU/lAIalMx6LIesGLVeEZkr6uhVDkVsMXsm2qBDnm23bqmC1pwz1AjrZMzJmbkjNt6qptahWfgPH31QCUs4+zzHLNuaeUURKrb8NdR08VqrFUyrGpRe2jso6NDdAvvCr4dMkfEDPANdA68ofLexyd6iaI1r80i6xku4R/TZfuO/KvMmqHa8DfgN74tss7sDTLViLgHex3Uw6yH27pGdAOePmwdj256dBlkDYWJrrKzympUtkT9PT3TK8+6m8X0vYvTmrdQP7cPnC+l2uPWDlxjsHfRMLfaidwhV6QJ/pI2eL/TR33RV33XT/3Sb53B2sVrFfTg3jm1M0X6dxI9xNv+Z7VKC5zPSdT/iEXqbnhvYnyjrIOWrYxO603CPsKaOL6ETsMPUZNyGnlyRJ63hnWB1eU7Bn02m8YWa8n7PGIGbAIqdKfB05im85bS4Usw2W6qa8O71YLnop+W9dRu0rJ/2czbKVfAXOYdUVnd+/MI7xUsxjS3VD0qRbVx3MefonaezVRVUdX02bXJmvgtGJJpkzqmSmrcXLsBE5+q6yioZzdyndMw9Z3spM47LvaoAM1RdpMT75lN8gBtNhXjv2nbY10AAAB4nGNgZMpnnMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVFgEqgRRAAAy9AKRgAAeJy102dSWzEUhuHXhW56TaN3Y2wwvRkb/rAM0hlSGNKZrDI70QZCvnPPyQLITDTz+Ls6o6srjSygDSjImhQhXySHtd+q5rJ6ge6sXuSX+iU6yeu5whU33KXa/b2qFS655jblst7fltPoEk9ZZEe9I811oKdjqrT0xh4b7LPLCXU2OWWdbWo0OGeLQ5qc6f28vl7UGtvp0He7tJIezdhLH/0MMMgQw4wwyhjjTPCYJ/raM42ZZIppZpjVuDnmWdAalvTcwzIr+l1Vr6wFtvOwdvTA8dbWDnaOq63Knna7e1Lf1Ea3a43zrcPm2T9M9h9ayX4KP6N3gZ2ms91eBvt/PA8H8iLYyb4Mx/IqVOV1aMmbYPO+DXtyFTbkOuzLu7Ar78OJfAh1+Rg25Sacym1Yl09hWz6HmnwJDfkazuVb2JLv4VB+hKbcBR1gyjm7KynvsCw4u1up6Ox+pTZn9y61Oyw7HJadDssuh2W3s/uYehyWJWcnmXodln0Oy36H5YDDctBhOeSwHHZYjjgsRx2WYw7LcYflhMPykdPdJAXdUlLQfSUF3VxSyPY16bCcclhOOyxnHJazDss5l+133mG1BYfVFh1WW3JYbdlhtRWXzbPqsrWVHTZ2zWFjKy4bs+6w96oum7PmKP8BU32drwAAAHic7RhpcBvVeb+3lmRZsm5pJdk6V4ety9YdS/Zu7MTGdu7DCRlC0jQHDTFH0tAwIYJCaCAhDDSZcEwzFDoDGZgpw7TTDNMmpUMZMFNi0hQ6JTD9AbQNaRtCyXQGFy393molxybl+l1pd9/33vve9773ve96j2EZ/LHPss8yHJNm1jMMeAlnYQ1E0xROkSixCqQYUgXVRlDbbZwXuKawAEULm4JohA+qVXyetzs45a/WyH97Np+1B6K5YqGIuIViIRKl/3yANXcMxqCpCWKDHdJ70nvTNfBIfwvPAWCbSI4HL3j5HNHpEF65de5/4CFxCqw6v9fg0JlanEZ/xMBNidJ+aNLYDf0Gu1rt9XVbPAC72KevRBo8cm2gEF77+JIfXF8nrUzDslMia7ToHQ691dI+4Gh1egycSazouuwhm75bbzWa250hm5+fR0UFsrweYR9hfAxj5TTRIqcJmOUiag7IRTFglgvOPDGcOHw4MQytM0vpY6X+5pXbG/2tynzkZdbGNGNFmYeHN/clz5xJ7hPI0X2JM2cS+6Q5lC2Zt23sNsbGdDJ5xA/S7bDRrcnQfcjRfdBkaN1Ge+R9KdAeK9JFykg/WoRLW1aPZbLZzNjq1+rAlrGRoVg8HhsaeYYCEENo7MnkU08ln5S/7LYZ6DIgzESXIenj+gj8Mg2enawTIQ2jQ5lmzTx9i1k7f7pSOb9z5we33EK2SteR4erzU1PTYz5gzzFWJsogmU4IpiBvzgmQDWS8YDfbDMAGggYKeWmbQHtToAGUH7C56vfTK7q7V6RJreyqVjwZDz5kr1x2SOteyz4KN01jpOUR7E88aU91D37wIXfj5yPEzDwKN8/mKf7VeWIDaBdfxlF/9SXS++XsSKlhWV1m8MJAfXo+0GBJdSVOcpcRp5PdNYsL9tzlvbQcms2BIodb2U2MCjXWyTBa0HBaYIs+qPkGmyNTyFNFJH+X1pc2SlUQJiZeeU6ncxkd6cG0w+iCF+GJMnZIv4W+iQmhtdXbFnEF0+mgK9zupeSb5DmSrEHRGSPDhHlz1qq8QN/jovgrQTghitVTgvA2yVQnp9+GHZPDrAr5RB6p3pND0sXE++8n4FKtVNayCO3JyvBMN52lLsByQ6gsekEEHNhSwK4Izi7vuT2A7eSnl+Ij8dhIghbxkcinkUJB/khNc2MjcTgiXRfOV7APsjJCXDqFH5IpRKSXKCr0RgqSnljiw3ExH57m+2XyMrUVmGG1l5kj8V9uZjN9iOKbssSq+BBYWPMhMDFbLrh1Gi2QQygM6SKYyJ+odExgQhSVLJtjbAkl08MsZMaYdYhfKGYxfNSiAOXMANGa7y/KXgbZ5AxgBDlY0KpaFmiuCAKIkCI4ppClgrVpwqgpqJwZEVBbUsAHNcCv32pZ+/SdoVazpc3tj/QlRhY8s2zl/GVpk1Wr05lMCbE3IXQv5CCybMmGzWsdtvbSSO+mcgLu6V7AgXfnkR8v4Esj5c2luDTpjl8V74om3LHhWFeUfJRm2cX3Xt0e9MbaAy4kHLbY7N3lVW0pm9PutffF+xIP+67OkzVCn83uVbe0x8ubyiMl6ff+NXkyfGMfGwxiS+9I6WxHF1J0J6JdcSymdfUYyzNtTIopo6TkCKuISH25eDBWcgZSl05NIhqUBioZSgmViqOSQLv1AIqGWi1UG/JYcMP1N+1YszSjyEL8zTgsvP9GnyKLZXfyVADDpQ2l0oadG3p6NvwxNrxyOCZ/WL6x+MUh3mCcW1qtLHxsU5NI+sYHawv3uG9ZQlfr60ESNTp/gBglEiO1ouF7kmwS8wn0gqCs0wOaYkFZbKQPAiqbkjPYi/maahTybBI6nQNFZ/MJAAIaZ2HA1Um2V081yxCqSK2XnIt2e8rdbq3+uwfHdpR0za50n7c7NCiate50n6c7tLdrRUe3p5R2a80KP2RK1mdtXaNVZt5MPlG0WvqW0FBsh6SHS4y+tgZyoeFfrLiaNoz4vOzbuximyOez3GVv+EvqU7IvmvZIV65MVWo/USkFpUR2mmfkaXm0uT6mnxlkRr5uxmZFblQYc8Kzym+Ymx2tVGCX9Ar0SPsbkB6hS9IoHP9m6Vj1n4IgiMrbiGfTe1jz1tTLk7jisf8sCHWvXf037mBdD3ewbSg5M913dMh061muGMXVFqMkKsJ+aZd4QDoLkcnJdAXelbyVNHlQOCEcgAhEpLOTGdyBTJ3WdowDMWa1rNMoVg0KGN0blWpBhHwkmkY9NwCqtBdzXhHVFVXdGpSxsJF6u5TSQUfbsAOb07Ldy1R44sRYGWhraWkf96zoCOU0aofLomctYVO70WDi43t6Yr7xpNPDxTbFFnm2dXHtXNzbDJqwy66z0CHxInA2C+hYC29ot7Xo5qUinWRQq1e1Le+MeLZ5rK2tfRF+yG1h+bAlZI9u7E6H4m2c0b8tdU855QOtH6neXe72e7U6lW9TkkOqVoNxScqTt8ljAtbQtcn0Eqvp/zK5kkxqNnofe9/n/AZDrYzGaRW+ssXhW1TqGoTRaoWbJxIT8GJiIgGuqanq5NTUAoTJOmxF77FuyocAPokMWsU6LPGZeHpq2j6qpMqoGTwyWH3UQDThLsDsoPgP9q2hHct2wO+UcuIsS8vHaoWS4yTJ6/X8G9A66n82WX0APbDygktEexDrex/EmCbPp0ykTAuvN8kT/bA237/easJiO7zwFju0ffkOZewzmLvV7LKejaA51w43UDqYevts6mA//KIfobe7DsLSvfFTp+J74WR1Ek7WYJyZ0rmL3cU4mAQzh5kr5yAMUFXjHLLaoa5R7SoKhKNVjVrRQwxEsm4hGm2NRrpACw45BnWBwwcgjyoUOTlyccUITF27atkNLfpYZNHI81dfO69vLiFh/4339S8dnn+NVhuOLF98cvFYjG9uXjM0uvqCX61e0jcwmktHYbf0YXa8M2Y0W08O9HRI+0I6p7tQWq4Vchm7w/KZj/0eyaWPrdt8zdI5+bDdIfQ8tnL1aP/GgkgSsfuXji1akoqrYslVI2PLHownX+0bGaoEQxqV2wG3SQ+b2sKRXKn8GvE6pH3iof55nUmVwHZ29Arlz1qUfR1nb0Pt62B6UTLy4U8+ENr5zyf/vCbjsKmDkVwBAsEINhXKYA/ksxkHIqrJdr3B5Vvlcxn0lWBPEB+4VCunzC5X0OUCnaR3h0JuEXYJ7nCY9VhsToPFYnDaLIgkjSqDjuPH7PQ78ak+HnbBcXeoUgm5pVFXuOGz9yDPQYxuDNSzxgLuAS1EoNuloXkD9TRoTzS98IEmgquC2v4VOUdWTi1h2SEgTSqtp9RV3Nhs1LssnA289rmD38HsgrXZk9xDGDj+YtXqm01HCx0ZM7ibOQLN5Ehzi85osJjegNsPYS5l1HfotLoNbq+zzWoxSO+2j+k3q1WufLyb0yEF8oDJZDU4jhpYtk36q9oWdeYsD2Gk0zRb3qDLabksbvtxJ/qZIWYBs5K5htnAbPkfsTtgdsgXJyoavn2Y5tUsw46JoIavXTk4ZMGEbVw2H1VrsvliDFAiWUw87Fmq3WE1r7FnixHenv2iwA67q698eAGjrrbaDBiD/fDLlsTYyoQ2NtSxU5sYG0u0zA1l3F6ovgp7bgOoiLkFmAnsFuHkboqP4uiJ3fHCnKvu+MJQ/2n1VbUW0S+cMptwMrgNjDJx7c0dV8WJNrES5wGVxuqIeYfm3P7r0fwdnxTC68U9e4I0IQDYU4HbG/pxDs+19H5Dud0wUXXwU3GYZt1uBGmdXkIV4NK9O7fPmz9/3vadYKpD9+7asrHU21vauOUCAuUyAuw52iFdnIkszMChQG/9vF/nRfha3My6e5FxviqL8NwVblW+Mt/S6NjMkZTY7FyJ5lfo/DEwcZg0oWePstulswdEaRfsFw+kK5IX3q2kJycx4zp7gGZLB2iaNDmp0BnHnKAVvTID5gDm2TYHOhk8Gavqnp51Vp9fkQ6S4WBa+vl46fTp0vhKJPUOhKR36CkfQu3j5dOny+NwuHHfpiKH5XM6KXJFtkm6KKd6ZAtN3xFgZuMBPRNjvpqopfV31coGzov1Mz+HONKhn+HRd4AcQSB5Dww0aCWJje6yFWVwQg6AVqFx93QDO477Hsf8m7EGMdHG0wxGHXpYRS+LscWK+Y2XoMOKaqbzoSjQzIeTTZteltZgGqT4Y4SECPkRzDlPVDIkTZwnphTncSz/9saQkBT4rTFnQNNsdwtJeKJzsQebzElX1yqL2exD2OdXO9o2zmG34WAVOSpNfIAEQU2OQvE8kW7FVAbxfTIhfZsp1R4abUNCo36ZjoNVZRIda5CO6Fu1tiNdxhX+FyXYf3Z4nGNgZGBgAOJNb47Mjue3+crAzfwCKBDF+XhfA4JmYGB+CRJn4GBgAvEAeqIMgAB4nGNgZGBgfsHAACH//2d+ycDIgApcAXBnBQgAeJxjYGBgYH4xdDA9AADYnCd6AAB4nGNgAIIZDBcYnjE6MEYxLmF8xaTBFMVUw9THdIPpEzMHswzzBhYNlgKWLpYrrEGsOayT2GTYlrE9Ymdgl2K3YI9hf8PhxrGBM4xzDhcTlxpXAFcKVxlXF9cMbh7SIQDoHxaseJxjYGRgYHBlSGfgYQABJiDmAkIGhv9gPgMAGrQBzwB4nHWPP07DMBjFX2haRIsQEhJiwxMLUvpnYOjYodk7dGBzGydtlcSR41bqxjE4Acdg5AicgkPwEr6hQqotOT///N4nBcAtvhCgWQGu27NZF7jk7Y87pDvhkPwo3MUAz8I9+hfhPu1MeMBmwQlBeEXzgDfhC9zgXbhD/yEckj+Fu7jHt3CP/ke4j2UQCg/wFLzqLHbbZKbzjS4WJtvn2p2qU14aV29tqcbR6FTHpjROe5Oo1VHVh2zifapSZws1t6U3eW5V5ezOrH208b6aDoep+GhtC2hkiOGwRcI/18ix4VlgAcOXPe+ar+dS5/ySbYea3qKEwhgRRmfTMdNl29Dw/CZsrHDkWePAzoTWI+U9ZcayoTBvJzfpnNvSVO3bjmZNH3F206owxZA7/ZePmOKkX1qXaMkAAAB4nG2R6W7bMBCE/cWSrThp47ptet/3obbpfadX+h40RclEJFIgKR95+hJ1ESBA9w9nBsvZWbK30VvXqPf/OmCDPgkpA4ZkbDJii21OcZodxpxhwlnOcZ5dLnCRS1zmCle5xnVucJNb3OYOd7nHfR7wkEc85glPyXnGc16wx0te8Zo3vOUd7/nARz7xmS98ZZ9vfOcHP/nFAb97W6KqnKpE0NYMhHN24fvCy4EURqo6lTPhwljOlDyc2mX+F6hi91jQplBBuUYbEdTkWO7Mv85taWvr8lZH4oaRdI3xI2lNcEIGVSTStqtUOut9UigvM7VsRfQsNtVK5b4WftaPaFDqOo5JS+18SCqn27RytmuT2BCSWpVhUGsT52XrI98b1lYU2lRZI5a60UcqaZTpshh0zYw1asvYkIu6tgtVpG10Uv1Wm7TVcxvGLl63+bQLwZrcluXOScGkTlezkHgxVyPfRJe8sAuTrWFMFuLKk+CUOvlGWWfWERFUOBQBjcWwwCOpmXHIlGX8zYKGjpYVJUfMe70/6zKeWwA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n .ag-theme-balham .ag-icon {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n .ag-theme-balham .ag-icon-aggregation:before {\n content: \"\\f101\"; }\n .ag-theme-balham .ag-icon-arrows:before {\n content: \"\\f102\"; }\n .ag-theme-balham .ag-icon-asc:before {\n content: \"\\f103\"; }\n .ag-theme-balham .ag-icon-cancel:before {\n content: \"\\f104\"; }\n .ag-theme-balham .ag-icon-chart:before {\n content: \"\\f105\"; }\n .ag-theme-balham .ag-icon-color-picker:before {\n content: \"\\f109\"; }\n .ag-theme-balham .ag-icon-columns:before {\n content: \"\\f10a\"; }\n .ag-theme-balham .ag-icon-contracted:before {\n content: \"\\f10b\"; }\n .ag-theme-balham .ag-icon-copy:before {\n content: \"\\f10c\"; }\n .ag-theme-balham .ag-icon-cross:before {\n content: \"\\f10d\"; }\n .ag-theme-balham .ag-icon-desc:before {\n content: \"\\f10e\"; }\n .ag-theme-balham .ag-icon-expanded:before {\n content: \"\\f10f\"; }\n .ag-theme-balham .ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n .ag-theme-balham .ag-icon-eye:before {\n content: \"\\f111\"; }\n .ag-theme-balham .ag-icon-filter:before {\n content: \"\\f112\"; }\n .ag-theme-balham .ag-icon-first:before {\n content: \"\\f113\"; }\n .ag-theme-balham .ag-icon-grip:before {\n content: \"\\f114\"; }\n .ag-theme-balham .ag-icon-group:before {\n content: \"\\f115\"; }\n .ag-theme-balham .ag-icon-last:before {\n content: \"\\f116\"; }\n .ag-theme-balham .ag-icon-left:before {\n content: \"\\f117\"; }\n .ag-theme-balham .ag-icon-linked:before {\n content: \"\\f118\"; }\n .ag-theme-balham .ag-icon-loading:before {\n content: \"\\f119\"; }\n .ag-theme-balham .ag-icon-maximize:before {\n content: \"\\f11a\"; }\n .ag-theme-balham .ag-icon-menu:before {\n content: \"\\f11b\"; }\n .ag-theme-balham .ag-icon-minimize:before {\n content: \"\\f11c\"; }\n .ag-theme-balham .ag-icon-next:before {\n content: \"\\f11d\"; }\n .ag-theme-balham .ag-icon-none:before {\n content: \"\\f11e\"; }\n .ag-theme-balham .ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n .ag-theme-balham .ag-icon-paste:before {\n content: \"\\f120\"; }\n .ag-theme-balham .ag-icon-pin:before {\n content: \"\\f121\"; }\n .ag-theme-balham .ag-icon-pivot:before {\n content: \"\\f122\"; }\n .ag-theme-balham .ag-icon-previous:before {\n content: \"\\f123\"; }\n .ag-theme-balham .ag-icon-right:before {\n content: \"\\f126\"; }\n .ag-theme-balham .ag-icon-save:before {\n content: \"\\f127\"; }\n .ag-theme-balham .ag-icon-small-down:before {\n content: \"\\f128\"; }\n .ag-theme-balham .ag-icon-small-left:before {\n content: \"\\f129\"; }\n .ag-theme-balham .ag-icon-small-right:before {\n content: \"\\f12a\"; }\n .ag-theme-balham .ag-icon-small-up:before {\n content: \"\\f12b\"; }\n .ag-theme-balham .ag-icon-tick:before {\n content: \"\\f12c\"; }\n .ag-theme-balham .ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n .ag-theme-balham .ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n .ag-theme-balham .ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n .ag-theme-balham .ag-icon-unlinked:before {\n content: \"\\f130\"; }\n .ag-theme-balham .ag-icon-row-drag:before {\n content: \"\\f114\"; }\n .ag-theme-balham .ag-right-arrow:before {\n content: \"\\f117\"; }\n .ag-theme-balham .ag-right-arrow:before {\n content: \"\\f126\"; }\n .ag-theme-balham .ag-root-wrapper {\n background-color: white;\n background-color: var(--ag-background-color, white); }\n .ag-theme-balham [class^='ag-'], .ag-theme-balham [class^='ag-']:focus, .ag-theme-balham [class^='ag-']:after, .ag-theme-balham [class^='ag-']:before {\n box-sizing: border-box;\n outline: none; }\n .ag-theme-balham [class^='ag-']::-ms-clear {\n display: none; }\n .ag-theme-balham .ag-checkbox .ag-input-wrapper,\n .ag-theme-balham .ag-radio-button .ag-input-wrapper {\n overflow: visible; }\n .ag-theme-balham .ag-range-field .ag-input-wrapper {\n height: 100%; }\n .ag-theme-balham .ag-toggle-button {\n flex: none;\n width: unset;\n min-width: unset; }\n .ag-theme-balham .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 4px; }\n .ag-theme-balham .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 4px; }\n .ag-theme-balham input[class^='ag-'] {\n margin: 0;\n background-color: white;\n background-color: var(--ag-background-color, white); }\n .ag-theme-balham textarea[class^='ag-'],\n .ag-theme-balham select[class^='ag-'] {\n background-color: white;\n background-color: var(--ag-background-color, white); }\n .ag-theme-balham input[class^='ag-']:not([type]),\n .ag-theme-balham input[class^='ag-'][type='text'],\n .ag-theme-balham input[class^='ag-'][type='number'],\n .ag-theme-balham input[class^='ag-'][type='tel'],\n .ag-theme-balham input[class^='ag-'][type='date'],\n .ag-theme-balham input[class^='ag-'][type='datetime-local'],\n .ag-theme-balham textarea[class^='ag-'] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #95a5a6;\n border-color: var(--ag-input-border-color, #95a5a6); }\n .ag-theme-balham input[class^='ag-']:not([type]):disabled,\n .ag-theme-balham input[class^='ag-'][type='text']:disabled,\n .ag-theme-balham input[class^='ag-'][type='number']:disabled,\n .ag-theme-balham input[class^='ag-'][type='tel']:disabled,\n .ag-theme-balham input[class^='ag-'][type='date']:disabled,\n .ag-theme-balham input[class^='ag-'][type='datetime-local']:disabled,\n .ag-theme-balham textarea[class^='ag-']:disabled {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n background-color: #ebebeb;\n background-color: var(--ag-input-disabled-background-color, #ebebeb);\n border-color: rgba(149, 165, 166, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(149, 165, 166, 0.3)); }\n .ag-theme-balham input[class^='ag-']:not([type]):focus,\n .ag-theme-balham input[class^='ag-'][type='text']:focus,\n .ag-theme-balham input[class^='ag-'][type='number']:focus,\n .ag-theme-balham input[class^='ag-'][type='tel']:focus,\n .ag-theme-balham input[class^='ag-'][type='date']:focus,\n .ag-theme-balham input[class^='ag-'][type='datetime-local']:focus,\n .ag-theme-balham textarea[class^='ag-']:focus {\n outline: none;\n box-shadow: 0 0 2px 1px #719ECE;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham input[class^='ag-'][type='number'] {\n -moz-appearance: textfield; }\n .ag-theme-balham input[class^='ag-'][type='number']::-webkit-outer-spin-button, .ag-theme-balham input[class^='ag-'][type='number']::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0; }\n .ag-theme-balham input[class^='ag-'][type='range'] {\n padding: 0; }\n .ag-theme-balham input[class^='ag-'][type='button']:focus, .ag-theme-balham button[class^='ag-']:focus {\n box-shadow: 0 0 2px 1px #719ECE; }\n .ag-theme-balham .ag-drag-handle {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-list-item, .ag-theme-balham .ag-virtual-list-item {\n height: 28px; }\n .ag-theme-balham .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-virtual-list-item:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-select-list {\n background-color: white;\n background-color: var(--ag-background-color, white);\n overflow-y: auto;\n overflow-x: hidden; }\n .ag-theme-balham .ag-list-item {\n display: flex;\n align-items: center; }\n .ag-theme-balham .ag-list-item.ag-active-item {\n background-color: #ecf0f1;\n background-color: var(--ag-row-hover-color, #ecf0f1); }\n .ag-theme-balham .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n .ag-theme-balham .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden; }\n .ag-theme-balham .ag-select .ag-picker-field-wrapper {\n background-color: white;\n background-color: var(--ag-background-color, white);\n min-height: 28px;\n cursor: default; }\n .ag-theme-balham .ag-select:not(.ag-cell-editor) {\n height: 28px; }\n .ag-theme-balham .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis; }\n .ag-theme-balham .ag-select .ag-picker-field-icon {\n display: flex;\n align-items: center; }\n .ag-theme-balham .ag-select.ag-disabled {\n opacity: 0.5; }\n .ag-theme-balham .ag-rich-select {\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7); }\n .ag-theme-balham .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 182px; }\n .ag-theme-balham .ag-rich-select-value {\n padding: 0 4px 0 12px;\n height: 28px;\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7)); }\n .ag-theme-balham .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 28px; }\n .ag-theme-balham .ag-rich-select-virtual-list-item:hover {\n background-color: #ecf0f1;\n background-color: var(--ag-row-hover-color, #ecf0f1); }\n .ag-theme-balham .ag-rich-select-row {\n padding-left: 12px; }\n .ag-theme-balham .ag-rich-select-row-selected {\n background-color: #b7e4ff;\n background-color: var(--ag-selected-row-background-color, #b7e4ff); }\n .ag-theme-balham .ag-row-drag,\n .ag-theme-balham .ag-selection-checkbox,\n .ag-theme-balham .ag-group-expanded,\n .ag-theme-balham .ag-group-contracted {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-ltr .ag-row-drag, .ag-theme-balham .ag-ltr .ag-selection-checkbox, .ag-theme-balham .ag-ltr .ag-group-expanded, .ag-theme-balham .ag-ltr .ag-group-contracted {\n margin-right: 12px; }\n .ag-theme-balham .ag-rtl .ag-row-drag, .ag-theme-balham .ag-rtl .ag-selection-checkbox, .ag-theme-balham .ag-rtl .ag-group-expanded, .ag-theme-balham .ag-rtl .ag-group-contracted {\n margin-left: 12px; }\n .ag-theme-balham .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: 26px;\n display: flex;\n align-items: center;\n flex: none; }\n .ag-theme-balham .ag-group-expanded,\n .ag-theme-balham .ag-group-contracted {\n cursor: pointer; }\n .ag-theme-balham .ag-group-title-bar-icon {\n cursor: pointer;\n flex: none;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-ltr .ag-group-child-count {\n margin-left: 2px; }\n .ag-theme-balham .ag-rtl .ag-group-child-count {\n margin-right: 2px; }\n .ag-theme-balham .ag-group-title-bar {\n background-color: #e2e9eb;\n background-color: var(--ag-subheader-background-color, #e2e9eb);\n padding: 4px; }\n .ag-theme-balham .ag-group-toolbar {\n padding: 4px; }\n .ag-theme-balham .ag-disabled-group-title-bar, .ag-theme-balham .ag-disabled-group-container {\n opacity: 0.5; }\n .ag-theme-balham .group-item {\n margin: 2px 0; }\n .ag-theme-balham .ag-label {\n white-space: nowrap; }\n .ag-theme-balham .ag-ltr .ag-label {\n margin-right: 4px; }\n .ag-theme-balham .ag-rtl .ag-label {\n margin-left: 4px; }\n .ag-theme-balham .ag-label-align-top .ag-label {\n margin-bottom: 2px; }\n .ag-theme-balham .ag-ltr .ag-slider-field, .ag-theme-balham .ag-ltr .ag-angle-select-field {\n margin-right: 8px; }\n .ag-theme-balham .ag-rtl .ag-slider-field, .ag-theme-balham .ag-rtl .ag-angle-select-field {\n margin-left: 8px; }\n .ag-theme-balham .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background-color: white;\n background-color: var(--ag-background-color, white); }\n .ag-theme-balham .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: rgba(0, 0, 0, 0.54);\n background-color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n border-radius: 5px; }\n .ag-theme-balham .ag-picker-field-wrapper:focus {\n box-shadow: 0 0 2px 1px #719ECE; }\n .ag-theme-balham .ag-picker-field-button {\n background-color: white;\n background-color: var(--ag-background-color, white);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-dialog.ag-color-dialog {\n border-radius: 5px; }\n .ag-theme-balham .ag-color-picker .ag-picker-field-display {\n height: 16px; }\n .ag-theme-balham .ag-color-panel {\n padding: 4px; }\n .ag-theme-balham .ag-spectrum-color {\n background-color: red;\n border-radius: 2px; }\n .ag-theme-balham .ag-spectrum-tools {\n padding: 10px; }\n .ag-theme-balham .ag-spectrum-sat {\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0)); }\n .ag-theme-balham .ag-spectrum-val {\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0)); }\n .ag-theme-balham .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24); }\n .ag-theme-balham .ag-spectrum-hue-background {\n border-radius: 2px; }\n .ag-theme-balham .ag-spectrum-alpha-background {\n border-radius: 2px; }\n .ag-theme-balham .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px; }\n .ag-theme-balham .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37); }\n .ag-theme-balham .ag-recent-color {\n margin: 0 3px; }\n .ag-theme-balham .ag-recent-color:first-child {\n margin-left: 0; }\n .ag-theme-balham .ag-recent-color:last-child {\n margin-right: 0; }\n .ag-theme-balham.ag-dnd-ghost {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background: white;\n background: var(--ag-background-color, white);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n overflow: hidden;\n text-overflow: ellipsis;\n z-index: 10;\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7));\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n height: 32px !important;\n line-height: 32px;\n margin: 0;\n padding: 0 8px;\n -webkit-transform: translateY(8px);\n transform: translateY(8px); }\n .ag-theme-balham .ag-dnd-ghost-icon {\n margin-right: 4px;\n color: #000;\n color: var(--ag-foreground-color, #000); }\n .ag-theme-balham .ag-popup-child:not(.ag-tooltip-custom) {\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3); }\n .ag-dragging-range-handle .ag-theme-balham .ag-dialog,\n .ag-dragging-fill-handle .ag-theme-balham .ag-dialog {\n opacity: 0.7;\n pointer-events: none; }\n .ag-theme-balham .ag-dialog {\n border-radius: 2px;\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-panel {\n background-color: white;\n background-color: var(--ag-background-color, white); }\n .ag-theme-balham .ag-panel-title-bar {\n background-color: #f5f7f7;\n background-color: var(--ag-header-background-color, #f5f7f7);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)));\n height: 32px;\n padding: 4px 12px;\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-ltr .ag-panel-title-bar-button {\n margin-left: 4px; }\n .ag-theme-balham .ag-rtl .ag-panel-title-bar-button {\n margin-right: 4px; }\n .ag-theme-balham .ag-tooltip {\n background-color: #f5f7f7;\n background-color: var(--ag-header-background-color, #f5f7f7);\n color: #000;\n color: var(--ag-foreground-color, #000);\n padding: 4px;\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n border-radius: 2px;\n transition: opacity 1s; }\n .ag-theme-balham .ag-tooltip.ag-tooltip-hiding {\n opacity: 0; }\n .ag-theme-balham .ag-ltr .ag-column-select-indent-1 {\n padding-left: 20px; }\n .ag-theme-balham .ag-rtl .ag-column-select-indent-1 {\n padding-right: 20px; }\n .ag-theme-balham .ag-ltr .ag-column-select-indent-2 {\n padding-left: 40px; }\n .ag-theme-balham .ag-rtl .ag-column-select-indent-2 {\n padding-right: 40px; }\n .ag-theme-balham .ag-ltr .ag-column-select-indent-3 {\n padding-left: 60px; }\n .ag-theme-balham .ag-rtl .ag-column-select-indent-3 {\n padding-right: 60px; }\n .ag-theme-balham .ag-ltr .ag-column-select-indent-4 {\n padding-left: 80px; }\n .ag-theme-balham .ag-rtl .ag-column-select-indent-4 {\n padding-right: 80px; }\n .ag-theme-balham .ag-ltr .ag-column-select-indent-5 {\n padding-left: 100px; }\n .ag-theme-balham .ag-rtl .ag-column-select-indent-5 {\n padding-right: 100px; }\n .ag-theme-balham .ag-ltr .ag-column-select-indent-6 {\n padding-left: 120px; }\n .ag-theme-balham .ag-rtl .ag-column-select-indent-6 {\n padding-right: 120px; }\n .ag-theme-balham .ag-ltr .ag-column-select-indent-7 {\n padding-left: 140px; }\n .ag-theme-balham .ag-rtl .ag-column-select-indent-7 {\n padding-right: 140px; }\n .ag-theme-balham .ag-ltr .ag-column-select-indent-8 {\n padding-left: 160px; }\n .ag-theme-balham .ag-rtl .ag-column-select-indent-8 {\n padding-right: 160px; }\n .ag-theme-balham .ag-ltr .ag-column-select-indent-9 {\n padding-left: 180px; }\n .ag-theme-balham .ag-rtl .ag-column-select-indent-9 {\n padding-right: 180px; }\n .ag-theme-balham .ag-column-select-header-icon {\n cursor: pointer; }\n .ag-theme-balham .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-column-select-header-icon:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-balham .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 6px; }\n .ag-theme-balham .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-balham .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 6px; }\n .ag-theme-balham .ag-keyboard-focus .ag-column-select-column-group:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-column-select-column-group:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-keyboard-focus .ag-column-select-column:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-column-select-column:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-column-select-column-group:not(:last-child),\n .ag-theme-balham .ag-column-select-column:not(:last-child) {\n margin-bottom: 4px; }\n .ag-theme-balham .ag-column-select-column-readonly,\n .ag-theme-balham .ag-column-select-column-group-readonly {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n pointer-events: none; }\n .ag-theme-balham .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 24px; }\n .ag-theme-balham .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 24px; }\n .ag-theme-balham .ag-column-select-list {\n padding: 6px 6px; }\n .ag-theme-balham .ag-rtl {\n text-align: right; }\n .ag-theme-balham .ag-root-wrapper {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n border-radius: 2px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 40px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 40px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-1 {\n padding-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-1 {\n padding-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 68px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 68px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-2 {\n padding-left: 56px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-2 {\n padding-right: 56px; }\n .ag-theme-balham .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 96px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 96px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-3 {\n padding-left: 84px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-3 {\n padding-right: 84px; }\n .ag-theme-balham .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 124px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 124px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-4 {\n padding-left: 112px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-4 {\n padding-right: 112px; }\n .ag-theme-balham .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 152px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 152px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-5 {\n padding-left: 140px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-5 {\n padding-right: 140px; }\n .ag-theme-balham .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 180px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 180px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-6 {\n padding-left: 168px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-6 {\n padding-right: 168px; }\n .ag-theme-balham .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 208px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 208px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-7 {\n padding-left: 196px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-7 {\n padding-right: 196px; }\n .ag-theme-balham .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 236px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 236px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-8 {\n padding-left: 224px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-8 {\n padding-right: 224px; }\n .ag-theme-balham .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 264px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 264px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-9 {\n padding-left: 252px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-9 {\n padding-right: 252px; }\n .ag-theme-balham .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 292px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 292px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-10 {\n padding-left: 280px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-10 {\n padding-right: 280px; }\n .ag-theme-balham .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 320px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 320px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-11 {\n padding-left: 308px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-11 {\n padding-right: 308px; }\n .ag-theme-balham .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 348px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 348px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-12 {\n padding-left: 336px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-12 {\n padding-right: 336px; }\n .ag-theme-balham .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 376px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 376px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-13 {\n padding-left: 364px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-13 {\n padding-right: 364px; }\n .ag-theme-balham .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 404px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 404px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-14 {\n padding-left: 392px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-14 {\n padding-right: 392px; }\n .ag-theme-balham .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 432px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 432px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-15 {\n padding-left: 420px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-15 {\n padding-right: 420px; }\n .ag-theme-balham .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 460px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 460px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-16 {\n padding-left: 448px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-16 {\n padding-right: 448px; }\n .ag-theme-balham .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 488px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 488px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-17 {\n padding-left: 476px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-17 {\n padding-right: 476px; }\n .ag-theme-balham .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 516px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 516px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-18 {\n padding-left: 504px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-18 {\n padding-right: 504px; }\n .ag-theme-balham .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 544px; }\n .ag-theme-balham .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 544px; }\n .ag-theme-balham .ag-ltr .ag-row-group-indent-19 {\n padding-left: 532px; }\n .ag-theme-balham .ag-rtl .ag-row-group-indent-19 {\n padding-right: 532px; }\n .ag-theme-balham .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-left: 28px; }\n .ag-theme-balham .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-right: 28px; }\n .ag-theme-balham .ag-cell {\n -webkit-font-smoothing: subpixel-antialiased; }\n .ag-theme-balham .ag-value-change-delta {\n padding-right: 2px; }\n .ag-theme-balham .ag-value-change-delta-up {\n color: #43a047;\n color: var(--ag-value-change-delta-up-color, #43a047); }\n .ag-theme-balham .ag-value-change-delta-down {\n color: #e53935;\n color: var(--ag-value-change-delta-down-color, #e53935); }\n .ag-theme-balham .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n transition: background-color 1s; }\n .ag-theme-balham .ag-value-change-value-highlight {\n background-color: rgba(22, 160, 133, 0.5);\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5));\n transition: background-color 0.1s; }\n .ag-theme-balham .ag-cell-data-changed {\n background-color: rgba(22, 160, 133, 0.5) !important;\n background-color: var(--ag-value-change-value-highlight-background-color, rgba(22, 160, 133, 0.5)) !important; }\n .ag-theme-balham .ag-cell-data-changed-animation {\n background-color: transparent; }\n .ag-theme-balham .ag-cell-highlight {\n background-color: #0091ea !important;\n background-color: var(--ag-range-selection-highlight-color, var(--ag-balham-active-color, #0091ea)) !important; }\n .ag-theme-balham .ag-row {\n height: 28px;\n background-color: white;\n background-color: var(--ag-background-color, white);\n color: #000;\n color: var(--ag-data-color, var(--ag-foreground-color, #000));\n border-width: 1px;\n border-color: #d9dcde;\n border-color: var(--ag-row-border-color, #d9dcde); }\n .ag-theme-balham .ag-row:not(.ag-row-first) {\n border-top-style: solid; }\n .ag-theme-balham .ag-row.ag-row-last {\n border-bottom-style: solid; }\n .ag-theme-balham .ag-row-highlight-above::after, .ag-theme-balham .ag-row-highlight-below::after {\n content: '';\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #0091ea;\n background-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea));\n left: 1px; }\n .ag-theme-balham .ag-row-highlight-above::after {\n top: -1px; }\n .ag-theme-balham .ag-row-highlight-above.ag-row-first::after {\n top: 0; }\n .ag-theme-balham .ag-row-highlight-below::after {\n bottom: 0px; }\n .ag-theme-balham .ag-row-odd {\n background-color: #fcfdfe;\n background-color: var(--ag-odd-row-background-color, #fcfdfe); }\n .ag-theme-balham .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-row-hover {\n background-color: #ecf0f1;\n background-color: var(--ag-row-hover-color, #ecf0f1); }\n .ag-theme-balham .ag-ltr .ag-right-aligned-cell {\n text-align: right; }\n .ag-theme-balham .ag-rtl .ag-right-aligned-cell {\n text-align: left; }\n .ag-theme-balham .ag-ltr .ag-right-aligned-cell .ag-cell-value {\n margin-left: auto; }\n .ag-theme-balham .ag-rtl .ag-right-aligned-cell .ag-cell-value {\n margin-right: auto; }\n .ag-theme-balham .ag-cell {\n border: 1px solid transparent;\n line-height: 26px;\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-balham .ag-row > .ag-cell-wrapper {\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-balham .ag-row-dragging {\n cursor: move; }\n .ag-theme-balham .ag-row-dragging {\n opacity: 0.5; }\n .ag-theme-balham .ag-cell-inline-editing {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background: white;\n background: var(--ag-background-color, white);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n height: 28px;\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7); }\n .ag-theme-balham .ag-popup-editor {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background: white;\n background: var(--ag-background-color, white);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7);\n padding: 0; }\n .ag-theme-balham .ag-large-text-input {\n height: auto;\n padding: 12px; }\n .ag-theme-balham .ag-details-row {\n padding: 20px;\n background-color: white;\n background-color: var(--ag-background-color, white); }\n .ag-theme-balham .ag-overlay-loading-wrapper {\n background-color: rgba(255, 255, 255, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(255, 255, 255, 0.66)); }\n .ag-theme-balham .ag-overlay-loading-center {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background: white;\n background: var(--ag-background-color, white);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px; }\n .ag-theme-balham .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px; }\n .ag-theme-balham .ag-loading {\n padding-left: 12px;\n display: flex;\n height: 100%;\n align-items: center; }\n .ag-theme-balham .ag-loading-icon {\n padding-right: 12px; }\n .ag-theme-balham .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear; }\n\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n .ag-theme-balham .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-ltr .ag-cell {\n border-right: solid transparent; }\n .ag-theme-balham .ag-rtl .ag-cell {\n border-left: solid transparent; }\n .ag-theme-balham .ag-ltr .ag-cell {\n border-right-width: 1px; }\n .ag-theme-balham .ag-rtl .ag-cell {\n border-left-width: 1px; }\n .ag-theme-balham .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-row-selected {\n background-color: #b7e4ff;\n background-color: var(--ag-selected-row-background-color, #b7e4ff); }\n .ag-theme-balham .ag-cell-range-selected:not(.ag-cell-focus) {\n background-color: rgba(0, 145, 234, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(0, 145, 234, 0.2)); }\n .ag-theme-balham .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1);\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)); }\n .ag-theme-balham .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1);\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)); }\n .ag-theme-balham .ag-cell-range-selected-1:not(.ag-cell-focus) {\n background-color: rgba(0, 145, 234, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(0, 145, 234, 0.2))); }\n .ag-theme-balham .ag-cell-range-selected-2:not(.ag-cell-focus) {\n background-color: rgba(0, 145, 234, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(0, 145, 234, 0.36)); }\n .ag-theme-balham .ag-cell-range-selected-3:not(.ag-cell-focus) {\n background-color: rgba(0, 145, 234, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(0, 145, 234, 0.488)); }\n .ag-theme-balham .ag-cell-range-selected-4:not(.ag-cell-focus) {\n background-color: rgba(0, 145, 234, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(0, 145, 234, 0.5904)); }\n .ag-theme-balham .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #0091ea;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #0091ea;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #0091ea;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #0091ea;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-balham .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-balham .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-balham .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-balham .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-balham .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #0091ea;\n border-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea));\n outline: initial; }\n .ag-theme-balham .ag-cell.ag-selection-fill-top,\n .ag-theme-balham .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #0091ea;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-balham .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #0091ea;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-balham .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #0091ea;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-cell.ag-selection-fill-bottom,\n .ag-theme-balham .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #0091ea;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-balham .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #0091ea;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-balham .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #0091ea;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-fill-handle, .ag-theme-balham .ag-range-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #0091ea;\n background-color: var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham .ag-ltr .ag-fill-handle, .ag-theme-balham .ag-ltr .ag-range-handle {\n right: -1px; }\n .ag-theme-balham .ag-rtl .ag-fill-handle, .ag-theme-balham .ag-rtl .ag-range-handle {\n left: -1px; }\n .ag-theme-balham .ag-fill-handle {\n cursor: cell; }\n .ag-theme-balham .ag-range-handle {\n cursor: nwse-resize; }\n .ag-theme-balham .ag-cell-inline-editing {\n border-color: #719ECE !important;\n border-color: var(--ag-input-focus-border-color, #719ECE) !important; }\n .ag-theme-balham .ag-menu {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background: white;\n background: var(--ag-background-color, white);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n padding: 0; }\n .ag-theme-balham .ag-menu-list {\n cursor: default;\n width: 100%;\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-balham .ag-menu-option-part {\n padding-top: 6px;\n padding-bottom: 6px;\n line-height: 16px; }\n .ag-theme-balham .ag-menu-option-active {\n background-color: #ecf0f1;\n background-color: var(--ag-row-hover-color, #ecf0f1); }\n .ag-theme-balham .ag-menu-option-disabled {\n opacity: 0.5; }\n .ag-theme-balham .ag-menu-option-text {\n margin-left: 4px; }\n .ag-theme-balham .ag-menu-option-icon {\n padding-left: 8px;\n padding-right: 4px;\n min-width: 24px; }\n .ag-theme-balham .ag-menu-option-shortcut {\n padding-left: 8px; }\n .ag-theme-balham .ag-menu-separator {\n height: 8px; }\n .ag-theme-balham .ag-menu-separator-cell:after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-menu-option-popup-pointer {\n width: 24px;\n text-align: center; }\n .ag-theme-balham .ag-tabs-header {\n min-width: 220px;\n width: 100%;\n display: flex; }\n .ag-theme-balham .ag-tab {\n border-bottom: 0 solid transparent;\n display: flex;\n flex: none;\n align-items: center;\n justify-content: center;\n cursor: pointer; }\n .ag-theme-balham .ag-keyboard-focus .ag-tab:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-tab:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-tab-selected {\n border-bottom-color: #0091ea;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea))); }\n .ag-theme-balham .ag-menu-header {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-filter-condition-operator {\n height: 17px; }\n .ag-theme-balham .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 8px; }\n .ag-theme-balham .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 8px; }\n .ag-theme-balham .ag-set-filter-select-all {\n padding-top: 6px; }\n .ag-theme-balham .ag-set-filter-list {\n height: 168px; }\n .ag-theme-balham .ag-set-filter-filter {\n margin-top: 6px;\n margin-left: 6px;\n margin-right: 6px; }\n .ag-theme-balham .ag-filter-to {\n margin-top: 4px; }\n .ag-theme-balham .ag-mini-filter {\n margin: 6px 6px;\n margin-bottom: 0; }\n .ag-theme-balham .ag-set-filter-item {\n margin: 0px 6px; }\n .ag-theme-balham .ag-ltr .ag-set-filter-item-value {\n margin-left: 6px; }\n .ag-theme-balham .ag-rtl .ag-set-filter-item-value {\n margin-right: 6px; }\n .ag-theme-balham .ag-filter-header-container {\n padding-bottom: 6px;\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7)); }\n .ag-theme-balham .ag-filter-apply-panel {\n padding: 6px 6px;\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7)); }\n .ag-theme-balham .ag-filter-apply-panel-button {\n line-height: 1.5; }\n .ag-theme-balham .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 8px; }\n .ag-theme-balham .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 8px; }\n .ag-theme-balham .ag-simple-filter-body-wrapper {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-balham .ag-simple-filter-body-wrapper > * {\n margin-bottom: 4px; }\n .ag-theme-balham .ag-filter-no-matches {\n margin: 6px 6px; }\n .ag-theme-balham .ag-side-bar {\n position: relative; }\n .ag-theme-balham .ag-tool-panel-wrapper {\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7); }\n .ag-theme-balham .ag-side-buttons {\n padding-top: 16px;\n width: 20px;\n position: relative;\n color: #000;\n color: var(--ag-foreground-color, #000);\n overflow: hidden; }\n .ag-theme-balham button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 8px 0 8px 0;\n width: calc(100% + 1px);\n margin: 0;\n min-height: 72px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none;\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7);\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham button.ag-side-button-button:focus {\n box-shadow: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-side-button-button:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-selected .ag-side-button-button {\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7);\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7);\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-side-button-icon-wrapper {\n margin-bottom: 3px; }\n .ag-theme-balham .ag-ltr .ag-side-bar-left,\n .ag-theme-balham .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-balham .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-ltr .ag-side-bar-left .ag-side-button-button,\n .ag-theme-balham .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 0 solid transparent;\n margin-right: -1px;\n padding-right: 1px; }\n .ag-theme-balham .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-balham .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #0091ea;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea))); }\n .ag-theme-balham .ag-rtl .ag-side-bar-left,\n .ag-theme-balham .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-balham .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-rtl .ag-side-bar-left .ag-side-button-button,\n .ag-theme-balham .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 0 solid transparent;\n margin-left: -1px;\n padding-left: 1px; }\n .ag-theme-balham .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-balham .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #0091ea;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-balham-active-color, #0091ea))); }\n .ag-theme-balham .ag-filter-toolpanel-header {\n height: 24px; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-header, .ag-theme-balham .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 4px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-header, .ag-theme-balham .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 4px; }\n .ag-theme-balham .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f112\";\n position: absolute; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-left: 4px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-right: 4px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-0-header {\n height: 32px; }\n .ag-theme-balham .ag-filter-toolpanel-group-item {\n margin-top: 2px;\n margin-bottom: 2px; }\n .ag-theme-balham .ag-filter-toolpanel-search {\n height: 32px; }\n .ag-theme-balham .ag-filter-toolpanel-search-input {\n flex-grow: 1;\n height: 16px; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 4px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 4px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7)); }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 4px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 4px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 20px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 20px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 36px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 36px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 52px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 52px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 68px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 68px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 84px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 84px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 100px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 100px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 116px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 116px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 132px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 132px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 148px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 148px; }\n .ag-theme-balham .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 164px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 164px; }\n .ag-theme-balham .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 4px; }\n .ag-theme-balham .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7);\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7);\n padding-top: 4px; }\n .ag-theme-balham .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 4px; }\n .ag-theme-balham .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 4px; }\n .ag-theme-balham .ag-pivot-mode-panel {\n height: 32px;\n display: flex; }\n .ag-theme-balham .ag-pivot-mode-select {\n display: flex;\n align-items: center; }\n .ag-theme-balham .ag-ltr .ag-pivot-mode-select {\n margin-left: 6px; }\n .ag-theme-balham .ag-rtl .ag-pivot-mode-select {\n margin-right: 6px; }\n .ag-theme-balham .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-column-select-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-column-select-header {\n height: 32px;\n align-items: center;\n padding: 0 6px;\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7)); }\n .ag-theme-balham .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7));\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7)); }\n .ag-theme-balham .ag-column-group-icons,\n .ag-theme-balham .ag-column-select-header-icon {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-header {\n background-color: #f5f7f7;\n background-color: var(--ag-header-background-color, #f5f7f7);\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-header-row {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54))); }\n .ag-theme-balham .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-header-row {\n height: 32px; }\n .ag-theme-balham .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-balham .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-balham .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-balham .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-balham .ag-header-cell,\n .ag-theme-balham .ag-header-group-cell {\n padding-left: 12px;\n padding-right: 12px; }\n .ag-theme-balham .ag-header-cell.ag-header-cell-moving,\n .ag-theme-balham .ag-header-group-cell.ag-header-cell-moving {\n background-color: white;\n background-color: var(--ag-header-cell-moving-background-color, var(--ag-background-color, white)); }\n .ag-theme-balham .ag-keyboard-focus .ag-header-cell:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-header-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none; }\n .ag-theme-balham .ag-keyboard-focus .ag-header-group-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #719ECE;\n border-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham .ag-header-icon {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-header-expand-icon {\n cursor: pointer; }\n .ag-theme-balham .ag-ltr .ag-header-expand-icon {\n padding-left: 4px; }\n .ag-theme-balham .ag-rtl .ag-header-expand-icon {\n padding-right: 4px; }\n .ag-theme-balham .ag-header-row:not(:first-child) .ag-header-cell,\n .ag-theme-balham .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-header-cell::after,\n .ag-theme-balham .ag-header-group-cell::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n width: 1px;\n height: 50%;\n top: calc(50% - 25%);\n background-color: rgba(189, 195, 199, 0.5);\n background-color: var(--ag-header-column-separator-color, rgba(189, 195, 199, 0.5)); }\n .ag-theme-balham .ag-ltr .ag-header-cell::after, .ag-theme-balham .ag-ltr .ag-header-group-cell::after {\n right: 0; }\n .ag-theme-balham .ag-rtl .ag-header-cell::after, .ag-theme-balham .ag-rtl .ag-header-group-cell::after {\n left: 0; }\n .ag-theme-balham .ag-ltr .ag-header-select-all {\n margin-right: 12px; }\n .ag-theme-balham .ag-rtl .ag-header-select-all {\n margin-left: 12px; }\n .ag-theme-balham .ag-ltr .ag-floating-filter-button {\n margin-left: 12px; }\n .ag-theme-balham .ag-rtl .ag-floating-filter-button {\n margin-right: 12px; }\n .ag-theme-balham .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 16px;\n padding: 0;\n width: 16px; }\n .ag-theme-balham .ag-filter-loading {\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7);\n height: 100%;\n padding: 6px 6px;\n position: absolute;\n width: 100%;\n z-index: 1; }\n .ag-theme-balham .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n height: 32px; }\n .ag-theme-balham .ag-paging-panel > * {\n margin: 0 12px; }\n .ag-theme-balham .ag-paging-button {\n cursor: pointer;\n opacity: 0;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n padding: 0;\n width: 16px; }\n .ag-theme-balham .ag-disabled .ag-paging-button {\n cursor: default; }\n .ag-theme-balham .ag-paging-button-wrapper.ag-disabled {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n cursor: default; }\n .ag-theme-balham .ag-paging-button-wrapper, .ag-theme-balham .ag-paging-description {\n margin: 0 4px; }\n .ag-theme-balham .ag-status-bar {\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-border-color, #bdc3c7);\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n padding-right: 16px;\n padding-left: 16px;\n line-height: 1.5; }\n .ag-theme-balham .ag-status-name-value-value {\n color: #000;\n color: var(--ag-foreground-color, #000); }\n .ag-theme-balham .ag-status-bar-center {\n text-align: center; }\n .ag-theme-balham .ag-status-name-value {\n margin-left: 4px;\n margin-right: 4px;\n padding-top: 8px;\n padding-bottom: 8px; }\n .ag-theme-balham .ag-column-drop-cell {\n background: #dddede;\n background: var(--ag-chip-background-color, #dddede);\n border-radius: 16px;\n height: 16px;\n padding: 0 2px; }\n .ag-theme-balham .ag-column-drop-cell-text {\n margin: 0 4px; }\n .ag-theme-balham .ag-column-drop-cell-button {\n min-width: 16px;\n margin: 0 2px;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-column-drop-cell-drag-handle {\n margin-left: 8px; }\n .ag-theme-balham .ag-column-drop-cell-ghost {\n opacity: 0.5; }\n .ag-theme-balham .ag-column-drop-horizontal {\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n height: 28px;\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-ltr .ag-column-drop-horizontal {\n padding-left: 12px; }\n .ag-theme-balham .ag-rtl .ag-column-drop-horizontal {\n padding-right: 12px; }\n .ag-theme-balham .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-column-drop-horizontal-cell-separator {\n margin: 0 4px;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-column-drop-horizontal-empty-message {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-balham .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 12px; }\n .ag-theme-balham .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 12px; }\n .ag-theme-balham .ag-column-drop-vertical-list {\n padding-bottom: 4px;\n padding-right: 4px;\n padding-left: 4px; }\n .ag-theme-balham .ag-column-drop-vertical-cell {\n margin-top: 4px; }\n .ag-theme-balham .ag-column-drop-vertical {\n min-height: 50px;\n max-height: 150px;\n border-bottom: solid 1px;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7)); }\n .ag-theme-balham .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none; }\n .ag-theme-balham .ag-column-drop-vertical-icon {\n margin-left: 4px;\n margin-right: 4px; }\n .ag-theme-balham .ag-column-drop-vertical-list {\n position: relative; }\n .ag-theme-balham .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n margin-top: 4px; }\n .ag-theme-balham .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n background: white;\n background: var(--ag-background-color, white);\n border-radius: 2px;\n box-shadow: none;\n padding: 4px;\n background: white;\n background: var(--ag-background-color, white);\n height: 70px;\n padding: 0; }\n .ag-theme-balham .ag-select-agg-func-virtual-list-item {\n cursor: default;\n line-height: 20px;\n padding-left: 8px; }\n .ag-theme-balham .ag-select-agg-func-virtual-list-item:hover {\n background-color: #b7e4ff;\n background-color: var(--ag-selected-row-background-color, #b7e4ff); }\n .ag-theme-balham .ag-chart-menu {\n border-radius: 2px;\n background: white;\n background: var(--ag-background-color, white); }\n .ag-theme-balham .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 2px;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-chart-menu-icon:hover {\n opacity: 1; }\n .ag-theme-balham .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: #bdc3c7;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7));\n border-radius: 5px;\n margin: 5px; }\n .ag-theme-balham .ag-chart-mini-thumbnail:nth-last-child(3),\n .ag-theme-balham .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto; }\n .ag-theme-balham .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0; }\n .ag-theme-balham .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0; }\n .ag-theme-balham .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0; }\n .ag-theme-balham .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0; }\n .ag-theme-balham .ag-chart-mini-thumbnail.ag-selected {\n border-color: #0091ea;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea))); }\n .ag-theme-balham .ag-chart-settings-card-item {\n background: #000;\n background: var(--ag-foreground-color, #000);\n width: 8px;\n height: 8px;\n border-radius: 4px; }\n .ag-theme-balham .ag-chart-settings-card-item.ag-selected {\n background-color: #0091ea;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea))); }\n .ag-theme-balham .ag-chart-data-column-drag-handle {\n margin-left: 4px; }\n .ag-theme-balham .ag-charts-settings-group-title-bar,\n .ag-theme-balham .ag-charts-data-group-title-bar,\n .ag-theme-balham .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: #bdc3c7;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #bdc3c7)); }\n .ag-theme-balham .ag-charts-settings-group-container {\n padding: 4px; }\n .ag-theme-balham .ag-charts-data-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-balham .ag-charts-data-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-balham .ag-charts-format-top-level-group-container {\n margin-left: 8px;\n padding: 4px; }\n .ag-theme-balham .ag-charts-format-top-level-group-item {\n margin: 4px 0; }\n .ag-theme-balham .ag-charts-format-sub-level-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-balham .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-balham .ag-charts-group-container.ag-group-container-horizontal {\n padding: 4px; }\n .ag-theme-balham .ag-chart-data-section,\n .ag-theme-balham .ag-chart-format-section {\n display: flex;\n margin: 0; }\n .ag-theme-balham .ag-chart-menu-panel {\n background-color: #f5f7f7;\n background-color: var(--ag-control-panel-background-color, #f5f7f7); }\n .ag-theme-balham .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: #bdc3c7;\n border-left-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: #bdc3c7;\n border-right-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-date-time-list-page-title {\n flex-grow: 1;\n text-align: center; }\n .ag-theme-balham .ag-date-time-list-page-column-label {\n text-align: center; }\n .ag-theme-balham .ag-date-time-list-page-entry {\n text-align: center; }\n .ag-theme-balham .ag-checkbox-input-wrapper {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: white;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, white));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n flex: none; }\n .ag-theme-balham .ag-checkbox-input-wrapper input, .ag-theme-balham .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-balham .ag-checkbox-input-wrapper:focus-within, .ag-theme-balham .ag-checkbox-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 2px 1px #719ECE; }\n .ag-theme-balham .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-balham .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #7f8c8d;\n color: var(--ag-checkbox-unchecked-color, #7f8c8d);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #0091ea;\n color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #7f8c8d;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, #7f8c8d));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham .ag-toggle-button-input-wrapper {\n box-sizing: border-box;\n width: 32px;\n height: 16px;\n background-color: #7f8c8d;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, #7f8c8d));\n border-radius: 8px;\n position: relative;\n flex: none;\n border: 1px solid;\n border-color: #7f8c8d;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #7f8c8d)); }\n .ag-theme-balham .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%; }\n .ag-theme-balham .ag-toggle-button-input-wrapper:focus-within {\n outline: none;\n box-shadow: 0 0 2px 1px #719ECE; }\n .ag-theme-balham .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-balham .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #0091ea;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea)));\n border-color: #0091ea;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea))); }\n .ag-theme-balham .ag-toggle-button-input-wrapper::before {\n content: ' ';\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n box-sizing: border-box;\n height: 16px;\n width: 16px;\n background-color: white;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, white));\n border-radius: 8px;\n transition: left 100ms;\n border: 1px solid;\n border-color: #7f8c8d;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #7f8c8d))); }\n .ag-theme-balham .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 16px);\n border-color: #0091ea;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea))); }\n .ag-theme-balham .ag-radio-button-input-wrapper {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 16px;\n height: 16px;\n background-color: white;\n background-color: var(--ag-checkbox-background-color, var(--ag-background-color, white));\n border-radius: 3px;\n display: inline-block;\n vertical-align: middle;\n flex: none;\n border-radius: 16px; }\n .ag-theme-balham .ag-radio-button-input-wrapper input, .ag-theme-balham .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-balham .ag-radio-button-input-wrapper:focus-within, .ag-theme-balham .ag-radio-button-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 2px 1px #719ECE; }\n .ag-theme-balham .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-balham .ag-radio-button-input-wrapper::after {\n content: \"\\f124\";\n color: #7f8c8d;\n color: var(--ag-checkbox-unchecked-color, #7f8c8d);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f125\";\n color: #0091ea;\n color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-balham input[class^='ag-'][type='range'] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible; }\n .ag-theme-balham input[class^='ag-'][type='range']::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #bdc3c7;\n background-color: var(--ag-border-color, #bdc3c7);\n border-radius: 2px;\n border-radius: 3px; }\n .ag-theme-balham input[class^='ag-'][type='range']::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #bdc3c7;\n background-color: var(--ag-border-color, #bdc3c7);\n border-radius: 2px;\n border-radius: 3px; }\n .ag-theme-balham input[class^='ag-'][type='range']::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #bdc3c7;\n background-color: var(--ag-border-color, #bdc3c7);\n border-radius: 2px;\n border-radius: 3px;\n color: transparent;\n width: calc(100% - 2px); }\n .ag-theme-balham input[class^='ag-'][type='range']::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: white;\n background-color: var(--ag-background-color, white);\n border: 1px solid;\n border-color: #7f8c8d;\n border-color: var(--ag-checkbox-unchecked-color, #7f8c8d);\n border-radius: 16px;\n -webkit-transform: translateY(-6.5px);\n transform: translateY(-6.5px); }\n .ag-theme-balham input[class^='ag-'][type='range']::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: white;\n background-color: var(--ag-background-color, white);\n border: 1px solid;\n border-color: #7f8c8d;\n border-color: var(--ag-checkbox-unchecked-color, #7f8c8d);\n border-radius: 16px; }\n .ag-theme-balham input[class^='ag-'][type='range']::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 16px;\n height: 16px;\n background-color: white;\n background-color: var(--ag-background-color, white);\n border: 1px solid;\n border-color: #7f8c8d;\n border-color: var(--ag-checkbox-unchecked-color, #7f8c8d);\n border-radius: 16px; }\n .ag-theme-balham input[class^='ag-'][type='range']:focus {\n outline: none; }\n .ag-theme-balham input[class^='ag-'][type='range']:focus::-webkit-slider-thumb {\n box-shadow: 0 0 2px 1px #719ECE;\n border-color: #0091ea;\n border-color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham input[class^='ag-'][type='range']:focus::-ms-thumb {\n box-shadow: 0 0 2px 1px #719ECE;\n border-color: #0091ea;\n border-color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham input[class^='ag-'][type='range']:focus::-moz-ag-range-thumb {\n box-shadow: 0 0 2px 1px #719ECE;\n border-color: #0091ea;\n border-color: var(--ag-checkbox-checked-color, var(--ag-balham-active-color, #0091ea)); }\n .ag-theme-balham input[class^='ag-'][type='range']:active::-webkit-slider-runnable-track {\n background-color: #719ECE;\n background-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham input[class^='ag-'][type='range']:active::-moz-ag-range-track {\n background-color: #719ECE;\n background-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham input[class^='ag-'][type='range']:active::-ms-track {\n background-color: #719ECE;\n background-color: var(--ag-input-focus-border-color, #719ECE); }\n .ag-theme-balham input[class^='ag-'][type='range']:disabled {\n opacity: 0.5; }\n .ag-theme-balham .ag-filter-toolpanel-header,\n .ag-theme-balham .ag-filter-toolpanel-search,\n .ag-theme-balham .ag-status-bar,\n .ag-theme-balham .ag-header-row {\n font-weight: 600;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54))); }\n .ag-theme-balham .ag-ltr input[class^='ag-']:not([type]),\n .ag-theme-balham .ag-ltr input[class^='ag-'][type='text'],\n .ag-theme-balham .ag-ltr input[class^='ag-'][type='number'],\n .ag-theme-balham .ag-ltr input[class^='ag-'][type='tel'],\n .ag-theme-balham .ag-ltr input[class^='ag-'][type='date'],\n .ag-theme-balham .ag-ltr input[class^='ag-'][type='datetime-local'],\n .ag-theme-balham .ag-ltr textarea[class^='ag-'] {\n padding-left: 4px; }\n .ag-theme-balham .ag-rtl input[class^='ag-']:not([type]),\n .ag-theme-balham .ag-rtl input[class^='ag-'][type='text'],\n .ag-theme-balham .ag-rtl input[class^='ag-'][type='number'],\n .ag-theme-balham .ag-rtl input[class^='ag-'][type='tel'],\n .ag-theme-balham .ag-rtl input[class^='ag-'][type='date'],\n .ag-theme-balham .ag-rtl input[class^='ag-'][type='datetime-local'],\n .ag-theme-balham .ag-rtl textarea[class^='ag-'] {\n padding-right: 4px; }\n .ag-theme-balham .ag-column-drop-vertical-empty-message, .ag-theme-balham .ag-status-bar {\n font-weight: 600;\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-balham .ag-dnd-ghost {\n font-weight: 600; }\n .ag-theme-balham .ag-tab {\n border: 1px solid transparent;\n padding: 4px 8px;\n margin: 4px;\n margin-bottom: -1px; }\n .ag-theme-balham .ag-tab-selected {\n background-color: white;\n background-color: var(--ag-background-color, white);\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n border-bottom-color: transparent; }\n .ag-theme-balham .ag-tabs-header {\n border-bottom: 1px solid;\n border-bottom-color: #bdc3c7;\n border-bottom-color: var(--ag-border-color, #bdc3c7); }\n .ag-theme-balham .ag-column-drop-cell {\n height: 24px; }\n .ag-theme-balham .ag-column-drop-vertical-title {\n color: #000;\n color: var(--ag-foreground-color, #000); }\n .ag-theme-balham .ag-column-drop-vertical-cell {\n margin-left: 8px;\n margin-right: 8px; }\n .ag-theme-balham .ag-column-drop-vertical-cell-text {\n margin-left: 8px; }\n .ag-theme-balham .ag-column-drop-vertical-icon {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-balham .ag-ltr .ag-column-drop-vertical-empty-message {\n padding-left: 24px;\n padding-right: 4px; }\n .ag-theme-balham .ag-rtl .ag-column-drop-vertical-empty-message {\n padding-right: 24px;\n padding-left: 4px; }\n .ag-theme-balham .ag-column-drop-horizontal {\n height: 32px; }\n .ag-theme-balham .ag-column-drop-empty {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-balham .ag-column-drop-horizontal-cell-text {\n margin-left: 8px; }\n .ag-theme-balham .ag-column-drop-vertical {\n padding-top: 8px; }\n .ag-theme-balham .ag-menu-header {\n background-color: #f5f7f7;\n background-color: var(--ag-header-background-color, #f5f7f7); }\n .ag-theme-balham .ag-overlay-loading-center {\n background-color: white;\n background-color: var(--ag-background-color, white);\n border: 1px solid;\n border-color: #bdc3c7;\n border-color: var(--ag-border-color, #bdc3c7);\n color: #000;\n color: var(--ag-foreground-color, #000);\n padding: 16px; }\n .ag-theme-balham .ag-tooltip {\n border: none;\n background-color: #cbd0d3; }\n .ag-theme-balham .ag-panel-title-bar-button-icon {\n font-size: 20px; }\n .ag-theme-balham .ag-chart-data-section,\n .ag-theme-balham .ag-chart-format-section {\n padding-bottom: 2px; }\n .ag-theme-balham .ag-group-toolbar {\n background-color: rgba(226, 233, 235, 0.5);\n background-color: var(--ag-subheader-toolbar-background-color, rgba(226, 233, 235, 0.5)); }\n .ag-theme-balham .ag-chart-tab {\n padding-top: 2px; }\n .ag-theme-balham .ag-charts-format-sub-level-group-item {\n margin-bottom: 6px; }\n\n", ""]);
  46292. // Exports
  46293. module.exports = exports;
  46294. /***/ }),
  46295. /* 236 */
  46296. /***/ (function(module, exports, __webpack_require__) {
  46297. var api = __webpack_require__(225);
  46298. var content = __webpack_require__(237);
  46299. content = content.__esModule ? content.default : content;
  46300. if (typeof content === 'string') {
  46301. content = [[module.i, content, '']];
  46302. }
  46303. var options = {};
  46304. options.insert = "head";
  46305. options.singleton = false;
  46306. var update = api(content, options);
  46307. module.exports = content.locals || {};
  46308. /***/ }),
  46309. /* 237 */
  46310. /***/ (function(module, exports, __webpack_require__) {
  46311. // Imports
  46312. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227);
  46313. exports = ___CSS_LOADER_API_IMPORT___(false);
  46314. // Module
  46315. exports.push([module.i, ".ag-theme-blue {\n -webkit-font-smoothing: antialiased;\n color: #222;\n color: var(--ag-foreground-color, #222);\n font-family: \"Helvetica Neue\", sans-serif;\n font-size: 14px;\n line-height: normal; }\n\n@font-face {\n font-family: \"agGridClassic\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABOsAAsAAAAAJiwAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlIAAAReYchjok9TLzIAAANcAAAAQQAAAFZWVlJ+Y21hcAAAA6AAAAHtAAAFgHClDfdnbHlmAAAFkAAACi0AABQQq+8lqmhlYWQAAA/AAAAANAAAADZ2z8SBaGhlYQAAD/QAAAAeAAAAJAfTBChobXR4AAAQFAAAABoAAAEou4L/4mxvY2EAABAwAAAAbwAAAJb7HvWgbWF4cAAAEKAAAAAfAAAAIAFgAHhuYW1lAAAQwAAAATMAAAJS8kTiWnBvc3QAABH0AAABtgAAApcplp2DeJx9k0lyE0EQRX+rZSMPyGDMZMRkRpsh3O5BjSTLltzyQHjBggULNmYBAeFg5ROw5gAEB+AUnIBgyYoDcACCA/Ay1UbGC6tC1VWZP3/+yspSIGlSy+qqUmzuPld9f+/gveZV1fBn/qPrYP/tmz3VDnf4qv6tKQj/qK4FvdCBvgUKXgefK+NhJeyGu+GH8FP4QyGoG3oMekorjFgJc6RUmZrKVdE4tpj1E7VAh8xtt87qgsbcU2ig8+SMiRk445Ke6o7OwNN3np7WQKUM4+wxbzHuauYERK578GeoWcVqrA10ntWENtHYQ0eH6BbeGXzrZI6I6eProy10VNXruK2XRM762SwyK3Ep/1gbvo9894AqHKLa8DfhN75Fsh7am2RKiHgEewaqW9Zwif8U3hRMRGzHa2bR10AmKEx1nZWdLOFk07oN+zO98qwbZUzPqzg88yLqR/a+8+XkOWrtwLUF9iEaRla7kfvkirSDf5KbKvROH/VFX/VdP/VLv3UK6ypeO8Ea3OsnVqZG/Y6jC7ztf1Y76Th3fhz1P2KCcze9NjG+QVlByzaFTqtNyjrCmjp+Ep2GL1CTU68qOSLPm2AdY6yyj0GfLruxxZj2Og/oAeuAeWqxwmxMw37L2V+GyVZDXRe9Wi14LvltWU3tJdV9Zz1vtzxPna/wjThZ5vXZxnsVizGNLA2PylFtHMv4c9SOspmqBqoSeqDmnbXjr6Ag003OMVSS6Ja/gB3vqgUUZOWLnNM5V98pb2rOcbFHBWiOypeces2sk/tos67Y+gsvGGrHAAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMnxi4gDQjSA4A1QYKdAAAAHictdQHTltBFIXh3wXTTEnvvRc6hGp6XQbpiBREOsoqs5O7gZBzPScLIFJG+nw9o+c3b/R8LtAB1OSp1KFap0KO31qttNdr9LTX6/zSvEkXVX0fYo8DjmL0+FirQ+yyz2FU2rO/o6Krm1zlPs80W2GMJeZZZZItxmlpdZEF1phhmg0mmGOKdXaYZZlNtvX7qnav6xkbdGrfbj1Jr+7YRz8DDHKaM5zlHOe5wEUucZkr2u0a17nBTW5xmzvc5Z72f8BDHvGYJzrPkD6HNRvRAzY42Vg54fU5xpbmVye3xls67cLazLQOOje1vjO7vLn9Dzf7D6OZH7Wfnu2Qb7PI0+7amDy3JXlh8/LSVuWVTcpr25I3Ni5vrSV7lv+QfVuUd7Yg721NPtiMfLRpObANObQJ+WRz8tmm5Iuty1fLs3+zWfluy/LDNuXI9AKjUmRWolqQtVZktqJeZL6io8jcRaMga2dB1q6CrN0FWXuKzGP0FmRtFvkmo68ga39B1oGCrIMFWU8VyhJhShVhyhdhShphyhxhSh9hyiFhSiRhyiZhSilhyithSi5hyjBhSjNhyjVhSjhhyjphSj1hyj9h6gSEqScQpu5AmPoEYeoRhKl3EKb+QVj2zbDMTFj7muGCrCNF+56jBSN/AHzNoH4AAAB4nO1Ye2xT1xm/37nEN87D8bUdXwezwLWJDZQCtmNfO4FATIgdQhLWGwhrt0DSGJHHpgaawFRatBIVVrXbHxXTWCiPabMHo9MgSH1IGxJMa6b+sbBJFZVK2/HHVNjI6JZ2k8W97DvHjzyggPrntBufe17fPec73/md3/edcMDhw4f4fs7IcSBLglwuW3mZD+mj+/ZBQtv//vtkhPxuYiIFe2EvijD5T/lPuUVYCQpeRRK8oswyRRZZJokyywQZLrXFxscbNwPf1oh5m65txjzWpuu0PdYGhF9k/LIuWm/czOXm3Mq/whViRfAaMYlu+NkbCeiG7sTZU2TPGz3QrR/vOavdzMmTSTLJFTN51AW1QX3IZOOFsdiFC7GxC41jUJ8rjTVe4Ao47q6O67rBWTk35+Ue41ZyXIHsWgFBsboOArK/EspFmwl42WXAgh1bQtjlgYDorgqUu3nM+T7N5qpx4Y/83VUjyzWyZjY7HGZyW5Qk7ReqCi2qmmpvJ66Ii3yGL/xpZfjifySJmig6HCL5hyjpY/q1ZBJO6jtw2Vm9bjK9luJ6coq4p5UrmKOTALheK9/HdHDldbo1Q5teffLf1aev8zdyKuRU2jJTk3f0ot/XH4YTc/XwPpoevByUH6jFX/Tz0PoQHfTSJN3OWfM/2uwPmvkhk9L14qL38T2IjELOwXEIOskIvLIQDAL+ldvsOEu11+Mlf9O31zyta1A3Pv7ur4uLK8rsvg0+e1kFXIJTtdihX4Y14+N1paWVTk+Fy+dzVVQtqKTDG9gcR/gjOJuAWC3DtUkcV1WOZsPEz8nhlH6ej+rnk7OydAofaEniA620zGV1v5HF8spHsxYghsvdQXcwEAzw/RmLadaMBcmkZmaWoZbT30uxJ2NBS9aCk1kLWlFCJLdw2y5QlVJMFfaK8lG2ShH1CYhy0I0sIYsyH5TFQJCMJvWSJEyp+hi0pPQxlYyyehrrp7AxzeV54Hn+eXqujYDbIRgB2UCBKbAM65PspU8OgwVfpG9WFSxYncElhxmXiAFkLDrAz0+eTejH9eMJ+C4xaVNYOQFdCe6r4p7u2oPQ9wO95GGoH0smp233Lq9wFZyPW43zK1IoYJfskgkBicwGobUQdLsQk17rCuI1CJUg2RXJgMikfyEUUFgJ5UGu9qyNHnpucNvSb9cF6xeZ9D+taPYW1T0WfvzAX0PfXF3UUO17pVX9uv9bT3ZtrYus9D85BFc3N5os9kq5uHY5b1qyyjLvieaDa3Z5GgJLiuFAEQG1wGBy6tcM4W1Bf7zhabujeN2CImN1VZ1/40ub9KO+TqskLZwfaHf+b65FQjwv4UK4FroORg1ZXUNYpm12Jac0QcB4qzxrwE3lJBRR4A5dQdvw/hd/uJ8q+Y0933umoXpdZ/euZ3Zs3ciULWnctbc3VgQboagtFAtVLQl5VvPlvNr84nBLW0nJRs8af/NI85Yz/vg2JWwwKP4eq2RfVBF+qjrUWcOXLlgGhcXzm22FAuEyPMo4px95DT2+VQbRG/SVB4Iq45Qk34/eZ3sq3d6elSV30I/yLDoQ3SI6Fq8gwVqVmC9fDqfTZFIvgSm94dIlrFDxkuxZvziL05zcwmmvqiDT5BI8pCwjH6WSyTT7ISN8WQlOJpMTSUaCJ+/NUKWC7Lovcl/jZK4KPenjlIcYsSLvZSk2n0R3UAZ3Ofr0TKrCBKeQYdFGyLY0p0zF8h3t0JqdjqnD96tovqSaxiytklhas6hwqh15TFXn2rTKLQaARicCuaOq2m1m1PQMi2b46iS/lfGVhIRHQzTYebpHPw7dPWdIDZw8nYmDzlCyJXe/uPsF/y/+n1w1159BpaGMuiwvYs+j4AEL+RkqsdUElQQb6sCDnUGfhxaxC6segXVTOSlgpx95q70+KsbkK0muuxL82KmEvB7yQsRmWxIeibQ2b2rZbcMnEi+qsAARyTxDhdNmCTY1OQ8usFidRgepWFpoL7JbwBpp2dTcGhkJL0FxSzkU2QuXOUhpsdFptToPOpuaghabs8IwjzcTsFQUxSN0XJyptfkozkQru9kAcaPZFPQXWgzznfGmkM3qHHHG406jaHY5lhYSg5nOxFQaCR9FcUuZQAqXOlxmo1BEBUecVluoKe6cb7AU+oMmszHOVjHzvBxBFC9kjCUgLJGs0FciYyE8cfPQYwaUoNctlJPY0eGjV6/iK5kv/Pjl7u6Xu8lvZjXSgvZWN+3i5s2KPZchNz5a5CmwoBYU5E5JeXDseevjmG80fAyuxT7xvR5+/SEBqFYX+2jVMRR//pOYD/O8H5qOVViUAtnEH7nzWz6aSelMNEJjEfrJV12bwsJ2XCIlnAev7bmPYquOKaNQHfuYKv2wtaWza3sNTXJMOZa/L7yKZ7KA7jA9jfAUO4ngzxFb5hw6+T9zpdN3EBY7SDDamwAveBO9vQn9A/2DRC8514ctWOrTX+rDNuzry8YSd1ksYeMWcwEaS9ATZqZOYxF1EWb0CKECemYDflqk8eVKehyZTzSU0+MIU4efHYxu2BAdfFb/bGgw2tAQHRyCCe3NUH00Nti1XYlI0rJ4qH49VjrDEcAafxOlh/TbQ7up9O4hMON3Gz7X3lwmSRGls3swFl0XaspUugbj0fpQDvdR9BMCcjiL2DBMC0iUKTFyo6y2M51Mqfp5FaZ4h5Ygo2qK8l/eVjTewxq4RckteN0KpVQy2Xkurarpc50wha5jvDed7oWwmuHnPE5k9Khhbu39kUIDBAaVWvRHwQKMIBExfOYeyg4mPaFWSuL0BjAHN9p3DlDcHEjx67R3SKUo/adk9eBgbcnFklqaDUxo10mjdA+CyO1kBkIkhiT9tkOE1ZkPMt+VkljyBbwzzMYR85Tk1Tk4IjMwQG9zbGPNFAaL6I6bKQwEBgsb7XHRejXtgalD+d0uyyHgMNvwiLK96zpuNj6dXfff7C10a693d1Lhzm4UViKz8biUxTD3w6PEVGQ+g4GS3nk8VtwJ3BvcGdyX+0LyUAZ+VKXrOSW/v37P4T3r2euR1dR3NGQ/Wb8nj60TWX/oVfACoMhBcvCXCejSTyROa38gsTOZUP50Ks/fA4jjUs5OYxh07XmeKcj+uyKAAH5L9blI3OXTxwZqJiZqBtrRCX8Ii/UP6Y0NFi8YqJ2YqB2A16bxTUbp6BhBpchP9DG8sJzPc8koYp/QO4pIYwS8nrRoO+f2kUz4wNdjwDU2Z0wj0CCjJSOR7UvyMYorI0HG4ZPaFf294YvwNrmiXYHgEJam9YrTnaVHABXTdiI4aXM+LnBzMa4D+dtumxsXLATalo0KQn6Jt/vz3t5gw96sr6dfCKxNAooH8LgyFbufPCEIHTNCgA7BKrQaDNvQn1MH2yHYBBemDuqm0cVvMxhaUaJjhivvEATiWG4y3fmpyWPCnO80ef54r0zL7FHgV7MnablXjTufL8cRcTgc1VuKw//fJvfa5L+BscYKAAAAeJxjYGRgYABi/jvPp8Xz23xl4GZ+ARSI4ny8rwFG///2/xvzZ+ZPQJUcDExAkgEAoUMP6XicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AIAnloHAgAAeJxjYGBgYH5Ba/z/G+3M/f+NgQ4AAPv8MfAAAHicY2AAAgmGIIYshhaGC4wijCGMPYz7GF8xGTGFMVUwTWC6wGzGPIf5BwsfiwZLCcsOlgssL1gnsB5iE2EzYGtim8K2jZ2HXYvdhX0Z+w72fxwRHAUcszhWcGzjOMJxieMZxxfOOi4O0iEAtgsblgB4nGNgZGBg8GLIYeBhAAEmIOYCQgaG/2A+AwAbuAHZAHicfZC9TsMwFIVP+odoBaoEYmAyCwtS+rPRtVKzd+ieJnaaKo2D41bqznPwBDxHn4OnYObEeCkStSXnu9899w4BMMQJAZoT4Ma9zWnhitUvt0n3njvkJ89dDBB67tG/eu7jBQvPA9zhjRuCzjXNI949t3CLD89t+k/PHfLJcxcP+PLco//23McqGHoe4DlQcRaZPJ0XcV3nyVJm+yI2Z+6sWElT57oUk3B85iNZShNbmYr1UdSHbGqtEsronVjo0sqi0KIyeisTG26srWajkfI+TPQOMTJEMMiRYo6Cdc2bI8ESkr29c+ZC7v/OihuMY40SAhP+9/GFfMR86WZiWH5Tzqxx5FvjwKkprYVirZjR2JEWbneTLng1TeV6W5qEPsTGTVWYYcSr/uRDprjpB8WrbRMAeJxtkmdv2zAURX1iyVbstEnTNt17D7VN994z/RUMRctEJFIgKY/8+rJxGiBA36dzHx7uu3xgZ6mzqEHn/7XFEl0SUnr0yVhmwJAVjnCUVdY4xjrHOcFJNjjFac5wlnOc5wIXucRlrnCVa1znBje5xW3ucJd73CfnAQ95xCaPecJTnvGcF7zkFa95w1ve8Z4PfOQTn/nCV77xnR/85Bdb/O4MRVk6VYqgrekJ5+zUd4WXPSmMVFUqx8KFNTlWcmfbzvI9UMXGQUObQgXlam1EUOsH7dbsT65IW1mXNzoK14+irY0fSGuCEzKoIpG2mafSWe+TQnmZqVkjomexrOYq95Xw4+EB5ZvdyL2RruLKdKSdD0npdJOWzrZNEkdCUqlR6FXaxN39yopCmzKrxUzXelcltTJtFrMulFGzkBhr1NDYkIuqslNVpE10Ud1Gm7TRExuyxqmJtq1fc9HM5tttCNbkdjRaPdwwqdPlOCReTNTA19EuL+zU7OPfWMMF7o1lC46pQzzNenBKHb5l1prFKwb/IN9EUOJQBDQWwxSPpGLMDtvM4lcoqGlpmDNil0mn8wcxorJdAAA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n .ag-theme-blue .ag-icon {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n .ag-theme-blue .ag-icon-aggregation:before {\n content: \"\\f101\"; }\n .ag-theme-blue .ag-icon-arrows:before {\n content: \"\\f102\"; }\n .ag-theme-blue .ag-icon-asc:before {\n content: \"\\f103\"; }\n .ag-theme-blue .ag-icon-cancel:before {\n content: \"\\f104\"; }\n .ag-theme-blue .ag-icon-chart:before {\n content: \"\\f105\"; }\n .ag-theme-blue .ag-icon-color-picker:before {\n content: \"\\f109\"; }\n .ag-theme-blue .ag-icon-columns:before {\n content: \"\\f10a\"; }\n .ag-theme-blue .ag-icon-contracted:before {\n content: \"\\f10b\"; }\n .ag-theme-blue .ag-icon-copy:before {\n content: \"\\f10c\"; }\n .ag-theme-blue .ag-icon-cross:before {\n content: \"\\f10d\"; }\n .ag-theme-blue .ag-icon-desc:before {\n content: \"\\f10e\"; }\n .ag-theme-blue .ag-icon-expanded:before {\n content: \"\\f10f\"; }\n .ag-theme-blue .ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n .ag-theme-blue .ag-icon-eye:before {\n content: \"\\f111\"; }\n .ag-theme-blue .ag-icon-filter:before {\n content: \"\\f112\"; }\n .ag-theme-blue .ag-icon-first:before {\n content: \"\\f113\"; }\n .ag-theme-blue .ag-icon-grip:before {\n content: \"\\f114\"; }\n .ag-theme-blue .ag-icon-group:before {\n content: \"\\f115\"; }\n .ag-theme-blue .ag-icon-last:before {\n content: \"\\f116\"; }\n .ag-theme-blue .ag-icon-left:before {\n content: \"\\f117\"; }\n .ag-theme-blue .ag-icon-linked:before {\n content: \"\\f118\"; }\n .ag-theme-blue .ag-icon-loading:before {\n content: \"\\f119\"; }\n .ag-theme-blue .ag-icon-maximize:before {\n content: \"\\f11a\"; }\n .ag-theme-blue .ag-icon-menu:before {\n content: \"\\f11b\"; }\n .ag-theme-blue .ag-icon-minimize:before {\n content: \"\\f11c\"; }\n .ag-theme-blue .ag-icon-next:before {\n content: \"\\f11d\"; }\n .ag-theme-blue .ag-icon-none:before {\n content: \"\\f11e\"; }\n .ag-theme-blue .ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n .ag-theme-blue .ag-icon-paste:before {\n content: \"\\f120\"; }\n .ag-theme-blue .ag-icon-pin:before {\n content: \"\\f121\"; }\n .ag-theme-blue .ag-icon-pivot:before {\n content: \"\\f122\"; }\n .ag-theme-blue .ag-icon-previous:before {\n content: \"\\f123\"; }\n .ag-theme-blue .ag-icon-right:before {\n content: \"\\f126\"; }\n .ag-theme-blue .ag-icon-save:before {\n content: \"\\f127\"; }\n .ag-theme-blue .ag-icon-small-down:before {\n content: \"\\f128\"; }\n .ag-theme-blue .ag-icon-small-left:before {\n content: \"\\f129\"; }\n .ag-theme-blue .ag-icon-small-right:before {\n content: \"\\f12a\"; }\n .ag-theme-blue .ag-icon-small-up:before {\n content: \"\\f12b\"; }\n .ag-theme-blue .ag-icon-tick:before {\n content: \"\\f12c\"; }\n .ag-theme-blue .ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n .ag-theme-blue .ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n .ag-theme-blue .ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n .ag-theme-blue .ag-icon-unlinked:before {\n content: \"\\f130\"; }\n .ag-theme-blue .ag-icon-row-drag:before {\n content: \"\\f114\"; }\n .ag-theme-blue .ag-right-arrow:before {\n content: \"\\f117\"; }\n .ag-theme-blue .ag-right-arrow:before {\n content: \"\\f126\"; }\n .ag-theme-blue .ag-root-wrapper {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-blue [class^='ag-'], .ag-theme-blue [class^='ag-']:focus, .ag-theme-blue [class^='ag-']:after, .ag-theme-blue [class^='ag-']:before {\n box-sizing: border-box;\n outline: none; }\n .ag-theme-blue [class^='ag-']::-ms-clear {\n display: none; }\n .ag-theme-blue .ag-checkbox .ag-input-wrapper,\n .ag-theme-blue .ag-radio-button .ag-input-wrapper {\n overflow: visible; }\n .ag-theme-blue .ag-range-field .ag-input-wrapper {\n height: 100%; }\n .ag-theme-blue .ag-toggle-button {\n flex: none;\n width: unset;\n min-width: unset; }\n .ag-theme-blue .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 4px; }\n .ag-theme-blue .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 4px; }\n .ag-theme-blue input[class^='ag-'] {\n margin: 0;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-blue textarea[class^='ag-'],\n .ag-theme-blue select[class^='ag-'] {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-blue input[class^='ag-']:not([type]),\n .ag-theme-blue input[class^='ag-'][type='text'],\n .ag-theme-blue input[class^='ag-'][type='number'],\n .ag-theme-blue input[class^='ag-'][type='tel'],\n .ag-theme-blue input[class^='ag-'][type='date'],\n .ag-theme-blue input[class^='ag-'][type='datetime-local'],\n .ag-theme-blue textarea[class^='ag-'] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #000;\n border-color: var(--ag-input-border-color, #000); }\n .ag-theme-blue input[class^='ag-']:not([type]):disabled,\n .ag-theme-blue input[class^='ag-'][type='text']:disabled,\n .ag-theme-blue input[class^='ag-'][type='number']:disabled,\n .ag-theme-blue input[class^='ag-'][type='tel']:disabled,\n .ag-theme-blue input[class^='ag-'][type='date']:disabled,\n .ag-theme-blue input[class^='ag-'][type='datetime-local']:disabled,\n .ag-theme-blue textarea[class^='ag-']:disabled {\n color: rgba(34, 34, 34, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(34, 34, 34, 0.5));\n background-color: #dedede;\n background-color: var(--ag-input-disabled-background-color, #dedede);\n border-color: rgba(0, 0, 0, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(0, 0, 0, 0.3)); }\n .ag-theme-blue input[class^='ag-']:not([type]):focus,\n .ag-theme-blue input[class^='ag-'][type='text']:focus,\n .ag-theme-blue input[class^='ag-'][type='number']:focus,\n .ag-theme-blue input[class^='ag-'][type='tel']:focus,\n .ag-theme-blue input[class^='ag-'][type='date']:focus,\n .ag-theme-blue input[class^='ag-'][type='datetime-local']:focus,\n .ag-theme-blue textarea[class^='ag-']:focus {\n outline: none;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue input[class^='ag-'][type='number'] {\n -moz-appearance: textfield; }\n .ag-theme-blue input[class^='ag-'][type='number']::-webkit-outer-spin-button, .ag-theme-blue input[class^='ag-'][type='number']::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0; }\n .ag-theme-blue input[class^='ag-'][type='range'] {\n padding: 0; }\n .ag-theme-blue .ag-drag-handle {\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-list-item, .ag-theme-blue .ag-virtual-list-item {\n height: 20px; }\n .ag-theme-blue .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-virtual-list-item:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-select-list {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n overflow-y: auto;\n overflow-x: hidden; }\n .ag-theme-blue .ag-list-item {\n display: flex;\n align-items: center; }\n .ag-theme-blue .ag-list-item.ag-active-item {\n background-color: #f0f0f0;\n background-color: var(--ag-row-hover-color, #f0f0f0); }\n .ag-theme-blue .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n .ag-theme-blue .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden; }\n .ag-theme-blue .ag-select .ag-picker-field-wrapper {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n min-height: 20px;\n cursor: default; }\n .ag-theme-blue .ag-select:not(.ag-cell-editor) {\n height: 20px; }\n .ag-theme-blue .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis; }\n .ag-theme-blue .ag-select .ag-picker-field-icon {\n display: flex;\n align-items: center; }\n .ag-theme-blue .ag-select.ag-disabled {\n opacity: 0.5; }\n .ag-theme-blue .ag-rich-select {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-blue .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 162.5px; }\n .ag-theme-blue .ag-rich-select-value {\n padding: 0 4px 0 12px;\n height: 25px;\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6)); }\n .ag-theme-blue .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 20px; }\n .ag-theme-blue .ag-rich-select-virtual-list-item:hover {\n background-color: #f0f0f0;\n background-color: var(--ag-row-hover-color, #f0f0f0); }\n .ag-theme-blue .ag-rich-select-row {\n padding-left: 12px; }\n .ag-theme-blue .ag-rich-select-row-selected {\n background-color: #c8c8c8;\n background-color: var(--ag-selected-row-background-color, #c8c8c8); }\n .ag-theme-blue .ag-row-drag,\n .ag-theme-blue .ag-selection-checkbox,\n .ag-theme-blue .ag-group-expanded,\n .ag-theme-blue .ag-group-contracted {\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-ltr .ag-row-drag, .ag-theme-blue .ag-ltr .ag-selection-checkbox, .ag-theme-blue .ag-ltr .ag-group-expanded, .ag-theme-blue .ag-ltr .ag-group-contracted {\n margin-right: 12px; }\n .ag-theme-blue .ag-rtl .ag-row-drag, .ag-theme-blue .ag-rtl .ag-selection-checkbox, .ag-theme-blue .ag-rtl .ag-group-expanded, .ag-theme-blue .ag-rtl .ag-group-contracted {\n margin-left: 12px; }\n .ag-theme-blue .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: 23px;\n display: flex;\n align-items: center;\n flex: none; }\n .ag-theme-blue .ag-group-expanded,\n .ag-theme-blue .ag-group-contracted {\n cursor: pointer; }\n .ag-theme-blue .ag-group-title-bar-icon {\n cursor: pointer;\n flex: none;\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-ltr .ag-group-child-count {\n margin-left: 2px; }\n .ag-theme-blue .ag-rtl .ag-group-child-count {\n margin-right: 2px; }\n .ag-theme-blue .ag-group-title-bar {\n background-color: #ececec;\n background-color: var(--ag-subheader-background-color, #ececec);\n padding: 4px; }\n .ag-theme-blue .ag-group-toolbar {\n padding: 4px; }\n .ag-theme-blue .ag-disabled-group-title-bar, .ag-theme-blue .ag-disabled-group-container {\n opacity: 0.5; }\n .ag-theme-blue .group-item {\n margin: 2px 0; }\n .ag-theme-blue .ag-label {\n white-space: nowrap; }\n .ag-theme-blue .ag-ltr .ag-label {\n margin-right: 4px; }\n .ag-theme-blue .ag-rtl .ag-label {\n margin-left: 4px; }\n .ag-theme-blue .ag-label-align-top .ag-label {\n margin-bottom: 2px; }\n .ag-theme-blue .ag-ltr .ag-slider-field, .ag-theme-blue .ag-ltr .ag-angle-select-field {\n margin-right: 8px; }\n .ag-theme-blue .ag-rtl .ag-slider-field, .ag-theme-blue .ag-rtl .ag-angle-select-field {\n margin-left: 8px; }\n .ag-theme-blue .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-blue .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #222;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n border-radius: 5px; }\n .ag-theme-blue .ag-picker-field-button {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-dialog.ag-color-dialog {\n border-radius: 5px; }\n .ag-theme-blue .ag-color-picker .ag-picker-field-display {\n height: 12px; }\n .ag-theme-blue .ag-color-panel {\n padding: 4px; }\n .ag-theme-blue .ag-spectrum-color {\n background-color: red;\n border-radius: 2px; }\n .ag-theme-blue .ag-spectrum-tools {\n padding: 10px; }\n .ag-theme-blue .ag-spectrum-sat {\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0)); }\n .ag-theme-blue .ag-spectrum-val {\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0)); }\n .ag-theme-blue .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24); }\n .ag-theme-blue .ag-spectrum-hue-background {\n border-radius: 2px; }\n .ag-theme-blue .ag-spectrum-alpha-background {\n border-radius: 2px; }\n .ag-theme-blue .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px; }\n .ag-theme-blue .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37); }\n .ag-theme-blue .ag-recent-color {\n margin: 0 3px; }\n .ag-theme-blue .ag-recent-color:first-child {\n margin-left: 0; }\n .ag-theme-blue .ag-recent-color:last-child {\n margin-right: 0; }\n .ag-theme-blue.ag-dnd-ghost {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n overflow: hidden;\n text-overflow: ellipsis;\n z-index: 10;\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6));\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n height: 25px !important;\n line-height: 25px;\n margin: 0;\n padding: 0 8px;\n -webkit-transform: translateY(8px);\n transform: translateY(8px); }\n .ag-theme-blue .ag-dnd-ghost-icon {\n margin-right: 4px;\n color: #222;\n color: var(--ag-foreground-color, #222); }\n .ag-theme-blue .ag-popup-child:not(.ag-tooltip-custom) {\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3); }\n .ag-dragging-range-handle .ag-theme-blue .ag-dialog,\n .ag-dragging-fill-handle .ag-theme-blue .ag-dialog {\n opacity: 0.7;\n pointer-events: none; }\n .ag-theme-blue .ag-dialog {\n border-radius: 0px;\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-panel {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-blue .ag-panel-title-bar {\n background-color: #5e9cd3;\n background-color: var(--ag-header-background-color, #5e9cd3);\n color: #fff;\n color: var(--ag-header-foreground-color, #fff);\n height: 25px;\n padding: 4px 12px;\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-ltr .ag-panel-title-bar-button {\n margin-left: 4px; }\n .ag-theme-blue .ag-rtl .ag-panel-title-bar-button {\n margin-right: 4px; }\n .ag-theme-blue .ag-tooltip {\n background-color: #5e9cd3;\n background-color: var(--ag-header-background-color, #5e9cd3);\n color: #222;\n color: var(--ag-foreground-color, #222);\n padding: 4px;\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n border-radius: 0px;\n transition: opacity 1s; }\n .ag-theme-blue .ag-tooltip.ag-tooltip-hiding {\n opacity: 0; }\n .ag-theme-blue .ag-ltr .ag-column-select-indent-1 {\n padding-left: 16px; }\n .ag-theme-blue .ag-rtl .ag-column-select-indent-1 {\n padding-right: 16px; }\n .ag-theme-blue .ag-ltr .ag-column-select-indent-2 {\n padding-left: 32px; }\n .ag-theme-blue .ag-rtl .ag-column-select-indent-2 {\n padding-right: 32px; }\n .ag-theme-blue .ag-ltr .ag-column-select-indent-3 {\n padding-left: 48px; }\n .ag-theme-blue .ag-rtl .ag-column-select-indent-3 {\n padding-right: 48px; }\n .ag-theme-blue .ag-ltr .ag-column-select-indent-4 {\n padding-left: 64px; }\n .ag-theme-blue .ag-rtl .ag-column-select-indent-4 {\n padding-right: 64px; }\n .ag-theme-blue .ag-ltr .ag-column-select-indent-5 {\n padding-left: 80px; }\n .ag-theme-blue .ag-rtl .ag-column-select-indent-5 {\n padding-right: 80px; }\n .ag-theme-blue .ag-ltr .ag-column-select-indent-6 {\n padding-left: 96px; }\n .ag-theme-blue .ag-rtl .ag-column-select-indent-6 {\n padding-right: 96px; }\n .ag-theme-blue .ag-ltr .ag-column-select-indent-7 {\n padding-left: 112px; }\n .ag-theme-blue .ag-rtl .ag-column-select-indent-7 {\n padding-right: 112px; }\n .ag-theme-blue .ag-ltr .ag-column-select-indent-8 {\n padding-left: 128px; }\n .ag-theme-blue .ag-rtl .ag-column-select-indent-8 {\n padding-right: 128px; }\n .ag-theme-blue .ag-ltr .ag-column-select-indent-9 {\n padding-left: 144px; }\n .ag-theme-blue .ag-rtl .ag-column-select-indent-9 {\n padding-right: 144px; }\n .ag-theme-blue .ag-column-select-header-icon {\n cursor: pointer; }\n .ag-theme-blue .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-column-select-header-icon:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-blue .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 6px; }\n .ag-theme-blue .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-blue .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 6px; }\n .ag-theme-blue .ag-keyboard-focus .ag-column-select-column-group:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-column-select-column-group:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-keyboard-focus .ag-column-select-column:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-column-select-column:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-column-select-column-group:not(:last-child),\n .ag-theme-blue .ag-column-select-column:not(:last-child) {\n margin-bottom: 4px; }\n .ag-theme-blue .ag-column-select-column-readonly,\n .ag-theme-blue .ag-column-select-column-group-readonly {\n color: rgba(34, 34, 34, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(34, 34, 34, 0.5));\n pointer-events: none; }\n .ag-theme-blue .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 20px; }\n .ag-theme-blue .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 20px; }\n .ag-theme-blue .ag-column-select-list {\n padding: 6px 6px; }\n .ag-theme-blue .ag-rtl {\n text-align: right; }\n .ag-theme-blue .ag-root-wrapper {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n border-radius: 0px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 36px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 36px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-1 {\n padding-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-1 {\n padding-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 60px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 60px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-2 {\n padding-left: 48px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-2 {\n padding-right: 48px; }\n .ag-theme-blue .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 84px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 84px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-3 {\n padding-left: 72px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-3 {\n padding-right: 72px; }\n .ag-theme-blue .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 108px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 108px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-4 {\n padding-left: 96px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-4 {\n padding-right: 96px; }\n .ag-theme-blue .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 132px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 132px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-5 {\n padding-left: 120px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-5 {\n padding-right: 120px; }\n .ag-theme-blue .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 156px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 156px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-6 {\n padding-left: 144px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-6 {\n padding-right: 144px; }\n .ag-theme-blue .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 180px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 180px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-7 {\n padding-left: 168px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-7 {\n padding-right: 168px; }\n .ag-theme-blue .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 204px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 204px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-8 {\n padding-left: 192px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-8 {\n padding-right: 192px; }\n .ag-theme-blue .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 228px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 228px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-9 {\n padding-left: 216px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-9 {\n padding-right: 216px; }\n .ag-theme-blue .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 252px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 252px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-10 {\n padding-left: 240px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-10 {\n padding-right: 240px; }\n .ag-theme-blue .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 276px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 276px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-11 {\n padding-left: 264px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-11 {\n padding-right: 264px; }\n .ag-theme-blue .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 300px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 300px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-12 {\n padding-left: 288px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-12 {\n padding-right: 288px; }\n .ag-theme-blue .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 324px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 324px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-13 {\n padding-left: 312px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-13 {\n padding-right: 312px; }\n .ag-theme-blue .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 348px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 348px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-14 {\n padding-left: 336px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-14 {\n padding-right: 336px; }\n .ag-theme-blue .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 372px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 372px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-15 {\n padding-left: 360px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-15 {\n padding-right: 360px; }\n .ag-theme-blue .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 396px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 396px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-16 {\n padding-left: 384px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-16 {\n padding-right: 384px; }\n .ag-theme-blue .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 420px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 420px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-17 {\n padding-left: 408px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-17 {\n padding-right: 408px; }\n .ag-theme-blue .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 444px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 444px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-18 {\n padding-left: 432px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-18 {\n padding-right: 432px; }\n .ag-theme-blue .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 468px; }\n .ag-theme-blue .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 468px; }\n .ag-theme-blue .ag-ltr .ag-row-group-indent-19 {\n padding-left: 456px; }\n .ag-theme-blue .ag-rtl .ag-row-group-indent-19 {\n padding-right: 456px; }\n .ag-theme-blue .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-blue .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-blue .ag-cell {\n -webkit-font-smoothing: subpixel-antialiased; }\n .ag-theme-blue .ag-value-change-delta {\n padding-right: 2px; }\n .ag-theme-blue .ag-value-change-delta-up {\n color: darkgreen;\n color: var(--ag-value-change-delta-up-color, darkgreen); }\n .ag-theme-blue .ag-value-change-delta-down {\n color: darkred;\n color: var(--ag-value-change-delta-down-color, darkred); }\n .ag-theme-blue .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n transition: background-color 1s; }\n .ag-theme-blue .ag-value-change-value-highlight {\n background-color: #cec;\n background-color: var(--ag-value-change-value-highlight-background-color, #cec);\n transition: background-color 0.1s; }\n .ag-theme-blue .ag-cell-data-changed {\n background-color: #cec !important;\n background-color: var(--ag-value-change-value-highlight-background-color, #cec) !important; }\n .ag-theme-blue .ag-cell-data-changed-animation {\n background-color: transparent; }\n .ag-theme-blue .ag-cell-highlight {\n background-color: rgba(136, 255, 136, 0.4) !important;\n background-color: var(--ag-range-selection-highlight-color, rgba(136, 255, 136, 0.4)) !important; }\n .ag-theme-blue .ag-row {\n height: 25px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n color: #222;\n color: var(--ag-data-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-row-highlight-above::after, .ag-theme-blue .ag-row-highlight-below::after {\n content: '';\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #222;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222));\n left: 1px; }\n .ag-theme-blue .ag-row-highlight-above::after {\n top: -1px; }\n .ag-theme-blue .ag-row-highlight-above.ag-row-first::after {\n top: 0; }\n .ag-theme-blue .ag-row-highlight-below::after {\n bottom: 0px; }\n .ag-theme-blue .ag-row-odd {\n background-color: #deebf7;\n background-color: var(--ag-odd-row-background-color, #deebf7); }\n .ag-theme-blue .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-row-hover {\n background-color: #f0f0f0;\n background-color: var(--ag-row-hover-color, #f0f0f0); }\n .ag-theme-blue .ag-ltr .ag-right-aligned-cell {\n text-align: right; }\n .ag-theme-blue .ag-rtl .ag-right-aligned-cell {\n text-align: left; }\n .ag-theme-blue .ag-ltr .ag-right-aligned-cell .ag-cell-value {\n margin-left: auto; }\n .ag-theme-blue .ag-rtl .ag-right-aligned-cell .ag-cell-value {\n margin-right: auto; }\n .ag-theme-blue .ag-cell {\n border: 1px solid transparent;\n line-height: 23px;\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-blue .ag-row > .ag-cell-wrapper {\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-blue .ag-row-dragging {\n cursor: move; }\n .ag-theme-blue .ag-row-dragging {\n opacity: 0.5; }\n .ag-theme-blue .ag-cell-inline-editing {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n height: 25px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-blue .ag-popup-editor {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n padding: 0; }\n .ag-theme-blue .ag-large-text-input {\n height: auto;\n padding: 12px; }\n .ag-theme-blue .ag-details-row {\n padding: 20px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-blue .ag-overlay-loading-wrapper {\n background-color: rgba(255, 255, 255, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(255, 255, 255, 0.66)); }\n .ag-theme-blue .ag-overlay-loading-center {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px; }\n .ag-theme-blue .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px; }\n .ag-theme-blue .ag-loading {\n padding-left: 12px;\n display: flex;\n height: 100%;\n align-items: center; }\n .ag-theme-blue .ag-loading-icon {\n padding-right: 12px; }\n .ag-theme-blue .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear; }\n\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n .ag-theme-blue .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-ltr .ag-cell {\n border-right: dotted #9bc2e6; }\n .ag-theme-blue .ag-rtl .ag-cell {\n border-left: dotted #9bc2e6; }\n .ag-theme-blue .ag-ltr .ag-cell {\n border-right-width: 1px; }\n .ag-theme-blue .ag-rtl .ag-cell {\n border-left-width: 1px; }\n .ag-theme-blue .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-row-selected {\n background-color: #c8c8c8;\n background-color: var(--ag-selected-row-background-color, #c8c8c8); }\n .ag-theme-blue .ag-cell-range-selected:not(.ag-cell-focus) {\n background-color: rgba(34, 34, 34, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(34, 34, 34, 0.2)); }\n .ag-theme-blue .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1);\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)); }\n .ag-theme-blue .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1);\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)); }\n .ag-theme-blue .ag-cell-range-selected-1:not(.ag-cell-focus) {\n background-color: rgba(34, 34, 34, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(34, 34, 34, 0.2))); }\n .ag-theme-blue .ag-cell-range-selected-2:not(.ag-cell-focus) {\n background-color: rgba(34, 34, 34, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(34, 34, 34, 0.36)); }\n .ag-theme-blue .ag-cell-range-selected-3:not(.ag-cell-focus) {\n background-color: rgba(34, 34, 34, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(34, 34, 34, 0.488)); }\n .ag-theme-blue .ag-cell-range-selected-4:not(.ag-cell-focus) {\n background-color: rgba(34, 34, 34, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(34, 34, 34, 0.5904)); }\n .ag-theme-blue .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #222;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #222;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #222;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #222;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-blue .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-blue .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-blue .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-blue .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-blue .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #222;\n border-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222));\n outline: initial; }\n .ag-theme-blue .ag-cell.ag-selection-fill-top,\n .ag-theme-blue .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #222;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-blue .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #222;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-blue .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #222;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-cell.ag-selection-fill-bottom,\n .ag-theme-blue .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #222;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-blue .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #222;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-blue .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #222;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-fill-handle, .ag-theme-blue .ag-range-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #222;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-ltr .ag-fill-handle, .ag-theme-blue .ag-ltr .ag-range-handle {\n right: -1px; }\n .ag-theme-blue .ag-rtl .ag-fill-handle, .ag-theme-blue .ag-rtl .ag-range-handle {\n left: -1px; }\n .ag-theme-blue .ag-fill-handle {\n cursor: cell; }\n .ag-theme-blue .ag-range-handle {\n cursor: nwse-resize; }\n .ag-theme-blue .ag-cell-inline-editing {\n border-color: var(--ag-input-focus-border-color) !important; }\n .ag-theme-blue .ag-menu {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n padding: 0; }\n .ag-theme-blue .ag-menu-list {\n cursor: default;\n width: 100%;\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-blue .ag-menu-option-part {\n padding-top: 6px;\n padding-bottom: 6px;\n line-height: 12px; }\n .ag-theme-blue .ag-menu-option-active {\n background-color: #f0f0f0;\n background-color: var(--ag-row-hover-color, #f0f0f0); }\n .ag-theme-blue .ag-menu-option-disabled {\n opacity: 0.5; }\n .ag-theme-blue .ag-menu-option-text {\n margin-left: 4px; }\n .ag-theme-blue .ag-menu-option-icon {\n padding-left: 8px;\n padding-right: 4px;\n min-width: 20px; }\n .ag-theme-blue .ag-menu-option-shortcut {\n padding-left: 8px; }\n .ag-theme-blue .ag-menu-separator {\n height: 8px; }\n .ag-theme-blue .ag-menu-separator-cell:after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-menu-option-popup-pointer {\n width: 20px;\n text-align: center; }\n .ag-theme-blue .ag-tabs-header {\n min-width: 220px;\n width: 100%;\n display: flex; }\n .ag-theme-blue .ag-tab {\n border-bottom: 0 solid transparent;\n display: flex;\n flex: none;\n align-items: center;\n justify-content: center;\n cursor: pointer; }\n .ag-theme-blue .ag-keyboard-focus .ag-tab:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-tab:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-tab-selected {\n border-bottom-color: #222;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #222))); }\n .ag-theme-blue .ag-menu-header {\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-filter-condition-operator {\n height: 17px; }\n .ag-theme-blue .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 8px; }\n .ag-theme-blue .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 8px; }\n .ag-theme-blue .ag-set-filter-select-all {\n padding-top: 6px; }\n .ag-theme-blue .ag-set-filter-list {\n height: 120px; }\n .ag-theme-blue .ag-set-filter-filter {\n margin-top: 6px;\n margin-left: 6px;\n margin-right: 6px; }\n .ag-theme-blue .ag-filter-to {\n margin-top: 4px; }\n .ag-theme-blue .ag-mini-filter {\n margin: 6px 6px;\n margin-bottom: 0; }\n .ag-theme-blue .ag-set-filter-item {\n margin: 0px 6px; }\n .ag-theme-blue .ag-ltr .ag-set-filter-item-value {\n margin-left: 6px; }\n .ag-theme-blue .ag-rtl .ag-set-filter-item-value {\n margin-right: 6px; }\n .ag-theme-blue .ag-filter-header-container {\n padding-bottom: 6px;\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6)); }\n .ag-theme-blue .ag-filter-apply-panel {\n padding: 6px 6px;\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6)); }\n .ag-theme-blue .ag-filter-apply-panel-button {\n line-height: 1.5; }\n .ag-theme-blue .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 8px; }\n .ag-theme-blue .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 8px; }\n .ag-theme-blue .ag-simple-filter-body-wrapper {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-blue .ag-simple-filter-body-wrapper > * {\n margin-bottom: 4px; }\n .ag-theme-blue .ag-filter-no-matches {\n margin: 6px 6px; }\n .ag-theme-blue .ag-side-bar {\n position: relative; }\n .ag-theme-blue .ag-tool-panel-wrapper {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-blue .ag-side-buttons {\n padding-top: 16px;\n width: 16px;\n position: relative;\n color: #222;\n color: var(--ag-foreground-color, #222);\n overflow: hidden; }\n .ag-theme-blue button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 8px 0 8px 0;\n width: calc(100% + 1px);\n margin: 0;\n min-height: 72px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none;\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6);\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue button.ag-side-button-button:focus {\n box-shadow: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-side-button-button:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-selected .ag-side-button-button {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6);\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-side-button-icon-wrapper {\n margin-bottom: 3px; }\n .ag-theme-blue .ag-ltr .ag-side-bar-left,\n .ag-theme-blue .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-blue .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-ltr .ag-side-bar-left .ag-side-button-button,\n .ag-theme-blue .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 0 solid transparent;\n margin-right: -1px;\n padding-right: 1px; }\n .ag-theme-blue .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-blue .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #222;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #222))); }\n .ag-theme-blue .ag-rtl .ag-side-bar-left,\n .ag-theme-blue .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-blue .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-rtl .ag-side-bar-left .ag-side-button-button,\n .ag-theme-blue .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 0 solid transparent;\n margin-left: -1px;\n padding-left: 1px; }\n .ag-theme-blue .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-blue .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #222;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #222))); }\n .ag-theme-blue .ag-filter-toolpanel-header {\n height: 24px; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-header, .ag-theme-blue .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 4px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-header, .ag-theme-blue .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 4px; }\n .ag-theme-blue .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f112\";\n position: absolute; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-left: 4px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-right: 4px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-0-header {\n height: 32px; }\n .ag-theme-blue .ag-filter-toolpanel-group-item {\n margin-top: 2px;\n margin-bottom: 2px; }\n .ag-theme-blue .ag-filter-toolpanel-search {\n height: 25px; }\n .ag-theme-blue .ag-filter-toolpanel-search-input {\n flex-grow: 1;\n height: 16px; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 4px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 4px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6)); }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 4px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 4px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 20px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 20px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 36px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 36px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 52px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 52px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 68px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 68px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 84px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 84px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 100px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 100px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 116px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 116px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 132px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 132px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 148px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 148px; }\n .ag-theme-blue .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 164px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 164px; }\n .ag-theme-blue .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 4px; }\n .ag-theme-blue .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6);\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6);\n padding-top: 4px; }\n .ag-theme-blue .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 4px; }\n .ag-theme-blue .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 4px; }\n .ag-theme-blue .ag-pivot-mode-panel {\n height: 25px;\n display: flex; }\n .ag-theme-blue .ag-pivot-mode-select {\n display: flex;\n align-items: center; }\n .ag-theme-blue .ag-ltr .ag-pivot-mode-select {\n margin-left: 6px; }\n .ag-theme-blue .ag-rtl .ag-pivot-mode-select {\n margin-right: 6px; }\n .ag-theme-blue .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-column-select-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-column-select-header {\n height: 25px;\n align-items: center;\n padding: 0 6px;\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6)); }\n .ag-theme-blue .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6));\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6)); }\n .ag-theme-blue .ag-column-group-icons,\n .ag-theme-blue .ag-column-select-header-icon {\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-header {\n background-color: #5e9cd3;\n background-color: var(--ag-header-background-color, #5e9cd3);\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-header-row {\n color: #fff;\n color: var(--ag-header-foreground-color, #fff); }\n .ag-theme-blue .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-header-row {\n height: 25px; }\n .ag-theme-blue .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-blue .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-blue .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-blue .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-blue .ag-header-cell,\n .ag-theme-blue .ag-header-group-cell {\n padding-left: 12px;\n padding-right: 12px; }\n .ag-theme-blue .ag-header-cell.ag-header-cell-moving,\n .ag-theme-blue .ag-header-group-cell.ag-header-cell-moving {\n background-color: #9bc2e6;\n background-color: var(--ag-header-cell-moving-background-color, #9bc2e6); }\n .ag-theme-blue .ag-keyboard-focus .ag-header-cell:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-header-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none; }\n .ag-theme-blue .ag-keyboard-focus .ag-header-group-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue .ag-header-icon {\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-header-expand-icon {\n cursor: pointer; }\n .ag-theme-blue .ag-ltr .ag-header-expand-icon {\n padding-left: 4px; }\n .ag-theme-blue .ag-rtl .ag-header-expand-icon {\n padding-right: 4px; }\n .ag-theme-blue .ag-header-row:not(:first-child) .ag-header-cell,\n .ag-theme-blue .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-header-cell::after,\n .ag-theme-blue .ag-header-group-cell::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n width: 1px;\n height: 100%;\n top: calc(50% - 50%);\n background-color: rgba(155, 194, 230, 0.5);\n background-color: var(--ag-header-column-separator-color, rgba(155, 194, 230, 0.5)); }\n .ag-theme-blue .ag-ltr .ag-header-cell::after, .ag-theme-blue .ag-ltr .ag-header-group-cell::after {\n right: 0; }\n .ag-theme-blue .ag-rtl .ag-header-cell::after, .ag-theme-blue .ag-rtl .ag-header-group-cell::after {\n left: 0; }\n .ag-theme-blue .ag-ltr .ag-header-select-all {\n margin-right: 12px; }\n .ag-theme-blue .ag-rtl .ag-header-select-all {\n margin-left: 12px; }\n .ag-theme-blue .ag-ltr .ag-floating-filter-button {\n margin-left: 12px; }\n .ag-theme-blue .ag-rtl .ag-floating-filter-button {\n margin-right: 12px; }\n .ag-theme-blue .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 12px;\n padding: 0;\n width: 12px; }\n .ag-theme-blue .ag-filter-loading {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n height: 100%;\n padding: 6px 6px;\n position: absolute;\n width: 100%;\n z-index: 1; }\n .ag-theme-blue .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6);\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n height: 25px; }\n .ag-theme-blue .ag-paging-panel > * {\n margin: 0 12px; }\n .ag-theme-blue .ag-paging-button {\n cursor: pointer;\n opacity: 0;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n padding: 0;\n width: 12px; }\n .ag-theme-blue .ag-disabled .ag-paging-button {\n cursor: default; }\n .ag-theme-blue .ag-paging-button-wrapper.ag-disabled {\n color: rgba(34, 34, 34, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(34, 34, 34, 0.5));\n cursor: default; }\n .ag-theme-blue .ag-paging-button-wrapper, .ag-theme-blue .ag-paging-description {\n margin: 0 4px; }\n .ag-theme-blue .ag-status-bar {\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-border-color, #9bc2e6);\n color: rgba(34, 34, 34, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(34, 34, 34, 0.5));\n padding-right: 16px;\n padding-left: 16px;\n line-height: 1.5; }\n .ag-theme-blue .ag-status-name-value-value {\n color: #222;\n color: var(--ag-foreground-color, #222); }\n .ag-theme-blue .ag-status-bar-center {\n text-align: center; }\n .ag-theme-blue .ag-status-name-value {\n margin-left: 4px;\n margin-right: 4px;\n padding-top: 8px;\n padding-bottom: 8px; }\n .ag-theme-blue .ag-column-drop-cell {\n background: #ddebf7;\n background: var(--ag-chip-background-color, #ddebf7);\n border-radius: 16px;\n height: 16px;\n padding: 0 2px; }\n .ag-theme-blue .ag-column-drop-cell-text {\n margin: 0 4px; }\n .ag-theme-blue .ag-column-drop-cell-button {\n min-width: 16px;\n margin: 0 2px;\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-column-drop-cell-drag-handle {\n margin-left: 8px; }\n .ag-theme-blue .ag-column-drop-cell-ghost {\n opacity: 0.5; }\n .ag-theme-blue .ag-column-drop-horizontal {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222));\n height: 25px;\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-ltr .ag-column-drop-horizontal {\n padding-left: 12px; }\n .ag-theme-blue .ag-rtl .ag-column-drop-horizontal {\n padding-right: 12px; }\n .ag-theme-blue .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-column-drop-horizontal-cell-separator {\n margin: 0 4px;\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-column-drop-horizontal-empty-message {\n color: rgba(34, 34, 34, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(34, 34, 34, 0.5)); }\n .ag-theme-blue .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 12px; }\n .ag-theme-blue .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 12px; }\n .ag-theme-blue .ag-column-drop-vertical-list {\n padding-bottom: 4px;\n padding-right: 4px;\n padding-left: 4px; }\n .ag-theme-blue .ag-column-drop-vertical-cell {\n margin-top: 4px; }\n .ag-theme-blue .ag-column-drop-vertical {\n min-height: 50px;\n max-height: 150px;\n border-bottom: solid 1px;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6)); }\n .ag-theme-blue .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none; }\n .ag-theme-blue .ag-column-drop-vertical-icon {\n margin-left: 4px;\n margin-right: 4px; }\n .ag-theme-blue .ag-column-drop-vertical-list {\n position: relative; }\n .ag-theme-blue .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(34, 34, 34, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(34, 34, 34, 0.5));\n margin-top: 4px; }\n .ag-theme-blue .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n background: #fff;\n background: var(--ag-background-color, #fff);\n height: 70px;\n padding: 0; }\n .ag-theme-blue .ag-select-agg-func-virtual-list-item {\n cursor: default;\n line-height: 20px;\n padding-left: 8px; }\n .ag-theme-blue .ag-select-agg-func-virtual-list-item:hover {\n background-color: #c8c8c8;\n background-color: var(--ag-selected-row-background-color, #c8c8c8); }\n .ag-theme-blue .ag-chart-menu {\n border-radius: 0px;\n background: #fff;\n background: var(--ag-background-color, #fff); }\n .ag-theme-blue .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 0px;\n color: #222;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue .ag-chart-menu-icon:hover {\n opacity: 1; }\n .ag-theme-blue .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: #9bc2e6;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6));\n border-radius: 5px;\n margin: 5px; }\n .ag-theme-blue .ag-chart-mini-thumbnail:nth-last-child(3),\n .ag-theme-blue .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto; }\n .ag-theme-blue .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0; }\n .ag-theme-blue .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0; }\n .ag-theme-blue .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0; }\n .ag-theme-blue .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0; }\n .ag-theme-blue .ag-chart-mini-thumbnail.ag-selected {\n border-color: #222;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222))); }\n .ag-theme-blue .ag-chart-settings-card-item {\n background: #222;\n background: var(--ag-foreground-color, #222);\n width: 8px;\n height: 8px;\n border-radius: 4px; }\n .ag-theme-blue .ag-chart-settings-card-item.ag-selected {\n background-color: #222;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222))); }\n .ag-theme-blue .ag-chart-data-column-drag-handle {\n margin-left: 4px; }\n .ag-theme-blue .ag-charts-settings-group-title-bar,\n .ag-theme-blue .ag-charts-data-group-title-bar,\n .ag-theme-blue .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: #9bc2e6;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, #9bc2e6)); }\n .ag-theme-blue .ag-charts-settings-group-container {\n padding: 4px; }\n .ag-theme-blue .ag-charts-data-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-blue .ag-charts-data-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-blue .ag-charts-format-top-level-group-container {\n margin-left: 8px;\n padding: 4px; }\n .ag-theme-blue .ag-charts-format-top-level-group-item {\n margin: 4px 0; }\n .ag-theme-blue .ag-charts-format-sub-level-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-blue .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-blue .ag-charts-group-container.ag-group-container-horizontal {\n padding: 4px; }\n .ag-theme-blue .ag-chart-data-section,\n .ag-theme-blue .ag-chart-format-section {\n display: flex;\n margin: 0; }\n .ag-theme-blue .ag-chart-menu-panel {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-blue .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: #9bc2e6;\n border-left-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: #9bc2e6;\n border-right-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-date-time-list-page-title {\n flex-grow: 1;\n text-align: center; }\n .ag-theme-blue .ag-date-time-list-page-column-label {\n text-align: center; }\n .ag-theme-blue .ag-date-time-list-page-entry {\n text-align: center; }\n .ag-theme-blue .ag-checkbox-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n flex: none; }\n .ag-theme-blue .ag-checkbox-input-wrapper input, .ag-theme-blue .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-blue .ag-checkbox-input-wrapper:focus-within, .ag-theme-blue .ag-checkbox-input-wrapper:active {\n outline: none; }\n .ag-theme-blue .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-blue .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #222;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-blue .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #222;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-blue .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #222;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222)));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-blue .ag-toggle-button-input-wrapper {\n box-sizing: border-box;\n width: 24px;\n height: 12px;\n background-color: #222;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222)));\n border-radius: 6px;\n position: relative;\n flex: none;\n border: 1px solid;\n border-color: #222;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222))); }\n .ag-theme-blue .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%; }\n .ag-theme-blue .ag-toggle-button-input-wrapper:focus-within {\n outline: none; }\n .ag-theme-blue .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-blue .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #222;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222)));\n border-color: #222;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222))); }\n .ag-theme-blue .ag-toggle-button-input-wrapper::before {\n content: ' ';\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n background-color: #fff;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #fff));\n border-radius: 6px;\n transition: left 100ms;\n border: 1px solid;\n border-color: #222;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222)))); }\n .ag-theme-blue .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 12px);\n border-color: #222;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222))); }\n .ag-theme-blue .ag-radio-button-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n flex: none;\n border-radius: 12px; }\n .ag-theme-blue .ag-radio-button-input-wrapper input, .ag-theme-blue .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-blue .ag-radio-button-input-wrapper:focus-within, .ag-theme-blue .ag-radio-button-input-wrapper:active {\n outline: none; }\n .ag-theme-blue .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-blue .ag-radio-button-input-wrapper::after {\n content: \"\\f124\";\n color: #222;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-blue .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f125\";\n color: #222;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-blue input[class^='ag-'][type='range'] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible; }\n .ag-theme-blue input[class^='ag-'][type='range']::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #9bc2e6;\n background-color: var(--ag-border-color, #9bc2e6);\n border-radius: 0px;\n border-radius: 0px; }\n .ag-theme-blue input[class^='ag-'][type='range']::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #9bc2e6;\n background-color: var(--ag-border-color, #9bc2e6);\n border-radius: 0px;\n border-radius: 0px; }\n .ag-theme-blue input[class^='ag-'][type='range']::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #9bc2e6;\n background-color: var(--ag-border-color, #9bc2e6);\n border-radius: 0px;\n border-radius: 0px;\n color: transparent;\n width: calc(100% - 2px); }\n .ag-theme-blue input[class^='ag-'][type='range']::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #222;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222));\n border-radius: 12px;\n -webkit-transform: translateY(-4.5px);\n transform: translateY(-4.5px); }\n .ag-theme-blue input[class^='ag-'][type='range']::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #222;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222));\n border-radius: 12px; }\n .ag-theme-blue input[class^='ag-'][type='range']::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #222;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #222));\n border-radius: 12px; }\n .ag-theme-blue input[class^='ag-'][type='range']:focus {\n outline: none; }\n .ag-theme-blue input[class^='ag-'][type='range']:focus::-webkit-slider-thumb {\n border-color: #222;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue input[class^='ag-'][type='range']:focus::-ms-thumb {\n border-color: #222;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue input[class^='ag-'][type='range']:focus::-moz-ag-range-thumb {\n border-color: #222;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #222)); }\n .ag-theme-blue input[class^='ag-'][type='range']:active::-webkit-slider-runnable-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue input[class^='ag-'][type='range']:active::-moz-ag-range-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue input[class^='ag-'][type='range']:active::-ms-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-blue input[class^='ag-'][type='range']:disabled {\n opacity: 0.5; }\n .ag-theme-blue .ag-icon {\n color: #333; }\n .ag-theme-blue .ag-icon-tree-closed::before {\n content: \"\\f10b\"; }\n .ag-theme-blue .ag-icon-tree-open::before {\n content: \"\\f10f\"; }\n .ag-theme-blue .ag-header, .ag-theme-blue .ag-column-drop-cell {\n background-image: none; }\n .ag-theme-blue .ag-tab {\n border: 1px solid transparent;\n padding: 4px 8px;\n margin: 4px;\n margin-bottom: -1px; }\n .ag-theme-blue .ag-tabs-body {\n margin: 2px 0; }\n .ag-theme-blue .ag-icon {\n margin: 1px 1px 2px 1px; }\n .ag-theme-blue .ag-tab-selected {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n border-bottom-color: transparent; }\n .ag-theme-blue .ag-tabs-header {\n background-color: #5e9cd3;\n background-color: var(--ag-header-background-color, #5e9cd3);\n border-bottom: 1px solid;\n border-bottom-color: #9bc2e6;\n border-bottom-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-filter .ag-filter-apply-panel {\n justify-content: flex-start; }\n .ag-theme-blue .ag-menu-option-active {\n background-color: #c8c8c8;\n background-color: var(--ag-selected-row-background-color, #c8c8c8); }\n .ag-theme-blue .ag-column-drop-cell {\n border: 1px solid;\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6);\n border-radius: 0; }\n .ag-theme-blue .ag-column-drop-cell-button .ag-icon {\n border: 1px solid transparent; }\n .ag-theme-blue .ag-column-drop-cell-button:hover .ag-icon {\n border-color: #9bc2e6;\n border-color: var(--ag-border-color, #9bc2e6); }\n .ag-theme-blue .ag-panel-title-bar-button-icon {\n font-size: 20px;\n line-height: 20px; }\n .ag-theme-blue .ag-menu-option-part {\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-blue .ag-column-drop-vertical-title-bar {\n margin-top: 4px;\n margin-left: 4px; }\n .ag-theme-blue .ag-column-drop-vertical-title {\n margin-left: 4px; }\n .ag-theme-blue .ag-column-drop-vertical-empty-message {\n margin-left: 24px; }\n\n", ""]);
  46316. // Exports
  46317. module.exports = exports;
  46318. /***/ }),
  46319. /* 238 */
  46320. /***/ (function(module, exports, __webpack_require__) {
  46321. var api = __webpack_require__(225);
  46322. var content = __webpack_require__(239);
  46323. content = content.__esModule ? content.default : content;
  46324. if (typeof content === 'string') {
  46325. content = [[module.i, content, '']];
  46326. }
  46327. var options = {};
  46328. options.insert = "head";
  46329. options.singleton = false;
  46330. var update = api(content, options);
  46331. module.exports = content.locals || {};
  46332. /***/ }),
  46333. /* 239 */
  46334. /***/ (function(module, exports, __webpack_require__) {
  46335. // Imports
  46336. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227);
  46337. exports = ___CSS_LOADER_API_IMPORT___(false);
  46338. // Module
  46339. exports.push([module.i, ".ag-theme-bootstrap {\n -webkit-font-smoothing: antialiased;\n color: #000;\n color: var(--ag-foreground-color, #000);\n font-family: \"Helvetica Neue\", sans-serif;\n font-size: 14px;\n line-height: normal; }\n\n@font-face {\n font-family: \"agGridClassic\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABOsAAsAAAAAJiwAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlIAAAReYchjok9TLzIAAANcAAAAQQAAAFZWVlJ+Y21hcAAAA6AAAAHtAAAFgHClDfdnbHlmAAAFkAAACi0AABQQq+8lqmhlYWQAAA/AAAAANAAAADZ2z8SBaGhlYQAAD/QAAAAeAAAAJAfTBChobXR4AAAQFAAAABoAAAEou4L/4mxvY2EAABAwAAAAbwAAAJb7HvWgbWF4cAAAEKAAAAAfAAAAIAFgAHhuYW1lAAAQwAAAATMAAAJS8kTiWnBvc3QAABH0AAABtgAAApcplp2DeJx9k0lyE0EQRX+rZSMPyGDMZMRkRpsh3O5BjSTLltzyQHjBggULNmYBAeFg5ROw5gAEB+AUnIBgyYoDcACCA/Ay1UbGC6tC1VWZP3/+yspSIGlSy+qqUmzuPld9f+/gveZV1fBn/qPrYP/tmz3VDnf4qv6tKQj/qK4FvdCBvgUKXgefK+NhJeyGu+GH8FP4QyGoG3oMekorjFgJc6RUmZrKVdE4tpj1E7VAh8xtt87qgsbcU2ig8+SMiRk445Ke6o7OwNN3np7WQKUM4+wxbzHuauYERK578GeoWcVqrA10ntWENtHYQ0eH6BbeGXzrZI6I6eProy10VNXruK2XRM762SwyK3Ep/1gbvo9894AqHKLa8DfhN75Fsh7am2RKiHgEewaqW9Zwif8U3hRMRGzHa2bR10AmKEx1nZWdLOFk07oN+zO98qwbZUzPqzg88yLqR/a+8+XkOWrtwLUF9iEaRla7kfvkirSDf5KbKvROH/VFX/VdP/VLv3UK6ypeO8Ea3OsnVqZG/Y6jC7ztf1Y76Th3fhz1P2KCcze9NjG+QVlByzaFTqtNyjrCmjp+Ep2GL1CTU68qOSLPm2AdY6yyj0GfLruxxZj2Og/oAeuAeWqxwmxMw37L2V+GyVZDXRe9Wi14LvltWU3tJdV9Zz1vtzxPna/wjThZ5vXZxnsVizGNLA2PylFtHMv4c9SOspmqBqoSeqDmnbXjr6Ag003OMVSS6Ja/gB3vqgUUZOWLnNM5V98pb2rOcbFHBWiOypeces2sk/tos67Y+gsvGGrHAAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMnxi4gDQjSA4A1QYKdAAAAHictdQHTltBFIXh3wXTTEnvvRc6hGp6XQbpiBREOsoqs5O7gZBzPScLIFJG+nw9o+c3b/R8LtAB1OSp1KFap0KO31qttNdr9LTX6/zSvEkXVX0fYo8DjmL0+FirQ+yyz2FU2rO/o6Krm1zlPs80W2GMJeZZZZItxmlpdZEF1phhmg0mmGOKdXaYZZlNtvX7qnav6xkbdGrfbj1Jr+7YRz8DDHKaM5zlHOe5wEUucZkr2u0a17nBTW5xmzvc5Z72f8BDHvGYJzrPkD6HNRvRAzY42Vg54fU5xpbmVye3xls67cLazLQOOje1vjO7vLn9Dzf7D6OZH7Wfnu2Qb7PI0+7amDy3JXlh8/LSVuWVTcpr25I3Ni5vrSV7lv+QfVuUd7Yg721NPtiMfLRpObANObQJ+WRz8tmm5Iuty1fLs3+zWfluy/LDNuXI9AKjUmRWolqQtVZktqJeZL6io8jcRaMga2dB1q6CrN0FWXuKzGP0FmRtFvkmo68ga39B1oGCrIMFWU8VyhJhShVhyhdhShphyhxhSh9hyiFhSiRhyiZhSilhyithSi5hyjBhSjNhyjVhSjhhyjphSj1hyj9h6gSEqScQpu5AmPoEYeoRhKl3EKb+QVj2zbDMTFj7muGCrCNF+56jBSN/AHzNoH4AAAB4nO1Ye2xT1xm/37nEN87D8bUdXwezwLWJDZQCtmNfO4FATIgdQhLWGwhrt0DSGJHHpgaawFRatBIVVrXbHxXTWCiPabMHo9MgSH1IGxJMa6b+sbBJFZVK2/HHVNjI6JZ2k8W97DvHjzyggPrntBufe17fPec73/md3/edcMDhw4f4fs7IcSBLglwuW3mZD+mj+/ZBQtv//vtkhPxuYiIFe2EvijD5T/lPuUVYCQpeRRK8oswyRRZZJokyywQZLrXFxscbNwPf1oh5m65txjzWpuu0PdYGhF9k/LIuWm/czOXm3Mq/whViRfAaMYlu+NkbCeiG7sTZU2TPGz3QrR/vOavdzMmTSTLJFTN51AW1QX3IZOOFsdiFC7GxC41jUJ8rjTVe4Ao47q6O67rBWTk35+Ue41ZyXIHsWgFBsboOArK/EspFmwl42WXAgh1bQtjlgYDorgqUu3nM+T7N5qpx4Y/83VUjyzWyZjY7HGZyW5Qk7ReqCi2qmmpvJ66Ii3yGL/xpZfjifySJmig6HCL5hyjpY/q1ZBJO6jtw2Vm9bjK9luJ6coq4p5UrmKOTALheK9/HdHDldbo1Q5teffLf1aev8zdyKuRU2jJTk3f0ot/XH4YTc/XwPpoevByUH6jFX/Tz0PoQHfTSJN3OWfM/2uwPmvkhk9L14qL38T2IjELOwXEIOskIvLIQDAL+ldvsOEu11+Mlf9O31zyta1A3Pv7ur4uLK8rsvg0+e1kFXIJTtdihX4Y14+N1paWVTk+Fy+dzVVQtqKTDG9gcR/gjOJuAWC3DtUkcV1WOZsPEz8nhlH6ej+rnk7OydAofaEniA620zGV1v5HF8spHsxYghsvdQXcwEAzw/RmLadaMBcmkZmaWoZbT30uxJ2NBS9aCk1kLWlFCJLdw2y5QlVJMFfaK8lG2ShH1CYhy0I0sIYsyH5TFQJCMJvWSJEyp+hi0pPQxlYyyehrrp7AxzeV54Hn+eXqujYDbIRgB2UCBKbAM65PspU8OgwVfpG9WFSxYncElhxmXiAFkLDrAz0+eTejH9eMJ+C4xaVNYOQFdCe6r4p7u2oPQ9wO95GGoH0smp233Lq9wFZyPW43zK1IoYJfskgkBicwGobUQdLsQk17rCuI1CJUg2RXJgMikfyEUUFgJ5UGu9qyNHnpucNvSb9cF6xeZ9D+taPYW1T0WfvzAX0PfXF3UUO17pVX9uv9bT3ZtrYus9D85BFc3N5os9kq5uHY5b1qyyjLvieaDa3Z5GgJLiuFAEQG1wGBy6tcM4W1Bf7zhabujeN2CImN1VZ1/40ub9KO+TqskLZwfaHf+b65FQjwv4UK4FroORg1ZXUNYpm12Jac0QcB4qzxrwE3lJBRR4A5dQdvw/hd/uJ8q+Y0933umoXpdZ/euZ3Zs3ciULWnctbc3VgQboagtFAtVLQl5VvPlvNr84nBLW0nJRs8af/NI85Yz/vg2JWwwKP4eq2RfVBF+qjrUWcOXLlgGhcXzm22FAuEyPMo4px95DT2+VQbRG/SVB4Iq45Qk34/eZ3sq3d6elSV30I/yLDoQ3SI6Fq8gwVqVmC9fDqfTZFIvgSm94dIlrFDxkuxZvziL05zcwmmvqiDT5BI8pCwjH6WSyTT7ISN8WQlOJpMTSUaCJ+/NUKWC7Lovcl/jZK4KPenjlIcYsSLvZSk2n0R3UAZ3Ofr0TKrCBKeQYdFGyLY0p0zF8h3t0JqdjqnD96tovqSaxiytklhas6hwqh15TFXn2rTKLQaARicCuaOq2m1m1PQMi2b46iS/lfGVhIRHQzTYebpHPw7dPWdIDZw8nYmDzlCyJXe/uPsF/y/+n1w1159BpaGMuiwvYs+j4AEL+RkqsdUElQQb6sCDnUGfhxaxC6segXVTOSlgpx95q70+KsbkK0muuxL82KmEvB7yQsRmWxIeibQ2b2rZbcMnEi+qsAARyTxDhdNmCTY1OQ8usFidRgepWFpoL7JbwBpp2dTcGhkJL0FxSzkU2QuXOUhpsdFptToPOpuaghabs8IwjzcTsFQUxSN0XJyptfkozkQru9kAcaPZFPQXWgzznfGmkM3qHHHG406jaHY5lhYSg5nOxFQaCR9FcUuZQAqXOlxmo1BEBUecVluoKe6cb7AU+oMmszHOVjHzvBxBFC9kjCUgLJGs0FciYyE8cfPQYwaUoNctlJPY0eGjV6/iK5kv/Pjl7u6Xu8lvZjXSgvZWN+3i5s2KPZchNz5a5CmwoBYU5E5JeXDseevjmG80fAyuxT7xvR5+/SEBqFYX+2jVMRR//pOYD/O8H5qOVViUAtnEH7nzWz6aSelMNEJjEfrJV12bwsJ2XCIlnAev7bmPYquOKaNQHfuYKv2wtaWza3sNTXJMOZa/L7yKZ7KA7jA9jfAUO4ngzxFb5hw6+T9zpdN3EBY7SDDamwAveBO9vQn9A/2DRC8514ctWOrTX+rDNuzry8YSd1ksYeMWcwEaS9ATZqZOYxF1EWb0CKECemYDflqk8eVKehyZTzSU0+MIU4efHYxu2BAdfFb/bGgw2tAQHRyCCe3NUH00Nti1XYlI0rJ4qH49VjrDEcAafxOlh/TbQ7up9O4hMON3Gz7X3lwmSRGls3swFl0XaspUugbj0fpQDvdR9BMCcjiL2DBMC0iUKTFyo6y2M51Mqfp5FaZ4h5Ygo2qK8l/eVjTewxq4RckteN0KpVQy2Xkurarpc50wha5jvDed7oWwmuHnPE5k9Khhbu39kUIDBAaVWvRHwQKMIBExfOYeyg4mPaFWSuL0BjAHN9p3DlDcHEjx67R3SKUo/adk9eBgbcnFklqaDUxo10mjdA+CyO1kBkIkhiT9tkOE1ZkPMt+VkljyBbwzzMYR85Tk1Tk4IjMwQG9zbGPNFAaL6I6bKQwEBgsb7XHRejXtgalD+d0uyyHgMNvwiLK96zpuNj6dXfff7C10a693d1Lhzm4UViKz8biUxTD3w6PEVGQ+g4GS3nk8VtwJ3BvcGdyX+0LyUAZ+VKXrOSW/v37P4T3r2euR1dR3NGQ/Wb8nj60TWX/oVfACoMhBcvCXCejSTyROa38gsTOZUP50Ks/fA4jjUs5OYxh07XmeKcj+uyKAAH5L9blI3OXTxwZqJiZqBtrRCX8Ii/UP6Y0NFi8YqJ2YqB2A16bxTUbp6BhBpchP9DG8sJzPc8koYp/QO4pIYwS8nrRoO+f2kUz4wNdjwDU2Z0wj0CCjJSOR7UvyMYorI0HG4ZPaFf294YvwNrmiXYHgEJam9YrTnaVHABXTdiI4aXM+LnBzMa4D+dtumxsXLATalo0KQn6Jt/vz3t5gw96sr6dfCKxNAooH8LgyFbufPCEIHTNCgA7BKrQaDNvQn1MH2yHYBBemDuqm0cVvMxhaUaJjhivvEATiWG4y3fmpyWPCnO80ef54r0zL7FHgV7MnablXjTufL8cRcTgc1VuKw//fJvfa5L+BscYKAAAAeJxjYGRgYABi/jvPp8Xz23xl4GZ+ARSI4ny8rwFG///2/xvzZ+ZPQJUcDExAkgEAoUMP6XicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AIAnloHAgAAeJxjYGBgYH5Ba/z/G+3M/f+NgQ4AAPv8MfAAAHicY2AAAgmGIIYshhaGC4wijCGMPYz7GF8xGTGFMVUwTWC6wGzGPIf5BwsfiwZLCcsOlgssL1gnsB5iE2EzYGtim8K2jZ2HXYvdhX0Z+w72fxwRHAUcszhWcGzjOMJxieMZxxfOOi4O0iEAtgsblgB4nGNgZGBg8GLIYeBhAAEmIOYCQgaG/2A+AwAbuAHZAHicfZC9TsMwFIVP+odoBaoEYmAyCwtS+rPRtVKzd+ieJnaaKo2D41bqznPwBDxHn4OnYObEeCkStSXnu9899w4BMMQJAZoT4Ma9zWnhitUvt0n3njvkJ89dDBB67tG/eu7jBQvPA9zhjRuCzjXNI949t3CLD89t+k/PHfLJcxcP+PLco//23McqGHoe4DlQcRaZPJ0XcV3nyVJm+yI2Z+6sWElT57oUk3B85iNZShNbmYr1UdSHbGqtEsronVjo0sqi0KIyeisTG26srWajkfI+TPQOMTJEMMiRYo6Cdc2bI8ESkr29c+ZC7v/OihuMY40SAhP+9/GFfMR86WZiWH5Tzqxx5FvjwKkprYVirZjR2JEWbneTLng1TeV6W5qEPsTGTVWYYcSr/uRDprjpB8WrbRMAeJxtkmdv2zAURX1iyVbstEnTNt17D7VN994z/RUMRctEJFIgKY/8+rJxGiBA36dzHx7uu3xgZ6mzqEHn/7XFEl0SUnr0yVhmwJAVjnCUVdY4xjrHOcFJNjjFac5wlnOc5wIXucRlrnCVa1znBje5xW3ucJd73CfnAQ95xCaPecJTnvGcF7zkFa95w1ve8Z4PfOQTn/nCV77xnR/85Bdb/O4MRVk6VYqgrekJ5+zUd4WXPSmMVFUqx8KFNTlWcmfbzvI9UMXGQUObQgXlam1EUOsH7dbsT65IW1mXNzoK14+irY0fSGuCEzKoIpG2mafSWe+TQnmZqVkjomexrOYq95Xw4+EB5ZvdyL2RruLKdKSdD0npdJOWzrZNEkdCUqlR6FXaxN39yopCmzKrxUzXelcltTJtFrMulFGzkBhr1NDYkIuqslNVpE10Ud1Gm7TRExuyxqmJtq1fc9HM5tttCNbkdjRaPdwwqdPlOCReTNTA19EuL+zU7OPfWMMF7o1lC46pQzzNenBKHb5l1prFKwb/IN9EUOJQBDQWwxSPpGLMDtvM4lcoqGlpmDNil0mn8wcxorJdAAA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n .ag-theme-bootstrap .ag-icon {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n .ag-theme-bootstrap .ag-icon-aggregation:before {\n content: \"\\f101\"; }\n .ag-theme-bootstrap .ag-icon-arrows:before {\n content: \"\\f102\"; }\n .ag-theme-bootstrap .ag-icon-asc:before {\n content: \"\\f103\"; }\n .ag-theme-bootstrap .ag-icon-cancel:before {\n content: \"\\f104\"; }\n .ag-theme-bootstrap .ag-icon-chart:before {\n content: \"\\f105\"; }\n .ag-theme-bootstrap .ag-icon-color-picker:before {\n content: \"\\f109\"; }\n .ag-theme-bootstrap .ag-icon-columns:before {\n content: \"\\f10a\"; }\n .ag-theme-bootstrap .ag-icon-contracted:before {\n content: \"\\f10b\"; }\n .ag-theme-bootstrap .ag-icon-copy:before {\n content: \"\\f10c\"; }\n .ag-theme-bootstrap .ag-icon-cross:before {\n content: \"\\f10d\"; }\n .ag-theme-bootstrap .ag-icon-desc:before {\n content: \"\\f10e\"; }\n .ag-theme-bootstrap .ag-icon-expanded:before {\n content: \"\\f10f\"; }\n .ag-theme-bootstrap .ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n .ag-theme-bootstrap .ag-icon-eye:before {\n content: \"\\f111\"; }\n .ag-theme-bootstrap .ag-icon-filter:before {\n content: \"\\f112\"; }\n .ag-theme-bootstrap .ag-icon-first:before {\n content: \"\\f113\"; }\n .ag-theme-bootstrap .ag-icon-grip:before {\n content: \"\\f114\"; }\n .ag-theme-bootstrap .ag-icon-group:before {\n content: \"\\f115\"; }\n .ag-theme-bootstrap .ag-icon-last:before {\n content: \"\\f116\"; }\n .ag-theme-bootstrap .ag-icon-left:before {\n content: \"\\f117\"; }\n .ag-theme-bootstrap .ag-icon-linked:before {\n content: \"\\f118\"; }\n .ag-theme-bootstrap .ag-icon-loading:before {\n content: \"\\f119\"; }\n .ag-theme-bootstrap .ag-icon-maximize:before {\n content: \"\\f11a\"; }\n .ag-theme-bootstrap .ag-icon-menu:before {\n content: \"\\f11b\"; }\n .ag-theme-bootstrap .ag-icon-minimize:before {\n content: \"\\f11c\"; }\n .ag-theme-bootstrap .ag-icon-next:before {\n content: \"\\f11d\"; }\n .ag-theme-bootstrap .ag-icon-none:before {\n content: \"\\f11e\"; }\n .ag-theme-bootstrap .ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n .ag-theme-bootstrap .ag-icon-paste:before {\n content: \"\\f120\"; }\n .ag-theme-bootstrap .ag-icon-pin:before {\n content: \"\\f121\"; }\n .ag-theme-bootstrap .ag-icon-pivot:before {\n content: \"\\f122\"; }\n .ag-theme-bootstrap .ag-icon-previous:before {\n content: \"\\f123\"; }\n .ag-theme-bootstrap .ag-icon-right:before {\n content: \"\\f126\"; }\n .ag-theme-bootstrap .ag-icon-save:before {\n content: \"\\f127\"; }\n .ag-theme-bootstrap .ag-icon-small-down:before {\n content: \"\\f128\"; }\n .ag-theme-bootstrap .ag-icon-small-left:before {\n content: \"\\f129\"; }\n .ag-theme-bootstrap .ag-icon-small-right:before {\n content: \"\\f12a\"; }\n .ag-theme-bootstrap .ag-icon-small-up:before {\n content: \"\\f12b\"; }\n .ag-theme-bootstrap .ag-icon-tick:before {\n content: \"\\f12c\"; }\n .ag-theme-bootstrap .ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n .ag-theme-bootstrap .ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n .ag-theme-bootstrap .ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n .ag-theme-bootstrap .ag-icon-unlinked:before {\n content: \"\\f130\"; }\n .ag-theme-bootstrap .ag-icon-row-drag:before {\n content: \"\\f114\"; }\n .ag-theme-bootstrap .ag-right-arrow:before {\n content: \"\\f117\"; }\n .ag-theme-bootstrap .ag-right-arrow:before {\n content: \"\\f126\"; }\n .ag-theme-bootstrap .ag-root-wrapper {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-bootstrap [class^='ag-'], .ag-theme-bootstrap [class^='ag-']:focus, .ag-theme-bootstrap [class^='ag-']:after, .ag-theme-bootstrap [class^='ag-']:before {\n box-sizing: border-box;\n outline: none; }\n .ag-theme-bootstrap [class^='ag-']::-ms-clear {\n display: none; }\n .ag-theme-bootstrap .ag-checkbox .ag-input-wrapper,\n .ag-theme-bootstrap .ag-radio-button .ag-input-wrapper {\n overflow: visible; }\n .ag-theme-bootstrap .ag-range-field .ag-input-wrapper {\n height: 100%; }\n .ag-theme-bootstrap .ag-toggle-button {\n flex: none;\n width: unset;\n min-width: unset; }\n .ag-theme-bootstrap .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 4px; }\n .ag-theme-bootstrap input[class^='ag-'] {\n margin: 0;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-bootstrap textarea[class^='ag-'],\n .ag-theme-bootstrap select[class^='ag-'] {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-bootstrap input[class^='ag-']:not([type]),\n .ag-theme-bootstrap input[class^='ag-'][type='text'],\n .ag-theme-bootstrap input[class^='ag-'][type='number'],\n .ag-theme-bootstrap input[class^='ag-'][type='tel'],\n .ag-theme-bootstrap input[class^='ag-'][type='date'],\n .ag-theme-bootstrap input[class^='ag-'][type='datetime-local'],\n .ag-theme-bootstrap textarea[class^='ag-'] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #000;\n border-color: var(--ag-input-border-color, #000); }\n .ag-theme-bootstrap input[class^='ag-']:not([type]):disabled,\n .ag-theme-bootstrap input[class^='ag-'][type='text']:disabled,\n .ag-theme-bootstrap input[class^='ag-'][type='number']:disabled,\n .ag-theme-bootstrap input[class^='ag-'][type='tel']:disabled,\n .ag-theme-bootstrap input[class^='ag-'][type='date']:disabled,\n .ag-theme-bootstrap input[class^='ag-'][type='datetime-local']:disabled,\n .ag-theme-bootstrap textarea[class^='ag-']:disabled {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n background-color: #ebebeb;\n background-color: var(--ag-input-disabled-background-color, #ebebeb);\n border-color: rgba(0, 0, 0, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(0, 0, 0, 0.3)); }\n .ag-theme-bootstrap input[class^='ag-']:not([type]):focus,\n .ag-theme-bootstrap input[class^='ag-'][type='text']:focus,\n .ag-theme-bootstrap input[class^='ag-'][type='number']:focus,\n .ag-theme-bootstrap input[class^='ag-'][type='tel']:focus,\n .ag-theme-bootstrap input[class^='ag-'][type='date']:focus,\n .ag-theme-bootstrap input[class^='ag-'][type='datetime-local']:focus,\n .ag-theme-bootstrap textarea[class^='ag-']:focus {\n outline: none;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap input[class^='ag-'][type='number'] {\n -moz-appearance: textfield; }\n .ag-theme-bootstrap input[class^='ag-'][type='number']::-webkit-outer-spin-button, .ag-theme-bootstrap input[class^='ag-'][type='number']::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0; }\n .ag-theme-bootstrap input[class^='ag-'][type='range'] {\n padding: 0; }\n .ag-theme-bootstrap .ag-drag-handle {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-list-item, .ag-theme-bootstrap .ag-virtual-list-item {\n height: 20px; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-virtual-list-item:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-select-list {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n overflow-y: auto;\n overflow-x: hidden; }\n .ag-theme-bootstrap .ag-list-item {\n display: flex;\n align-items: center; }\n .ag-theme-bootstrap .ag-list-item.ag-active-item {\n background-color: var(--ag-row-hover-color); }\n .ag-theme-bootstrap .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n .ag-theme-bootstrap .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden; }\n .ag-theme-bootstrap .ag-select .ag-picker-field-wrapper {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n min-height: 20px;\n cursor: default; }\n .ag-theme-bootstrap .ag-select:not(.ag-cell-editor) {\n height: 20px; }\n .ag-theme-bootstrap .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis; }\n .ag-theme-bootstrap .ag-select .ag-picker-field-icon {\n display: flex;\n align-items: center; }\n .ag-theme-bootstrap .ag-select.ag-disabled {\n opacity: 0.5; }\n .ag-theme-bootstrap .ag-rich-select {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-bootstrap .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 162.5px; }\n .ag-theme-bootstrap .ag-rich-select-value {\n padding: 0 4px 0 12px;\n height: 25px; }\n .ag-theme-bootstrap .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 20px; }\n .ag-theme-bootstrap .ag-rich-select-virtual-list-item:hover {\n background-color: var(--ag-row-hover-color); }\n .ag-theme-bootstrap .ag-rich-select-row {\n padding-left: 12px; }\n .ag-theme-bootstrap .ag-rich-select-row-selected {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5); }\n .ag-theme-bootstrap .ag-row-drag,\n .ag-theme-bootstrap .ag-selection-checkbox,\n .ag-theme-bootstrap .ag-group-expanded,\n .ag-theme-bootstrap .ag-group-contracted {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-ltr .ag-row-drag, .ag-theme-bootstrap .ag-ltr .ag-selection-checkbox, .ag-theme-bootstrap .ag-ltr .ag-group-expanded, .ag-theme-bootstrap .ag-ltr .ag-group-contracted {\n margin-right: 12px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-drag, .ag-theme-bootstrap .ag-rtl .ag-selection-checkbox, .ag-theme-bootstrap .ag-rtl .ag-group-expanded, .ag-theme-bootstrap .ag-rtl .ag-group-contracted {\n margin-left: 12px; }\n .ag-theme-bootstrap .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: 23px;\n display: flex;\n align-items: center;\n flex: none; }\n .ag-theme-bootstrap .ag-group-expanded,\n .ag-theme-bootstrap .ag-group-contracted {\n cursor: pointer; }\n .ag-theme-bootstrap .ag-group-title-bar-icon {\n cursor: pointer;\n flex: none;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-ltr .ag-group-child-count {\n margin-left: 2px; }\n .ag-theme-bootstrap .ag-rtl .ag-group-child-count {\n margin-right: 2px; }\n .ag-theme-bootstrap .ag-group-title-bar {\n background-color: #ececec;\n background-color: var(--ag-subheader-background-color, #ececec);\n padding: 4px; }\n .ag-theme-bootstrap .ag-group-toolbar {\n padding: 4px; }\n .ag-theme-bootstrap .ag-disabled-group-title-bar, .ag-theme-bootstrap .ag-disabled-group-container {\n opacity: 0.5; }\n .ag-theme-bootstrap .group-item {\n margin: 2px 0; }\n .ag-theme-bootstrap .ag-label {\n white-space: nowrap; }\n .ag-theme-bootstrap .ag-ltr .ag-label {\n margin-right: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-label {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-label-align-top .ag-label {\n margin-bottom: 2px; }\n .ag-theme-bootstrap .ag-ltr .ag-slider-field, .ag-theme-bootstrap .ag-ltr .ag-angle-select-field {\n margin-right: 8px; }\n .ag-theme-bootstrap .ag-rtl .ag-slider-field, .ag-theme-bootstrap .ag-rtl .ag-angle-select-field {\n margin-left: 8px; }\n .ag-theme-bootstrap .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-bootstrap .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #000;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 5px; }\n .ag-theme-bootstrap .ag-picker-field-button {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-dialog.ag-color-dialog {\n border-radius: 5px; }\n .ag-theme-bootstrap .ag-color-picker .ag-picker-field-display {\n height: 12px; }\n .ag-theme-bootstrap .ag-color-panel {\n padding: 4px; }\n .ag-theme-bootstrap .ag-spectrum-color {\n background-color: red;\n border-radius: 2px; }\n .ag-theme-bootstrap .ag-spectrum-tools {\n padding: 10px; }\n .ag-theme-bootstrap .ag-spectrum-sat {\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0)); }\n .ag-theme-bootstrap .ag-spectrum-val {\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0)); }\n .ag-theme-bootstrap .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24); }\n .ag-theme-bootstrap .ag-spectrum-hue-background {\n border-radius: 2px; }\n .ag-theme-bootstrap .ag-spectrum-alpha-background {\n border-radius: 2px; }\n .ag-theme-bootstrap .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px; }\n .ag-theme-bootstrap .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37); }\n .ag-theme-bootstrap .ag-recent-color {\n margin: 0 3px; }\n .ag-theme-bootstrap .ag-recent-color:first-child {\n margin-left: 0; }\n .ag-theme-bootstrap .ag-recent-color:last-child {\n margin-right: 0; }\n .ag-theme-bootstrap.ag-dnd-ghost {\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n overflow: hidden;\n text-overflow: ellipsis;\n z-index: 10;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n height: 25px !important;\n line-height: 25px;\n margin: 0;\n padding: 0 8px;\n -webkit-transform: translateY(8px);\n transform: translateY(8px); }\n .ag-theme-bootstrap .ag-dnd-ghost-icon {\n margin-right: 4px;\n color: #000;\n color: var(--ag-foreground-color, #000); }\n .ag-theme-bootstrap .ag-popup-child:not(.ag-tooltip-custom) {\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3); }\n .ag-dragging-range-handle .ag-theme-bootstrap .ag-dialog,\n .ag-dragging-fill-handle .ag-theme-bootstrap .ag-dialog {\n opacity: 0.7;\n pointer-events: none; }\n .ag-theme-bootstrap .ag-dialog {\n border-radius: 0px; }\n .ag-theme-bootstrap .ag-panel {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-bootstrap .ag-panel-title-bar {\n background-color: var(--ag-header-background-color);\n color: #000;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)));\n height: 25px;\n padding: 4px 12px; }\n .ag-theme-bootstrap .ag-ltr .ag-panel-title-bar-button {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-panel-title-bar-button {\n margin-right: 4px; }\n .ag-theme-bootstrap .ag-tooltip {\n background-color: var(--ag-header-background-color);\n color: #000;\n color: var(--ag-foreground-color, #000);\n padding: 4px;\n border-radius: 0px;\n transition: opacity 1s; }\n .ag-theme-bootstrap .ag-tooltip.ag-tooltip-hiding {\n opacity: 0; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-indent-1 {\n padding-left: 16px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-indent-1 {\n padding-right: 16px; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-indent-2 {\n padding-left: 32px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-indent-2 {\n padding-right: 32px; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-indent-3 {\n padding-left: 48px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-indent-3 {\n padding-right: 48px; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-indent-4 {\n padding-left: 64px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-indent-4 {\n padding-right: 64px; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-indent-5 {\n padding-left: 80px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-indent-5 {\n padding-right: 80px; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-indent-6 {\n padding-left: 96px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-indent-6 {\n padding-right: 96px; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-indent-7 {\n padding-left: 112px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-indent-7 {\n padding-right: 112px; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-indent-8 {\n padding-left: 128px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-indent-8 {\n padding-right: 128px; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-indent-9 {\n padding-left: 144px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-indent-9 {\n padding-right: 144px; }\n .ag-theme-bootstrap .ag-column-select-header-icon {\n cursor: pointer; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-header-icon:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-bootstrap .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 6px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-bootstrap .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 6px; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-column-group:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-column-group:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-column:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-column:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-column-select-column-group:not(:last-child),\n .ag-theme-bootstrap .ag-column-select-column:not(:last-child) {\n margin-bottom: 4px; }\n .ag-theme-bootstrap .ag-column-select-column-readonly,\n .ag-theme-bootstrap .ag-column-select-column-group-readonly {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n pointer-events: none; }\n .ag-theme-bootstrap .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 20px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 20px; }\n .ag-theme-bootstrap .ag-column-select-list {\n padding: 6px 6px; }\n .ag-theme-bootstrap .ag-rtl {\n text-align: right; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 36px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 36px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-1 {\n padding-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-1 {\n padding-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 60px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 60px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-2 {\n padding-left: 48px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-2 {\n padding-right: 48px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 84px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 84px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-3 {\n padding-left: 72px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-3 {\n padding-right: 72px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 108px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 108px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-4 {\n padding-left: 96px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-4 {\n padding-right: 96px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 132px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 132px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-5 {\n padding-left: 120px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-5 {\n padding-right: 120px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 156px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 156px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-6 {\n padding-left: 144px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-6 {\n padding-right: 144px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 180px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 180px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-7 {\n padding-left: 168px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-7 {\n padding-right: 168px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 204px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 204px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-8 {\n padding-left: 192px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-8 {\n padding-right: 192px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 228px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 228px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-9 {\n padding-left: 216px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-9 {\n padding-right: 216px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 252px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 252px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-10 {\n padding-left: 240px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-10 {\n padding-right: 240px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 276px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 276px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-11 {\n padding-left: 264px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-11 {\n padding-right: 264px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 300px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 300px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-12 {\n padding-left: 288px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-12 {\n padding-right: 288px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 324px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 324px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-13 {\n padding-left: 312px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-13 {\n padding-right: 312px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 348px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 348px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-14 {\n padding-left: 336px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-14 {\n padding-right: 336px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 372px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 372px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-15 {\n padding-left: 360px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-15 {\n padding-right: 360px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 396px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 396px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-16 {\n padding-left: 384px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-16 {\n padding-right: 384px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 420px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 420px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-17 {\n padding-left: 408px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-17 {\n padding-right: 408px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 444px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 444px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-18 {\n padding-left: 432px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-18 {\n padding-right: 432px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 468px; }\n .ag-theme-bootstrap .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 468px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-group-indent-19 {\n padding-left: 456px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-group-indent-19 {\n padding-right: 456px; }\n .ag-theme-bootstrap .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-bootstrap .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-bootstrap .ag-cell {\n -webkit-font-smoothing: subpixel-antialiased; }\n .ag-theme-bootstrap .ag-value-change-delta {\n padding-right: 2px; }\n .ag-theme-bootstrap .ag-value-change-delta-up {\n color: darkgreen;\n color: var(--ag-value-change-delta-up-color, darkgreen); }\n .ag-theme-bootstrap .ag-value-change-delta-down {\n color: darkred;\n color: var(--ag-value-change-delta-down-color, darkred); }\n .ag-theme-bootstrap .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n transition: background-color 1s; }\n .ag-theme-bootstrap .ag-value-change-value-highlight {\n background-color: #cec;\n background-color: var(--ag-value-change-value-highlight-background-color, #cec);\n transition: background-color 0.1s; }\n .ag-theme-bootstrap .ag-cell-data-changed {\n background-color: #cec !important;\n background-color: var(--ag-value-change-value-highlight-background-color, #cec) !important; }\n .ag-theme-bootstrap .ag-cell-data-changed-animation {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-cell-highlight {\n background-color: rgba(136, 255, 136, 0.4) !important;\n background-color: var(--ag-range-selection-highlight-color, rgba(136, 255, 136, 0.4)) !important; }\n .ag-theme-bootstrap .ag-row {\n height: 25px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n color: #000;\n color: var(--ag-data-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-row-highlight-above::after, .ag-theme-bootstrap .ag-row-highlight-below::after {\n content: '';\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #000;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n left: 1px; }\n .ag-theme-bootstrap .ag-row-highlight-above::after {\n top: -1px; }\n .ag-theme-bootstrap .ag-row-highlight-above.ag-row-first::after {\n top: 0; }\n .ag-theme-bootstrap .ag-row-highlight-below::after {\n bottom: 0px; }\n .ag-theme-bootstrap .ag-row-odd {\n background-color: #f6f6f6;\n background-color: var(--ag-odd-row-background-color, #f6f6f6); }\n .ag-theme-bootstrap .ag-ltr .ag-right-aligned-cell {\n text-align: right; }\n .ag-theme-bootstrap .ag-rtl .ag-right-aligned-cell {\n text-align: left; }\n .ag-theme-bootstrap .ag-ltr .ag-right-aligned-cell .ag-cell-value {\n margin-left: auto; }\n .ag-theme-bootstrap .ag-rtl .ag-right-aligned-cell .ag-cell-value {\n margin-right: auto; }\n .ag-theme-bootstrap .ag-cell {\n border: 1px solid transparent;\n line-height: 23px;\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-bootstrap .ag-row > .ag-cell-wrapper {\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-bootstrap .ag-row-dragging {\n cursor: move; }\n .ag-theme-bootstrap .ag-row-dragging {\n opacity: 0.5; }\n .ag-theme-bootstrap .ag-cell-inline-editing {\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n height: 25px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-bootstrap .ag-popup-editor {\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n padding: 0; }\n .ag-theme-bootstrap .ag-large-text-input {\n height: auto;\n padding: 12px; }\n .ag-theme-bootstrap .ag-details-row {\n padding: 20px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-bootstrap .ag-overlay-loading-wrapper {\n background-color: rgba(255, 255, 255, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(255, 255, 255, 0.66)); }\n .ag-theme-bootstrap .ag-overlay-loading-center {\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px; }\n .ag-theme-bootstrap .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px; }\n .ag-theme-bootstrap .ag-loading {\n padding-left: 12px;\n display: flex;\n height: 100%;\n align-items: center; }\n .ag-theme-bootstrap .ag-loading-icon {\n padding-right: 12px; }\n .ag-theme-bootstrap .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear; }\n\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n .ag-theme-bootstrap .ag-ltr .ag-cell {\n border-right: solid transparent; }\n .ag-theme-bootstrap .ag-rtl .ag-cell {\n border-left: solid transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-cell {\n border-right-width: 1px; }\n .ag-theme-bootstrap .ag-rtl .ag-cell {\n border-left-width: 1px; }\n .ag-theme-bootstrap .ag-row-selected {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5); }\n .ag-theme-bootstrap .ag-cell-range-selected:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(0, 0, 0, 0.2)); }\n .ag-theme-bootstrap .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1);\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)); }\n .ag-theme-bootstrap .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1);\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)); }\n .ag-theme-bootstrap .ag-cell-range-selected-1:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(0, 0, 0, 0.2))); }\n .ag-theme-bootstrap .ag-cell-range-selected-2:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(0, 0, 0, 0.36)); }\n .ag-theme-bootstrap .ag-cell-range-selected-3:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(0, 0, 0, 0.488)); }\n .ag-theme-bootstrap .ag-cell-range-selected-4:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(0, 0, 0, 0.5904)); }\n .ag-theme-bootstrap .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #000;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #000;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #000;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #000;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-bootstrap .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-bootstrap .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-bootstrap .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-bootstrap .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-bootstrap .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n outline: initial; }\n .ag-theme-bootstrap .ag-cell.ag-selection-fill-top,\n .ag-theme-bootstrap .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #000;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-bootstrap .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #000;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-bootstrap .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #000;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-cell.ag-selection-fill-bottom,\n .ag-theme-bootstrap .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #000;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-bootstrap .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #000;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-bootstrap .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #000;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-fill-handle, .ag-theme-bootstrap .ag-range-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #000;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-ltr .ag-fill-handle, .ag-theme-bootstrap .ag-ltr .ag-range-handle {\n right: -1px; }\n .ag-theme-bootstrap .ag-rtl .ag-fill-handle, .ag-theme-bootstrap .ag-rtl .ag-range-handle {\n left: -1px; }\n .ag-theme-bootstrap .ag-fill-handle {\n cursor: cell; }\n .ag-theme-bootstrap .ag-range-handle {\n cursor: nwse-resize; }\n .ag-theme-bootstrap .ag-cell-inline-editing {\n border-color: var(--ag-input-focus-border-color) !important; }\n .ag-theme-bootstrap .ag-menu {\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n padding: 0; }\n .ag-theme-bootstrap .ag-menu-list {\n cursor: default;\n width: 100%;\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-bootstrap .ag-menu-option-part {\n padding-top: 6px;\n padding-bottom: 6px;\n line-height: 12px; }\n .ag-theme-bootstrap .ag-menu-option-active {\n background-color: var(--ag-row-hover-color); }\n .ag-theme-bootstrap .ag-menu-option-disabled {\n opacity: 0.5; }\n .ag-theme-bootstrap .ag-menu-option-text {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-menu-option-icon {\n padding-left: 8px;\n padding-right: 4px;\n min-width: 20px; }\n .ag-theme-bootstrap .ag-menu-option-shortcut {\n padding-left: 8px; }\n .ag-theme-bootstrap .ag-menu-separator {\n height: 8px; }\n .ag-theme-bootstrap .ag-menu-separator-cell:after {\n content: \"\";\n display: block; }\n .ag-theme-bootstrap .ag-menu-option-popup-pointer {\n width: 20px;\n text-align: center; }\n .ag-theme-bootstrap .ag-tabs-header {\n min-width: 220px;\n width: 100%;\n display: flex; }\n .ag-theme-bootstrap .ag-tab {\n border-bottom: 0 solid transparent;\n display: flex;\n flex: none;\n align-items: center;\n justify-content: center;\n cursor: pointer; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-tab:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-tab:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-tab-selected {\n border-bottom-color: #000;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #000))); }\n .ag-theme-bootstrap .ag-menu-header {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-filter-condition-operator {\n height: 17px; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 8px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 8px; }\n .ag-theme-bootstrap .ag-set-filter-select-all {\n padding-top: 6px; }\n .ag-theme-bootstrap .ag-set-filter-list {\n height: 120px; }\n .ag-theme-bootstrap .ag-set-filter-filter {\n margin-top: 6px;\n margin-left: 6px;\n margin-right: 6px; }\n .ag-theme-bootstrap .ag-filter-to {\n margin-top: 4px; }\n .ag-theme-bootstrap .ag-mini-filter {\n margin: 6px 6px;\n margin-bottom: 0; }\n .ag-theme-bootstrap .ag-set-filter-item {\n margin: 0px 6px; }\n .ag-theme-bootstrap .ag-ltr .ag-set-filter-item-value {\n margin-left: 6px; }\n .ag-theme-bootstrap .ag-rtl .ag-set-filter-item-value {\n margin-right: 6px; }\n .ag-theme-bootstrap .ag-filter-header-container {\n padding-bottom: 6px; }\n .ag-theme-bootstrap .ag-filter-apply-panel {\n padding: 6px 6px; }\n .ag-theme-bootstrap .ag-filter-apply-panel-button {\n line-height: 1.5; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 8px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 8px; }\n .ag-theme-bootstrap .ag-simple-filter-body-wrapper {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-bootstrap .ag-simple-filter-body-wrapper > * {\n margin-bottom: 4px; }\n .ag-theme-bootstrap .ag-filter-no-matches {\n margin: 6px 6px; }\n .ag-theme-bootstrap .ag-side-bar {\n position: relative; }\n .ag-theme-bootstrap .ag-tool-panel-wrapper {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-bootstrap .ag-side-buttons {\n padding-top: 16px;\n width: 16px;\n position: relative;\n color: #000;\n color: var(--ag-foreground-color, #000);\n overflow: hidden; }\n .ag-theme-bootstrap button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 8px 0 8px 0;\n width: 100%;\n margin: 0;\n min-height: 72px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none; }\n .ag-theme-bootstrap button.ag-side-button-button:focus {\n box-shadow: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-side-button-button:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-side-button-icon-wrapper {\n margin-bottom: 3px; }\n .ag-theme-bootstrap .ag-ltr .ag-side-bar-left .ag-side-button-button,\n .ag-theme-bootstrap .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 0 solid transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-bootstrap .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #000;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #000))); }\n .ag-theme-bootstrap .ag-rtl .ag-side-bar-left .ag-side-button-button,\n .ag-theme-bootstrap .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 0 solid transparent; }\n .ag-theme-bootstrap .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-bootstrap .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #000;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #000))); }\n .ag-theme-bootstrap .ag-filter-toolpanel-header {\n height: 24px; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-header, .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-header, .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 4px; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f112\";\n position: absolute; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-left: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-right: 4px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-0-header {\n height: 32px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-item {\n margin-top: 2px;\n margin-bottom: 2px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-search {\n height: 25px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-search-input {\n flex-grow: 1;\n height: 16px; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 20px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 20px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 36px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 36px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 52px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 52px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 68px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 68px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 84px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 84px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 100px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 100px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 116px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 116px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 132px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 132px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 148px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 148px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 164px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 164px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 4px; }\n .ag-theme-bootstrap .ag-filter-toolpanel-instance-filter {\n padding-top: 4px; }\n .ag-theme-bootstrap .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 4px; }\n .ag-theme-bootstrap .ag-pivot-mode-panel {\n height: 25px;\n display: flex; }\n .ag-theme-bootstrap .ag-pivot-mode-select {\n display: flex;\n align-items: center; }\n .ag-theme-bootstrap .ag-ltr .ag-pivot-mode-select {\n margin-left: 6px; }\n .ag-theme-bootstrap .ag-rtl .ag-pivot-mode-select {\n margin-right: 6px; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-column-select-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-column-select-header {\n height: 25px;\n align-items: center;\n padding: 0 6px; }\n .ag-theme-bootstrap .ag-column-group-icons,\n .ag-theme-bootstrap .ag-column-select-header-icon {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-header {\n background-color: var(--ag-header-background-color); }\n .ag-theme-bootstrap .ag-header-row {\n color: #000;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000))); }\n .ag-theme-bootstrap .ag-header-row {\n height: 25px; }\n .ag-theme-bootstrap .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-bootstrap .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-header-cell,\n .ag-theme-bootstrap .ag-header-group-cell {\n padding-left: 12px;\n padding-right: 12px; }\n .ag-theme-bootstrap .ag-header-cell.ag-header-cell-moving,\n .ag-theme-bootstrap .ag-header-group-cell.ag-header-cell-moving {\n background-color: #bebebe;\n background-color: var(--ag-header-cell-moving-background-color, #bebebe); }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-header-cell:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-header-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none; }\n .ag-theme-bootstrap .ag-keyboard-focus .ag-header-group-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap .ag-header-icon {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-header-expand-icon {\n cursor: pointer; }\n .ag-theme-bootstrap .ag-ltr .ag-header-expand-icon {\n padding-left: 4px; }\n .ag-theme-bootstrap .ag-rtl .ag-header-expand-icon {\n padding-right: 4px; }\n .ag-theme-bootstrap .ag-ltr .ag-header-select-all {\n margin-right: 12px; }\n .ag-theme-bootstrap .ag-rtl .ag-header-select-all {\n margin-left: 12px; }\n .ag-theme-bootstrap .ag-ltr .ag-floating-filter-button {\n margin-left: 12px; }\n .ag-theme-bootstrap .ag-rtl .ag-floating-filter-button {\n margin-right: 12px; }\n .ag-theme-bootstrap .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 12px;\n padding: 0;\n width: 12px; }\n .ag-theme-bootstrap .ag-filter-loading {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n height: 100%;\n padding: 6px 6px;\n position: absolute;\n width: 100%;\n z-index: 1; }\n .ag-theme-bootstrap .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n height: 25px; }\n .ag-theme-bootstrap .ag-paging-panel > * {\n margin: 0 12px; }\n .ag-theme-bootstrap .ag-paging-button {\n cursor: pointer;\n opacity: 0;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n padding: 0;\n width: 12px; }\n .ag-theme-bootstrap .ag-disabled .ag-paging-button {\n cursor: default; }\n .ag-theme-bootstrap .ag-paging-button-wrapper.ag-disabled {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n cursor: default; }\n .ag-theme-bootstrap .ag-paging-button-wrapper, .ag-theme-bootstrap .ag-paging-description {\n margin: 0 4px; }\n .ag-theme-bootstrap .ag-status-bar {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n padding-right: 16px;\n padding-left: 16px;\n line-height: 1.5; }\n .ag-theme-bootstrap .ag-status-name-value-value {\n color: #000;\n color: var(--ag-foreground-color, #000); }\n .ag-theme-bootstrap .ag-status-bar-center {\n text-align: center; }\n .ag-theme-bootstrap .ag-status-name-value {\n margin-left: 4px;\n margin-right: 4px;\n padding-top: 8px;\n padding-bottom: 8px; }\n .ag-theme-bootstrap .ag-column-drop-cell {\n background: #ecf0f1;\n background: var(--ag-chip-background-color, #ecf0f1);\n border-radius: 16px;\n height: 16px;\n padding: 0 2px; }\n .ag-theme-bootstrap .ag-column-drop-cell-text {\n margin: 0 4px; }\n .ag-theme-bootstrap .ag-column-drop-cell-button {\n min-width: 16px;\n margin: 0 2px;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-column-drop-cell-drag-handle {\n margin-left: 8px; }\n .ag-theme-bootstrap .ag-column-drop-cell-ghost {\n opacity: 0.5; }\n .ag-theme-bootstrap .ag-column-drop-horizontal {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n height: 25px; }\n .ag-theme-bootstrap .ag-ltr .ag-column-drop-horizontal {\n padding-left: 12px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-drop-horizontal {\n padding-right: 12px; }\n .ag-theme-bootstrap .ag-column-drop-horizontal-cell-separator {\n margin: 0 4px;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-column-drop-horizontal-empty-message {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5)); }\n .ag-theme-bootstrap .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 12px; }\n .ag-theme-bootstrap .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 12px; }\n .ag-theme-bootstrap .ag-column-drop-vertical-list {\n padding-bottom: 4px;\n padding-right: 4px;\n padding-left: 4px; }\n .ag-theme-bootstrap .ag-column-drop-vertical-cell {\n margin-top: 4px; }\n .ag-theme-bootstrap .ag-column-drop-vertical {\n min-height: 50px;\n max-height: 150px; }\n .ag-theme-bootstrap .ag-column-drop-vertical-icon {\n margin-left: 4px;\n margin-right: 4px; }\n .ag-theme-bootstrap .ag-column-drop-vertical-list {\n position: relative; }\n .ag-theme-bootstrap .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n margin-top: 4px; }\n .ag-theme-bootstrap .ag-select-agg-func-popup {\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n height: 70px;\n padding: 0; }\n .ag-theme-bootstrap .ag-select-agg-func-virtual-list-item {\n cursor: default;\n line-height: 20px;\n padding-left: 8px; }\n .ag-theme-bootstrap .ag-select-agg-func-virtual-list-item:hover {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5); }\n .ag-theme-bootstrap .ag-chart-menu {\n border-radius: 0px;\n background: #FFF;\n background: var(--ag-background-color, #FFF); }\n .ag-theme-bootstrap .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 0px;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap .ag-chart-menu-icon:hover {\n opacity: 1; }\n .ag-theme-bootstrap .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n border-radius: 5px;\n margin: 5px; }\n .ag-theme-bootstrap .ag-chart-mini-thumbnail:nth-last-child(3),\n .ag-theme-bootstrap .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto; }\n .ag-theme-bootstrap .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0; }\n .ag-theme-bootstrap .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0; }\n .ag-theme-bootstrap .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0; }\n .ag-theme-bootstrap .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0; }\n .ag-theme-bootstrap .ag-chart-mini-thumbnail.ag-selected {\n border-color: #000;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-bootstrap .ag-chart-settings-card-item {\n background: #000;\n background: var(--ag-foreground-color, #000);\n width: 8px;\n height: 8px;\n border-radius: 4px; }\n .ag-theme-bootstrap .ag-chart-settings-card-item.ag-selected {\n background-color: #000;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-bootstrap .ag-chart-data-column-drag-handle {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-charts-settings-group-container {\n padding: 4px; }\n .ag-theme-bootstrap .ag-charts-data-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-bootstrap .ag-charts-data-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-bootstrap .ag-charts-format-top-level-group-container {\n margin-left: 8px;\n padding: 4px; }\n .ag-theme-bootstrap .ag-charts-format-top-level-group-item {\n margin: 4px 0; }\n .ag-theme-bootstrap .ag-charts-format-sub-level-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-bootstrap .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-bootstrap .ag-charts-group-container.ag-group-container-horizontal {\n padding: 4px; }\n .ag-theme-bootstrap .ag-chart-data-section,\n .ag-theme-bootstrap .ag-chart-format-section {\n display: flex;\n margin: 0; }\n .ag-theme-bootstrap .ag-chart-menu-panel {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-bootstrap .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-bootstrap .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-bootstrap .ag-date-time-list-page-title {\n flex-grow: 1;\n text-align: center; }\n .ag-theme-bootstrap .ag-date-time-list-page-column-label {\n text-align: center; }\n .ag-theme-bootstrap .ag-date-time-list-page-entry {\n text-align: center; }\n .ag-theme-bootstrap .ag-checkbox-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n flex: none; }\n .ag-theme-bootstrap .ag-checkbox-input-wrapper input, .ag-theme-bootstrap .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-bootstrap .ag-checkbox-input-wrapper:focus-within, .ag-theme-bootstrap .ag-checkbox-input-wrapper:active {\n outline: none; }\n .ag-theme-bootstrap .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-bootstrap .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #000;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-bootstrap .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #000;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-bootstrap .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #000;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000)));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-bootstrap .ag-toggle-button-input-wrapper {\n box-sizing: border-box;\n width: 24px;\n height: 12px;\n background-color: #000;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000)));\n border-radius: 6px;\n position: relative;\n flex: none;\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-bootstrap .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%; }\n .ag-theme-bootstrap .ag-toggle-button-input-wrapper:focus-within {\n outline: none; }\n .ag-theme-bootstrap .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-bootstrap .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #000;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)));\n border-color: #000;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-bootstrap .ag-toggle-button-input-wrapper::before {\n content: ' ';\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n background-color: #FFF;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #FFF));\n border-radius: 6px;\n transition: left 100ms;\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000)))); }\n .ag-theme-bootstrap .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 12px);\n border-color: #000;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-bootstrap .ag-radio-button-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n flex: none;\n border-radius: 12px; }\n .ag-theme-bootstrap .ag-radio-button-input-wrapper input, .ag-theme-bootstrap .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-bootstrap .ag-radio-button-input-wrapper:focus-within, .ag-theme-bootstrap .ag-radio-button-input-wrapper:active {\n outline: none; }\n .ag-theme-bootstrap .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-bootstrap .ag-radio-button-input-wrapper::after {\n content: \"\\f124\";\n color: #000;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-bootstrap .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f125\";\n color: #000;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-bootstrap input[class^='ag-'][type='range'] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible; }\n .ag-theme-bootstrap input[class^='ag-'][type='range']::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px; }\n .ag-theme-bootstrap input[class^='ag-'][type='range']::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px; }\n .ag-theme-bootstrap input[class^='ag-'][type='range']::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px;\n color: transparent;\n width: calc(100% - 2px); }\n .ag-theme-bootstrap input[class^='ag-'][type='range']::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n border-radius: 12px;\n -webkit-transform: translateY(-4.5px);\n transform: translateY(-4.5px); }\n .ag-theme-bootstrap input[class^='ag-'][type='range']::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n border-radius: 12px; }\n .ag-theme-bootstrap input[class^='ag-'][type='range']::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n border-radius: 12px; }\n .ag-theme-bootstrap input[class^='ag-'][type='range']:focus {\n outline: none; }\n .ag-theme-bootstrap input[class^='ag-'][type='range']:focus::-webkit-slider-thumb {\n border-color: #000;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap input[class^='ag-'][type='range']:focus::-ms-thumb {\n border-color: #000;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap input[class^='ag-'][type='range']:focus::-moz-ag-range-thumb {\n border-color: #000;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)); }\n .ag-theme-bootstrap input[class^='ag-'][type='range']:active::-webkit-slider-runnable-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap input[class^='ag-'][type='range']:active::-moz-ag-range-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap input[class^='ag-'][type='range']:active::-ms-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-bootstrap input[class^='ag-'][type='range']:disabled {\n opacity: 0.5; }\n .ag-theme-bootstrap .ag-icon {\n color: #333; }\n .ag-theme-bootstrap .ag-icon-tree-closed::before {\n content: \"\\f10b\"; }\n .ag-theme-bootstrap .ag-icon-tree-open::before {\n content: \"\\f10f\"; }\n .ag-theme-bootstrap .ag-header, .ag-theme-bootstrap .ag-column-drop-cell {\n background-image: none; }\n .ag-theme-bootstrap .ag-tab {\n border: 1px solid transparent;\n padding: 4px 8px;\n margin: 4px;\n margin-bottom: -1px; }\n .ag-theme-bootstrap .ag-tabs-body {\n margin: 2px 0; }\n .ag-theme-bootstrap .ag-icon {\n margin: 1px 1px 2px 1px; }\n .ag-theme-bootstrap .ag-tab-selected {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-bottom-color: transparent; }\n .ag-theme-bootstrap .ag-tabs-header {\n background-color: var(--ag-header-background-color);\n border-bottom: 1px solid;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-bootstrap .ag-filter .ag-filter-apply-panel {\n justify-content: flex-start; }\n .ag-theme-bootstrap .ag-menu-option-active {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5); }\n .ag-theme-bootstrap .ag-column-drop-cell {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 0; }\n .ag-theme-bootstrap .ag-column-drop-cell-button .ag-icon {\n border: 1px solid transparent; }\n .ag-theme-bootstrap .ag-column-drop-cell-button:hover .ag-icon {\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey); }\n .ag-theme-bootstrap .ag-panel-title-bar-button-icon {\n font-size: 20px;\n line-height: 20px; }\n .ag-theme-bootstrap .ag-menu-option-part {\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-bootstrap .ag-column-drop-vertical-title-bar {\n margin-top: 4px;\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-column-drop-vertical-title {\n margin-left: 4px; }\n .ag-theme-bootstrap .ag-column-drop-vertical-empty-message {\n margin-left: 24px; }\n\n", ""]);
  46340. // Exports
  46341. module.exports = exports;
  46342. /***/ }),
  46343. /* 240 */
  46344. /***/ (function(module, exports, __webpack_require__) {
  46345. var api = __webpack_require__(225);
  46346. var content = __webpack_require__(241);
  46347. content = content.__esModule ? content.default : content;
  46348. if (typeof content === 'string') {
  46349. content = [[module.i, content, '']];
  46350. }
  46351. var options = {};
  46352. options.insert = "head";
  46353. options.singleton = false;
  46354. var update = api(content, options);
  46355. module.exports = content.locals || {};
  46356. /***/ }),
  46357. /* 241 */
  46358. /***/ (function(module, exports, __webpack_require__) {
  46359. // Imports
  46360. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227);
  46361. exports = ___CSS_LOADER_API_IMPORT___(false);
  46362. // Module
  46363. exports.push([module.i, ".ag-theme-dark {\n -webkit-font-smoothing: antialiased;\n color: #ccc;\n color: var(--ag-foreground-color, #ccc);\n font-family: \"Helvetica Neue\", sans-serif;\n font-size: 14px;\n line-height: normal; }\n\n@font-face {\n font-family: \"agGridClassic\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABOsAAsAAAAAJiwAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlIAAAReYchjok9TLzIAAANcAAAAQQAAAFZWVlJ+Y21hcAAAA6AAAAHtAAAFgHClDfdnbHlmAAAFkAAACi0AABQQq+8lqmhlYWQAAA/AAAAANAAAADZ2z8SBaGhlYQAAD/QAAAAeAAAAJAfTBChobXR4AAAQFAAAABoAAAEou4L/4mxvY2EAABAwAAAAbwAAAJb7HvWgbWF4cAAAEKAAAAAfAAAAIAFgAHhuYW1lAAAQwAAAATMAAAJS8kTiWnBvc3QAABH0AAABtgAAApcplp2DeJx9k0lyE0EQRX+rZSMPyGDMZMRkRpsh3O5BjSTLltzyQHjBggULNmYBAeFg5ROw5gAEB+AUnIBgyYoDcACCA/Ay1UbGC6tC1VWZP3/+yspSIGlSy+qqUmzuPld9f+/gveZV1fBn/qPrYP/tmz3VDnf4qv6tKQj/qK4FvdCBvgUKXgefK+NhJeyGu+GH8FP4QyGoG3oMekorjFgJc6RUmZrKVdE4tpj1E7VAh8xtt87qgsbcU2ig8+SMiRk445Ke6o7OwNN3np7WQKUM4+wxbzHuauYERK578GeoWcVqrA10ntWENtHYQ0eH6BbeGXzrZI6I6eProy10VNXruK2XRM762SwyK3Ep/1gbvo9894AqHKLa8DfhN75Fsh7am2RKiHgEewaqW9Zwif8U3hRMRGzHa2bR10AmKEx1nZWdLOFk07oN+zO98qwbZUzPqzg88yLqR/a+8+XkOWrtwLUF9iEaRla7kfvkirSDf5KbKvROH/VFX/VdP/VLv3UK6ypeO8Ea3OsnVqZG/Y6jC7ztf1Y76Th3fhz1P2KCcze9NjG+QVlByzaFTqtNyjrCmjp+Ep2GL1CTU68qOSLPm2AdY6yyj0GfLruxxZj2Og/oAeuAeWqxwmxMw37L2V+GyVZDXRe9Wi14LvltWU3tJdV9Zz1vtzxPna/wjThZ5vXZxnsVizGNLA2PylFtHMv4c9SOspmqBqoSeqDmnbXjr6Ag003OMVSS6Ja/gB3vqgUUZOWLnNM5V98pb2rOcbFHBWiOypeces2sk/tos67Y+gsvGGrHAAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMnxi4gDQjSA4A1QYKdAAAAHictdQHTltBFIXh3wXTTEnvvRc6hGp6XQbpiBREOsoqs5O7gZBzPScLIFJG+nw9o+c3b/R8LtAB1OSp1KFap0KO31qttNdr9LTX6/zSvEkXVX0fYo8DjmL0+FirQ+yyz2FU2rO/o6Krm1zlPs80W2GMJeZZZZItxmlpdZEF1phhmg0mmGOKdXaYZZlNtvX7qnav6xkbdGrfbj1Jr+7YRz8DDHKaM5zlHOe5wEUucZkr2u0a17nBTW5xmzvc5Z72f8BDHvGYJzrPkD6HNRvRAzY42Vg54fU5xpbmVye3xls67cLazLQOOje1vjO7vLn9Dzf7D6OZH7Wfnu2Qb7PI0+7amDy3JXlh8/LSVuWVTcpr25I3Ni5vrSV7lv+QfVuUd7Yg721NPtiMfLRpObANObQJ+WRz8tmm5Iuty1fLs3+zWfluy/LDNuXI9AKjUmRWolqQtVZktqJeZL6io8jcRaMga2dB1q6CrN0FWXuKzGP0FmRtFvkmo68ga39B1oGCrIMFWU8VyhJhShVhyhdhShphyhxhSh9hyiFhSiRhyiZhSilhyithSi5hyjBhSjNhyjVhSjhhyjphSj1hyj9h6gSEqScQpu5AmPoEYeoRhKl3EKb+QVj2zbDMTFj7muGCrCNF+56jBSN/AHzNoH4AAAB4nO1Ye2xT1xm/37nEN87D8bUdXwezwLWJDZQCtmNfO4FATIgdQhLWGwhrt0DSGJHHpgaawFRatBIVVrXbHxXTWCiPabMHo9MgSH1IGxJMa6b+sbBJFZVK2/HHVNjI6JZ2k8W97DvHjzyggPrntBufe17fPec73/md3/edcMDhw4f4fs7IcSBLglwuW3mZD+mj+/ZBQtv//vtkhPxuYiIFe2EvijD5T/lPuUVYCQpeRRK8oswyRRZZJokyywQZLrXFxscbNwPf1oh5m65txjzWpuu0PdYGhF9k/LIuWm/czOXm3Mq/whViRfAaMYlu+NkbCeiG7sTZU2TPGz3QrR/vOavdzMmTSTLJFTN51AW1QX3IZOOFsdiFC7GxC41jUJ8rjTVe4Ao47q6O67rBWTk35+Ue41ZyXIHsWgFBsboOArK/EspFmwl42WXAgh1bQtjlgYDorgqUu3nM+T7N5qpx4Y/83VUjyzWyZjY7HGZyW5Qk7ReqCi2qmmpvJ66Ii3yGL/xpZfjifySJmig6HCL5hyjpY/q1ZBJO6jtw2Vm9bjK9luJ6coq4p5UrmKOTALheK9/HdHDldbo1Q5teffLf1aev8zdyKuRU2jJTk3f0ot/XH4YTc/XwPpoevByUH6jFX/Tz0PoQHfTSJN3OWfM/2uwPmvkhk9L14qL38T2IjELOwXEIOskIvLIQDAL+ldvsOEu11+Mlf9O31zyta1A3Pv7ur4uLK8rsvg0+e1kFXIJTtdihX4Y14+N1paWVTk+Fy+dzVVQtqKTDG9gcR/gjOJuAWC3DtUkcV1WOZsPEz8nhlH6ej+rnk7OydAofaEniA620zGV1v5HF8spHsxYghsvdQXcwEAzw/RmLadaMBcmkZmaWoZbT30uxJ2NBS9aCk1kLWlFCJLdw2y5QlVJMFfaK8lG2ShH1CYhy0I0sIYsyH5TFQJCMJvWSJEyp+hi0pPQxlYyyehrrp7AxzeV54Hn+eXqujYDbIRgB2UCBKbAM65PspU8OgwVfpG9WFSxYncElhxmXiAFkLDrAz0+eTejH9eMJ+C4xaVNYOQFdCe6r4p7u2oPQ9wO95GGoH0smp233Lq9wFZyPW43zK1IoYJfskgkBicwGobUQdLsQk17rCuI1CJUg2RXJgMikfyEUUFgJ5UGu9qyNHnpucNvSb9cF6xeZ9D+taPYW1T0WfvzAX0PfXF3UUO17pVX9uv9bT3ZtrYus9D85BFc3N5os9kq5uHY5b1qyyjLvieaDa3Z5GgJLiuFAEQG1wGBy6tcM4W1Bf7zhabujeN2CImN1VZ1/40ub9KO+TqskLZwfaHf+b65FQjwv4UK4FroORg1ZXUNYpm12Jac0QcB4qzxrwE3lJBRR4A5dQdvw/hd/uJ8q+Y0933umoXpdZ/euZ3Zs3ciULWnctbc3VgQboagtFAtVLQl5VvPlvNr84nBLW0nJRs8af/NI85Yz/vg2JWwwKP4eq2RfVBF+qjrUWcOXLlgGhcXzm22FAuEyPMo4px95DT2+VQbRG/SVB4Iq45Qk34/eZ3sq3d6elSV30I/yLDoQ3SI6Fq8gwVqVmC9fDqfTZFIvgSm94dIlrFDxkuxZvziL05zcwmmvqiDT5BI8pCwjH6WSyTT7ISN8WQlOJpMTSUaCJ+/NUKWC7Lovcl/jZK4KPenjlIcYsSLvZSk2n0R3UAZ3Ofr0TKrCBKeQYdFGyLY0p0zF8h3t0JqdjqnD96tovqSaxiytklhas6hwqh15TFXn2rTKLQaARicCuaOq2m1m1PQMi2b46iS/lfGVhIRHQzTYebpHPw7dPWdIDZw8nYmDzlCyJXe/uPsF/y/+n1w1159BpaGMuiwvYs+j4AEL+RkqsdUElQQb6sCDnUGfhxaxC6segXVTOSlgpx95q70+KsbkK0muuxL82KmEvB7yQsRmWxIeibQ2b2rZbcMnEi+qsAARyTxDhdNmCTY1OQ8usFidRgepWFpoL7JbwBpp2dTcGhkJL0FxSzkU2QuXOUhpsdFptToPOpuaghabs8IwjzcTsFQUxSN0XJyptfkozkQru9kAcaPZFPQXWgzznfGmkM3qHHHG406jaHY5lhYSg5nOxFQaCR9FcUuZQAqXOlxmo1BEBUecVluoKe6cb7AU+oMmszHOVjHzvBxBFC9kjCUgLJGs0FciYyE8cfPQYwaUoNctlJPY0eGjV6/iK5kv/Pjl7u6Xu8lvZjXSgvZWN+3i5s2KPZchNz5a5CmwoBYU5E5JeXDseevjmG80fAyuxT7xvR5+/SEBqFYX+2jVMRR//pOYD/O8H5qOVViUAtnEH7nzWz6aSelMNEJjEfrJV12bwsJ2XCIlnAev7bmPYquOKaNQHfuYKv2wtaWza3sNTXJMOZa/L7yKZ7KA7jA9jfAUO4ngzxFb5hw6+T9zpdN3EBY7SDDamwAveBO9vQn9A/2DRC8514ctWOrTX+rDNuzry8YSd1ksYeMWcwEaS9ATZqZOYxF1EWb0CKECemYDflqk8eVKehyZTzSU0+MIU4efHYxu2BAdfFb/bGgw2tAQHRyCCe3NUH00Nti1XYlI0rJ4qH49VjrDEcAafxOlh/TbQ7up9O4hMON3Gz7X3lwmSRGls3swFl0XaspUugbj0fpQDvdR9BMCcjiL2DBMC0iUKTFyo6y2M51Mqfp5FaZ4h5Ygo2qK8l/eVjTewxq4RckteN0KpVQy2Xkurarpc50wha5jvDed7oWwmuHnPE5k9Khhbu39kUIDBAaVWvRHwQKMIBExfOYeyg4mPaFWSuL0BjAHN9p3DlDcHEjx67R3SKUo/adk9eBgbcnFklqaDUxo10mjdA+CyO1kBkIkhiT9tkOE1ZkPMt+VkljyBbwzzMYR85Tk1Tk4IjMwQG9zbGPNFAaL6I6bKQwEBgsb7XHRejXtgalD+d0uyyHgMNvwiLK96zpuNj6dXfff7C10a693d1Lhzm4UViKz8biUxTD3w6PEVGQ+g4GS3nk8VtwJ3BvcGdyX+0LyUAZ+VKXrOSW/v37P4T3r2euR1dR3NGQ/Wb8nj60TWX/oVfACoMhBcvCXCejSTyROa38gsTOZUP50Ks/fA4jjUs5OYxh07XmeKcj+uyKAAH5L9blI3OXTxwZqJiZqBtrRCX8Ii/UP6Y0NFi8YqJ2YqB2A16bxTUbp6BhBpchP9DG8sJzPc8koYp/QO4pIYwS8nrRoO+f2kUz4wNdjwDU2Z0wj0CCjJSOR7UvyMYorI0HG4ZPaFf294YvwNrmiXYHgEJam9YrTnaVHABXTdiI4aXM+LnBzMa4D+dtumxsXLATalo0KQn6Jt/vz3t5gw96sr6dfCKxNAooH8LgyFbufPCEIHTNCgA7BKrQaDNvQn1MH2yHYBBemDuqm0cVvMxhaUaJjhivvEATiWG4y3fmpyWPCnO80ef54r0zL7FHgV7MnablXjTufL8cRcTgc1VuKw//fJvfa5L+BscYKAAAAeJxjYGRgYABi/jvPp8Xz23xl4GZ+ARSI4ny8rwFG///2/xvzZ+ZPQJUcDExAkgEAoUMP6XicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AIAnloHAgAAeJxjYGBgYH5Ba/z/G+3M/f+NgQ4AAPv8MfAAAHicY2AAAgmGIIYshhaGC4wijCGMPYz7GF8xGTGFMVUwTWC6wGzGPIf5BwsfiwZLCcsOlgssL1gnsB5iE2EzYGtim8K2jZ2HXYvdhX0Z+w72fxwRHAUcszhWcGzjOMJxieMZxxfOOi4O0iEAtgsblgB4nGNgZGBg8GLIYeBhAAEmIOYCQgaG/2A+AwAbuAHZAHicfZC9TsMwFIVP+odoBaoEYmAyCwtS+rPRtVKzd+ieJnaaKo2D41bqznPwBDxHn4OnYObEeCkStSXnu9899w4BMMQJAZoT4Ma9zWnhitUvt0n3njvkJ89dDBB67tG/eu7jBQvPA9zhjRuCzjXNI949t3CLD89t+k/PHfLJcxcP+PLco//23McqGHoe4DlQcRaZPJ0XcV3nyVJm+yI2Z+6sWElT57oUk3B85iNZShNbmYr1UdSHbGqtEsronVjo0sqi0KIyeisTG26srWajkfI+TPQOMTJEMMiRYo6Cdc2bI8ESkr29c+ZC7v/OihuMY40SAhP+9/GFfMR86WZiWH5Tzqxx5FvjwKkprYVirZjR2JEWbneTLng1TeV6W5qEPsTGTVWYYcSr/uRDprjpB8WrbRMAeJxtkmdv2zAURX1iyVbstEnTNt17D7VN994z/RUMRctEJFIgKY/8+rJxGiBA36dzHx7uu3xgZ6mzqEHn/7XFEl0SUnr0yVhmwJAVjnCUVdY4xjrHOcFJNjjFac5wlnOc5wIXucRlrnCVa1znBje5xW3ucJd73CfnAQ95xCaPecJTnvGcF7zkFa95w1ve8Z4PfOQTn/nCV77xnR/85Bdb/O4MRVk6VYqgrekJ5+zUd4WXPSmMVFUqx8KFNTlWcmfbzvI9UMXGQUObQgXlam1EUOsH7dbsT65IW1mXNzoK14+irY0fSGuCEzKoIpG2mafSWe+TQnmZqVkjomexrOYq95Xw4+EB5ZvdyL2RruLKdKSdD0npdJOWzrZNEkdCUqlR6FXaxN39yopCmzKrxUzXelcltTJtFrMulFGzkBhr1NDYkIuqslNVpE10Ud1Gm7TRExuyxqmJtq1fc9HM5tttCNbkdjRaPdwwqdPlOCReTNTA19EuL+zU7OPfWMMF7o1lC46pQzzNenBKHb5l1prFKwb/IN9EUOJQBDQWwxSPpGLMDtvM4lcoqGlpmDNil0mn8wcxorJdAAA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n .ag-theme-dark .ag-icon {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n .ag-theme-dark .ag-icon-aggregation:before {\n content: \"\\f101\"; }\n .ag-theme-dark .ag-icon-arrows:before {\n content: \"\\f102\"; }\n .ag-theme-dark .ag-icon-asc:before {\n content: \"\\f103\"; }\n .ag-theme-dark .ag-icon-cancel:before {\n content: \"\\f104\"; }\n .ag-theme-dark .ag-icon-chart:before {\n content: \"\\f105\"; }\n .ag-theme-dark .ag-icon-color-picker:before {\n content: \"\\f109\"; }\n .ag-theme-dark .ag-icon-columns:before {\n content: \"\\f10a\"; }\n .ag-theme-dark .ag-icon-contracted:before {\n content: \"\\f10b\"; }\n .ag-theme-dark .ag-icon-copy:before {\n content: \"\\f10c\"; }\n .ag-theme-dark .ag-icon-cross:before {\n content: \"\\f10d\"; }\n .ag-theme-dark .ag-icon-desc:before {\n content: \"\\f10e\"; }\n .ag-theme-dark .ag-icon-expanded:before {\n content: \"\\f10f\"; }\n .ag-theme-dark .ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n .ag-theme-dark .ag-icon-eye:before {\n content: \"\\f111\"; }\n .ag-theme-dark .ag-icon-filter:before {\n content: \"\\f112\"; }\n .ag-theme-dark .ag-icon-first:before {\n content: \"\\f113\"; }\n .ag-theme-dark .ag-icon-grip:before {\n content: \"\\f114\"; }\n .ag-theme-dark .ag-icon-group:before {\n content: \"\\f115\"; }\n .ag-theme-dark .ag-icon-last:before {\n content: \"\\f116\"; }\n .ag-theme-dark .ag-icon-left:before {\n content: \"\\f117\"; }\n .ag-theme-dark .ag-icon-linked:before {\n content: \"\\f118\"; }\n .ag-theme-dark .ag-icon-loading:before {\n content: \"\\f119\"; }\n .ag-theme-dark .ag-icon-maximize:before {\n content: \"\\f11a\"; }\n .ag-theme-dark .ag-icon-menu:before {\n content: \"\\f11b\"; }\n .ag-theme-dark .ag-icon-minimize:before {\n content: \"\\f11c\"; }\n .ag-theme-dark .ag-icon-next:before {\n content: \"\\f11d\"; }\n .ag-theme-dark .ag-icon-none:before {\n content: \"\\f11e\"; }\n .ag-theme-dark .ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n .ag-theme-dark .ag-icon-paste:before {\n content: \"\\f120\"; }\n .ag-theme-dark .ag-icon-pin:before {\n content: \"\\f121\"; }\n .ag-theme-dark .ag-icon-pivot:before {\n content: \"\\f122\"; }\n .ag-theme-dark .ag-icon-previous:before {\n content: \"\\f123\"; }\n .ag-theme-dark .ag-icon-right:before {\n content: \"\\f126\"; }\n .ag-theme-dark .ag-icon-save:before {\n content: \"\\f127\"; }\n .ag-theme-dark .ag-icon-small-down:before {\n content: \"\\f128\"; }\n .ag-theme-dark .ag-icon-small-left:before {\n content: \"\\f129\"; }\n .ag-theme-dark .ag-icon-small-right:before {\n content: \"\\f12a\"; }\n .ag-theme-dark .ag-icon-small-up:before {\n content: \"\\f12b\"; }\n .ag-theme-dark .ag-icon-tick:before {\n content: \"\\f12c\"; }\n .ag-theme-dark .ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n .ag-theme-dark .ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n .ag-theme-dark .ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n .ag-theme-dark .ag-icon-unlinked:before {\n content: \"\\f130\"; }\n .ag-theme-dark .ag-icon-row-drag:before {\n content: \"\\f114\"; }\n .ag-theme-dark .ag-right-arrow:before {\n content: \"\\f117\"; }\n .ag-theme-dark .ag-right-arrow:before {\n content: \"\\f126\"; }\n .ag-theme-dark .ag-root-wrapper {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e); }\n .ag-theme-dark [class^='ag-'], .ag-theme-dark [class^='ag-']:focus, .ag-theme-dark [class^='ag-']:after, .ag-theme-dark [class^='ag-']:before {\n box-sizing: border-box;\n outline: none; }\n .ag-theme-dark [class^='ag-']::-ms-clear {\n display: none; }\n .ag-theme-dark .ag-checkbox .ag-input-wrapper,\n .ag-theme-dark .ag-radio-button .ag-input-wrapper {\n overflow: visible; }\n .ag-theme-dark .ag-range-field .ag-input-wrapper {\n height: 100%; }\n .ag-theme-dark .ag-toggle-button {\n flex: none;\n width: unset;\n min-width: unset; }\n .ag-theme-dark .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 4px; }\n .ag-theme-dark .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 4px; }\n .ag-theme-dark input[class^='ag-'] {\n margin: 0;\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e); }\n .ag-theme-dark textarea[class^='ag-'],\n .ag-theme-dark select[class^='ag-'] {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e); }\n .ag-theme-dark input[class^='ag-']:not([type]),\n .ag-theme-dark input[class^='ag-'][type='text'],\n .ag-theme-dark input[class^='ag-'][type='number'],\n .ag-theme-dark input[class^='ag-'][type='tel'],\n .ag-theme-dark input[class^='ag-'][type='date'],\n .ag-theme-dark input[class^='ag-'][type='datetime-local'],\n .ag-theme-dark textarea[class^='ag-'] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #000;\n border-color: var(--ag-input-border-color, #000); }\n .ag-theme-dark input[class^='ag-']:not([type]):disabled,\n .ag-theme-dark input[class^='ag-'][type='text']:disabled,\n .ag-theme-dark input[class^='ag-'][type='number']:disabled,\n .ag-theme-dark input[class^='ag-'][type='tel']:disabled,\n .ag-theme-dark input[class^='ag-'][type='date']:disabled,\n .ag-theme-dark input[class^='ag-'][type='datetime-local']:disabled,\n .ag-theme-dark textarea[class^='ag-']:disabled {\n color: rgba(204, 204, 204, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(204, 204, 204, 0.5));\n background-color: rgba(48, 46, 46, 0.3);\n background-color: var(--ag-input-disabled-background-color, rgba(48, 46, 46, 0.3));\n border-color: rgba(0, 0, 0, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(0, 0, 0, 0.3)); }\n .ag-theme-dark input[class^='ag-']:not([type]):focus,\n .ag-theme-dark input[class^='ag-'][type='text']:focus,\n .ag-theme-dark input[class^='ag-'][type='number']:focus,\n .ag-theme-dark input[class^='ag-'][type='tel']:focus,\n .ag-theme-dark input[class^='ag-'][type='date']:focus,\n .ag-theme-dark input[class^='ag-'][type='datetime-local']:focus,\n .ag-theme-dark textarea[class^='ag-']:focus {\n outline: none;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark input[class^='ag-'][type='number'] {\n -moz-appearance: textfield; }\n .ag-theme-dark input[class^='ag-'][type='number']::-webkit-outer-spin-button, .ag-theme-dark input[class^='ag-'][type='number']::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0; }\n .ag-theme-dark input[class^='ag-'][type='range'] {\n padding: 0; }\n .ag-theme-dark .ag-drag-handle {\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-list-item, .ag-theme-dark .ag-virtual-list-item {\n height: 20px; }\n .ag-theme-dark .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-virtual-list-item:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-select-list {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n overflow-y: auto;\n overflow-x: hidden; }\n .ag-theme-dark .ag-list-item {\n display: flex;\n align-items: center; }\n .ag-theme-dark .ag-list-item.ag-active-item {\n background-color: var(--ag-row-hover-color); }\n .ag-theme-dark .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n .ag-theme-dark .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden; }\n .ag-theme-dark .ag-select .ag-picker-field-wrapper {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n min-height: 20px;\n cursor: default; }\n .ag-theme-dark .ag-select:not(.ag-cell-editor) {\n height: 20px; }\n .ag-theme-dark .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis; }\n .ag-theme-dark .ag-select .ag-picker-field-icon {\n display: flex;\n align-items: center; }\n .ag-theme-dark .ag-select.ag-disabled {\n opacity: 0.5; }\n .ag-theme-dark .ag-rich-select {\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e); }\n .ag-theme-dark .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 162.5px; }\n .ag-theme-dark .ag-rich-select-value {\n padding: 0 4px 0 12px;\n height: 25px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-dark .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 20px; }\n .ag-theme-dark .ag-rich-select-virtual-list-item:hover {\n background-color: var(--ag-row-hover-color); }\n .ag-theme-dark .ag-rich-select-row {\n padding-left: 12px; }\n .ag-theme-dark .ag-rich-select-row-selected {\n background-color: #4a708b;\n background-color: var(--ag-selected-row-background-color, #4a708b); }\n .ag-theme-dark .ag-row-drag,\n .ag-theme-dark .ag-selection-checkbox,\n .ag-theme-dark .ag-group-expanded,\n .ag-theme-dark .ag-group-contracted {\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-ltr .ag-row-drag, .ag-theme-dark .ag-ltr .ag-selection-checkbox, .ag-theme-dark .ag-ltr .ag-group-expanded, .ag-theme-dark .ag-ltr .ag-group-contracted {\n margin-right: 12px; }\n .ag-theme-dark .ag-rtl .ag-row-drag, .ag-theme-dark .ag-rtl .ag-selection-checkbox, .ag-theme-dark .ag-rtl .ag-group-expanded, .ag-theme-dark .ag-rtl .ag-group-contracted {\n margin-left: 12px; }\n .ag-theme-dark .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: 23px;\n display: flex;\n align-items: center;\n flex: none; }\n .ag-theme-dark .ag-group-expanded,\n .ag-theme-dark .ag-group-contracted {\n cursor: pointer; }\n .ag-theme-dark .ag-group-title-bar-icon {\n cursor: pointer;\n flex: none;\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-ltr .ag-group-child-count {\n margin-left: 2px; }\n .ag-theme-dark .ag-rtl .ag-group-child-count {\n margin-right: 2px; }\n .ag-theme-dark .ag-group-title-bar {\n background-color: #201f1f;\n background-color: var(--ag-subheader-background-color, #201f1f);\n padding: 4px; }\n .ag-theme-dark .ag-group-toolbar {\n padding: 4px; }\n .ag-theme-dark .ag-disabled-group-title-bar, .ag-theme-dark .ag-disabled-group-container {\n opacity: 0.5; }\n .ag-theme-dark .group-item {\n margin: 2px 0; }\n .ag-theme-dark .ag-label {\n white-space: nowrap; }\n .ag-theme-dark .ag-ltr .ag-label {\n margin-right: 4px; }\n .ag-theme-dark .ag-rtl .ag-label {\n margin-left: 4px; }\n .ag-theme-dark .ag-label-align-top .ag-label {\n margin-bottom: 2px; }\n .ag-theme-dark .ag-ltr .ag-slider-field, .ag-theme-dark .ag-ltr .ag-angle-select-field {\n margin-right: 8px; }\n .ag-theme-dark .ag-rtl .ag-slider-field, .ag-theme-dark .ag-rtl .ag-angle-select-field {\n margin-left: 8px; }\n .ag-theme-dark .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e); }\n .ag-theme-dark .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #ccc;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 5px; }\n .ag-theme-dark .ag-picker-field-button {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-dialog.ag-color-dialog {\n border-radius: 5px; }\n .ag-theme-dark .ag-color-picker .ag-picker-field-display {\n height: 12px; }\n .ag-theme-dark .ag-color-panel {\n padding: 4px; }\n .ag-theme-dark .ag-spectrum-color {\n background-color: red;\n border-radius: 2px; }\n .ag-theme-dark .ag-spectrum-tools {\n padding: 10px; }\n .ag-theme-dark .ag-spectrum-sat {\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0)); }\n .ag-theme-dark .ag-spectrum-val {\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0)); }\n .ag-theme-dark .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24); }\n .ag-theme-dark .ag-spectrum-hue-background {\n border-radius: 2px; }\n .ag-theme-dark .ag-spectrum-alpha-background {\n border-radius: 2px; }\n .ag-theme-dark .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px; }\n .ag-theme-dark .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37); }\n .ag-theme-dark .ag-recent-color {\n margin: 0 3px; }\n .ag-theme-dark .ag-recent-color:first-child {\n margin-left: 0; }\n .ag-theme-dark .ag-recent-color:last-child {\n margin-right: 0; }\n .ag-theme-dark.ag-dnd-ghost {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n overflow: hidden;\n text-overflow: ellipsis;\n z-index: 10;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n height: 25px !important;\n line-height: 25px;\n margin: 0;\n padding: 0 8px;\n -webkit-transform: translateY(8px);\n transform: translateY(8px); }\n .ag-theme-dark .ag-dnd-ghost-icon {\n margin-right: 4px;\n color: #ccc;\n color: var(--ag-foreground-color, #ccc); }\n .ag-theme-dark .ag-popup-child:not(.ag-tooltip-custom) {\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3); }\n .ag-dragging-range-handle .ag-theme-dark .ag-dialog,\n .ag-dragging-fill-handle .ag-theme-dark .ag-dialog {\n opacity: 0.7;\n pointer-events: none; }\n .ag-theme-dark .ag-dialog {\n border-radius: 0px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-panel {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e); }\n .ag-theme-dark .ag-panel-title-bar {\n background-color: #626262;\n background-color: var(--ag-header-background-color, #626262);\n color: #ccc;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)));\n height: 25px;\n padding: 4px 12px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-ltr .ag-panel-title-bar-button {\n margin-left: 4px; }\n .ag-theme-dark .ag-rtl .ag-panel-title-bar-button {\n margin-right: 4px; }\n .ag-theme-dark .ag-tooltip {\n background-color: #626262;\n background-color: var(--ag-header-background-color, #626262);\n color: #ccc;\n color: var(--ag-foreground-color, #ccc);\n padding: 4px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n transition: opacity 1s; }\n .ag-theme-dark .ag-tooltip.ag-tooltip-hiding {\n opacity: 0; }\n .ag-theme-dark .ag-ltr .ag-column-select-indent-1 {\n padding-left: 16px; }\n .ag-theme-dark .ag-rtl .ag-column-select-indent-1 {\n padding-right: 16px; }\n .ag-theme-dark .ag-ltr .ag-column-select-indent-2 {\n padding-left: 32px; }\n .ag-theme-dark .ag-rtl .ag-column-select-indent-2 {\n padding-right: 32px; }\n .ag-theme-dark .ag-ltr .ag-column-select-indent-3 {\n padding-left: 48px; }\n .ag-theme-dark .ag-rtl .ag-column-select-indent-3 {\n padding-right: 48px; }\n .ag-theme-dark .ag-ltr .ag-column-select-indent-4 {\n padding-left: 64px; }\n .ag-theme-dark .ag-rtl .ag-column-select-indent-4 {\n padding-right: 64px; }\n .ag-theme-dark .ag-ltr .ag-column-select-indent-5 {\n padding-left: 80px; }\n .ag-theme-dark .ag-rtl .ag-column-select-indent-5 {\n padding-right: 80px; }\n .ag-theme-dark .ag-ltr .ag-column-select-indent-6 {\n padding-left: 96px; }\n .ag-theme-dark .ag-rtl .ag-column-select-indent-6 {\n padding-right: 96px; }\n .ag-theme-dark .ag-ltr .ag-column-select-indent-7 {\n padding-left: 112px; }\n .ag-theme-dark .ag-rtl .ag-column-select-indent-7 {\n padding-right: 112px; }\n .ag-theme-dark .ag-ltr .ag-column-select-indent-8 {\n padding-left: 128px; }\n .ag-theme-dark .ag-rtl .ag-column-select-indent-8 {\n padding-right: 128px; }\n .ag-theme-dark .ag-ltr .ag-column-select-indent-9 {\n padding-left: 144px; }\n .ag-theme-dark .ag-rtl .ag-column-select-indent-9 {\n padding-right: 144px; }\n .ag-theme-dark .ag-column-select-header-icon {\n cursor: pointer; }\n .ag-theme-dark .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-column-select-header-icon:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-dark .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 6px; }\n .ag-theme-dark .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-dark .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 6px; }\n .ag-theme-dark .ag-keyboard-focus .ag-column-select-column-group:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-column-select-column-group:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-keyboard-focus .ag-column-select-column:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-column-select-column:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-column-select-column-group:not(:last-child),\n .ag-theme-dark .ag-column-select-column:not(:last-child) {\n margin-bottom: 4px; }\n .ag-theme-dark .ag-column-select-column-readonly,\n .ag-theme-dark .ag-column-select-column-group-readonly {\n color: rgba(204, 204, 204, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(204, 204, 204, 0.5));\n pointer-events: none; }\n .ag-theme-dark .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 20px; }\n .ag-theme-dark .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 20px; }\n .ag-theme-dark .ag-column-select-list {\n padding: 6px 6px; }\n .ag-theme-dark .ag-rtl {\n text-align: right; }\n .ag-theme-dark .ag-root-wrapper {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 0px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 36px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 36px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-1 {\n padding-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-1 {\n padding-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 60px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 60px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-2 {\n padding-left: 48px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-2 {\n padding-right: 48px; }\n .ag-theme-dark .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 84px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 84px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-3 {\n padding-left: 72px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-3 {\n padding-right: 72px; }\n .ag-theme-dark .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 108px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 108px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-4 {\n padding-left: 96px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-4 {\n padding-right: 96px; }\n .ag-theme-dark .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 132px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 132px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-5 {\n padding-left: 120px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-5 {\n padding-right: 120px; }\n .ag-theme-dark .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 156px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 156px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-6 {\n padding-left: 144px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-6 {\n padding-right: 144px; }\n .ag-theme-dark .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 180px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 180px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-7 {\n padding-left: 168px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-7 {\n padding-right: 168px; }\n .ag-theme-dark .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 204px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 204px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-8 {\n padding-left: 192px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-8 {\n padding-right: 192px; }\n .ag-theme-dark .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 228px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 228px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-9 {\n padding-left: 216px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-9 {\n padding-right: 216px; }\n .ag-theme-dark .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 252px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 252px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-10 {\n padding-left: 240px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-10 {\n padding-right: 240px; }\n .ag-theme-dark .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 276px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 276px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-11 {\n padding-left: 264px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-11 {\n padding-right: 264px; }\n .ag-theme-dark .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 300px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 300px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-12 {\n padding-left: 288px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-12 {\n padding-right: 288px; }\n .ag-theme-dark .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 324px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 324px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-13 {\n padding-left: 312px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-13 {\n padding-right: 312px; }\n .ag-theme-dark .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 348px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 348px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-14 {\n padding-left: 336px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-14 {\n padding-right: 336px; }\n .ag-theme-dark .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 372px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 372px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-15 {\n padding-left: 360px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-15 {\n padding-right: 360px; }\n .ag-theme-dark .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 396px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 396px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-16 {\n padding-left: 384px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-16 {\n padding-right: 384px; }\n .ag-theme-dark .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 420px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 420px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-17 {\n padding-left: 408px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-17 {\n padding-right: 408px; }\n .ag-theme-dark .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 444px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 444px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-18 {\n padding-left: 432px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-18 {\n padding-right: 432px; }\n .ag-theme-dark .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 468px; }\n .ag-theme-dark .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 468px; }\n .ag-theme-dark .ag-ltr .ag-row-group-indent-19 {\n padding-left: 456px; }\n .ag-theme-dark .ag-rtl .ag-row-group-indent-19 {\n padding-right: 456px; }\n .ag-theme-dark .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-dark .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-dark .ag-cell {\n -webkit-font-smoothing: subpixel-antialiased; }\n .ag-theme-dark .ag-value-change-delta {\n padding-right: 2px; }\n .ag-theme-dark .ag-value-change-delta-up {\n color: greenyellow;\n color: var(--ag-value-change-delta-up-color, greenyellow); }\n .ag-theme-dark .ag-value-change-delta-down {\n color: red;\n color: var(--ag-value-change-delta-down-color, red); }\n .ag-theme-dark .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n transition: background-color 1s; }\n .ag-theme-dark .ag-value-change-value-highlight {\n background-color: chocolate;\n background-color: var(--ag-value-change-value-highlight-background-color, chocolate);\n transition: background-color 0.1s; }\n .ag-theme-dark .ag-cell-data-changed {\n background-color: chocolate !important;\n background-color: var(--ag-value-change-value-highlight-background-color, chocolate) !important; }\n .ag-theme-dark .ag-cell-data-changed-animation {\n background-color: transparent; }\n .ag-theme-dark .ag-cell-highlight {\n background-color: rgba(255, 255, 255, 0.4) !important;\n background-color: var(--ag-range-selection-highlight-color, rgba(255, 255, 255, 0.4)) !important; }\n .ag-theme-dark .ag-row {\n height: 25px;\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n color: #ccc;\n color: var(--ag-data-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-row-highlight-above::after, .ag-theme-dark .ag-row-highlight-below::after {\n content: '';\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #ccc;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc));\n left: 1px; }\n .ag-theme-dark .ag-row-highlight-above::after {\n top: -1px; }\n .ag-theme-dark .ag-row-highlight-above.ag-row-first::after {\n top: 0; }\n .ag-theme-dark .ag-row-highlight-below::after {\n bottom: 0px; }\n .ag-theme-dark .ag-row-odd {\n background-color: #403e3e;\n background-color: var(--ag-odd-row-background-color, #403e3e); }\n .ag-theme-dark .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-ltr .ag-right-aligned-cell {\n text-align: right; }\n .ag-theme-dark .ag-rtl .ag-right-aligned-cell {\n text-align: left; }\n .ag-theme-dark .ag-ltr .ag-right-aligned-cell .ag-cell-value {\n margin-left: auto; }\n .ag-theme-dark .ag-rtl .ag-right-aligned-cell .ag-cell-value {\n margin-right: auto; }\n .ag-theme-dark .ag-cell {\n border: 1px solid transparent;\n line-height: 23px;\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-dark .ag-row > .ag-cell-wrapper {\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-dark .ag-row-dragging {\n cursor: move; }\n .ag-theme-dark .ag-row-dragging {\n opacity: 0.5; }\n .ag-theme-dark .ag-cell-inline-editing {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n height: 25px;\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e); }\n .ag-theme-dark .ag-popup-editor {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e);\n padding: 0; }\n .ag-theme-dark .ag-large-text-input {\n height: auto;\n padding: 12px; }\n .ag-theme-dark .ag-details-row {\n padding: 20px;\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e); }\n .ag-theme-dark .ag-overlay-loading-wrapper {\n background-color: rgba(48, 46, 46, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(48, 46, 46, 0.66)); }\n .ag-theme-dark .ag-overlay-loading-center {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px; }\n .ag-theme-dark .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px; }\n .ag-theme-dark .ag-loading {\n padding-left: 12px;\n display: flex;\n height: 100%;\n align-items: center; }\n .ag-theme-dark .ag-loading-icon {\n padding-right: 12px; }\n .ag-theme-dark .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear; }\n\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n .ag-theme-dark .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-ltr .ag-cell {\n border-right: dotted grey; }\n .ag-theme-dark .ag-rtl .ag-cell {\n border-left: dotted grey; }\n .ag-theme-dark .ag-ltr .ag-cell {\n border-right-width: 1px; }\n .ag-theme-dark .ag-rtl .ag-cell {\n border-left-width: 1px; }\n .ag-theme-dark .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-row-selected {\n background-color: #4a708b;\n background-color: var(--ag-selected-row-background-color, #4a708b); }\n .ag-theme-dark .ag-cell-range-selected:not(.ag-cell-focus) {\n background-color: rgba(100, 160, 160, 0.4);\n background-color: var(--ag-range-selection-background-color, rgba(100, 160, 160, 0.4)); }\n .ag-theme-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1);\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)); }\n .ag-theme-dark .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1);\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)); }\n .ag-theme-dark .ag-cell-range-selected-1:not(.ag-cell-focus) {\n background-color: rgba(100, 160, 160, 0.4);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(100, 160, 160, 0.4))); }\n .ag-theme-dark .ag-cell-range-selected-2:not(.ag-cell-focus) {\n background-color: rgba(100, 160, 160, 0.64);\n background-color: var(--ag-range-selection-background-color-2, rgba(100, 160, 160, 0.64)); }\n .ag-theme-dark .ag-cell-range-selected-3:not(.ag-cell-focus) {\n background-color: rgba(100, 160, 160, 0.784);\n background-color: var(--ag-range-selection-background-color-3, rgba(100, 160, 160, 0.784)); }\n .ag-theme-dark .ag-cell-range-selected-4:not(.ag-cell-focus) {\n background-color: rgba(100, 160, 160, 0.8704);\n background-color: var(--ag-range-selection-background-color-4, rgba(100, 160, 160, 0.8704)); }\n .ag-theme-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #ccc;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #ccc;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #ccc;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #ccc;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-dark .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-dark .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-dark .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-dark .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-dark .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #ccc;\n border-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc));\n outline: initial; }\n .ag-theme-dark .ag-cell.ag-selection-fill-top,\n .ag-theme-dark .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #ccc;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-dark .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #ccc;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-dark .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #ccc;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-cell.ag-selection-fill-bottom,\n .ag-theme-dark .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #ccc;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-dark .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #ccc;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-dark .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #ccc;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-fill-handle, .ag-theme-dark .ag-range-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #ccc;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-ltr .ag-fill-handle, .ag-theme-dark .ag-ltr .ag-range-handle {\n right: -1px; }\n .ag-theme-dark .ag-rtl .ag-fill-handle, .ag-theme-dark .ag-rtl .ag-range-handle {\n left: -1px; }\n .ag-theme-dark .ag-fill-handle {\n cursor: cell; }\n .ag-theme-dark .ag-range-handle {\n cursor: nwse-resize; }\n .ag-theme-dark .ag-cell-inline-editing {\n border-color: var(--ag-input-focus-border-color) !important; }\n .ag-theme-dark .ag-menu {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n padding: 0; }\n .ag-theme-dark .ag-menu-list {\n cursor: default;\n width: 100%;\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-dark .ag-menu-option-part {\n padding-top: 6px;\n padding-bottom: 6px;\n line-height: 12px; }\n .ag-theme-dark .ag-menu-option-active {\n background-color: var(--ag-row-hover-color); }\n .ag-theme-dark .ag-menu-option-disabled {\n opacity: 0.5; }\n .ag-theme-dark .ag-menu-option-text {\n margin-left: 4px; }\n .ag-theme-dark .ag-menu-option-icon {\n padding-left: 8px;\n padding-right: 4px;\n min-width: 20px; }\n .ag-theme-dark .ag-menu-option-shortcut {\n padding-left: 8px; }\n .ag-theme-dark .ag-menu-separator {\n height: 8px; }\n .ag-theme-dark .ag-menu-separator-cell:after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-menu-option-popup-pointer {\n width: 20px;\n text-align: center; }\n .ag-theme-dark .ag-tabs-header {\n min-width: 220px;\n width: 100%;\n display: flex; }\n .ag-theme-dark .ag-tab {\n border-bottom: 0 solid transparent;\n display: flex;\n flex: none;\n align-items: center;\n justify-content: center;\n cursor: pointer; }\n .ag-theme-dark .ag-keyboard-focus .ag-tab:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-tab:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-tab-selected {\n border-bottom-color: #ccc;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc))); }\n .ag-theme-dark .ag-menu-header {\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-filter-condition-operator {\n height: 17px; }\n .ag-theme-dark .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 8px; }\n .ag-theme-dark .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 8px; }\n .ag-theme-dark .ag-set-filter-select-all {\n padding-top: 6px; }\n .ag-theme-dark .ag-set-filter-list {\n height: 120px; }\n .ag-theme-dark .ag-set-filter-filter {\n margin-top: 6px;\n margin-left: 6px;\n margin-right: 6px; }\n .ag-theme-dark .ag-filter-to {\n margin-top: 4px; }\n .ag-theme-dark .ag-mini-filter {\n margin: 6px 6px;\n margin-bottom: 0; }\n .ag-theme-dark .ag-set-filter-item {\n margin: 0px 6px; }\n .ag-theme-dark .ag-ltr .ag-set-filter-item-value {\n margin-left: 6px; }\n .ag-theme-dark .ag-rtl .ag-set-filter-item-value {\n margin-right: 6px; }\n .ag-theme-dark .ag-filter-header-container {\n padding-bottom: 6px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-dark .ag-filter-apply-panel {\n padding: 6px 6px;\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-dark .ag-filter-apply-panel-button {\n line-height: 1.5; }\n .ag-theme-dark .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 8px; }\n .ag-theme-dark .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 8px; }\n .ag-theme-dark .ag-simple-filter-body-wrapper {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-dark .ag-simple-filter-body-wrapper > * {\n margin-bottom: 4px; }\n .ag-theme-dark .ag-filter-no-matches {\n margin: 6px 6px; }\n .ag-theme-dark .ag-side-bar {\n position: relative; }\n .ag-theme-dark .ag-tool-panel-wrapper {\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e); }\n .ag-theme-dark .ag-side-buttons {\n padding-top: 16px;\n width: 16px;\n position: relative;\n color: #ccc;\n color: var(--ag-foreground-color, #ccc);\n overflow: hidden; }\n .ag-theme-dark button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 8px 0 8px 0;\n width: calc(100% + 1px);\n margin: 0;\n min-height: 72px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none;\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark button.ag-side-button-button:focus {\n box-shadow: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-side-button-button:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-selected .ag-side-button-button {\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e);\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-side-button-icon-wrapper {\n margin-bottom: 3px; }\n .ag-theme-dark .ag-ltr .ag-side-bar-left,\n .ag-theme-dark .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-dark .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-ltr .ag-side-bar-left .ag-side-button-button,\n .ag-theme-dark .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 0 solid transparent;\n margin-right: -1px;\n padding-right: 1px; }\n .ag-theme-dark .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-dark .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #ccc;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc))); }\n .ag-theme-dark .ag-rtl .ag-side-bar-left,\n .ag-theme-dark .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-dark .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-rtl .ag-side-bar-left .ag-side-button-button,\n .ag-theme-dark .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 0 solid transparent;\n margin-left: -1px;\n padding-left: 1px; }\n .ag-theme-dark .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-dark .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #ccc;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #ccc))); }\n .ag-theme-dark .ag-filter-toolpanel-header {\n height: 24px; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-header, .ag-theme-dark .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 4px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-header, .ag-theme-dark .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 4px; }\n .ag-theme-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f112\";\n position: absolute; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-left: 4px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-right: 4px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-0-header {\n height: 32px; }\n .ag-theme-dark .ag-filter-toolpanel-group-item {\n margin-top: 2px;\n margin-bottom: 2px; }\n .ag-theme-dark .ag-filter-toolpanel-search {\n height: 25px; }\n .ag-theme-dark .ag-filter-toolpanel-search-input {\n flex-grow: 1;\n height: 16px; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 4px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 4px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 4px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 4px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 20px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 20px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 36px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 36px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 52px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 52px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 68px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 68px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 84px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 84px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 100px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 100px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 116px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 116px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 132px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 132px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 148px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 148px; }\n .ag-theme-dark .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 164px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 164px; }\n .ag-theme-dark .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 4px; }\n .ag-theme-dark .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n padding-top: 4px; }\n .ag-theme-dark .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 4px; }\n .ag-theme-dark .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 4px; }\n .ag-theme-dark .ag-pivot-mode-panel {\n height: 25px;\n display: flex; }\n .ag-theme-dark .ag-pivot-mode-select {\n display: flex;\n align-items: center; }\n .ag-theme-dark .ag-ltr .ag-pivot-mode-select {\n margin-left: 6px; }\n .ag-theme-dark .ag-rtl .ag-pivot-mode-select {\n margin-right: 6px; }\n .ag-theme-dark .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-column-select-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-column-select-header {\n height: 25px;\n align-items: center;\n padding: 0 6px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-dark .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-dark .ag-column-group-icons,\n .ag-theme-dark .ag-column-select-header-icon {\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-header {\n background-color: #626262;\n background-color: var(--ag-header-background-color, #626262);\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-header-row {\n color: #ccc;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc))); }\n .ag-theme-dark .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-header-row {\n height: 25px; }\n .ag-theme-dark .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-dark .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-dark .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-dark .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-dark .ag-header-cell,\n .ag-theme-dark .ag-header-group-cell {\n padding-left: 12px;\n padding-right: 12px; }\n .ag-theme-dark .ag-header-cell.ag-header-cell-moving,\n .ag-theme-dark .ag-header-group-cell.ag-header-cell-moving {\n background-color: #bebebe;\n background-color: var(--ag-header-cell-moving-background-color, #bebebe); }\n .ag-theme-dark .ag-keyboard-focus .ag-header-cell:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-header-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none; }\n .ag-theme-dark .ag-keyboard-focus .ag-header-group-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark .ag-header-icon {\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-header-expand-icon {\n cursor: pointer; }\n .ag-theme-dark .ag-ltr .ag-header-expand-icon {\n padding-left: 4px; }\n .ag-theme-dark .ag-rtl .ag-header-expand-icon {\n padding-right: 4px; }\n .ag-theme-dark .ag-header-row:not(:first-child) .ag-header-cell,\n .ag-theme-dark .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-header-cell::after,\n .ag-theme-dark .ag-header-group-cell::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n width: 1px;\n height: 100%;\n top: calc(50% - 50%);\n background-color: rgba(169, 169, 169, 0.5);\n background-color: var(--ag-header-column-separator-color, rgba(169, 169, 169, 0.5)); }\n .ag-theme-dark .ag-ltr .ag-header-cell::after, .ag-theme-dark .ag-ltr .ag-header-group-cell::after {\n right: 0; }\n .ag-theme-dark .ag-rtl .ag-header-cell::after, .ag-theme-dark .ag-rtl .ag-header-group-cell::after {\n left: 0; }\n .ag-theme-dark .ag-ltr .ag-header-select-all {\n margin-right: 12px; }\n .ag-theme-dark .ag-rtl .ag-header-select-all {\n margin-left: 12px; }\n .ag-theme-dark .ag-ltr .ag-floating-filter-button {\n margin-left: 12px; }\n .ag-theme-dark .ag-rtl .ag-floating-filter-button {\n margin-right: 12px; }\n .ag-theme-dark .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 12px;\n padding: 0;\n width: 12px; }\n .ag-theme-dark .ag-filter-loading {\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e);\n height: 100%;\n padding: 6px 6px;\n position: absolute;\n width: 100%;\n z-index: 1; }\n .ag-theme-dark .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n height: 25px; }\n .ag-theme-dark .ag-paging-panel > * {\n margin: 0 12px; }\n .ag-theme-dark .ag-paging-button {\n cursor: pointer;\n opacity: 0;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n padding: 0;\n width: 12px; }\n .ag-theme-dark .ag-disabled .ag-paging-button {\n cursor: default; }\n .ag-theme-dark .ag-paging-button-wrapper.ag-disabled {\n color: rgba(204, 204, 204, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(204, 204, 204, 0.5));\n cursor: default; }\n .ag-theme-dark .ag-paging-button-wrapper, .ag-theme-dark .ag-paging-description {\n margin: 0 4px; }\n .ag-theme-dark .ag-status-bar {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n color: rgba(204, 204, 204, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(204, 204, 204, 0.5));\n padding-right: 16px;\n padding-left: 16px;\n line-height: 1.5; }\n .ag-theme-dark .ag-status-name-value-value {\n color: #ccc;\n color: var(--ag-foreground-color, #ccc); }\n .ag-theme-dark .ag-status-bar-center {\n text-align: center; }\n .ag-theme-dark .ag-status-name-value {\n margin-left: 4px;\n margin-right: 4px;\n padding-top: 8px;\n padding-bottom: 8px; }\n .ag-theme-dark .ag-column-drop-cell {\n background: #403e3e;\n background: var(--ag-chip-background-color, #403e3e);\n border-radius: 16px;\n height: 16px;\n padding: 0 2px; }\n .ag-theme-dark .ag-column-drop-cell-text {\n margin: 0 4px; }\n .ag-theme-dark .ag-column-drop-cell-button {\n min-width: 16px;\n margin: 0 2px;\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-column-drop-cell-drag-handle {\n margin-left: 8px; }\n .ag-theme-dark .ag-column-drop-cell-ghost {\n opacity: 0.5; }\n .ag-theme-dark .ag-column-drop-horizontal {\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e);\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc));\n height: 25px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-ltr .ag-column-drop-horizontal {\n padding-left: 12px; }\n .ag-theme-dark .ag-rtl .ag-column-drop-horizontal {\n padding-right: 12px; }\n .ag-theme-dark .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-column-drop-horizontal-cell-separator {\n margin: 0 4px;\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-column-drop-horizontal-empty-message {\n color: rgba(204, 204, 204, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(204, 204, 204, 0.5)); }\n .ag-theme-dark .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 12px; }\n .ag-theme-dark .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 12px; }\n .ag-theme-dark .ag-column-drop-vertical-list {\n padding-bottom: 4px;\n padding-right: 4px;\n padding-left: 4px; }\n .ag-theme-dark .ag-column-drop-vertical-cell {\n margin-top: 4px; }\n .ag-theme-dark .ag-column-drop-vertical {\n min-height: 50px;\n max-height: 150px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-dark .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none; }\n .ag-theme-dark .ag-column-drop-vertical-icon {\n margin-left: 4px;\n margin-right: 4px; }\n .ag-theme-dark .ag-column-drop-vertical-list {\n position: relative; }\n .ag-theme-dark .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(204, 204, 204, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(204, 204, 204, 0.5));\n margin-top: 4px; }\n .ag-theme-dark .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n background: #302e2e;\n background: var(--ag-background-color, #302e2e);\n height: 70px;\n padding: 0; }\n .ag-theme-dark .ag-select-agg-func-virtual-list-item {\n cursor: default;\n line-height: 20px;\n padding-left: 8px; }\n .ag-theme-dark .ag-select-agg-func-virtual-list-item:hover {\n background-color: #4a708b;\n background-color: var(--ag-selected-row-background-color, #4a708b); }\n .ag-theme-dark .ag-chart-menu {\n border-radius: 0px;\n background: #302e2e;\n background: var(--ag-background-color, #302e2e); }\n .ag-theme-dark .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 0px;\n color: #ccc;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark .ag-chart-menu-icon:hover {\n opacity: 1; }\n .ag-theme-dark .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n border-radius: 5px;\n margin: 5px; }\n .ag-theme-dark .ag-chart-mini-thumbnail:nth-last-child(3),\n .ag-theme-dark .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto; }\n .ag-theme-dark .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0; }\n .ag-theme-dark .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0; }\n .ag-theme-dark .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0; }\n .ag-theme-dark .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0; }\n .ag-theme-dark .ag-chart-mini-thumbnail.ag-selected {\n border-color: #ccc;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc))); }\n .ag-theme-dark .ag-chart-settings-card-item {\n background: #ccc;\n background: var(--ag-foreground-color, #ccc);\n width: 8px;\n height: 8px;\n border-radius: 4px; }\n .ag-theme-dark .ag-chart-settings-card-item.ag-selected {\n background-color: #ccc;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc))); }\n .ag-theme-dark .ag-chart-data-column-drag-handle {\n margin-left: 4px; }\n .ag-theme-dark .ag-charts-settings-group-title-bar,\n .ag-theme-dark .ag-charts-data-group-title-bar,\n .ag-theme-dark .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-dark .ag-charts-settings-group-container {\n padding: 4px; }\n .ag-theme-dark .ag-charts-data-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-dark .ag-charts-data-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-dark .ag-charts-format-top-level-group-container {\n margin-left: 8px;\n padding: 4px; }\n .ag-theme-dark .ag-charts-format-top-level-group-item {\n margin: 4px 0; }\n .ag-theme-dark .ag-charts-format-sub-level-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-dark .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-dark .ag-charts-group-container.ag-group-container-horizontal {\n padding: 4px; }\n .ag-theme-dark .ag-chart-data-section,\n .ag-theme-dark .ag-chart-format-section {\n display: flex;\n margin: 0; }\n .ag-theme-dark .ag-chart-menu-panel {\n background-color: #302e2e;\n background-color: var(--ag-control-panel-background-color, #302e2e); }\n .ag-theme-dark .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-date-time-list-page-title {\n flex-grow: 1;\n text-align: center; }\n .ag-theme-dark .ag-date-time-list-page-column-label {\n text-align: center; }\n .ag-theme-dark .ag-date-time-list-page-entry {\n text-align: center; }\n .ag-theme-dark .ag-checkbox-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n flex: none; }\n .ag-theme-dark .ag-checkbox-input-wrapper input, .ag-theme-dark .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-dark .ag-checkbox-input-wrapper:focus-within, .ag-theme-dark .ag-checkbox-input-wrapper:active {\n outline: none; }\n .ag-theme-dark .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-dark .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #ccc;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-dark .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #ccc;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-dark .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #ccc;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc)));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-dark .ag-toggle-button-input-wrapper {\n box-sizing: border-box;\n width: 24px;\n height: 12px;\n background-color: #ccc;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc)));\n border-radius: 6px;\n position: relative;\n flex: none;\n border: 1px solid;\n border-color: #ccc;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc))); }\n .ag-theme-dark .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%; }\n .ag-theme-dark .ag-toggle-button-input-wrapper:focus-within {\n outline: none; }\n .ag-theme-dark .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-dark .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #ccc;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc)));\n border-color: #ccc;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc))); }\n .ag-theme-dark .ag-toggle-button-input-wrapper::before {\n content: ' ';\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n background-color: #302e2e;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #302e2e));\n border-radius: 6px;\n transition: left 100ms;\n border: 1px solid;\n border-color: #ccc;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc)))); }\n .ag-theme-dark .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 12px);\n border-color: #ccc;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc))); }\n .ag-theme-dark .ag-radio-button-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n flex: none;\n border-radius: 12px; }\n .ag-theme-dark .ag-radio-button-input-wrapper input, .ag-theme-dark .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-dark .ag-radio-button-input-wrapper:focus-within, .ag-theme-dark .ag-radio-button-input-wrapper:active {\n outline: none; }\n .ag-theme-dark .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-dark .ag-radio-button-input-wrapper::after {\n content: \"\\f124\";\n color: #ccc;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-dark .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f125\";\n color: #ccc;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-dark input[class^='ag-'][type='range'] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible; }\n .ag-theme-dark input[class^='ag-'][type='range']::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px; }\n .ag-theme-dark input[class^='ag-'][type='range']::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px; }\n .ag-theme-dark input[class^='ag-'][type='range']::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px;\n color: transparent;\n width: calc(100% - 2px); }\n .ag-theme-dark input[class^='ag-'][type='range']::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n border: 1px solid;\n border-color: #ccc;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc));\n border-radius: 12px;\n -webkit-transform: translateY(-4.5px);\n transform: translateY(-4.5px); }\n .ag-theme-dark input[class^='ag-'][type='range']::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n border: 1px solid;\n border-color: #ccc;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc));\n border-radius: 12px; }\n .ag-theme-dark input[class^='ag-'][type='range']::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n border: 1px solid;\n border-color: #ccc;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #ccc));\n border-radius: 12px; }\n .ag-theme-dark input[class^='ag-'][type='range']:focus {\n outline: none; }\n .ag-theme-dark input[class^='ag-'][type='range']:focus::-webkit-slider-thumb {\n border-color: #ccc;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark input[class^='ag-'][type='range']:focus::-ms-thumb {\n border-color: #ccc;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark input[class^='ag-'][type='range']:focus::-moz-ag-range-thumb {\n border-color: #ccc;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #ccc)); }\n .ag-theme-dark input[class^='ag-'][type='range']:active::-webkit-slider-runnable-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark input[class^='ag-'][type='range']:active::-moz-ag-range-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark input[class^='ag-'][type='range']:active::-ms-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-dark input[class^='ag-'][type='range']:disabled {\n opacity: 0.5; }\n .ag-theme-dark .ag-icon {\n color: #d6d5d5; }\n .ag-theme-dark .ag-icon-tree-closed::before {\n content: \"\\f10b\"; }\n .ag-theme-dark .ag-icon-tree-open::before {\n content: \"\\f10f\"; }\n .ag-theme-dark .ag-header, .ag-theme-dark .ag-column-drop-cell {\n background-image: none; }\n .ag-theme-dark .ag-tab {\n border: 1px solid transparent;\n padding: 4px 8px;\n margin: 4px;\n margin-bottom: -1px; }\n .ag-theme-dark .ag-tabs-body {\n margin: 2px 0; }\n .ag-theme-dark .ag-icon {\n margin: 1px 1px 2px 1px; }\n .ag-theme-dark .ag-tab-selected {\n background-color: #302e2e;\n background-color: var(--ag-background-color, #302e2e);\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-bottom-color: transparent; }\n .ag-theme-dark .ag-tabs-header {\n background-color: #626262;\n background-color: var(--ag-header-background-color, #626262);\n border-bottom: 1px solid;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-filter .ag-filter-apply-panel {\n justify-content: flex-start; }\n .ag-theme-dark .ag-menu-option-active {\n background-color: #4a708b;\n background-color: var(--ag-selected-row-background-color, #4a708b); }\n .ag-theme-dark .ag-column-drop-cell {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 0; }\n .ag-theme-dark .ag-column-drop-cell-button .ag-icon {\n border: 1px solid transparent; }\n .ag-theme-dark .ag-column-drop-cell-button:hover .ag-icon {\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey); }\n .ag-theme-dark .ag-panel-title-bar-button-icon {\n font-size: 20px;\n line-height: 20px; }\n .ag-theme-dark .ag-menu-option-part {\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-dark .ag-column-drop-vertical-title-bar {\n margin-top: 4px;\n margin-left: 4px; }\n .ag-theme-dark .ag-column-drop-vertical-title {\n margin-left: 4px; }\n .ag-theme-dark .ag-column-drop-vertical-empty-message {\n margin-left: 24px; }\n\n", ""]);
  46364. // Exports
  46365. module.exports = exports;
  46366. /***/ }),
  46367. /* 242 */
  46368. /***/ (function(module, exports, __webpack_require__) {
  46369. var api = __webpack_require__(225);
  46370. var content = __webpack_require__(243);
  46371. content = content.__esModule ? content.default : content;
  46372. if (typeof content === 'string') {
  46373. content = [[module.i, content, '']];
  46374. }
  46375. var options = {};
  46376. options.insert = "head";
  46377. options.singleton = false;
  46378. var update = api(content, options);
  46379. module.exports = content.locals || {};
  46380. /***/ }),
  46381. /* 243 */
  46382. /***/ (function(module, exports, __webpack_require__) {
  46383. // Imports
  46384. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227);
  46385. exports = ___CSS_LOADER_API_IMPORT___(false);
  46386. // Module
  46387. exports.push([module.i, ".ag-theme-fresh {\n -webkit-font-smoothing: antialiased;\n color: #000;\n color: var(--ag-foreground-color, #000);\n font-family: \"Helvetica Neue\", sans-serif;\n font-size: 14px;\n line-height: normal; }\n\n@font-face {\n font-family: \"agGridClassic\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABOsAAsAAAAAJiwAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlIAAAReYchjok9TLzIAAANcAAAAQQAAAFZWVlJ+Y21hcAAAA6AAAAHtAAAFgHClDfdnbHlmAAAFkAAACi0AABQQq+8lqmhlYWQAAA/AAAAANAAAADZ2z8SBaGhlYQAAD/QAAAAeAAAAJAfTBChobXR4AAAQFAAAABoAAAEou4L/4mxvY2EAABAwAAAAbwAAAJb7HvWgbWF4cAAAEKAAAAAfAAAAIAFgAHhuYW1lAAAQwAAAATMAAAJS8kTiWnBvc3QAABH0AAABtgAAApcplp2DeJx9k0lyE0EQRX+rZSMPyGDMZMRkRpsh3O5BjSTLltzyQHjBggULNmYBAeFg5ROw5gAEB+AUnIBgyYoDcACCA/Ay1UbGC6tC1VWZP3/+yspSIGlSy+qqUmzuPld9f+/gveZV1fBn/qPrYP/tmz3VDnf4qv6tKQj/qK4FvdCBvgUKXgefK+NhJeyGu+GH8FP4QyGoG3oMekorjFgJc6RUmZrKVdE4tpj1E7VAh8xtt87qgsbcU2ig8+SMiRk445Ke6o7OwNN3np7WQKUM4+wxbzHuauYERK578GeoWcVqrA10ntWENtHYQ0eH6BbeGXzrZI6I6eProy10VNXruK2XRM762SwyK3Ep/1gbvo9894AqHKLa8DfhN75Fsh7am2RKiHgEewaqW9Zwif8U3hRMRGzHa2bR10AmKEx1nZWdLOFk07oN+zO98qwbZUzPqzg88yLqR/a+8+XkOWrtwLUF9iEaRla7kfvkirSDf5KbKvROH/VFX/VdP/VLv3UK6ypeO8Ea3OsnVqZG/Y6jC7ztf1Y76Th3fhz1P2KCcze9NjG+QVlByzaFTqtNyjrCmjp+Ep2GL1CTU68qOSLPm2AdY6yyj0GfLruxxZj2Og/oAeuAeWqxwmxMw37L2V+GyVZDXRe9Wi14LvltWU3tJdV9Zz1vtzxPna/wjThZ5vXZxnsVizGNLA2PylFtHMv4c9SOspmqBqoSeqDmnbXjr6Ag003OMVSS6Ja/gB3vqgUUZOWLnNM5V98pb2rOcbFHBWiOypeces2sk/tos67Y+gsvGGrHAAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMnxi4gDQjSA4A1QYKdAAAAHictdQHTltBFIXh3wXTTEnvvRc6hGp6XQbpiBREOsoqs5O7gZBzPScLIFJG+nw9o+c3b/R8LtAB1OSp1KFap0KO31qttNdr9LTX6/zSvEkXVX0fYo8DjmL0+FirQ+yyz2FU2rO/o6Krm1zlPs80W2GMJeZZZZItxmlpdZEF1phhmg0mmGOKdXaYZZlNtvX7qnav6xkbdGrfbj1Jr+7YRz8DDHKaM5zlHOe5wEUucZkr2u0a17nBTW5xmzvc5Z72f8BDHvGYJzrPkD6HNRvRAzY42Vg54fU5xpbmVye3xls67cLazLQOOje1vjO7vLn9Dzf7D6OZH7Wfnu2Qb7PI0+7amDy3JXlh8/LSVuWVTcpr25I3Ni5vrSV7lv+QfVuUd7Yg721NPtiMfLRpObANObQJ+WRz8tmm5Iuty1fLs3+zWfluy/LDNuXI9AKjUmRWolqQtVZktqJeZL6io8jcRaMga2dB1q6CrN0FWXuKzGP0FmRtFvkmo68ga39B1oGCrIMFWU8VyhJhShVhyhdhShphyhxhSh9hyiFhSiRhyiZhSilhyithSi5hyjBhSjNhyjVhSjhhyjphSj1hyj9h6gSEqScQpu5AmPoEYeoRhKl3EKb+QVj2zbDMTFj7muGCrCNF+56jBSN/AHzNoH4AAAB4nO1Ye2xT1xm/37nEN87D8bUdXwezwLWJDZQCtmNfO4FATIgdQhLWGwhrt0DSGJHHpgaawFRatBIVVrXbHxXTWCiPabMHo9MgSH1IGxJMa6b+sbBJFZVK2/HHVNjI6JZ2k8W97DvHjzyggPrntBufe17fPec73/md3/edcMDhw4f4fs7IcSBLglwuW3mZD+mj+/ZBQtv//vtkhPxuYiIFe2EvijD5T/lPuUVYCQpeRRK8oswyRRZZJokyywQZLrXFxscbNwPf1oh5m65txjzWpuu0PdYGhF9k/LIuWm/czOXm3Mq/whViRfAaMYlu+NkbCeiG7sTZU2TPGz3QrR/vOavdzMmTSTLJFTN51AW1QX3IZOOFsdiFC7GxC41jUJ8rjTVe4Ao47q6O67rBWTk35+Ue41ZyXIHsWgFBsboOArK/EspFmwl42WXAgh1bQtjlgYDorgqUu3nM+T7N5qpx4Y/83VUjyzWyZjY7HGZyW5Qk7ReqCi2qmmpvJ66Ii3yGL/xpZfjifySJmig6HCL5hyjpY/q1ZBJO6jtw2Vm9bjK9luJ6coq4p5UrmKOTALheK9/HdHDldbo1Q5teffLf1aev8zdyKuRU2jJTk3f0ot/XH4YTc/XwPpoevByUH6jFX/Tz0PoQHfTSJN3OWfM/2uwPmvkhk9L14qL38T2IjELOwXEIOskIvLIQDAL+ldvsOEu11+Mlf9O31zyta1A3Pv7ur4uLK8rsvg0+e1kFXIJTtdihX4Y14+N1paWVTk+Fy+dzVVQtqKTDG9gcR/gjOJuAWC3DtUkcV1WOZsPEz8nhlH6ej+rnk7OydAofaEniA620zGV1v5HF8spHsxYghsvdQXcwEAzw/RmLadaMBcmkZmaWoZbT30uxJ2NBS9aCk1kLWlFCJLdw2y5QlVJMFfaK8lG2ShH1CYhy0I0sIYsyH5TFQJCMJvWSJEyp+hi0pPQxlYyyehrrp7AxzeV54Hn+eXqujYDbIRgB2UCBKbAM65PspU8OgwVfpG9WFSxYncElhxmXiAFkLDrAz0+eTejH9eMJ+C4xaVNYOQFdCe6r4p7u2oPQ9wO95GGoH0smp233Lq9wFZyPW43zK1IoYJfskgkBicwGobUQdLsQk17rCuI1CJUg2RXJgMikfyEUUFgJ5UGu9qyNHnpucNvSb9cF6xeZ9D+taPYW1T0WfvzAX0PfXF3UUO17pVX9uv9bT3ZtrYus9D85BFc3N5os9kq5uHY5b1qyyjLvieaDa3Z5GgJLiuFAEQG1wGBy6tcM4W1Bf7zhabujeN2CImN1VZ1/40ub9KO+TqskLZwfaHf+b65FQjwv4UK4FroORg1ZXUNYpm12Jac0QcB4qzxrwE3lJBRR4A5dQdvw/hd/uJ8q+Y0933umoXpdZ/euZ3Zs3ciULWnctbc3VgQboagtFAtVLQl5VvPlvNr84nBLW0nJRs8af/NI85Yz/vg2JWwwKP4eq2RfVBF+qjrUWcOXLlgGhcXzm22FAuEyPMo4px95DT2+VQbRG/SVB4Iq45Qk34/eZ3sq3d6elSV30I/yLDoQ3SI6Fq8gwVqVmC9fDqfTZFIvgSm94dIlrFDxkuxZvziL05zcwmmvqiDT5BI8pCwjH6WSyTT7ISN8WQlOJpMTSUaCJ+/NUKWC7Lovcl/jZK4KPenjlIcYsSLvZSk2n0R3UAZ3Ofr0TKrCBKeQYdFGyLY0p0zF8h3t0JqdjqnD96tovqSaxiytklhas6hwqh15TFXn2rTKLQaARicCuaOq2m1m1PQMi2b46iS/lfGVhIRHQzTYebpHPw7dPWdIDZw8nYmDzlCyJXe/uPsF/y/+n1w1159BpaGMuiwvYs+j4AEL+RkqsdUElQQb6sCDnUGfhxaxC6segXVTOSlgpx95q70+KsbkK0muuxL82KmEvB7yQsRmWxIeibQ2b2rZbcMnEi+qsAARyTxDhdNmCTY1OQ8usFidRgepWFpoL7JbwBpp2dTcGhkJL0FxSzkU2QuXOUhpsdFptToPOpuaghabs8IwjzcTsFQUxSN0XJyptfkozkQru9kAcaPZFPQXWgzznfGmkM3qHHHG406jaHY5lhYSg5nOxFQaCR9FcUuZQAqXOlxmo1BEBUecVluoKe6cb7AU+oMmszHOVjHzvBxBFC9kjCUgLJGs0FciYyE8cfPQYwaUoNctlJPY0eGjV6/iK5kv/Pjl7u6Xu8lvZjXSgvZWN+3i5s2KPZchNz5a5CmwoBYU5E5JeXDseevjmG80fAyuxT7xvR5+/SEBqFYX+2jVMRR//pOYD/O8H5qOVViUAtnEH7nzWz6aSelMNEJjEfrJV12bwsJ2XCIlnAev7bmPYquOKaNQHfuYKv2wtaWza3sNTXJMOZa/L7yKZ7KA7jA9jfAUO4ngzxFb5hw6+T9zpdN3EBY7SDDamwAveBO9vQn9A/2DRC8514ctWOrTX+rDNuzry8YSd1ksYeMWcwEaS9ATZqZOYxF1EWb0CKECemYDflqk8eVKehyZTzSU0+MIU4efHYxu2BAdfFb/bGgw2tAQHRyCCe3NUH00Nti1XYlI0rJ4qH49VjrDEcAafxOlh/TbQ7up9O4hMON3Gz7X3lwmSRGls3swFl0XaspUugbj0fpQDvdR9BMCcjiL2DBMC0iUKTFyo6y2M51Mqfp5FaZ4h5Ygo2qK8l/eVjTewxq4RckteN0KpVQy2Xkurarpc50wha5jvDed7oWwmuHnPE5k9Khhbu39kUIDBAaVWvRHwQKMIBExfOYeyg4mPaFWSuL0BjAHN9p3DlDcHEjx67R3SKUo/adk9eBgbcnFklqaDUxo10mjdA+CyO1kBkIkhiT9tkOE1ZkPMt+VkljyBbwzzMYR85Tk1Tk4IjMwQG9zbGPNFAaL6I6bKQwEBgsb7XHRejXtgalD+d0uyyHgMNvwiLK96zpuNj6dXfff7C10a693d1Lhzm4UViKz8biUxTD3w6PEVGQ+g4GS3nk8VtwJ3BvcGdyX+0LyUAZ+VKXrOSW/v37P4T3r2euR1dR3NGQ/Wb8nj60TWX/oVfACoMhBcvCXCejSTyROa38gsTOZUP50Ks/fA4jjUs5OYxh07XmeKcj+uyKAAH5L9blI3OXTxwZqJiZqBtrRCX8Ii/UP6Y0NFi8YqJ2YqB2A16bxTUbp6BhBpchP9DG8sJzPc8koYp/QO4pIYwS8nrRoO+f2kUz4wNdjwDU2Z0wj0CCjJSOR7UvyMYorI0HG4ZPaFf294YvwNrmiXYHgEJam9YrTnaVHABXTdiI4aXM+LnBzMa4D+dtumxsXLATalo0KQn6Jt/vz3t5gw96sr6dfCKxNAooH8LgyFbufPCEIHTNCgA7BKrQaDNvQn1MH2yHYBBemDuqm0cVvMxhaUaJjhivvEATiWG4y3fmpyWPCnO80ef54r0zL7FHgV7MnablXjTufL8cRcTgc1VuKw//fJvfa5L+BscYKAAAAeJxjYGRgYABi/jvPp8Xz23xl4GZ+ARSI4ny8rwFG///2/xvzZ+ZPQJUcDExAkgEAoUMP6XicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AIAnloHAgAAeJxjYGBgYH5Ba/z/G+3M/f+NgQ4AAPv8MfAAAHicY2AAAgmGIIYshhaGC4wijCGMPYz7GF8xGTGFMVUwTWC6wGzGPIf5BwsfiwZLCcsOlgssL1gnsB5iE2EzYGtim8K2jZ2HXYvdhX0Z+w72fxwRHAUcszhWcGzjOMJxieMZxxfOOi4O0iEAtgsblgB4nGNgZGBg8GLIYeBhAAEmIOYCQgaG/2A+AwAbuAHZAHicfZC9TsMwFIVP+odoBaoEYmAyCwtS+rPRtVKzd+ieJnaaKo2D41bqznPwBDxHn4OnYObEeCkStSXnu9899w4BMMQJAZoT4Ma9zWnhitUvt0n3njvkJ89dDBB67tG/eu7jBQvPA9zhjRuCzjXNI949t3CLD89t+k/PHfLJcxcP+PLco//23McqGHoe4DlQcRaZPJ0XcV3nyVJm+yI2Z+6sWElT57oUk3B85iNZShNbmYr1UdSHbGqtEsronVjo0sqi0KIyeisTG26srWajkfI+TPQOMTJEMMiRYo6Cdc2bI8ESkr29c+ZC7v/OihuMY40SAhP+9/GFfMR86WZiWH5Tzqxx5FvjwKkprYVirZjR2JEWbneTLng1TeV6W5qEPsTGTVWYYcSr/uRDprjpB8WrbRMAeJxtkmdv2zAURX1iyVbstEnTNt17D7VN994z/RUMRctEJFIgKY/8+rJxGiBA36dzHx7uu3xgZ6mzqEHn/7XFEl0SUnr0yVhmwJAVjnCUVdY4xjrHOcFJNjjFac5wlnOc5wIXucRlrnCVa1znBje5xW3ucJd73CfnAQ95xCaPecJTnvGcF7zkFa95w1ve8Z4PfOQTn/nCV77xnR/85Bdb/O4MRVk6VYqgrekJ5+zUd4WXPSmMVFUqx8KFNTlWcmfbzvI9UMXGQUObQgXlam1EUOsH7dbsT65IW1mXNzoK14+irY0fSGuCEzKoIpG2mafSWe+TQnmZqVkjomexrOYq95Xw4+EB5ZvdyL2RruLKdKSdD0npdJOWzrZNEkdCUqlR6FXaxN39yopCmzKrxUzXelcltTJtFrMulFGzkBhr1NDYkIuqslNVpE10Ud1Gm7TRExuyxqmJtq1fc9HM5tttCNbkdjRaPdwwqdPlOCReTNTA19EuL+zU7OPfWMMF7o1lC46pQzzNenBKHb5l1prFKwb/IN9EUOJQBDQWwxSPpGLMDtvM4lcoqGlpmDNil0mn8wcxorJdAAA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n .ag-theme-fresh .ag-icon {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n .ag-theme-fresh .ag-icon-aggregation:before {\n content: \"\\f101\"; }\n .ag-theme-fresh .ag-icon-arrows:before {\n content: \"\\f102\"; }\n .ag-theme-fresh .ag-icon-asc:before {\n content: \"\\f103\"; }\n .ag-theme-fresh .ag-icon-cancel:before {\n content: \"\\f104\"; }\n .ag-theme-fresh .ag-icon-chart:before {\n content: \"\\f105\"; }\n .ag-theme-fresh .ag-icon-color-picker:before {\n content: \"\\f109\"; }\n .ag-theme-fresh .ag-icon-columns:before {\n content: \"\\f10a\"; }\n .ag-theme-fresh .ag-icon-contracted:before {\n content: \"\\f10b\"; }\n .ag-theme-fresh .ag-icon-copy:before {\n content: \"\\f10c\"; }\n .ag-theme-fresh .ag-icon-cross:before {\n content: \"\\f10d\"; }\n .ag-theme-fresh .ag-icon-desc:before {\n content: \"\\f10e\"; }\n .ag-theme-fresh .ag-icon-expanded:before {\n content: \"\\f10f\"; }\n .ag-theme-fresh .ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n .ag-theme-fresh .ag-icon-eye:before {\n content: \"\\f111\"; }\n .ag-theme-fresh .ag-icon-filter:before {\n content: \"\\f112\"; }\n .ag-theme-fresh .ag-icon-first:before {\n content: \"\\f113\"; }\n .ag-theme-fresh .ag-icon-grip:before {\n content: \"\\f114\"; }\n .ag-theme-fresh .ag-icon-group:before {\n content: \"\\f115\"; }\n .ag-theme-fresh .ag-icon-last:before {\n content: \"\\f116\"; }\n .ag-theme-fresh .ag-icon-left:before {\n content: \"\\f117\"; }\n .ag-theme-fresh .ag-icon-linked:before {\n content: \"\\f118\"; }\n .ag-theme-fresh .ag-icon-loading:before {\n content: \"\\f119\"; }\n .ag-theme-fresh .ag-icon-maximize:before {\n content: \"\\f11a\"; }\n .ag-theme-fresh .ag-icon-menu:before {\n content: \"\\f11b\"; }\n .ag-theme-fresh .ag-icon-minimize:before {\n content: \"\\f11c\"; }\n .ag-theme-fresh .ag-icon-next:before {\n content: \"\\f11d\"; }\n .ag-theme-fresh .ag-icon-none:before {\n content: \"\\f11e\"; }\n .ag-theme-fresh .ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n .ag-theme-fresh .ag-icon-paste:before {\n content: \"\\f120\"; }\n .ag-theme-fresh .ag-icon-pin:before {\n content: \"\\f121\"; }\n .ag-theme-fresh .ag-icon-pivot:before {\n content: \"\\f122\"; }\n .ag-theme-fresh .ag-icon-previous:before {\n content: \"\\f123\"; }\n .ag-theme-fresh .ag-icon-right:before {\n content: \"\\f126\"; }\n .ag-theme-fresh .ag-icon-save:before {\n content: \"\\f127\"; }\n .ag-theme-fresh .ag-icon-small-down:before {\n content: \"\\f128\"; }\n .ag-theme-fresh .ag-icon-small-left:before {\n content: \"\\f129\"; }\n .ag-theme-fresh .ag-icon-small-right:before {\n content: \"\\f12a\"; }\n .ag-theme-fresh .ag-icon-small-up:before {\n content: \"\\f12b\"; }\n .ag-theme-fresh .ag-icon-tick:before {\n content: \"\\f12c\"; }\n .ag-theme-fresh .ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n .ag-theme-fresh .ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n .ag-theme-fresh .ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n .ag-theme-fresh .ag-icon-unlinked:before {\n content: \"\\f130\"; }\n .ag-theme-fresh .ag-icon-row-drag:before {\n content: \"\\f114\"; }\n .ag-theme-fresh .ag-right-arrow:before {\n content: \"\\f117\"; }\n .ag-theme-fresh .ag-right-arrow:before {\n content: \"\\f126\"; }\n .ag-theme-fresh .ag-root-wrapper {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-fresh [class^='ag-'], .ag-theme-fresh [class^='ag-']:focus, .ag-theme-fresh [class^='ag-']:after, .ag-theme-fresh [class^='ag-']:before {\n box-sizing: border-box;\n outline: none; }\n .ag-theme-fresh [class^='ag-']::-ms-clear {\n display: none; }\n .ag-theme-fresh .ag-checkbox .ag-input-wrapper,\n .ag-theme-fresh .ag-radio-button .ag-input-wrapper {\n overflow: visible; }\n .ag-theme-fresh .ag-range-field .ag-input-wrapper {\n height: 100%; }\n .ag-theme-fresh .ag-toggle-button {\n flex: none;\n width: unset;\n min-width: unset; }\n .ag-theme-fresh .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 4px; }\n .ag-theme-fresh .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 4px; }\n .ag-theme-fresh input[class^='ag-'] {\n margin: 0;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-fresh textarea[class^='ag-'],\n .ag-theme-fresh select[class^='ag-'] {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-fresh input[class^='ag-']:not([type]),\n .ag-theme-fresh input[class^='ag-'][type='text'],\n .ag-theme-fresh input[class^='ag-'][type='number'],\n .ag-theme-fresh input[class^='ag-'][type='tel'],\n .ag-theme-fresh input[class^='ag-'][type='date'],\n .ag-theme-fresh input[class^='ag-'][type='datetime-local'],\n .ag-theme-fresh textarea[class^='ag-'] {\n font-size: inherit;\n line-height: inherit;\n color: inherit;\n border-width: 1px;\n border-style: solid;\n border-color: #000;\n border-color: var(--ag-input-border-color, #000); }\n .ag-theme-fresh input[class^='ag-']:not([type]):disabled,\n .ag-theme-fresh input[class^='ag-'][type='text']:disabled,\n .ag-theme-fresh input[class^='ag-'][type='number']:disabled,\n .ag-theme-fresh input[class^='ag-'][type='tel']:disabled,\n .ag-theme-fresh input[class^='ag-'][type='date']:disabled,\n .ag-theme-fresh input[class^='ag-'][type='datetime-local']:disabled,\n .ag-theme-fresh textarea[class^='ag-']:disabled {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n background-color: #ebebeb;\n background-color: var(--ag-input-disabled-background-color, #ebebeb);\n border-color: rgba(0, 0, 0, 0.3);\n border-color: var(--ag-input-disabled-border-color, rgba(0, 0, 0, 0.3)); }\n .ag-theme-fresh input[class^='ag-']:not([type]):focus,\n .ag-theme-fresh input[class^='ag-'][type='text']:focus,\n .ag-theme-fresh input[class^='ag-'][type='number']:focus,\n .ag-theme-fresh input[class^='ag-'][type='tel']:focus,\n .ag-theme-fresh input[class^='ag-'][type='date']:focus,\n .ag-theme-fresh input[class^='ag-'][type='datetime-local']:focus,\n .ag-theme-fresh textarea[class^='ag-']:focus {\n outline: none;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh input[class^='ag-'][type='number'] {\n -moz-appearance: textfield; }\n .ag-theme-fresh input[class^='ag-'][type='number']::-webkit-outer-spin-button, .ag-theme-fresh input[class^='ag-'][type='number']::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0; }\n .ag-theme-fresh input[class^='ag-'][type='range'] {\n padding: 0; }\n .ag-theme-fresh .ag-drag-handle {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-list-item, .ag-theme-fresh .ag-virtual-list-item {\n height: 20px; }\n .ag-theme-fresh .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-virtual-list-item:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-select-list {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n overflow-y: auto;\n overflow-x: hidden; }\n .ag-theme-fresh .ag-list-item {\n display: flex;\n align-items: center; }\n .ag-theme-fresh .ag-list-item.ag-active-item {\n background-color: var(--ag-row-hover-color); }\n .ag-theme-fresh .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n .ag-theme-fresh .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden; }\n .ag-theme-fresh .ag-select .ag-picker-field-wrapper {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n min-height: 20px;\n cursor: default; }\n .ag-theme-fresh .ag-select:not(.ag-cell-editor) {\n height: 20px; }\n .ag-theme-fresh .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis; }\n .ag-theme-fresh .ag-select .ag-picker-field-icon {\n display: flex;\n align-items: center; }\n .ag-theme-fresh .ag-select.ag-disabled {\n opacity: 0.5; }\n .ag-theme-fresh .ag-rich-select {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-fresh .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 162.5px; }\n .ag-theme-fresh .ag-rich-select-value {\n padding: 0 4px 0 12px;\n height: 25px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-fresh .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 20px; }\n .ag-theme-fresh .ag-rich-select-virtual-list-item:hover {\n background-color: var(--ag-row-hover-color); }\n .ag-theme-fresh .ag-rich-select-row {\n padding-left: 12px; }\n .ag-theme-fresh .ag-rich-select-row-selected {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5); }\n .ag-theme-fresh .ag-row-drag,\n .ag-theme-fresh .ag-selection-checkbox,\n .ag-theme-fresh .ag-group-expanded,\n .ag-theme-fresh .ag-group-contracted {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-ltr .ag-row-drag, .ag-theme-fresh .ag-ltr .ag-selection-checkbox, .ag-theme-fresh .ag-ltr .ag-group-expanded, .ag-theme-fresh .ag-ltr .ag-group-contracted {\n margin-right: 12px; }\n .ag-theme-fresh .ag-rtl .ag-row-drag, .ag-theme-fresh .ag-rtl .ag-selection-checkbox, .ag-theme-fresh .ag-rtl .ag-group-expanded, .ag-theme-fresh .ag-rtl .ag-group-contracted {\n margin-left: 12px; }\n .ag-theme-fresh .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: 23px;\n display: flex;\n align-items: center;\n flex: none; }\n .ag-theme-fresh .ag-group-expanded,\n .ag-theme-fresh .ag-group-contracted {\n cursor: pointer; }\n .ag-theme-fresh .ag-group-title-bar-icon {\n cursor: pointer;\n flex: none;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-ltr .ag-group-child-count {\n margin-left: 2px; }\n .ag-theme-fresh .ag-rtl .ag-group-child-count {\n margin-right: 2px; }\n .ag-theme-fresh .ag-group-title-bar {\n background-color: #ececec;\n background-color: var(--ag-subheader-background-color, #ececec);\n padding: 4px; }\n .ag-theme-fresh .ag-group-toolbar {\n padding: 4px; }\n .ag-theme-fresh .ag-disabled-group-title-bar, .ag-theme-fresh .ag-disabled-group-container {\n opacity: 0.5; }\n .ag-theme-fresh .group-item {\n margin: 2px 0; }\n .ag-theme-fresh .ag-label {\n white-space: nowrap; }\n .ag-theme-fresh .ag-ltr .ag-label {\n margin-right: 4px; }\n .ag-theme-fresh .ag-rtl .ag-label {\n margin-left: 4px; }\n .ag-theme-fresh .ag-label-align-top .ag-label {\n margin-bottom: 2px; }\n .ag-theme-fresh .ag-ltr .ag-slider-field, .ag-theme-fresh .ag-ltr .ag-angle-select-field {\n margin-right: 8px; }\n .ag-theme-fresh .ag-rtl .ag-slider-field, .ag-theme-fresh .ag-rtl .ag-angle-select-field {\n margin-left: 8px; }\n .ag-theme-fresh .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-fresh .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: #000;\n background-color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 5px; }\n .ag-theme-fresh .ag-picker-field-button {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-dialog.ag-color-dialog {\n border-radius: 5px; }\n .ag-theme-fresh .ag-color-picker .ag-picker-field-display {\n height: 12px; }\n .ag-theme-fresh .ag-color-panel {\n padding: 4px; }\n .ag-theme-fresh .ag-spectrum-color {\n background-color: red;\n border-radius: 2px; }\n .ag-theme-fresh .ag-spectrum-tools {\n padding: 10px; }\n .ag-theme-fresh .ag-spectrum-sat {\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0)); }\n .ag-theme-fresh .ag-spectrum-val {\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0)); }\n .ag-theme-fresh .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24); }\n .ag-theme-fresh .ag-spectrum-hue-background {\n border-radius: 2px; }\n .ag-theme-fresh .ag-spectrum-alpha-background {\n border-radius: 2px; }\n .ag-theme-fresh .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px; }\n .ag-theme-fresh .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37); }\n .ag-theme-fresh .ag-recent-color {\n margin: 0 3px; }\n .ag-theme-fresh .ag-recent-color:first-child {\n margin-left: 0; }\n .ag-theme-fresh .ag-recent-color:last-child {\n margin-right: 0; }\n .ag-theme-fresh.ag-dnd-ghost {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n overflow: hidden;\n text-overflow: ellipsis;\n z-index: 10;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n height: 25px !important;\n line-height: 25px;\n margin: 0;\n padding: 0 8px;\n -webkit-transform: translateY(8px);\n transform: translateY(8px); }\n .ag-theme-fresh .ag-dnd-ghost-icon {\n margin-right: 4px;\n color: #000;\n color: var(--ag-foreground-color, #000); }\n .ag-theme-fresh .ag-popup-child:not(.ag-tooltip-custom) {\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3); }\n .ag-dragging-range-handle .ag-theme-fresh .ag-dialog,\n .ag-dragging-fill-handle .ag-theme-fresh .ag-dialog {\n opacity: 0.7;\n pointer-events: none; }\n .ag-theme-fresh .ag-dialog {\n border-radius: 0px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-panel {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-fresh .ag-panel-title-bar {\n background-color: var(--ag-header-background-color);\n color: #000;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)));\n height: 25px;\n padding: 4px 12px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-ltr .ag-panel-title-bar-button {\n margin-left: 4px; }\n .ag-theme-fresh .ag-rtl .ag-panel-title-bar-button {\n margin-right: 4px; }\n .ag-theme-fresh .ag-tooltip {\n background-color: var(--ag-header-background-color);\n color: #000;\n color: var(--ag-foreground-color, #000);\n padding: 4px;\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n transition: opacity 1s; }\n .ag-theme-fresh .ag-tooltip.ag-tooltip-hiding {\n opacity: 0; }\n .ag-theme-fresh .ag-ltr .ag-column-select-indent-1 {\n padding-left: 16px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-indent-1 {\n padding-right: 16px; }\n .ag-theme-fresh .ag-ltr .ag-column-select-indent-2 {\n padding-left: 32px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-indent-2 {\n padding-right: 32px; }\n .ag-theme-fresh .ag-ltr .ag-column-select-indent-3 {\n padding-left: 48px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-indent-3 {\n padding-right: 48px; }\n .ag-theme-fresh .ag-ltr .ag-column-select-indent-4 {\n padding-left: 64px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-indent-4 {\n padding-right: 64px; }\n .ag-theme-fresh .ag-ltr .ag-column-select-indent-5 {\n padding-left: 80px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-indent-5 {\n padding-right: 80px; }\n .ag-theme-fresh .ag-ltr .ag-column-select-indent-6 {\n padding-left: 96px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-indent-6 {\n padding-right: 96px; }\n .ag-theme-fresh .ag-ltr .ag-column-select-indent-7 {\n padding-left: 112px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-indent-7 {\n padding-right: 112px; }\n .ag-theme-fresh .ag-ltr .ag-column-select-indent-8 {\n padding-left: 128px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-indent-8 {\n padding-right: 128px; }\n .ag-theme-fresh .ag-ltr .ag-column-select-indent-9 {\n padding-left: 144px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-indent-9 {\n padding-right: 144px; }\n .ag-theme-fresh .ag-column-select-header-icon {\n cursor: pointer; }\n .ag-theme-fresh .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-column-select-header-icon:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-fresh .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 6px; }\n .ag-theme-fresh .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-fresh .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 6px; }\n .ag-theme-fresh .ag-keyboard-focus .ag-column-select-column-group:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-column-select-column-group:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-keyboard-focus .ag-column-select-column:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-column-select-column:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -2px;\n left: -2px;\n display: block;\n width: calc(100% - -4px);\n height: calc(100% - -4px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-column-select-column-group:not(:last-child),\n .ag-theme-fresh .ag-column-select-column:not(:last-child) {\n margin-bottom: 4px; }\n .ag-theme-fresh .ag-column-select-column-readonly,\n .ag-theme-fresh .ag-column-select-column-group-readonly {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n pointer-events: none; }\n .ag-theme-fresh .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 20px; }\n .ag-theme-fresh .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 20px; }\n .ag-theme-fresh .ag-column-select-list {\n padding: 6px 6px; }\n .ag-theme-fresh .ag-rtl {\n text-align: right; }\n .ag-theme-fresh .ag-root-wrapper {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 0px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 36px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 36px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-1 {\n padding-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-1 {\n padding-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 60px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 60px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-2 {\n padding-left: 48px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-2 {\n padding-right: 48px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 84px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 84px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-3 {\n padding-left: 72px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-3 {\n padding-right: 72px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 108px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 108px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-4 {\n padding-left: 96px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-4 {\n padding-right: 96px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 132px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 132px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-5 {\n padding-left: 120px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-5 {\n padding-right: 120px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 156px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 156px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-6 {\n padding-left: 144px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-6 {\n padding-right: 144px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 180px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 180px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-7 {\n padding-left: 168px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-7 {\n padding-right: 168px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 204px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 204px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-8 {\n padding-left: 192px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-8 {\n padding-right: 192px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 228px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 228px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-9 {\n padding-left: 216px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-9 {\n padding-right: 216px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 252px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 252px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-10 {\n padding-left: 240px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-10 {\n padding-right: 240px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 276px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 276px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-11 {\n padding-left: 264px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-11 {\n padding-right: 264px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 300px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 300px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-12 {\n padding-left: 288px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-12 {\n padding-right: 288px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 324px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 324px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-13 {\n padding-left: 312px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-13 {\n padding-right: 312px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 348px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 348px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-14 {\n padding-left: 336px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-14 {\n padding-right: 336px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 372px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 372px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-15 {\n padding-left: 360px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-15 {\n padding-right: 360px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 396px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 396px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-16 {\n padding-left: 384px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-16 {\n padding-right: 384px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 420px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 420px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-17 {\n padding-left: 408px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-17 {\n padding-right: 408px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 444px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 444px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-18 {\n padding-left: 432px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-18 {\n padding-right: 432px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 468px; }\n .ag-theme-fresh .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 468px; }\n .ag-theme-fresh .ag-ltr .ag-row-group-indent-19 {\n padding-left: 456px; }\n .ag-theme-fresh .ag-rtl .ag-row-group-indent-19 {\n padding-right: 456px; }\n .ag-theme-fresh .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-left: 24px; }\n .ag-theme-fresh .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-right: 24px; }\n .ag-theme-fresh .ag-cell {\n -webkit-font-smoothing: subpixel-antialiased; }\n .ag-theme-fresh .ag-value-change-delta {\n padding-right: 2px; }\n .ag-theme-fresh .ag-value-change-delta-up {\n color: darkgreen;\n color: var(--ag-value-change-delta-up-color, darkgreen); }\n .ag-theme-fresh .ag-value-change-delta-down {\n color: darkred;\n color: var(--ag-value-change-delta-down-color, darkred); }\n .ag-theme-fresh .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n transition: background-color 1s; }\n .ag-theme-fresh .ag-value-change-value-highlight {\n background-color: #cec;\n background-color: var(--ag-value-change-value-highlight-background-color, #cec);\n transition: background-color 0.1s; }\n .ag-theme-fresh .ag-cell-data-changed {\n background-color: #cec !important;\n background-color: var(--ag-value-change-value-highlight-background-color, #cec) !important; }\n .ag-theme-fresh .ag-cell-data-changed-animation {\n background-color: transparent; }\n .ag-theme-fresh .ag-cell-highlight {\n background-color: rgba(136, 255, 136, 0.4) !important;\n background-color: var(--ag-range-selection-highlight-color, rgba(136, 255, 136, 0.4)) !important; }\n .ag-theme-fresh .ag-row {\n height: 25px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n color: #000;\n color: var(--ag-data-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-row-highlight-above::after, .ag-theme-fresh .ag-row-highlight-below::after {\n content: '';\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #000;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n left: 1px; }\n .ag-theme-fresh .ag-row-highlight-above::after {\n top: -1px; }\n .ag-theme-fresh .ag-row-highlight-above.ag-row-first::after {\n top: 0; }\n .ag-theme-fresh .ag-row-highlight-below::after {\n bottom: 0px; }\n .ag-theme-fresh .ag-row-odd {\n background-color: #f6f6f6;\n background-color: var(--ag-odd-row-background-color, #f6f6f6); }\n .ag-theme-fresh .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-ltr .ag-right-aligned-cell {\n text-align: right; }\n .ag-theme-fresh .ag-rtl .ag-right-aligned-cell {\n text-align: left; }\n .ag-theme-fresh .ag-ltr .ag-right-aligned-cell .ag-cell-value {\n margin-left: auto; }\n .ag-theme-fresh .ag-rtl .ag-right-aligned-cell .ag-cell-value {\n margin-right: auto; }\n .ag-theme-fresh .ag-cell {\n border: 1px solid transparent;\n line-height: 23px;\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-fresh .ag-row > .ag-cell-wrapper {\n padding-left: 11px;\n padding-right: 11px; }\n .ag-theme-fresh .ag-row-dragging {\n cursor: move; }\n .ag-theme-fresh .ag-row-dragging {\n opacity: 0.5; }\n .ag-theme-fresh .ag-cell-inline-editing {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n padding: 0;\n height: 25px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-fresh .ag-popup-editor {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n padding: 0; }\n .ag-theme-fresh .ag-large-text-input {\n height: auto;\n padding: 12px; }\n .ag-theme-fresh .ag-details-row {\n padding: 20px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF); }\n .ag-theme-fresh .ag-overlay-loading-wrapper {\n background-color: rgba(255, 255, 255, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(255, 255, 255, 0.66)); }\n .ag-theme-fresh .ag-overlay-loading-center {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px; }\n .ag-theme-fresh .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px; }\n .ag-theme-fresh .ag-loading {\n padding-left: 12px;\n display: flex;\n height: 100%;\n align-items: center; }\n .ag-theme-fresh .ag-loading-icon {\n padding-right: 12px; }\n .ag-theme-fresh .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear; }\n\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n .ag-theme-fresh .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-ltr .ag-cell {\n border-right: dotted darkgrey; }\n .ag-theme-fresh .ag-rtl .ag-cell {\n border-left: dotted darkgrey; }\n .ag-theme-fresh .ag-ltr .ag-cell {\n border-right-width: 1px; }\n .ag-theme-fresh .ag-rtl .ag-cell {\n border-left-width: 1px; }\n .ag-theme-fresh .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-row-selected {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5); }\n .ag-theme-fresh .ag-cell-range-selected:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.2);\n background-color: var(--ag-range-selection-background-color, rgba(0, 0, 0, 0.2)); }\n .ag-theme-fresh .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1);\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)); }\n .ag-theme-fresh .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1);\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)); }\n .ag-theme-fresh .ag-cell-range-selected-1:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.2);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(0, 0, 0, 0.2))); }\n .ag-theme-fresh .ag-cell-range-selected-2:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.36);\n background-color: var(--ag-range-selection-background-color-2, rgba(0, 0, 0, 0.36)); }\n .ag-theme-fresh .ag-cell-range-selected-3:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.488);\n background-color: var(--ag-range-selection-background-color-3, rgba(0, 0, 0, 0.488)); }\n .ag-theme-fresh .ag-cell-range-selected-4:not(.ag-cell-focus) {\n background-color: rgba(0, 0, 0, 0.5904);\n background-color: var(--ag-range-selection-background-color-4, rgba(0, 0, 0, 0.5904)); }\n .ag-theme-fresh .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #000;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #000;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #000;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #000;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-fresh .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-fresh .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-fresh .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-fresh .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-fresh .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000));\n outline: initial; }\n .ag-theme-fresh .ag-cell.ag-selection-fill-top,\n .ag-theme-fresh .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #000;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-fresh .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #000;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-fresh .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #000;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-cell.ag-selection-fill-bottom,\n .ag-theme-fresh .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #000;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-fresh .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #000;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-fresh .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #000;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-fill-handle, .ag-theme-fresh .ag-range-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #000;\n background-color: var(--ag-range-selection-border-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-ltr .ag-fill-handle, .ag-theme-fresh .ag-ltr .ag-range-handle {\n right: -1px; }\n .ag-theme-fresh .ag-rtl .ag-fill-handle, .ag-theme-fresh .ag-rtl .ag-range-handle {\n left: -1px; }\n .ag-theme-fresh .ag-fill-handle {\n cursor: cell; }\n .ag-theme-fresh .ag-range-handle {\n cursor: nwse-resize; }\n .ag-theme-fresh .ag-cell-inline-editing {\n border-color: var(--ag-input-focus-border-color) !important; }\n .ag-theme-fresh .ag-menu {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n padding: 0; }\n .ag-theme-fresh .ag-menu-list {\n cursor: default;\n width: 100%;\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-fresh .ag-menu-option-part {\n padding-top: 6px;\n padding-bottom: 6px;\n line-height: 12px; }\n .ag-theme-fresh .ag-menu-option-active {\n background-color: var(--ag-row-hover-color); }\n .ag-theme-fresh .ag-menu-option-disabled {\n opacity: 0.5; }\n .ag-theme-fresh .ag-menu-option-text {\n margin-left: 4px; }\n .ag-theme-fresh .ag-menu-option-icon {\n padding-left: 8px;\n padding-right: 4px;\n min-width: 20px; }\n .ag-theme-fresh .ag-menu-option-shortcut {\n padding-left: 8px; }\n .ag-theme-fresh .ag-menu-separator {\n height: 8px; }\n .ag-theme-fresh .ag-menu-separator-cell:after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-menu-option-popup-pointer {\n width: 20px;\n text-align: center; }\n .ag-theme-fresh .ag-tabs-header {\n min-width: 220px;\n width: 100%;\n display: flex; }\n .ag-theme-fresh .ag-tab {\n border-bottom: 0 solid transparent;\n display: flex;\n flex: none;\n align-items: center;\n justify-content: center;\n cursor: pointer; }\n .ag-theme-fresh .ag-keyboard-focus .ag-tab:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-tab:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-tab-selected {\n border-bottom-color: #000;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #000))); }\n .ag-theme-fresh .ag-menu-header {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-filter-condition-operator {\n height: 17px; }\n .ag-theme-fresh .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 8px; }\n .ag-theme-fresh .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 8px; }\n .ag-theme-fresh .ag-set-filter-select-all {\n padding-top: 6px; }\n .ag-theme-fresh .ag-set-filter-list {\n height: 120px; }\n .ag-theme-fresh .ag-set-filter-filter {\n margin-top: 6px;\n margin-left: 6px;\n margin-right: 6px; }\n .ag-theme-fresh .ag-filter-to {\n margin-top: 4px; }\n .ag-theme-fresh .ag-mini-filter {\n margin: 6px 6px;\n margin-bottom: 0; }\n .ag-theme-fresh .ag-set-filter-item {\n margin: 0px 6px; }\n .ag-theme-fresh .ag-ltr .ag-set-filter-item-value {\n margin-left: 6px; }\n .ag-theme-fresh .ag-rtl .ag-set-filter-item-value {\n margin-right: 6px; }\n .ag-theme-fresh .ag-filter-header-container {\n padding-bottom: 6px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-fresh .ag-filter-apply-panel {\n padding: 6px 6px;\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-fresh .ag-filter-apply-panel-button {\n line-height: 1.5; }\n .ag-theme-fresh .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 8px; }\n .ag-theme-fresh .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 8px; }\n .ag-theme-fresh .ag-simple-filter-body-wrapper {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-fresh .ag-simple-filter-body-wrapper > * {\n margin-bottom: 4px; }\n .ag-theme-fresh .ag-filter-no-matches {\n margin: 6px 6px; }\n .ag-theme-fresh .ag-side-bar {\n position: relative; }\n .ag-theme-fresh .ag-tool-panel-wrapper {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-fresh .ag-side-buttons {\n padding-top: 16px;\n width: 16px;\n position: relative;\n color: #000;\n color: var(--ag-foreground-color, #000);\n overflow: hidden; }\n .ag-theme-fresh button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 8px 0 8px 0;\n width: calc(100% + 1px);\n margin: 0;\n min-height: 72px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none;\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh button.ag-side-button-button:focus {\n box-shadow: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-side-button-button:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-selected .ag-side-button-button {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-side-button-icon-wrapper {\n margin-bottom: 3px; }\n .ag-theme-fresh .ag-ltr .ag-side-bar-left,\n .ag-theme-fresh .ag-rtl .ag-side-bar-right {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-ltr .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-fresh .ag-rtl .ag-side-bar-right .ag-tool-panel-wrapper {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-ltr .ag-side-bar-left .ag-side-button-button,\n .ag-theme-fresh .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 0 solid transparent;\n margin-right: -1px;\n padding-right: 1px; }\n .ag-theme-fresh .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-fresh .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #000;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #000))); }\n .ag-theme-fresh .ag-rtl .ag-side-bar-left,\n .ag-theme-fresh .ag-ltr .ag-side-bar-right {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-rtl .ag-side-bar-left .ag-tool-panel-wrapper,\n .ag-theme-fresh .ag-ltr .ag-side-bar-right .ag-tool-panel-wrapper {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-rtl .ag-side-bar-left .ag-side-button-button,\n .ag-theme-fresh .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 0 solid transparent;\n margin-left: -1px;\n padding-left: 1px; }\n .ag-theme-fresh .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-fresh .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #000;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-range-selection-border-color, var(--ag-foreground-color, #000))); }\n .ag-theme-fresh .ag-filter-toolpanel-header {\n height: 24px; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-header, .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 4px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-header, .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 4px; }\n .ag-theme-fresh .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f112\";\n position: absolute; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-left: 4px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-right: 4px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-0-header {\n height: 32px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-item {\n margin-top: 2px;\n margin-bottom: 2px; }\n .ag-theme-fresh .ag-filter-toolpanel-search {\n height: 25px; }\n .ag-theme-fresh .ag-filter-toolpanel-search-input {\n flex-grow: 1;\n height: 16px; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 4px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 4px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-0 {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 4px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 4px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 20px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 20px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 36px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 36px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 52px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 52px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 68px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 68px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 84px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 84px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 100px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 100px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 116px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 116px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 132px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 132px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 148px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 148px; }\n .ag-theme-fresh .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 164px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 164px; }\n .ag-theme-fresh .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 4px; }\n .ag-theme-fresh .ag-filter-toolpanel-instance-filter {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey);\n padding-top: 4px; }\n .ag-theme-fresh .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 4px; }\n .ag-theme-fresh .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 4px; }\n .ag-theme-fresh .ag-pivot-mode-panel {\n height: 25px;\n display: flex; }\n .ag-theme-fresh .ag-pivot-mode-select {\n display: flex;\n align-items: center; }\n .ag-theme-fresh .ag-ltr .ag-pivot-mode-select {\n margin-left: 6px; }\n .ag-theme-fresh .ag-rtl .ag-pivot-mode-select {\n margin-right: 6px; }\n .ag-theme-fresh .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-column-select-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-column-select-header {\n height: 25px;\n align-items: center;\n padding: 0 6px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-fresh .ag-column-panel-column-select {\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-fresh .ag-column-group-icons,\n .ag-theme-fresh .ag-column-select-header-icon {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-header {\n background-color: var(--ag-header-background-color);\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-header-row {\n color: #000;\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000))); }\n .ag-theme-fresh .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-header-row {\n height: 25px; }\n .ag-theme-fresh .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-fresh .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-fresh .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 4px; }\n .ag-theme-fresh .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 4px; }\n .ag-theme-fresh .ag-header-cell,\n .ag-theme-fresh .ag-header-group-cell {\n padding-left: 12px;\n padding-right: 12px; }\n .ag-theme-fresh .ag-header-cell.ag-header-cell-moving,\n .ag-theme-fresh .ag-header-group-cell.ag-header-cell-moving {\n background-color: #bebebe;\n background-color: var(--ag-header-cell-moving-background-color, #bebebe); }\n .ag-theme-fresh .ag-keyboard-focus .ag-header-cell:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-header-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none; }\n .ag-theme-fresh .ag-keyboard-focus .ag-header-group-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh .ag-header-icon {\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-header-expand-icon {\n cursor: pointer; }\n .ag-theme-fresh .ag-ltr .ag-header-expand-icon {\n padding-left: 4px; }\n .ag-theme-fresh .ag-rtl .ag-header-expand-icon {\n padding-right: 4px; }\n .ag-theme-fresh .ag-header-row:not(:first-child) .ag-header-cell,\n .ag-theme-fresh .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-header-cell::after,\n .ag-theme-fresh .ag-header-group-cell::after {\n content: \"\";\n position: absolute;\n z-index: 1;\n display: block;\n width: 1px;\n height: 100%;\n top: calc(50% - 50%);\n background-color: rgba(169, 169, 169, 0.5);\n background-color: var(--ag-header-column-separator-color, rgba(169, 169, 169, 0.5)); }\n .ag-theme-fresh .ag-ltr .ag-header-cell::after, .ag-theme-fresh .ag-ltr .ag-header-group-cell::after {\n right: 0; }\n .ag-theme-fresh .ag-rtl .ag-header-cell::after, .ag-theme-fresh .ag-rtl .ag-header-group-cell::after {\n left: 0; }\n .ag-theme-fresh .ag-ltr .ag-header-select-all {\n margin-right: 12px; }\n .ag-theme-fresh .ag-rtl .ag-header-select-all {\n margin-left: 12px; }\n .ag-theme-fresh .ag-ltr .ag-floating-filter-button {\n margin-left: 12px; }\n .ag-theme-fresh .ag-rtl .ag-floating-filter-button {\n margin-right: 12px; }\n .ag-theme-fresh .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 12px;\n padding: 0;\n width: 12px; }\n .ag-theme-fresh .ag-filter-loading {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n height: 100%;\n padding: 6px 6px;\n position: absolute;\n width: 100%;\n z-index: 1; }\n .ag-theme-fresh .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n height: 25px; }\n .ag-theme-fresh .ag-paging-panel > * {\n margin: 0 12px; }\n .ag-theme-fresh .ag-paging-button {\n cursor: pointer;\n opacity: 0;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n padding: 0;\n width: 12px; }\n .ag-theme-fresh .ag-disabled .ag-paging-button {\n cursor: default; }\n .ag-theme-fresh .ag-paging-button-wrapper.ag-disabled {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n cursor: default; }\n .ag-theme-fresh .ag-paging-button-wrapper, .ag-theme-fresh .ag-paging-description {\n margin: 0 4px; }\n .ag-theme-fresh .ag-status-bar {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-border-color, darkgrey);\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n padding-right: 16px;\n padding-left: 16px;\n line-height: 1.5; }\n .ag-theme-fresh .ag-status-name-value-value {\n color: #000;\n color: var(--ag-foreground-color, #000); }\n .ag-theme-fresh .ag-status-bar-center {\n text-align: center; }\n .ag-theme-fresh .ag-status-name-value {\n margin-left: 4px;\n margin-right: 4px;\n padding-top: 8px;\n padding-bottom: 8px; }\n .ag-theme-fresh .ag-column-drop-cell {\n background: var(--ag-chip-background-color);\n border-radius: 16px;\n height: 16px;\n padding: 0 2px; }\n .ag-theme-fresh .ag-column-drop-cell-text {\n margin: 0 4px; }\n .ag-theme-fresh .ag-column-drop-cell-button {\n min-width: 16px;\n margin: 0 2px;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-column-drop-cell-drag-handle {\n margin-left: 8px; }\n .ag-theme-fresh .ag-column-drop-cell-ghost {\n opacity: 0.5; }\n .ag-theme-fresh .ag-column-drop-horizontal {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6);\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000));\n height: 25px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-ltr .ag-column-drop-horizontal {\n padding-left: 12px; }\n .ag-theme-fresh .ag-rtl .ag-column-drop-horizontal {\n padding-right: 12px; }\n .ag-theme-fresh .ag-ltr .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-rtl .ag-column-drop-horizontal-half-width:not(:last-child) {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-column-drop-horizontal-cell-separator {\n margin: 0 4px;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-column-drop-horizontal-empty-message {\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5)); }\n .ag-theme-fresh .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 12px; }\n .ag-theme-fresh .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 12px; }\n .ag-theme-fresh .ag-column-drop-vertical-list {\n padding-bottom: 4px;\n padding-right: 4px;\n padding-left: 4px; }\n .ag-theme-fresh .ag-column-drop-vertical-cell {\n margin-top: 4px; }\n .ag-theme-fresh .ag-column-drop-vertical {\n min-height: 50px;\n max-height: 150px;\n border-bottom: solid 1px;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-fresh .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none; }\n .ag-theme-fresh .ag-column-drop-vertical-icon {\n margin-left: 4px;\n margin-right: 4px; }\n .ag-theme-fresh .ag-column-drop-vertical-list {\n position: relative; }\n .ag-theme-fresh .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(0, 0, 0, 0.5);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.5));\n margin-top: 4px; }\n .ag-theme-fresh .ag-select-agg-func-popup {\n border: solid 1px;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n border-radius: 0px;\n box-shadow: none;\n padding: 4px;\n background: #FFF;\n background: var(--ag-background-color, #FFF);\n height: 70px;\n padding: 0; }\n .ag-theme-fresh .ag-select-agg-func-virtual-list-item {\n cursor: default;\n line-height: 20px;\n padding-left: 8px; }\n .ag-theme-fresh .ag-select-agg-func-virtual-list-item:hover {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5); }\n .ag-theme-fresh .ag-chart-menu {\n border-radius: 0px;\n background: #FFF;\n background: var(--ag-background-color, #FFF); }\n .ag-theme-fresh .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 0px;\n color: #000;\n color: var(--ag-secondary-foreground-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh .ag-chart-menu-icon:hover {\n opacity: 1; }\n .ag-theme-fresh .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey));\n border-radius: 5px;\n margin: 5px; }\n .ag-theme-fresh .ag-chart-mini-thumbnail:nth-last-child(3),\n .ag-theme-fresh .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto; }\n .ag-theme-fresh .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0; }\n .ag-theme-fresh .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0; }\n .ag-theme-fresh .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0; }\n .ag-theme-fresh .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0; }\n .ag-theme-fresh .ag-chart-mini-thumbnail.ag-selected {\n border-color: #000;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-fresh .ag-chart-settings-card-item {\n background: #000;\n background: var(--ag-foreground-color, #000);\n width: 8px;\n height: 8px;\n border-radius: 4px; }\n .ag-theme-fresh .ag-chart-settings-card-item.ag-selected {\n background-color: #000;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-fresh .ag-chart-data-column-drag-handle {\n margin-left: 4px; }\n .ag-theme-fresh .ag-charts-settings-group-title-bar,\n .ag-theme-fresh .ag-charts-data-group-title-bar,\n .ag-theme-fresh .ag-charts-format-top-level-group-title-bar {\n border-top: solid 1px;\n border-top-color: darkgrey;\n border-top-color: var(--ag-secondary-border-color, var(--ag-border-color, darkgrey)); }\n .ag-theme-fresh .ag-charts-settings-group-container {\n padding: 4px; }\n .ag-theme-fresh .ag-charts-data-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-fresh .ag-charts-data-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-fresh .ag-charts-format-top-level-group-container {\n margin-left: 8px;\n padding: 4px; }\n .ag-theme-fresh .ag-charts-format-top-level-group-item {\n margin: 4px 0; }\n .ag-theme-fresh .ag-charts-format-sub-level-group-container {\n padding: 6px 6px;\n padding-bottom: 2px; }\n .ag-theme-fresh .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 4px; }\n .ag-theme-fresh .ag-charts-group-container.ag-group-container-horizontal {\n padding: 4px; }\n .ag-theme-fresh .ag-chart-data-section,\n .ag-theme-fresh .ag-chart-format-section {\n display: flex;\n margin: 0; }\n .ag-theme-fresh .ag-chart-menu-panel {\n background-color: #f6f6f6;\n background-color: var(--ag-control-panel-background-color, #f6f6f6); }\n .ag-theme-fresh .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: darkgrey;\n border-left-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: darkgrey;\n border-right-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-date-time-list-page-title {\n flex-grow: 1;\n text-align: center; }\n .ag-theme-fresh .ag-date-time-list-page-column-label {\n text-align: center; }\n .ag-theme-fresh .ag-date-time-list-page-entry {\n text-align: center; }\n .ag-theme-fresh .ag-checkbox-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n flex: none; }\n .ag-theme-fresh .ag-checkbox-input-wrapper input, .ag-theme-fresh .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-fresh .ag-checkbox-input-wrapper:focus-within, .ag-theme-fresh .ag-checkbox-input-wrapper:active {\n outline: none; }\n .ag-theme-fresh .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-fresh .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #000;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-fresh .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #000;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-fresh .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #000;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000)));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-fresh .ag-toggle-button-input-wrapper {\n box-sizing: border-box;\n width: 24px;\n height: 12px;\n background-color: #000;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000)));\n border-radius: 6px;\n position: relative;\n flex: none;\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-fresh .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%; }\n .ag-theme-fresh .ag-toggle-button-input-wrapper:focus-within {\n outline: none; }\n .ag-theme-fresh .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-fresh .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #000;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)));\n border-color: #000;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-fresh .ag-toggle-button-input-wrapper::before {\n content: ' ';\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n box-sizing: border-box;\n height: 12px;\n width: 12px;\n background-color: #FFF;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #FFF));\n border-radius: 6px;\n transition: left 100ms;\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000)))); }\n .ag-theme-fresh .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 12px);\n border-color: #000;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000))); }\n .ag-theme-fresh .ag-radio-button-input-wrapper {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 12px;\n height: 12px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 0px;\n display: inline-block;\n vertical-align: middle;\n flex: none;\n border-radius: 12px; }\n .ag-theme-fresh .ag-radio-button-input-wrapper input, .ag-theme-fresh .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-fresh .ag-radio-button-input-wrapper:focus-within, .ag-theme-fresh .ag-radio-button-input-wrapper:active {\n outline: none; }\n .ag-theme-fresh .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-fresh .ag-radio-button-input-wrapper::after {\n content: \"\\f124\";\n color: #000;\n color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-fresh .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f125\";\n color: #000;\n color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-fresh input[class^='ag-'][type='range'] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible; }\n .ag-theme-fresh input[class^='ag-'][type='range']::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px; }\n .ag-theme-fresh input[class^='ag-'][type='range']::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px; }\n .ag-theme-fresh input[class^='ag-'][type='range']::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: darkgrey;\n background-color: var(--ag-border-color, darkgrey);\n border-radius: 0px;\n border-radius: 0px;\n color: transparent;\n width: calc(100% - 2px); }\n .ag-theme-fresh input[class^='ag-'][type='range']::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n border-radius: 12px;\n -webkit-transform: translateY(-4.5px);\n transform: translateY(-4.5px); }\n .ag-theme-fresh input[class^='ag-'][type='range']::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n border-radius: 12px; }\n .ag-theme-fresh input[class^='ag-'][type='range']::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 12px;\n height: 12px;\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border: 1px solid;\n border-color: #000;\n border-color: var(--ag-checkbox-unchecked-color, var(--ag-foreground-color, #000));\n border-radius: 12px; }\n .ag-theme-fresh input[class^='ag-'][type='range']:focus {\n outline: none; }\n .ag-theme-fresh input[class^='ag-'][type='range']:focus::-webkit-slider-thumb {\n border-color: #000;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh input[class^='ag-'][type='range']:focus::-ms-thumb {\n border-color: #000;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh input[class^='ag-'][type='range']:focus::-moz-ag-range-thumb {\n border-color: #000;\n border-color: var(--ag-checkbox-checked-color, var(--ag-foreground-color, #000)); }\n .ag-theme-fresh input[class^='ag-'][type='range']:active::-webkit-slider-runnable-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh input[class^='ag-'][type='range']:active::-moz-ag-range-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh input[class^='ag-'][type='range']:active::-ms-track {\n background-color: var(--ag-input-focus-border-color); }\n .ag-theme-fresh input[class^='ag-'][type='range']:disabled {\n opacity: 0.5; }\n .ag-theme-fresh .ag-icon {\n color: #333; }\n .ag-theme-fresh .ag-icon-tree-closed::before {\n content: \"\\f10b\"; }\n .ag-theme-fresh .ag-icon-tree-open::before {\n content: \"\\f10f\"; }\n .ag-theme-fresh .ag-header, .ag-theme-fresh .ag-column-drop-cell {\n background-image: linear-gradient(white, lightgrey); }\n .ag-theme-fresh .ag-tab {\n border: 1px solid transparent;\n padding: 4px 8px;\n margin: 4px;\n margin-bottom: -1px; }\n .ag-theme-fresh .ag-tabs-body {\n margin: 2px 0; }\n .ag-theme-fresh .ag-icon {\n margin: 1px 1px 2px 1px; }\n .ag-theme-fresh .ag-tab-selected {\n background-color: #FFF;\n background-color: var(--ag-background-color, #FFF);\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-bottom-color: transparent; }\n .ag-theme-fresh .ag-tabs-header {\n background-color: var(--ag-header-background-color);\n border-bottom: 1px solid;\n border-bottom-color: darkgrey;\n border-bottom-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-filter .ag-filter-apply-panel {\n justify-content: flex-start; }\n .ag-theme-fresh .ag-menu-option-active {\n background-color: #bde2e5;\n background-color: var(--ag-selected-row-background-color, #bde2e5); }\n .ag-theme-fresh .ag-column-drop-cell {\n border: 1px solid;\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey);\n border-radius: 0; }\n .ag-theme-fresh .ag-column-drop-cell-button .ag-icon {\n border: 1px solid transparent; }\n .ag-theme-fresh .ag-column-drop-cell-button:hover .ag-icon {\n border-color: darkgrey;\n border-color: var(--ag-border-color, darkgrey); }\n .ag-theme-fresh .ag-panel-title-bar-button-icon {\n font-size: 20px;\n line-height: 20px; }\n .ag-theme-fresh .ag-menu-option-part {\n padding-top: 4px;\n padding-bottom: 4px; }\n .ag-theme-fresh .ag-column-drop-vertical-title-bar {\n margin-top: 4px;\n margin-left: 4px; }\n .ag-theme-fresh .ag-column-drop-vertical-title {\n margin-left: 4px; }\n .ag-theme-fresh .ag-column-drop-vertical-empty-message {\n margin-left: 24px; }\n\n", ""]);
  46388. // Exports
  46389. module.exports = exports;
  46390. /***/ }),
  46391. /* 244 */
  46392. /***/ (function(module, exports, __webpack_require__) {
  46393. var api = __webpack_require__(225);
  46394. var content = __webpack_require__(245);
  46395. content = content.__esModule ? content.default : content;
  46396. if (typeof content === 'string') {
  46397. content = [[module.i, content, '']];
  46398. }
  46399. var options = {};
  46400. options.insert = "head";
  46401. options.singleton = false;
  46402. var update = api(content, options);
  46403. module.exports = content.locals || {};
  46404. /***/ }),
  46405. /* 245 */
  46406. /***/ (function(module, exports, __webpack_require__) {
  46407. // Imports
  46408. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227);
  46409. exports = ___CSS_LOADER_API_IMPORT___(false);
  46410. // Module
  46411. exports.push([module.i, ".ag-theme-material {\n -webkit-font-smoothing: antialiased;\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-foreground-color, rgba(0, 0, 0, 0.87));\n font-family: \"Roboto\", sans-serif;\n font-size: 13px;\n line-height: normal; }\n\n@font-face {\n font-family: \"agGridMaterial\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABGsAAsAAAAAIJAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlEAAAReYPJi3U9TLzIAAANcAAAAPgAAAFZWTFJvY21hcAAAA5wAAAHsAAAFgGqPB0pnbHlmAAAFiAAACFEAAA58peGl1GhlYWQAAA3cAAAALwAAADZ2zcSBaGhlYQAADgwAAAAWAAAAJAfRBDJobXR4AAAOJAAAABIAAAEkt5gAAGxvY2EAAA44AAAAbQAAAJSyFLU8bWF4cAAADqgAAAAfAAAAIAFcAEluYW1lAAAOyAAAATIAAAJebBQ2inBvc3QAAA/8AAABrgAAAom3/2OGeJx9k09yElEQxr9hCCYBk6gRFVFT8X/UOM4MTIBIQBApKwsXLly4iQstrZSrnMC1B7A8gKfwBJZLVx7AA1gewF83g5gswhQz73V//fXX/fopkLSoSF0VhqPd51ra3zt4r5qKmvzM//862H/7Zk/z0x2+on/nFYR/tKR1vdCBvgUKXgefC6WwEHbD3fBD+Cn8oRDUmjZBl/WAJ1bCO1KqhprKVFAJW8x6Sy3QIe+2W0+rqjn3DDTUWXLGxAydcUNPdU0r8PSdp0ctAzhT5+zxHvFc1/IxiEw34G+gZhursdbReUoLeozGHjo6RLfwruDbIXNETB9fH22ho4rex7Fe6h42q80iGzku5R/rke8j31XowhTVhr8Jv/FtknVqb5IpIeIu7A1QD/MebugK0U14erB1PHrLoysgExSmuszKKkuorEKH2nqmV0SWUTGJ6XkXJzXfQv3M3ne+TLcPWTtwjcDeQcPMaidyk1xWewK+yv6dPuqLvuq7fuqXfoOvkiXxCrpw7xzbmQX6dxQ9wNv+Z7VKT3AWR1GHEYvU3fTexPiGeQctWwWf9SZlHWFNHV+G0/AD1GScxhyTF3neBGuJ/Tb7GPRSPo0tnpPe5yEzYBNQo5Mxb2OazFtGhy8QbauJrnPerRY85/20rKd2k5Z9ZzNvp1zj1C/yjais4f15gvcSFmOaWeoelaHaOO7jz1A7y2aq6qhKfXZtssZ+CwZkWqOOiZJEV/0GjH2q1lHQyG/kqs64+k5+UquOiz0qoBNRfpNT75lNch9tNhWjv/VfaSwAAAB4nGNgZGphnMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVFgEqgRRAAA0p8KWwAAeJy11AduVDEUheF/SkILvbcUSK+T3ntlGaFHoUShR6ySndwNEM4dHxYQJCx9c8d+nvdsPZ8BWoCaDEsdqnUqZPut0UpzvMbF5nidX+q3cZ6qvo9wwBEn0Tg91egI+xxyHJVm72+raHYbj+hlRr01GqywwDqT7DDOEtMss8gGs7q+xQTzTLHJHnOsss2ufl/V0+u0ck5PvaB1XNL9LnOFq1zjOje4yS1uc4e73OM+D3iopz3WnHY66KSLp5rXTY9W0Ec/AwwypB21ab2jjGmBrZytrZ1xfrbGysL65M74kna7uDE7o43OT23uza1u7/7Dzf5Da8uP2k/3npFvs1iTfWvIc1uRF7YgL21dXtmkvLYdeWPj8taW5MCm5dCW5Z0tynvbkA82Kx8tT9eRbcmxTcgnm5fPNiVfbFO+2p58szn5bqvyw7blxPQCo1JkVqJakLVWZLaiXmS+oqXQmSZMp5swnXPCdOIJywyGKQWE5dsLUzIIU0YIU1oIUx4IU4IIU5YIU6oIU74IU9IIU+YIU/oIUw4JUyIJUzYJU0oJU14JU3IJa+6rvSBrR0HWzoKsXQVZnxRKPWHN/XYXZO0pyNpbkLWvIGt/QdaBgqyDBVmHCrIOF/kfGiNFc/2jRWYpxgpyrFEw9gcVSJ+veJzFV21MW+cVvue9xTcmEOKAffECduyLfWkwrsy1udgGwlcCisrHZCdaG1LTdIG0sBjaVF2WoX1okyK1ayqt9Efzp9GkizSpTVv+pNOUVCxVmfrHUfNrYmzqn+GsQ1RCreTGVzvnxTbhY1Kn/Rjc933PfT/OPee8z/mwAAL+sTWxR9gvCOCxV4LdE/HoqoetmRVQZX4FG+byvXvQIHYncrnEbCYjCI/RGfED8QPBIlQKNcJhPKlFNFXSJCUiyRHNp9oVu2ZXFbsi6wrcMNKLi+k26lj/Yjo9z9/Zz7CfJyqxmDbSOlLIlssj9qA8+wShWtZtmk3WYT6WTa7GzQXYiGfNMvg2G4dBFJvvnRPnUIYjeNQrWSRLjeyQHS16q94aVv2qv1pSJVVXdVmXJdiYeTalR6N66tkvikQq9tZbsbk53otz25Y4kf9zcRV74f/zTZF/s1asRUqie6rWbAo1XbMrmdnZB5cuZV9+mT1vTrCB/K1cTijJuSquCtWCk27WewDsthoXaJ6WTojYwkGwgi6DLF5++LVLc+EjlvMxv2Y+GFoCY0hcxfdtiw+/BsfQp2AMb+cv781fRCDt4v6b/H0W2M05f3/6UZ4i52nz2Hx78UWeYvkOvpuT6Z18C7b7sfhDoQwRVSsIVpBkK4i6Gyx0dfYaR0trhK6N/dNMxZ4z89C5tPTp+/v3O6scoeMhR5UTFuFGHBfMP0HH0lJnZaXrsN/pDYW8Tl+di9hbS5jdvJ8qbpPDgltQ6K4iCjUJWwSbjE23a5GywrwN27xh5PhTGM2xwhu7buTHcUwahQlcwafoJ+waW0O9BFRJQi95M3b7dizH1uJ37sRzJdz8XLyDmjuFen5LFjt6lEfmRI0DjdqKNvUr1R6bh71vViihJGzMmhFSDz7DXgEzAp+Jt0Pe/EesPxFS8h/RGutXQvnzrL/gr4RNih+Iey6KrKtibTybLT7sr4+8bPdxPGNTbKoEYjd3chgkJ4dvzbIsOvwOPZG7rrLXY7lc7DZbiOdy8TulmPEUWxXa8SXIFK9FUlu1FtkF8gFAUldwQpEtitevKi6mtehEq0HAJdkiabTZIWvsTSnYp3ri8uBTEyMDJ16ok0+1DfmsvZLt6FDfPqsnvK9Xaj6uNhzp7x3A9ck6//fPWB/71eP1jUfC1h5m83UoTseg5nZf7O845xn0abWHjh4H1e3vVKpOfI+mx7pGq2sa6/xFXJLMhxAnjTySoKwoMQaSTtBRNr/oDUK4E1pcUHMARK+FoBr2wwaXre6FEwPvIFFfj8RI4GQgcPIH1AUao9GRaJT9g77Xf9HtLo7mZGEHdiDSnpFoESOTaN9CbPEhHikHAHovRm7DXGZr+WuYBSpyCbiRSJjLyVJ8Yd/we7HSzeh4N4AxiX3z8cd4MWYkmYQIATFHZwu+3cNm+Hco03jKKD5058fZ24U2k5hP0DYL3/uMWI5UuWAT7IheN51BMzQBCaejTXCo5h6FmUdBM2msHxzo8vPgMB/MI2FWpOlvhYICDFI3ND29gmM6fz+dnqbpXXpUE3pVD+rxFVcDXkkm2QJXA5XYmZ8AEyVGURXV2IQrDBJ0mSsbMxfMhVi2aN859gnmi1ohgF9AUeMQUTCuYVTjVBBkNIUPU2aLi5GKSHQCRrrfedsVw4iOtbWNRQ1Daff+HobMD+EVToNSWoQNJa4Mt6VeTLUNK3EpaWB/gmbGZlJtxbhajvaUuR0xLWHikCXM0hFMVGRAHbO2qOkRVZHsLHB+ePyNN8aHz0+XiPHR7u7RbvaTbZNEmFe6aalgl0lxkjSuxtudRdgcEicTwh4Y01Fd/o93yPdtNiwvkplEouDza8I9OqkjLw6hDMfGnrxsBbzO0r4ivy24io/kbI8Q/A9ZG8JEUiCAIABGCkCM1dDGvXK42dMceHLwTPRCk9nsbYBBJOBzbwNN7pXSzdSZwScDzQ1es7npgvllgxc+b7oQ5XNFnaYwTjvwflSUTwkCxjBlR5D2tDhqLF5/uBU8Ng1V1sTam5VdI12VN3lIHqDeXLY5nV6nEyL5W0l4JylO+oJBH0bv83zPdW+oVqnFB210fXa2iI0usROlqKJMourVwKM41S8qnHlVffVvEHC51ttPr59qv+yCVpyBv5v3Xa7L7afWT7evu7bqjf+dj7VUW27mUI/gE5qEJwRN0DE2edBX0BSdVA24qC44AIBug/bw+PinsOTUfLz8onlyKR0bRRm3Vl+vudnbfMz/yzAQK33wR/OLY8fUiYmb+P6l2nWsccK8gqRjZWXFMNq2Drg5A7Ab8GvzynvHuujI/BNqFxLgp8RsbKu5aoTHiyg7SCg7QtA6SCgTvdRzqLXQSgFgVy/N9Pb19c5cgoNF6uqPzj4d0fXI02f/UiTEVVow17dvfvjTbZs4UcAUyVKBNmwlaXjA2Qws6n8hWt9Lvb0vXaWu77tJydYK+7HLfWeBd8VWSUbPx5zyaM3Pa4RsDIt/VvCZSfwF4tisFZWSr5TpHHY2dJD8rcSma5gLU7FMJjaVpB800GAu8xKnoW4qnsnEp+C3pZrqE3aWuAMWVA2ZDBulXzzFtbMYxxmXjebZ3b3WEOyvZTJ0VtjFEwtunKf1LX2fEyuKtQ2ocPHd+CpsxCDxbiyLY7G+Yq5iXM1Qjc9cyRLvNXZtswak4qiQq9jrVAlu1YBzaCfKoy0UWyjNgN1hkWQsqBEMEtakVCjZt/JRJIyFEW6U8dGB3d1MOPrRjvCxtrFzo8l9+Vu/jA0Us1JP6LT7xdTAfDjfz+5i6lECx/d3HD7XHk21GUmY+kXt811RnpmU0Mmy08lncCf7gyD8G975gHwAAAB4nGNgZGBgAOLNefk58fw2Xxm4mV8ABaI4H+9rQNAMDMwvQOIMHAxMIB4AThwLfgB4nGNgZGBgfsHAgEQyMqACTwBFgwMNAAB4nGNgYGBgfjF0MT0AAODAKyYAAHicY2AAAikGD4Y4hhkMlxjeMMowujEWMC5ivMP4jkmByYopgCmJaQ8zA7MMswmzF3MD8wzmDcyfWFRYjFi8WCJYilgOsTKwqrB6sC5jfcPmxhbD1sY2hW0R2wa2fWwX2O6xfWC3Ix0CAAMJHZwAAAB4nGNgZGBg8GSwZeBkAAEmIOYCQgaG/2A+AwAWwQGmAHicfZA9asNAEIWf/BdiQwiEuFKxEEgTkH9Kk9qCgBsX7mVrJcustWK1NvgGOUhOkEOkzEFyijytt7ELz8LwvTdvplgAj/hBgKYCPLjeVAt3VGduk549d8gvnrsYYOK5R//dcx9v+PA8wBMOvBB07umE+PTcYv7Lc5v+t+cO+ddzF0P8ee4hDOC5j1UQeh7gNTBJHpsiXSRWmiJRS5kfVHJlXqqVNHWhSzGJxpeDWJbSkFOxPon6mE+tzURm9F7MdWmlUlpURu/kxkZba6vZaJR5P9roPRLkiGFQIMWCykI6lUBhSc75F4rK3Ezemq0c11QaJQT/P8L45kZMLp0++ym31jix1zhyb0rXIqPOmNHYk+buepNWfJpO5WY7Ohv6EbZuq8IMI77sKh8xxUv/NPJv3gAAeJxtkQdv2zAQhf3Fki3baeO6bbr3Hmqb7r1X+i9oipaJSKRAUR759WXtIECAHnDgew+Hd4OtjdY6+q3/xy4btImI6dAloUefAZsc4zhbDDnBiJOc4jTbnOEs5zjPBS5yictc4SrXuM4NbnKL29zhLve4zwMekvKIxzxhh6c84zkveMkrXvOGt7zjPR/4yCc+84WvfOM7P/jJL36zy5/WQOS5U7nw2pqOcM7O67aoZUcKI1WRrJ90J5ZT4fxQTpXcG9tFugIq2z4UtMmUV67URng1OpQbc1C5KW1hXVrpQFw3kKY0dV9a452QXmWRtNUyls7WdZSpWiZqUYngmfXUUqV1IeppO6DORBehTTzRrvZR7nQV5842VRQKfFSoie8U2oR+3cKKTJs8KcVCl3pfRaUyTRLmWzNjjRoY61NRFHausrgKBqpdaROHDAtXemb90AUTm44b761J7WSydVQwsdP51Ee1mKl+XQavNLNzcwD/jTNYw1VZssZhWh/OMPJOqaN3660kWymTNGa9B4Ich8KjsRjm1EgKpuwxZhE+P6OkoWLJhH1mrdZfDrCtIAAA\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n .ag-theme-material .ag-icon {\n font-family: \"agGridMaterial\";\n font-size: 18px;\n line-height: 18px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n .ag-theme-material .ag-icon-aggregation:before {\n content: \"\\f101\"; }\n .ag-theme-material .ag-icon-arrows:before {\n content: \"\\f102\"; }\n .ag-theme-material .ag-icon-asc:before {\n content: \"\\f103\"; }\n .ag-theme-material .ag-icon-cancel:before {\n content: \"\\f104\"; }\n .ag-theme-material .ag-icon-chart:before {\n content: \"\\f105\"; }\n .ag-theme-material .ag-icon-color-picker:before {\n content: \"\\f109\"; }\n .ag-theme-material .ag-icon-columns:before {\n content: \"\\f10a\"; }\n .ag-theme-material .ag-icon-contracted:before {\n content: \"\\f10b\"; }\n .ag-theme-material .ag-icon-copy:before {\n content: \"\\f10c\"; }\n .ag-theme-material .ag-icon-cross:before {\n content: \"\\f10d\"; }\n .ag-theme-material .ag-icon-desc:before {\n content: \"\\f10e\"; }\n .ag-theme-material .ag-icon-expanded:before {\n content: \"\\f10f\"; }\n .ag-theme-material .ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n .ag-theme-material .ag-icon-eye:before {\n content: \"\\f111\"; }\n .ag-theme-material .ag-icon-filter:before {\n content: \"\\f112\"; }\n .ag-theme-material .ag-icon-first:before {\n content: \"\\f113\"; }\n .ag-theme-material .ag-icon-grip:before {\n content: \"\\f114\"; }\n .ag-theme-material .ag-icon-group:before {\n content: \"\\f115\"; }\n .ag-theme-material .ag-icon-last:before {\n content: \"\\f116\"; }\n .ag-theme-material .ag-icon-left:before {\n content: \"\\f117\"; }\n .ag-theme-material .ag-icon-linked:before {\n content: \"\\f118\"; }\n .ag-theme-material .ag-icon-loading:before {\n content: \"\\f119\"; }\n .ag-theme-material .ag-icon-maximize:before {\n content: \"\\f11a\"; }\n .ag-theme-material .ag-icon-menu:before {\n content: \"\\f11b\"; }\n .ag-theme-material .ag-icon-minimize:before {\n content: \"\\f11c\"; }\n .ag-theme-material .ag-icon-next:before {\n content: \"\\f11d\"; }\n .ag-theme-material .ag-icon-none:before {\n content: \"\\f11e\"; }\n .ag-theme-material .ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n .ag-theme-material .ag-icon-paste:before {\n content: \"\\f120\"; }\n .ag-theme-material .ag-icon-pin:before {\n content: \"\\f121\"; }\n .ag-theme-material .ag-icon-pivot:before {\n content: \"\\f122\"; }\n .ag-theme-material .ag-icon-previous:before {\n content: \"\\f123\"; }\n .ag-theme-material .ag-icon-right:before {\n content: \"\\f126\"; }\n .ag-theme-material .ag-icon-save:before {\n content: \"\\f127\"; }\n .ag-theme-material .ag-icon-small-down:before {\n content: \"\\f128\"; }\n .ag-theme-material .ag-icon-small-left:before {\n content: \"\\f129\"; }\n .ag-theme-material .ag-icon-small-right:before {\n content: \"\\f12a\"; }\n .ag-theme-material .ag-icon-small-up:before {\n content: \"\\f12b\"; }\n .ag-theme-material .ag-icon-tick:before {\n content: \"\\f12c\"; }\n .ag-theme-material .ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n .ag-theme-material .ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n .ag-theme-material .ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n .ag-theme-material .ag-icon-unlinked:before {\n content: \"\\f130\"; }\n .ag-theme-material .ag-icon-row-drag:before {\n content: \"\\f114\"; }\n .ag-theme-material .ag-right-arrow:before {\n content: \"\\f117\"; }\n .ag-theme-material .ag-right-arrow:before {\n content: \"\\f126\"; }\n .ag-theme-material .ag-root-wrapper {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-material [class^='ag-'], .ag-theme-material [class^='ag-']:focus, .ag-theme-material [class^='ag-']:after, .ag-theme-material [class^='ag-']:before {\n box-sizing: border-box;\n outline: none; }\n .ag-theme-material [class^='ag-']::-ms-clear {\n display: none; }\n .ag-theme-material .ag-checkbox .ag-input-wrapper,\n .ag-theme-material .ag-radio-button .ag-input-wrapper {\n overflow: visible; }\n .ag-theme-material .ag-range-field .ag-input-wrapper {\n height: 100%; }\n .ag-theme-material .ag-toggle-button {\n flex: none;\n width: unset;\n min-width: unset; }\n .ag-theme-material .ag-ltr .ag-label-align-right .ag-label {\n margin-left: 8px; }\n .ag-theme-material .ag-rtl .ag-label-align-right .ag-label {\n margin-right: 8px; }\n .ag-theme-material input[class^='ag-'] {\n margin: 0;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-material textarea[class^='ag-'],\n .ag-theme-material select[class^='ag-'] {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-material input[class^='ag-']:not([type]),\n .ag-theme-material input[class^='ag-'][type='text'],\n .ag-theme-material input[class^='ag-'][type='number'],\n .ag-theme-material input[class^='ag-'][type='tel'],\n .ag-theme-material input[class^='ag-'][type='date'],\n .ag-theme-material input[class^='ag-'][type='datetime-local'],\n .ag-theme-material textarea[class^='ag-'] {\n font-size: inherit;\n line-height: inherit;\n color: inherit; }\n .ag-theme-material input[class^='ag-']:not([type]):disabled,\n .ag-theme-material input[class^='ag-'][type='text']:disabled,\n .ag-theme-material input[class^='ag-'][type='number']:disabled,\n .ag-theme-material input[class^='ag-'][type='tel']:disabled,\n .ag-theme-material input[class^='ag-'][type='date']:disabled,\n .ag-theme-material input[class^='ag-'][type='datetime-local']:disabled,\n .ag-theme-material textarea[class^='ag-']:disabled {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n background-color: var(--ag-input-disabled-background-color);\n border-color: var(--ag-input-disabled-border-color); }\n .ag-theme-material input[class^='ag-']:not([type]):focus,\n .ag-theme-material input[class^='ag-'][type='text']:focus,\n .ag-theme-material input[class^='ag-'][type='number']:focus,\n .ag-theme-material input[class^='ag-'][type='tel']:focus,\n .ag-theme-material input[class^='ag-'][type='date']:focus,\n .ag-theme-material input[class^='ag-'][type='datetime-local']:focus,\n .ag-theme-material textarea[class^='ag-']:focus {\n outline: none;\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material input[class^='ag-'][type='number'] {\n -moz-appearance: textfield; }\n .ag-theme-material input[class^='ag-'][type='number']::-webkit-outer-spin-button, .ag-theme-material input[class^='ag-'][type='number']::-webkit-inner-spin-button {\n -webkit-appearance: none;\n margin: 0; }\n .ag-theme-material input[class^='ag-'][type='range'] {\n padding: 0; }\n .ag-theme-material input[class^='ag-'][type='button']:focus, .ag-theme-material button[class^='ag-']:focus {\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122); }\n .ag-theme-material .ag-drag-handle {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-list-item, .ag-theme-material .ag-virtual-list-item {\n height: 40px; }\n .ag-theme-material .ag-keyboard-focus .ag-virtual-list-item:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-virtual-list-item:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-select-list {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n overflow-y: auto;\n overflow-x: hidden; }\n .ag-theme-material .ag-list-item {\n display: flex;\n align-items: center; }\n .ag-theme-material .ag-list-item.ag-active-item {\n background-color: #fafafa;\n background-color: var(--ag-row-hover-color, #fafafa); }\n .ag-theme-material .ag-select-list-item {\n padding-left: 4px;\n padding-right: 4px;\n cursor: default;\n -moz-user-select: none;\n -webkit-user-select: none;\n -ms-user-select: none;\n user-select: none; }\n .ag-theme-material .ag-select-list-item span {\n white-space: nowrap;\n text-overflow: ellipsis;\n overflow: hidden; }\n .ag-theme-material .ag-select .ag-picker-field-wrapper {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n min-height: 40px;\n cursor: default; }\n .ag-theme-material .ag-select:not(.ag-cell-editor) {\n height: 40px; }\n .ag-theme-material .ag-select .ag-picker-field-display {\n margin: 4px;\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis; }\n .ag-theme-material .ag-select .ag-picker-field-icon {\n display: flex;\n align-items: center; }\n .ag-theme-material .ag-select.ag-disabled {\n opacity: 0.5; }\n .ag-theme-material .ag-rich-select {\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa); }\n .ag-theme-material .ag-rich-select-list {\n width: 100%;\n min-width: 200px;\n height: 312px; }\n .ag-theme-material .ag-rich-select-value {\n padding: 0 8px 0 24px;\n height: 48px; }\n .ag-theme-material .ag-rich-select-virtual-list-item {\n cursor: default;\n height: 40px; }\n .ag-theme-material .ag-rich-select-virtual-list-item:hover {\n background-color: #fafafa;\n background-color: var(--ag-row-hover-color, #fafafa); }\n .ag-theme-material .ag-rich-select-row {\n padding-left: 24px; }\n .ag-theme-material .ag-rich-select-row-selected {\n background-color: #eee;\n background-color: var(--ag-selected-row-background-color, #eee); }\n .ag-theme-material .ag-row-drag,\n .ag-theme-material .ag-selection-checkbox,\n .ag-theme-material .ag-group-expanded,\n .ag-theme-material .ag-group-contracted {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-ltr .ag-row-drag, .ag-theme-material .ag-ltr .ag-selection-checkbox, .ag-theme-material .ag-ltr .ag-group-expanded, .ag-theme-material .ag-ltr .ag-group-contracted {\n margin-right: 24px; }\n .ag-theme-material .ag-rtl .ag-row-drag, .ag-theme-material .ag-rtl .ag-selection-checkbox, .ag-theme-material .ag-rtl .ag-group-expanded, .ag-theme-material .ag-rtl .ag-group-contracted {\n margin-left: 24px; }\n .ag-theme-material .ag-cell-wrapper > *:not(.ag-cell-value):not(.ag-group-value) {\n height: 46px;\n display: flex;\n align-items: center;\n flex: none; }\n .ag-theme-material .ag-group-expanded,\n .ag-theme-material .ag-group-contracted {\n cursor: pointer; }\n .ag-theme-material .ag-group-title-bar-icon {\n cursor: pointer;\n flex: none;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-ltr .ag-group-child-count {\n margin-left: 2px; }\n .ag-theme-material .ag-rtl .ag-group-child-count {\n margin-right: 2px; }\n .ag-theme-material .ag-group-title-bar {\n background-color: #eee;\n background-color: var(--ag-subheader-background-color, #eee);\n padding: 8px; }\n .ag-theme-material .ag-group-toolbar {\n padding: 8px; }\n .ag-theme-material .ag-disabled-group-title-bar, .ag-theme-material .ag-disabled-group-container {\n opacity: 0.5; }\n .ag-theme-material .group-item {\n margin: 4px 0; }\n .ag-theme-material .ag-label {\n white-space: nowrap; }\n .ag-theme-material .ag-ltr .ag-label {\n margin-right: 8px; }\n .ag-theme-material .ag-rtl .ag-label {\n margin-left: 8px; }\n .ag-theme-material .ag-label-align-top .ag-label {\n margin-bottom: 4px; }\n .ag-theme-material .ag-ltr .ag-slider-field, .ag-theme-material .ag-ltr .ag-angle-select-field {\n margin-right: 16px; }\n .ag-theme-material .ag-rtl .ag-slider-field, .ag-theme-material .ag-rtl .ag-angle-select-field {\n margin-left: 16px; }\n .ag-theme-material .ag-angle-select-parent-circle {\n width: 24px;\n height: 24px;\n border-radius: 12px;\n border: solid 1px;\n border-color: #e2e2e2;\n border-color: var(--ag-border-color, #e2e2e2);\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-material .ag-angle-select-child-circle {\n top: 4px;\n left: 12px;\n width: 6px;\n height: 6px;\n margin-left: -3px;\n margin-top: -4px;\n border-radius: 3px;\n background-color: rgba(0, 0, 0, 0.54);\n background-color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-picker-field-wrapper {\n border: 1px solid;\n border-color: #e2e2e2;\n border-color: var(--ag-border-color, #e2e2e2);\n border-radius: 5px; }\n .ag-theme-material .ag-picker-field-wrapper:focus {\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122); }\n .ag-theme-material .ag-picker-field-button {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-dialog.ag-color-dialog {\n border-radius: 5px; }\n .ag-theme-material .ag-color-picker .ag-picker-field-display {\n height: 18px; }\n .ag-theme-material .ag-color-panel {\n padding: 8px; }\n .ag-theme-material .ag-spectrum-color {\n background-color: red;\n border-radius: 2px; }\n .ag-theme-material .ag-spectrum-tools {\n padding: 10px; }\n .ag-theme-material .ag-spectrum-sat {\n background-image: linear-gradient(to right, white, rgba(204, 154, 129, 0)); }\n .ag-theme-material .ag-spectrum-val {\n background-image: linear-gradient(to top, black, rgba(204, 154, 129, 0)); }\n .ag-theme-material .ag-spectrum-dragger {\n border-radius: 12px;\n height: 12px;\n width: 12px;\n border: 1px solid white;\n background: black;\n box-shadow: 0 0 2px 0px rgba(0, 0, 0, 0.24); }\n .ag-theme-material .ag-spectrum-hue-background {\n border-radius: 2px; }\n .ag-theme-material .ag-spectrum-alpha-background {\n border-radius: 2px; }\n .ag-theme-material .ag-spectrum-tool {\n margin-bottom: 10px;\n height: 11px;\n border-radius: 2px; }\n .ag-theme-material .ag-spectrum-slider {\n margin-top: -12px;\n width: 13px;\n height: 13px;\n border-radius: 13px;\n background-color: #f8f8f8;\n box-shadow: 0 1px 4px 0 rgba(0, 0, 0, 0.37); }\n .ag-theme-material .ag-recent-color {\n margin: 0 3px; }\n .ag-theme-material .ag-recent-color:first-child {\n margin-left: 0; }\n .ag-theme-material .ag-recent-color:last-child {\n margin-right: 0; }\n .ag-theme-material.ag-dnd-ghost {\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 2px;\n box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n padding: 8px;\n overflow: hidden;\n text-overflow: ellipsis;\n z-index: 10;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n height: 56px !important;\n line-height: 56px;\n margin: 0;\n padding: 0 16px;\n -webkit-transform: translateY(16px);\n transform: translateY(16px); }\n .ag-theme-material .ag-dnd-ghost-icon {\n margin-right: 8px;\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-foreground-color, rgba(0, 0, 0, 0.87)); }\n .ag-theme-material .ag-popup-child:not(.ag-tooltip-custom) {\n box-shadow: 5px 5px 10px rgba(0, 0, 0, 0.3); }\n .ag-dragging-range-handle .ag-theme-material .ag-dialog,\n .ag-dragging-fill-handle .ag-theme-material .ag-dialog {\n opacity: 0.7;\n pointer-events: none; }\n .ag-theme-material .ag-dialog {\n border-radius: 0px; }\n .ag-theme-material .ag-panel {\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-material .ag-panel-title-bar {\n background-color: #fff;\n background-color: var(--ag-header-background-color, #fff);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)));\n height: 56px;\n padding: 8px 24px; }\n .ag-theme-material .ag-ltr .ag-panel-title-bar-button {\n margin-left: 8px; }\n .ag-theme-material .ag-rtl .ag-panel-title-bar-button {\n margin-right: 8px; }\n .ag-theme-material .ag-tooltip {\n background-color: #fff;\n background-color: var(--ag-header-background-color, #fff);\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-foreground-color, rgba(0, 0, 0, 0.87));\n padding: 8px;\n border-radius: 2px;\n transition: opacity 1s; }\n .ag-theme-material .ag-tooltip.ag-tooltip-hiding {\n opacity: 0; }\n .ag-theme-material .ag-ltr .ag-column-select-indent-1 {\n padding-left: 26px; }\n .ag-theme-material .ag-rtl .ag-column-select-indent-1 {\n padding-right: 26px; }\n .ag-theme-material .ag-ltr .ag-column-select-indent-2 {\n padding-left: 52px; }\n .ag-theme-material .ag-rtl .ag-column-select-indent-2 {\n padding-right: 52px; }\n .ag-theme-material .ag-ltr .ag-column-select-indent-3 {\n padding-left: 78px; }\n .ag-theme-material .ag-rtl .ag-column-select-indent-3 {\n padding-right: 78px; }\n .ag-theme-material .ag-ltr .ag-column-select-indent-4 {\n padding-left: 104px; }\n .ag-theme-material .ag-rtl .ag-column-select-indent-4 {\n padding-right: 104px; }\n .ag-theme-material .ag-ltr .ag-column-select-indent-5 {\n padding-left: 130px; }\n .ag-theme-material .ag-rtl .ag-column-select-indent-5 {\n padding-right: 130px; }\n .ag-theme-material .ag-ltr .ag-column-select-indent-6 {\n padding-left: 156px; }\n .ag-theme-material .ag-rtl .ag-column-select-indent-6 {\n padding-right: 156px; }\n .ag-theme-material .ag-ltr .ag-column-select-indent-7 {\n padding-left: 182px; }\n .ag-theme-material .ag-rtl .ag-column-select-indent-7 {\n padding-right: 182px; }\n .ag-theme-material .ag-ltr .ag-column-select-indent-8 {\n padding-left: 208px; }\n .ag-theme-material .ag-rtl .ag-column-select-indent-8 {\n padding-right: 208px; }\n .ag-theme-material .ag-ltr .ag-column-select-indent-9 {\n padding-left: 234px; }\n .ag-theme-material .ag-rtl .ag-column-select-indent-9 {\n padding-right: 234px; }\n .ag-theme-material .ag-column-select-header-icon {\n cursor: pointer; }\n .ag-theme-material .ag-keyboard-focus .ag-column-select-header-icon:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-column-select-header-icon:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 0px;\n left: 0px;\n display: block;\n width: calc(100% - 0px);\n height: calc(100% - 0px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-ltr .ag-column-group-icons:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-header-icon:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-header-checkbox:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-checkbox:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-material .ag-ltr .ag-column-select-column-label:not(:last-child) {\n margin-right: 12px; }\n .ag-theme-material .ag-rtl .ag-column-group-icons:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-header-icon:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-header-checkbox:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-header-filter-wrapper:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-checkbox:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-column-drag-handle:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-column-group-drag-handle:not(:last-child), .ag-theme-material .ag-rtl .ag-column-select-column-label:not(:last-child) {\n margin-left: 12px; }\n .ag-theme-material .ag-keyboard-focus .ag-column-select-column-group:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-column-select-column-group:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -4px;\n left: -4px;\n display: block;\n width: calc(100% - -8px);\n height: calc(100% - -8px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-keyboard-focus .ag-column-select-column:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-column-select-column:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: -4px;\n left: -4px;\n display: block;\n width: calc(100% - -8px);\n height: calc(100% - -8px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-column-select-column-group:not(:last-child),\n .ag-theme-material .ag-column-select-column:not(:last-child) {\n margin-bottom: 14px; }\n .ag-theme-material .ag-column-select-column-readonly,\n .ag-theme-material .ag-column-select-column-group-readonly {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n pointer-events: none; }\n .ag-theme-material .ag-ltr .ag-column-select-add-group-indent {\n margin-left: 34px; }\n .ag-theme-material .ag-rtl .ag-column-select-add-group-indent {\n margin-right: 34px; }\n .ag-theme-material .ag-column-select-list {\n padding: 16px 12px; }\n .ag-theme-material .ag-rtl {\n text-align: right; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-left: 66px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-1 {\n padding-right: 66px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-1 {\n padding-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-1 {\n padding-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-1 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-left: 108px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-2 {\n padding-right: 108px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-2 {\n padding-left: 84px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-2 {\n padding-right: 84px; }\n .ag-theme-material .ag-ltr .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-2 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-left: 150px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-3 {\n padding-right: 150px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-3 {\n padding-left: 126px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-3 {\n padding-right: 126px; }\n .ag-theme-material .ag-ltr .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-3 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-left: 192px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-4 {\n padding-right: 192px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-4 {\n padding-left: 168px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-4 {\n padding-right: 168px; }\n .ag-theme-material .ag-ltr .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-4 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-left: 234px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-5 {\n padding-right: 234px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-5 {\n padding-left: 210px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-5 {\n padding-right: 210px; }\n .ag-theme-material .ag-ltr .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-5 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-left: 276px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-6 {\n padding-right: 276px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-6 {\n padding-left: 252px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-6 {\n padding-right: 252px; }\n .ag-theme-material .ag-ltr .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-6 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-left: 318px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-7 {\n padding-right: 318px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-7 {\n padding-left: 294px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-7 {\n padding-right: 294px; }\n .ag-theme-material .ag-ltr .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-7 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-left: 360px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-8 {\n padding-right: 360px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-8 {\n padding-left: 336px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-8 {\n padding-right: 336px; }\n .ag-theme-material .ag-ltr .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-8 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-left: 402px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-9 {\n padding-right: 402px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-9 {\n padding-left: 378px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-9 {\n padding-right: 378px; }\n .ag-theme-material .ag-ltr .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-9 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-left: 444px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-10 {\n padding-right: 444px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-10 {\n padding-left: 420px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-10 {\n padding-right: 420px; }\n .ag-theme-material .ag-ltr .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-10 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-left: 486px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-11 {\n padding-right: 486px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-11 {\n padding-left: 462px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-11 {\n padding-right: 462px; }\n .ag-theme-material .ag-ltr .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-11 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-left: 528px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-12 {\n padding-right: 528px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-12 {\n padding-left: 504px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-12 {\n padding-right: 504px; }\n .ag-theme-material .ag-ltr .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-12 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-left: 570px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-13 {\n padding-right: 570px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-13 {\n padding-left: 546px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-13 {\n padding-right: 546px; }\n .ag-theme-material .ag-ltr .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-13 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-left: 612px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-14 {\n padding-right: 612px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-14 {\n padding-left: 588px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-14 {\n padding-right: 588px; }\n .ag-theme-material .ag-ltr .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-14 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-left: 654px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-15 {\n padding-right: 654px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-15 {\n padding-left: 630px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-15 {\n padding-right: 630px; }\n .ag-theme-material .ag-ltr .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-15 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-left: 696px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-16 {\n padding-right: 696px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-16 {\n padding-left: 672px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-16 {\n padding-right: 672px; }\n .ag-theme-material .ag-ltr .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-16 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-left: 738px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-17 {\n padding-right: 738px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-17 {\n padding-left: 714px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-17 {\n padding-right: 714px; }\n .ag-theme-material .ag-ltr .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-17 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-left: 780px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-18 {\n padding-right: 780px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-18 {\n padding-left: 756px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-18 {\n padding-right: 756px; }\n .ag-theme-material .ag-ltr .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-18 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-ltr .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-left: 822px; }\n .ag-theme-material .ag-rtl .ag-row > .ag-cell-wrapper.ag-row-group-indent-19 {\n padding-right: 822px; }\n .ag-theme-material .ag-ltr .ag-row-group-indent-19 {\n padding-left: 798px; }\n .ag-theme-material .ag-rtl .ag-row-group-indent-19 {\n padding-right: 798px; }\n .ag-theme-material .ag-ltr .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-left: 42px; }\n .ag-theme-material .ag-rtl .ag-row-level-19 .ag-row-group-leaf-indent {\n margin-right: 42px; }\n .ag-theme-material .ag-cell {\n -webkit-font-smoothing: subpixel-antialiased; }\n .ag-theme-material .ag-value-change-delta {\n padding-right: 2px; }\n .ag-theme-material .ag-value-change-delta-up {\n color: #43a047;\n color: var(--ag-value-change-delta-up-color, #43a047); }\n .ag-theme-material .ag-value-change-delta-down {\n color: #e53935;\n color: var(--ag-value-change-delta-down-color, #e53935); }\n .ag-theme-material .ag-value-change-value {\n background-color: transparent;\n border-radius: 1px;\n padding-left: 1px;\n padding-right: 1px;\n transition: background-color 1s; }\n .ag-theme-material .ag-value-change-value-highlight {\n background-color: #00acc1;\n background-color: var(--ag-value-change-value-highlight-background-color, #00acc1);\n transition: background-color 0.1s; }\n .ag-theme-material .ag-cell-data-changed {\n background-color: #00acc1 !important;\n background-color: var(--ag-value-change-value-highlight-background-color, #00acc1) !important; }\n .ag-theme-material .ag-cell-data-changed-animation {\n background-color: transparent; }\n .ag-theme-material .ag-cell-highlight {\n background-color: #fce4ec !important;\n background-color: var(--ag-range-selection-highlight-color, #fce4ec) !important; }\n .ag-theme-material .ag-row {\n height: 48px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-data-color, var(--ag-foreground-color, rgba(0, 0, 0, 0.87)));\n border-width: 1px;\n border-color: #e2e2e2;\n border-color: var(--ag-row-border-color, var(--ag-secondary-border-color, var(--ag-border-color, #e2e2e2))); }\n .ag-theme-material .ag-row:not(.ag-row-first) {\n border-top-style: solid; }\n .ag-theme-material .ag-row.ag-row-last {\n border-bottom-style: solid; }\n .ag-theme-material .ag-row-highlight-above::after, .ag-theme-material .ag-row-highlight-below::after {\n content: '';\n position: absolute;\n width: calc(100% - 1px);\n height: 1px;\n background-color: #3f51b5;\n background-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5));\n left: 1px; }\n .ag-theme-material .ag-row-highlight-above::after {\n top: -1px; }\n .ag-theme-material .ag-row-highlight-above.ag-row-first::after {\n top: 0; }\n .ag-theme-material .ag-row-highlight-below::after {\n bottom: 0px; }\n .ag-theme-material .ag-row-odd {\n background-color: var(--ag-odd-row-background-color); }\n .ag-theme-material .ag-horizontal-left-spacer:not(.ag-scroller-corner) {\n border-right: solid 1px;\n border-right-color: #e2e2e2;\n border-right-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-horizontal-right-spacer:not(.ag-scroller-corner) {\n border-left: solid 1px;\n border-left-color: #e2e2e2;\n border-left-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-row-hover {\n background-color: #fafafa;\n background-color: var(--ag-row-hover-color, #fafafa); }\n .ag-theme-material .ag-ltr .ag-right-aligned-cell {\n text-align: right; }\n .ag-theme-material .ag-rtl .ag-right-aligned-cell {\n text-align: left; }\n .ag-theme-material .ag-ltr .ag-right-aligned-cell .ag-cell-value {\n margin-left: auto; }\n .ag-theme-material .ag-rtl .ag-right-aligned-cell .ag-cell-value {\n margin-right: auto; }\n .ag-theme-material .ag-cell {\n border: 1px solid transparent;\n line-height: 46px;\n padding-left: 23px;\n padding-right: 23px; }\n .ag-theme-material .ag-row > .ag-cell-wrapper {\n padding-left: 23px;\n padding-right: 23px; }\n .ag-theme-material .ag-row-dragging {\n cursor: move; }\n .ag-theme-material .ag-row-dragging {\n opacity: 0.5; }\n .ag-theme-material .ag-cell-inline-editing {\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 2px;\n box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n padding: 8px;\n padding: 0;\n height: 48px;\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa); }\n .ag-theme-material .ag-popup-editor {\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 2px;\n box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n padding: 8px;\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa);\n padding: 0; }\n .ag-theme-material .ag-large-text-input {\n height: auto;\n padding: 24px; }\n .ag-theme-material .ag-details-row {\n padding: 40px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff); }\n .ag-theme-material .ag-overlay-loading-wrapper {\n background-color: rgba(255, 255, 255, 0.66);\n background-color: var(--ag-modal-overlay-background-color, rgba(255, 255, 255, 0.66)); }\n .ag-theme-material .ag-overlay-loading-center {\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 2px;\n box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n padding: 8px; }\n .ag-theme-material .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 30px; }\n .ag-theme-material .ag-loading {\n padding-left: 24px;\n display: flex;\n height: 100%;\n align-items: center; }\n .ag-theme-material .ag-loading-icon {\n padding-right: 24px; }\n .ag-theme-material .ag-icon-loading {\n -webkit-animation-name: spin;\n animation-name: spin;\n -webkit-animation-duration: 1000ms;\n animation-duration: 1000ms;\n -webkit-animation-iteration-count: infinite;\n animation-iteration-count: infinite;\n -webkit-animation-timing-function: linear;\n animation-timing-function: linear; }\n\n@-webkit-keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n\n@keyframes spin {\n from {\n -webkit-transform: rotate(0deg);\n transform: rotate(0deg); }\n to {\n -webkit-transform: rotate(360deg);\n transform: rotate(360deg); } }\n .ag-theme-material .ag-floating-top {\n border-bottom: solid 1px;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-floating-bottom {\n border-top: solid 1px;\n border-top-color: #e2e2e2;\n border-top-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-ltr .ag-cell {\n border-right: solid transparent; }\n .ag-theme-material .ag-rtl .ag-cell {\n border-left: solid transparent; }\n .ag-theme-material .ag-ltr .ag-cell {\n border-right-width: 1px; }\n .ag-theme-material .ag-rtl .ag-cell {\n border-left-width: 1px; }\n .ag-theme-material .ag-cell.ag-cell-first-right-pinned:not(.ag-cell-range-left):not(.ag-cell-range-single-cell) {\n border-left: solid 1px;\n border-left-color: #e2e2e2;\n border-left-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-cell.ag-cell-last-left-pinned:not(.ag-cell-range-right):not(.ag-cell-range-single-cell) {\n border-right: solid 1px;\n border-right-color: #e2e2e2;\n border-right-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-row-selected {\n background-color: #eee;\n background-color: var(--ag-selected-row-background-color, #eee); }\n .ag-theme-material .ag-cell-range-selected:not(.ag-cell-focus) {\n background-color: rgba(122, 134, 203, 0.1);\n background-color: var(--ag-range-selection-background-color, rgba(122, 134, 203, 0.1)); }\n .ag-theme-material .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart {\n background-color: rgba(0, 88, 255, 0.1);\n background-color: var(--ag-range-selection-chart-background-color, rgba(0, 88, 255, 0.1)); }\n .ag-theme-material .ag-cell-range-selected:not(.ag-cell-focus).ag-cell-range-chart.ag-cell-range-chart-category {\n background-color: rgba(0, 255, 132, 0.1);\n background-color: var(--ag-range-selection-chart-category-background-color, rgba(0, 255, 132, 0.1)); }\n .ag-theme-material .ag-cell-range-selected-1:not(.ag-cell-focus) {\n background-color: rgba(122, 134, 203, 0.1);\n background-color: var(--ag-range-selection-background-color-1, var(--ag-range-selection-background-color, rgba(122, 134, 203, 0.1))); }\n .ag-theme-material .ag-cell-range-selected-2:not(.ag-cell-focus) {\n background-color: rgba(122, 134, 203, 0.19);\n background-color: var(--ag-range-selection-background-color-2, rgba(122, 134, 203, 0.19)); }\n .ag-theme-material .ag-cell-range-selected-3:not(.ag-cell-focus) {\n background-color: rgba(122, 134, 203, 0.271);\n background-color: var(--ag-range-selection-background-color-3, rgba(122, 134, 203, 0.271)); }\n .ag-theme-material .ag-cell-range-selected-4:not(.ag-cell-focus) {\n background-color: rgba(122, 134, 203, 0.3439);\n background-color: var(--ag-range-selection-background-color-4, rgba(122, 134, 203, 0.3439)); }\n .ag-theme-material .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-top {\n border-top-color: #3f51b5;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-right {\n border-right-color: #3f51b5;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-bottom {\n border-bottom-color: #3f51b5;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-cell.ag-cell-range-selected:not(.ag-cell-range-single-cell).ag-cell-range-left {\n border-left-color: #3f51b5;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-ltr .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-material .ag-ltr .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-material .ag-ltr .ag-cell-range-single-cell.ag-cell-range-handle, .ag-theme-material .ag-rtl .ag-has-focus .ag-cell-focus:not(.ag-cell-range-selected),\n .ag-theme-material .ag-rtl .ag-has-focus .ag-cell-focus.ag-cell-range-single-cell,\n .ag-theme-material .ag-rtl .ag-cell-range-single-cell.ag-cell-range-handle {\n border: 1px solid;\n border-color: #3f51b5;\n border-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5));\n outline: initial; }\n .ag-theme-material .ag-cell.ag-selection-fill-top,\n .ag-theme-material .ag-cell.ag-selection-fill-top.ag-cell-range-selected {\n border-top: 1px dashed;\n border-top-color: #3f51b5;\n border-top-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-ltr .ag-cell.ag-selection-fill-right, .ag-theme-material .ag-ltr .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #3f51b5;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-rtl .ag-cell.ag-selection-fill-right, .ag-theme-material .ag-rtl .ag-cell.ag-selection-fill-right.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #3f51b5;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-cell.ag-selection-fill-bottom,\n .ag-theme-material .ag-cell.ag-selection-fill-bottom.ag-cell-range-selected {\n border-bottom: 1px dashed;\n border-bottom-color: #3f51b5;\n border-bottom-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-ltr .ag-cell.ag-selection-fill-left, .ag-theme-material .ag-ltr .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-left: 1px dashed;\n border-left-color: #3f51b5;\n border-left-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-rtl .ag-cell.ag-selection-fill-left, .ag-theme-material .ag-rtl .ag-cell.ag-selection-fill-left.ag-cell-range-selected {\n border-right: 1px dashed;\n border-right-color: #3f51b5;\n border-right-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-fill-handle, .ag-theme-material .ag-range-handle {\n position: absolute;\n width: 6px;\n height: 6px;\n bottom: -1px;\n background-color: #3f51b5;\n background-color: var(--ag-range-selection-border-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-ltr .ag-fill-handle, .ag-theme-material .ag-ltr .ag-range-handle {\n right: -1px; }\n .ag-theme-material .ag-rtl .ag-fill-handle, .ag-theme-material .ag-rtl .ag-range-handle {\n left: -1px; }\n .ag-theme-material .ag-fill-handle {\n cursor: cell; }\n .ag-theme-material .ag-range-handle {\n cursor: nwse-resize; }\n .ag-theme-material .ag-cell-inline-editing {\n border-color: #ff4081 !important;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)) !important; }\n .ag-theme-material .ag-menu {\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 2px;\n box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n padding: 8px;\n padding: 0; }\n .ag-theme-material .ag-menu-list {\n cursor: default;\n width: 100%;\n padding-top: 8px;\n padding-bottom: 8px; }\n .ag-theme-material .ag-menu-option-part {\n padding-top: 10px;\n padding-bottom: 10px;\n line-height: 18px; }\n .ag-theme-material .ag-menu-option-active {\n background-color: #fafafa;\n background-color: var(--ag-row-hover-color, #fafafa); }\n .ag-theme-material .ag-menu-option-disabled {\n opacity: 0.5; }\n .ag-theme-material .ag-menu-option-text {\n margin-left: 8px; }\n .ag-theme-material .ag-menu-option-icon {\n padding-left: 16px;\n padding-right: 8px;\n min-width: 34px; }\n .ag-theme-material .ag-menu-option-shortcut {\n padding-left: 16px; }\n .ag-theme-material .ag-menu-separator {\n height: 16px; }\n .ag-theme-material .ag-menu-separator-cell:after {\n content: \"\";\n display: block;\n border-top: solid 1px;\n border-top-color: #e2e2e2;\n border-top-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-menu-option-popup-pointer {\n width: 34px;\n text-align: center; }\n .ag-theme-material .ag-tabs-header {\n min-width: 220px;\n width: 100%;\n display: flex; }\n .ag-theme-material .ag-tab {\n border-bottom: 2px solid transparent;\n display: flex;\n flex: none;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n flex: 1 1 auto; }\n .ag-theme-material .ag-keyboard-focus .ag-tab:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-tab:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-tab-selected {\n border-bottom-color: #3f51b5;\n border-bottom-color: var(--ag-selected-tab-underline-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-menu-header {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-filter-condition-operator {\n height: 17px; }\n .ag-theme-material .ag-ltr .ag-filter-condition-operator-or {\n margin-left: 16px; }\n .ag-theme-material .ag-rtl .ag-filter-condition-operator-or {\n margin-right: 16px; }\n .ag-theme-material .ag-set-filter-select-all {\n padding-top: 16px; }\n .ag-theme-material .ag-set-filter-list {\n height: 240px; }\n .ag-theme-material .ag-set-filter-filter {\n margin-top: 16px;\n margin-left: 12px;\n margin-right: 12px; }\n .ag-theme-material .ag-filter-to {\n margin-top: 14px; }\n .ag-theme-material .ag-mini-filter {\n margin: 16px 12px;\n margin-bottom: 0; }\n .ag-theme-material .ag-set-filter-item {\n margin: 0px 12px; }\n .ag-theme-material .ag-ltr .ag-set-filter-item-value {\n margin-left: 12px; }\n .ag-theme-material .ag-rtl .ag-set-filter-item-value {\n margin-right: 12px; }\n .ag-theme-material .ag-filter-header-container {\n padding-bottom: 16px; }\n .ag-theme-material .ag-filter-apply-panel {\n padding: 16px 12px; }\n .ag-theme-material .ag-filter-apply-panel-button {\n line-height: 1.5; }\n .ag-theme-material .ag-ltr .ag-filter-apply-panel-button {\n margin-left: 16px; }\n .ag-theme-material .ag-rtl .ag-filter-apply-panel-button {\n margin-right: 16px; }\n .ag-theme-material .ag-simple-filter-body-wrapper {\n padding: 16px 12px;\n padding-bottom: 2px; }\n .ag-theme-material .ag-simple-filter-body-wrapper > * {\n margin-bottom: 14px; }\n .ag-theme-material .ag-filter-no-matches {\n margin: 16px 12px; }\n .ag-theme-material .ag-side-bar {\n position: relative; }\n .ag-theme-material .ag-tool-panel-wrapper {\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa); }\n .ag-theme-material .ag-side-buttons {\n padding-top: 32px;\n width: 22px;\n position: relative;\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-foreground-color, rgba(0, 0, 0, 0.87));\n overflow: hidden; }\n .ag-theme-material button.ag-side-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n background: transparent;\n padding: 16px 0 16px 0;\n width: 100%;\n margin: 0;\n min-height: 144px;\n background-position-y: center;\n background-position-x: center;\n background-repeat: no-repeat;\n border: none; }\n .ag-theme-material button.ag-side-button-button:focus {\n box-shadow: none; }\n .ag-theme-material .ag-keyboard-focus .ag-side-button-button:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-side-button-button:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-side-button-icon-wrapper {\n margin-bottom: 3px; }\n .ag-theme-material .ag-ltr .ag-side-bar-left .ag-side-button-button,\n .ag-theme-material .ag-rtl .ag-side-bar-right .ag-side-button-button {\n border-right: 2px solid transparent; }\n .ag-theme-material .ag-ltr .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-material .ag-rtl .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-right-color: #3f51b5;\n border-right-color: var(--ag-selected-tab-underline-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-rtl .ag-side-bar-left .ag-side-button-button,\n .ag-theme-material .ag-ltr .ag-side-bar-right .ag-side-button-button {\n border-left: 2px solid transparent; }\n .ag-theme-material .ag-rtl .ag-side-bar-left .ag-selected .ag-side-button-button,\n .ag-theme-material .ag-ltr .ag-side-bar-right .ag-selected .ag-side-button-button {\n border-left-color: #3f51b5;\n border-left-color: var(--ag-selected-tab-underline-color, var(--ag-material-primary-color, #3f51b5)); }\n .ag-theme-material .ag-filter-toolpanel-header {\n height: 48px; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-header, .ag-theme-material .ag-ltr .ag-filter-toolpanel-search {\n padding-left: 8px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-header, .ag-theme-material .ag-rtl .ag-filter-toolpanel-search {\n padding-right: 8px; }\n .ag-theme-material .ag-keyboard-focus .ag-filter-toolpanel-header:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-filter-toolpanel-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n font-family: \"agGridMaterial\";\n font-size: 18px;\n line-height: 18px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n content: \"\\f112\";\n position: absolute; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-left: 8px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group.ag-has-filter > .ag-group-title-bar .ag-group-title:after {\n padding-right: 8px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-0-header {\n height: 64px; }\n .ag-theme-material .ag-filter-toolpanel-group-item {\n margin-top: 4px;\n margin-bottom: 4px; }\n .ag-theme-material .ag-filter-toolpanel-search {\n height: 56px; }\n .ag-theme-material .ag-filter-toolpanel-search-input {\n flex-grow: 1;\n height: 32px; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-search-input {\n margin-right: 8px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-search-input {\n margin-left: 8px; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-expand, .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-title-bar-icon {\n margin-right: 8px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-expand, .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-title-bar-icon {\n margin-left: 8px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-1-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-left: 24px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-1 .ag-filter-toolpanel-group-level-2-header {\n padding-right: 24px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-2-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-left: 40px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-2 .ag-filter-toolpanel-group-level-3-header {\n padding-right: 40px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-3-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-left: 56px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-3 .ag-filter-toolpanel-group-level-4-header {\n padding-right: 56px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-4-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-left: 72px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-4 .ag-filter-toolpanel-group-level-5-header {\n padding-right: 72px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-5-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-left: 88px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-5 .ag-filter-toolpanel-group-level-6-header {\n padding-right: 88px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-6-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-left: 104px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-6 .ag-filter-toolpanel-group-level-7-header {\n padding-right: 104px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-7-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-left: 120px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-7 .ag-filter-toolpanel-group-level-8-header {\n padding-right: 120px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-8-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-left: 136px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-8 .ag-filter-toolpanel-group-level-9-header {\n padding-right: 136px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-9-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-left: 152px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-9 .ag-filter-toolpanel-group-level-10-header {\n padding-right: 152px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-10-header.ag-filter-toolpanel-group-title-bar {\n background-color: transparent; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-left: 168px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-group-level-10 .ag-filter-toolpanel-group-level-11-header {\n padding-right: 168px; }\n .ag-theme-material .ag-filter-toolpanel-instance-header.ag-filter-toolpanel-group-level-1-header {\n padding-left: 8px; }\n .ag-theme-material .ag-filter-toolpanel-instance-filter {\n padding-top: 8px; }\n .ag-theme-material .ag-ltr .ag-filter-toolpanel-instance-header-icon {\n margin-left: 8px; }\n .ag-theme-material .ag-rtl .ag-filter-toolpanel-instance-header-icon {\n margin-right: 8px; }\n .ag-theme-material .ag-pivot-mode-panel {\n height: 56px;\n display: flex; }\n .ag-theme-material .ag-pivot-mode-select {\n display: flex;\n align-items: center; }\n .ag-theme-material .ag-ltr .ag-pivot-mode-select {\n margin-left: 12px; }\n .ag-theme-material .ag-rtl .ag-pivot-mode-select {\n margin-right: 12px; }\n .ag-theme-material .ag-keyboard-focus .ag-column-select-header:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-column-select-header:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-column-select-header {\n height: 56px;\n align-items: center;\n padding: 0 12px; }\n .ag-theme-material .ag-column-group-icons,\n .ag-theme-material .ag-column-select-header-icon {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-header {\n background-color: #fff;\n background-color: var(--ag-header-background-color, #fff);\n border-bottom: solid 1px;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-header-row {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54))); }\n .ag-theme-material .ag-pinned-right-header {\n border-left: solid 1px;\n border-left-color: #e2e2e2;\n border-left-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-pinned-left-header {\n border-right: solid 1px;\n border-right-color: #e2e2e2;\n border-right-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-header-row {\n height: 56px; }\n .ag-theme-material .ag-ltr .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-left: 8px; }\n .ag-theme-material .ag-rtl .ag-header-cell:not(.ag-right-aligned-header) .ag-header-label-icon {\n margin-right: 8px; }\n .ag-theme-material .ag-ltr .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-right: 8px; }\n .ag-theme-material .ag-rtl .ag-header-cell.ag-right-aligned-header .ag-header-label-icon {\n margin-left: 8px; }\n .ag-theme-material .ag-header-cell,\n .ag-theme-material .ag-header-group-cell {\n padding-left: 24px;\n padding-right: 24px; }\n .ag-theme-material .ag-header-cell.ag-header-cell-moving,\n .ag-theme-material .ag-header-group-cell.ag-header-cell-moving {\n background-color: #f2f2f2;\n background-color: var(--ag-header-cell-moving-background-color, var(--ag-header-cell-hover-background-color, #f2f2f2)); }\n .ag-theme-material .ag-keyboard-focus .ag-header-cell:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-header-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-keyboard-focus .ag-header-group-cell:focus {\n outline: none; }\n .ag-theme-material .ag-keyboard-focus .ag-header-group-cell:focus:after {\n content: '';\n position: absolute;\n background-color: transparent;\n pointer-events: none;\n top: 4px;\n left: 4px;\n display: block;\n width: calc(100% - 8px);\n height: calc(100% - 8px);\n border: 1px solid;\n border-color: #ff4081;\n border-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material .ag-header-icon {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-header-expand-icon {\n cursor: pointer; }\n .ag-theme-material .ag-ltr .ag-header-expand-icon {\n padding-left: 4px; }\n .ag-theme-material .ag-rtl .ag-header-expand-icon {\n padding-right: 4px; }\n .ag-theme-material .ag-header-row:not(:first-child) .ag-header-cell,\n .ag-theme-material .ag-header-row:not(:first-child) .ag-header-group-cell.ag-header-group-cell-with-group {\n border-top: solid 1px;\n border-top-color: #e2e2e2;\n border-top-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-header-group-cell:not(.ag-column-resizing) + .ag-header-group-cell:not(.ag-header-cell-moving):hover, .ag-theme-material .ag-header-group-cell:not(.ag-column-resizing) + .ag-header-group-cell.ag-column-resizing,\n .ag-theme-material .ag-header-cell:not(.ag-column-resizing) + .ag-header-cell:not(.ag-header-cell-moving):hover,\n .ag-theme-material .ag-header-cell:not(.ag-column-resizing) + .ag-header-cell.ag-column-resizing,\n .ag-theme-material .ag-header-group-cell:first-of-type:not(.ag-header-cell-moving):hover,\n .ag-theme-material .ag-header-group-cell:first-of-type.ag-column-resizing,\n .ag-theme-material .ag-header-cell:first-of-type:not(.ag-header-cell-moving):hover,\n .ag-theme-material .ag-header-cell:first-of-type.ag-column-resizing {\n background-color: #f2f2f2;\n background-color: var(--ag-header-cell-hover-background-color, #f2f2f2); }\n .ag-theme-material .ag-ltr .ag-header-select-all {\n margin-right: 24px; }\n .ag-theme-material .ag-rtl .ag-header-select-all {\n margin-left: 24px; }\n .ag-theme-material .ag-ltr .ag-floating-filter-button {\n margin-left: 24px; }\n .ag-theme-material .ag-rtl .ag-floating-filter-button {\n margin-right: 24px; }\n .ag-theme-material .ag-floating-filter-button-button {\n color: inherit;\n font-family: inherit;\n font-size: inherit;\n font-weight: inherit;\n line-height: inherit;\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background: transparent;\n border: none;\n height: 18px;\n padding: 0;\n width: 18px; }\n .ag-theme-material .ag-filter-loading {\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa);\n height: 100%;\n padding: 16px 12px;\n position: absolute;\n width: 100%;\n z-index: 1; }\n .ag-theme-material .ag-paging-panel {\n border-top: 1px solid;\n border-top-color: #e2e2e2;\n border-top-color: var(--ag-border-color, #e2e2e2);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n height: 56px; }\n .ag-theme-material .ag-paging-panel > * {\n margin: 0 24px; }\n .ag-theme-material .ag-paging-button {\n cursor: pointer;\n opacity: 0;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n padding: 0;\n width: 18px; }\n .ag-theme-material .ag-disabled .ag-paging-button {\n cursor: default; }\n .ag-theme-material .ag-paging-button-wrapper.ag-disabled {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n cursor: default; }\n .ag-theme-material .ag-paging-button-wrapper, .ag-theme-material .ag-paging-description {\n margin: 0 8px; }\n .ag-theme-material .ag-status-bar {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n padding-right: 32px;\n padding-left: 32px;\n line-height: 1.5; }\n .ag-theme-material .ag-status-name-value-value {\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-foreground-color, rgba(0, 0, 0, 0.87)); }\n .ag-theme-material .ag-status-bar-center {\n text-align: center; }\n .ag-theme-material .ag-status-name-value {\n margin-left: 8px;\n margin-right: 8px;\n padding-top: 16px;\n padding-bottom: 16px; }\n .ag-theme-material .ag-column-drop-cell {\n background: #e2e2e2;\n background: var(--ag-chip-background-color, #e2e2e2);\n border-radius: 32px;\n height: 32px;\n padding: 0 4px; }\n .ag-theme-material .ag-column-drop-cell-text {\n margin: 0 8px; }\n .ag-theme-material .ag-column-drop-cell-button {\n min-width: 32px;\n margin: 0 4px;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-column-drop-cell-drag-handle {\n margin-left: 16px; }\n .ag-theme-material .ag-column-drop-cell-ghost {\n opacity: 0.5; }\n .ag-theme-material .ag-column-drop-horizontal {\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa);\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54));\n height: 48px; }\n .ag-theme-material .ag-ltr .ag-column-drop-horizontal {\n padding-left: 24px; }\n .ag-theme-material .ag-rtl .ag-column-drop-horizontal {\n padding-right: 24px; }\n .ag-theme-material .ag-column-drop-horizontal-cell-separator {\n margin: 0 8px;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-column-drop-horizontal-empty-message {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-material .ag-ltr .ag-column-drop-horizontal-icon {\n margin-right: 24px; }\n .ag-theme-material .ag-rtl .ag-column-drop-horizontal-icon {\n margin-left: 24px; }\n .ag-theme-material .ag-column-drop-vertical-list {\n padding-bottom: 8px;\n padding-right: 8px;\n padding-left: 8px; }\n .ag-theme-material .ag-column-drop-vertical-cell {\n margin-top: 8px; }\n .ag-theme-material .ag-column-drop-vertical {\n min-height: 50px;\n max-height: 150px; }\n .ag-theme-material .ag-column-drop-vertical-icon {\n margin-left: 8px;\n margin-right: 8px; }\n .ag-theme-material .ag-column-drop-vertical-list {\n position: relative; }\n .ag-theme-material .ag-column-drop-vertical-empty-message {\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n overflow: hidden;\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n margin-top: 8px; }\n .ag-theme-material .ag-select-agg-func-popup {\n background: #fff;\n background: var(--ag-background-color, #fff);\n border-radius: 2px;\n box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);\n padding: 8px;\n background: #fff;\n background: var(--ag-background-color, #fff);\n height: 140px;\n padding: 0; }\n .ag-theme-material .ag-select-agg-func-virtual-list-item {\n cursor: default;\n line-height: 40px;\n padding-left: 16px; }\n .ag-theme-material .ag-select-agg-func-virtual-list-item:hover {\n background-color: #eee;\n background-color: var(--ag-selected-row-background-color, #eee); }\n .ag-theme-material .ag-chart-menu {\n border-radius: 2px;\n background: #fff;\n background: var(--ag-background-color, #fff); }\n .ag-theme-material .ag-chart-menu-icon {\n opacity: 0.5;\n line-height: 24px;\n font-size: 24px;\n width: 24px;\n height: 24px;\n margin: 2px 0;\n cursor: pointer;\n border-radius: 2px;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-chart-menu-icon:hover {\n opacity: 1; }\n .ag-theme-material .ag-chart-mini-thumbnail {\n border: 1px solid;\n border-color: #e2e2e2;\n border-color: var(--ag-secondary-border-color, var(--ag-border-color, #e2e2e2));\n border-radius: 5px;\n margin: 5px; }\n .ag-theme-material .ag-chart-mini-thumbnail:nth-last-child(3),\n .ag-theme-material .ag-chart-mini-thumbnail:nth-last-child(3) ~ .ag-chart-mini-thumbnail {\n margin-left: auto;\n margin-right: auto; }\n .ag-theme-material .ag-ltr .ag-chart-mini-thumbnail:first-child {\n margin-left: 0; }\n .ag-theme-material .ag-rtl .ag-chart-mini-thumbnail:first-child {\n margin-right: 0; }\n .ag-theme-material .ag-ltr .ag-chart-mini-thumbnail:last-child {\n margin-right: 0; }\n .ag-theme-material .ag-rtl .ag-chart-mini-thumbnail:last-child {\n margin-left: 0; }\n .ag-theme-material .ag-chart-mini-thumbnail.ag-selected {\n border-color: #ff4081;\n border-color: var(--ag-minichart-selected-chart-color, var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081))); }\n .ag-theme-material .ag-chart-settings-card-item {\n background: rgba(0, 0, 0, 0.87);\n background: var(--ag-foreground-color, rgba(0, 0, 0, 0.87));\n width: 8px;\n height: 8px;\n border-radius: 4px; }\n .ag-theme-material .ag-chart-settings-card-item.ag-selected {\n background-color: #ff4081;\n background-color: var(--ag-minichart-selected-page-color, var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081))); }\n .ag-theme-material .ag-chart-data-column-drag-handle {\n margin-left: 8px; }\n .ag-theme-material .ag-charts-settings-group-container {\n padding: 8px; }\n .ag-theme-material .ag-charts-data-group-container {\n padding: 16px 12px;\n padding-bottom: 2px; }\n .ag-theme-material .ag-charts-data-group-container > * {\n margin-bottom: 14px; }\n .ag-theme-material .ag-charts-format-top-level-group-container {\n margin-left: 16px;\n padding: 8px; }\n .ag-theme-material .ag-charts-format-top-level-group-item {\n margin: 8px 0; }\n .ag-theme-material .ag-charts-format-sub-level-group-container {\n padding: 16px 12px;\n padding-bottom: 2px; }\n .ag-theme-material .ag-charts-format-sub-level-group-container > * {\n margin-bottom: 14px; }\n .ag-theme-material .ag-charts-group-container.ag-group-container-horizontal {\n padding: 8px; }\n .ag-theme-material .ag-chart-data-section,\n .ag-theme-material .ag-chart-format-section {\n display: flex;\n margin: 0; }\n .ag-theme-material .ag-chart-menu-panel {\n background-color: #fafafa;\n background-color: var(--ag-control-panel-background-color, #fafafa); }\n .ag-theme-material .ag-ltr .ag-chart-menu-panel {\n border-left: solid 1px;\n border-left-color: #e2e2e2;\n border-left-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-rtl .ag-chart-menu-panel {\n border-right: solid 1px;\n border-right-color: #e2e2e2;\n border-right-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-date-time-list-page-title {\n flex-grow: 1;\n text-align: center; }\n .ag-theme-material .ag-date-time-list-page-column-label {\n text-align: center; }\n .ag-theme-material .ag-date-time-list-page-entry {\n text-align: center; }\n .ag-theme-material .ag-checkbox-input-wrapper {\n font-family: \"agGridMaterial\";\n font-size: 18px;\n line-height: 18px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 18px;\n height: 18px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 2px;\n display: inline-block;\n vertical-align: middle;\n flex: none; }\n .ag-theme-material .ag-checkbox-input-wrapper input, .ag-theme-material .ag-checkbox-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-material .ag-checkbox-input-wrapper:focus-within, .ag-theme-material .ag-checkbox-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122); }\n .ag-theme-material .ag-checkbox-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-material .ag-checkbox-input-wrapper::after {\n content: \"\\f108\";\n color: #333;\n color: var(--ag-checkbox-unchecked-color, #333);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-material .ag-checkbox-input-wrapper.ag-checked::after {\n content: \"\\f106\";\n color: #ff4081;\n color: var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-material .ag-checkbox-input-wrapper.ag-indeterminate::after {\n content: \"\\f107\";\n color: #333;\n color: var(--ag-checkbox-indeterminate-color, var(--ag-checkbox-unchecked-color, #333));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-material .ag-toggle-button-input-wrapper {\n box-sizing: border-box;\n width: 36px;\n height: 18px;\n background-color: #333;\n background-color: var(--ag-toggle-button-off-background-color, var(--ag-checkbox-unchecked-color, #333));\n border-radius: 9px;\n position: relative;\n flex: none;\n border: 1px solid;\n border-color: #333;\n border-color: var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #333)); }\n .ag-theme-material .ag-toggle-button-input-wrapper input {\n opacity: 0;\n height: 100%;\n width: 100%; }\n .ag-theme-material .ag-toggle-button-input-wrapper:focus-within {\n outline: none;\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122); }\n .ag-theme-material .ag-toggle-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-material .ag-toggle-button-input-wrapper.ag-checked {\n background-color: #ff4081;\n background-color: var(--ag-toggle-button-on-background-color, var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081)));\n border-color: #ff4081;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081))); }\n .ag-theme-material .ag-toggle-button-input-wrapper::before {\n content: ' ';\n position: absolute;\n top: -1px;\n left: -1px;\n display: block;\n box-sizing: border-box;\n height: 18px;\n width: 18px;\n background-color: #fff;\n background-color: var(--ag-toggle-button-switch-background-color, var(--ag-background-color, #fff));\n border-radius: 9px;\n transition: left 100ms;\n border: 1px solid;\n border-color: #333;\n border-color: var(--ag-toggle-button-switch-border-color, var(--ag-toggle-button-off-border-color, var(--ag-checkbox-unchecked-color, #333))); }\n .ag-theme-material .ag-toggle-button-input-wrapper.ag-checked::before {\n left: calc(100% - 18px);\n border-color: #ff4081;\n border-color: var(--ag-toggle-button-on-border-color, var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081))); }\n .ag-theme-material .ag-radio-button-input-wrapper {\n font-family: \"agGridMaterial\";\n font-size: 18px;\n line-height: 18px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n width: 18px;\n height: 18px;\n background-color: var(--ag-checkbox-background-color);\n border-radius: 2px;\n display: inline-block;\n vertical-align: middle;\n flex: none;\n border-radius: 18px; }\n .ag-theme-material .ag-radio-button-input-wrapper input, .ag-theme-material .ag-radio-button-input-wrapper input {\n -webkit-appearance: none;\n opacity: 0;\n width: 100%;\n height: 100%; }\n .ag-theme-material .ag-radio-button-input-wrapper:focus-within, .ag-theme-material .ag-radio-button-input-wrapper:active {\n outline: none;\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122); }\n .ag-theme-material .ag-radio-button-input-wrapper.ag-disabled {\n opacity: 0.5; }\n .ag-theme-material .ag-radio-button-input-wrapper::after {\n content: \"\\f124\";\n color: #333;\n color: var(--ag-checkbox-unchecked-color, #333);\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-material .ag-radio-button-input-wrapper.ag-checked::after {\n content: \"\\f125\";\n color: #ff4081;\n color: var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081));\n position: absolute;\n top: 0;\n left: 0;\n pointer-events: none; }\n .ag-theme-material input[class^='ag-'][type='range'] {\n -webkit-appearance: none;\n width: 100%;\n height: 100%;\n background: none;\n overflow: visible; }\n .ag-theme-material input[class^='ag-'][type='range']::-webkit-slider-runnable-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #e2e2e2;\n background-color: var(--ag-border-color, #e2e2e2);\n border-radius: 0px;\n border-radius: 2px; }\n .ag-theme-material input[class^='ag-'][type='range']::-moz-range-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #e2e2e2;\n background-color: var(--ag-border-color, #e2e2e2);\n border-radius: 0px;\n border-radius: 2px; }\n .ag-theme-material input[class^='ag-'][type='range']::-ms-track {\n margin: 0;\n padding: 0;\n width: 100%;\n height: 3px;\n background-color: #e2e2e2;\n background-color: var(--ag-border-color, #e2e2e2);\n border-radius: 0px;\n border-radius: 2px;\n color: transparent;\n width: calc(100% - 2px); }\n .ag-theme-material input[class^='ag-'][type='range']::-webkit-slider-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 18px;\n height: 18px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #333;\n border-color: var(--ag-checkbox-unchecked-color, #333);\n border-radius: 18px;\n -webkit-transform: translateY(-7.5px);\n transform: translateY(-7.5px); }\n .ag-theme-material input[class^='ag-'][type='range']::-ms-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 18px;\n height: 18px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #333;\n border-color: var(--ag-checkbox-unchecked-color, #333);\n border-radius: 18px; }\n .ag-theme-material input[class^='ag-'][type='range']::-moz-ag-range-thumb {\n margin: 0;\n padding: 0;\n -webkit-appearance: none;\n width: 18px;\n height: 18px;\n background-color: #fff;\n background-color: var(--ag-background-color, #fff);\n border: 1px solid;\n border-color: #333;\n border-color: var(--ag-checkbox-unchecked-color, #333);\n border-radius: 18px; }\n .ag-theme-material input[class^='ag-'][type='range']:focus {\n outline: none; }\n .ag-theme-material input[class^='ag-'][type='range']:focus::-webkit-slider-thumb {\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n border-color: #ff4081;\n border-color: var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material input[class^='ag-'][type='range']:focus::-ms-thumb {\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n border-color: #ff4081;\n border-color: var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material input[class^='ag-'][type='range']:focus::-moz-ag-range-thumb {\n box-shadow: 0 0 0 5px rgba(32, 33, 36, 0.122);\n border-color: #ff4081;\n border-color: var(--ag-checkbox-checked-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material input[class^='ag-'][type='range']:active::-webkit-slider-runnable-track {\n background-color: #ff4081;\n background-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material input[class^='ag-'][type='range']:active::-moz-ag-range-track {\n background-color: #ff4081;\n background-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material input[class^='ag-'][type='range']:active::-ms-track {\n background-color: #ff4081;\n background-color: var(--ag-input-focus-border-color, var(--ag-material-accent-color, #ff4081)); }\n .ag-theme-material input[class^='ag-'][type='range']:disabled {\n opacity: 0.5; }\n .ag-theme-material .ag-filter-toolpanel-header,\n .ag-theme-material .ag-filter-toolpanel-search,\n .ag-theme-material .ag-status-bar,\n .ag-theme-material .ag-header-row,\n .ag-theme-material .ag-panel-title-bar-title,\n .ag-theme-material .ag-side-button-button {\n font-size: 12px;\n font-weight: 600;\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-header-foreground-color, var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54))); }\n .ag-theme-material .ag-tab {\n height: 36px; }\n .ag-theme-material .ag-tabs-header,\n .ag-theme-material .ag-column-drop-horizontal {\n background-color: #eee;\n background-color: var(--ag-subheader-background-color, #eee); }\n .ag-theme-material .ag-tabs-body {\n padding: 4px 0; }\n .ag-theme-material .ag-tabs-body .ag-menu-list {\n padding-top: 0;\n padding-bottom: 0; }\n .ag-theme-material .ag-header-cell,\n .ag-theme-material .ag-header-group-cell {\n transition: background-color 0.5s; }\n .ag-theme-material .ag-row-last .ag-cell-inline-editing {\n bottom: 0; }\n .ag-theme-material .ag-cell-inline-editing {\n padding: 8px;\n height: 72px; }\n .ag-theme-material .ag-side-button-button {\n color: rgba(0, 0, 0, 0.54);\n color: var(--ag-secondary-foreground-color, rgba(0, 0, 0, 0.54)); }\n .ag-theme-material .ag-column-drop-vertical {\n border-bottom: solid 1px;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2);\n padding-top: 8px; }\n .ag-theme-material .ag-column-drop-vertical.ag-last-column-drop {\n border-bottom: none; }\n .ag-theme-material .ag-column-drop-vertical-cell {\n margin-left: 0; }\n .ag-theme-material .ag-set-filter-select-all {\n border-bottom: solid 1px;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-column-drop-vertical-empty-message {\n font-size: 12px;\n font-weight: 600;\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-material .ag-ltr .ag-column-drop-vertical-empty-message {\n padding-left: 34px;\n padding-right: 8px; }\n .ag-theme-material .ag-rtl .ag-column-drop-vertical-empty-message {\n padding-right: 34px;\n padding-left: 8px; }\n .ag-theme-material .ag-status-bar {\n border: solid 1px;\n border-color: #e2e2e2;\n border-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-column-panel-column-select {\n border-top: solid 1px;\n border-top-color: #e2e2e2;\n border-top-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-column-select, .ag-theme-material .ag-column-select-header {\n border-bottom: solid 1px;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-column-select-header {\n height: 56px; }\n .ag-theme-material .ag-group-title-bar {\n padding: 6px 8px; }\n .ag-theme-material .ag-charts-format-sub-level-group-title-bar {\n padding: 4px 8px; }\n .ag-theme-material .ag-chart-data-section,\n .ag-theme-material .ag-chart-format-section {\n padding-bottom: 4px; }\n .ag-theme-material .ag-group-toolbar {\n background-color: rgba(238, 238, 238, 0.5); }\n .ag-theme-material input[class^='ag-']:not([type]),\n .ag-theme-material input[class^='ag-'][type='text'],\n .ag-theme-material input[class^='ag-'][type='number'],\n .ag-theme-material input[class^='ag-'][type='tel'],\n .ag-theme-material input[class^='ag-'][type='date'],\n .ag-theme-material input[class^='ag-'][type='datetime-local'],\n .ag-theme-material textarea[class^='ag-'] {\n background: transparent;\n color: rgba(0, 0, 0, 0.87);\n color: var(--ag-foreground-color, rgba(0, 0, 0, 0.87));\n font-family: inherit;\n font-size: inherit;\n height: 40px;\n padding-bottom: 8px;\n border-width: 0;\n border-bottom: 2px solid;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material input:focus[class^='ag-']:not([type]),\n .ag-theme-material input:focus[class^='ag-'][type='text'],\n .ag-theme-material input:focus[class^='ag-'][type='number'],\n .ag-theme-material input:focus[class^='ag-'][type='tel'],\n .ag-theme-material input:focus[class^='ag-'][type='date'],\n .ag-theme-material input:focus[class^='ag-'][type='datetime-local'],\n .ag-theme-material textarea:focus[class^='ag-'] {\n border-bottom: 2px solid;\n border-bottom-color: #3f51b5;\n border-bottom-color: var(--ag-material-primary-color, #3f51b5);\n outline: none;\n box-shadow: none; }\n .ag-theme-material input:not([type])[class^='ag-']::-webkit-input-placeholder, .ag-theme-material input[type='text'][class^='ag-']::-webkit-input-placeholder, .ag-theme-material input[type='number'][class^='ag-']::-webkit-input-placeholder, .ag-theme-material input[type='tel'][class^='ag-']::-webkit-input-placeholder, .ag-theme-material input[type='date'][class^='ag-']::-webkit-input-placeholder, .ag-theme-material input[type='datetime-local'][class^='ag-']::-webkit-input-placeholder, .ag-theme-material textarea[class^='ag-']::-webkit-input-placeholder {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-material input:not([type])[class^='ag-']::-moz-placeholder, .ag-theme-material input[type='text'][class^='ag-']::-moz-placeholder, .ag-theme-material input[type='number'][class^='ag-']::-moz-placeholder, .ag-theme-material input[type='tel'][class^='ag-']::-moz-placeholder, .ag-theme-material input[type='date'][class^='ag-']::-moz-placeholder, .ag-theme-material input[type='datetime-local'][class^='ag-']::-moz-placeholder, .ag-theme-material textarea[class^='ag-']::-moz-placeholder {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-material input:not([type])[class^='ag-']:-ms-input-placeholder, .ag-theme-material input[type='text'][class^='ag-']:-ms-input-placeholder, .ag-theme-material input[type='number'][class^='ag-']:-ms-input-placeholder, .ag-theme-material input[type='tel'][class^='ag-']:-ms-input-placeholder, .ag-theme-material input[type='date'][class^='ag-']:-ms-input-placeholder, .ag-theme-material input[type='datetime-local'][class^='ag-']:-ms-input-placeholder, .ag-theme-material textarea[class^='ag-']:-ms-input-placeholder {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-material input:not([type])[class^='ag-']::-ms-input-placeholder, .ag-theme-material input[type='text'][class^='ag-']::-ms-input-placeholder, .ag-theme-material input[type='number'][class^='ag-']::-ms-input-placeholder, .ag-theme-material input[type='tel'][class^='ag-']::-ms-input-placeholder, .ag-theme-material input[type='date'][class^='ag-']::-ms-input-placeholder, .ag-theme-material input[type='datetime-local'][class^='ag-']::-ms-input-placeholder, .ag-theme-material textarea[class^='ag-']::-ms-input-placeholder {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-material input:not([type])[class^='ag-']::placeholder,\n .ag-theme-material input[type='text'][class^='ag-']::placeholder,\n .ag-theme-material input[type='number'][class^='ag-']::placeholder,\n .ag-theme-material input[type='tel'][class^='ag-']::placeholder,\n .ag-theme-material input[type='date'][class^='ag-']::placeholder,\n .ag-theme-material input[type='datetime-local'][class^='ag-']::placeholder,\n .ag-theme-material textarea[class^='ag-']::placeholder {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38)); }\n .ag-theme-material input:disabled[class^='ag-']:not([type]),\n .ag-theme-material input:disabled[class^='ag-'][type='text'],\n .ag-theme-material input:disabled[class^='ag-'][type='number'],\n .ag-theme-material input:disabled[class^='ag-'][type='tel'],\n .ag-theme-material input:disabled[class^='ag-'][type='date'],\n .ag-theme-material input:disabled[class^='ag-'][type='datetime-local'],\n .ag-theme-material textarea:disabled[class^='ag-'] {\n border-bottom: 1px solid;\n border-bottom-color: #e2e2e2;\n border-bottom-color: var(--ag-border-color, #e2e2e2); }\n .ag-theme-material .ag-standard-button {\n -webkit-appearance: none;\n -moz-appearance: none;\n appearance: none;\n background-color: transparent;\n border: 0;\n color: #3f51b5;\n color: var(--ag-material-primary-color, #3f51b5);\n font-family: inherit;\n font-size: inherit;\n margin: 0;\n padding: 0;\n text-transform: uppercase; }\n .ag-theme-material .ag-standard-button:disabled {\n color: rgba(0, 0, 0, 0.38);\n color: var(--ag-disabled-foreground-color, rgba(0, 0, 0, 0.38));\n background-color: var(--ag-input-disabled-background-color);\n border-color: var(--ag-input-disabled-border-color); }\n .ag-theme-material .ag-dnd-ghost {\n font-size: 12px;\n font-weight: 600; }\n .ag-theme-material .ag-filter-toolpanel-header {\n height: 32px; }\n .ag-theme-material .ag-filter-toolpanel-group-level-0-header {\n height: 56px; }\n .ag-theme-material .ag-overlay-no-rows-wrapper.ag-layout-auto-height {\n padding-top: 60px; }\n\n", ""]);
  46412. // Exports
  46413. module.exports = exports;
  46414. /***/ }),
  46415. /* 246 */
  46416. /***/ (function(module, exports, __webpack_require__) {
  46417. var api = __webpack_require__(225);
  46418. var content = __webpack_require__(247);
  46419. content = content.__esModule ? content.default : content;
  46420. if (typeof content === 'string') {
  46421. content = [[module.i, content, '']];
  46422. }
  46423. var options = {};
  46424. options.insert = "head";
  46425. options.singleton = false;
  46426. var update = api(content, options);
  46427. module.exports = content.locals || {};
  46428. /***/ }),
  46429. /* 247 */
  46430. /***/ (function(module, exports, __webpack_require__) {
  46431. // Imports
  46432. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227);
  46433. exports = ___CSS_LOADER_API_IMPORT___(false);
  46434. // Module
  46435. exports.push([module.i, "@font-face {\n font-family: \"agGridAlpine\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABNkAAsAAAAAIqAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlMAAAReYc5joU9TLzIAAANcAAAAQAAAAFZWUVJ5Y21hcAAAA5wAAAHqAAAFgHCsDfxnbHlmAAAFiAAACesAABCUC9Ir6mhlYWQAAA90AAAANAAAADZ2zsSBaGhlYQAAD6gAAAAeAAAAJAfSBC5obXR4AAAPyAAAABcAAAEou4D/+2xvY2EAAA/gAAAAbwAAAJbPsst2bWF4cAAAEFAAAAAfAAAAIAFgAHNuYW1lAAAQcAAAATUAAAJG5xgJvXBvc3QAABGoAAABuQAAApPSPvKNeJx9k81SE1EQhc9kQgwJBkREjREU//GPYX4yJiGQMAFisXDhwoUbXGhpUa54Atc+gOUD+BQ+geXSlQ/gA1g+gN/tTAyyIFOZubf79Onuc/vKk1TRmroqZDv7z1U7PDh6r7qKGv2c//jaO3z75kDl8Q5f0b5lef4f1bSiFzrSN0/ea+9zoeQX/K6/73/wP/k/5IO6pkegq1rnCRXxDhQrUVOpCiphC1k/UQu0z7tt1nktaso8mQa6QM6QmIExruqpbmkOnr7x9LQJKuZxnD3euzy3NXsKItUd+BOq2cDqWBvUeU7T2qHGHnV0iG7hncO3ReaAmD6+PrX5hiqajnt6SeS89eYikxwX8w+1bfvAdkuoMEa14W/C7/gek3Vsb5IpIuIh7Amobq7hKv8q3hhMQGzHNHPRSyAjKoy1zMp1FtHZjG7C/kyvdJ+47TymZyqOer5H9RN73/hS8hy3duDaBfuAGiZWdyJ3yRVoiL/CSWV6p4/6oq/6rp/6pd/gF8kSWQebcG+dqsw0+p1EZ3jb/6yu0zOcxUnU/4gKfTdNmxDfIFfQZZvB57SJWQdYY8NX4XT4jGpS9Jpi8gLLG2Etsd9gH4Ku5dPY4jlrOg+YATcBdbRY5+2YRvOWsr9MtFuN6rpoarXguWSn5TR1N2nWdm7m3SnX0fkK34DOEtNnD+9VLI5pYmlYVErVjmMNf0q1k2yuqgZVRcxA2SZraLcgI9N1+hhVEumG3YChTdUKFST5jVzQeau+k5/UguFCi/JQIshvcmyauUnuU5ubit2/LKNqzAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMb0GmMDCC5ADUogpqeJy11IdSWkEYxfE/RdNM79X0jgJiQIogIMhjmO6Y4pju5CnzJt8LxJzlnjyAmcnO/Fh2udy9O3fPB8wABXkqRcgXyZHab83mpvMFjk7ni/zSeI7D5PW9xBY77EV5f1+zJTbZZjdy09HfltPVc1zjPs80WqNClxZ9aoyp0tHsKm0GNKizzhJNlhkyYYUeIzb0/7xWLzLLIa16RM9xTPc7zglOcorTnOEs5zjPBS5yictc4apWu84N5rnJLW5zh7vc0/oPeMgjHvNE+ynp9wUWKesBZzlYWzvg9alVuq1+bVztaLftQaOujTaXh5OV3mjjH272H9pc+ij89GhCepuZtNtNq8hz68oLa8lL68srq8lrG8sbq8pb68iWpROybavyztry3gbywRry0eqyY+uya0vyyZry2Zbliw3lq6W9f7MV+W49+WEj2TO9wMhlUlYinyH1hUzKVhQzKV8xk9GZJkynmzCdc8J04glLGQxTCghLby9MySBMGSFMaSFMuSFMCSJMWSJMqSJM+SJMSSNMmSNM6SNMOSRMiSRM2SRMKSVMeSVMySVMGSVMaSZMuSZMCSdMWSdMqSdM+SdMlYAw1QTCVB0IU50gTBWDMNUOwlRFCEt1MyxlJmz6/AsZUr+YIfXlDOU/rrOgigAAeJzFF21sU9f1nntjvzgJSRx/vJgQg/3ivNSxwxL7+dkx2JAEEmhIqWpYCqMhMCbWdFppM7EBbsd+dEVV1apS6A/yY9O2oFVaQEOb+sFKtZaRqh/qVLQf/fixdkxkXbNRodIZ3mXnXttpApnW/Zr93rnn3nt8zrnnni8TIPihcyxKqgmBgEdVPAEjYOoBOsdrCgW4yu9HeJxFs4VCJlMoCHLbzes3r7NP2afEhr+qIx7SRIhLURXdtJkChhAwVaAuXcBPnn028uqrNIMg8iwfHR4eXidXInKBPrFgMnzv8DD/YiE9qiWEsh7WQypRjmo6Y07VhJPds7nLaX4GrqZnuQ2uz6ZhCx5F0k6wCeImq/CnQcWu2N2qV/V2mQkzEddb9VaXoqOSqBnqBlcPjI6YqZQ5MvpRGRnpPn68e2JCQjaxaEsi1uvlXYTk/yOTle6tFjFF3l3MqekxjyZG+G0+fzafh4P5PFtmvY0XeJAfK+t5mV0mLuITtx2sBY/T7YdYoCsDhjPeAQ4wVVDZD2587o/58WFVcrTm+N+GZmBqiF3G+aLNG5+Dd+gCTN21mL+6NH+GznUb9yetizRyO2fr4oMLeTLJ0xlwhpbiizxZ1S18i4vfvZVv0Xbs++yb6L+VpJEQByiqA5i5Euzi6jxub1fCENdGP+Ej3Xu5BZmZmQunq6t9dd7ODZ3eOh/8Hn6axg3+KqydmcksW+ZvavUFOzuDvtAKv2BfIWVEMa6K91NHSCjgDNg0Z8ylOdPg1Jwsaj1FD/DN8q5eyhdoLM+PiZsq3lbJ7+lp5GFDHSm6DxyEFL+AYcii/AKfKcVj8Tw/ZOfwND7SLC1v92CUBFSJuL1oqATaqVVzoQ70NK/ROnNwNc8NoTK8gVADbsAb7OXOoPUC7b+nU7NeEHu0X+u09tH+Ugw+zZ4WvuYANJfiAB3dBa7Cvb18Cnb08pN8qhd2IKCJRVPYgSTkljgGXUEb6Aqw9TKQYYsIZLjObbMY1IvPHkKBioq2moEk5qGzkIRUduHZn8A4aCIdZK3ga6qJWJcfVoJSCyIp2ZUOuhrMDKg499NYl6nbtWAHGHFTVxNI6VbUhNlBg9C4NjKwfWT75HgzY+6+aDRi7hr7+uT4iooKz9BotM+9fPTowN2b0mGjfVM4UJlsuWdT2D0w1OLbc/RJ+nP87R19h7dWVZu7tI5IIgbQd2hrddWafY7me7rW7zVbuleG+9uN9t1Jd3gg1zKQ3omLC/SvxdwRRf3RpYUyUtdQhpZOQlHh1WDDTfR23ETvpxX9R/f4UPhTR0eXo2r8/IrxyV9J5ZslsqICfhzeFA5v2iYA+My961FkEV7aerhPaFtVGidRp4GwBKWYG0PbK2QZaqR4FKduBGyqxzRMNlZ4qUBPWdPvZ9+jc4XJszBcyGbffy8z+T4p50J6jc7hvTnkbeiKKnISvfbKK+lCgRu5HBjnzqVlbakhNcU4QfpynIjc0URWEo3opJ2sJsTUjJi64A39lznWqbPZ7EsSWm/9p0khX/xkS2OmNKI6lfPnv1UnAlgdQ/i6UI6Br46vWFNwDODIxoSPWm9LViiCnuIziMFv+Aw9IOXyzVmUleXHUIVMJrOEzVzo61iA0WZXpMngYC5Hz0iT8RpyWxxhscYw1ANsfTF0YIsII+qf7eZn+Jnu2XKMTNDzWJ8aSQQlxDOQBkMr+pHEOkDF1BzSPBg6tBbaARHpaz8LrtGmplK7k8ndqakpbU3wORjiv4aDEgdtfhOuamntruTIQyPJu7S0kptCuFGs7D4wkpQ2vXmTzco8fotNA5gTRXG0ic4BlbCJBqQ0F/mSLh8cPHbNvEbbzWsmJpQ3IW4NCrgL5/QT3OFvDg5CvBUxfMy1g4OD4zjic+2PEC/XkOfYc6iFU+bhmAfQKTEZagbogPWSHxsG2sP5h1g07+W8B+gHWTj4oVxjLn7sA7k2n2++9Fe0vzH/LWb08gspvOd8piz/HfZOUf682HlFsvNC0X/KmgilimL/VNZkviZMF/OiSG8qwPfSnKchxaI4dkOy5E+XWL3sz0SmVbG0KaL5oJeuXImcPx+RkPrl8JiE82cr9jEBzKZLdzIQF2isy6tCB0CwVQc/eNyCcKm+hvdEI4Nbdqb2t/NosAW2IALvBlvE4lJtDh/ZuWUwEm0J8mj7fv73liC8274/JdfK+j2Adc6LfqOjfhrmQrui3VLkAl1etz3YGk+AMHDAiLHGU8vWbV237JQsaQMC8g+cPl/Q5wPDej4HP8mxsVBHRwir3z5JcyLY2ag14mM10BMiKRTv8Ag7TIKlKpMoflWzVQxZAMWOhkZTKfY6NLkuegm0eitaBgQFliDVG/MiqsPdz2D2tjmau1ebeyvranwNqhv8nnUb9gNQ5vZE1eN/icAll6Omsn4y0dblhOWVKoVKOlFZVV1X21B/ER55xlFdXVfTVu2oHl3ub2xyNdTyj1Zsq9lnt/mM9q+p1ciBPlVf76r1TtYy1sT/anfrjfGG4xUVoFQ2XBTHqZJnmmbTGImrSBtZTzaSO0mO7CSj5Ft4Rj9VG1gtVSpCHVSnrgw1W2wBpxcrqZmwuVVRmAzpVorucWO90lQ58UrDhNxqzMDaGzPMMKBFYpioPTG9A/SQXVM8MbMVcw1ztm0IA6oU3tDGP+YffzmDZjhkXfjHnBanDqsSaFxbBS9WRbblIo7wxrZxR2TbtkjVupau5X6wXocjhwHy2fidSYBDWfjdIUGP5kiFHz2X7H+U/XJJ/s1ydsN63e5A8rm3nPUoDA5DnWTueLCtv506IjmUAzbF5Q37NyYfeXmz8ei/EqGR7JEjQaRmAEfy8MhtcSkzMp1O8wuQSnP6WVp0a92cLOxn3eSOcoTVC7dZJcxWLyKMBQWUYdYldkrB9fj4gd6+vt4D41Bfxh7/zq4dhmkaO3a9V0bYZbHB/7mY+MaRRUQSKcWT0KUG4z0htJEFoZj49f9Btb6He3sfflyAvq+mJZ0r0SMofGWFb6t9iopFV6TABf8BZT85241/BovnG2Rjsq7KTkbkQPyXG5AdSTEXWh/T09ZWTNYZmJUL/GSWzllvl2UxekLcmssBl6AO6ugJrH5Dpfs+wZjYc9DiKmP8Cr+yeA97V2xtsWTKXy/Ns0hQ2vsFc8l+X/TYJtwPX/Ra5/mfe6BJYH+AlT0luijtFSd04WnOyoLTc9+8faJ0ulgfdOzS6WeyLECKTmOdEC65INePYUXykC6RS0XpB4/Xrqj4pwodAOM5Jnpmz5c9ghFPmCoSqviYQF8rNgFmeG08m9y95xu5Suv5H3UPlDuFns7tKx8aGTgZt/rpa9gOaJEN1Wub9qxJjSSncvDA0cZvr0vJbkHr3GzbnrsPKemLhPwbDwYCEQB4nGNgZGBgAOLsD0FR8fw2Xxm4mV8ABaI4H+9rgNH/f///zfyW+S1QJQcDE5BkAACRug+HeJxjYGRgYH7BwAAi///+/5v5LQMjAyrwAgCe2QcHAAB4nGNgYGBgfgHC/39D6KGH6QEAIHUuCwB4nGNgAAIphiCGDIZFDHcYvjGqMQYwVjGuYTzH+IhJhMmMyYcpgekAMxezBrMDcxfzIeZbzJ9YTFiKWGawbGK5wfKKlY01jHUK6z+2JWw72P6xR7Dnsfexz2Ffxb6D/Rj7LfYX7H84vEiHANyaI6IAeJxjYGRgYPBiSGfgYQABJiDmAkIGhv9gPgMAGzsB1AB4nHWRPU7DQBCFnxMniBghJCREx1Y0SM5PQZEuFHGfIgWdE68dR7bXWm8ipeMYnIBjUHIETsEheDFTREjZ1a6/+fbNNAZwgy94OC4PV+19XB1csPrjLulW2Cc/CPcQ4Em4T/8sPKB9EQ7YWXKC51/S3ONNuINrvAt36T+EffKncA93+Bbu0/8ID7D0fOEAj95rnEU2T2ZFnVd6obNdEdtTdcpLbZvcVGocjk51pCttY6cTtTqoZp9NnEtVak2p5qZyuiiMqq3Z6rULN87V0+EwFR+uTYkYGSJY5EgwQ4GaVEFjwZNhRxPz9VzqnF/yWDSsDGuFMUKMzqYjnqrtiOH4TdixwoF3gz17JrQOKeuUGcO/ojBvJx/TBbehqdu3Lc2aPsSm7aoxxZA7/ZcPmeKkXwK+aWkAAAB4nG2S6W7bMBCE/cWSI9tpk7ptet/3obbpfaf3kT4FQ9EyEYkUSMp28vRl4yBAgO4fzgwWs7MLdpY6ixp0/l9bLNElIaXHMhl9BgxZ4RjHWWWNE4w4ySlOs84ZznKO81zgIpe4zBWuco3r3OAmt7jNHe5yj/s84CE5j3jMEzZ4yjOe84KXvOI1b3jLO97zgY9s8onPfOEr3/jOD37yi99s8aczFGXpVCmCtqYnnLMz3xVe9qQwUlXZ4sk3UjkRLqzJiZI723ae7wNVrB8K2hQqKFdrI4IaHcqtOehckbayLm90JG45krY2fiCtCU7IoIpE2mY3lc56nxTKy0zNGxE9i77aVbmvhJ90I+qNdRXHpGPtfEhKp5u0dLZtktgQkkqNQ6/SJs5brqwotCmzWsx1rfdUUivTZjHfghk1D4mxRg2NDbmoKjtTRdpEF9VttEkbPbUha5yaatv6NRfNbL7dhmBNbsfj1aOCSZ0uJyHxYqoGvo52eWFn5gD+izVcwP22bIFj6hDPMQpOqaP36+9LtlEma81iHwQlDkVAYzHM8EgqJuywzTx+g4KaloZdxuwx7XT+AvL3sQsAAAA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n\n.ag-icon {\n font-family: \"agGridAlpine\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n\n.ag-icon-aggregation:before {\n content: \"\\f101\"; }\n\n.ag-icon-arrows:before {\n content: \"\\f102\"; }\n\n.ag-icon-asc:before {\n content: \"\\f103\"; }\n\n.ag-icon-cancel:before {\n content: \"\\f104\"; }\n\n.ag-icon-chart:before {\n content: \"\\f105\"; }\n\n.ag-icon-color-picker:before {\n content: \"\\f109\"; }\n\n.ag-icon-columns:before {\n content: \"\\f10a\"; }\n\n.ag-icon-contracted:before {\n content: \"\\f10b\"; }\n\n.ag-icon-copy:before {\n content: \"\\f10c\"; }\n\n.ag-icon-cross:before {\n content: \"\\f10d\"; }\n\n.ag-icon-desc:before {\n content: \"\\f10e\"; }\n\n.ag-icon-expanded:before {\n content: \"\\f10f\"; }\n\n.ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n\n.ag-icon-eye:before {\n content: \"\\f111\"; }\n\n.ag-icon-filter:before {\n content: \"\\f112\"; }\n\n.ag-icon-first:before {\n content: \"\\f113\"; }\n\n.ag-icon-grip:before {\n content: \"\\f114\"; }\n\n.ag-icon-group:before {\n content: \"\\f115\"; }\n\n.ag-icon-last:before {\n content: \"\\f116\"; }\n\n.ag-icon-left:before {\n content: \"\\f117\"; }\n\n.ag-icon-linked:before {\n content: \"\\f118\"; }\n\n.ag-icon-loading:before {\n content: \"\\f119\"; }\n\n.ag-icon-maximize:before {\n content: \"\\f11a\"; }\n\n.ag-icon-menu:before {\n content: \"\\f11b\"; }\n\n.ag-icon-minimize:before {\n content: \"\\f11c\"; }\n\n.ag-icon-next:before {\n content: \"\\f11d\"; }\n\n.ag-icon-none:before {\n content: \"\\f11e\"; }\n\n.ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n\n.ag-icon-paste:before {\n content: \"\\f120\"; }\n\n.ag-icon-pin:before {\n content: \"\\f121\"; }\n\n.ag-icon-pivot:before {\n content: \"\\f122\"; }\n\n.ag-icon-previous:before {\n content: \"\\f123\"; }\n\n.ag-icon-right:before {\n content: \"\\f126\"; }\n\n.ag-icon-save:before {\n content: \"\\f127\"; }\n\n.ag-icon-small-down:before {\n content: \"\\f128\"; }\n\n.ag-icon-small-left:before {\n content: \"\\f129\"; }\n\n.ag-icon-small-right:before {\n content: \"\\f12a\"; }\n\n.ag-icon-small-up:before {\n content: \"\\f12b\"; }\n\n.ag-icon-tick:before {\n content: \"\\f12c\"; }\n\n.ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n\n.ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n\n.ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n\n.ag-icon-unlinked:before {\n content: \"\\f130\"; }\n\n.ag-icon-row-drag:before {\n content: \"\\f114\"; }\n\n.ag-right-arrow:before {\n content: \"\\f117\"; }\n\n.ag-right-arrow:before {\n content: \"\\f126\"; }\n\n", ""]);
  46436. // Exports
  46437. module.exports = exports;
  46438. /***/ }),
  46439. /* 248 */
  46440. /***/ (function(module, exports, __webpack_require__) {
  46441. var api = __webpack_require__(225);
  46442. var content = __webpack_require__(249);
  46443. content = content.__esModule ? content.default : content;
  46444. if (typeof content === 'string') {
  46445. content = [[module.i, content, '']];
  46446. }
  46447. var options = {};
  46448. options.insert = "head";
  46449. options.singleton = false;
  46450. var update = api(content, options);
  46451. module.exports = content.locals || {};
  46452. /***/ }),
  46453. /* 249 */
  46454. /***/ (function(module, exports, __webpack_require__) {
  46455. // Imports
  46456. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227);
  46457. exports = ___CSS_LOADER_API_IMPORT___(false);
  46458. // Module
  46459. exports.push([module.i, "@font-face {\n font-family: \"agGridBalham\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABX4AAsAAAAAJ8wAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlEAAAReXgFf/09TLzIAAANcAAAAPgAAAFZWTFJaY21hcAAAA5wAAAHtAAAFgFIH7gFnbHlmAAAFjAAADLgAABYYNphscGhlYWQAABJEAAAALwAAADZ2zsSBaGhlYQAAEnQAAAAbAAAAJAfTBC1obXR4AAASkAAAABIAAAEUp/gAAGxvY2EAABKkAAAAZAAAAIwBFQakbWF4cAAAEwgAAAAfAAAAIAFbAHNuYW1lAAATKAAAATUAAAJG0OP3eXBvc3QAABRgAAABlwAAAlqez14KeJx9k09yElEQxr9hCBKISYwxloga/0bjOAwM/yQQCFKWZWXhwoULN3GhpZVylRO49gCWB/AUnsBy6coDeADLA/jrZpCYRXjFzJvur7/+ul8/BZJKSrSr3OTx/nMtHx4cvVdFeU1/5j++Dw7fvjlQcfaFL+/vooLwj5Z1Qy90pG+BgtfB51whzIW74X74IfwU/lAIalMx6LIesGLVeEZkr6uhVDkVsMXsm2qBDnm23bqmC1pwz1AjrZMzJmbkjNt6qptahWfgPH31QCUs4+zzHLNuaeUURKrb8NdR08VqrFUyrGpRe2jso6NDdAvvCr4dMkfEDPANdA68ofLexyd6iaI1r80i6xku4R/TZfuO/KvMmqHa8DfgN74tss7sDTLViLgHex3Uw6yH27pGdAOePmwdj256dBlkDYWJrrKzympUtkT9PT3TK8+6m8X0vYvTmrdQP7cPnC+l2uPWDlxjsHfRMLfaidwhV6QJ/pI2eL/TR33RV33XT/3Sb53B2sVrFfTg3jm1M0X6dxI9xNv+Z7VKC5zPSdT/iEXqbnhvYnyjrIOWrYxO603CPsKaOL6ETsMPUZNyGnlyRJ63hnWB1eU7Bn02m8YWa8n7PGIGbAIqdKfB05im85bS4Usw2W6qa8O71YLnop+W9dRu0rJ/2czbKVfAXOYdUVnd+/MI7xUsxjS3VD0qRbVx3MefonaezVRVUdX02bXJmvgtGJJpkzqmSmrcXLsBE5+q6yioZzdyndMw9Z3spM47LvaoAM1RdpMT75lN8gBtNhXjv2nbY10AAAB4nGNgZMpnnMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVFgEqgRRAAAy9AKRgAAeJy102dSWzEUhuHXhW56TaN3Y2wwvRkb/rAM0hlSGNKZrDI70QZCvnPPyQLITDTz+Ls6o6srjSygDSjImhQhXySHtd+q5rJ6ge6sXuSX+iU6yeu5whU33KXa/b2qFS655jblst7fltPoEk9ZZEe9I811oKdjqrT0xh4b7LPLCXU2OWWdbWo0OGeLQ5qc6f28vl7UGtvp0He7tJIezdhLH/0MMMgQw4wwyhjjTPCYJ/raM42ZZIppZpjVuDnmWdAalvTcwzIr+l1Vr6wFtvOwdvTA8dbWDnaOq63Knna7e1Lf1Ea3a43zrcPm2T9M9h9ayX4KP6N3gZ2ms91eBvt/PA8H8iLYyb4Mx/IqVOV1aMmbYPO+DXtyFTbkOuzLu7Ar78OJfAh1+Rg25Sacym1Yl09hWz6HmnwJDfkazuVb2JLv4VB+hKbcBR1gyjm7KynvsCw4u1up6Ox+pTZn9y61Oyw7HJadDssuh2W3s/uYehyWJWcnmXodln0Oy36H5YDDctBhOeSwHHZYjjgsRx2WYw7LcYflhMPykdPdJAXdUlLQfSUF3VxSyPY16bCcclhOOyxnHJazDss5l+133mG1BYfVFh1WW3JYbdlhtRWXzbPqsrWVHTZ2zWFjKy4bs+6w96oum7PmKP8BU32drwAAAHic7RhpcBvVeb+3lmRZsm5pJdk6V4ety9YdS/Zu7MTGdu7DCRlC0jQHDTFH0tAwIYJCaCAhDDSZcEwzFDoDGZgpw7TTDNMmpUMZMFNi0hQ6JTD9AbQNaRtCyXQGFy393molxybl+l1pd9/33vve9773ve96j2EZ/LHPss8yHJNm1jMMeAlnYQ1E0xROkSixCqQYUgXVRlDbbZwXuKawAEULm4JohA+qVXyetzs45a/WyH97Np+1B6K5YqGIuIViIRKl/3yANXcMxqCpCWKDHdJ70nvTNfBIfwvPAWCbSI4HL3j5HNHpEF65de5/4CFxCqw6v9fg0JlanEZ/xMBNidJ+aNLYDf0Gu1rt9XVbPAC72KevRBo8cm2gEF77+JIfXF8nrUzDslMia7ToHQ691dI+4Gh1egycSazouuwhm75bbzWa250hm5+fR0UFsrweYR9hfAxj5TTRIqcJmOUiag7IRTFglgvOPDGcOHw4MQytM0vpY6X+5pXbG/2tynzkZdbGNGNFmYeHN/clz5xJ7hPI0X2JM2cS+6Q5lC2Zt23sNsbGdDJ5xA/S7bDRrcnQfcjRfdBkaN1Ge+R9KdAeK9JFykg/WoRLW1aPZbLZzNjq1+rAlrGRoVg8HhsaeYYCEENo7MnkU08ln5S/7LYZ6DIgzESXIenj+gj8Mg2enawTIQ2jQ5lmzTx9i1k7f7pSOb9z5we33EK2SteR4erzU1PTYz5gzzFWJsogmU4IpiBvzgmQDWS8YDfbDMAGggYKeWmbQHtToAGUH7C56vfTK7q7V6RJreyqVjwZDz5kr1x2SOteyz4KN01jpOUR7E88aU91D37wIXfj5yPEzDwKN8/mKf7VeWIDaBdfxlF/9SXS++XsSKlhWV1m8MJAfXo+0GBJdSVOcpcRp5PdNYsL9tzlvbQcms2BIodb2U2MCjXWyTBa0HBaYIs+qPkGmyNTyFNFJH+X1pc2SlUQJiZeeU6ncxkd6cG0w+iCF+GJMnZIv4W+iQmhtdXbFnEF0+mgK9zupeSb5DmSrEHRGSPDhHlz1qq8QN/jovgrQTghitVTgvA2yVQnp9+GHZPDrAr5RB6p3pND0sXE++8n4FKtVNayCO3JyvBMN52lLsByQ6gsekEEHNhSwK4Izi7vuT2A7eSnl+Ij8dhIghbxkcinkUJB/khNc2MjcTgiXRfOV7APsjJCXDqFH5IpRKSXKCr0RgqSnljiw3ExH57m+2XyMrUVmGG1l5kj8V9uZjN9iOKbssSq+BBYWPMhMDFbLrh1Gi2QQygM6SKYyJ+odExgQhSVLJtjbAkl08MsZMaYdYhfKGYxfNSiAOXMANGa7y/KXgbZ5AxgBDlY0KpaFmiuCAKIkCI4ppClgrVpwqgpqJwZEVBbUsAHNcCv32pZ+/SdoVazpc3tj/QlRhY8s2zl/GVpk1Wr05lMCbE3IXQv5CCybMmGzWsdtvbSSO+mcgLu6V7AgXfnkR8v4Esj5c2luDTpjl8V74om3LHhWFeUfJRm2cX3Xt0e9MbaAy4kHLbY7N3lVW0pm9PutffF+xIP+67OkzVCn83uVbe0x8ubyiMl6ff+NXkyfGMfGwxiS+9I6WxHF1J0J6JdcSymdfUYyzNtTIopo6TkCKuISH25eDBWcgZSl05NIhqUBioZSgmViqOSQLv1AIqGWi1UG/JYcMP1N+1YszSjyEL8zTgsvP9GnyKLZXfyVADDpQ2l0oadG3p6NvwxNrxyOCZ/WL6x+MUh3mCcW1qtLHxsU5NI+sYHawv3uG9ZQlfr60ESNTp/gBglEiO1ouF7kmwS8wn0gqCs0wOaYkFZbKQPAiqbkjPYi/maahTybBI6nQNFZ/MJAAIaZ2HA1Um2V081yxCqSK2XnIt2e8rdbq3+uwfHdpR0za50n7c7NCiate50n6c7tLdrRUe3p5R2a80KP2RK1mdtXaNVZt5MPlG0WvqW0FBsh6SHS4y+tgZyoeFfrLiaNoz4vOzbuximyOez3GVv+EvqU7IvmvZIV65MVWo/USkFpUR2mmfkaXm0uT6mnxlkRr5uxmZFblQYc8Kzym+Ymx2tVGCX9Ar0SPsbkB6hS9IoHP9m6Vj1n4IgiMrbiGfTe1jz1tTLk7jisf8sCHWvXf037mBdD3ewbSg5M913dMh061muGMXVFqMkKsJ+aZd4QDoLkcnJdAXelbyVNHlQOCEcgAhEpLOTGdyBTJ3WdowDMWa1rNMoVg0KGN0blWpBhHwkmkY9NwCqtBdzXhHVFVXdGpSxsJF6u5TSQUfbsAOb07Ldy1R44sRYGWhraWkf96zoCOU0aofLomctYVO70WDi43t6Yr7xpNPDxTbFFnm2dXHtXNzbDJqwy66z0CHxInA2C+hYC29ot7Xo5qUinWRQq1e1Le+MeLZ5rK2tfRF+yG1h+bAlZI9u7E6H4m2c0b8tdU855QOtH6neXe72e7U6lW9TkkOqVoNxScqTt8ljAtbQtcn0Eqvp/zK5kkxqNnofe9/n/AZDrYzGaRW+ssXhW1TqGoTRaoWbJxIT8GJiIgGuqanq5NTUAoTJOmxF77FuyocAPokMWsU6LPGZeHpq2j6qpMqoGTwyWH3UQDThLsDsoPgP9q2hHct2wO+UcuIsS8vHaoWS4yTJ6/X8G9A66n82WX0APbDygktEexDrex/EmCbPp0ykTAuvN8kT/bA237/easJiO7zwFju0ffkOZewzmLvV7LKejaA51w43UDqYevts6mA//KIfobe7DsLSvfFTp+J74WR1Ek7WYJyZ0rmL3cU4mAQzh5kr5yAMUFXjHLLaoa5R7SoKhKNVjVrRQwxEsm4hGm2NRrpACw45BnWBwwcgjyoUOTlyccUITF27atkNLfpYZNHI81dfO69vLiFh/4339S8dnn+NVhuOLF98cvFYjG9uXjM0uvqCX61e0jcwmktHYbf0YXa8M2Y0W08O9HRI+0I6p7tQWq4Vchm7w/KZj/0eyaWPrdt8zdI5+bDdIfQ8tnL1aP/GgkgSsfuXji1akoqrYslVI2PLHownX+0bGaoEQxqV2wG3SQ+b2sKRXKn8GvE6pH3iof55nUmVwHZ29Arlz1qUfR1nb0Pt62B6UTLy4U8+ENr5zyf/vCbjsKmDkVwBAsEINhXKYA/ksxkHIqrJdr3B5Vvlcxn0lWBPEB+4VCunzC5X0OUCnaR3h0JuEXYJ7nCY9VhsToPFYnDaLIgkjSqDjuPH7PQ78ak+HnbBcXeoUgm5pVFXuOGz9yDPQYxuDNSzxgLuAS1EoNuloXkD9TRoTzS98IEmgquC2v4VOUdWTi1h2SEgTSqtp9RV3Nhs1LssnA289rmD38HsgrXZk9xDGDj+YtXqm01HCx0ZM7ibOQLN5Ehzi85osJjegNsPYS5l1HfotLoNbq+zzWoxSO+2j+k3q1WufLyb0yEF8oDJZDU4jhpYtk36q9oWdeYsD2Gk0zRb3qDLabksbvtxJ/qZIWYBs5K5htnAbPkfsTtgdsgXJyoavn2Y5tUsw46JoIavXTk4ZMGEbVw2H1VrsvliDFAiWUw87Fmq3WE1r7FnixHenv2iwA67q698eAGjrrbaDBiD/fDLlsTYyoQ2NtSxU5sYG0u0zA1l3F6ovgp7bgOoiLkFmAnsFuHkboqP4uiJ3fHCnKvu+MJQ/2n1VbUW0S+cMptwMrgNjDJx7c0dV8WJNrES5wGVxuqIeYfm3P7r0fwdnxTC68U9e4I0IQDYU4HbG/pxDs+19H5Dud0wUXXwU3GYZt1uBGmdXkIV4NK9O7fPmz9/3vadYKpD9+7asrHU21vauOUCAuUyAuw52iFdnIkszMChQG/9vF/nRfha3My6e5FxviqL8NwVblW+Mt/S6NjMkZTY7FyJ5lfo/DEwcZg0oWePstulswdEaRfsFw+kK5IX3q2kJycx4zp7gGZLB2iaNDmp0BnHnKAVvTID5gDm2TYHOhk8Gavqnp51Vp9fkQ6S4WBa+vl46fTp0vhKJPUOhKR36CkfQu3j5dOny+NwuHHfpiKH5XM6KXJFtkm6KKd6ZAtN3xFgZuMBPRNjvpqopfV31coGzov1Mz+HONKhn+HRd4AcQSB5Dww0aCWJje6yFWVwQg6AVqFx93QDO477Hsf8m7EGMdHG0wxGHXpYRS+LscWK+Y2XoMOKaqbzoSjQzIeTTZteltZgGqT4Y4SECPkRzDlPVDIkTZwnphTncSz/9saQkBT4rTFnQNNsdwtJeKJzsQebzElX1yqL2exD2OdXO9o2zmG34WAVOSpNfIAEQU2OQvE8kW7FVAbxfTIhfZsp1R4abUNCo36ZjoNVZRIda5CO6Fu1tiNdxhX+FyXYf3Z4nGNgZGBgAOJNb47Mjue3+crAzfwCKBDF+XhfA4JmYGB+CRJn4GBgAvEAeqIMgAB4nGNgZGBgfsHAACH//2d+ycDIgApcAXBnBQgAeJxjYGBgYH4xdDA9AADYnCd6AAB4nGNgAIIZDBcYnjE6MEYxLmF8xaTBFMVUw9THdIPpEzMHswzzBhYNlgKWLpYrrEGsOayT2GTYlrE9Ymdgl2K3YI9hf8PhxrGBM4xzDhcTlxpXAFcKVxlXF9cMbh7SIQDoHxaseJxjYGRgYHBlSGfgYQABJiDmAkIGhv9gPgMAGrQBzwB4nHWPP07DMBjFX2haRIsQEhJiwxMLUvpnYOjYodk7dGBzGydtlcSR41bqxjE4Acdg5AicgkPwEr6hQqotOT///N4nBcAtvhCgWQGu27NZF7jk7Y87pDvhkPwo3MUAz8I9+hfhPu1MeMBmwQlBeEXzgDfhC9zgXbhD/yEckj+Fu7jHt3CP/ke4j2UQCg/wFLzqLHbbZKbzjS4WJtvn2p2qU14aV29tqcbR6FTHpjROe5Oo1VHVh2zifapSZws1t6U3eW5V5ezOrH208b6aDoep+GhtC2hkiOGwRcI/18ix4VlgAcOXPe+ar+dS5/ySbYea3qKEwhgRRmfTMdNl29Dw/CZsrHDkWePAzoTWI+U9ZcayoTBvJzfpnNvSVO3bjmZNH3F206owxZA7/ZePmOKkX1qXaMkAAAB4nG2R6W7bMBCE/cWSrThp47ptet/3obbpfadX+h40RclEJFIgKR95+hJ1ESBA9w9nBsvZWbK30VvXqPf/OmCDPgkpA4ZkbDJii21OcZodxpxhwlnOcZ5dLnCRS1zmCle5xnVucJNb3OYOd7nHfR7wkEc85glPyXnGc16wx0te8Zo3vOUd7/nARz7xmS98ZZ9vfOcHP/nFAb97W6KqnKpE0NYMhHN24fvCy4EURqo6lTPhwljOlDyc2mX+F6hi91jQplBBuUYbEdTkWO7Mv85taWvr8lZH4oaRdI3xI2lNcEIGVSTStqtUOut9UigvM7VsRfQsNtVK5b4WftaPaFDqOo5JS+18SCqn27RytmuT2BCSWpVhUGsT52XrI98b1lYU2lRZI5a60UcqaZTpshh0zYw1asvYkIu6tgtVpG10Uv1Wm7TVcxvGLl63+bQLwZrcluXOScGkTlezkHgxVyPfRJe8sAuTrWFMFuLKk+CUOvlGWWfWERFUOBQBjcWwwCOpmXHIlGX8zYKGjpYVJUfMe70/6zKeWwA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n\n.ag-icon {\n font-family: \"agGridBalham\";\n font-size: 16px;\n line-height: 16px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n\n.ag-icon-aggregation:before {\n content: \"\\f101\"; }\n\n.ag-icon-arrows:before {\n content: \"\\f102\"; }\n\n.ag-icon-asc:before {\n content: \"\\f103\"; }\n\n.ag-icon-cancel:before {\n content: \"\\f104\"; }\n\n.ag-icon-chart:before {\n content: \"\\f105\"; }\n\n.ag-icon-color-picker:before {\n content: \"\\f109\"; }\n\n.ag-icon-columns:before {\n content: \"\\f10a\"; }\n\n.ag-icon-contracted:before {\n content: \"\\f10b\"; }\n\n.ag-icon-copy:before {\n content: \"\\f10c\"; }\n\n.ag-icon-cross:before {\n content: \"\\f10d\"; }\n\n.ag-icon-desc:before {\n content: \"\\f10e\"; }\n\n.ag-icon-expanded:before {\n content: \"\\f10f\"; }\n\n.ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n\n.ag-icon-eye:before {\n content: \"\\f111\"; }\n\n.ag-icon-filter:before {\n content: \"\\f112\"; }\n\n.ag-icon-first:before {\n content: \"\\f113\"; }\n\n.ag-icon-grip:before {\n content: \"\\f114\"; }\n\n.ag-icon-group:before {\n content: \"\\f115\"; }\n\n.ag-icon-last:before {\n content: \"\\f116\"; }\n\n.ag-icon-left:before {\n content: \"\\f117\"; }\n\n.ag-icon-linked:before {\n content: \"\\f118\"; }\n\n.ag-icon-loading:before {\n content: \"\\f119\"; }\n\n.ag-icon-maximize:before {\n content: \"\\f11a\"; }\n\n.ag-icon-menu:before {\n content: \"\\f11b\"; }\n\n.ag-icon-minimize:before {\n content: \"\\f11c\"; }\n\n.ag-icon-next:before {\n content: \"\\f11d\"; }\n\n.ag-icon-none:before {\n content: \"\\f11e\"; }\n\n.ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n\n.ag-icon-paste:before {\n content: \"\\f120\"; }\n\n.ag-icon-pin:before {\n content: \"\\f121\"; }\n\n.ag-icon-pivot:before {\n content: \"\\f122\"; }\n\n.ag-icon-previous:before {\n content: \"\\f123\"; }\n\n.ag-icon-right:before {\n content: \"\\f126\"; }\n\n.ag-icon-save:before {\n content: \"\\f127\"; }\n\n.ag-icon-small-down:before {\n content: \"\\f128\"; }\n\n.ag-icon-small-left:before {\n content: \"\\f129\"; }\n\n.ag-icon-small-right:before {\n content: \"\\f12a\"; }\n\n.ag-icon-small-up:before {\n content: \"\\f12b\"; }\n\n.ag-icon-tick:before {\n content: \"\\f12c\"; }\n\n.ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n\n.ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n\n.ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n\n.ag-icon-unlinked:before {\n content: \"\\f130\"; }\n\n.ag-icon-row-drag:before {\n content: \"\\f114\"; }\n\n.ag-right-arrow:before {\n content: \"\\f117\"; }\n\n.ag-right-arrow:before {\n content: \"\\f126\"; }\n\n", ""]);
  46460. // Exports
  46461. module.exports = exports;
  46462. /***/ }),
  46463. /* 250 */
  46464. /***/ (function(module, exports, __webpack_require__) {
  46465. var api = __webpack_require__(225);
  46466. var content = __webpack_require__(251);
  46467. content = content.__esModule ? content.default : content;
  46468. if (typeof content === 'string') {
  46469. content = [[module.i, content, '']];
  46470. }
  46471. var options = {};
  46472. options.insert = "head";
  46473. options.singleton = false;
  46474. var update = api(content, options);
  46475. module.exports = content.locals || {};
  46476. /***/ }),
  46477. /* 251 */
  46478. /***/ (function(module, exports, __webpack_require__) {
  46479. // Imports
  46480. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227);
  46481. exports = ___CSS_LOADER_API_IMPORT___(false);
  46482. // Module
  46483. exports.push([module.i, "@font-face {\n font-family: \"agGridClassic\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABOsAAsAAAAAJiwAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlIAAAReYchjok9TLzIAAANcAAAAQQAAAFZWVlJ+Y21hcAAAA6AAAAHtAAAFgHClDfdnbHlmAAAFkAAACi0AABQQq+8lqmhlYWQAAA/AAAAANAAAADZ2z8SBaGhlYQAAD/QAAAAeAAAAJAfTBChobXR4AAAQFAAAABoAAAEou4L/4mxvY2EAABAwAAAAbwAAAJb7HvWgbWF4cAAAEKAAAAAfAAAAIAFgAHhuYW1lAAAQwAAAATMAAAJS8kTiWnBvc3QAABH0AAABtgAAApcplp2DeJx9k0lyE0EQRX+rZSMPyGDMZMRkRpsh3O5BjSTLltzyQHjBggULNmYBAeFg5ROw5gAEB+AUnIBgyYoDcACCA/Ay1UbGC6tC1VWZP3/+yspSIGlSy+qqUmzuPld9f+/gveZV1fBn/qPrYP/tmz3VDnf4qv6tKQj/qK4FvdCBvgUKXgefK+NhJeyGu+GH8FP4QyGoG3oMekorjFgJc6RUmZrKVdE4tpj1E7VAh8xtt87qgsbcU2ig8+SMiRk445Ke6o7OwNN3np7WQKUM4+wxbzHuauYERK578GeoWcVqrA10ntWENtHYQ0eH6BbeGXzrZI6I6eProy10VNXruK2XRM762SwyK3Ep/1gbvo9894AqHKLa8DfhN75Fsh7am2RKiHgEewaqW9Zwif8U3hRMRGzHa2bR10AmKEx1nZWdLOFk07oN+zO98qwbZUzPqzg88yLqR/a+8+XkOWrtwLUF9iEaRla7kfvkirSDf5KbKvROH/VFX/VdP/VLv3UK6ypeO8Ea3OsnVqZG/Y6jC7ztf1Y76Th3fhz1P2KCcze9NjG+QVlByzaFTqtNyjrCmjp+Ep2GL1CTU68qOSLPm2AdY6yyj0GfLruxxZj2Og/oAeuAeWqxwmxMw37L2V+GyVZDXRe9Wi14LvltWU3tJdV9Zz1vtzxPna/wjThZ5vXZxnsVizGNLA2PylFtHMv4c9SOspmqBqoSeqDmnbXjr6Ag003OMVSS6Ja/gB3vqgUUZOWLnNM5V98pb2rOcbFHBWiOypeces2sk/tos67Y+gsvGGrHAAB4nGNgZOpknMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVHMnxi4gDQjSA4A1QYKdAAAAHictdQHTltBFIXh3wXTTEnvvRc6hGp6XQbpiBREOsoqs5O7gZBzPScLIFJG+nw9o+c3b/R8LtAB1OSp1KFap0KO31qttNdr9LTX6/zSvEkXVX0fYo8DjmL0+FirQ+yyz2FU2rO/o6Krm1zlPs80W2GMJeZZZZItxmlpdZEF1phhmg0mmGOKdXaYZZlNtvX7qnav6xkbdGrfbj1Jr+7YRz8DDHKaM5zlHOe5wEUucZkr2u0a17nBTW5xmzvc5Z72f8BDHvGYJzrPkD6HNRvRAzY42Vg54fU5xpbmVye3xls67cLazLQOOje1vjO7vLn9Dzf7D6OZH7Wfnu2Qb7PI0+7amDy3JXlh8/LSVuWVTcpr25I3Ni5vrSV7lv+QfVuUd7Yg721NPtiMfLRpObANObQJ+WRz8tmm5Iuty1fLs3+zWfluy/LDNuXI9AKjUmRWolqQtVZktqJeZL6io8jcRaMga2dB1q6CrN0FWXuKzGP0FmRtFvkmo68ga39B1oGCrIMFWU8VyhJhShVhyhdhShphyhxhSh9hyiFhSiRhyiZhSilhyithSi5hyjBhSjNhyjVhSjhhyjphSj1hyj9h6gSEqScQpu5AmPoEYeoRhKl3EKb+QVj2zbDMTFj7muGCrCNF+56jBSN/AHzNoH4AAAB4nO1Ye2xT1xm/37nEN87D8bUdXwezwLWJDZQCtmNfO4FATIgdQhLWGwhrt0DSGJHHpgaawFRatBIVVrXbHxXTWCiPabMHo9MgSH1IGxJMa6b+sbBJFZVK2/HHVNjI6JZ2k8W97DvHjzyggPrntBufe17fPec73/md3/edcMDhw4f4fs7IcSBLglwuW3mZD+mj+/ZBQtv//vtkhPxuYiIFe2EvijD5T/lPuUVYCQpeRRK8oswyRRZZJokyywQZLrXFxscbNwPf1oh5m65txjzWpuu0PdYGhF9k/LIuWm/czOXm3Mq/whViRfAaMYlu+NkbCeiG7sTZU2TPGz3QrR/vOavdzMmTSTLJFTN51AW1QX3IZOOFsdiFC7GxC41jUJ8rjTVe4Ao47q6O67rBWTk35+Ue41ZyXIHsWgFBsboOArK/EspFmwl42WXAgh1bQtjlgYDorgqUu3nM+T7N5qpx4Y/83VUjyzWyZjY7HGZyW5Qk7ReqCi2qmmpvJ66Ii3yGL/xpZfjifySJmig6HCL5hyjpY/q1ZBJO6jtw2Vm9bjK9luJ6coq4p5UrmKOTALheK9/HdHDldbo1Q5teffLf1aev8zdyKuRU2jJTk3f0ot/XH4YTc/XwPpoevByUH6jFX/Tz0PoQHfTSJN3OWfM/2uwPmvkhk9L14qL38T2IjELOwXEIOskIvLIQDAL+ldvsOEu11+Mlf9O31zyta1A3Pv7ur4uLK8rsvg0+e1kFXIJTtdihX4Y14+N1paWVTk+Fy+dzVVQtqKTDG9gcR/gjOJuAWC3DtUkcV1WOZsPEz8nhlH6ej+rnk7OydAofaEniA620zGV1v5HF8spHsxYghsvdQXcwEAzw/RmLadaMBcmkZmaWoZbT30uxJ2NBS9aCk1kLWlFCJLdw2y5QlVJMFfaK8lG2ShH1CYhy0I0sIYsyH5TFQJCMJvWSJEyp+hi0pPQxlYyyehrrp7AxzeV54Hn+eXqujYDbIRgB2UCBKbAM65PspU8OgwVfpG9WFSxYncElhxmXiAFkLDrAz0+eTejH9eMJ+C4xaVNYOQFdCe6r4p7u2oPQ9wO95GGoH0smp233Lq9wFZyPW43zK1IoYJfskgkBicwGobUQdLsQk17rCuI1CJUg2RXJgMikfyEUUFgJ5UGu9qyNHnpucNvSb9cF6xeZ9D+taPYW1T0WfvzAX0PfXF3UUO17pVX9uv9bT3ZtrYus9D85BFc3N5os9kq5uHY5b1qyyjLvieaDa3Z5GgJLiuFAEQG1wGBy6tcM4W1Bf7zhabujeN2CImN1VZ1/40ub9KO+TqskLZwfaHf+b65FQjwv4UK4FroORg1ZXUNYpm12Jac0QcB4qzxrwE3lJBRR4A5dQdvw/hd/uJ8q+Y0933umoXpdZ/euZ3Zs3ciULWnctbc3VgQboagtFAtVLQl5VvPlvNr84nBLW0nJRs8af/NI85Yz/vg2JWwwKP4eq2RfVBF+qjrUWcOXLlgGhcXzm22FAuEyPMo4px95DT2+VQbRG/SVB4Iq45Qk34/eZ3sq3d6elSV30I/yLDoQ3SI6Fq8gwVqVmC9fDqfTZFIvgSm94dIlrFDxkuxZvziL05zcwmmvqiDT5BI8pCwjH6WSyTT7ISN8WQlOJpMTSUaCJ+/NUKWC7Lovcl/jZK4KPenjlIcYsSLvZSk2n0R3UAZ3Ofr0TKrCBKeQYdFGyLY0p0zF8h3t0JqdjqnD96tovqSaxiytklhas6hwqh15TFXn2rTKLQaARicCuaOq2m1m1PQMi2b46iS/lfGVhIRHQzTYebpHPw7dPWdIDZw8nYmDzlCyJXe/uPsF/y/+n1w1159BpaGMuiwvYs+j4AEL+RkqsdUElQQb6sCDnUGfhxaxC6segXVTOSlgpx95q70+KsbkK0muuxL82KmEvB7yQsRmWxIeibQ2b2rZbcMnEi+qsAARyTxDhdNmCTY1OQ8usFidRgepWFpoL7JbwBpp2dTcGhkJL0FxSzkU2QuXOUhpsdFptToPOpuaghabs8IwjzcTsFQUxSN0XJyptfkozkQru9kAcaPZFPQXWgzznfGmkM3qHHHG406jaHY5lhYSg5nOxFQaCR9FcUuZQAqXOlxmo1BEBUecVluoKe6cb7AU+oMmszHOVjHzvBxBFC9kjCUgLJGs0FciYyE8cfPQYwaUoNctlJPY0eGjV6/iK5kv/Pjl7u6Xu8lvZjXSgvZWN+3i5s2KPZchNz5a5CmwoBYU5E5JeXDseevjmG80fAyuxT7xvR5+/SEBqFYX+2jVMRR//pOYD/O8H5qOVViUAtnEH7nzWz6aSelMNEJjEfrJV12bwsJ2XCIlnAev7bmPYquOKaNQHfuYKv2wtaWza3sNTXJMOZa/L7yKZ7KA7jA9jfAUO4ngzxFb5hw6+T9zpdN3EBY7SDDamwAveBO9vQn9A/2DRC8514ctWOrTX+rDNuzry8YSd1ksYeMWcwEaS9ATZqZOYxF1EWb0CKECemYDflqk8eVKehyZTzSU0+MIU4efHYxu2BAdfFb/bGgw2tAQHRyCCe3NUH00Nti1XYlI0rJ4qH49VjrDEcAafxOlh/TbQ7up9O4hMON3Gz7X3lwmSRGls3swFl0XaspUugbj0fpQDvdR9BMCcjiL2DBMC0iUKTFyo6y2M51Mqfp5FaZ4h5Ygo2qK8l/eVjTewxq4RckteN0KpVQy2Xkurarpc50wha5jvDed7oWwmuHnPE5k9Khhbu39kUIDBAaVWvRHwQKMIBExfOYeyg4mPaFWSuL0BjAHN9p3DlDcHEjx67R3SKUo/adk9eBgbcnFklqaDUxo10mjdA+CyO1kBkIkhiT9tkOE1ZkPMt+VkljyBbwzzMYR85Tk1Tk4IjMwQG9zbGPNFAaL6I6bKQwEBgsb7XHRejXtgalD+d0uyyHgMNvwiLK96zpuNj6dXfff7C10a693d1Lhzm4UViKz8biUxTD3w6PEVGQ+g4GS3nk8VtwJ3BvcGdyX+0LyUAZ+VKXrOSW/v37P4T3r2euR1dR3NGQ/Wb8nj60TWX/oVfACoMhBcvCXCejSTyROa38gsTOZUP50Ks/fA4jjUs5OYxh07XmeKcj+uyKAAH5L9blI3OXTxwZqJiZqBtrRCX8Ii/UP6Y0NFi8YqJ2YqB2A16bxTUbp6BhBpchP9DG8sJzPc8koYp/QO4pIYwS8nrRoO+f2kUz4wNdjwDU2Z0wj0CCjJSOR7UvyMYorI0HG4ZPaFf294YvwNrmiXYHgEJam9YrTnaVHABXTdiI4aXM+LnBzMa4D+dtumxsXLATalo0KQn6Jt/vz3t5gw96sr6dfCKxNAooH8LgyFbufPCEIHTNCgA7BKrQaDNvQn1MH2yHYBBemDuqm0cVvMxhaUaJjhivvEATiWG4y3fmpyWPCnO80ef54r0zL7FHgV7MnablXjTufL8cRcTgc1VuKw//fJvfa5L+BscYKAAAAeJxjYGRgYABi/jvPp8Xz23xl4GZ+ARSI4ny8rwFG///2/xvzZ+ZPQJUcDExAkgEAoUMP6XicY2BkYGB+wcAAIv9/+/+V+TMDIwMq8AIAnloHAgAAeJxjYGBgYH5Ba/z/G+3M/f+NgQ4AAPv8MfAAAHicY2AAAgmGIIYshhaGC4wijCGMPYz7GF8xGTGFMVUwTWC6wGzGPIf5BwsfiwZLCcsOlgssL1gnsB5iE2EzYGtim8K2jZ2HXYvdhX0Z+w72fxwRHAUcszhWcGzjOMJxieMZxxfOOi4O0iEAtgsblgB4nGNgZGBg8GLIYeBhAAEmIOYCQgaG/2A+AwAbuAHZAHicfZC9TsMwFIVP+odoBaoEYmAyCwtS+rPRtVKzd+ieJnaaKo2D41bqznPwBDxHn4OnYObEeCkStSXnu9899w4BMMQJAZoT4Ma9zWnhitUvt0n3njvkJ89dDBB67tG/eu7jBQvPA9zhjRuCzjXNI949t3CLD89t+k/PHfLJcxcP+PLco//23McqGHoe4DlQcRaZPJ0XcV3nyVJm+yI2Z+6sWElT57oUk3B85iNZShNbmYr1UdSHbGqtEsronVjo0sqi0KIyeisTG26srWajkfI+TPQOMTJEMMiRYo6Cdc2bI8ESkr29c+ZC7v/OihuMY40SAhP+9/GFfMR86WZiWH5Tzqxx5FvjwKkprYVirZjR2JEWbneTLng1TeV6W5qEPsTGTVWYYcSr/uRDprjpB8WrbRMAeJxtkmdv2zAURX1iyVbstEnTNt17D7VN994z/RUMRctEJFIgKY/8+rJxGiBA36dzHx7uu3xgZ6mzqEHn/7XFEl0SUnr0yVhmwJAVjnCUVdY4xjrHOcFJNjjFac5wlnOc5wIXucRlrnCVa1znBje5xW3ucJd73CfnAQ95xCaPecJTnvGcF7zkFa95w1ve8Z4PfOQTn/nCV77xnR/85Bdb/O4MRVk6VYqgrekJ5+zUd4WXPSmMVFUqx8KFNTlWcmfbzvI9UMXGQUObQgXlam1EUOsH7dbsT65IW1mXNzoK14+irY0fSGuCEzKoIpG2mafSWe+TQnmZqVkjomexrOYq95Xw4+EB5ZvdyL2RruLKdKSdD0npdJOWzrZNEkdCUqlR6FXaxN39yopCmzKrxUzXelcltTJtFrMulFGzkBhr1NDYkIuqslNVpE10Ud1Gm7TRExuyxqmJtq1fc9HM5tttCNbkdjRaPdwwqdPlOCReTNTA19EuL+zU7OPfWMMF7o1lC46pQzzNenBKHb5l1prFKwb/IN9EUOJQBDQWwxSPpGLMDtvM4lcoqGlpmDNil0mn8wcxorJdAAA=\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n\n.ag-icon {\n font-family: \"agGridClassic\";\n font-size: 12px;\n line-height: 12px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n\n.ag-icon-aggregation:before {\n content: \"\\f101\"; }\n\n.ag-icon-arrows:before {\n content: \"\\f102\"; }\n\n.ag-icon-asc:before {\n content: \"\\f103\"; }\n\n.ag-icon-cancel:before {\n content: \"\\f104\"; }\n\n.ag-icon-chart:before {\n content: \"\\f105\"; }\n\n.ag-icon-color-picker:before {\n content: \"\\f109\"; }\n\n.ag-icon-columns:before {\n content: \"\\f10a\"; }\n\n.ag-icon-contracted:before {\n content: \"\\f10b\"; }\n\n.ag-icon-copy:before {\n content: \"\\f10c\"; }\n\n.ag-icon-cross:before {\n content: \"\\f10d\"; }\n\n.ag-icon-desc:before {\n content: \"\\f10e\"; }\n\n.ag-icon-expanded:before {\n content: \"\\f10f\"; }\n\n.ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n\n.ag-icon-eye:before {\n content: \"\\f111\"; }\n\n.ag-icon-filter:before {\n content: \"\\f112\"; }\n\n.ag-icon-first:before {\n content: \"\\f113\"; }\n\n.ag-icon-grip:before {\n content: \"\\f114\"; }\n\n.ag-icon-group:before {\n content: \"\\f115\"; }\n\n.ag-icon-last:before {\n content: \"\\f116\"; }\n\n.ag-icon-left:before {\n content: \"\\f117\"; }\n\n.ag-icon-linked:before {\n content: \"\\f118\"; }\n\n.ag-icon-loading:before {\n content: \"\\f119\"; }\n\n.ag-icon-maximize:before {\n content: \"\\f11a\"; }\n\n.ag-icon-menu:before {\n content: \"\\f11b\"; }\n\n.ag-icon-minimize:before {\n content: \"\\f11c\"; }\n\n.ag-icon-next:before {\n content: \"\\f11d\"; }\n\n.ag-icon-none:before {\n content: \"\\f11e\"; }\n\n.ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n\n.ag-icon-paste:before {\n content: \"\\f120\"; }\n\n.ag-icon-pin:before {\n content: \"\\f121\"; }\n\n.ag-icon-pivot:before {\n content: \"\\f122\"; }\n\n.ag-icon-previous:before {\n content: \"\\f123\"; }\n\n.ag-icon-right:before {\n content: \"\\f126\"; }\n\n.ag-icon-save:before {\n content: \"\\f127\"; }\n\n.ag-icon-small-down:before {\n content: \"\\f128\"; }\n\n.ag-icon-small-left:before {\n content: \"\\f129\"; }\n\n.ag-icon-small-right:before {\n content: \"\\f12a\"; }\n\n.ag-icon-small-up:before {\n content: \"\\f12b\"; }\n\n.ag-icon-tick:before {\n content: \"\\f12c\"; }\n\n.ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n\n.ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n\n.ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n\n.ag-icon-unlinked:before {\n content: \"\\f130\"; }\n\n.ag-icon-row-drag:before {\n content: \"\\f114\"; }\n\n.ag-right-arrow:before {\n content: \"\\f117\"; }\n\n.ag-right-arrow:before {\n content: \"\\f126\"; }\n\n", ""]);
  46484. // Exports
  46485. module.exports = exports;
  46486. /***/ }),
  46487. /* 252 */
  46488. /***/ (function(module, exports, __webpack_require__) {
  46489. var api = __webpack_require__(225);
  46490. var content = __webpack_require__(253);
  46491. content = content.__esModule ? content.default : content;
  46492. if (typeof content === 'string') {
  46493. content = [[module.i, content, '']];
  46494. }
  46495. var options = {};
  46496. options.insert = "head";
  46497. options.singleton = false;
  46498. var update = api(content, options);
  46499. module.exports = content.locals || {};
  46500. /***/ }),
  46501. /* 253 */
  46502. /***/ (function(module, exports, __webpack_require__) {
  46503. // Imports
  46504. var ___CSS_LOADER_API_IMPORT___ = __webpack_require__(227);
  46505. exports = ___CSS_LOADER_API_IMPORT___(false);
  46506. // Module
  46507. exports.push([module.i, "@font-face {\n font-family: \"agGridMaterial\";\n src: url(\"data:application/font-woff;charset=utf-8;base64,d09GRgABAAAAABGsAAsAAAAAIJAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAABHU1VCAAABCAAAAlEAAAReYPJi3U9TLzIAAANcAAAAPgAAAFZWTFJvY21hcAAAA5wAAAHsAAAFgGqPB0pnbHlmAAAFiAAACFEAAA58peGl1GhlYWQAAA3cAAAALwAAADZ2zcSBaGhlYQAADgwAAAAWAAAAJAfRBDJobXR4AAAOJAAAABIAAAEkt5gAAGxvY2EAAA44AAAAbQAAAJSyFLU8bWF4cAAADqgAAAAfAAAAIAFcAEluYW1lAAAOyAAAATIAAAJebBQ2inBvc3QAAA/8AAABrgAAAom3/2OGeJx9k09yElEQxr9hCCYBk6gRFVFT8X/UOM4MTIBIQBApKwsXLly4iQstrZSrnMC1B7A8gKfwBJZLVx7AA1gewF83g5gswhQz73V//fXX/fopkLSoSF0VhqPd51ra3zt4r5qKmvzM//862H/7Zk/z0x2+on/nFYR/tKR1vdCBvgUKXgefC6WwEHbD3fBD+Cn8oRDUmjZBl/WAJ1bCO1KqhprKVFAJW8x6Sy3QIe+2W0+rqjn3DDTUWXLGxAydcUNPdU0r8PSdp0ctAzhT5+zxHvFc1/IxiEw34G+gZhursdbReUoLeozGHjo6RLfwruDbIXNETB9fH22ho4rex7Fe6h42q80iGzku5R/rke8j31XowhTVhr8Jv/FtknVqb5IpIeIu7A1QD/MebugK0U14erB1PHrLoysgExSmuszKKkuorEKH2nqmV0SWUTGJ6XkXJzXfQv3M3ne+TLcPWTtwjcDeQcPMaidyk1xWewK+yv6dPuqLvuq7fuqXfoOvkiXxCrpw7xzbmQX6dxQ9wNv+Z7VKT3AWR1GHEYvU3fTexPiGeQctWwWf9SZlHWFNHV+G0/AD1GScxhyTF3neBGuJ/Tb7GPRSPo0tnpPe5yEzYBNQo5Mxb2OazFtGhy8QbauJrnPerRY85/20rKd2k5Z9ZzNvp1zj1C/yjais4f15gvcSFmOaWeoelaHaOO7jz1A7y2aq6qhKfXZtssZ+CwZkWqOOiZJEV/0GjH2q1lHQyG/kqs64+k5+UquOiz0qoBNRfpNT75lNch9tNhWjv/VfaSwAAAB4nGNgZGphnMDAysDAVMW0h4GBoQdCMz5gMGRkAooysDIzYAUBaa4pDA4Muh8NmF8AuVFgEqgRRAAA0p8KWwAAeJy11AduVDEUheF/SkILvbcUSK+T3ntlGaFHoUShR6ySndwNEM4dHxYQJCx9c8d+nvdsPZ8BWoCaDEsdqnUqZPut0UpzvMbF5nidX+q3cZ6qvo9wwBEn0Tg91egI+xxyHJVm72+raHYbj+hlRr01GqywwDqT7DDOEtMss8gGs7q+xQTzTLHJHnOsss2ufl/V0+u0ck5PvaB1XNL9LnOFq1zjOje4yS1uc4e73OM+D3iopz3WnHY66KSLp5rXTY9W0Ec/AwwypB21ab2jjGmBrZytrZ1xfrbGysL65M74kna7uDE7o43OT23uza1u7/7Dzf5Da8uP2k/3npFvs1iTfWvIc1uRF7YgL21dXtmkvLYdeWPj8taW5MCm5dCW5Z0tynvbkA82Kx8tT9eRbcmxTcgnm5fPNiVfbFO+2p58szn5bqvyw7blxPQCo1JkVqJakLVWZLaiXmS+oqXQmSZMp5swnXPCdOIJywyGKQWE5dsLUzIIU0YIU1oIUx4IU4IIU5YIU6oIU74IU9IIU+YIU/oIUw4JUyIJUzYJU0oJU14JU3IJa+6rvSBrR0HWzoKsXQVZnxRKPWHN/XYXZO0pyNpbkLWvIGt/QdaBgqyDBVmHCrIOF/kfGiNFc/2jRWYpxgpyrFEw9gcVSJ+veJzFV21MW+cVvue9xTcmEOKAffECduyLfWkwrsy1udgGwlcCisrHZCdaG1LTdIG0sBjaVF2WoX1okyK1ayqt9Efzp9GkizSpTVv+pNOUVCxVmfrHUfNrYmzqn+GsQ1RCreTGVzvnxTbhY1Kn/Rjc933PfT/OPee8z/mwAAL+sTWxR9gvCOCxV4LdE/HoqoetmRVQZX4FG+byvXvQIHYncrnEbCYjCI/RGfED8QPBIlQKNcJhPKlFNFXSJCUiyRHNp9oVu2ZXFbsi6wrcMNKLi+k26lj/Yjo9z9/Zz7CfJyqxmDbSOlLIlssj9qA8+wShWtZtmk3WYT6WTa7GzQXYiGfNMvg2G4dBFJvvnRPnUIYjeNQrWSRLjeyQHS16q94aVv2qv1pSJVVXdVmXJdiYeTalR6N66tkvikQq9tZbsbk53otz25Y4kf9zcRV74f/zTZF/s1asRUqie6rWbAo1XbMrmdnZB5cuZV9+mT1vTrCB/K1cTijJuSquCtWCk27WewDsthoXaJ6WTojYwkGwgi6DLF5++LVLc+EjlvMxv2Y+GFoCY0hcxfdtiw+/BsfQp2AMb+cv781fRCDt4v6b/H0W2M05f3/6UZ4i52nz2Hx78UWeYvkOvpuT6Z18C7b7sfhDoQwRVSsIVpBkK4i6Gyx0dfYaR0trhK6N/dNMxZ4z89C5tPTp+/v3O6scoeMhR5UTFuFGHBfMP0HH0lJnZaXrsN/pDYW8Tl+di9hbS5jdvJ8qbpPDgltQ6K4iCjUJWwSbjE23a5GywrwN27xh5PhTGM2xwhu7buTHcUwahQlcwafoJ+waW0O9BFRJQi95M3b7dizH1uJ37sRzJdz8XLyDmjuFen5LFjt6lEfmRI0DjdqKNvUr1R6bh71vViihJGzMmhFSDz7DXgEzAp+Jt0Pe/EesPxFS8h/RGutXQvnzrL/gr4RNih+Iey6KrKtibTybLT7sr4+8bPdxPGNTbKoEYjd3chgkJ4dvzbIsOvwOPZG7rrLXY7lc7DZbiOdy8TulmPEUWxXa8SXIFK9FUlu1FtkF8gFAUldwQpEtitevKi6mtehEq0HAJdkiabTZIWvsTSnYp3ri8uBTEyMDJ16ok0+1DfmsvZLt6FDfPqsnvK9Xaj6uNhzp7x3A9ck6//fPWB/71eP1jUfC1h5m83UoTseg5nZf7O845xn0abWHjh4H1e3vVKpOfI+mx7pGq2sa6/xFXJLMhxAnjTySoKwoMQaSTtBRNr/oDUK4E1pcUHMARK+FoBr2wwaXre6FEwPvIFFfj8RI4GQgcPIH1AUao9GRaJT9g77Xf9HtLo7mZGEHdiDSnpFoESOTaN9CbPEhHikHAHovRm7DXGZr+WuYBSpyCbiRSJjLyVJ8Yd/we7HSzeh4N4AxiX3z8cd4MWYkmYQIATFHZwu+3cNm+Hco03jKKD5058fZ24U2k5hP0DYL3/uMWI5UuWAT7IheN51BMzQBCaejTXCo5h6FmUdBM2msHxzo8vPgMB/MI2FWpOlvhYICDFI3ND29gmM6fz+dnqbpXXpUE3pVD+rxFVcDXkkm2QJXA5XYmZ8AEyVGURXV2IQrDBJ0mSsbMxfMhVi2aN859gnmi1ohgF9AUeMQUTCuYVTjVBBkNIUPU2aLi5GKSHQCRrrfedsVw4iOtbWNRQ1Daff+HobMD+EVToNSWoQNJa4Mt6VeTLUNK3EpaWB/gmbGZlJtxbhajvaUuR0xLWHikCXM0hFMVGRAHbO2qOkRVZHsLHB+ePyNN8aHz0+XiPHR7u7RbvaTbZNEmFe6aalgl0lxkjSuxtudRdgcEicTwh4Y01Fd/o93yPdtNiwvkplEouDza8I9OqkjLw6hDMfGnrxsBbzO0r4ivy24io/kbI8Q/A9ZG8JEUiCAIABGCkCM1dDGvXK42dMceHLwTPRCk9nsbYBBJOBzbwNN7pXSzdSZwScDzQ1es7npgvllgxc+b7oQ5XNFnaYwTjvwflSUTwkCxjBlR5D2tDhqLF5/uBU8Ng1V1sTam5VdI12VN3lIHqDeXLY5nV6nEyL5W0l4JylO+oJBH0bv83zPdW+oVqnFB210fXa2iI0usROlqKJMourVwKM41S8qnHlVffVvEHC51ttPr59qv+yCVpyBv5v3Xa7L7afWT7evu7bqjf+dj7VUW27mUI/gE5qEJwRN0DE2edBX0BSdVA24qC44AIBug/bw+PinsOTUfLz8onlyKR0bRRm3Vl+vudnbfMz/yzAQK33wR/OLY8fUiYmb+P6l2nWsccK8gqRjZWXFMNq2Drg5A7Ab8GvzynvHuujI/BNqFxLgp8RsbKu5aoTHiyg7SCg7QtA6SCgTvdRzqLXQSgFgVy/N9Pb19c5cgoNF6uqPzj4d0fXI02f/UiTEVVow17dvfvjTbZs4UcAUyVKBNmwlaXjA2Qws6n8hWt9Lvb0vXaWu77tJydYK+7HLfWeBd8VWSUbPx5zyaM3Pa4RsDIt/VvCZSfwF4tisFZWSr5TpHHY2dJD8rcSma5gLU7FMJjaVpB800GAu8xKnoW4qnsnEp+C3pZrqE3aWuAMWVA2ZDBulXzzFtbMYxxmXjebZ3b3WEOyvZTJ0VtjFEwtunKf1LX2fEyuKtQ2ocPHd+CpsxCDxbiyLY7G+Yq5iXM1Qjc9cyRLvNXZtswak4qiQq9jrVAlu1YBzaCfKoy0UWyjNgN1hkWQsqBEMEtakVCjZt/JRJIyFEW6U8dGB3d1MOPrRjvCxtrFzo8l9+Vu/jA0Us1JP6LT7xdTAfDjfz+5i6lECx/d3HD7XHk21GUmY+kXt811RnpmU0Mmy08lncCf7gyD8G975gHwAAAB4nGNgZGBgAOLNefk58fw2Xxm4mV8ABaI4H+9rQNAMDMwvQOIMHAxMIB4AThwLfgB4nGNgZGBgfsHAgEQyMqACTwBFgwMNAAB4nGNgYGBgfjF0MT0AAODAKyYAAHicY2AAAikGD4Y4hhkMlxjeMMowujEWMC5ivMP4jkmByYopgCmJaQ8zA7MMswmzF3MD8wzmDcyfWFRYjFi8WCJYilgOsTKwqrB6sC5jfcPmxhbD1sY2hW0R2wa2fWwX2O6xfWC3Ix0CAAMJHZwAAAB4nGNgZGBg8GSwZeBkAAEmIOYCQgaG/2A+AwAWwQGmAHicfZA9asNAEIWf/BdiQwiEuFKxEEgTkH9Kk9qCgBsX7mVrJcustWK1NvgGOUhOkEOkzEFyijytt7ELz8LwvTdvplgAj/hBgKYCPLjeVAt3VGduk549d8gvnrsYYOK5R//dcx9v+PA8wBMOvBB07umE+PTcYv7Lc5v+t+cO+ddzF0P8ee4hDOC5j1UQeh7gNTBJHpsiXSRWmiJRS5kfVHJlXqqVNHWhSzGJxpeDWJbSkFOxPon6mE+tzURm9F7MdWmlUlpURu/kxkZba6vZaJR5P9roPRLkiGFQIMWCykI6lUBhSc75F4rK3Ezemq0c11QaJQT/P8L45kZMLp0++ym31jix1zhyb0rXIqPOmNHYk+buepNWfJpO5WY7Ohv6EbZuq8IMI77sKh8xxUv/NPJv3gAAeJxtkQdv2zAQhf3Fki3baeO6bbr3Hmqb7r1X+i9oipaJSKRAUR759WXtIECAHnDgew+Hd4OtjdY6+q3/xy4btImI6dAloUefAZsc4zhbDDnBiJOc4jTbnOEs5zjPBS5yictc4SrXuM4NbnKL29zhLve4zwMekvKIxzxhh6c84zkveMkrXvOGt7zjPR/4yCc+84WvfOM7P/jJL36zy5/WQOS5U7nw2pqOcM7O67aoZUcKI1WRrJ90J5ZT4fxQTpXcG9tFugIq2z4UtMmUV67URng1OpQbc1C5KW1hXVrpQFw3kKY0dV9a452QXmWRtNUyls7WdZSpWiZqUYngmfXUUqV1IeppO6DORBehTTzRrvZR7nQV5842VRQKfFSoie8U2oR+3cKKTJs8KcVCl3pfRaUyTRLmWzNjjRoY61NRFHausrgKBqpdaROHDAtXemb90AUTm44b761J7WSydVQwsdP51Ee1mKl+XQavNLNzcwD/jTNYw1VZssZhWh/OMPJOqaN3660kWymTNGa9B4Ich8KjsRjm1EgKpuwxZhE+P6OkoWLJhH1mrdZfDrCtIAAA\") format(\"woff\");\n font-weight: normal;\n font-style: normal; }\n\n.ag-icon {\n font-family: \"agGridMaterial\";\n font-size: 18px;\n line-height: 18px;\n font-style: normal;\n font-weight: normal;\n font-variant: normal;\n text-transform: none;\n /* Better Font Rendering =========== */\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale; }\n\n.ag-icon-aggregation:before {\n content: \"\\f101\"; }\n\n.ag-icon-arrows:before {\n content: \"\\f102\"; }\n\n.ag-icon-asc:before {\n content: \"\\f103\"; }\n\n.ag-icon-cancel:before {\n content: \"\\f104\"; }\n\n.ag-icon-chart:before {\n content: \"\\f105\"; }\n\n.ag-icon-color-picker:before {\n content: \"\\f109\"; }\n\n.ag-icon-columns:before {\n content: \"\\f10a\"; }\n\n.ag-icon-contracted:before {\n content: \"\\f10b\"; }\n\n.ag-icon-copy:before {\n content: \"\\f10c\"; }\n\n.ag-icon-cross:before {\n content: \"\\f10d\"; }\n\n.ag-icon-desc:before {\n content: \"\\f10e\"; }\n\n.ag-icon-expanded:before {\n content: \"\\f10f\"; }\n\n.ag-icon-eye-slash:before {\n content: \"\\f110\"; }\n\n.ag-icon-eye:before {\n content: \"\\f111\"; }\n\n.ag-icon-filter:before {\n content: \"\\f112\"; }\n\n.ag-icon-first:before {\n content: \"\\f113\"; }\n\n.ag-icon-grip:before {\n content: \"\\f114\"; }\n\n.ag-icon-group:before {\n content: \"\\f115\"; }\n\n.ag-icon-last:before {\n content: \"\\f116\"; }\n\n.ag-icon-left:before {\n content: \"\\f117\"; }\n\n.ag-icon-linked:before {\n content: \"\\f118\"; }\n\n.ag-icon-loading:before {\n content: \"\\f119\"; }\n\n.ag-icon-maximize:before {\n content: \"\\f11a\"; }\n\n.ag-icon-menu:before {\n content: \"\\f11b\"; }\n\n.ag-icon-minimize:before {\n content: \"\\f11c\"; }\n\n.ag-icon-next:before {\n content: \"\\f11d\"; }\n\n.ag-icon-none:before {\n content: \"\\f11e\"; }\n\n.ag-icon-not-allowed:before {\n content: \"\\f11f\"; }\n\n.ag-icon-paste:before {\n content: \"\\f120\"; }\n\n.ag-icon-pin:before {\n content: \"\\f121\"; }\n\n.ag-icon-pivot:before {\n content: \"\\f122\"; }\n\n.ag-icon-previous:before {\n content: \"\\f123\"; }\n\n.ag-icon-right:before {\n content: \"\\f126\"; }\n\n.ag-icon-save:before {\n content: \"\\f127\"; }\n\n.ag-icon-small-down:before {\n content: \"\\f128\"; }\n\n.ag-icon-small-left:before {\n content: \"\\f129\"; }\n\n.ag-icon-small-right:before {\n content: \"\\f12a\"; }\n\n.ag-icon-small-up:before {\n content: \"\\f12b\"; }\n\n.ag-icon-tick:before {\n content: \"\\f12c\"; }\n\n.ag-icon-tree-closed:before {\n content: \"\\f12d\"; }\n\n.ag-icon-tree-indeterminate:before {\n content: \"\\f12e\"; }\n\n.ag-icon-tree-open:before {\n content: \"\\f12f\"; }\n\n.ag-icon-unlinked:before {\n content: \"\\f130\"; }\n\n.ag-icon-row-drag:before {\n content: \"\\f114\"; }\n\n.ag-right-arrow:before {\n content: \"\\f117\"; }\n\n.ag-right-arrow:before {\n content: \"\\f126\"; }\n\n", ""]);
  46508. // Exports
  46509. module.exports = exports;
  46510. /***/ })
  46511. /******/ ])});;