|
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574357535763577357835793580358135823583358435853586358735883589359035913592359335943595359635973598359936003601360236033604360536063607360836093610361136123613361436153616361736183619362036213622362336243625362636273628362936303631363236333634363536363637363836393640364136423643364436453646364736483649365036513652365336543655365636573658365936603661366236633664366536663667366836693670367136723673367436753676367736783679368036813682368336843685368636873688368936903691369236933694369536963697369836993700370137023703370437053706370737083709371037113712371337143715371637173718371937203721372237233724372537263727372837293730373137323733373437353736373737383739374037413742374337443745374637473748374937503751375237533754375537563757375837593760376137623763376437653766376737683769377037713772377337743775377637773778377937803781378237833784378537863787378837893790379137923793379437953796379737983799380038013802380338043805380638073808380938103811381238133814381538163817381838193820382138223823382438253826382738283829383038313832383338343835383638373838383938403841384238433844384538463847384838493850385138523853385438553856385738583859386038613862386338643865386638673868386938703871387238733874387538763877387838793880388138823883388438853886388738883889389038913892389338943895389638973898389939003901390239033904390539063907390839093910391139123913391439153916391739183919392039213922392339243925392639273928392939303931393239333934393539363937393839393940394139423943394439453946394739483949395039513952395339543955395639573958395939603961396239633964396539663967396839693970397139723973397439753976397739783979398039813982398339843985398639873988398939903991399239933994399539963997399839994000400140024003400440054006400740084009401040114012401340144015401640174018401940204021402240234024402540264027402840294030403140324033403440354036403740384039404040414042404340444045404640474048404940504051405240534054405540564057405840594060406140624063406440654066406740684069407040714072407340744075407640774078407940804081408240834084408540864087408840894090409140924093409440954096409740984099410041014102410341044105410641074108410941104111411241134114411541164117411841194120412141224123412441254126412741284129413041314132413341344135413641374138413941404141414241434144414541464147414841494150415141524153415441554156415741584159416041614162416341644165416641674168416941704171417241734174417541764177417841794180418141824183418441854186418741884189419041914192419341944195419641974198419942004201420242034204420542064207420842094210421142124213421442154216421742184219422042214222422342244225422642274228422942304231423242334234423542364237423842394240424142424243424442454246424742484249425042514252425342544255425642574258425942604261426242634264426542664267426842694270427142724273427442754276427742784279428042814282428342844285428642874288428942904291429242934294429542964297429842994300430143024303430443054306430743084309431043114312431343144315431643174318431943204321432243234324432543264327432843294330433143324333433443354336433743384339434043414342434343444345434643474348434943504351435243534354435543564357435843594360436143624363436443654366436743684369437043714372437343744375437643774378437943804381438243834384438543864387438843894390439143924393439443954396439743984399440044014402440344044405440644074408440944104411441244134414441544164417441844194420442144224423442444254426442744284429443044314432443344344435443644374438443944404441444244434444444544464447444844494450445144524453445444554456445744584459446044614462446344644465446644674468446944704471447244734474447544764477447844794480448144824483448444854486448744884489449044914492449344944495449644974498449945004501450245034504450545064507450845094510451145124513451445154516451745184519452045214522452345244525452645274528452945304531453245334534453545364537453845394540454145424543454445454546454745484549455045514552455345544555455645574558455945604561456245634564456545664567456845694570457145724573457445754576457745784579458045814582458345844585458645874588458945904591459245934594459545964597459845994600460146024603460446054606460746084609461046114612461346144615461646174618461946204621462246234624462546264627462846294630463146324633463446354636463746384639464046414642464346444645464646474648464946504651465246534654465546564657465846594660466146624663466446654666466746684669467046714672467346744675467646774678467946804681468246834684468546864687468846894690469146924693469446954696469746984699470047014702470347044705470647074708470947104711471247134714471547164717471847194720472147224723472447254726472747284729473047314732473347344735473647374738473947404741474247434744474547464747474847494750475147524753475447554756475747584759476047614762476347644765476647674768476947704771477247734774477547764777477847794780478147824783478447854786478747884789479047914792479347944795479647974798479948004801480248034804480548064807480848094810481148124813481448154816481748184819482048214822482348244825482648274828482948304831483248334834483548364837483848394840484148424843484448454846484748484849485048514852485348544855485648574858485948604861486248634864486548664867486848694870487148724873487448754876487748784879488048814882488348844885488648874888488948904891489248934894489548964897489848994900490149024903490449054906490749084909491049114912491349144915491649174918491949204921492249234924492549264927492849294930493149324933493449354936493749384939494049414942494349444945494649474948494949504951495249534954495549564957495849594960496149624963496449654966496749684969497049714972497349744975497649774978497949804981498249834984498549864987498849894990499149924993499449954996499749984999500050015002500350045005500650075008500950105011501250135014501550165017501850195020502150225023502450255026502750285029503050315032503350345035503650375038503950405041504250435044504550465047504850495050505150525053505450555056505750585059506050615062506350645065506650675068506950705071507250735074507550765077507850795080508150825083508450855086508750885089509050915092509350945095509650975098509951005101510251035104510551065107510851095110511151125113511451155116511751185119512051215122512351245125512651275128512951305131513251335134513551365137513851395140514151425143514451455146514751485149515051515152515351545155515651575158515951605161516251635164516551665167516851695170517151725173517451755176517751785179518051815182518351845185518651875188518951905191519251935194519551965197519851995200520152025203520452055206520752085209521052115212521352145215521652175218521952205221522252235224522552265227522852295230523152325233523452355236523752385239524052415242524352445245524652475248524952505251525252535254525552565257525852595260526152625263526452655266526752685269527052715272527352745275527652775278527952805281528252835284528552865287528852895290529152925293529452955296529752985299530053015302530353045305530653075308530953105311531253135314531553165317531853195320532153225323532453255326532753285329533053315332533353345335533653375338533953405341534253435344534553465347534853495350535153525353535453555356535753585359536053615362536353645365536653675368536953705371537253735374537553765377537853795380538153825383538453855386538753885389539053915392539353945395539653975398539954005401540254035404540554065407540854095410541154125413541454155416541754185419542054215422542354245425542654275428542954305431543254335434543554365437543854395440544154425443544454455446544754485449545054515452545354545455545654575458545954605461546254635464546554665467546854695470547154725473547454755476547754785479548054815482548354845485548654875488548954905491549254935494549554965497549854995500550155025503550455055506550755085509551055115512551355145515551655175518551955205521552255235524552555265527552855295530553155325533553455355536553755385539554055415542554355445545554655475548554955505551555255535554555555565557555855595560556155625563556455655566556755685569557055715572557355745575557655775578557955805581558255835584558555865587558855895590559155925593559455955596559755985599560056015602560356045605560656075608560956105611561256135614561556165617561856195620562156225623562456255626562756285629563056315632563356345635563656375638563956405641564256435644564556465647564856495650565156525653565456555656565756585659566056615662566356645665566656675668566956705671567256735674567556765677567856795680568156825683568456855686568756885689569056915692569356945695569656975698569957005701570257035704570557065707570857095710571157125713571457155716571757185719572057215722572357245725572657275728572957305731573257335734573557365737573857395740574157425743574457455746574757485749575057515752575357545755575657575758575957605761576257635764576557665767576857695770577157725773577457755776577757785779578057815782578357845785578657875788578957905791579257935794579557965797579857995800580158025803580458055806580758085809581058115812581358145815581658175818581958205821582258235824582558265827582858295830583158325833583458355836583758385839584058415842584358445845584658475848584958505851585258535854585558565857585858595860586158625863586458655866586758685869587058715872587358745875587658775878587958805881588258835884588558865887588858895890589158925893589458955896589758985899590059015902590359045905590659075908590959105911591259135914591559165917591859195920592159225923592459255926592759285929593059315932593359345935593659375938593959405941594259435944594559465947594859495950595159525953595459555956595759585959596059615962596359645965596659675968596959705971597259735974597559765977597859795980598159825983 |
- 'use strict';
-
- function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; }
-
- var Sortable = _interopDefault(require('sortablejs'));
-
- function $(expr, con) {
- return typeof expr === 'string' ?
- (con || document).querySelector(expr) :
- expr || null;
- }
-
- $.each = (expr, con) => {
- return typeof expr === 'string' ?
- Array.from((con || document).querySelectorAll(expr)) :
- expr || null;
- };
-
- $.create = (tag, o) => {
- let element = document.createElement(tag);
-
- for (let i in o) {
- let val = o[i];
-
- if (i === 'inside') {
- $(val).appendChild(element);
- } else
- if (i === 'around') {
- let ref = $(val);
- ref.parentNode.insertBefore(element, ref);
- element.appendChild(ref);
- } else
- if (i === 'styles') {
- if (typeof val === 'object') {
- Object.keys(val).map(prop => {
- element.style[prop] = val[prop];
- });
- }
- } else
- if (i in element) {
- element[i] = val;
- } else {
- element.setAttribute(i, val);
- }
- }
-
- return element;
- };
-
- $.on = (element, event, selector, callback) => {
- if (!callback) {
- callback = selector;
- $.bind(element, event, callback);
- } else {
- $.delegate(element, event, selector, callback);
- }
- };
-
- $.off = (element, event, handler) => {
- element.removeEventListener(event, handler);
- };
-
- $.bind = (element, event, callback) => {
- event.split(/\s+/).forEach(function (event) {
- element.addEventListener(event, callback);
- });
- };
-
- $.delegate = (element, event, selector, callback) => {
- element.addEventListener(event, function (e) {
- const delegatedTarget = e.target.closest(selector);
- if (delegatedTarget) {
- e.delegatedTarget = delegatedTarget;
- callback.call(this, e, delegatedTarget);
- }
- });
- };
-
- $.unbind = (element, o) => {
- if (element) {
- for (let event in o) {
- let callback = o[event];
-
- event.split(/\s+/).forEach(function (event) {
- element.removeEventListener(event, callback);
- });
- }
- }
- };
-
- $.fire = (target, type, properties) => {
- let evt = document.createEvent('HTMLEvents');
-
- evt.initEvent(type, true, true);
-
- for (let j in properties) {
- evt[j] = properties[j];
- }
-
- return target.dispatchEvent(evt);
- };
-
- $.data = (element, attrs) => { // eslint-disable-line
- if (!attrs) {
- return element.dataset;
- }
-
- for (const attr in attrs) {
- element.dataset[attr] = attrs[attr];
- }
- };
-
- $.style = (elements, styleMap) => { // eslint-disable-line
-
- if (typeof styleMap === 'string') {
- return $.getStyle(elements, styleMap);
- }
-
- if (!Array.isArray(elements)) {
- elements = [elements];
- }
-
- elements.map(element => {
- for (const prop in styleMap) {
- element.style[prop] = styleMap[prop];
- }
- });
- };
-
- $.removeStyle = (elements, styleProps) => {
- if (!Array.isArray(elements)) {
- elements = [elements];
- }
-
- if (!Array.isArray(styleProps)) {
- styleProps = [styleProps];
- }
-
- elements.map(element => {
- for (const prop of styleProps) {
- element.style[prop] = '';
- }
- });
- };
-
- $.getStyle = (element, prop) => {
- if (!prop) {
- return getComputedStyle(element);
- }
-
- let val = getComputedStyle(element)[prop];
-
- if (['width', 'height'].includes(prop)) {
- val = parseFloat(val);
- }
-
- return val;
- };
-
- $.closest = (selector, element) => {
- if (!element) return null;
-
- if (element.matches(selector)) {
- return element;
- }
-
- return $.closest(selector, element.parentNode);
- };
-
- $.inViewport = (el, parentEl) => {
- const {
- top,
- left,
- bottom,
- right
- } = el.getBoundingClientRect();
- const {
- top: pTop,
- left: pLeft,
- bottom: pBottom,
- right: pRight
- } = parentEl.getBoundingClientRect();
-
- return top >= pTop && left >= pLeft && bottom <= pBottom && right <= pRight;
- };
-
- $.scrollTop = function scrollTop(element, pixels) {
- requestAnimationFrame(() => {
- element.scrollTop = pixels;
- });
- };
-
- $.scrollbarSize = function scrollbarSize() {
- if (!$.scrollBarSizeValue) {
- $.scrollBarSizeValue = getScrollBarSize();
- }
- return $.scrollBarSizeValue;
- };
-
- function getScrollBarSize() {
- // assume scrollbar width and height would be the same
-
- // Create the measurement node
- const scrollDiv = document.createElement('div');
- $.style(scrollDiv, {
- width: '100px',
- height: '100px',
- overflow: 'scroll',
- position: 'absolute',
- top: '-9999px'
- });
- document.body.appendChild(scrollDiv);
-
- // Get the scrollbar width
- const scrollbarWidth = scrollDiv.offsetWidth - scrollDiv.clientWidth;
-
- // Delete the DIV
- document.body.removeChild(scrollDiv);
-
- return scrollbarWidth;
- }
-
- $.hasVerticalOverflow = function (element) {
- return element.scrollHeight > element.offsetHeight + 10;
- };
-
- $.hasHorizontalOverflow = function (element) {
- return element.scrollWidth > element.offsetWidth + 10;
- };
-
- $.measureTextWidth = function (text) {
- const div = document.createElement('div');
- div.style.position = 'absolute';
- div.style.visibility = 'hidden';
- div.style.height = 'auto';
- div.style.width = 'auto';
- div.style.whiteSpace = 'nowrap';
- div.innerText = text;
- document.body.appendChild(div);
- return div.clientWidth + 1;
- };
-
- /**
- * Checks if `value` is the
- * [language type](http://www.ecma-international.org/ecma-262/7.0/#sec-ecmascript-language-types)
- * of `Object`. (e.g. arrays, functions, objects, regexes, `new Number(0)`, and `new String('')`)
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is an object, else `false`.
- * @example
- *
- * _.isObject({});
- * // => true
- *
- * _.isObject([1, 2, 3]);
- * // => true
- *
- * _.isObject(_.noop);
- * // => true
- *
- * _.isObject(null);
- * // => false
- */
- function isObject(value) {
- var type = typeof value;
- return value != null && (type == 'object' || type == 'function');
- }
-
- var isObject_1 = isObject;
-
- var commonjsGlobal = typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {};
-
- function commonjsRequire () {
- throw new Error('Dynamic requires are not currently supported by rollup-plugin-commonjs');
- }
-
- function unwrapExports (x) {
- return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, 'default') ? x['default'] : x;
- }
-
- function createCommonjsModule(fn, module) {
- return module = { exports: {} }, fn(module, module.exports), module.exports;
- }
-
- /** Detect free variable `global` from Node.js. */
- var freeGlobal = typeof commonjsGlobal == 'object' && commonjsGlobal && commonjsGlobal.Object === Object && commonjsGlobal;
-
- var _freeGlobal = freeGlobal;
-
- /** Detect free variable `self`. */
- var freeSelf = typeof self == 'object' && self && self.Object === Object && self;
-
- /** Used as a reference to the global object. */
- var root = _freeGlobal || freeSelf || Function('return this')();
-
- var _root = root;
-
- /**
- * Gets the timestamp of the number of milliseconds that have elapsed since
- * the Unix epoch (1 January 1970 00:00:00 UTC).
- *
- * @static
- * @memberOf _
- * @since 2.4.0
- * @category Date
- * @returns {number} Returns the timestamp.
- * @example
- *
- * _.defer(function(stamp) {
- * console.log(_.now() - stamp);
- * }, _.now());
- * // => Logs the number of milliseconds it took for the deferred invocation.
- */
- var now = function() {
- return _root.Date.now();
- };
-
- var now_1 = now;
-
- /** Used to match a single whitespace character. */
- var reWhitespace = /\s/;
-
- /**
- * Used by `_.trim` and `_.trimEnd` to get the index of the last non-whitespace
- * character of `string`.
- *
- * @private
- * @param {string} string The string to inspect.
- * @returns {number} Returns the index of the last non-whitespace character.
- */
- function trimmedEndIndex(string) {
- var index = string.length;
-
- while (index-- && reWhitespace.test(string.charAt(index))) {}
- return index;
- }
-
- var _trimmedEndIndex = trimmedEndIndex;
-
- /** Used to match leading whitespace. */
- var reTrimStart = /^\s+/;
-
- /**
- * The base implementation of `_.trim`.
- *
- * @private
- * @param {string} string The string to trim.
- * @returns {string} Returns the trimmed string.
- */
- function baseTrim(string) {
- return string
- ? string.slice(0, _trimmedEndIndex(string) + 1).replace(reTrimStart, '')
- : string;
- }
-
- var _baseTrim = baseTrim;
-
- /** Built-in value references. */
- var Symbol = _root.Symbol;
-
- var _Symbol = Symbol;
-
- /** Used for built-in method references. */
- var objectProto = Object.prototype;
-
- /** Used to check objects for own properties. */
- var hasOwnProperty = objectProto.hasOwnProperty;
-
- /**
- * Used to resolve the
- * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)
- * of values.
- */
- var nativeObjectToString = objectProto.toString;
-
- /** Built-in value references. */
- var symToStringTag = _Symbol ? _Symbol.toStringTag : undefined;
-
- /**
- * A specialized version of `baseGetTag` which ignores `Symbol.toStringTag` values.
- *
- * @private
- * @param {*} value The value to query.
- * @returns {string} Returns the raw `toStringTag`.
- */
- function getRawTag(value) {
- var isOwn = hasOwnProperty.call(value, symToStringTag),
- tag = value[symToStringTag];
-
- try {
- value[symToStringTag] = undefined;
- } catch (e) {}
-
- var result = nativeObjectToString.call(value);
- {
- if (isOwn) {
- value[symToStringTag] = tag;
- } else {
- delete value[symToStringTag];
- }
- }
- return result;
- }
-
- var _getRawTag = getRawTag;
-
- /** Used for built-in method references. */
- var objectProto$1 = Object.prototype;
-
- /**
- * Used to resolve the
- * [`toStringTag`](http://ecma-international.org/ecma-262/7.0/#sec-object.prototype.tostring)
- * of values.
- */
- var nativeObjectToString$1 = objectProto$1.toString;
-
- /**
- * Converts `value` to a string using `Object.prototype.toString`.
- *
- * @private
- * @param {*} value The value to convert.
- * @returns {string} Returns the converted string.
- */
- function objectToString(value) {
- return nativeObjectToString$1.call(value);
- }
-
- var _objectToString = objectToString;
-
- /** `Object#toString` result references. */
- var nullTag = '[object Null]',
- undefinedTag = '[object Undefined]';
-
- /** Built-in value references. */
- var symToStringTag$1 = _Symbol ? _Symbol.toStringTag : undefined;
-
- /**
- * The base implementation of `getTag` without fallbacks for buggy environments.
- *
- * @private
- * @param {*} value The value to query.
- * @returns {string} Returns the `toStringTag`.
- */
- function baseGetTag(value) {
- if (value == null) {
- return value === undefined ? undefinedTag : nullTag;
- }
- return (symToStringTag$1 && symToStringTag$1 in Object(value))
- ? _getRawTag(value)
- : _objectToString(value);
- }
-
- var _baseGetTag = baseGetTag;
-
- /**
- * Checks if `value` is object-like. A value is object-like if it's not `null`
- * and has a `typeof` result of "object".
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is object-like, else `false`.
- * @example
- *
- * _.isObjectLike({});
- * // => true
- *
- * _.isObjectLike([1, 2, 3]);
- * // => true
- *
- * _.isObjectLike(_.noop);
- * // => false
- *
- * _.isObjectLike(null);
- * // => false
- */
- function isObjectLike(value) {
- return value != null && typeof value == 'object';
- }
-
- var isObjectLike_1 = isObjectLike;
-
- /** `Object#toString` result references. */
- var symbolTag = '[object Symbol]';
-
- /**
- * Checks if `value` is classified as a `Symbol` primitive or object.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a symbol, else `false`.
- * @example
- *
- * _.isSymbol(Symbol.iterator);
- * // => true
- *
- * _.isSymbol('abc');
- * // => false
- */
- function isSymbol(value) {
- return typeof value == 'symbol' ||
- (isObjectLike_1(value) && _baseGetTag(value) == symbolTag);
- }
-
- var isSymbol_1 = isSymbol;
-
- /** Used as references for various `Number` constants. */
- var NAN = 0 / 0;
-
- /** Used to detect bad signed hexadecimal string values. */
- var reIsBadHex = /^[-+]0x[0-9a-f]+$/i;
-
- /** Used to detect binary string values. */
- var reIsBinary = /^0b[01]+$/i;
-
- /** Used to detect octal string values. */
- var reIsOctal = /^0o[0-7]+$/i;
-
- /** Built-in method references without a dependency on `root`. */
- var freeParseInt = parseInt;
-
- /**
- * Converts `value` to a number.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to process.
- * @returns {number} Returns the number.
- * @example
- *
- * _.toNumber(3.2);
- * // => 3.2
- *
- * _.toNumber(Number.MIN_VALUE);
- * // => 5e-324
- *
- * _.toNumber(Infinity);
- * // => Infinity
- *
- * _.toNumber('3.2');
- * // => 3.2
- */
- function toNumber(value) {
- if (typeof value == 'number') {
- return value;
- }
- if (isSymbol_1(value)) {
- return NAN;
- }
- if (isObject_1(value)) {
- var other = typeof value.valueOf == 'function' ? value.valueOf() : value;
- value = isObject_1(other) ? (other + '') : other;
- }
- if (typeof value != 'string') {
- return value === 0 ? value : +value;
- }
- value = _baseTrim(value);
- var isBinary = reIsBinary.test(value);
- return (isBinary || reIsOctal.test(value))
- ? freeParseInt(value.slice(2), isBinary ? 2 : 8)
- : (reIsBadHex.test(value) ? NAN : +value);
- }
-
- var toNumber_1 = toNumber;
-
- /** Error message constants. */
- var FUNC_ERROR_TEXT = 'Expected a function';
-
- /* Built-in method references for those with the same name as other `lodash` methods. */
- var nativeMax = Math.max,
- nativeMin = Math.min;
-
- /**
- * Creates a debounced function that delays invoking `func` until after `wait`
- * milliseconds have elapsed since the last time the debounced function was
- * invoked. The debounced function comes with a `cancel` method to cancel
- * delayed `func` invocations and a `flush` method to immediately invoke them.
- * Provide `options` to indicate whether `func` should be invoked on the
- * leading and/or trailing edge of the `wait` timeout. The `func` is invoked
- * with the last arguments provided to the debounced function. Subsequent
- * calls to the debounced function return the result of the last `func`
- * invocation.
- *
- * **Note:** If `leading` and `trailing` options are `true`, `func` is
- * invoked on the trailing edge of the timeout only if the debounced function
- * is invoked more than once during the `wait` timeout.
- *
- * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred
- * until to the next tick, similar to `setTimeout` with a timeout of `0`.
- *
- * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)
- * for details over the differences between `_.debounce` and `_.throttle`.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Function
- * @param {Function} func The function to debounce.
- * @param {number} [wait=0] The number of milliseconds to delay.
- * @param {Object} [options={}] The options object.
- * @param {boolean} [options.leading=false]
- * Specify invoking on the leading edge of the timeout.
- * @param {number} [options.maxWait]
- * The maximum time `func` is allowed to be delayed before it's invoked.
- * @param {boolean} [options.trailing=true]
- * Specify invoking on the trailing edge of the timeout.
- * @returns {Function} Returns the new debounced function.
- * @example
- *
- * // Avoid costly calculations while the window size is in flux.
- * jQuery(window).on('resize', _.debounce(calculateLayout, 150));
- *
- * // Invoke `sendMail` when clicked, debouncing subsequent calls.
- * jQuery(element).on('click', _.debounce(sendMail, 300, {
- * 'leading': true,
- * 'trailing': false
- * }));
- *
- * // Ensure `batchLog` is invoked once after 1 second of debounced calls.
- * var debounced = _.debounce(batchLog, 250, { 'maxWait': 1000 });
- * var source = new EventSource('/stream');
- * jQuery(source).on('message', debounced);
- *
- * // Cancel the trailing debounced invocation.
- * jQuery(window).on('popstate', debounced.cancel);
- */
- function debounce(func, wait, options) {
- var lastArgs,
- lastThis,
- maxWait,
- result,
- timerId,
- lastCallTime,
- lastInvokeTime = 0,
- leading = false,
- maxing = false,
- trailing = true;
-
- if (typeof func != 'function') {
- throw new TypeError(FUNC_ERROR_TEXT);
- }
- wait = toNumber_1(wait) || 0;
- if (isObject_1(options)) {
- leading = !!options.leading;
- maxing = 'maxWait' in options;
- maxWait = maxing ? nativeMax(toNumber_1(options.maxWait) || 0, wait) : maxWait;
- trailing = 'trailing' in options ? !!options.trailing : trailing;
- }
-
- function invokeFunc(time) {
- var args = lastArgs,
- thisArg = lastThis;
-
- lastArgs = lastThis = undefined;
- lastInvokeTime = time;
- result = func.apply(thisArg, args);
- return result;
- }
-
- function leadingEdge(time) {
- // Reset any `maxWait` timer.
- lastInvokeTime = time;
- // Start the timer for the trailing edge.
- timerId = setTimeout(timerExpired, wait);
- // Invoke the leading edge.
- return leading ? invokeFunc(time) : result;
- }
-
- function remainingWait(time) {
- var timeSinceLastCall = time - lastCallTime,
- timeSinceLastInvoke = time - lastInvokeTime,
- timeWaiting = wait - timeSinceLastCall;
-
- return maxing
- ? nativeMin(timeWaiting, maxWait - timeSinceLastInvoke)
- : timeWaiting;
- }
-
- function shouldInvoke(time) {
- var timeSinceLastCall = time - lastCallTime,
- timeSinceLastInvoke = time - lastInvokeTime;
-
- // Either this is the first call, activity has stopped and we're at the
- // trailing edge, the system time has gone backwards and we're treating
- // it as the trailing edge, or we've hit the `maxWait` limit.
- return (lastCallTime === undefined || (timeSinceLastCall >= wait) ||
- (timeSinceLastCall < 0) || (maxing && timeSinceLastInvoke >= maxWait));
- }
-
- function timerExpired() {
- var time = now_1();
- if (shouldInvoke(time)) {
- return trailingEdge(time);
- }
- // Restart the timer.
- timerId = setTimeout(timerExpired, remainingWait(time));
- }
-
- function trailingEdge(time) {
- timerId = undefined;
-
- // Only invoke if we have `lastArgs` which means `func` has been
- // debounced at least once.
- if (trailing && lastArgs) {
- return invokeFunc(time);
- }
- lastArgs = lastThis = undefined;
- return result;
- }
-
- function cancel() {
- if (timerId !== undefined) {
- clearTimeout(timerId);
- }
- lastInvokeTime = 0;
- lastArgs = lastCallTime = lastThis = timerId = undefined;
- }
-
- function flush() {
- return timerId === undefined ? result : trailingEdge(now_1());
- }
-
- function debounced() {
- var time = now_1(),
- isInvoking = shouldInvoke(time);
-
- lastArgs = arguments;
- lastThis = this;
- lastCallTime = time;
-
- if (isInvoking) {
- if (timerId === undefined) {
- return leadingEdge(lastCallTime);
- }
- if (maxing) {
- // Handle invocations in a tight loop.
- clearTimeout(timerId);
- timerId = setTimeout(timerExpired, wait);
- return invokeFunc(lastCallTime);
- }
- }
- if (timerId === undefined) {
- timerId = setTimeout(timerExpired, wait);
- }
- return result;
- }
- debounced.cancel = cancel;
- debounced.flush = flush;
- return debounced;
- }
-
- var debounce_1 = debounce;
-
- /** Error message constants. */
- var FUNC_ERROR_TEXT$1 = 'Expected a function';
-
- /**
- * Creates a throttled function that only invokes `func` at most once per
- * every `wait` milliseconds. The throttled function comes with a `cancel`
- * method to cancel delayed `func` invocations and a `flush` method to
- * immediately invoke them. Provide `options` to indicate whether `func`
- * should be invoked on the leading and/or trailing edge of the `wait`
- * timeout. The `func` is invoked with the last arguments provided to the
- * throttled function. Subsequent calls to the throttled function return the
- * result of the last `func` invocation.
- *
- * **Note:** If `leading` and `trailing` options are `true`, `func` is
- * invoked on the trailing edge of the timeout only if the throttled function
- * is invoked more than once during the `wait` timeout.
- *
- * If `wait` is `0` and `leading` is `false`, `func` invocation is deferred
- * until to the next tick, similar to `setTimeout` with a timeout of `0`.
- *
- * See [David Corbacho's article](https://css-tricks.com/debouncing-throttling-explained-examples/)
- * for details over the differences between `_.throttle` and `_.debounce`.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Function
- * @param {Function} func The function to throttle.
- * @param {number} [wait=0] The number of milliseconds to throttle invocations to.
- * @param {Object} [options={}] The options object.
- * @param {boolean} [options.leading=true]
- * Specify invoking on the leading edge of the timeout.
- * @param {boolean} [options.trailing=true]
- * Specify invoking on the trailing edge of the timeout.
- * @returns {Function} Returns the new throttled function.
- * @example
- *
- * // Avoid excessively updating the position while scrolling.
- * jQuery(window).on('scroll', _.throttle(updatePosition, 100));
- *
- * // Invoke `renewToken` when the click event is fired, but not more than once every 5 minutes.
- * var throttled = _.throttle(renewToken, 300000, { 'trailing': false });
- * jQuery(element).on('click', throttled);
- *
- * // Cancel the trailing throttled invocation.
- * jQuery(window).on('popstate', throttled.cancel);
- */
- function throttle(func, wait, options) {
- var leading = true,
- trailing = true;
-
- if (typeof func != 'function') {
- throw new TypeError(FUNC_ERROR_TEXT$1);
- }
- if (isObject_1(options)) {
- leading = 'leading' in options ? !!options.leading : leading;
- trailing = 'trailing' in options ? !!options.trailing : trailing;
- }
- return debounce_1(func, wait, {
- 'leading': leading,
- 'maxWait': wait,
- 'trailing': trailing
- });
- }
-
- var throttle_1 = throttle;
-
- /** `Object#toString` result references. */
- var asyncTag = '[object AsyncFunction]',
- funcTag = '[object Function]',
- genTag = '[object GeneratorFunction]',
- proxyTag = '[object Proxy]';
-
- /**
- * Checks if `value` is classified as a `Function` object.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Lang
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a function, else `false`.
- * @example
- *
- * _.isFunction(_);
- * // => true
- *
- * _.isFunction(/abc/);
- * // => false
- */
- function isFunction(value) {
- if (!isObject_1(value)) {
- return false;
- }
- // The use of `Object#toString` avoids issues with the `typeof` operator
- // in Safari 9 which returns 'object' for typed arrays and other constructors.
- var tag = _baseGetTag(value);
- return tag == funcTag || tag == genTag || tag == asyncTag || tag == proxyTag;
- }
-
- var isFunction_1 = isFunction;
-
- /** Used to detect overreaching core-js shims. */
- var coreJsData = _root['__core-js_shared__'];
-
- var _coreJsData = coreJsData;
-
- /** Used to detect methods masquerading as native. */
- var maskSrcKey = (function() {
- var uid = /[^.]+$/.exec(_coreJsData && _coreJsData.keys && _coreJsData.keys.IE_PROTO || '');
- return uid ? ('Symbol(src)_1.' + uid) : '';
- }());
-
- /**
- * Checks if `func` has its source masked.
- *
- * @private
- * @param {Function} func The function to check.
- * @returns {boolean} Returns `true` if `func` is masked, else `false`.
- */
- function isMasked(func) {
- return !!maskSrcKey && (maskSrcKey in func);
- }
-
- var _isMasked = isMasked;
-
- /** Used for built-in method references. */
- var funcProto = Function.prototype;
-
- /** Used to resolve the decompiled source of functions. */
- var funcToString = funcProto.toString;
-
- /**
- * Converts `func` to its source code.
- *
- * @private
- * @param {Function} func The function to convert.
- * @returns {string} Returns the source code.
- */
- function toSource(func) {
- if (func != null) {
- try {
- return funcToString.call(func);
- } catch (e) {}
- try {
- return (func + '');
- } catch (e) {}
- }
- return '';
- }
-
- var _toSource = toSource;
-
- /**
- * Used to match `RegExp`
- * [syntax characters](http://ecma-international.org/ecma-262/7.0/#sec-patterns).
- */
- var reRegExpChar = /[\\^$.*+?()[\]{}|]/g;
-
- /** Used to detect host constructors (Safari). */
- var reIsHostCtor = /^\[object .+?Constructor\]$/;
-
- /** Used for built-in method references. */
- var funcProto$1 = Function.prototype,
- objectProto$2 = Object.prototype;
-
- /** Used to resolve the decompiled source of functions. */
- var funcToString$1 = funcProto$1.toString;
-
- /** Used to check objects for own properties. */
- var hasOwnProperty$1 = objectProto$2.hasOwnProperty;
-
- /** Used to detect if a method is native. */
- var reIsNative = RegExp('^' +
- funcToString$1.call(hasOwnProperty$1).replace(reRegExpChar, '\\$&')
- .replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g, '$1.*?') + '$'
- );
-
- /**
- * The base implementation of `_.isNative` without bad shim checks.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is a native function,
- * else `false`.
- */
- function baseIsNative(value) {
- if (!isObject_1(value) || _isMasked(value)) {
- return false;
- }
- var pattern = isFunction_1(value) ? reIsNative : reIsHostCtor;
- return pattern.test(_toSource(value));
- }
-
- var _baseIsNative = baseIsNative;
-
- /**
- * Gets the value at `key` of `object`.
- *
- * @private
- * @param {Object} [object] The object to query.
- * @param {string} key The key of the property to get.
- * @returns {*} Returns the property value.
- */
- function getValue(object, key) {
- return object == null ? undefined : object[key];
- }
-
- var _getValue = getValue;
-
- /**
- * Gets the native function at `key` of `object`.
- *
- * @private
- * @param {Object} object The object to query.
- * @param {string} key The key of the method to get.
- * @returns {*} Returns the function if it's native, else `undefined`.
- */
- function getNative(object, key) {
- var value = _getValue(object, key);
- return _baseIsNative(value) ? value : undefined;
- }
-
- var _getNative = getNative;
-
- /* Built-in method references that are verified to be native. */
- var nativeCreate = _getNative(Object, 'create');
-
- var _nativeCreate = nativeCreate;
-
- /**
- * Removes all key-value entries from the hash.
- *
- * @private
- * @name clear
- * @memberOf Hash
- */
- function hashClear() {
- this.__data__ = _nativeCreate ? _nativeCreate(null) : {};
- this.size = 0;
- }
-
- var _hashClear = hashClear;
-
- /**
- * Removes `key` and its value from the hash.
- *
- * @private
- * @name delete
- * @memberOf Hash
- * @param {Object} hash The hash to modify.
- * @param {string} key The key of the value to remove.
- * @returns {boolean} Returns `true` if the entry was removed, else `false`.
- */
- function hashDelete(key) {
- var result = this.has(key) && delete this.__data__[key];
- this.size -= result ? 1 : 0;
- return result;
- }
-
- var _hashDelete = hashDelete;
-
- /** Used to stand-in for `undefined` hash values. */
- var HASH_UNDEFINED = '__lodash_hash_undefined__';
-
- /** Used for built-in method references. */
- var objectProto$3 = Object.prototype;
-
- /** Used to check objects for own properties. */
- var hasOwnProperty$2 = objectProto$3.hasOwnProperty;
-
- /**
- * Gets the hash value for `key`.
- *
- * @private
- * @name get
- * @memberOf Hash
- * @param {string} key The key of the value to get.
- * @returns {*} Returns the entry value.
- */
- function hashGet(key) {
- var data = this.__data__;
- if (_nativeCreate) {
- var result = data[key];
- return result === HASH_UNDEFINED ? undefined : result;
- }
- return hasOwnProperty$2.call(data, key) ? data[key] : undefined;
- }
-
- var _hashGet = hashGet;
-
- /** Used for built-in method references. */
- var objectProto$4 = Object.prototype;
-
- /** Used to check objects for own properties. */
- var hasOwnProperty$3 = objectProto$4.hasOwnProperty;
-
- /**
- * Checks if a hash value for `key` exists.
- *
- * @private
- * @name has
- * @memberOf Hash
- * @param {string} key The key of the entry to check.
- * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
- */
- function hashHas(key) {
- var data = this.__data__;
- return _nativeCreate ? (data[key] !== undefined) : hasOwnProperty$3.call(data, key);
- }
-
- var _hashHas = hashHas;
-
- /** Used to stand-in for `undefined` hash values. */
- var HASH_UNDEFINED$1 = '__lodash_hash_undefined__';
-
- /**
- * Sets the hash `key` to `value`.
- *
- * @private
- * @name set
- * @memberOf Hash
- * @param {string} key The key of the value to set.
- * @param {*} value The value to set.
- * @returns {Object} Returns the hash instance.
- */
- function hashSet(key, value) {
- var data = this.__data__;
- this.size += this.has(key) ? 0 : 1;
- data[key] = (_nativeCreate && value === undefined) ? HASH_UNDEFINED$1 : value;
- return this;
- }
-
- var _hashSet = hashSet;
-
- /**
- * Creates a hash object.
- *
- * @private
- * @constructor
- * @param {Array} [entries] The key-value pairs to cache.
- */
- function Hash(entries) {
- var index = -1,
- length = entries == null ? 0 : entries.length;
-
- this.clear();
- while (++index < length) {
- var entry = entries[index];
- this.set(entry[0], entry[1]);
- }
- }
-
- // Add methods to `Hash`.
- Hash.prototype.clear = _hashClear;
- Hash.prototype['delete'] = _hashDelete;
- Hash.prototype.get = _hashGet;
- Hash.prototype.has = _hashHas;
- Hash.prototype.set = _hashSet;
-
- var _Hash = Hash;
-
- /**
- * Removes all key-value entries from the list cache.
- *
- * @private
- * @name clear
- * @memberOf ListCache
- */
- function listCacheClear() {
- this.__data__ = [];
- this.size = 0;
- }
-
- var _listCacheClear = listCacheClear;
-
- /**
- * Performs a
- * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
- * comparison between two values to determine if they are equivalent.
- *
- * @static
- * @memberOf _
- * @since 4.0.0
- * @category Lang
- * @param {*} value The value to compare.
- * @param {*} other The other value to compare.
- * @returns {boolean} Returns `true` if the values are equivalent, else `false`.
- * @example
- *
- * var object = { 'a': 1 };
- * var other = { 'a': 1 };
- *
- * _.eq(object, object);
- * // => true
- *
- * _.eq(object, other);
- * // => false
- *
- * _.eq('a', 'a');
- * // => true
- *
- * _.eq('a', Object('a'));
- * // => false
- *
- * _.eq(NaN, NaN);
- * // => true
- */
- function eq(value, other) {
- return value === other || (value !== value && other !== other);
- }
-
- var eq_1 = eq;
-
- /**
- * Gets the index at which the `key` is found in `array` of key-value pairs.
- *
- * @private
- * @param {Array} array The array to inspect.
- * @param {*} key The key to search for.
- * @returns {number} Returns the index of the matched value, else `-1`.
- */
- function assocIndexOf(array, key) {
- var length = array.length;
- while (length--) {
- if (eq_1(array[length][0], key)) {
- return length;
- }
- }
- return -1;
- }
-
- var _assocIndexOf = assocIndexOf;
-
- /** Used for built-in method references. */
- var arrayProto = Array.prototype;
-
- /** Built-in value references. */
- var splice = arrayProto.splice;
-
- /**
- * Removes `key` and its value from the list cache.
- *
- * @private
- * @name delete
- * @memberOf ListCache
- * @param {string} key The key of the value to remove.
- * @returns {boolean} Returns `true` if the entry was removed, else `false`.
- */
- function listCacheDelete(key) {
- var data = this.__data__,
- index = _assocIndexOf(data, key);
-
- if (index < 0) {
- return false;
- }
- var lastIndex = data.length - 1;
- if (index == lastIndex) {
- data.pop();
- } else {
- splice.call(data, index, 1);
- }
- --this.size;
- return true;
- }
-
- var _listCacheDelete = listCacheDelete;
-
- /**
- * Gets the list cache value for `key`.
- *
- * @private
- * @name get
- * @memberOf ListCache
- * @param {string} key The key of the value to get.
- * @returns {*} Returns the entry value.
- */
- function listCacheGet(key) {
- var data = this.__data__,
- index = _assocIndexOf(data, key);
-
- return index < 0 ? undefined : data[index][1];
- }
-
- var _listCacheGet = listCacheGet;
-
- /**
- * Checks if a list cache value for `key` exists.
- *
- * @private
- * @name has
- * @memberOf ListCache
- * @param {string} key The key of the entry to check.
- * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
- */
- function listCacheHas(key) {
- return _assocIndexOf(this.__data__, key) > -1;
- }
-
- var _listCacheHas = listCacheHas;
-
- /**
- * Sets the list cache `key` to `value`.
- *
- * @private
- * @name set
- * @memberOf ListCache
- * @param {string} key The key of the value to set.
- * @param {*} value The value to set.
- * @returns {Object} Returns the list cache instance.
- */
- function listCacheSet(key, value) {
- var data = this.__data__,
- index = _assocIndexOf(data, key);
-
- if (index < 0) {
- ++this.size;
- data.push([key, value]);
- } else {
- data[index][1] = value;
- }
- return this;
- }
-
- var _listCacheSet = listCacheSet;
-
- /**
- * Creates an list cache object.
- *
- * @private
- * @constructor
- * @param {Array} [entries] The key-value pairs to cache.
- */
- function ListCache(entries) {
- var index = -1,
- length = entries == null ? 0 : entries.length;
-
- this.clear();
- while (++index < length) {
- var entry = entries[index];
- this.set(entry[0], entry[1]);
- }
- }
-
- // Add methods to `ListCache`.
- ListCache.prototype.clear = _listCacheClear;
- ListCache.prototype['delete'] = _listCacheDelete;
- ListCache.prototype.get = _listCacheGet;
- ListCache.prototype.has = _listCacheHas;
- ListCache.prototype.set = _listCacheSet;
-
- var _ListCache = ListCache;
-
- /* Built-in method references that are verified to be native. */
- var Map = _getNative(_root, 'Map');
-
- var _Map = Map;
-
- /**
- * Removes all key-value entries from the map.
- *
- * @private
- * @name clear
- * @memberOf MapCache
- */
- function mapCacheClear() {
- this.size = 0;
- this.__data__ = {
- 'hash': new _Hash,
- 'map': new (_Map || _ListCache),
- 'string': new _Hash
- };
- }
-
- var _mapCacheClear = mapCacheClear;
-
- /**
- * Checks if `value` is suitable for use as unique object key.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is suitable, else `false`.
- */
- function isKeyable(value) {
- var type = typeof value;
- return (type == 'string' || type == 'number' || type == 'symbol' || type == 'boolean')
- ? (value !== '__proto__')
- : (value === null);
- }
-
- var _isKeyable = isKeyable;
-
- /**
- * Gets the data for `map`.
- *
- * @private
- * @param {Object} map The map to query.
- * @param {string} key The reference key.
- * @returns {*} Returns the map data.
- */
- function getMapData(map, key) {
- var data = map.__data__;
- return _isKeyable(key)
- ? data[typeof key == 'string' ? 'string' : 'hash']
- : data.map;
- }
-
- var _getMapData = getMapData;
-
- /**
- * Removes `key` and its value from the map.
- *
- * @private
- * @name delete
- * @memberOf MapCache
- * @param {string} key The key of the value to remove.
- * @returns {boolean} Returns `true` if the entry was removed, else `false`.
- */
- function mapCacheDelete(key) {
- var result = _getMapData(this, key)['delete'](key);
- this.size -= result ? 1 : 0;
- return result;
- }
-
- var _mapCacheDelete = mapCacheDelete;
-
- /**
- * Gets the map value for `key`.
- *
- * @private
- * @name get
- * @memberOf MapCache
- * @param {string} key The key of the value to get.
- * @returns {*} Returns the entry value.
- */
- function mapCacheGet(key) {
- return _getMapData(this, key).get(key);
- }
-
- var _mapCacheGet = mapCacheGet;
-
- /**
- * Checks if a map value for `key` exists.
- *
- * @private
- * @name has
- * @memberOf MapCache
- * @param {string} key The key of the entry to check.
- * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
- */
- function mapCacheHas(key) {
- return _getMapData(this, key).has(key);
- }
-
- var _mapCacheHas = mapCacheHas;
-
- /**
- * Sets the map `key` to `value`.
- *
- * @private
- * @name set
- * @memberOf MapCache
- * @param {string} key The key of the value to set.
- * @param {*} value The value to set.
- * @returns {Object} Returns the map cache instance.
- */
- function mapCacheSet(key, value) {
- var data = _getMapData(this, key),
- size = data.size;
-
- data.set(key, value);
- this.size += data.size == size ? 0 : 1;
- return this;
- }
-
- var _mapCacheSet = mapCacheSet;
-
- /**
- * Creates a map cache object to store key-value pairs.
- *
- * @private
- * @constructor
- * @param {Array} [entries] The key-value pairs to cache.
- */
- function MapCache(entries) {
- var index = -1,
- length = entries == null ? 0 : entries.length;
-
- this.clear();
- while (++index < length) {
- var entry = entries[index];
- this.set(entry[0], entry[1]);
- }
- }
-
- // Add methods to `MapCache`.
- MapCache.prototype.clear = _mapCacheClear;
- MapCache.prototype['delete'] = _mapCacheDelete;
- MapCache.prototype.get = _mapCacheGet;
- MapCache.prototype.has = _mapCacheHas;
- MapCache.prototype.set = _mapCacheSet;
-
- var _MapCache = MapCache;
-
- /** Used to stand-in for `undefined` hash values. */
- var HASH_UNDEFINED$2 = '__lodash_hash_undefined__';
-
- /**
- * Adds `value` to the array cache.
- *
- * @private
- * @name add
- * @memberOf SetCache
- * @alias push
- * @param {*} value The value to cache.
- * @returns {Object} Returns the cache instance.
- */
- function setCacheAdd(value) {
- this.__data__.set(value, HASH_UNDEFINED$2);
- return this;
- }
-
- var _setCacheAdd = setCacheAdd;
-
- /**
- * Checks if `value` is in the array cache.
- *
- * @private
- * @name has
- * @memberOf SetCache
- * @param {*} value The value to search for.
- * @returns {number} Returns `true` if `value` is found, else `false`.
- */
- function setCacheHas(value) {
- return this.__data__.has(value);
- }
-
- var _setCacheHas = setCacheHas;
-
- /**
- *
- * Creates an array cache object to store unique values.
- *
- * @private
- * @constructor
- * @param {Array} [values] The values to cache.
- */
- function SetCache(values) {
- var index = -1,
- length = values == null ? 0 : values.length;
-
- this.__data__ = new _MapCache;
- while (++index < length) {
- this.add(values[index]);
- }
- }
-
- // Add methods to `SetCache`.
- SetCache.prototype.add = SetCache.prototype.push = _setCacheAdd;
- SetCache.prototype.has = _setCacheHas;
-
- var _SetCache = SetCache;
-
- /**
- * The base implementation of `_.findIndex` and `_.findLastIndex` without
- * support for iteratee shorthands.
- *
- * @private
- * @param {Array} array The array to inspect.
- * @param {Function} predicate The function invoked per iteration.
- * @param {number} fromIndex The index to search from.
- * @param {boolean} [fromRight] Specify iterating from right to left.
- * @returns {number} Returns the index of the matched value, else `-1`.
- */
- function baseFindIndex(array, predicate, fromIndex, fromRight) {
- var length = array.length,
- index = fromIndex + (fromRight ? 1 : -1);
-
- while ((fromRight ? index-- : ++index < length)) {
- if (predicate(array[index], index, array)) {
- return index;
- }
- }
- return -1;
- }
-
- var _baseFindIndex = baseFindIndex;
-
- /**
- * The base implementation of `_.isNaN` without support for number objects.
- *
- * @private
- * @param {*} value The value to check.
- * @returns {boolean} Returns `true` if `value` is `NaN`, else `false`.
- */
- function baseIsNaN(value) {
- return value !== value;
- }
-
- var _baseIsNaN = baseIsNaN;
-
- /**
- * A specialized version of `_.indexOf` which performs strict equality
- * comparisons of values, i.e. `===`.
- *
- * @private
- * @param {Array} array The array to inspect.
- * @param {*} value The value to search for.
- * @param {number} fromIndex The index to search from.
- * @returns {number} Returns the index of the matched value, else `-1`.
- */
- function strictIndexOf(array, value, fromIndex) {
- var index = fromIndex - 1,
- length = array.length;
-
- while (++index < length) {
- if (array[index] === value) {
- return index;
- }
- }
- return -1;
- }
-
- var _strictIndexOf = strictIndexOf;
-
- /**
- * The base implementation of `_.indexOf` without `fromIndex` bounds checks.
- *
- * @private
- * @param {Array} array The array to inspect.
- * @param {*} value The value to search for.
- * @param {number} fromIndex The index to search from.
- * @returns {number} Returns the index of the matched value, else `-1`.
- */
- function baseIndexOf(array, value, fromIndex) {
- return value === value
- ? _strictIndexOf(array, value, fromIndex)
- : _baseFindIndex(array, _baseIsNaN, fromIndex);
- }
-
- var _baseIndexOf = baseIndexOf;
-
- /**
- * A specialized version of `_.includes` for arrays without support for
- * specifying an index to search from.
- *
- * @private
- * @param {Array} [array] The array to inspect.
- * @param {*} target The value to search for.
- * @returns {boolean} Returns `true` if `target` is found, else `false`.
- */
- function arrayIncludes(array, value) {
- var length = array == null ? 0 : array.length;
- return !!length && _baseIndexOf(array, value, 0) > -1;
- }
-
- var _arrayIncludes = arrayIncludes;
-
- /**
- * This function is like `arrayIncludes` except that it accepts a comparator.
- *
- * @private
- * @param {Array} [array] The array to inspect.
- * @param {*} target The value to search for.
- * @param {Function} comparator The comparator invoked per element.
- * @returns {boolean} Returns `true` if `target` is found, else `false`.
- */
- function arrayIncludesWith(array, value, comparator) {
- var index = -1,
- length = array == null ? 0 : array.length;
-
- while (++index < length) {
- if (comparator(value, array[index])) {
- return true;
- }
- }
- return false;
- }
-
- var _arrayIncludesWith = arrayIncludesWith;
-
- /**
- * Checks if a `cache` value for `key` exists.
- *
- * @private
- * @param {Object} cache The cache to query.
- * @param {string} key The key of the entry to check.
- * @returns {boolean} Returns `true` if an entry for `key` exists, else `false`.
- */
- function cacheHas(cache, key) {
- return cache.has(key);
- }
-
- var _cacheHas = cacheHas;
-
- /* Built-in method references that are verified to be native. */
- var Set = _getNative(_root, 'Set');
-
- var _Set = Set;
-
- /**
- * This method returns `undefined`.
- *
- * @static
- * @memberOf _
- * @since 2.3.0
- * @category Util
- * @example
- *
- * _.times(2, _.noop);
- * // => [undefined, undefined]
- */
- function noop() {
- // No operation performed.
- }
-
- var noop_1 = noop;
-
- /**
- * Converts `set` to an array of its values.
- *
- * @private
- * @param {Object} set The set to convert.
- * @returns {Array} Returns the values.
- */
- function setToArray(set) {
- var index = -1,
- result = Array(set.size);
-
- set.forEach(function(value) {
- result[++index] = value;
- });
- return result;
- }
-
- var _setToArray = setToArray;
-
- /** Used as references for various `Number` constants. */
- var INFINITY = 1 / 0;
-
- /**
- * Creates a set object of `values`.
- *
- * @private
- * @param {Array} values The values to add to the set.
- * @returns {Object} Returns the new set.
- */
- var createSet = !(_Set && (1 / _setToArray(new _Set([,-0]))[1]) == INFINITY) ? noop_1 : function(values) {
- return new _Set(values);
- };
-
- var _createSet = createSet;
-
- /** Used as the size to enable large array optimizations. */
- var LARGE_ARRAY_SIZE = 200;
-
- /**
- * The base implementation of `_.uniqBy` without support for iteratee shorthands.
- *
- * @private
- * @param {Array} array The array to inspect.
- * @param {Function} [iteratee] The iteratee invoked per element.
- * @param {Function} [comparator] The comparator invoked per element.
- * @returns {Array} Returns the new duplicate free array.
- */
- function baseUniq(array, iteratee, comparator) {
- var index = -1,
- includes = _arrayIncludes,
- length = array.length,
- isCommon = true,
- result = [],
- seen = result;
-
- if (comparator) {
- isCommon = false;
- includes = _arrayIncludesWith;
- }
- else if (length >= LARGE_ARRAY_SIZE) {
- var set = iteratee ? null : _createSet(array);
- if (set) {
- return _setToArray(set);
- }
- isCommon = false;
- includes = _cacheHas;
- seen = new _SetCache;
- }
- else {
- seen = iteratee ? [] : result;
- }
- outer:
- while (++index < length) {
- var value = array[index],
- computed = iteratee ? iteratee(value) : value;
-
- value = (comparator || value !== 0) ? value : 0;
- if (isCommon && computed === computed) {
- var seenIndex = seen.length;
- while (seenIndex--) {
- if (seen[seenIndex] === computed) {
- continue outer;
- }
- }
- if (iteratee) {
- seen.push(computed);
- }
- result.push(value);
- }
- else if (!includes(seen, computed, comparator)) {
- if (seen !== result) {
- seen.push(computed);
- }
- result.push(value);
- }
- }
- return result;
- }
-
- var _baseUniq = baseUniq;
-
- /**
- * Creates a duplicate-free version of an array, using
- * [`SameValueZero`](http://ecma-international.org/ecma-262/7.0/#sec-samevaluezero)
- * for equality comparisons, in which only the first occurrence of each element
- * is kept. The order of result values is determined by the order they occur
- * in the array.
- *
- * @static
- * @memberOf _
- * @since 0.1.0
- * @category Array
- * @param {Array} array The array to inspect.
- * @returns {Array} Returns the new duplicate free array.
- * @example
- *
- * _.uniq([2, 1, 2]);
- * // => [2, 1]
- */
- function uniq(array) {
- return (array && array.length) ? _baseUniq(array) : [];
- }
-
- var uniq_1 = uniq;
-
- function camelCaseToDash(str) {
- return str.replace(/([A-Z])/g, (g) => `-${g[0].toLowerCase()}`);
- }
-
- function makeDataAttributeString(props) {
- const keys = Object.keys(props);
-
- return keys
- .map((key) => {
- const _key = camelCaseToDash(key);
- const val = props[key];
-
- if (val === undefined) return '';
- return `data-${_key}="${val}" `;
- })
- .join('')
- .trim();
- }
-
- function copyTextToClipboard(text) {
- // https://stackoverflow.com/a/30810322/5353542
- var textArea = document.createElement('textarea');
-
- //
- // *** This styling is an extra step which is likely not required. ***
- //
- // Why is it here? To ensure:
- // 1. the element is able to have focus and selection.
- // 2. if element was to flash render it has minimal visual impact.
- // 3. less flakyness with selection and copying which **might** occur if
- // the textarea element is not visible.
- //
- // The likelihood is the element won't even render, not even a flash,
- // so some of these are just precautions. However in IE the element
- // is visible whilst the popup box asking the user for permission for
- // the web page to copy to the clipboard.
- //
-
- // Place in top-left corner of screen regardless of scroll position.
- textArea.style.position = 'fixed';
- textArea.style.top = 0;
- textArea.style.left = 0;
-
- // Ensure it has a small width and height. Setting to 1px / 1em
- // doesn't work as this gives a negative w/h on some browsers.
- textArea.style.width = '2em';
- textArea.style.height = '2em';
-
- // We don't need padding, reducing the size if it does flash render.
- textArea.style.padding = 0;
-
- // Clean up any borders.
- textArea.style.border = 'none';
- textArea.style.outline = 'none';
- textArea.style.boxShadow = 'none';
-
- // Avoid flash of white box if rendered for any reason.
- textArea.style.background = 'transparent';
-
- textArea.value = text;
-
- document.body.appendChild(textArea);
-
- textArea.select();
-
- try {
- document.execCommand('copy');
- } catch (err) {
- console.log('Oops, unable to copy');
- }
-
- document.body.removeChild(textArea);
- }
-
- function isNumeric(val) {
- return !isNaN(val);
- }
-
- let throttle$1 = throttle_1;
-
- let debounce$1 = debounce_1;
-
- function nextTick(fn, context = null) {
- return (...args) => {
- return new Promise(resolve => {
- const execute = () => {
- const out = fn.apply(context, args);
- resolve(out);
- };
- setTimeout(execute);
- });
- };
- }
- function linkProperties(target, source, properties) {
- const props = properties.reduce((acc, prop) => {
- acc[prop] = {
- get() {
- return source[prop];
- }
- };
- return acc;
- }, {});
- Object.defineProperties(target, props);
- }
- function isSet(val) {
- return val !== undefined || val !== null;
- }
-
- function notSet(val) {
- return !isSet(val);
- }
-
- function isNumber(val) {
- return !isNaN(val);
- }
-
- function ensureArray(val) {
- if (!Array.isArray(val)) {
- return [val];
- }
- return val;
- }
-
- function uniq$1(arr) {
- return uniq_1(arr);
- }
-
- function numberSortAsc(a, b) {
- return a - b;
- }
- function stripHTML(html) {
- return html.replace(/<[^>]*>/g, '');
- }
- function format(str, args) {
- if (!str) return str;
-
- Object.keys(args).forEach(arg => {
- let regex = new RegExp(`{(${arg})}`, 'g');
- str = str.replace(regex, args[arg]);
- });
-
- return str;
- }
-
- class DataManager {
- constructor(options) {
- this.options = options;
- this.sortRows = nextTick(this.sortRows, this);
- this.switchColumn = nextTick(this.switchColumn, this);
- this.removeColumn = nextTick(this.removeColumn, this);
- this.options.filterRows = nextTick(this.options.filterRows, this);
- }
-
- init(data, columns) {
- if (!data) {
- data = this.options.data;
- }
- if (columns) {
- this.options.columns = columns;
- }
-
- this.data = data;
-
- this.rowCount = 0;
- this.columns = [];
- this.rows = [];
-
- this.prepareColumns();
- this.prepareRows();
- this.prepareTreeRows();
- this.prepareRowView();
- this.prepareNumericColumns();
- }
-
- // computed property
- get currentSort() {
- const col = this.columns.find(col => col.sortOrder !== 'none');
- return col || {
- colIndex: -1,
- sortOrder: 'none'
- };
- }
-
- prepareColumns() {
- this.columns = [];
- this.validateColumns();
- this.prepareDefaultColumns();
- this.prepareHeader();
- }
-
- prepareDefaultColumns() {
- if (this.options.checkboxColumn && !this.hasColumnById('_checkbox')) {
- const cell = {
- id: '_checkbox',
- content: this.getCheckboxHTML(),
- editable: false,
- resizable: false,
- sortable: false,
- focusable: false,
- dropdown: false,
- width: 32
- };
- this.columns.push(cell);
- }
-
- if (this.options.serialNoColumn && !this.hasColumnById('_rowIndex')) {
- let cell = {
- id: '_rowIndex',
- content: '',
- align: 'center',
- editable: false,
- resizable: false,
- focusable: false,
- dropdown: false
- };
-
- this.columns.push(cell);
- }
- }
-
- prepareHeader() {
- let columns = this.columns.concat(this.options.columns);
- const baseCell = {
- isHeader: 1,
- editable: true,
- sortable: true,
- resizable: true,
- focusable: true,
- dropdown: true,
- width: null,
- format: (value) => {
- if (value === null || value === undefined) {
- return '';
- }
- return value + '';
- }
- };
-
- this.columns = columns
- .map((cell, i) => this.prepareCell(cell, i))
- .map(col => Object.assign({}, baseCell, col))
- .map(col => {
- col.content = col.content || col.name || '';
- col.id = col.id || col.content;
- return col;
- });
- }
-
- prepareCell(content, i) {
- const cell = {
- content: '',
- sortOrder: 'none',
- colIndex: i,
- column: this.columns[i]
- };
-
- if (content !== null && typeof content === 'object') {
- // passed as column/header
- Object.assign(cell, content);
- } else {
- cell.content = content;
- }
-
- return cell;
- }
-
- prepareNumericColumns() {
- const row0 = this.getRow(0);
- if (!row0) return;
- this.columns = this.columns.map((column, i) => {
-
- const cellValue = row0[i].content;
- if (!column.align && isNumeric(cellValue)) {
- column.align = 'right';
- }
-
- return column;
- });
- }
-
- prepareRows() {
- this.validateData(this.data);
-
- this.rows = this.data.map((d, i) => {
- const index = this._getNextRowCount();
-
- let row = [];
- let meta = {
- rowIndex: index
- };
-
- if (Array.isArray(d)) {
- // row is an array
- if (this.options.checkboxColumn) {
- row.push(this.getCheckboxHTML());
- }
- if (this.options.serialNoColumn) {
- row.push((index + 1) + '');
- }
- row = row.concat(d);
-
- while (row.length < this.columns.length) {
- row.push('');
- }
-
- } else {
- // row is an object
- for (let col of this.columns) {
- if (col.id === '_checkbox') {
- row.push(this.getCheckboxHTML());
- } else if (col.id === '_rowIndex') {
- row.push((index + 1) + '');
- } else {
- row.push(d[col.id]);
- }
- }
-
- meta.indent = d.indent || 0;
- }
-
- return this.prepareRow(row, meta);
- });
- }
-
- prepareTreeRows() {
- this.rows.forEach((row, i) => {
- if (isNumber(row.meta.indent)) {
- // if (i === 36) debugger;
- const nextRow = this.getRow(i + 1);
- row.meta.isLeaf = !nextRow ||
- notSet(nextRow.meta.indent) ||
- nextRow.meta.indent <= row.meta.indent;
- row.meta.isTreeNodeClose = false;
- }
- });
- }
-
- prepareRowView() {
- // This is order in which rows will be rendered in the table.
- // When sorting happens, only this.rowViewOrder will change
- // and not the original this.rows
- this.rowViewOrder = this.rows.map(row => row.meta.rowIndex);
- }
-
- prepareRow(row, meta) {
- const baseRowCell = {
- rowIndex: meta.rowIndex,
- indent: meta.indent
- };
-
- row = row
- .map((cell, i) => this.prepareCell(cell, i))
- .map(cell => Object.assign({}, baseRowCell, cell));
-
- // monkey patched in array object
- row.meta = meta;
- return row;
- }
-
- validateColumns() {
- const columns = this.options.columns;
- if (!Array.isArray(columns)) {
- throw new DataError('`columns` must be an array');
- }
-
- columns.forEach((column, i) => {
- if (typeof column !== 'string' && typeof column !== 'object') {
- throw new DataError(`column "${i}" must be a string or an object`);
- }
- });
- }
-
- validateData(data) {
- if (Array.isArray(data) &&
- (data.length === 0 || Array.isArray(data[0]) || typeof data[0] === 'object')) {
- return true;
- }
- throw new DataError('`data` must be an array of arrays or objects');
- }
-
- appendRows(rows) {
- this.validateData(rows);
-
- this.rows.push(...this.prepareRows(rows));
- }
-
- sortRows(colIndex, sortOrder = 'none') {
- colIndex = +colIndex;
-
- // reset sortOrder and update for colIndex
- this.getColumns()
- .map(col => {
- if (col.colIndex === colIndex) {
- col.sortOrder = sortOrder;
- } else {
- col.sortOrder = 'none';
- }
- });
-
- this._sortRows(colIndex, sortOrder);
- }
-
- _sortRows(colIndex, sortOrder) {
-
- if (this.currentSort.colIndex === colIndex) {
- // reverse the array if only sortOrder changed
- if (
- (this.currentSort.sortOrder === 'asc' && sortOrder === 'desc') ||
- (this.currentSort.sortOrder === 'desc' && sortOrder === 'asc')
- ) {
- this.reverseArray(this.rowViewOrder);
- this.currentSort.sortOrder = sortOrder;
- return;
- }
- }
-
- this.rowViewOrder.sort((a, b) => {
- const aIndex = a;
- const bIndex = b;
-
- let aContent = this.getCell(colIndex, a).content;
- let bContent = this.getCell(colIndex, b).content;
- aContent = aContent == null ? '' : aContent;
- bContent = bContent == null ? '' : bContent;
-
- if (sortOrder === 'none') {
- return aIndex - bIndex;
- } else if (sortOrder === 'asc') {
- if (aContent < bContent) return -1;
- if (aContent > bContent) return 1;
- if (aContent === bContent) return 0;
- } else if (sortOrder === 'desc') {
- if (aContent < bContent) return 1;
- if (aContent > bContent) return -1;
- if (aContent === bContent) return 0;
- }
- return 0;
- });
-
- if (this.hasColumnById('_rowIndex')) {
- // update row index
- const srNoColIndex = this.getColumnIndexById('_rowIndex');
- this.rows.forEach((row, index) => {
- const viewIndex = this.rowViewOrder.indexOf(index);
- const cell = row[srNoColIndex];
- cell.content = (viewIndex + 1) + '';
- });
- }
- }
-
- reverseArray(array) {
- let left = null;
- let right = null;
- let length = array.length;
-
- for (left = 0, right = length - 1; left < right; left += 1, right -= 1) {
- const temporary = array[left];
-
- array[left] = array[right];
- array[right] = temporary;
- }
- }
-
- switchColumn(index1, index2) {
- // update columns
- const temp = this.columns[index1];
- this.columns[index1] = this.columns[index2];
- this.columns[index2] = temp;
-
- this.columns[index1].colIndex = index1;
- this.columns[index2].colIndex = index2;
-
- // update rows
- this.rows.forEach(row => {
- const newCell1 = Object.assign({}, row[index1], {
- colIndex: index2
- });
- const newCell2 = Object.assign({}, row[index2], {
- colIndex: index1
- });
-
- row[index2] = newCell1;
- row[index1] = newCell2;
- });
- }
-
- removeColumn(index) {
- index = +index;
- const filter = cell => cell.colIndex !== index;
- const map = (cell, i) => Object.assign({}, cell, {
- colIndex: i
- });
- // update columns
- this.columns = this.columns
- .filter(filter)
- .map(map);
-
- // update rows
- this.rows.forEach(row => {
- // remove cell
- row.splice(index, 1);
- // update colIndex
- row.forEach((cell, i) => {
- cell.colIndex = i;
- });
- });
- }
-
- updateRow(row, rowIndex) {
- if (row.length < this.columns.length) {
- if (this.hasColumnById('_rowIndex')) {
- const val = (rowIndex + 1) + '';
-
- row = [val].concat(row);
- }
-
- if (this.hasColumnById('_checkbox')) {
- const val = '<input type="checkbox" />';
-
- row = [val].concat(row);
- }
- }
-
- const _row = this.prepareRow(row, {rowIndex});
- const index = this.rows.findIndex(row => row[0].rowIndex === rowIndex);
- this.rows[index] = _row;
-
- return _row;
- }
-
- updateCell(colIndex, rowIndex, options) {
- let cell;
- if (typeof colIndex === 'object') {
- // cell object was passed,
- // must have colIndex, rowIndex
- cell = colIndex;
- colIndex = cell.colIndex;
- rowIndex = cell.rowIndex;
- // the object passed must be merged with original cell
- options = cell;
- }
- cell = this.getCell(colIndex, rowIndex);
-
- // mutate object directly
- for (let key in options) {
- const newVal = options[key];
- if (newVal !== undefined) {
- cell[key] = newVal;
- }
- }
-
- return cell;
- }
-
- updateColumn(colIndex, keyValPairs) {
- const column = this.getColumn(colIndex);
- for (let key in keyValPairs) {
- const newVal = keyValPairs[key];
- if (newVal !== undefined) {
- column[key] = newVal;
- }
- }
- return column;
- }
-
- filterRows(filters) {
- return this.options.filterRows(this.rows, filters)
- .then(result => {
- if (!result) {
- result = this.getAllRowIndices();
- }
-
- if (!result.then) {
- result = Promise.resolve(result);
- }
-
- return result.then(rowsToShow => {
- this._filteredRows = rowsToShow;
-
- const rowsToHide = this.getAllRowIndices()
- .filter(index => !rowsToShow.includes(index));
-
- return {
- rowsToHide,
- rowsToShow
- };
- });
- });
- }
-
- getFilteredRowIndices() {
- return this._filteredRows || this.getAllRowIndices();
- }
-
- getAllRowIndices() {
- return this.rows.map(row => row.meta.rowIndex);
- }
-
- getRowCount() {
- return this.rowCount;
- }
-
- _getNextRowCount() {
- const val = this.rowCount;
-
- this.rowCount++;
- return val;
- }
-
- getRows(start, end) {
- return this.rows.slice(start, end);
- }
-
- getRowsForView(start, end) {
- const rows = this.rowViewOrder.map(i => this.rows[i]);
- return rows.slice(start, end);
- }
-
- getColumns(skipStandardColumns) {
- let columns = this.columns;
-
- if (skipStandardColumns) {
- columns = columns.slice(this.getStandardColumnCount());
- }
-
- return columns;
- }
-
- getStandardColumnCount() {
- if (this.options.checkboxColumn && this.options.serialNoColumn) {
- return 2;
- }
-
- if (this.options.checkboxColumn || this.options.serialNoColumn) {
- return 1;
- }
-
- return 0;
- }
-
- getColumnCount(skipStandardColumns) {
- let val = this.columns.length;
-
- if (skipStandardColumns) {
- val = val - this.getStandardColumnCount();
- }
-
- return val;
- }
-
- getColumn(colIndex) {
- colIndex = +colIndex;
-
- if (colIndex < 0) {
- // negative indexes
- colIndex = this.columns.length + colIndex;
- }
-
- return this.columns.find(col => col.colIndex === colIndex);
- }
-
- getColumnById(id) {
- return this.columns.find(col => col.id === id);
- }
-
- getRow(rowIndex) {
- rowIndex = +rowIndex;
- return this.rows[rowIndex];
- }
-
- getCell(colIndex, rowIndex) {
- rowIndex = +rowIndex;
- colIndex = +colIndex;
- return this.getRow(rowIndex)[colIndex];
- }
-
- getChildren(parentRowIndex) {
- parentRowIndex = +parentRowIndex;
- const parentIndent = this.getRow(parentRowIndex).meta.indent;
- const out = [];
-
- for (let i = parentRowIndex + 1; i < this.rowCount; i++) {
- const row = this.getRow(i);
- if (isNaN(row.meta.indent)) continue;
-
- if (row.meta.indent > parentIndent) {
- out.push(i);
- }
-
- if (row.meta.indent === parentIndent) {
- break;
- }
- }
-
- return out;
- }
-
- getImmediateChildren(parentRowIndex) {
- parentRowIndex = +parentRowIndex;
- const parentIndent = this.getRow(parentRowIndex).meta.indent;
- const out = [];
- const childIndent = parentIndent + 1;
-
- for (let i = parentRowIndex + 1; i < this.rowCount; i++) {
- const row = this.getRow(i);
- if (isNaN(row.meta.indent) || row.meta.indent > childIndent) continue;
-
- if (row.meta.indent === childIndent) {
- out.push(i);
- }
-
- if (row.meta.indent === parentIndent) {
- break;
- }
- }
-
- return out;
- }
-
- get() {
- return {
- columns: this.columns,
- rows: this.rows
- };
- }
-
- /**
- * Returns the original data which was passed
- * based on rowIndex
- * @param {Number} rowIndex
- * @returns Array|Object
- * @memberof DataManager
- */
- getData(rowIndex) {
- return this.data[rowIndex];
- }
-
- hasColumn(name) {
- return Boolean(this.columns.find(col => col.content === name));
- }
-
- hasColumnById(id) {
- return Boolean(this.columns.find(col => col.id === id));
- }
-
- getColumnIndex(name) {
- return this.columns.findIndex(col => col.content === name);
- }
-
- getColumnIndexById(id) {
- return this.columns.findIndex(col => col.id === id);
- }
-
- getCheckboxHTML() {
- return '<input type="checkbox" />';
- }
- }
-
- // Custom Errors
- class DataError extends TypeError {}
-
- /* eslint-disable max-len */
-
- // Icons from https://feathericons.com/
-
- let icons = {
- chevronDown: '<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-chevron-down"><polyline points="6 9 12 15 18 9"></polyline></svg>',
- chevronRight: '<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="feather feather-chevron-right"><polyline points="9 18 15 12 9 6"></polyline></svg>'
- };
-
- class CellManager {
- constructor(instance) {
- this.instance = instance;
- linkProperties(this, this.instance, [
- 'wrapper',
- 'options',
- 'style',
- 'header',
- 'bodyScrollable',
- 'columnmanager',
- 'rowmanager',
- 'datamanager',
- 'keyboard'
- ]);
-
- this.bindEvents();
- }
-
- bindEvents() {
- this.bindFocusCell();
- this.bindEditCell();
- this.bindKeyboardSelection();
- this.bindCopyCellContents();
- this.bindMouseEvents();
- this.bindTreeEvents();
- }
-
- bindFocusCell() {
- this.bindKeyboardNav();
- }
-
- bindEditCell() {
- this.$editingCell = null;
-
- $.on(this.bodyScrollable, 'dblclick', '.dt-cell', (e, cell) => {
- this.activateEditing(cell);
- });
-
- this.keyboard.on('enter', () => {
- if (this.$focusedCell && !this.$editingCell) {
- // enter keypress on focused cell
- this.activateEditing(this.$focusedCell);
- } else if (this.$editingCell) {
- // enter keypress on editing cell
- this.deactivateEditing();
- }
- });
- }
-
- bindKeyboardNav() {
- const focusLastCell = (direction) => {
- if (!this.$focusedCell || this.$editingCell) {
- return false;
- }
-
- let $cell = this.$focusedCell;
- const {
- rowIndex,
- colIndex
- } = $.data($cell);
-
- if (direction === 'left') {
- $cell = this.getLeftMostCell$(rowIndex);
- } else if (direction === 'right') {
- $cell = this.getRightMostCell$(rowIndex);
- } else if (direction === 'up') {
- $cell = this.getTopMostCell$(colIndex);
- } else if (direction === 'down') {
- $cell = this.getBottomMostCell$(colIndex);
- }
-
- this.focusCell($cell);
- return true;
- };
-
- ['left', 'right', 'up', 'down', 'tab', 'shift+tab']
- .map(direction => this.keyboard.on(direction, () => this.focusCellInDirection(direction)));
-
- ['left', 'right', 'up', 'down']
- .map(direction => this.keyboard.on(`ctrl+${direction}`, () => focusLastCell(direction)));
-
- this.keyboard.on('esc', () => {
- this.deactivateEditing(false);
- this.columnmanager.toggleFilter(false);
- });
-
- if (this.options.inlineFilters) {
- this.keyboard.on('ctrl+f', (e) => {
- const $cell = $.closest('.dt-cell', e.target);
- const { colIndex } = $.data($cell);
-
- this.activateFilter(colIndex);
- return true;
- });
-
- $.on(this.header, 'focusin', '.dt-filter', () => {
- this.unfocusCell(this.$focusedCell);
- });
- }
- }
-
- bindKeyboardSelection() {
- const getNextSelectionCursor = (direction) => {
- let $selectionCursor = this.getSelectionCursor();
-
- if (direction === 'left') {
- $selectionCursor = this.getLeftCell$($selectionCursor);
- } else if (direction === 'right') {
- $selectionCursor = this.getRightCell$($selectionCursor);
- } else if (direction === 'up') {
- $selectionCursor = this.getAboveCell$($selectionCursor);
- } else if (direction === 'down') {
- $selectionCursor = this.getBelowCell$($selectionCursor);
- }
-
- return $selectionCursor;
- };
-
- ['left', 'right', 'up', 'down']
- .map(direction =>
- this.keyboard.on(`shift+${direction}`, () => this.selectArea(getNextSelectionCursor(direction))));
- }
-
- bindCopyCellContents() {
- this.keyboard.on('ctrl+c', () => {
- const noOfCellsCopied = this.copyCellContents(this.$focusedCell, this.$selectionCursor);
- const message = this.instance.translate('{count} cells copied', {
- count: noOfCellsCopied
- });
-
- if (noOfCellsCopied) {
- this.instance.showToastMessage(message, 2);
- }
- });
-
- if (this.options.pasteFromClipboard) {
- this.keyboard.on('ctrl+v', (e) => {
- // hack
- // https://stackoverflow.com/a/2177059/5353542
- this.instance.pasteTarget.focus();
-
- setTimeout(() => {
- const data = this.instance.pasteTarget.value;
- this.instance.pasteTarget.value = '';
- this.pasteContentInCell(data);
- }, 10);
-
- return false;
- });
- }
- }
-
- bindMouseEvents() {
- let mouseDown = null;
-
- $.on(this.bodyScrollable, 'mousedown', '.dt-cell', (e) => {
- mouseDown = true;
- this.focusCell($(e.delegatedTarget));
- });
-
- $.on(this.bodyScrollable, 'mouseup', () => {
- mouseDown = false;
- });
-
- const selectArea = (e) => {
- if (!mouseDown) return;
- this.selectArea($(e.delegatedTarget));
- };
-
- $.on(this.bodyScrollable, 'mousemove', '.dt-cell', throttle$1(selectArea, 50));
- }
-
- bindTreeEvents() {
- $.on(this.bodyScrollable, 'click', '.dt-tree-node__toggle', (e, $toggle) => {
- const $cell = $.closest('.dt-cell', $toggle);
- const { rowIndex } = $.data($cell);
-
- if ($cell.classList.contains('dt-cell--tree-close')) {
- this.rowmanager.openSingleNode(rowIndex);
- } else {
- this.rowmanager.closeSingleNode(rowIndex);
- }
- });
- }
-
- focusCell($cell, {
- skipClearSelection = 0,
- skipDOMFocus = 0,
- skipScrollToCell = 0
- } = {}) {
- if (!$cell) return;
-
- // don't focus if already editing cell
- if ($cell === this.$editingCell) return;
-
- const {
- colIndex,
- isHeader
- } = $.data($cell);
- if (isHeader) {
- return;
- }
-
- const column = this.columnmanager.getColumn(colIndex);
- if (column.focusable === false) {
- return;
- }
-
- if (!skipScrollToCell) {
- this.scrollToCell($cell);
- }
-
- this.deactivateEditing();
- if (!skipClearSelection) {
- this.clearSelection();
- }
-
- if (this.$focusedCell) {
- this.$focusedCell.classList.remove('dt-cell--focus');
- }
-
- this.$focusedCell = $cell;
- $cell.classList.add('dt-cell--focus');
-
- if (!skipDOMFocus) {
- // so that keyboard nav works
- $cell.focus();
- }
-
- this.highlightRowColumnHeader($cell);
- }
-
- unfocusCell($cell) {
- if (!$cell) return;
-
- // remove cell border
- $cell.classList.remove('dt-cell--focus');
- this.$focusedCell = null;
-
- // reset header background
- if (this.lastHeaders) {
- this.lastHeaders.forEach(header => header && header.classList.remove('dt-cell--highlight'));
- }
- }
-
- highlightRowColumnHeader($cell) {
- const {
- colIndex,
- rowIndex
- } = $.data($cell);
-
- const srNoColIndex = this.datamanager.getColumnIndexById('_rowIndex');
- const colHeaderSelector = `.dt-cell--header-${colIndex}`;
- const rowHeaderSelector = `.dt-cell--${srNoColIndex}-${rowIndex}`;
-
- if (this.lastHeaders) {
- this.lastHeaders.forEach(header => header && header.classList.remove('dt-cell--highlight'));
- }
-
- const colHeader = $(colHeaderSelector, this.wrapper);
- const rowHeader = $(rowHeaderSelector, this.wrapper);
-
- this.lastHeaders = [colHeader, rowHeader];
- this.lastHeaders.forEach(header => header && header.classList.add('dt-cell--highlight'));
- }
-
- selectAreaOnClusterChanged() {
- if (!(this.$focusedCell && this.$selectionCursor)) return;
- const {
- colIndex,
- rowIndex
- } = $.data(this.$selectionCursor);
- const $cell = this.getCell$(colIndex, rowIndex);
-
- if (!$cell || $cell === this.$selectionCursor) return;
-
- // selectArea needs $focusedCell
- const fCell = $.data(this.$focusedCell);
- this.$focusedCell = this.getCell$(fCell.colIndex, fCell.rowIndex);
-
- this.selectArea($cell);
- }
-
- focusCellOnClusterChanged() {
- if (!this.$focusedCell) return;
-
- const {
- colIndex,
- rowIndex
- } = $.data(this.$focusedCell);
- const $cell = this.getCell$(colIndex, rowIndex);
-
- if (!$cell) return;
- // this function is called after hyperlist renders the rows after scroll,
- // focusCell calls clearSelection which resets the area selection
- // so a flag to skip it
- // we also skip DOM focus and scroll to cell
- // because it fights with the user scroll
- this.focusCell($cell, {
- skipClearSelection: 1,
- skipDOMFocus: 1,
- skipScrollToCell: 1
- });
- }
-
- selectArea($selectionCursor) {
- if (!this.$focusedCell) return;
-
- if (this._selectArea(this.$focusedCell, $selectionCursor)) {
- // valid selection
- this.$selectionCursor = $selectionCursor;
- }
- }
-
- _selectArea($cell1, $cell2) {
- if ($cell1 === $cell2) return false;
-
- const cells = this.getCellsInRange($cell1, $cell2);
- if (!cells) return false;
-
- this.clearSelection();
- this._selectedCells = cells.map(index => this.getCell$(...index));
- requestAnimationFrame(() => {
- this._selectedCells.map($cell => $cell.classList.add('dt-cell--highlight'));
- });
- return true;
- }
-
- getCellsInRange($cell1, $cell2) {
- let colIndex1, rowIndex1, colIndex2, rowIndex2;
-
- if (typeof $cell1 === 'number') {
- [colIndex1, rowIndex1, colIndex2, rowIndex2] = arguments;
- } else
- if (typeof $cell1 === 'object') {
- if (!($cell1 && $cell2)) {
- return false;
- }
-
- const cell1 = $.data($cell1);
- const cell2 = $.data($cell2);
-
- colIndex1 = +cell1.colIndex;
- rowIndex1 = +cell1.rowIndex;
- colIndex2 = +cell2.colIndex;
- rowIndex2 = +cell2.rowIndex;
- }
-
- if (rowIndex1 > rowIndex2) {
- [rowIndex1, rowIndex2] = [rowIndex2, rowIndex1];
- }
-
- if (colIndex1 > colIndex2) {
- [colIndex1, colIndex2] = [colIndex2, colIndex1];
- }
-
- if (this.isStandardCell(colIndex1) || this.isStandardCell(colIndex2)) {
- return false;
- }
-
- const cells = [];
- let colIndex = colIndex1;
- let rowIndex = rowIndex1;
- const rowIndices = [];
-
- while (rowIndex <= rowIndex2) {
- rowIndices.push(rowIndex);
- rowIndex += 1;
- }
-
- rowIndices.map((rowIndex) => {
- while (colIndex <= colIndex2) {
- cells.push([colIndex, rowIndex]);
- colIndex++;
- }
- colIndex = colIndex1;
- });
-
- return cells;
- }
-
- clearSelection() {
- (this._selectedCells || [])
- .forEach($cell => $cell.classList.remove('dt-cell--highlight'));
-
- this._selectedCells = [];
- this.$selectionCursor = null;
- }
-
- getSelectionCursor() {
- return this.$selectionCursor || this.$focusedCell;
- }
-
- activateEditing($cell) {
- this.focusCell($cell);
- const {
- rowIndex,
- colIndex
- } = $.data($cell);
-
- const col = this.columnmanager.getColumn(colIndex);
- if (col && (col.editable === false || col.focusable === false)) {
- return;
- }
-
- const cell = this.getCell(colIndex, rowIndex);
- if (cell && cell.editable === false) {
- return;
- }
-
- if (this.$editingCell) {
- const {
- _rowIndex,
- _colIndex
- } = $.data(this.$editingCell);
-
- if (rowIndex === _rowIndex && colIndex === _colIndex) {
- // editing the same cell
- return;
- }
- }
-
- this.$editingCell = $cell;
- $cell.classList.add('dt-cell--editing');
-
- const $editCell = $('.dt-cell__edit', $cell);
- $editCell.innerHTML = '';
-
- const editor = this.getEditor(colIndex, rowIndex, cell.content, $editCell);
-
- if (editor) {
- this.currentCellEditor = editor;
- // initialize editing input with cell value
- editor.initValue(cell.content, rowIndex, col);
- }
- }
-
- deactivateEditing(submitValue = true) {
- if (submitValue) {
- this.submitEditing();
- }
- // keep focus on the cell so that keyboard navigation works
- if (this.$focusedCell) this.$focusedCell.focus();
-
- if (!this.$editingCell) return;
- this.$editingCell.classList.remove('dt-cell--editing');
- this.$editingCell = null;
- }
-
- getEditor(colIndex, rowIndex, value, parent) {
- const column = this.datamanager.getColumn(colIndex);
- const row = this.datamanager.getRow(rowIndex);
- const data = this.datamanager.getData(rowIndex);
- let editor = this.options.getEditor ?
- this.options.getEditor(colIndex, rowIndex, value, parent, column, row, data) :
- this.getDefaultEditor(parent);
-
- if (editor === false) {
- // explicitly returned false
- return false;
- }
- if (editor === undefined) {
- // didn't return editor, fallback to default
- editor = this.getDefaultEditor(parent);
- }
-
- return editor;
- }
-
- getDefaultEditor(parent) {
- const $input = $.create('input', {
- class: 'dt-input',
- type: 'text',
- inside: parent
- });
-
- return {
- initValue(value) {
- $input.focus();
- $input.value = value;
- },
- getValue() {
- return $input.value;
- },
- setValue(value) {
- $input.value = value;
- }
- };
- }
-
- submitEditing() {
- let promise = Promise.resolve();
- if (!this.$editingCell) return promise;
-
- const $cell = this.$editingCell;
- const {
- rowIndex,
- colIndex
- } = $.data($cell);
- const col = this.datamanager.getColumn(colIndex);
-
- if ($cell) {
- const editor = this.currentCellEditor;
-
- if (editor) {
- let valuePromise = editor.getValue();
-
- // convert to stubbed Promise
- if (!valuePromise.then) {
- valuePromise = Promise.resolve(valuePromise);
- }
-
- promise = valuePromise.then((value) => {
- const oldValue = this.getCell(colIndex, rowIndex).content;
-
- if (oldValue === value) return false;
-
- const done = editor.setValue(value, rowIndex, col);
-
- // update cell immediately
- this.updateCell(colIndex, rowIndex, value, true);
- $cell.focus();
-
- if (done && done.then) {
- // revert to oldValue if promise fails
- done.catch((e) => {
- console.log(e);
- this.updateCell(colIndex, rowIndex, oldValue);
- });
- }
- return done;
- });
- }
- }
-
- this.currentCellEditor = null;
- return promise;
- }
-
- copyCellContents($cell1, $cell2) {
- if (!$cell2 && $cell1) {
- // copy only focusedCell
- const {
- colIndex,
- rowIndex
- } = $.data($cell1);
- const cell = this.getCell(colIndex, rowIndex);
- copyTextToClipboard(cell.content);
- return 1;
- }
- const cells = this.getCellsInRange($cell1, $cell2);
-
- if (!cells) return 0;
-
- const rows = cells
- // get cell objects
- .map(index => this.getCell(...index))
- // convert to array of rows
- .reduce((acc, curr) => {
- const rowIndex = curr.rowIndex;
-
- acc[rowIndex] = acc[rowIndex] || [];
- acc[rowIndex].push(curr.content);
-
- return acc;
- }, []);
-
- const values = rows
- // join values by tab
- .map(row => row.join('\t'))
- // join rows by newline
- .join('\n');
-
- copyTextToClipboard(values);
-
- // return no of cells copied
- return rows.reduce((total, row) => total + row.length, 0);
- }
-
- pasteContentInCell(data) {
- if (!this.$focusedCell) return;
-
- const matrix = data
- .split('\n')
- .map(row => row.split('\t'))
- .filter(row => row.length && row.every(it => it));
-
- let { colIndex, rowIndex } = $.data(this.$focusedCell);
-
- let focusedCell = {
- colIndex: +colIndex,
- rowIndex: +rowIndex
- };
-
- matrix.forEach((row, i) => {
- let rowIndex = i + focusedCell.rowIndex;
- row.forEach((cell, j) => {
- let colIndex = j + focusedCell.colIndex;
- this.updateCell(colIndex, rowIndex, cell, true);
- });
- });
- }
-
- activateFilter(colIndex) {
- this.columnmanager.toggleFilter();
- this.columnmanager.focusFilter(colIndex);
-
- if (!this.columnmanager.isFilterShown) {
- // put focus back on cell
- this.$focusedCell && this.$focusedCell.focus();
- }
- }
-
- updateCell(colIndex, rowIndex, value, refreshHtml = false) {
- const cell = this.datamanager.updateCell(colIndex, rowIndex, {
- content: value
- });
- this.refreshCell(cell, refreshHtml);
- }
-
- refreshCell(cell, refreshHtml = false) {
- const $cell = $(this.selector(cell.colIndex, cell.rowIndex), this.bodyScrollable);
- $cell.innerHTML = this.getCellContent(cell, refreshHtml);
- }
-
- toggleTreeButton(rowIndex, flag) {
- const colIndex = this.columnmanager.getFirstColumnIndex();
- const $cell = this.getCell$(colIndex, rowIndex);
- if ($cell) {
- $cell.classList[flag ? 'remove' : 'add']('dt-cell--tree-close');
- }
- }
-
- isStandardCell(colIndex) {
- // Standard cells are in Sr. No and Checkbox column
- return colIndex < this.columnmanager.getFirstColumnIndex();
- }
-
- focusCellInDirection(direction) {
- if (!this.$focusedCell || (this.$editingCell && ['left', 'right', 'up', 'down'].includes(direction))) {
- return false;
- } else if (this.$editingCell && ['tab', 'shift+tab'].includes(direction)) {
- this.deactivateEditing();
- }
-
- let $cell = this.$focusedCell;
-
- if (direction === 'left' || direction === 'shift+tab') {
- $cell = this.getLeftCell$($cell);
- } else if (direction === 'right' || direction === 'tab') {
- $cell = this.getRightCell$($cell);
- } else if (direction === 'up') {
- $cell = this.getAboveCell$($cell);
- } else if (direction === 'down') {
- $cell = this.getBelowCell$($cell);
- }
-
- if (!$cell) {
- return false;
- }
-
- const {
- colIndex
- } = $.data($cell);
- const column = this.columnmanager.getColumn(colIndex);
-
- if (!column.focusable) {
- let $prevFocusedCell = this.$focusedCell;
- this.unfocusCell($prevFocusedCell);
- this.$focusedCell = $cell;
- let ret = this.focusCellInDirection(direction);
- if (!ret) {
- this.focusCell($prevFocusedCell);
- }
- return ret;
- }
-
- this.focusCell($cell);
- return true;
- }
-
- getCell$(colIndex, rowIndex) {
- return $(this.selector(colIndex, rowIndex), this.bodyScrollable);
- }
-
- getAboveCell$($cell) {
- const {
- colIndex
- } = $.data($cell);
-
- let $aboveRow = $cell.parentElement.previousElementSibling;
- while ($aboveRow && $aboveRow.classList.contains('dt-row--hide')) {
- $aboveRow = $aboveRow.previousElementSibling;
- }
-
- if (!$aboveRow) return $cell;
- return $(`.dt-cell--col-${colIndex}`, $aboveRow);
- }
-
- getBelowCell$($cell) {
- const {
- colIndex
- } = $.data($cell);
-
- let $belowRow = $cell.parentElement.nextElementSibling;
- while ($belowRow && $belowRow.classList.contains('dt-row--hide')) {
- $belowRow = $belowRow.nextElementSibling;
- }
-
- if (!$belowRow) return $cell;
- return $(`.dt-cell--col-${colIndex}`, $belowRow);
- }
-
- getLeftCell$($cell) {
- return $cell.previousElementSibling;
- }
-
- getRightCell$($cell) {
- return $cell.nextElementSibling;
- }
-
- getLeftMostCell$(rowIndex) {
- return this.getCell$(this.columnmanager.getFirstColumnIndex(), rowIndex);
- }
-
- getRightMostCell$(rowIndex) {
- return this.getCell$(this.columnmanager.getLastColumnIndex(), rowIndex);
- }
-
- getTopMostCell$(colIndex) {
- return this.getCell$(colIndex, this.rowmanager.getFirstRowIndex());
- }
-
- getBottomMostCell$(colIndex) {
- return this.getCell$(colIndex, this.rowmanager.getLastRowIndex());
- }
-
- getCell(colIndex, rowIndex) {
- return this.instance.datamanager.getCell(colIndex, rowIndex);
- }
-
- getRowHeight() {
- return $.style($('.dt-row', this.bodyScrollable), 'height');
- }
-
- scrollToCell($cell) {
- if ($.inViewport($cell, this.bodyScrollable)) return false;
-
- const {
- rowIndex
- } = $.data($cell);
- this.rowmanager.scrollToRow(rowIndex);
- return false;
- }
-
- getRowCountPerPage() {
- return Math.ceil(this.instance.getViewportHeight() / this.getRowHeight());
- }
-
- getCellHTML(cell) {
- const {
- rowIndex,
- colIndex,
- isHeader,
- isFilter,
- isTotalRow
- } = cell;
- const dataAttr = makeDataAttributeString({
- rowIndex,
- colIndex,
- isHeader,
- isFilter,
- isTotalRow
- });
-
- const row = this.datamanager.getRow(rowIndex);
-
- const isBodyCell = !(isHeader || isFilter || isTotalRow);
-
- const className = [
- 'dt-cell',
- 'dt-cell--col-' + colIndex,
- isBodyCell ? `dt-cell--${colIndex}-${rowIndex}` : '',
- isBodyCell ? 'dt-cell--row-' + rowIndex : '',
- isHeader ? 'dt-cell--header' : '',
- isHeader ? `dt-cell--header-${colIndex}` : '',
- isFilter ? 'dt-cell--filter' : '',
- isBodyCell && (row && row.meta.isTreeNodeClose) ? 'dt-cell--tree-close' : ''
- ].join(' ');
-
- return `
- <div class="${className}" ${dataAttr} tabindex="0">
- ${this.getCellContent(cell)}
- </div>
- `;
- }
-
- getCellContent(cell, refreshHtml = false) {
- const {
- isHeader,
- isFilter,
- colIndex
- } = cell;
-
- const editable = !isHeader && cell.editable !== false;
- const editCellHTML = editable ? this.getEditCellHTML(colIndex) : '';
-
- const sortable = isHeader && cell.sortable !== false;
- const sortIndicator = sortable ?
- `<span class="sort-indicator">
- ${this.options.sortIndicator[cell.sortOrder]}
- </span>` :
- '';
-
- const resizable = isHeader && cell.resizable !== false;
- const resizeColumn = resizable ? '<span class="dt-cell__resize-handle"></span>' : '';
-
- const hasDropdown = isHeader && cell.dropdown !== false;
- const dropdown = hasDropdown ? this.columnmanager.getDropdownHTML() : '';
-
- let customFormatter = CellManager.getCustomCellFormatter(cell);
- let contentHTML;
- if (isHeader || isFilter || !customFormatter) {
- contentHTML = cell.content;
- } else {
- if (!cell.html || refreshHtml) {
- const row = this.datamanager.getRow(cell.rowIndex);
- const data = this.datamanager.getData(cell.rowIndex);
- contentHTML = customFormatter(cell.content, row, cell.column, data);
- } else {
- contentHTML = cell.html;
- }
- }
-
- cell.html = contentHTML;
-
- if (this.options.treeView && !(isHeader || isFilter) && cell.indent !== undefined) {
- const nextRow = this.datamanager.getRow(cell.rowIndex + 1);
- const addToggle = nextRow && nextRow.meta.indent > cell.indent;
- const leftPadding = 20;
- const unit = 'px';
-
- // Add toggle and indent in the first column
- const firstColumnIndex = this.datamanager.getColumnIndexById('_rowIndex') + 1;
- if (firstColumnIndex === cell.colIndex) {
- const padding = ((cell.indent || 0)) * leftPadding;
- const toggleHTML = addToggle ?
- `<span class="dt-tree-node__toggle" style="left: ${padding - leftPadding}${unit}">
- <span class="icon-open">${icons.chevronDown}</span>
- <span class="icon-close">${icons.chevronRight}</span>
- </span>` : '';
- contentHTML = `<span class="dt-tree-node" style="padding-left: ${padding}${unit}">
- ${toggleHTML}
- <span>${contentHTML}</span>
- </span>`;
- }
- }
-
- const className = [
- 'dt-cell__content',
- isHeader ? `dt-cell__content--header-${colIndex}` : `dt-cell__content--col-${colIndex}`
- ].join(' ');
-
- return `
- <div class="${className}">
- ${contentHTML}
- ${sortIndicator}
- ${resizeColumn}
- ${dropdown}
- </div>
- ${editCellHTML}
- `;
- }
-
- getEditCellHTML(colIndex) {
- return `<div class="dt-cell__edit dt-cell__edit--col-${colIndex}"></div>`;
- }
-
- selector(colIndex, rowIndex) {
- return `.dt-cell--${colIndex}-${rowIndex}`;
- }
-
- static getCustomCellFormatter(cell) {
- return cell.format || (cell.column && cell.column.format) || null;
- }
- }
-
- class ColumnManager {
- constructor(instance) {
- this.instance = instance;
-
- linkProperties(this, this.instance, [
- 'options',
- 'fireEvent',
- 'header',
- 'datamanager',
- 'cellmanager',
- 'style',
- 'wrapper',
- 'rowmanager',
- 'bodyScrollable',
- 'bodyRenderer'
- ]);
-
- this.bindEvents();
- }
-
- renderHeader() {
- this.header.innerHTML = '<div></div>';
- this.refreshHeader();
- }
-
- refreshHeader() {
- const columns = this.datamanager.getColumns();
-
- // refresh html
- $('div', this.header).innerHTML = this.getHeaderHTML(columns);
-
- this.$filterRow = $('.dt-row-filter', this.header);
- if (this.$filterRow) {
- $.style(this.$filterRow, { display: 'none' });
- }
- // reset columnMap
- this.$columnMap = [];
- this.bindMoveColumn();
- }
-
- getHeaderHTML(columns) {
- let html = this.rowmanager.getRowHTML(columns, {
- isHeader: 1
- });
- if (this.options.inlineFilters) {
- html += this.rowmanager.getRowHTML(columns, {
- isFilter: 1
- });
- }
- return html;
- }
-
- bindEvents() {
- this.bindDropdown();
- this.bindResizeColumn();
- this.bindPerfectColumnWidth();
- this.bindFilter();
- }
-
- bindDropdown() {
- let toggleClass = '.dt-dropdown__toggle';
- let dropdownClass = '.dt-dropdown__list';
-
- // attach the dropdown list to container
- this.instance.dropdownContainer.innerHTML = this.getDropdownListHTML();
- this.$dropdownList = this.instance.dropdownContainer.firstElementChild;
-
- $.on(this.header, 'click', toggleClass, e => {
- this.openDropdown(e);
- });
-
- const deactivateDropdownOnBodyClick = (e) => {
- const selector = [
- toggleClass, toggleClass + ' *',
- dropdownClass, dropdownClass + ' *'
- ].join(',');
- if (e.target.matches(selector)) return;
- deactivateDropdown();
- };
- $.on(document.body, 'click', deactivateDropdownOnBodyClick);
- document.addEventListener('scroll', deactivateDropdown, true);
-
- this.instance.on('onDestroy', () => {
- $.off(document.body, 'click', deactivateDropdownOnBodyClick);
- $.off(document, 'scroll', deactivateDropdown);
- });
-
- $.on(this.$dropdownList, 'click', '.dt-dropdown__list-item', (e, $item) => {
- if (!this._dropdownActiveColIndex) return;
- const dropdownItems = this.options.headerDropdown;
- const { index } = $.data($item);
- const colIndex = this._dropdownActiveColIndex;
- let callback = dropdownItems[index].action;
-
- callback && callback.call(this.instance, this.getColumn(colIndex));
- this.hideDropdown();
- });
-
- const _this = this;
- function deactivateDropdown(e) {
- _this.hideDropdown();
- }
-
- this.hideDropdown();
- }
-
- openDropdown(e) {
- if (!this._dropdownWidth) {
- $.style(this.$dropdownList, { display: '' });
- this._dropdownWidth = $.style(this.$dropdownList, 'width');
- }
- $.style(this.$dropdownList, {
- display: '',
- left: (e.clientX - this._dropdownWidth + 4) + 'px',
- top: (e.clientY + 4) + 'px'
- });
- const $cell = $.closest('.dt-cell', e.target);
- const { colIndex } = $.data($cell);
- this._dropdownActiveColIndex = colIndex;
- }
-
- hideDropdown() {
- $.style(this.$dropdownList, {
- display: 'none'
- });
- this._dropdownActiveColIndex = null;
- }
-
- bindResizeColumn() {
- let isDragging = false;
- let $resizingCell, startWidth, startX;
-
- $.on(this.header, 'mousedown', '.dt-cell .dt-cell__resize-handle', (e, $handle) => {
- document.body.classList.add('dt-resize');
- const $cell = $handle.parentNode.parentNode;
- $resizingCell = $cell;
- const {
- colIndex
- } = $.data($resizingCell);
- const col = this.getColumn(colIndex);
-
- if (col && col.resizable === false) {
- return;
- }
-
- isDragging = true;
- startWidth = $.style($('.dt-cell__content', $resizingCell), 'width');
- startX = e.pageX;
- });
-
- const onMouseup = (e) => {
- document.body.classList.remove('dt-resize');
- if (!$resizingCell) return;
- isDragging = false;
-
- const {
- colIndex
- } = $.data($resizingCell);
- this.setColumnWidth(colIndex);
- this.style.setBodyStyle();
- $resizingCell = null;
- };
- $.on(document.body, 'mouseup', onMouseup);
- this.instance.on('onDestroy', () => {
- $.off(document.body, 'mouseup', onMouseup);
- });
-
- const onMouseMove = (e) => {
- if (!isDragging) return;
- let delta = e.pageX - startX;
- if (this.options.direction === 'rtl') {
- delta = -1 * delta;
- }
- const finalWidth = startWidth + delta;
- const {
- colIndex
- } = $.data($resizingCell);
-
- let columnMinWidth = this.options.minimumColumnWidth;
- if (columnMinWidth > finalWidth) {
- // don't resize past 30 pixels
- return;
- }
- this.datamanager.updateColumn(colIndex, {
- width: finalWidth
- });
- this.setColumnHeaderWidth(colIndex);
- };
- $.on(document.body, 'mousemove', onMouseMove);
- this.instance.on('onDestroy', () => {
- $.off(document.body, 'mousemove', onMouseMove);
- });
- }
-
- bindPerfectColumnWidth() {
- $.on(this.header, 'dblclick', '.dt-cell .dt-cell__resize-handle', (e, $handle) => {
- const $cell = $handle.parentNode.parentNode;
- const { colIndex } = $.data($cell);
-
- let longestCell = this.bodyRenderer.visibleRows
- .map(d => d[colIndex])
- .reduce((acc, curr) => acc.content.length > curr.content.length ? acc : curr);
-
- let $longestCellHTML = this.cellmanager.getCellHTML(longestCell);
- let $div = document.createElement('div');
- $div.innerHTML = $longestCellHTML;
- let cellText = $div.querySelector('.dt-cell__content').textContent;
-
- let {
- borderLeftWidth,
- borderRightWidth,
- paddingLeft,
- paddingRight
- } = $.getStyle(this.bodyScrollable.querySelector('.dt-cell__content'));
-
- let padding = [borderLeftWidth, borderRightWidth, paddingLeft, paddingRight]
- .map(parseFloat)
- .reduce((sum, val) => sum + val);
-
- let width = $.measureTextWidth(cellText) + padding;
- this.datamanager.updateColumn(colIndex, { width });
- this.setColumnHeaderWidth(colIndex);
- this.setColumnWidth(colIndex);
- });
- }
-
- bindMoveColumn() {
- if (this.options.disableReorderColumn) return;
-
- const $parent = $('.dt-row', this.header);
-
- this.sortable = Sortable.create($parent, {
- onEnd: (e) => {
- const {
- oldIndex,
- newIndex
- } = e;
- const $draggedCell = e.item;
- const {
- colIndex
- } = $.data($draggedCell);
- if (+colIndex === newIndex) return;
-
- this.switchColumn(oldIndex, newIndex);
- },
- preventOnFilter: false,
- filter: '.dt-cell__resize-handle, .dt-dropdown',
- chosenClass: 'dt-cell--dragging',
- animation: 150
- });
- }
-
- sortColumn(colIndex, nextSortOrder) {
- this.instance.freeze();
- this.sortRows(colIndex, nextSortOrder)
- .then(() => {
- this.refreshHeader();
- return this.rowmanager.refreshRows();
- })
- .then(() => this.instance.unfreeze())
- .then(() => {
- this.fireEvent('onSortColumn', this.getColumn(colIndex));
- });
- }
-
- removeColumn(colIndex) {
- const removedCol = this.getColumn(colIndex);
- this.instance.freeze();
- this.datamanager.removeColumn(colIndex)
- .then(() => {
- this.refreshHeader();
- return this.rowmanager.refreshRows();
- })
- .then(() => this.instance.unfreeze())
- .then(() => {
- this.fireEvent('onRemoveColumn', removedCol);
- });
- }
-
- switchColumn(oldIndex, newIndex) {
- this.instance.freeze();
- this.datamanager.switchColumn(oldIndex, newIndex)
- .then(() => {
- this.refreshHeader();
- return this.rowmanager.refreshRows();
- })
- .then(() => {
- this.setColumnWidth(oldIndex);
- this.setColumnWidth(newIndex);
- this.instance.unfreeze();
- })
- .then(() => {
- this.fireEvent('onSwitchColumn',
- this.getColumn(oldIndex), this.getColumn(newIndex)
- );
- });
- }
-
- toggleFilter(flag) {
- if (!this.options.inlineFilters) return;
-
- let showFilter;
- if (flag === undefined) {
- showFilter = !this.isFilterShown;
- } else {
- showFilter = flag;
- }
-
- if (showFilter) {
- $.style(this.$filterRow, { display: '' });
- } else {
- $.style(this.$filterRow, { display: 'none' });
- }
-
- this.isFilterShown = showFilter;
- this.style.setBodyStyle();
- }
-
- focusFilter(colIndex) {
- if (!this.isFilterShown) return;
-
- const $filterInput = $(`.dt-cell--col-${colIndex} .dt-filter`, this.$filterRow);
- $filterInput.focus();
- }
-
- bindFilter() {
- if (!this.options.inlineFilters) return;
- const handler = e => {
- this.applyFilter(this.getAppliedFilters());
- };
- $.on(this.header, 'keydown', '.dt-filter', debounce$1(handler, 300));
- }
-
- applyFilter(filters) {
- this.datamanager.filterRows(filters)
- .then(({
- rowsToShow
- }) => {
- this.rowmanager.showRows(rowsToShow);
- });
- }
-
- getAppliedFilters() {
- const filters = {};
- $.each('.dt-filter', this.header).map((input) => {
- const value = input.value;
- if (value) {
- filters[input.dataset.colIndex] = value;
- }
- });
- return filters;
- }
-
- applyDefaultSortOrder() {
- // sort rows if any 1 column has a default sortOrder set
- const columnsToSort = this.getColumns().filter(col => col.sortOrder !== 'none');
-
- if (columnsToSort.length === 1) {
- const column = columnsToSort[0];
- this.sortColumn(column.colIndex, column.sortOrder);
- }
- }
-
- sortRows(colIndex, sortOrder) {
- return this.datamanager.sortRows(colIndex, sortOrder);
- }
-
- getColumn(colIndex) {
- return this.datamanager.getColumn(colIndex);
- }
-
- getColumns() {
- return this.datamanager.getColumns();
- }
-
- setColumnWidth(colIndex, width) {
- colIndex = +colIndex;
-
- let columnWidth = width || this.getColumn(colIndex).width;
-
- const selector = [
- `.dt-cell__content--col-${colIndex}`,
- `.dt-cell__edit--col-${colIndex}`
- ].join(', ');
-
- const styles = {
- width: columnWidth + 'px'
- };
-
- this.style.setStyle(selector, styles);
- }
-
- setColumnHeaderWidth(colIndex) {
- colIndex = +colIndex;
- this.$columnMap = this.$columnMap || [];
- const selector = `.dt-cell__content--header-${colIndex}`;
- const {
- width
- } = this.getColumn(colIndex);
-
- let $column = this.$columnMap[colIndex];
- if (!$column) {
- $column = this.header.querySelector(selector);
- this.$columnMap[colIndex] = $column;
- }
-
- $column.style.width = width + 'px';
- }
-
- getColumnMinWidth(colIndex) {
- colIndex = +colIndex;
- return this.getColumn(colIndex).minWidth || 24;
- }
-
- getFirstColumnIndex() {
- return this.datamanager.getColumnIndexById('_rowIndex') + 1;
- }
-
- getHeaderCell$(colIndex) {
- return $(`.dt-cell--header-${colIndex}`, this.header);
- }
-
- getLastColumnIndex() {
- return this.datamanager.getColumnCount() - 1;
- }
-
- getDropdownHTML() {
- const { dropdownButton } = this.options;
-
- return `
- <div class="dt-dropdown">
- <div class="dt-dropdown__toggle">${dropdownButton}</div>
- </div>
- `;
- }
-
- getDropdownListHTML() {
- const { headerDropdown: dropdownItems } = this.options;
-
- return `
- <div class="dt-dropdown__list">
- ${dropdownItems.map((d, i) => `
- <div class="dt-dropdown__list-item" data-index="${i}">${d.label}</div>
- `).join('')}
- </div>
- `;
- }
- }
-
- class RowManager {
- constructor(instance) {
- this.instance = instance;
- linkProperties(this, this.instance, [
- 'options',
- 'fireEvent',
- 'wrapper',
- 'bodyScrollable',
- 'bodyRenderer',
- 'style'
- ]);
-
- this.bindEvents();
- this.refreshRows = nextTick(this.refreshRows, this);
- }
-
- get datamanager() {
- return this.instance.datamanager;
- }
-
- get cellmanager() {
- return this.instance.cellmanager;
- }
-
- bindEvents() {
- this.bindCheckbox();
- }
-
- bindCheckbox() {
- if (!this.options.checkboxColumn) return;
-
- // map of checked rows
- this.checkMap = [];
-
- $.on(this.wrapper, 'click', '.dt-cell--col-0 [type="checkbox"]', (e, $checkbox) => {
- const $cell = $checkbox.closest('.dt-cell');
- const {
- rowIndex,
- isHeader
- } = $.data($cell);
- const checked = $checkbox.checked;
-
- if (isHeader) {
- this.checkAll(checked);
- } else {
- this.checkRow(rowIndex, checked);
- }
- });
- }
-
- refreshRows() {
- this.instance.renderBody();
- this.instance.setDimensions();
- }
-
- refreshRow(row, rowIndex) {
- const _row = this.datamanager.updateRow(row, rowIndex);
-
- _row.forEach(cell => {
- this.cellmanager.refreshCell(cell, true);
- });
- }
-
- getCheckedRows() {
- if (!this.checkMap) {
- return [];
- }
-
- let out = [];
- for (let rowIndex in this.checkMap) {
- const checked = this.checkMap[rowIndex];
- if (checked === 1) {
- out.push(rowIndex);
- }
- }
-
- return out;
- }
-
- highlightCheckedRows() {
- this.getCheckedRows()
- .map(rowIndex => this.checkRow(rowIndex, true));
- }
-
- checkRow(rowIndex, toggle) {
- const value = toggle ? 1 : 0;
- const selector = rowIndex => `.dt-cell--0-${rowIndex} [type="checkbox"]`;
- // update internal map
- this.checkMap[rowIndex] = value;
- // set checkbox value explicitly
- $.each(selector(rowIndex), this.bodyScrollable)
- .map(input => {
- input.checked = toggle;
- });
- // highlight row
- this.highlightRow(rowIndex, toggle);
- this.showCheckStatus();
- this.fireEvent('onCheckRow', this.datamanager.getRow(rowIndex));
- }
-
- checkAll(toggle) {
- const value = toggle ? 1 : 0;
-
- // update internal map
- if (toggle) {
- this.checkMap = Array.from(Array(this.getTotalRows())).map(c => value);
- } else {
- this.checkMap = [];
- }
- // set checkbox value
- $.each('.dt-cell--col-0 [type="checkbox"]', this.bodyScrollable)
- .map(input => {
- input.checked = toggle;
- });
- // highlight all
- this.highlightAll(toggle);
- this.showCheckStatus();
- this.fireEvent('onCheckRow');
- }
-
- showCheckStatus() {
- if (!this.options.checkedRowStatus) return;
- const checkedRows = this.getCheckedRows();
- const count = checkedRows.length;
- if (count > 0) {
- let message = this.instance.translate('{count} rows selected', {
- count: count
- });
- this.bodyRenderer.showToastMessage(message);
- } else {
- this.bodyRenderer.clearToastMessage();
- }
- }
-
- highlightRow(rowIndex, toggle = true) {
- const $row = this.getRow$(rowIndex);
- if (!$row) return;
-
- if (!toggle && this.bodyScrollable.classList.contains('dt-scrollable--highlight-all')) {
- $row.classList.add('dt-row--unhighlight');
- return;
- }
-
- if (toggle && $row.classList.contains('dt-row--unhighlight')) {
- $row.classList.remove('dt-row--unhighlight');
- }
-
- this._highlightedRows = this._highlightedRows || {};
-
- if (toggle) {
- $row.classList.add('dt-row--highlight');
- this._highlightedRows[rowIndex] = $row;
- } else {
- $row.classList.remove('dt-row--highlight');
- delete this._highlightedRows[rowIndex];
- }
- }
-
- highlightAll(toggle = true) {
- if (toggle) {
- this.bodyScrollable.classList.add('dt-scrollable--highlight-all');
- } else {
- this.bodyScrollable.classList.remove('dt-scrollable--highlight-all');
- for (const rowIndex in this._highlightedRows) {
- const $row = this._highlightedRows[rowIndex];
- $row.classList.remove('dt-row--highlight');
- }
- this._highlightedRows = {};
- }
- }
-
- showRows(rowIndices) {
- rowIndices = ensureArray(rowIndices);
- const rows = rowIndices.map(rowIndex => this.datamanager.getRow(rowIndex));
- this.bodyRenderer.renderRows(rows);
- }
-
- showAllRows() {
- const rowIndices = this.datamanager.getAllRowIndices();
- this.showRows(rowIndices);
- }
-
- getChildrenToShowForNode(rowIndex) {
- const row = this.datamanager.getRow(rowIndex);
- row.meta.isTreeNodeClose = false;
-
- return this.datamanager.getImmediateChildren(rowIndex);
- }
-
- openSingleNode(rowIndex) {
- const childrenToShow = this.getChildrenToShowForNode(rowIndex);
- const visibleRowIndices = this.bodyRenderer.visibleRowIndices;
- const rowsToShow = uniq$1([...childrenToShow, ...visibleRowIndices]).sort(numberSortAsc);
-
- this.showRows(rowsToShow);
- }
-
- getChildrenToHideForNode(rowIndex) {
- const row = this.datamanager.getRow(rowIndex);
- row.meta.isTreeNodeClose = true;
-
- const rowsToHide = this.datamanager.getChildren(rowIndex);
- rowsToHide.forEach(rowIndex => {
- const row = this.datamanager.getRow(rowIndex);
- if (!row.meta.isLeaf) {
- row.meta.isTreeNodeClose = true;
- }
- });
-
- return rowsToHide;
- }
-
- closeSingleNode(rowIndex) {
- const rowsToHide = this.getChildrenToHideForNode(rowIndex);
- const visibleRows = this.bodyRenderer.visibleRowIndices;
- const rowsToShow = visibleRows
- .filter(rowIndex => !rowsToHide.includes(rowIndex))
- .sort(numberSortAsc);
-
- this.showRows(rowsToShow);
- }
-
- expandAllNodes() {
- let rows = this.datamanager.getRows();
- let rootNodes = rows.filter(row => !row.meta.isLeaf);
-
- const childrenToShow = rootNodes.map(row => this.getChildrenToShowForNode(row.meta.rowIndex)).flat();
- const visibleRowIndices = this.bodyRenderer.visibleRowIndices;
- const rowsToShow = uniq$1([...childrenToShow, ...visibleRowIndices]).sort(numberSortAsc);
-
- this.showRows(rowsToShow);
- }
-
- collapseAllNodes() {
- let rows = this.datamanager.getRows();
- let rootNodes = rows.filter(row => row.meta.indent === 0);
-
- const rowsToHide = rootNodes.map(row => this.getChildrenToHideForNode(row.meta.rowIndex)).flat();
- const visibleRows = this.bodyRenderer.visibleRowIndices;
- const rowsToShow = visibleRows
- .filter(rowIndex => !rowsToHide.includes(rowIndex))
- .sort(numberSortAsc);
-
- this.showRows(rowsToShow);
- }
-
- setTreeDepth(depth) {
- let rows = this.datamanager.getRows();
-
- const rowsToOpen = rows.filter(row => row.meta.indent < depth);
- const rowsToClose = rows.filter(row => row.meta.indent >= depth);
- const rowsToHide = rowsToClose.filter(row => row.meta.indent > depth);
-
- rowsToClose.forEach(row => {
- if (!row.meta.isLeaf) {
- row.meta.isTreeNodeClose = true;
- }
- });
- rowsToOpen.forEach(row => {
- if (!row.meta.isLeaf) {
- row.meta.isTreeNodeClose = false;
- }
- });
-
- const rowsToShow = rows
- .filter(row => !rowsToHide.includes(row))
- .map(row => row.meta.rowIndex)
- .sort(numberSortAsc);
- this.showRows(rowsToShow);
- }
-
- getRow$(rowIndex) {
- return $(this.selector(rowIndex), this.bodyScrollable);
- }
-
- getTotalRows() {
- return this.datamanager.getRowCount();
- }
-
- getFirstRowIndex() {
- return 0;
- }
-
- getLastRowIndex() {
- return this.datamanager.getRowCount() - 1;
- }
-
- scrollToRow(rowIndex) {
- rowIndex = +rowIndex;
- this._lastScrollTo = this._lastScrollTo || 0;
- const $row = this.getRow$(rowIndex);
- if ($.inViewport($row, this.bodyScrollable)) return;
-
- const {
- height
- } = $row.getBoundingClientRect();
- const {
- top,
- bottom
- } = this.bodyScrollable.getBoundingClientRect();
- const rowsInView = Math.floor((bottom - top) / height);
-
- let offset = 0;
- if (rowIndex > this._lastScrollTo) {
- offset = height * ((rowIndex + 1) - rowsInView);
- } else {
- offset = height * ((rowIndex + 1) - 1);
- }
-
- this._lastScrollTo = rowIndex;
- $.scrollTop(this.bodyScrollable, offset);
- }
-
- getRowHTML(row, props) {
- const dataAttr = makeDataAttributeString(props);
- let rowIdentifier = props.rowIndex;
-
- if (props.isFilter) {
- row = row.map(cell => (Object.assign({}, cell, {
- content: this.getFilterInput({
- colIndex: cell.colIndex,
- name: cell.name
- }),
- isFilter: 1,
- isHeader: undefined,
- editable: false
- })));
-
- rowIdentifier = 'filter';
- }
-
- if (props.isHeader) {
- rowIdentifier = 'header';
- }
-
- return `
- <div class="dt-row dt-row-${rowIdentifier}" ${dataAttr}>
- ${row.map(cell => this.cellmanager.getCellHTML(cell)).join('')}
- </div>
- `;
- }
-
- getFilterInput(props) {
- let title = `title="Filter based on ${props.name || 'Index'}"`;
- const dataAttr = makeDataAttributeString(props);
- return `<input class="dt-filter dt-input" type="text" ${dataAttr} tabindex="1"
- ${props.colIndex === 0 ? 'disabled' : title} />`;
- }
-
- selector(rowIndex) {
- return `.dt-row-${rowIndex}`;
- }
- }
-
- var hyperlist = createCommonjsModule(function (module, exports) {
- (function(f){{module.exports=f();}})(function(){return (function(){function r(e,n,t){function o(i,f){if(!n[i]){if(!e[i]){var c="function"==typeof commonjsRequire&&commonjsRequire;if(!f&&c)return c(i,!0);if(u)return u(i,!0);var a=new Error("Cannot find module '"+i+"'");throw a.code="MODULE_NOT_FOUND",a}var p=n[i]={exports:{}};e[i][0].call(p.exports,function(r){var n=e[i][1][r];return o(n||r)},p,p.exports,r,e,n,t);}return n[i].exports}for(var u="function"==typeof commonjsRequire&&commonjsRequire,i=0;i<t.length;i++)o(t[i]);return o}return r})()({1:[function(_dereq_,module,exports){
-
- // Default configuration.
-
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
-
- var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
-
- function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
-
- function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
-
- var defaultConfig = {
- width: '100%',
- height: '100%'
-
- // Check for valid number.
- };var isNumber = function isNumber(input) {
- return Number(input) === Number(input);
- };
-
- // Add a class to an element.
- var addClass = 'classList' in document.documentElement ? function (element, className) {
- element.classList.add(className);
- } : function (element, className) {
- var oldClass = element.getAttribute('class') || '';
- element.setAttribute('class', oldClass + ' ' + className);
- };
-
- /**
- * Creates a HyperList instance that virtually scrolls very large amounts of
- * data effortlessly.
- */
-
- var HyperList = function () {
- _createClass(HyperList, null, [{
- key: 'create',
- value: function create(element, userProvidedConfig) {
- return new HyperList(element, userProvidedConfig);
- }
-
- /**
- * Merge given css style on an element
- * @param {DOMElement} element
- * @param {Object} style
- */
-
- }, {
- key: 'mergeStyle',
- value: function mergeStyle(element, style) {
- for (var i in style) {
- if (element.style[i] !== style[i]) {
- element.style[i] = style[i];
- }
- }
- }
- }, {
- key: 'getMaxBrowserHeight',
- value: function getMaxBrowserHeight() {
- // Create two elements, the wrapper is `1px` tall and is transparent and
- // positioned at the top of the page. Inside that is an element that gets
- // set to 1 billion pixels. Then reads the max height the browser can
- // calculate.
- var wrapper = document.createElement('div');
- var fixture = document.createElement('div');
-
- // As said above, these values get set to put the fixture elements into the
- // right visual state.
- HyperList.mergeStyle(wrapper, { position: 'absolute', height: '1px', opacity: 0 });
- HyperList.mergeStyle(fixture, { height: '1e7px' });
-
- // Add the fixture into the wrapper element.
- wrapper.appendChild(fixture);
-
- // Apply to the page, the values won't kick in unless this is attached.
- document.body.appendChild(wrapper);
-
- // Get the maximum element height in pixels.
- var maxElementHeight = fixture.offsetHeight;
-
- // Remove the element immediately after reading the value.
- document.body.removeChild(wrapper);
-
- return maxElementHeight;
- }
- }]);
-
- function HyperList(element, userProvidedConfig) {
- var _this = this;
-
- _classCallCheck(this, HyperList);
-
- this._config = {};
- this._lastRepaint = null;
- this._maxElementHeight = HyperList.getMaxBrowserHeight();
-
- this.refresh(element, userProvidedConfig);
-
- var config = this._config;
-
- // Create internal render loop.
- var render = function render() {
- var scrollTop = _this._getScrollPosition();
- var lastRepaint = _this._lastRepaint;
-
- _this._renderAnimationFrame = window.requestAnimationFrame(render);
-
- if (scrollTop === lastRepaint) {
- return;
- }
-
- var diff = lastRepaint ? scrollTop - lastRepaint : 0;
- if (!lastRepaint || diff < 0 || diff > _this._averageHeight) {
- var rendered = _this._renderChunk();
-
- _this._lastRepaint = scrollTop;
-
- if (rendered !== false && typeof config.afterRender === 'function') {
- config.afterRender();
- }
- }
- };
-
- render();
- }
-
- _createClass(HyperList, [{
- key: 'destroy',
- value: function destroy() {
- window.cancelAnimationFrame(this._renderAnimationFrame);
- }
- }, {
- key: 'refresh',
- value: function refresh(element, userProvidedConfig) {
- var _scrollerStyle;
-
- Object.assign(this._config, defaultConfig, userProvidedConfig);
-
- if (!element || element.nodeType !== 1) {
- throw new Error('HyperList requires a valid DOM Node container');
- }
-
- this._element = element;
-
- var config = this._config;
-
- var scroller = this._scroller || config.scroller || document.createElement(config.scrollerTagName || 'tr');
-
- // Default configuration option `useFragment` to `true`.
- if (typeof config.useFragment !== 'boolean') {
- this._config.useFragment = true;
- }
-
- if (!config.generate) {
- throw new Error('Missing required `generate` function');
- }
-
- if (!isNumber(config.total)) {
- throw new Error('Invalid required `total` value, expected number');
- }
-
- if (!Array.isArray(config.itemHeight) && !isNumber(config.itemHeight)) {
- throw new Error('\n Invalid required `itemHeight` value, expected number or array\n '.trim());
- } else if (isNumber(config.itemHeight)) {
- this._itemHeights = Array(config.total).fill(config.itemHeight);
- } else {
- this._itemHeights = config.itemHeight;
- }
-
- // Width and height should be coerced to string representations. Either in
- // `%` or `px`.
- Object.keys(defaultConfig).filter(function (prop) {
- return prop in config;
- }).forEach(function (prop) {
- var value = config[prop];
- var isValueNumber = isNumber(value);
-
- if (value && typeof value !== 'string' && typeof value !== 'number') {
- var msg = 'Invalid optional `' + prop + '`, expected string or number';
- throw new Error(msg);
- } else if (isValueNumber) {
- config[prop] = value + 'px';
- }
- });
-
- var isHoriz = Boolean(config.horizontal);
- var value = config[isHoriz ? 'width' : 'height'];
-
- if (value) {
- var isValueNumber = isNumber(value);
- var isValuePercent = isValueNumber ? false : value.slice(-1) === '%';
- // Compute the containerHeight as number
- var numberValue = isValueNumber ? value : parseInt(value.replace(/px|%/, ''), 10);
- var innerSize = window[isHoriz ? 'innerWidth' : 'innerHeight'];
-
- if (isValuePercent) {
- this._containerSize = innerSize * numberValue / 100;
- } else {
- this._containerSize = isNumber(value) ? value : numberValue;
- }
- }
-
- var scrollContainer = config.scrollContainer;
- var scrollerHeight = config.itemHeight * config.total;
- var maxElementHeight = this._maxElementHeight;
-
- if (scrollerHeight > maxElementHeight) {
- console.warn(['HyperList: The maximum element height', maxElementHeight + 'px has', 'been exceeded; please reduce your item height.'].join(' '));
- }
-
- // Decorate the container element with styles that will match
- // the user supplied configuration.
- var elementStyle = {
- width: '' + config.width,
- height: scrollContainer ? scrollerHeight + 'px' : '' + config.height,
- overflow: scrollContainer ? 'none' : 'auto',
- position: 'relative'
- };
-
- HyperList.mergeStyle(element, elementStyle);
-
- if (scrollContainer) {
- HyperList.mergeStyle(config.scrollContainer, { overflow: 'auto' });
- }
-
- var scrollerStyle = (_scrollerStyle = {
- opacity: '0',
- position: 'absolute'
- }, _defineProperty(_scrollerStyle, isHoriz ? 'height' : 'width', '1px'), _defineProperty(_scrollerStyle, isHoriz ? 'width' : 'height', scrollerHeight + 'px'), _scrollerStyle);
-
- HyperList.mergeStyle(scroller, scrollerStyle);
-
- // Only append the scroller element once.
- if (!this._scroller) {
- element.appendChild(scroller);
- }
-
- var padding = this._computeScrollPadding();
- this._scrollPaddingBottom = padding.bottom;
- this._scrollPaddingTop = padding.top;
-
- // Set the scroller instance.
- this._scroller = scroller;
- this._scrollHeight = this._computeScrollHeight();
-
- // Reuse the item positions if refreshed, otherwise set to empty array.
- this._itemPositions = this._itemPositions || Array(config.total).fill(0);
-
- // Each index in the array should represent the position in the DOM.
- this._computePositions(0);
-
- // Render after refreshing. Force render if we're calling refresh manually.
- this._renderChunk(this._lastRepaint !== null);
-
- if (typeof config.afterRender === 'function') {
- config.afterRender();
- }
- }
- }, {
- key: '_getRow',
- value: function _getRow(i) {
- var config = this._config;
- var item = config.generate(i);
- var height = item.height;
-
- if (height !== undefined && isNumber(height)) {
- item = item.element;
-
- // The height isn't the same as predicted, compute positions again
- if (height !== this._itemHeights[i]) {
- this._itemHeights[i] = height;
- this._computePositions(i);
- this._scrollHeight = this._computeScrollHeight(i);
- }
- } else {
- height = this._itemHeights[i];
- }
-
- if (!item || item.nodeType !== 1) {
- throw new Error('Generator did not return a DOM Node for index: ' + i);
- }
-
- addClass(item, config.rowClassName || 'vrow');
-
- var top = this._itemPositions[i] + this._scrollPaddingTop;
-
- HyperList.mergeStyle(item, _defineProperty({
- position: 'absolute'
- }, config.horizontal ? 'left' : 'top', top + 'px'));
-
- return item;
- }
- }, {
- key: '_getScrollPosition',
- value: function _getScrollPosition() {
- var config = this._config;
-
- if (typeof config.overrideScrollPosition === 'function') {
- return config.overrideScrollPosition();
- }
-
- return this._element[config.horizontal ? 'scrollLeft' : 'scrollTop'];
- }
- }, {
- key: '_renderChunk',
- value: function _renderChunk(force) {
- var config = this._config;
- var element = this._element;
- var scrollTop = this._getScrollPosition();
- var total = config.total;
-
- var from = config.reverse ? this._getReverseFrom(scrollTop) : this._getFrom(scrollTop) - 1;
-
- if (from < 0 || from - this._screenItemsLen < 0) {
- from = 0;
- }
-
- if (!force && this._lastFrom === from) {
- return false;
- }
-
- this._lastFrom = from;
-
- var to = from + this._cachedItemsLen;
-
- if (to > total || to + this._cachedItemsLen > total) {
- to = total;
- }
-
- // Append all the new rows in a document fragment that we will later append
- // to the parent node
- var fragment = config.useFragment ? document.createDocumentFragment() : []
- // Sometimes you'll pass fake elements to this tool and Fragments require
- // real elements.
-
-
- // The element that forces the container to scroll.
- ;var scroller = this._scroller;
-
- // Keep the scroller in the list of children.
- fragment[config.useFragment ? 'appendChild' : 'push'](scroller);
-
- for (var i = from; i < to; i++) {
- var row = this._getRow(i);
-
- fragment[config.useFragment ? 'appendChild' : 'push'](row);
- }
-
- if (config.applyPatch) {
- return config.applyPatch(element, fragment);
- }
-
- element.innerHTML = '';
- element.appendChild(fragment);
- }
- }, {
- key: '_computePositions',
- value: function _computePositions() {
- var from = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 1;
-
- var config = this._config;
- var total = config.total;
- var reverse = config.reverse;
-
- if (from < 1 && !reverse) {
- from = 1;
- }
-
- for (var i = from; i < total; i++) {
- if (reverse) {
- if (i === 0) {
- this._itemPositions[0] = this._scrollHeight - this._itemHeights[0];
- } else {
- this._itemPositions[i] = this._itemPositions[i - 1] - this._itemHeights[i];
- }
- } else {
- this._itemPositions[i] = this._itemHeights[i - 1] + this._itemPositions[i - 1];
- }
- }
- }
- }, {
- key: '_computeScrollHeight',
- value: function _computeScrollHeight() {
- var _HyperList$mergeStyle2,
- _this2 = this;
-
- var config = this._config;
- var isHoriz = Boolean(config.horizontal);
- var total = config.total;
- var scrollHeight = this._itemHeights.reduce(function (a, b) {
- return a + b;
- }, 0) + this._scrollPaddingBottom + this._scrollPaddingTop;
-
- HyperList.mergeStyle(this._scroller, (_HyperList$mergeStyle2 = {
- opacity: 0,
- position: 'absolute',
- top: '0px'
- }, _defineProperty(_HyperList$mergeStyle2, isHoriz ? 'height' : 'width', '1px'), _defineProperty(_HyperList$mergeStyle2, isHoriz ? 'width' : 'height', scrollHeight + 'px'), _HyperList$mergeStyle2));
-
- // Calculate the height median
- var sortedItemHeights = this._itemHeights.slice(0).sort(function (a, b) {
- return a - b;
- });
- var middle = Math.floor(total / 2);
- var averageHeight = total % 2 === 0 ? (sortedItemHeights[middle] + sortedItemHeights[middle - 1]) / 2 : sortedItemHeights[middle];
-
- var clientProp = isHoriz ? 'clientWidth' : 'clientHeight';
- var element = config.scrollContainer ? config.scrollContainer : this._element;
- var containerHeight = element[clientProp] ? element[clientProp] : this._containerSize;
- this._screenItemsLen = Math.ceil(containerHeight / averageHeight);
- this._containerSize = containerHeight;
-
- // Cache 3 times the number of items that fit in the container viewport.
- this._cachedItemsLen = Math.max(this._cachedItemsLen || 0, this._screenItemsLen * 3);
- this._averageHeight = averageHeight;
-
- if (config.reverse) {
- window.requestAnimationFrame(function () {
- if (isHoriz) {
- _this2._element.scrollLeft = scrollHeight;
- } else {
- _this2._element.scrollTop = scrollHeight;
- }
- });
- }
-
- return scrollHeight;
- }
- }, {
- key: '_computeScrollPadding',
- value: function _computeScrollPadding() {
- var config = this._config;
- var isHoriz = Boolean(config.horizontal);
- var isReverse = config.reverse;
- var styles = window.getComputedStyle(this._element);
-
- var padding = function padding(location) {
- var cssValue = styles.getPropertyValue('padding-' + location);
- return parseInt(cssValue, 10) || 0;
- };
-
- if (isHoriz && isReverse) {
- return {
- bottom: padding('left'),
- top: padding('right')
- };
- } else if (isHoriz) {
- return {
- bottom: padding('right'),
- top: padding('left')
- };
- } else if (isReverse) {
- return {
- bottom: padding('top'),
- top: padding('bottom')
- };
- } else {
- return {
- bottom: padding('bottom'),
- top: padding('top')
- };
- }
- }
- }, {
- key: '_getFrom',
- value: function _getFrom(scrollTop) {
- var i = 0;
-
- while (this._itemPositions[i] < scrollTop) {
- i++;
- }
-
- return i;
- }
- }, {
- key: '_getReverseFrom',
- value: function _getReverseFrom(scrollTop) {
- var i = this._config.total - 1;
-
- while (i > 0 && this._itemPositions[i] < scrollTop + this._containerSize) {
- i--;
- }
-
- return i;
- }
- }]);
-
- return HyperList;
- }();
-
- exports.default = HyperList;
- module.exports = exports['default'];
-
- },{}]},{},[1])(1)
- });
- });
-
- var HyperList = unwrapExports(hyperlist);
-
- class BodyRenderer {
- constructor(instance) {
- this.instance = instance;
- this.options = instance.options;
- this.datamanager = instance.datamanager;
- this.rowmanager = instance.rowmanager;
- this.cellmanager = instance.cellmanager;
- this.bodyScrollable = instance.bodyScrollable;
- this.footer = this.instance.footer;
- this.log = instance.log;
- }
-
- renderRows(rows) {
- this.visibleRows = rows;
- this.visibleRowIndices = rows.map(row => row.meta.rowIndex);
-
- if (rows.length === 0) {
- this.bodyScrollable.innerHTML = this.getNoDataHTML();
- return;
- }
-
- const rowViewOrder = this.datamanager.rowViewOrder.map(index => {
- if (this.visibleRowIndices.includes(index)) {
- return index;
- }
- return null;
- }).filter(index => index !== null);
-
- const computedStyle = getComputedStyle(this.bodyScrollable);
-
- let config = {
- width: computedStyle.width,
- height: computedStyle.height,
- itemHeight: this.options.cellHeight,
- total: rows.length,
- generate: (index) => {
- const el = document.createElement('div');
- const rowIndex = rowViewOrder[index];
- const row = this.datamanager.getRow(rowIndex);
- const rowHTML = this.rowmanager.getRowHTML(row, row.meta);
- el.innerHTML = rowHTML;
- return el.children[0];
- },
- afterRender: () => {
- this.restoreState();
- }
- };
-
- if (!this.hyperlist) {
- this.hyperlist = new HyperList(this.bodyScrollable, config);
- } else {
- this.hyperlist.refresh(this.bodyScrollable, config);
- }
-
- this.renderFooter();
- }
-
- render() {
- const rows = this.datamanager.getRowsForView();
- this.renderRows(rows);
- // setDimensions requires atleast 1 row to exist in dom
- this.instance.setDimensions();
- }
-
- renderFooter() {
- if (!this.options.showTotalRow) return;
-
- const totalRow = this.getTotalRow();
- let html = this.rowmanager.getRowHTML(totalRow, { isTotalRow: 1, rowIndex: 'totalRow' });
-
- this.footer.innerHTML = html;
- }
-
- getTotalRow() {
- const columns = this.datamanager.getColumns();
- const totalRowTemplate = columns.map(col => {
- let content = null;
- if (['_rowIndex', '_checkbox'].includes(col.id)) {
- content = '';
- }
- return {
- content,
- isTotalRow: 1,
- colIndex: col.colIndex,
- column: col
- };
- });
-
- const totalRow = totalRowTemplate.map((cell, i) => {
- if (cell.content === '') return cell;
-
- if (this.options.hooks.columnTotal) {
- const columnValues = this.visibleRows.map(row => row[i].content);
- const result = this.options.hooks.columnTotal.call(this.instance, columnValues, cell);
- if (result != null) {
- cell.content = result;
- return cell;
- }
- }
-
- cell.content = this.visibleRows.reduce((acc, prevRow) => {
- const prevCell = prevRow[i];
- if (typeof prevCell.content === 'number') {
- if (acc == null) acc = 0;
- return acc + prevCell.content;
- }
- return acc;
- }, cell.content);
-
- return cell;
- });
-
- return totalRow;
- }
-
- restoreState() {
- this.rowmanager.highlightCheckedRows();
- this.cellmanager.selectAreaOnClusterChanged();
- this.cellmanager.focusCellOnClusterChanged();
- }
-
- showToastMessage(message, hideAfter) {
- this.instance.toastMessage.innerHTML = this.getToastMessageHTML(message);
-
- if (hideAfter) {
- setTimeout(() => {
- this.clearToastMessage();
- }, hideAfter * 1000);
- }
- }
-
- clearToastMessage() {
- this.instance.toastMessage.innerHTML = '';
- }
-
- getNoDataHTML() {
- return `<div class="dt-scrollable__no-data">${this.options.noDataMessage}</div>`;
- }
-
- getToastMessageHTML(message) {
- return `<span class="dt-toast__message">${message}</span>`;
- }
- }
-
- class Style {
- constructor(instance) {
- this.instance = instance;
-
- linkProperties(this, this.instance, [
- 'options', 'datamanager', 'columnmanager',
- 'header', 'footer', 'bodyScrollable', 'datatableWrapper',
- 'getColumn', 'bodyRenderer'
- ]);
-
- this.scopeClass = 'dt-instance-' + instance.constructor.instances;
- instance.datatableWrapper.classList.add(this.scopeClass);
-
- const styleEl = document.createElement('style');
- instance.wrapper.insertBefore(styleEl, instance.datatableWrapper);
- this.styleEl = styleEl;
-
- this.bindResizeWindow();
- this.bindScrollHeader();
- }
-
- get stylesheet() {
- return this.styleEl.sheet;
- }
-
- bindResizeWindow() {
- this.onWindowResize = this.onWindowResize.bind(this);
- this.onWindowResize = throttle$1(this.onWindowResize, 300);
-
- if (this.options.layout === 'fluid') {
- $.on(window, 'resize', this.onWindowResize);
- }
- }
-
- bindScrollHeader() {
- this._settingHeaderPosition = false;
-
- $.on(this.bodyScrollable, 'scroll', (e) => {
- if (this._settingHeaderPosition) return;
-
- this._settingHeaderPosition = true;
-
- requestAnimationFrame(() => {
- const left = -e.target.scrollLeft;
-
- $.style(this.header, {
- transform: `translateX(${left}px)`
- });
- $.style(this.footer, {
- transform: `translateX(${left}px)`
- });
- this._settingHeaderPosition = false;
- });
- });
- }
-
- onWindowResize() {
- this.distributeRemainingWidth();
- this.refreshColumnWidth();
- this.setBodyStyle();
- }
-
- destroy() {
- this.styleEl.remove();
- $.off(window, 'resize', this.onWindowResize);
- }
-
- setStyle(selector, styleObject) {
- if (selector.includes(',')) {
- selector.split(',')
- .map(s => s.trim())
- .forEach(selector => {
- this.setStyle(selector, styleObject);
- });
- return;
- }
-
- selector = selector.trim();
- if (!selector) return;
-
- this._styleRulesMap = this._styleRulesMap || {};
- const prefixedSelector = this._getPrefixedSelector(selector);
-
- if (this._styleRulesMap[prefixedSelector]) {
- this.removeStyle(selector);
-
- // merge with old styleobject
- styleObject = Object.assign({}, this._styleRulesMap[prefixedSelector], styleObject);
- }
-
- const styleString = this._getRuleString(styleObject);
- const ruleString = `${prefixedSelector} { ${styleString} }`;
-
- this._styleRulesMap[prefixedSelector] = styleObject;
- this.stylesheet.insertRule(ruleString);
- }
-
- removeStyle(selector) {
- if (selector.includes(',')) {
- selector.split(',')
- .map(s => s.trim())
- .forEach(selector => {
- this.removeStyle(selector);
- });
- return;
- }
-
- selector = selector.trim();
- if (!selector) return;
-
- // find and remove
- const prefixedSelector = this._getPrefixedSelector(selector);
- const index = Array.from(this.stylesheet.cssRules)
- .findIndex(rule => rule.selectorText === prefixedSelector);
-
- if (index === -1) return;
- this.stylesheet.deleteRule(index);
- }
-
- _getPrefixedSelector(selector) {
- return `.${this.scopeClass} ${selector}`;
- }
-
- _getRuleString(styleObject) {
- return Object.keys(styleObject)
- .map(prop => {
- let dashed = prop;
- if (!prop.includes('-')) {
- dashed = camelCaseToDash(prop);
- }
- return `${dashed}:${styleObject[prop]};`;
- })
- .join('');
- }
-
- setDimensions() {
- this.setCellHeight();
- this.setupMinWidth();
- this.setupNaturalColumnWidth();
- this.setupColumnWidth();
- this.distributeRemainingWidth();
- this.setColumnStyle();
- this.setBodyStyle();
- }
-
- setCellHeight() {
- this.setStyle('.dt-cell', {
- height: this.options.cellHeight + 'px'
- });
- }
-
- setupMinWidth() {
- $.each('.dt-cell--header', this.header).map(col => {
- const { colIndex } = $.data(col);
- const column = this.getColumn(colIndex);
-
- if (!column.minWidth) {
- const width = $.style($('.dt-cell__content', col), 'width');
- // only set this once
- column.minWidth = width;
- }
- });
- }
-
- setupNaturalColumnWidth() {
- if (!$('.dt-row')) return;
-
- $.each('.dt-row-header .dt-cell', this.header).map($headerCell => {
- const { colIndex } = $.data($headerCell);
- const column = this.datamanager.getColumn(colIndex);
- let width = $.style($('.dt-cell__content', $headerCell), 'width');
- if (typeof width === 'number' && width >= this.options.minimumColumnWidth) {
- column.naturalWidth = width;
- } else {
- column.naturalWidth = this.options.minimumColumnWidth;
- }
- });
-
- // set initial width as naturally calculated by table's first row
- $.each('.dt-row-0 .dt-cell', this.bodyScrollable).map($cell => {
- const {
- colIndex
- } = $.data($cell);
- const column = this.datamanager.getColumn(colIndex);
-
- let naturalWidth = $.style($('.dt-cell__content', $cell), 'width');
-
- if (typeof naturalWidth === 'number' && naturalWidth >= column.naturalWidth) {
- column.naturalWidth = naturalWidth;
- } else {
- column.naturalWidth = column.naturalWidth;
- }
- });
- }
-
- setupColumnWidth() {
- if (this.options.layout === 'ratio') {
- let totalWidth = $.style(this.datatableWrapper, 'width');
-
- if (this.options.serialNoColumn) {
- const rowIndexColumn = this.datamanager.getColumnById('_rowIndex');
- totalWidth = totalWidth - rowIndexColumn.width - 1;
- }
-
- if (this.options.checkboxColumn) {
- const rowIndexColumn = this.datamanager.getColumnById('_checkbox');
- totalWidth = totalWidth - rowIndexColumn.width - 1;
- }
-
- const totalParts = this.datamanager.getColumns()
- .map(column => {
- if (column.id === '_rowIndex' || column.id === '_checkbox') {
- return 0;
- }
- if (!column.width) {
- column.width = 1;
- }
- column.ratioWidth = parseInt(column.width, 10);
- return column.ratioWidth;
- })
- .reduce((a, c) => a + c);
-
- const onePart = totalWidth / totalParts;
-
- this.datamanager.getColumns()
- .map(column => {
- if (column.id === '_rowIndex' || column.id === '_checkbox') return;
- column.width = Math.floor(onePart * column.ratioWidth) - 1;
- });
- } else {
- this.datamanager.getColumns()
- .map(column => {
- if (!column.width) {
- column.width = column.naturalWidth;
- }
- if (column.id === '_rowIndex') {
- column.width = this.getRowIndexColumnWidth();
- }
- if (column.width < this.options.minimumColumnWidth) {
- column.width = this.options.minimumColumnWidth;
- }
- });
- }
- }
-
- distributeRemainingWidth() {
- if (this.options.layout !== 'fluid') return;
-
- const wrapperWidth = $.style(this.instance.datatableWrapper, 'width');
- let firstRow = $('.dt-row', this.bodyScrollable);
- let firstRowWidth = wrapperWidth;
- if (!firstRow) {
- let headerRow = $('.dt-row', this.instance.header);
- let cellWidths = Array.from(headerRow.children)
- .map(cell => cell.offsetWidth);
- firstRowWidth = cellWidths.reduce((sum, a) => sum + a, 0);
- } else {
- firstRowWidth = $.style(firstRow, 'width');
- }
- const resizableColumns = this.datamanager.getColumns().filter(col => col.resizable);
- const deltaWidth = (wrapperWidth - firstRowWidth) / resizableColumns.length;
-
- resizableColumns.map(col => {
- const width = $.style(this.getColumnHeaderElement(col.colIndex), 'width');
- let finalWidth = Math.floor(width + deltaWidth) - 2;
-
- this.datamanager.updateColumn(col.colIndex, {
- width: finalWidth
- });
- });
- }
-
- setColumnStyle() {
- // align columns
- this.datamanager.getColumns()
- .map(column => {
- // alignment
- if (!column.align) {
- column.align = 'left';
- }
- if (!['left', 'center', 'right'].includes(column.align)) {
- column.align = 'left';
- }
- this.setStyle(`.dt-cell--col-${column.colIndex}`, {
- 'text-align': column.align
- });
-
- // width
- this.columnmanager.setColumnHeaderWidth(column.colIndex);
- this.columnmanager.setColumnWidth(column.colIndex);
- });
- }
-
- refreshColumnWidth() {
- this.datamanager.getColumns()
- .map(column => {
- this.columnmanager.setColumnHeaderWidth(column.colIndex);
- this.columnmanager.setColumnWidth(column.colIndex);
- });
- }
-
- setBodyStyle() {
- const bodyWidth = $.style(this.datatableWrapper, 'width');
- const firstRow = $('.dt-row', this.bodyScrollable);
- if (!firstRow) return;
- const rowWidth = $.style(firstRow, 'width');
-
- let width = bodyWidth > rowWidth ? rowWidth : bodyWidth;
- $.style(this.bodyScrollable, {
- width: width + 'px'
- });
-
- // remove the body height, so that it resets to it's original
- $.removeStyle(this.bodyScrollable, 'height');
-
- // when there are less rows than the container
- // adapt the container height
- let bodyHeight = $.getStyle(this.bodyScrollable, 'height');
- const scrollHeight = (this.bodyRenderer.hyperlist || {})._scrollHeight || Infinity;
- const hasHorizontalOverflow = $.hasHorizontalOverflow(this.bodyScrollable);
-
- let height;
-
- if (scrollHeight < bodyHeight) {
- height = scrollHeight;
-
- // account for scrollbar size when
- // there is horizontal overflow
- if (hasHorizontalOverflow) {
- height += $.scrollbarSize();
- }
-
- $.style(this.bodyScrollable, {
- height: height + 'px'
- });
- }
-
- const verticalOverflow = this.bodyScrollable.scrollHeight - this.bodyScrollable.offsetHeight;
- if (verticalOverflow < $.scrollbarSize()) {
- // if verticalOverflow is less than scrollbar size
- // then most likely scrollbar is causing the scroll
- // which is not needed
- $.style(this.bodyScrollable, {
- overflowY: 'hidden'
- });
- }
-
- if (this.options.layout === 'fluid') {
- $.style(this.bodyScrollable, {
- overflowX: 'hidden'
- });
- }
- }
-
- getColumnHeaderElement(colIndex) {
- colIndex = +colIndex;
- if (colIndex < 0) return null;
- return $(`.dt-cell--col-${colIndex}`, this.header);
- }
-
- getRowIndexColumnWidth() {
- const rowCount = this.datamanager.getRowCount();
- const padding = 22;
- return $.measureTextWidth(rowCount + '') + padding;
- }
- }
-
- const KEYCODES = {
- 13: 'enter',
- 91: 'meta',
- 16: 'shift',
- 17: 'ctrl',
- 18: 'alt',
- 37: 'left',
- 38: 'up',
- 39: 'right',
- 40: 'down',
- 9: 'tab',
- 27: 'esc',
- 67: 'c',
- 70: 'f',
- 86: 'v'
- };
-
- class Keyboard {
- constructor(element) {
- this.listeners = {};
- $.on(element, 'keydown', this.handler.bind(this));
- }
-
- handler(e) {
- let key = KEYCODES[e.keyCode];
-
- if (e.shiftKey && key !== 'shift') {
- key = 'shift+' + key;
- }
-
- if ((e.ctrlKey && key !== 'ctrl') || (e.metaKey && key !== 'meta')) {
- key = 'ctrl+' + key;
- }
-
- const listeners = this.listeners[key];
-
- if (listeners && listeners.length > 0) {
- for (let listener of listeners) {
- const preventBubbling = listener(e);
- if (preventBubbling === undefined || preventBubbling === true) {
- e.preventDefault();
- }
- }
- }
- }
-
- on(key, listener) {
- const keys = key.split(',').map(k => k.trim());
-
- keys.map(key => {
- this.listeners[key] = this.listeners[key] || [];
- this.listeners[key].push(listener);
- });
- }
- }
-
- var en = {
- "Sort Ascending": "Sort Ascending",
- "Sort Descending": "Sort Descending",
- "Reset sorting": "Reset sorting",
- "Remove column": "Remove column",
- "No Data": "No Data",
- "{count} cells copied": {"1":"{count} cell copied","default":"{count} cells copied"},
- "{count} rows selected": {"1":"{count} row selected","default":"{count} rows selected"}
- };
-
- var de = {
- "Sort Ascending": "Aufsteigend sortieren",
- "Sort Descending": "Absteigend sortieren",
- "Reset sorting": "Sortierung zurücksetzen",
- "Remove column": "Spalte entfernen",
- "No Data": "Keine Daten",
- "{count} cells copied": {"1":"{count} Zelle kopiert","default":"{count} Zellen kopiert"},
- "{count} rows selected": {"1":"{count} Zeile ausgewählt","default":"{count} Zeilen ausgewählt"}
- };
-
- var fr = {
- "Sort Ascending": "Trier par ordre croissant",
- "Sort Descending": "Trier par ordre décroissant",
- "Reset sorting": "Réinitialiser le tri",
- "Remove column": "Supprimer colonne",
- "No Data": "Pas de données",
- "{count} cells copied": {"1":"{count} cellule copiée","default":"{count} cellules copiées"},
- "{count} rows selected": {"1":"{count} ligne sélectionnée","default":"{count} lignes sélectionnées"}
- };
-
- var it = {
- "Sort Ascending": "Ordinamento ascendente",
- "Sort Descending": "Ordinamento decrescente",
- "Reset sorting": "Azzeramento ordinamento",
- "Remove column": "Rimuovi colonna",
- "No Data": "Nessun dato",
- "{count} cells copied": {"1":"Copiato {count} cella","default":"{count} celle copiate"},
- "{count} rows selected": {"1":"{count} linea selezionata","default":"{count} linee selezionate"}
- };
-
- function getTranslations() {
- return {
- en,
- de,
- fr,
- it,
- };
- }
-
- class TranslationManager {
- constructor(language) {
- this.language = language;
- this.translations = getTranslations();
- }
-
- addTranslations(translations) {
- this.translations = Object.assign(this.translations, translations);
- }
-
- translate(sourceText, args) {
- let translation = (this.translations[this.language] &&
- this.translations[this.language][sourceText]) || sourceText;
-
- if (typeof translation === 'object') {
- translation = args && args.count ?
- this.getPluralizedTranslation(translation, args.count) :
- sourceText;
- }
-
- return format(translation, args || {});
- }
-
- getPluralizedTranslation(translations, count) {
- return translations[count] || translations['default'];
- }
- }
-
- function filterRows(rows, filters) {
- let filteredRowIndices = [];
-
- if (Object.keys(filters).length === 0) {
- return rows.map(row => row.meta.rowIndex);
- }
-
- for (let colIndex in filters) {
- const keyword = filters[colIndex];
-
- const filteredRows = filteredRowIndices.length ?
- filteredRowIndices.map(i => rows[i]) :
- rows;
-
- const cells = filteredRows.map(row => row[colIndex]);
-
- let filter = guessFilter(keyword);
- let filterMethod = getFilterMethod(rows, filter);
-
- if (filterMethod) {
- filteredRowIndices = filterMethod(filter.text, cells);
- } else {
- filteredRowIndices = cells.map(cell => cell.rowIndex);
- }
- }
-
- return filteredRowIndices;
- }
- function getFilterMethod(rows, filter) {
- const getFormattedValue = cell => {
- let formatter = CellManager.getCustomCellFormatter(cell);
- if (formatter && cell.content) {
- cell.html = formatter(cell.content, rows[cell.rowIndex], cell.column, rows[cell.rowIndex]);
- return stripHTML(cell.html);
- }
- return cell.content || '';
- };
-
- const stringCompareValue = cell =>
- String(stripHTML(cell.html || '') || getFormattedValue(cell)).toLowerCase();
-
- const numberCompareValue = cell => parseFloat(cell.content);
-
- const getCompareValues = (cell, keyword) => {
- if (cell.column.compareValue) {
- const compareValues = cell.column.compareValue(cell, keyword);
- if (compareValues && Array.isArray(compareValues)) return compareValues;
- }
-
- // check if it can be converted to number
- const float = numberCompareValue(cell);
- if (!isNaN(float)) {
- return [float, keyword];
- }
-
- return [stringCompareValue(cell), keyword];
- };
-
- let filterMethodMap = {
- contains(keyword, cells) {
- return cells
- .filter(cell => {
- const hay = stringCompareValue(cell);
- const needle = (keyword || '').toLowerCase();
- return !needle || hay.includes(needle);
- })
- .map(cell => cell.rowIndex);
- },
-
- greaterThan(keyword, cells) {
- return cells
- .filter(cell => {
- const [compareValue, keywordValue] = getCompareValues(cell, keyword);
- return compareValue > keywordValue;
- })
- .map(cell => cell.rowIndex);
- },
-
- lessThan(keyword, cells) {
- return cells
- .filter(cell => {
- const [compareValue, keywordValue] = getCompareValues(cell, keyword);
- return compareValue < keywordValue;
- })
- .map(cell => cell.rowIndex);
- },
-
- equals(keyword, cells) {
- return cells
- .filter(cell => {
- const value = parseFloat(cell.content);
- return value === keyword;
- })
- .map(cell => cell.rowIndex);
- },
-
- notEquals(keyword, cells) {
- return cells
- .filter(cell => {
- const value = parseFloat(cell.content);
- return value !== keyword;
- })
- .map(cell => cell.rowIndex);
- },
-
- range(rangeValues, cells) {
- return cells
- .filter(cell => {
- const values1 = getCompareValues(cell, rangeValues[0]);
- const values2 = getCompareValues(cell, rangeValues[1]);
- const value = values1[0];
- return value >= values1[1] && value <= values2[1];
- })
- .map(cell => cell.rowIndex);
- },
-
- containsNumber(keyword, cells) {
- return cells
- .filter(cell => {
- let number = parseFloat(keyword, 10);
- let string = keyword;
- let hayNumber = numberCompareValue(cell);
- let hayString = stringCompareValue(cell);
-
- return number === hayNumber || hayString.includes(string);
- })
- .map(cell => cell.rowIndex);
- }
- };
-
- return filterMethodMap[filter.type];
- }
-
- function guessFilter(keyword = '') {
- if (keyword.length === 0) return {};
-
- let compareString = keyword;
-
- if (['>', '<', '='].includes(compareString[0])) {
- compareString = keyword.slice(1);
- } else if (compareString.startsWith('!=')) {
- compareString = keyword.slice(2);
- }
-
- if (keyword.startsWith('>')) {
- if (compareString) {
- return {
- type: 'greaterThan',
- text: compareString.trim()
- };
- }
- }
-
- if (keyword.startsWith('<')) {
- if (compareString) {
- return {
- type: 'lessThan',
- text: compareString.trim()
- };
- }
- }
-
- if (keyword.startsWith('=')) {
- if (isNumber(compareString)) {
- return {
- type: 'equals',
- text: Number(keyword.slice(1).trim())
- };
- }
- }
-
- if (isNumber(compareString)) {
- return {
- type: 'containsNumber',
- text: compareString
- };
- }
-
- if (keyword.startsWith('!=')) {
- if (isNumber(compareString)) {
- return {
- type: 'notEquals',
- text: Number(keyword.slice(2).trim())
- };
- }
- }
-
- if (keyword.split(':').length === 2) {
- compareString = keyword.split(':');
- return {
- type: 'range',
- text: compareString.map(v => v.trim())
- };
- }
-
- return {
- type: 'contains',
- text: compareString.toLowerCase()
- };
- }
-
- function getDefaultOptions(instance) {
- return {
- columns: [],
- data: [],
- dropdownButton: icons.chevronDown,
- headerDropdown: [
- {
- label: instance.translate('Sort Ascending'),
- action: function (column) {
- this.sortColumn(column.colIndex, 'asc');
- }
- },
- {
- label: instance.translate('Sort Descending'),
- action: function (column) {
- this.sortColumn(column.colIndex, 'desc');
- }
- },
- {
- label: instance.translate('Reset sorting'),
- action: function (column) {
- this.sortColumn(column.colIndex, 'none');
- }
- },
- {
- label: instance.translate('Remove column'),
- action: function (column) {
- this.removeColumn(column.colIndex);
- }
- }
- ],
- events: {
- onRemoveColumn(column) {},
- onSwitchColumn(column1, column2) {},
- onSortColumn(column) {},
- onCheckRow(row) {},
- onDestroy() {}
- },
- hooks: {
- columnTotal: null
- },
- sortIndicator: {
- asc: '↑',
- desc: '↓',
- none: ''
- },
- overrideComponents: {
- // ColumnManager: CustomColumnManager
- },
- filterRows: filterRows,
- freezeMessage: '',
- getEditor: null,
- serialNoColumn: true,
- checkboxColumn: false,
- clusterize: true,
- logs: false,
- layout: 'fixed', // fixed, fluid, ratio
- noDataMessage: instance.translate('No Data'),
- cellHeight: 40,
- minimumColumnWidth: 30,
- inlineFilters: false,
- treeView: false,
- checkedRowStatus: true,
- dynamicRowHeight: false,
- pasteFromClipboard: false,
- showTotalRow: false,
- direction: 'ltr',
- disableReorderColumn: false
- };
- }
-
- let defaultComponents = {
- DataManager,
- CellManager,
- ColumnManager,
- RowManager,
- BodyRenderer,
- Style,
- Keyboard
- };
-
- class DataTable {
- constructor(wrapper, options) {
- DataTable.instances++;
-
- if (typeof wrapper === 'string') {
- // css selector
- wrapper = document.querySelector(wrapper);
- }
- this.wrapper = wrapper;
- if (!(this.wrapper instanceof HTMLElement)) {
- throw new Error('Invalid argument given for `wrapper`');
- }
-
- this.initializeTranslations(options);
- this.setDefaultOptions();
- this.buildOptions(options);
- this.prepare();
- this.initializeComponents();
-
- if (this.options.data) {
- this.refresh();
- this.columnmanager.applyDefaultSortOrder();
- }
- }
-
- initializeTranslations(options) {
- this.language = options.language || 'en';
- this.translationManager = new TranslationManager(this.language);
-
- if (options.translations) {
- this.translationManager.addTranslations(options.translations);
- }
- }
-
- setDefaultOptions() {
- this.DEFAULT_OPTIONS = getDefaultOptions(this);
- }
-
- buildOptions(options) {
- this.options = this.options || {};
-
- this.options = Object.assign(
- {}, this.DEFAULT_OPTIONS,
- this.options || {}, options
- );
-
- options.headerDropdown = options.headerDropdown || [];
- this.options.headerDropdown = [
- ...this.DEFAULT_OPTIONS.headerDropdown,
- ...options.headerDropdown
- ];
-
- // custom user events
- this.events = Object.assign(
- {}, this.DEFAULT_OPTIONS.events,
- this.options.events || {},
- options.events || {}
- );
- this.fireEvent = this.fireEvent.bind(this);
- }
-
- prepare() {
- this.prepareDom();
- this.unfreeze();
- }
-
- initializeComponents() {
- let components = Object.assign({}, defaultComponents, this.options.overrideComponents);
- let {
- Style: Style$$1,
- Keyboard: Keyboard$$1,
- DataManager: DataManager$$1,
- RowManager: RowManager$$1,
- ColumnManager: ColumnManager$$1,
- CellManager: CellManager$$1,
- BodyRenderer: BodyRenderer$$1
- } = components;
-
- this.style = new Style$$1(this);
- this.keyboard = new Keyboard$$1(this.wrapper);
- this.datamanager = new DataManager$$1(this.options);
- this.rowmanager = new RowManager$$1(this);
- this.columnmanager = new ColumnManager$$1(this);
- this.cellmanager = new CellManager$$1(this);
- this.bodyRenderer = new BodyRenderer$$1(this);
- }
-
- prepareDom() {
- this.wrapper.innerHTML = `
- <div class="datatable" dir="${this.options.direction}">
- <div class="dt-header"></div>
- <div class="dt-scrollable"></div>
- <div class="dt-footer"></div>
- <div class="dt-freeze">
- <span class="dt-freeze__message">
- ${this.options.freezeMessage}
- </span>
- </div>
- <div class="dt-toast"></div>
- <div class="dt-dropdown-container"></div>
- <textarea class="dt-paste-target"></textarea>
- </div>
- `;
-
- this.datatableWrapper = $('.datatable', this.wrapper);
- this.header = $('.dt-header', this.wrapper);
- this.footer = $('.dt-footer', this.wrapper);
- this.bodyScrollable = $('.dt-scrollable', this.wrapper);
- this.freezeContainer = $('.dt-freeze', this.wrapper);
- this.toastMessage = $('.dt-toast', this.wrapper);
- this.pasteTarget = $('.dt-paste-target', this.wrapper);
- this.dropdownContainer = $('.dt-dropdown-container', this.wrapper);
- }
-
- refresh(data, columns) {
- this.datamanager.init(data, columns);
- this.render();
- this.setDimensions();
- }
-
- destroy() {
- this.wrapper.innerHTML = '';
- this.style.destroy();
- this.fireEvent('onDestroy');
- }
-
- appendRows(rows) {
- this.datamanager.appendRows(rows);
- this.rowmanager.refreshRows();
- }
-
- refreshRow(row, rowIndex) {
- this.rowmanager.refreshRow(row, rowIndex);
- }
-
- render() {
- this.renderHeader();
- this.renderBody();
- }
-
- renderHeader() {
- this.columnmanager.renderHeader();
- }
-
- renderBody() {
- this.bodyRenderer.render();
- }
-
- setDimensions() {
- this.style.setDimensions();
- }
-
- showToastMessage(message, hideAfter) {
- this.bodyRenderer.showToastMessage(message, hideAfter);
- }
-
- clearToastMessage() {
- this.bodyRenderer.clearToastMessage();
- }
-
- getColumn(colIndex) {
- return this.datamanager.getColumn(colIndex);
- }
-
- getColumns() {
- return this.datamanager.getColumns();
- }
-
- getRows() {
- return this.datamanager.getRows();
- }
-
- getCell(colIndex, rowIndex) {
- return this.datamanager.getCell(colIndex, rowIndex);
- }
-
- getColumnHeaderElement(colIndex) {
- return this.columnmanager.getColumnHeaderElement(colIndex);
- }
-
- getViewportHeight() {
- if (!this.viewportHeight) {
- this.viewportHeight = $.style(this.bodyScrollable, 'height');
- }
-
- return this.viewportHeight;
- }
-
- sortColumn(colIndex, sortOrder) {
- this.columnmanager.sortColumn(colIndex, sortOrder);
- }
-
- removeColumn(colIndex) {
- this.columnmanager.removeColumn(colIndex);
- }
-
- scrollToLastColumn() {
- this.datatableWrapper.scrollLeft = 9999;
- }
-
- freeze() {
- $.style(this.freezeContainer, {
- display: ''
- });
- }
-
- unfreeze() {
- $.style(this.freezeContainer, {
- display: 'none'
- });
- }
-
- updateOptions(options) {
- this.buildOptions(options);
- }
-
- fireEvent(eventName, ...args) {
- // fire internalEventHandlers if any
- // and then user events
- const handlers = [
- ...(this._internalEventHandlers[eventName] || []),
- this.events[eventName]
- ].filter(Boolean);
-
- for (let handler of handlers) {
- handler.apply(this, args);
- }
- }
-
- on(event, handler) {
- this._internalEventHandlers = this._internalEventHandlers || {};
- this._internalEventHandlers[event] = this._internalEventHandlers[event] || [];
- this._internalEventHandlers[event].push(handler);
- }
-
- log() {
- if (this.options.logs) {
- console.log.apply(console, arguments);
- }
- }
-
- translate(str, args) {
- return this.translationManager.translate(str, args);
- }
- }
-
- DataTable.instances = 0;
-
- var name = "influxframework-datatable";
- var version = "0.0.0-development";
- var description = "A modern datatable library for the web";
- var main = "dist/influxframework-datatable.cjs.js";
- var unpkg = "dist/influxframework-datatable.min.js";
- var jsdelivr = "dist/influxframework-datatable.min.js";
- var scripts = {"start":"yarn run dev","build":"rollup -c && NODE_ENV=production rollup -c","dev":"rollup -c -w","cy:server":"http-server -p 8989","cy:open":"cypress open","cy:run":"cypress run","test":"start-server-and-test cy:server http://localhost:8989 cy:run","test-local":"start-server-and-test cy:server http://localhost:8989 cy:open","travis-deploy-once":"travis-deploy-once","semantic-release":"semantic-release","lint":"eslint src","lint-and-build":"yarn lint && yarn build","commit":"npx git-cz"};
- var files = ["dist","src"];
- var devDependencies = {"autoprefixer":"^9.0.0","chai":"3.5.0","cypress":"^9.2.0","cz-conventional-changelog":"^2.1.0","deepmerge":"^2.0.1","eslint":"^5.0.1","eslint-config-airbnb":"^16.1.0","eslint-config-airbnb-base":"^12.1.0","eslint-plugin-import":"^2.11.0","http-server":"^0.11.1","mocha":"3.3.0","postcss-custom-properties":"^7.0.0","postcss-nested":"^3.0.0","rollup":"^0.59.4","rollup-plugin-commonjs":"^8.3.0","rollup-plugin-eslint":"^4.0.0","rollup-plugin-json":"^2.3.0","rollup-plugin-node-resolve":"^3.0.3","rollup-plugin-postcss":"^1.2.8","rollup-plugin-uglify-es":"^0.0.1","semantic-release":"^17.1.1","start-server-and-test":"^1.4.1","travis-deploy-once":"^5.0.1"};
- var repository = {"type":"git","url":"https://github.com/influxframework/datatable.git"};
- var keywords = ["datatable","data","grid","table"];
- var author = "Faris Ansari";
- var license = "MIT";
- var bugs = {"url":"https://github.com/influxframework/datatable/issues"};
- var homepage = "https://influxframework.com/datatable";
- var dependencies = {"hyperlist":"^1.0.0-beta","lodash":"^4.17.5","sortablejs":"^1.7.0"};
- var config = {"commitizen":{"path":"cz-conventional-changelog"}};
- var packageJson = {
- name: name,
- version: version,
- description: description,
- main: main,
- unpkg: unpkg,
- jsdelivr: jsdelivr,
- scripts: scripts,
- files: files,
- devDependencies: devDependencies,
- repository: repository,
- keywords: keywords,
- author: author,
- license: license,
- bugs: bugs,
- homepage: homepage,
- dependencies: dependencies,
- config: config
- };
-
- DataTable.__version__ = packageJson.version;
-
- module.exports = DataTable;
|