{"version":3,"sources":["webpack:///../../../src/components/VGrid/VRow.ts","webpack:///../../../src/components/VDataTable/VSimpleTable.ts","webpack:///../../../src/mixins/picker-button/index.ts","webpack:///../../../src/components/VDatePicker/VDatePickerTitle.ts","webpack:///../../../src/mixins/localable/index.ts","webpack:///../../../../src/components/VDatePicker/util/pad.ts","webpack:///../../../../src/components/VDatePicker/util/createNativeLocaleFormatter.ts","webpack:///../../../../src/components/VDatePicker/util/monthChange.ts","webpack:///../../../src/components/VDatePicker/VDatePickerHeader.ts","webpack:///../../../../src/components/VDatePicker/util/eventHelpers.ts","webpack:///../../../../src/components/VDatePicker/util/sanitizeDateString.ts","webpack:///../../../../src/components/VDatePicker/util/isDateAllowed.ts","webpack:///../../../../src/components/VDatePicker/mixins/date-picker-table.ts","webpack:///../../src/util/dateTimeUtils.ts","webpack:///../../../src/components/VDatePicker/VDatePickerDateTable.ts","webpack:///../../../src/components/VDatePicker/VDatePickerMonthTable.ts","webpack:///../../../src/components/VDatePicker/VDatePickerYears.ts","webpack:///../../../src/components/VPicker/VPicker.ts","webpack:///../../../src/components/VPicker/index.ts","webpack:///../../../src/mixins/picker/index.ts","webpack:///../../../../src/components/VCalendar/util/timestamp.ts","webpack:///../../../src/components/VDatePicker/VDatePicker.ts","webpack:///../../../src/components/VGrid/VCol.ts","webpack:///../../../src/components/VData/VData.ts","webpack:///../../../src/components/VDataIterator/VDataFooter.ts","webpack:///../../../src/components/VDataIterator/VDataIterator.ts","webpack:///../../../../src/components/VDataTable/mixins/header.ts","webpack:///../../../src/components/VDataTable/VDataTableHeaderMobile.ts","webpack:///../../../src/components/VDataTable/VDataTableHeaderDesktop.ts","webpack:///../../src/util/dedupeModelListeners.ts","webpack:///../../src/util/rebuildFunctionalSlots.ts","webpack:///../../../src/components/VDataTable/VDataTableHeader.ts","webpack:///../../../src/components/VDataTable/Row.ts","webpack:///../../../src/components/VDataTable/RowGroup.ts","webpack:///../../../src/components/VDataTable/MobileRow.ts","webpack:///../../../src/components/VDataTable/VDataTable.ts"],"names":["breakpoints","ALIGNMENT","makeProps","props","val","prefix","def","alignValidator","str","alignProps","type","default","validator","justifyValidator","justifyProps","alignContentValidator","alignContentProps","propMap","align","Object","justify","alignContent","classMap","breakpointClass","className","breakpoint","prop","cache","name","functional","tag","dense","noGutters","children","cacheKey","String","classList","value","h","data","staticClass","class","fixedHeader","height","Number","computed","this","$slots","themeClasses","methods","wrapper","$createElement","style","classes","mixins","readonly","active","click","event","on","Array","date","disabled","selectingYear","year","yearIcon","isReversing","watch","VIcon","dark","genPickerButton","computedTransition","domProps","innerHTML","key","locale","$vuetify","lang","padStart","string","targetLength","padString","length","n","createNativeLocaleFormatter","substrOptions","start","makeIsoString","dateString","month","pad","intlFormatter","Intl","Date","e","format","min","max","nextAriaLabel","nextIcon","prevAriaLabel","prevIcon","required","timeZone","newVal","ariaLabelId","change","ariaLabel","t","calculateChange","VBtn","attrs","icon","light","sign","monthChange","color","header","setTextColor","$emit","formatter","transition","genBtn","instance","eventName","itemTypeSuffix","allowedFn","directives","Touch","allowedDates","current","events","Function","eventColor","range","scrollable","tableDate","wheelThrottle","split","isAllowed","isSelected","isCurrent","createItemTypeNativeListeners","mouseEventType","isOtherMonth","isDateAllowed","setColor","genButtonClasses","genButtonEvents","genEvents","arrayize","v","eventColors","eventData","includes","getEventColors","setBackgroundColor","calculateTableDate","sanitizeType","sanitizeDateString","touchDirective","left","isValidScroll","touch","right","wheel","from","to","indexOf","createUTCDate","day","isFinite","firstWeekOffset","firstWeekDayInFirstWeek","firstDayOfWeek","firstWeekDayOfYear","dayOfYear","isLeapYear","weeksInYear","weekOffset","weekOffsetNext","daysInYear","week","Math","localeFirstDayOfYear","showAdjacentMonths","showWeek","weekdayFormat","weekday","first","parseInt","weekdayFormatter","i","delta","days","weekDays","map","genTR","firstDayOfTheMonth","displayedYear","displayedMonth","weekDay","weekNumber","daysInMonth","rows","genWeekNumber","getWeekNumber","prevMonthYear","prevMonth","firstDayFromPreviousMonth","cellsInRow","genButton","nextMonthYear","nextMonth","nextMonthDay","genTable","cols","row","tds","_","col","defaultColor","setTimeout","activeItem","$el","getElementsByClassName","offsetHeight","scrollHeight","formatted","selectedYear","maxYear","minYear","genYearItem","ref","flat","fullWidth","landscape","noTitle","width","defaultTitleColor","isDark","undefined","elevationClasses","title","actions","headerColor","$scopedSlots","save","cancel","body","slot","elevation","DAYS_IN_MONTH","DAYS_IN_MONTH_LEAP","activePicker","dayFormat","headerDateFormat","monthFormat","multiple","nextMonthAriaLabel","nextYearAriaLabel","pickerDate","prevMonthAriaLabel","prevYearAriaLabel","reactive","showCurrent","Boolean","selectedItemsText","titleDateFormat","yearFormat","now","internalActivePicker","inputDay","inputMonth","inputYear","multipleValue","isMultiple","getFullYear","getMonth","getDate","titleDate","dates","defaultTitleDateFormatter","titleFormats","titleDateFormatter","landscapeFormatter","match","nonDigit","digit","immediate","prev","lastValue","oldValue","output","newInput","concat","filter","x","valueType","constructor","expected","console","tableMonth","formatters","toUpperCase","toggle","input","VDatePickerDateTable","createItemTypeListeners","VDatePickerMonthTable","tableYear","array","genPicker","breakpointProps","offsetProps","orderProps","offset","order","alignSelf","parent","hasColClasses","inheritAttrs","items","options","sortBy","sortDesc","customSort","mustSort","multiSort","page","itemsPerPage","groupBy","groupDesc","customGroup","disableSort","disablePagination","disableFiltering","search","customFilter","serverItemsLength","internalOptions","sortDiff","groupDiff","filteredItems","itemsLength","pageStart","pageStop","pageCount","sortItems","paginateItems","isGrouped","groupItems","sort","sortArray","group","updateOptions","pagination","groupedItems","originalItemsLength","computedOptions","deep","computedItems","by","oldBy","desc","oldDesc","byIndex","k","s","findIndex","itemsPerPageOptions","firstIcon","lastIcon","itemsPerPageText","itemsPerPageAllText","showFirstLastPage","showCurrentPage","disableItemsPerPage","pageText","option","genDataItemsPerPageOption","text","computedIPPO","ippo","VSelect","hideDetails","auto","minWidth","onChangeItemsPerPage","label","before","after","genIcon","rtl","VData","itemKey","singleSelect","expanded","mobileBreakpoint","singleExpand","loading","noResultsText","noDataText","loadingText","hideDefaultFooter","footerProps","selectableKey","selection","expansion","internalCurrentItems","shiftKeyDown","lastEntry","selectableItems","every","some","item","isSelectable","keys","breakingProps","original","$attrs","hasOwnProperty","replacement","removedProps","window","emit","index","multipleSelect","old","end","currentItem","select","expand","isExpanded","isMobile","genEmptyWrapper","noData","filteredItemsLength","noResults","empty","genEmpty","createItemProps","scopedSlots","outerProps","someItems","everyItem","toggleSelectAll","genItems","genFooter","genDefaultScopedSlot","ripple","headers","checkboxColor","sortIcon","showGroupBy","indeterminate","VSimpleCheckbox","size","sortByText","sortIndex","beingSorted","isDesc","sortable","asc","VChip","menuProps","closeOnContentClick","genSortChip","find","sortHeaders","genSortSelect","th","tr","$t","ariaSort","role","scope","getAria","genGroupByToggle","genHeader","slots","mobile","dedupeModelListeners","mergeData","VDataTableHeaderMobile","VDataTableHeaderDesktop","computedSlots","columns","slotName","scopedSlot","regularSlot","textAlign","divider","headerClass","contentClass","summaryClass","hideDefaultHeader","mobileRowChildren","filterFn","searchTableItems","matchesColumnFilters","headersWithCustomFilters","matchesSearchTerm","headersWithoutCustomFilters","showSelect","showExpand","caption","headerProps","calculateWidths","headersLength","expandIcon","itemClass","loaderHeight","internalGroupBy","openCache","widths","defaultHeader","colspan","computedHeaders","reduce","acc","sanitizedFooterProps","firstOption","querySelectorAll","VDataIterator","colspanAttrs","genGroupedRows","genRows","$set","genDefaultGroupedRow","isOpen","toggleFn","removeFn","remove","small","column","RowGroup","genScopedRows","genDefaultRows","genDefaultExpandedRow","genDefaultSimpleRow","headerRow","expandedRow","MobileRow","contextmenu","dblclick","simpleProps","VSimpleTable","proxySlot","genCaption","genColgroup","genHeaders","genBody","genFoot","genFooters","computedItemsPerPage"],"mappings":"uMAOA,MAAMA,EAAc,CAAC,KAAM,KAAM,KAAjC,MAEMC,EAAY,CAAC,QAAS,MAA5B,UAEA,SAASC,EAAT,KACE,OAAOF,EAAA,OAAmB,CAACG,EAAOC,KAChCD,EAAME,EAAS,eAAf,IAAkCC,IAClC,GAFF,IAMF,MAAMC,EAAkBC,GAAa,qCAArC,GACMC,EAAaP,EAAU,QAAS,KAAM,CAC1CQ,KAD2C,OAE3CC,QAF2C,KAG3CC,UAAWL,KAGPM,EAAoBL,GAAa,+CAAvC,GACMM,EAAeZ,EAAU,UAAW,KAAM,CAC9CQ,KAD+C,OAE/CC,QAF+C,KAG/CC,UAAWC,KAGPE,EAAyBP,GAAa,yDAA5C,GACMQ,EAAoBd,EAAU,eAAgB,KAAM,CACxDQ,KADyD,OAEzDC,QAFyD,KAGzDC,UAAWG,KAGPE,EAAU,CACdC,MAAOC,OAAA,KADO,GAEdC,QAASD,OAAA,KAFK,GAGdE,aAAcF,OAAA,SAGVG,EAAW,CACfJ,MADe,QAEfE,QAFe,UAGfC,aAAc,iBAGhB,SAASE,EAAT,OACE,IAAIC,EAAYF,EAAhB,GACA,SAAIlB,EAAJ,CAGA,KAAU,CAER,MAAMqB,EAAaC,EAAA,UAAnB,IACAF,GAAa,IAAIC,EAInB,OADAD,GAAa,IAAIpB,EACVoB,EAAP,eAGF,MAAMG,EAAQ,IAAd,IAEe,qBAAW,CACxBC,KADwB,QAExBC,YAFwB,EAGxB1B,MAAO,CACL2B,IAAK,CACHpB,KADG,OAEHC,QAAS,OAEXoB,MALK,QAMLC,UANK,QAOLd,MAAO,CACLR,KADK,OAELC,QAFK,KAGLC,UAAWL,MAVR,EAaLa,QAAS,CACPV,KADO,OAEPC,QAFO,KAGPC,UAAWC,MAhBR,EAmBLQ,aAAc,CACZX,KADY,OAEZC,QAFY,KAGZC,UAAWG,MAEVC,GAEL,OAAM,GAAK,wBAAeiB,IAExB,IAAIC,EAAJ,GACA,IAAK,MAAL,OACEA,GAAYC,OAAQhC,EAApB,IAEF,IAAIiC,EAAYT,EAAA,IAAhB,GAEA,MAAgB,CAGd,MACA,SAHAS,EADc,GAId,EACEnB,EAAA,WAAsBS,IACpB,MAAMW,EAAiBlC,EAAvB,GACMqB,EAAYD,EAAgBb,EAAMgB,EAAxC,GACA,GAAeU,EAAA,UAInBA,EAAA,KAAe,CACb,aAAcjC,EADD,UAEb,aAAcA,EAFD,MAGb,CAAC,SAASA,EAAMe,OAAUf,EAHb,MAIb,CAAC,WAAWA,EAAMiB,SAAYjB,EAJjB,QAKb,CAAC,iBAAiBA,EAAMkB,cAAiBlB,EAAMkB,eAGjDM,EAAA,SAGF,OAAOW,EACLnC,EADM,IAEN,eAAUoC,EAAM,CACdC,YADc,MAEdC,MAAOL,IAJX,O,oCChIJ,kDAOe,qCAAyB,CACtCR,KADsC,iBAGtCzB,MAAO,CACL4B,MADK,QAELW,YAFK,QAGLC,OAAQ,CAACC,OAAQT,SAGnBU,SAAU,CACR,UACE,MAAO,CACL,sBAAuBC,KADlB,MAEL,+BAAgCA,KAAF,SAAkBA,KAF3C,YAGL,6BAA8BA,KAHzB,YAIL,0BAA2BA,KAAKC,OAJ3B,IAKL,6BAA8BD,KAAKC,OAL9B,UAMFD,KAAKE,gBAKdC,QAAS,CACP,aACE,OAAOH,KAAKC,OAAOG,SAAWJ,KAAKK,eAAe,MAAO,CACvDX,YADuD,wBAEvDY,MAAO,CACLT,OAAQ,eAAcG,KAAD,UAEtB,CACDA,KAAKK,eAAe,QAASL,KAAKC,OANpC,aAWJ,OAAM,GACJ,OAAOT,EAAE,MAAO,CACdE,YADc,eAEdC,MAAOK,KAAKO,SACX,CACDP,KAAKC,OADJ,IAEDD,KAFC,aAGDA,KAAKC,OANP,a,yHChCW,SAAAO,EAAA,qBAEN,CACPL,QAAS,CACP,gBAAe,MAIbM,GAJa,EAKbf,EALa,IAOb,MAAMgB,EAAUV,KAAA,KAAhB,EACMW,EAASC,IACbA,EAAA,kBACAZ,KAAA,MAAW,UAAU,eAAUpB,GAA/B,IAGF,OAAOoB,KAAKK,eAAe,MAAO,CAChCX,aAAa,wBAAwBA,GADL,OAEhCC,MAAO,CACL,+BADK,EAEL,iCAAkCc,GAEpCI,GAAKH,GAAD,SAAmC,CAAEC,UACxCG,MAAA,aAAmC,CAPtC,QCdS,SAAAN,EAAA,MACb,GADa,OAGN,CACP1B,KADO,sBAGPzB,MAAO,CACL0D,KAAM,CACJnD,KADI,OAEJC,QAAS,IAEXmD,SALK,QAMLP,SANK,QAOLQ,cAPK,QAQL1B,MAAO,CACL3B,KAAMyB,QAER6B,KAAM,CACJtD,KAAM,CAACkC,OADH,QAEJjC,QAAS,IAEXsD,SAAU,CACRvD,KAAMyB,SAIVI,KAAM,KAAM,CACV2B,aAAa,IAGfrB,SAAU,CACR,qBACE,OAAOC,KAAKoB,YAAc,4BAA1B,sBAIJC,MAAO,CACL,MAAK,KACHrB,KAAA,YAAmB1C,EAAnB,IAIJ6C,QAAS,CACP,cACE,OAAOH,KAAKK,eAAeiB,EAApB,KAA2B,CAChCjE,MAAO,CACLkE,MAAM,IAEPvB,KAJH,WAMF,aACE,OAAOA,KAAKwB,gBAAgB,iBAAiB,EAAM,CACjDnC,OAAOW,KAD0C,MAEjDA,KAAKmB,SAAWnB,KAAhB,cAFK,SAAP,8BAKF,eACE,OAAOA,KAAKK,eAAe,aAAc,CACvChD,MAAO,CACLyB,KAAMkB,KAAKyB,qBAEZ,CACDzB,KAAKK,eAAe,MAAO,CACzBqB,SAAU,CAAEC,UAAW3B,KAAKe,MAAQ,UACpCa,IAAK5B,KAAKT,WAIhB,eACE,OAAOS,KAAKwB,gBAAgB,iBAAiB,EAAO,CAACxB,KAA9C,mBAAP,+BAIJ,OAAM,GACJ,OAAOR,EAAE,MAAO,CACdE,YADc,sBAEdC,MAAO,CACL,gCAAiCK,KAAKgB,WAEvC,CACDhB,KADC,aAEDA,KAPF,oB,oCCtFW,gBAAW,CACxBlB,KADwB,YAGxBzB,MAAO,CACLwE,OAAQxC,QAGVU,SAAU,CACR,gBACE,OAAOC,KAAK6B,QAAU7B,KAAK8B,SAASC,KAApC,Y,YCXN,MAAMC,EAAW,CAACC,EAAD,OACfC,IAAA,EACAD,EAAS5C,OAAT4C,GACAE,EAAY9C,OAAZ8C,GACIF,EAAA,OAAJ,EACS5C,OAAP,IAGF6C,GAA8BD,EAA9B,OACIC,EAAeC,EAAnB,SACEA,GAAaA,EAAA,OAAiBD,EAAeC,EAA7C,SAEKA,EAAA,WAAmC9C,OAA1C,KAGa,SAAqB+C,EAArB,IAAoCJ,EAASK,EAAGD,EAA/D,KCIA,SAASE,EAAT,IAGEC,EAA+B,CAAEC,MAAF,EAAYJ,OAAQ,IAEnD,MAAMK,EAAiBC,IACrB,MAAOxB,EAAMyB,EAAO5B,GAAQ2B,EAAA,2BAA5B,KACA,MAAO,CAACE,EAAI1B,EAAL,GAAe0B,EAAID,GAAnB,GAAgCC,EAAI7B,GAApC,SAAP,MAGF,IACE,MAAM8B,EAAgB,IAAIC,KAAJ,eAAwBjB,QAAxB,EAAtB,GACA,OAAQa,GAAuBG,EAAA,OAAqB,IAAIE,KAAQN,EAAcC,GAAjB,oBAC7D,MAAOM,GACP,OAAQT,EAAA,OAAuBA,EAAxB,OACFG,GAAuBD,EAAA,UAAiCF,EAAA,OAAjC,EAA2DA,EADhF,aAAP,GAMJ,QCjCe,UACb,MAAOrB,EAAMyB,GAASpD,EAAA,eAAtB,QAEA,OAAIoD,EAAA,IAAJ,EACYzB,EAAO,EAAV,MACEyB,EAAA,IAAJ,GACKzB,EAAO,EAAV,MAEA,GAAGA,KAAQ0B,EAAID,EAAD,MCKV,SAAAnC,EAAA,MAAO,EAAD,OAGnB,QAHa,OAKN,CACP1B,KADO,uBAGPzB,MAAO,CACL2D,SADK,QAELiC,OAFK,SAGLC,IAHK,OAILC,IAJK,OAKLC,cALK,OAMLC,SAAU,CACRzF,KADQ,OAERC,QAAS,SAEXyF,cAVK,OAWLC,SAAU,CACR3F,KADQ,OAERC,QAAS,SAEX4C,SAfK,QAgBLlB,MAAO,CACL3B,KAAM,CAACkC,OADF,QAEL0D,UAAU,IAId,OACE,MAAO,CACLpC,aAAa,IAIjBrB,SAAU,CACR,YACE,OAAIC,KAAJ,OACSA,KAAP,OACSX,OAAOW,KAAP,kBAAJ,GACE,EAA4BA,KAAD,cAAqB,CAAE2C,MAAF,OAAiBzB,KAAjB,UAAkCuC,SAAU,OAAS,CAAErB,OAAQ,IAE/G,EAA4BpC,KAAD,cAAqB,CAAEkB,KAAF,UAAmBuC,SAAU,OAAS,CAAErB,OAAQ,MAK7Gf,MAAO,CACL,MAAK,KACHrB,KAAA,YAAmB0D,EAAnB,IAIJvD,QAAS,CACP,OAAM,GACJ,MAAMwD,EAAcC,EAAA,EAAa5D,KAAb,cAAkCA,KAAtD,cACM6D,EAAYF,EAAc3D,KAAK8B,SAASC,KAAK+B,EAAtB,QAA7B,EACM9C,EAAWhB,KAAKgB,UACnB4C,EAAA,GAAc5D,KAAd,KAA0BA,KAAK+D,gBAAgBH,GAAU5D,KAD3C,KAEd4D,EAAA,GAAc5D,KAAd,KAA0BA,KAAK+D,gBAAgBH,GAAU5D,KAF5D,IAIA,OAAOA,KAAKK,eAAe2D,EAApB,KAA0B,CAC/BC,MAAO,CAAE,aAAcJ,GACvBxG,MAAO,CACLkE,KAAMvB,KADD,gBAGLkE,MAHK,EAILC,MAAOnE,KAAKmE,OAEdtD,GAAI,CACFF,MAAQqC,IACNA,EAAA,kBACAhD,KAAA,cAAoBA,KAAK+D,gBAAzB,OAGH,CACD/D,KAAKK,eAAeiB,EAApB,KAA6BsC,EAAD,KAAkB5D,KAAK8B,SAAxB,IAAwC9B,KAAxC,SAAwDA,KAfrF,aAkBF,gBAAe,GACb,MAAOkB,EAAMyB,GAAStD,OAAOW,KAAP,sBAAtB,QAEA,aAAI2C,EACK,IAAGzB,EAAOkD,GAEVC,EAAYhF,OAAOW,KAAR,OAAlB,IAGJ,YACE,MAAMsE,GAAStE,KAAD,WAAmBA,KAAKsE,OAAtC,UACMC,EAASvE,KAAKK,eAAe,MAAOL,KAAKwE,aAAaF,EAAO,CACjE1C,IAAKvC,OAAOW,KAAD,SACT,CAACA,KAAKK,eAAe,SAAU,CACjC4D,MAAO,CACLrG,KAAM,UAERiD,GAAI,CACFF,MAAO,IAAMX,KAAKyE,MAAM,YAEzB,CAACzE,KAAKC,OAAOpC,SAAWmC,KAAK0E,UAAUrF,OAAOW,KATjD,YAWM2E,EAAa3E,KAAKK,eAAe,aAAc,CACnDhD,MAAO,CACLyB,KAAOkB,KAAKoB,eAAiBpB,KAAK8B,SAA5B,6BAAuE,mBAE9E,CAJH,IAMA,OAAO9B,KAAKK,eAAe,MAAO,CAChCX,YADgC,8BAEhCC,MAAO,CACL,wCAAyCK,KAAKgB,WAE/C,CALH,MASJ,SACE,OAAOhB,KAAKK,eAAe,MAAO,CAChCX,YADgC,uBAEhCC,MAAO,CACL,iCAAkCK,KAD7B,YAEFA,KAAKE,eAET,CACDF,KAAK4E,QADJ,GAED5E,KAFC,YAGDA,KAAK4E,OAAO,Q,kCChJZ,kBACJ,OAAOvG,OAAA,KAAYwG,EAAZ,mBAAwC,CAAChE,EAAIiE,KAC9CA,EAAA,SAAJ,KACEjE,EAAGiE,EAAA,SAAoBC,EAAvB,SAAkDnE,GAAiBiE,EAAA,UAAnE,IAGF,GALF,IASI,gBACJ,OAAOxG,OAAA,KAAYwG,EAAZ,mBAAwC,CAAChE,EAAIiE,KAC9CA,EAAA,SAAJ,KACEjE,EAAA,GAAgBgE,EAAA,WAAhB,IAGF,GALF,ICTa,cACb,MAAO3D,EAAMyB,EAAP,EAAkB5B,EAAlB,GAA8B2B,EAAA,MAApC,KACA,MAAO,GAAGxB,KAAQ0B,EAAID,MAAUC,EAAI7B,KAA7B,SAA+C,CAAEA,KAAF,GAAY4B,MAAZ,EAAsBzB,KAAM,GAAlF,KCJY,oBACZ,QAAS8D,GAAaA,EAAf,OACH9B,GAAOnC,GAAQmC,EAAA,SADZ,QAEHC,GAAOpC,GAFX,G,gBC+Ba,SAAAP,EAAA,MAAO,EAAD,OAGnB,QAHa,OAKN,CACPyE,WAAY,CAAEC,MAAA,QAEd7H,MAAO,CACL8H,aADK,SAELC,QAFK,OAGLpE,SAHK,QAILiC,OAJK,SAKLoC,OAAQ,CACNzH,KAAM,CAACkD,MAAOwE,SADR,QAENzH,QAAS,IAAM,MAEjB0H,WAAY,CACV3H,KAAM,CAACkD,MAAOwE,SAAUjH,OADd,QAEVR,QAAS,IAAM,WAEjBqF,IAbK,OAcLC,IAdK,OAeLqC,MAfK,QAgBL/E,SAhBK,QAiBLgF,WAjBK,QAkBLC,UAAW,CACT9H,KADS,OAET4F,UAAU,GAEZjE,MAAO,CAACF,OAAQyB,QAGlBrB,KAAM,KAAM,CACV2B,aADW,EAEXuE,cAAe,OAGjB5F,SAAU,CACR,qBACE,OAAQC,KAAKoB,eAAiBpB,KAAK8B,SAA5B,6BAAP,kBAEF,iBACE,OAAOhC,OAAOE,KAAK0F,UAAUE,MAAM,KAA5B,IAAP,GAEF,gBACE,OAAO9F,OAAOE,KAAK0F,UAAUE,MAAM,KAAnC,MAIJvE,MAAO,CACL,UAAS,KACPrB,KAAA,YAAmB0D,EAAnB,IAIJ,UACE1D,KAAA,cAAqB,eAASA,KAAD,MAA7B,MAGFG,QAAS,CACP,iBAAgB,SACd,MAAO,CACL,mBADK,EAEL,+BAFK,EAGL,gBAHK,EAIL,eAAgB0F,GAAa7F,KAJxB,SAKL,cAAe8F,IALV,EAML,iBANK,EAOL,mBAAoBD,GAAa7F,KAP5B,SAQL,kBAAmB+F,IARd,KASF/F,KAAKE,eAGZ,gBAAe,OACb,IAAIF,KAAJ,SAEA,OAAO,eAAe,CACpBW,MAAO,KACDkF,IAAc7F,KAAlB,UAAiCA,KAAKyE,MAAM,QAASlF,KAEtDyG,EAA8BhG,KAAM,IAAIiG,EAJ3C,KAMF,UAAS,QAA8FC,GAA9F,GACP,MAAML,EAAYM,EAAc5G,EAAOS,KAAR,IAAkBA,KAAlB,IAA4BA,KAA3D,cACM8F,EAAa9F,KAAK8F,WAAWvG,IAAnC,EACMwG,EAAYxG,IAAUS,KAA5B,QACMoG,EAAWN,EAAa9F,KAAH,mBAA6BA,KAAxD,aACMsE,GAASwB,GAAD,KAA8B9F,KAAKsE,OAAjD,UAEA,OAAOtE,KAAKK,eAAe,SAAU+F,EAAS9B,EAAO,CACnD5E,YADmD,QAEnDC,MAAOK,KAAKqG,iBAAiBR,IAAtB,MAF4C,GAGnD5B,MAAO,CACLrG,KAAM,UAER8D,SAAU,CACRV,SAAUhB,KAAKgB,WAAL,GAA+BkF,GAE3CrF,GAAIb,KAAKsG,gBAAgB/G,EAAOsG,EAAWI,KACzC,CACFjG,KAAKK,eAAe,MAAO,CACzBX,YAAa,kBACZ,CAACgF,EAHF,KAIF1E,KAAKuG,UAdP,MAiBF,eAAc,GACZ,MAAMC,EAAYC,GAAyB3F,MAAA,aAAuB,CAAlE,GACA,MACI4F,EAAJ,GAYA,OATEC,EADE7F,MAAA,QAAcd,KAAlB,QACcA,KAAKqF,OAAOuB,SAAxB,GACS5G,KAAKqF,kBAAT,SACOrF,KAAKqF,OAAOtE,KAAxB,EACSf,KAAJ,QACOA,KAAKqF,OAAOtE,KAExB,EAGF,GAGE2F,GADK,IAAIC,EACKH,EAAd,GACK,kBAAWxG,KAAP,WACK,CAACA,KAAfuF,YACK,oBAAWvF,KAAP,WACKwG,EAASxG,KAAKuF,WAA5B,IACSzE,MAAA,QAAcd,KAAlB,YACSA,KAAduF,WAEciB,EAASxG,KAAKuF,WAA5B,IAGKmB,EAAA,OAAmBD,GAA1B,IAbE,IAeJ,UAAS,GACP,MAAMC,EAAc1G,KAAK6G,eAAzB,GAEA,OAAOH,EAAA,OAAqB1G,KAAKK,eAAe,MAAO,CACrDX,YAAa,+BACZgH,EAAA,IAAgBpC,GAAStE,KAAKK,eAAe,MAAOL,KAAK8G,mBAFrD,MAAP,MAIF,cAAa,KACX,MAAMpB,EAAYqB,EADwD,GAGpEC,EAAe,IAAAtB,EAAA,yBAArB,QACA,OAAQnG,EAAA,KAAcS,KAAKkD,KAAMwC,GAAauB,EAAmBjH,KAAD,IAA1C,KACnBT,EAAA,KAAcS,KAAKmD,KAAMuC,GAAauB,EAAmBjH,KAAD,IAA1C,KAEnB,MAAK,KACHA,KAAA,0BAAgC+G,EAAmB/D,EAAnD,UAEF,MAAK,KACHhD,KAAA,0BAAgC+G,EAAhC,KAEF,SAAQ,OACN,MAAMpC,EAAa3E,KAAKK,eAAe,aAAc,CACnDhD,MAAO,CAAEyB,KAAMkB,KAAKyB,qBACnB,CAACzB,KAAKK,eAAe,QAAS,CAAEuB,IAAK5B,KAAK0F,WAF7C,KAIMwB,EAAiB,CACrBpI,KADqB,QAErBS,MAAO,CACL4H,KAAOnE,GAAqBA,EAAA,SAAD,IACxBhD,KAAKoH,cAAc,EAAGL,IAAuB/G,KAAKqH,MAAM,EAFtD,GAGLC,MAAQtE,GAAqBA,EAAA,QAAD,IACzBhD,KAAKoH,eAAL,MAA8CpH,KAAKqH,OAAL,OAIrD,OAAOrH,KAAKK,eAAe,MAAO,eAEhCV,MAAO,CACL,gCAAiCK,KAD5B,YAEFA,KAAKE,cAEVW,IAAMb,KAAD,UAAkBA,KAAnB,WAAsC,CACxCuH,MAAQvE,IACNA,EAAA,iBACIhD,KAAKoH,cAAcpE,EAAnB,OAAJ,IAAwDhD,KAAA,0BAT5B,EAYhCiF,WAAY,CAACiC,IACZ,CAbH,KAeF,WAAU,GACR,GAAIpG,MAAA,QAAcd,KAAlB,OAA+B,CAC7B,GAAIA,KAAKwF,OAAT,IAAkBxF,KAAKT,MAAM6C,OAAc,CACzC,MAAOoF,EAAMC,GAAM,IAAIzH,KAAJ,OAAnB,OACA,OAAOwH,GAAA,GAAiBjI,GAAxB,EAEA,WAAOS,KAAKT,MAAMmI,QAAQnI,GAI9B,OAAOA,IAAUS,KAAjB,UCxON,SAAS2H,EAAT,EAAsChF,EAAtC,EAAiDiF,EAAjD,GACE,MAUA,OATI1G,EAAA,KAAcA,GAAlB,GACEH,EAAO,IAAIgC,KAAKA,KAAA,QAAhB,IACI8E,SAAS9G,EAAb,mBACEA,EAAA,mBAGFA,EAAO,IAAIgC,KAAKA,KAAA,QAAhB,IAGF,EAGF,SAAS+E,EAAT,OACE,MAAMC,EAA0B,EAAIC,EAApC,EACMC,GAAsB,EAAIN,EAAczG,EAAM,EAApB,GAAJ,YAAD,GAA3B,EAEA,OAAQ+G,EAAqBF,EAA7B,EAGF,SAASG,EAAT,SACE,IAAIA,EAAY,CAAC,EAAG,GAAI,GAAI,GAAI,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,KAAnE,GAKA,OAJIvF,EAAA,GAAawF,EAAjB,IACED,IAGKA,EAAP,EAGF,SAASE,EAAT,OACE,MAAMC,EAAaP,EAAgB5G,EAAM8G,EAAzC,GACMM,EAAiBR,EAAgB5G,EAAD,IAAtC,GACMqH,EAAaJ,EAAA,OAAnB,IAEA,OAAQI,EAAA,EAAD,GAAP,EAGI,sBACJ,MAAMF,EAAaP,EAAgB5G,EAAM8G,EAAzC,GACMQ,EAAOC,KAAA,MAAWP,EAAUhH,EAAMyB,EAAOiF,EAAvB,GAAD,GAAvB,GAEA,OAAIY,EAAJ,EACSA,EAAOJ,EAAYlH,EAAD,IAAzB,GACSsH,EAAOJ,EAAYlH,EAAM8G,EAA7B,GACEQ,EAAOJ,EAAYlH,EAAM8G,EAAhC,GAEA,EAIE,cACJ,OAAS9G,EAAA,IAAD,GAAqBA,EAAA,MAAtB,GAA6CA,EAAA,MAApD,ECvCa,aAAAV,EAAA,MACb,GADa,OAGN,CACP1B,KADO,2BAGPzB,MAAO,CACL2K,eAAgB,CACdpK,KAAM,CAACyB,OADO,QAEdxB,QAAS,GAEX6K,qBAAsB,CACpB9K,KAAM,CAACyB,OADa,QAEpBxB,QAAS,GAEX8K,mBATK,QAULC,SAVK,QAWLC,cAAevD,UAGjBvF,SAAU,CACR,YACE,OAAOC,KAAKiD,QAAU,EAA4BjD,KAAD,cAAqB,CAAE4H,IAAF,UAAkBnE,SAAU,OAAS,CAAEjB,MAAF,EAAYJ,OAAQ,KAEjI,mBACE,OAAOpC,KAAK6I,eAAiB,EAA4B7I,KAAD,cAAqB,CAAE8I,QAAF,SAAqBrF,SAAU,SAE9G,WACE,MAAMsF,EAAQC,SAAShJ,KAAD,eAAtB,IAEA,OAAOA,KAAKiJ,iBACR,sBAAmBC,GAAKlJ,KAAKiJ,iBAAkB,YAAWF,EAAA,EAAY,MACtE,sBAAmBG,GAAK,CAAC,IAAK,IAAK,IAAK,IAAK,IAAK,IAAK,MAAMA,EAAD,GAFhE,MAMJ/I,QAAS,CACP,mBAAkB,GAChB,OAAOkE,EAAYrE,KAAD,UAAiByI,KAAA,KAAUU,GAA7C,KAEF,WACE,MAAMC,EAAOpJ,KAAKqJ,SAASC,IAAI1B,GAAO5H,KAAKK,eAAe,KAA1D,IAKA,OAJIL,KAAJ,UACEoJ,EAAA,QAAapJ,KAAKK,eAAlB,OAGKL,KAAKK,eAAe,QAASL,KAAKuJ,MAAzC,KAGF,mCACE,MAAMC,EAAqB,IAAIzG,KAAK,GAAG/C,KAAKyJ,iBAAiB7G,EAAI5C,KAAK0J,eAAN,wBAC1DC,EAAUH,EAAhB,YAEA,OAAQG,EAAUX,SAAShJ,KAAnB,gBAAD,GAAP,GAEF,cAAa,GACX,OAAO4J,EACL5J,KADe,cAEfA,KAFe,iBAIfgJ,SAAShJ,KAJM,gBAKfgJ,SAAShJ,KALX,wBAQF,cAAa,GACX,OAAOA,KAAKK,eAAe,KAAM,CAC/BL,KAAKK,eAAe,QAAS,CAC3BX,YAAa,mCACZL,OAAA,cAHL,SAOF,WACE,MAAMF,EAAN,GACM0K,EAAc,IAAI9G,KAAK/C,KAAT,cAA6BA,KAAK0J,eAAlC,KAApB,UACA,IAAII,EAAJ,GACIlC,EAAM5H,KAAV,mCAEIA,KAAJ,UACE8J,EAAA,KAAU9J,KAAK+J,cAAc/J,KAAKgK,cAAlC,KAGF,MAAMC,EAAgBjK,KAAK0J,eAAiB1J,KAAtB,cAA2CA,KAAKyJ,cAAtE,EACMS,GAAalK,KAAK0J,eAAN,IAAlB,GACMS,EAA4B,IAAIpH,KAAK/C,KAAT,cAA6BA,KAA7B,kBAAlC,UACMoK,EAAapK,KAAK4I,SAAW,EAAnC,EAEA,MAAOhB,IAAO,CACZ,MAAM7G,EAAO,GAAGkJ,KAAiBrH,EAAIsH,EAAD,MAAmBtH,EAAIuH,EAAD,KAE1DL,EAAA,KAAU9J,KAAKK,eAAe,KAAML,KAAK2I,mBAAqB,CAC5D3I,KAAKqK,UAAUtJ,GAAM,EAAM,OAAQf,KAAnC,WADkC,IAApC,KAKF,IAAK4H,EAAL,EAAcA,GAAd,EAAkCA,IAAO,CACvC,MAAM7G,EAAO,GAAGf,KAAKyJ,iBAAiB7G,EAAI5C,KAAK0J,eAAN,MAA6B9G,EAAIgF,KAE1EkC,EAAA,KAAU9J,KAAKK,eAAe,KAAM,CAClCL,KAAKqK,UAAUtJ,GAAM,EAAM,OAAQf,KADrC,cAII8J,EAAA,WAAJ,IACE3K,EAAA,KAAca,KAAKuJ,MAAnB,IACAO,EAAA,GACI9J,KAAK4I,WAAahB,EAAA,GAAqB5H,KAA3C,qBACE8J,EAAA,KAAU9J,KAAK+J,cAAc/J,KAAKgK,cAAcpC,EAAhD,MAKN,MAAM0C,EAAwC,KAAxBtK,KAAK0J,eAAwB1J,KAAKyJ,cAAlC,EAAsDzJ,KAA5E,cACMuK,GAAavK,KAAK0J,eAAN,GAAlB,GACA,IAAIc,EAAJ,EAEA,MAAOV,EAAA,OAAP,EAAiC,CAC/B,MAAM/I,EAAO,GAAGuJ,KAAiB1H,EAAI2H,EAAD,MAAmB3H,EAAI4H,OAE3DV,EAAA,KAAU9J,KAAKK,eAAe,KAAML,KAAK2I,mBAAqB,CAC5D3I,KAAKqK,UAAUtJ,GAAM,EAAM,OAAQf,KAAnC,WADkC,IAApC,KASF,OAJI8J,EAAJ,QACE3K,EAAA,KAAca,KAAKuJ,MAAnB,IAGKvJ,KAAKK,eAAe,QAA3B,IAEF,MAAK,GACH,MAAO,CAACL,KAAKK,eAAe,KAA5B,MAIJ,SACE,OAAOL,KAAKyK,SAAS,gDAAiD,CACpEzK,KADoE,WAEpEA,KAFK,YAGJA,KAHH,uBCzIW,SAAAQ,EAAA,MACb,GADa,OAGN,CACP1B,KADO,4BAGPiB,SAAU,CACR,YACE,OAAOC,KAAKiD,QAAU,EAA4BjD,KAAD,cAAqB,CAAE2C,MAAF,QAAkBc,SAAU,OAAS,CAAEjB,MAAF,EAAYJ,OAAQ,MAInIjC,QAAS,CACP,mBAAkB,GAChB,MAAO,IAAG6I,SAAShJ,KAAD,UAAR,IAA+ByI,KAAA,KAAUU,GAAV,KAE3C,WACE,MAAMhK,EAAN,GACMuL,EAAO5J,MAAA,QAAb,MACMgJ,EAAO,GAAKY,EAAlB,OAEA,IAAK,IAAIC,EAAT,EAAkBA,EAAlB,EAA8BA,IAAO,CACnC,MAAMC,EAAMF,EAAA,IAAS,CAACG,EAAGC,KACvB,MAAMnI,EAAQgI,EAAMD,EAAN,OAAd,EACM3J,EAAO,GAAGf,KAAKyJ,iBAAiB7G,EAAID,EAAD,KACzC,OAAO3C,KAAKK,eAAe,KAAM,CAC/BuB,IAAKe,GACJ,CACD3C,KAAKqK,UAAUtJ,GAAM,EAAO,QAASf,KAHvC,eAOFb,EAAA,KAAca,KAAKK,eAAe,KAAM,CACtCuB,IAAK+I,GADP,IAKF,OAAO3K,KAAKK,eAAe,QAA3B,KAIJ,SACE,OAAOL,KAAKyK,SAAS,iDAAkD,CACrEzK,KADK,YAEJA,KAFH,uBC/BW,G,UAAA,OAAAQ,EAAA,MAAM,OASnB,GATa,OAWN,CACP1B,KADO,sBAGPzB,MAAO,CACL4F,OADK,SAELC,IAAK,CAACpD,OAFD,QAGLqD,IAAK,CAACrD,OAHD,QAILW,SAJK,QAKLlB,MAAO,CAACO,OAAQT,SAGlB,OACE,MAAO,CACL0L,aAAc,YAIlBhL,SAAU,CACR,YACE,OAAOC,KAAKiD,QAAU,EAA4BjD,KAAD,cAAqB,CAAEkB,KAAF,UAAmBuC,SAAU,OAAS,CAAErB,OAAQ,MAI1H,UACE4I,WAAW,KACT,MAAMC,EAAajL,KAAKkL,IAAIC,uBAAuB,UAAnD,GACA,EACEnL,KAAA,cAAqBiL,EAAA,UAAuBjL,KAAKkL,IAAIE,aAAhC,EAAmDH,EAAA,aAAxE,EACSjL,KAAKkD,MAAQlD,KAAjB,IACLA,KAAA,cAAqBA,KAAKkL,IAA1B,cACUlL,KAAD,KAAaA,KAAjB,IACLA,KAAA,gBAEAA,KAAA,cAAqBA,KAAKkL,IAAIG,aAAe,EAAIrL,KAAKkL,IAAIE,aAA1D,KAKNjL,QAAS,CACP,YAAW,GACT,MAAMmL,EAAYtL,KAAK0E,UAAU,GAAGxD,GAC9BR,EAASsI,SAAShJ,KAAD,MAAR,MAAf,EACMsE,EAAQ5D,IAAWV,KAAKsE,OAA9B,WAEA,OAAOtE,KAAKK,eAAe,KAAML,KAAKwE,aAAaF,EAAO,CACxD1C,IADwD,EAExDjC,MAAO,CAAEe,UACTG,GAAI,eAAe,CACjBF,MAAO,IAAMX,KAAKyE,MAAM,QAASvD,IAChC8E,EAA8BhG,KAAM,QAFrB,MAHpB,IASF,eACE,MAAMb,EAAN,GACMoM,EAAevL,KAAKT,MAAQyJ,SAAShJ,KAAD,MAArB,KAAwC,IAAI+C,MAAjE,cACMyI,EAAUxL,KAAKmD,IAAM6F,SAAShJ,KAAD,IAAnB,IAAqCuL,EAArD,IACME,EAAUhD,KAAA,MAAkBzI,KAAKkD,IAAM8F,SAAShJ,KAAD,IAAnB,IAAqCuL,EAAvE,KAEA,IAAK,IAAIrK,EAAT,EAAyBA,GAAzB,EAA0CA,IACxC/B,EAAA,KAAca,KAAK0L,YAAnB,IAGF,WAIJ,SACE,OAAO1L,KAAKK,eAAe,KAAM,CAC/BX,YAD+B,sBAE/BiM,IAAK,SACJ3L,KAHH,oB,kCCrFW,SAAAQ,EAAA,MAAO,EAAD,YAAN,eAIN,CACP1B,KADO,WAGPzB,MAAO,CACLuO,KADK,QAELC,UAFK,QAGLC,UAHK,QAILC,QAJK,QAKLpH,WAAY,CACV/G,KADU,OAEVC,QAAS,mBAEXmO,MAAO,CACLpO,KAAM,CAACkC,OADF,QAELjC,QAAS,MAIbkC,SAAU,CACR,qBACE,MAAMkM,GAAoBjM,KAAKkM,SAAkBlM,KAAKsE,OAAtD,WACA,OAAOtE,KAAKsE,OAAZ,IAIJnE,QAAS,CACP,WACE,OAAOH,KAAKK,eAAe,MAAOL,KAAK8G,mBAAmB9G,KAAxB,mBAAiD,CACjFN,YADiF,kBAEjFC,MAAO,CACL,6BAA8BK,KAAK8L,aAEnC9L,KAAKC,OALT,QAOF,oBACE,OAAOD,KAAKK,eAAe,aAAc,CACvChD,MAAO,CACLyB,KAAMkB,KAAK2E,aAEZ3E,KAAKC,OAJR,UAMF,UACE,OAAOD,KAAKK,eAAe,MAAO,CAChCX,YADgC,iBAEhCC,MAAO,CACL,2BAA4BK,KADvB,WAEFA,KAAKE,cAEVI,MAAON,KAAK6L,eAAYM,EAAY,CAClCH,MAAO,eAAchM,KAAD,SAErB,CACDA,KAVF,uBAaF,aACE,OAAOA,KAAKK,eAAe,MAAO,CAChCX,YADgC,oCAEhCC,MAAO,CACL,8BAA+BK,KAAK+L,UAErC/L,KAAKC,OALR,WASJ,OAAM,GACJ,OAAOT,EAAE,MAAO,CACdE,YADc,kBAEdC,MAAO,CACL,iBAAkBK,KADb,KAEL,sBAAuBA,KAFlB,UAGL,uBAAwBA,KAHnB,aAIFA,KAJE,gBAKFA,KAAKoM,mBAET,CACDpM,KAAKC,OAAOoM,MAAQrM,KAApB,WADC,KAEDA,KAFC,UAGDA,KAAKC,OAAOqM,QAAUtM,KAAtB,aAZF,UCnFJ,ICWe,SAAAQ,EAAA,MAAO,EAAD,YAGnB,QAHa,OAKN,CACP1B,KADO,SAGPzB,MAAO,CACLuO,KADK,QAELC,UAFK,QAGLU,YAHK,OAILT,UAJK,QAKLC,QALK,QAMLC,MAAO,CACLpO,KAAM,CAACkC,OADF,QAELjC,QAAS,MAIbsC,QAAS,CACP,iBACE,aAEF,gBACE,aAEF,uBACE,OAAOH,KAAKwM,aAAa3O,QAAUmC,KAAKwM,aAAa3O,QAAQ,CAC3D4O,KAAOzM,KADoD,KAE3D0M,OAAS1M,KAAa0M,SACnB1M,KAAKC,OAHV,SAKF,UAAS,GACP,MAAMd,EAAN,GAEA,IAAKa,KAAL,QAAmB,CACjB,MAAMqM,EAAQrM,KAAd,iBACAqM,GAASlN,EAAA,KAATkN,GAGF,MAAMM,EAAO3M,KAAb,gBAKA,OAJA2M,GAAQxN,EAAA,KAARwN,GAEAxN,EAAA,KAAca,KAAKK,eAAe,WAAY,CAAEuM,KAAM,WAAa,CAAC5M,KAApE,0BAEOA,KAAKK,eAAe,EAAS,eAElChD,MAAO,CACLiH,MAAOtE,KAAKuM,aAAevM,KADtB,MAELuB,KAAMvB,KAFD,KAGL6M,UAAW7M,KAHN,UAIL4L,KAAM5L,KAJD,KAKL6L,UAAW7L,KALN,UAML8L,UAAW9L,KANN,UAOLmE,MAAOnE,KAPF,MAQLgM,MAAOhM,KARF,MASL+L,QAAS/L,KAAK+L,UAXlB,OCzDC,MAGMe,EAA0B,CAAC,EAAG,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAA5E,IACMC,EAA+B,CAAC,EAAG,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAI,GAAjF,IAgRD,gBACJ,OAAO5E,EAAA,GAAmB4E,EAAnB,GAA+CD,EAAtD,G,gBCzOa,cAAAtM,EAAA,MAAO,EAAP,UAIN,CACP1B,KADO,gBAGPzB,MAAO,CACL2P,aADK,OAEL7H,aAFK,SAIL8H,UAJK,SAKLjM,SALK,QAMLqE,OAAQ,CACNzH,KAAM,CAACkD,MAAOwE,SADR,QAENzH,QAAS,IAAM,MAEjB0H,WAAY,CACV3H,KAAM,CAACkD,MAAOwE,SAAUjH,OADd,QAEVR,QAAS,IAAM,WAEjBmK,eAAgB,CACdpK,KAAM,CAACyB,OADO,QAEdxB,QAAS,GAGXqP,iBAnBK,SAoBLxE,qBAAsB,CACpB9K,KAAM,CAACyB,OADa,QAEpBxB,QAAS,GAEXsF,IAxBK,OAyBLD,IAzBK,OA2BLiK,YA3BK,SA4BLC,SA5BK,QA6BL/J,SAAU,CACRzF,KADQ,OAERC,QAAS,SAEXwP,mBAAoB,CAClBzP,KADkB,OAElBC,QAAS,0CAEXyP,kBAAmB,CACjB1P,KADiB,OAEjBC,QAAS,yCAEX0P,WAzCK,OA0CLhK,SAAU,CACR3F,KADQ,OAERC,QAAS,SAEX2P,mBAAoB,CAClB5P,KADkB,OAElBC,QAAS,0CAEX4P,kBAAmB,CACjB7P,KADiB,OAEjBC,QAAS,yCAEX2H,MAtDK,QAuDLkI,SAvDK,QAwDLjN,SAxDK,QAyDLgF,WAzDK,QA0DLkI,YAAa,CACX/P,KAAM,CAACgQ,QADI,QAEX/P,SAAS,GAEXgQ,kBAAmB,CACjBjQ,KADiB,OAEjBC,QAAS,qCAEX8K,mBAlEK,QAmELC,SAnEK,QAqELkF,gBArEK,SAsELlQ,KAAM,CACJA,KADI,OAEJC,QAFI,OAGJC,UAAYF,GAAc,CAAC,OAAQ,SAASgJ,SAAShJ,IAEvD2B,MAAO,CAACuB,MA3EH,QA4EL+H,cA5EK,SA8ELkF,WA9EK,SA+EL5M,SAAU9B,QAGZ,OACE,MAAM2O,EAAM,IAAZ,KACA,MAAO,CACLC,qBAAsBjO,KAAKpC,KADtB,cAELsQ,SAFK,KAGLC,WAHK,KAILC,UAJK,KAKLhN,aALK,QAQLsE,UAAW,MACT,GAAI1F,KAAJ,WACE,OAAOA,KAAP,WAGF,MAAMqO,EAAgB,eAAYrO,KAAlC,OACMe,EAAOsN,EAAcA,EAAA,OAAd,KACV,kBAAOrO,KAAP,YAAuCA,KAAvC,YAA0D,GAAGgO,EAAA,iBAAqBA,EAAA,WAAiB,KACtG,OAAO/G,EAAmBlG,EAA8B,SAAdf,KAAKpC,KAAkB,QAAjE,SARS,KAafmC,SAAU,CACR,gBACE,OAAO,eAAYC,KAAnB,QAEF,aACE,OAAOA,KAAKoN,UAAYpN,KAAxB,OAEF,YACE,OAAOA,KAAKsO,WAAatO,KAAKqO,cAAcrO,KAAKqO,cAAcjM,OAAxD,GAAuEpC,KAA9E,OAEF,iBACE,OAAKA,KAAD,OAAJ,UAAmBA,KAAKpC,KAEboC,KAAJ,WACEA,KAAKqO,cAAc/E,IAAIhM,GAAOA,EAAA,SAArC,IAEQ0C,KAAKT,MAAL,SAAR,GAJOS,KAAP,OAOJ,UACE,WAAIA,KAAK2N,YACA1G,EAAmB,GAAGjH,KAAKgO,IAAIO,iBAAiBvO,KAAKgO,IAAIQ,WAAa,KAAKxO,KAAKgO,IAAIS,YAAazO,KAAxG,MAGKA,KAAK2N,aAAZ,MAEF,YACE,MAAqB,SAAd3N,KAAKpC,KACR,GAAGoC,KAAKoO,aAAaxL,EAAI5C,KAAKmO,WAAN,MAA0BvL,EAAI5C,KAAD,YACrD,GAAGA,KAAKoO,aAAaxL,EAAI5C,KAAKmO,WAAN,MAE9B,aACE,OAAOrO,QAAQE,KAAKuN,YAAcvN,KAApB,sBAAP,IAAP,GAEF,YACE,OAAOF,QAAQE,KAAKuN,YAAcvN,KAApB,sBAAd,KAEF,WACE,OAAOA,KAAKkD,IAAM+D,EAAmBjH,KAAD,IAA7B,SAAP,MAEF,WACE,OAAOA,KAAKmD,IAAM8D,EAAmBjH,KAAD,IAA7B,SAAP,MAEF,UACE,OAAOA,KAAKkD,IAAM+D,EAAmBjH,KAAD,IAA7B,QAAP,MAEF,UACE,OAAOA,KAAKmD,IAAM8D,EAAmBjH,KAAD,IAA7B,QAAP,MAEF,aACE,MAAO,CACLkB,KAAMlB,KAAK+N,YAAc,EAA4B/N,KAAD,cAAqB,CAAEkB,KAAF,UAAmBuC,SAAU,OAAS,CAAErB,OAAQ,IACzHsM,UAAW1O,KAAK8N,kBACb9N,KAAKsO,WAAatO,KAAlB,kCAA2DA,KADnD,6BAIf,oCACE,OAAO2O,GACAA,EAAL,OAIA,IAAIA,EAAA,OACK3O,KAAK4O,0BAA0BD,EAAtC,IAGK3O,KAAK8B,SAASC,KAAK+B,EAAE9D,KAArB,kBAA6C2O,EAApD,QAPE,KAUN,4BACE,MAAME,EAAe,CACnB3N,KAAM,CAAEA,KAAF,UAAmBuC,SAAU,OACnCd,MAAO,CAAEA,MAAF,OAAiBc,SAAU,OAClC1C,KAAM,CAAE+H,QAAF,QAAoBnG,MAApB,QAAoCiF,IAApC,UAAoDnE,SAAU,QAGhEqL,EAAqB,EAA4B9O,KAAD,cAAqB6O,EAAa7O,KAAlC,MAA8C,CAClGwC,MADkG,EAElGJ,OAAQ,CAAErB,KAAF,GAAY4B,MAAZ,EAAsBzB,KAAM,GAAIlB,KAAhC,QAGJ+O,EAAsBhO,GAAiB+N,EAAA,8BACd,CAACE,EAAOC,EAAUC,IAAU,GAAGD,KAAYC,KAD7B,aAA7C,SAIA,OAAOlP,KAAK8L,UAAYiD,EAAxB,IAIJ1N,MAAO,CACL4M,qBAAsB,CACpBkB,WADoB,EAEpB,QAAO,GACLnP,KAAA,kCAGJ,aAAY,GACVA,KAAA,wBAEF,UAAS,KAGP,MAAMgH,EAA6B,UAAdhH,KAAKpC,KAAmB,OAA7C,QACAoC,KAAA,YAAmBiH,EAAmB3J,EAAnB,GAAwC2J,EAAmBmI,EAA9E,GACApP,KAAA,+BAEF,WAAU,GACR,EACEA,KAAA,YACSA,KAAKqP,WAAT,SAAsBrP,KAAKpC,KAChCoC,KAAA,UAAiBiH,EAAmBjH,KAAD,UAAnC,SACSA,KAAKqP,WAAT,UAAsBrP,KAAKpC,OAChCoC,KAAA,UAAiBiH,EAAmBjH,KAAD,UAAnC,UAGJ,MAAK,KACHA,KAAA,oBACAA,KAAA,gBAGIA,KAAD,aAAoBA,KAApB,OAAmCA,KAApC,eACCA,KAAKsO,aAActO,KAAKqO,cAAxB,QAAkDiB,GAAaA,EAA/D,QAAoFtP,KAFvF,cAIEA,KAAA,UAAiBiH,EAAmBjH,KAAD,UAA+B,UAAdA,KAAKpC,KAAmB,OAA5E,WAGJ,KAAI,GAGF,GAFAoC,KAAA,qBAA4BpC,EAA5B,cAEIoC,KAAKT,OAASS,KAAKT,MAAvB,OAAqC,CACnC,MAAMgQ,EAASvP,KAAKqO,cAAL,IACP/Q,GAAgB2J,EAAmB3J,EAD5B,WAEL0C,KAFV,eAGAA,KAAA,cAAoBA,KAAKsO,WAAaiB,EAASA,EAA/C,OAKN,UACEvP,KAAA,oBAEIA,KAAKuN,aAAevN,KAAxB,WACEA,KAAA,2BAAiCA,KAAjC,WAEFA,KAAA,gBAGFG,QAAS,CACP,UAAS,GACP,GAAIH,KAAJ,MAAgB,CACd,OAAIA,KAAKqO,cAAcjM,OACrBpC,KAAA,cAAoB,CAApB,QACK,CACL,MAAMuP,EAAS,CAACvP,KAAKqO,cAAN,GAAf,GACArO,KAAA,iBACAA,KAAA,kBAEF,OAGF,MAAMuP,EAASvP,KAAKoN,UAEhB,IAAApN,KAAKqO,cAAc3G,QAAQ8H,GACvBxP,KAAKqO,cAAcoB,OAAO,CAD9B,IAEIzP,KAAKqO,cAAcqB,OAAOC,GAAKA,IAJxB,GAAf,EAQA3P,KAAA,iBACAA,KAAA,UAAiBA,KAAKyE,MAAM,SAA5B,IAEF,oBACE,SAAIzE,KAAKT,MAAe,OACxB,MAAMqQ,EAAY5P,KAAKT,MAAMsQ,YAA7B,KACMC,EAAW9P,KAAKsO,WAAa,QAAnC,SACIsB,IAAJ,GACE,OAAAG,EAAA,MAAY,iBAAiB/P,KAAKsO,WAAa,KAAO,OAAOwB,UAAiBF,IAA9E,OAGJ,cAAa,GACX,OAAOzJ,EAAc5G,EAAOS,KAAR,IAAkBA,KAAlB,IAA4BA,KAAhD,eAEF,UAAS,GACPA,KAAA,YACA,UAAIA,KAAKpC,KACPoC,KAAA,UAAiB,GAAGT,EAEpBS,KAAA,UAAiB,GAAGT,KAASqD,GAAK5C,KAAKgQ,YAAN,GAAD,KAElChQ,KAAA,6BACIA,KAAK0N,WAAa1N,KAAlB,WAAoCA,KAApC,YAAuDA,KAAKmG,cAAcnG,KAA9E,YACEA,KAAA,cAAoBA,KAApB,YAGJ,WAAU,GACRA,KAAA,UAAiBgJ,SAASzJ,EAAA,WAAD,GAAzB,IACAS,KAAA,WAAkBgJ,SAASzJ,EAAA,WAAD,GAAR,IAAlB,EACA,SAAIS,KAAKpC,MACHoC,KAAJ,WACEA,KAAA,SAAgByI,KAAA,IAASzI,KAAT,SAAwB,EAAYA,KAAD,UAAiBA,KAAKmO,WAAzE,KAGFnO,KAAA,YACAA,KAAA,4BACIA,KAAK0N,WAAa1N,KAAlB,WAAoCA,KAApC,YAAuDA,KAAKmG,cAAcnG,KAA9E,YACEA,KAAA,cAAoBA,KAApB,YAGFA,KAAA,UAAeA,KAAf,YAGJ,UAAS,GACPA,KAAA,UAAiBgJ,SAASzJ,EAAA,WAAD,GAAzB,IACAS,KAAA,WAAkBgJ,SAASzJ,EAAA,WAAD,GAAR,IAAlB,EACAS,KAAA,SAAgBgJ,SAASzJ,EAAA,WAAD,GAAxB,IACAS,KAAA,UAAeA,KAAf,YAEF,iBACE,OAAOA,KAAKK,eAAe,EAAkB,CAC3ChD,MAAO,CACL0D,KAAMf,KAAKT,MAASS,KAAKiQ,WAAWvB,UAAqC1O,KAAKsO,WAAatO,KAAlB,cAAuCA,KAA1G,OADD,GAELgB,SAAUhB,KAFL,SAGLS,SAAUT,KAHL,SAILiB,cAJK,SAIUjB,KAAKiO,qBACpB/M,KAAMlB,KAAKiQ,WAAW/O,KAAKlB,KAAKqO,cAAcjM,OAAS,GAAGpC,KAAKoO,UAAcpO,KALxE,WAMLmB,SAAUnB,KANL,SAOLT,MAAOS,KAAKqO,cAAc,IAE5BzB,KAV2C,QAW3C/L,GAAI,CACF,wBAA0BtB,GAAmBS,KAAKiO,qBAAuB1O,EAAQ,OAASS,KAAKpC,KAAKsS,kBAI1G,iBACE,OAAOlQ,KAAKK,eAAe,EAAmB,CAC5ChD,MAAO,CACLgG,SAAUrD,KADL,SAELsE,MAAOtE,KAFF,MAGLuB,KAAMvB,KAHD,KAILgB,SAAUhB,KAJL,SAKLiD,OAAQjD,KALH,iBAMLmE,MAAOnE,KANF,MAOL6B,OAAQ7B,KAPH,OAQLkD,IAAmC,SAA9BlD,KAAKiO,qBAAkCjO,KAAvC,SAAuDA,KARvD,QASLmD,IAAmC,SAA9BnD,KAAKiO,qBAAkCjO,KAAvC,SAAuDA,KATvD,QAULoD,cAA6C,SAA9BpD,KAAKiO,qBAAkCjO,KAAvC,mBAAiEA,KAV3E,kBAWLsD,cAA6C,SAA9BtD,KAAKiO,qBAAkCjO,KAAvC,mBAAiEA,KAX3E,kBAYLuD,SAAUvD,KAZL,SAaLS,SAAUT,KAbL,SAcLT,MAAqC,SAA9BS,KAAKiO,qBAAkC,GAAGrL,EAAI5C,KAAD,gBAAuB4C,EAAI5C,KAAKgQ,WAAN,KAA0B,GAAGpN,EAAI5C,KAAD,cAEhHa,GAAI,CACFsP,OAAQ,IAAMnQ,KAAKiO,qBAAsD,SAA9BjO,KAAKiO,qBAAkC,QADhF,OAEFmC,MAAQ7Q,GAAkBS,KAAK0F,UAAYnG,MAIjD,eACE,OAAOS,KAAKK,eAAegQ,EAAsB,CAC/ChT,MAAO,CACL8H,aAAcnF,KADT,aAELsE,MAAOtE,KAFF,MAGLoF,QAASpF,KAHJ,QAILuB,KAAMvB,KAJD,KAKLgB,SAAUhB,KALL,SAMLqF,OAAQrF,KANH,OAOLuF,WAAYvF,KAPP,WAQLgI,eAAgBhI,KARX,eASLiD,OAAQjD,KATH,UAULmE,MAAOnE,KAVF,MAWL6B,OAAQ7B,KAXH,OAYL0I,qBAAsB1I,KAZjB,qBAaLkD,IAAKlD,KAbA,IAcLmD,IAAKnD,KAdA,IAeLwF,MAAOxF,KAfF,MAgBLS,SAAUT,KAhBL,SAiBLyF,WAAYzF,KAjBP,WAkBL2I,mBAAoB3I,KAlBf,mBAmBL4I,SAAU5I,KAnBL,SAoBL0F,UAAW,GAAG9C,EAAI5C,KAAD,gBAAuB4C,EAAI5C,KAAKgQ,WAAN,KAC3CzQ,MAAOS,KArBF,MAsBL6I,cAAe7I,KAAK6I,eAEtB8C,IAzB+C,QA0B/C9K,GAAI,CACFuP,MAAOpQ,KADL,UAEF,oBAAsBT,GAAkBS,KAAK0F,UAF3C,KAGC4K,EAAwBtQ,KAAM,aAIvC,gBACE,OAAOA,KAAKK,eAAekQ,EAAuB,CAChDlT,MAAO,CACL8H,aAA4B,UAAdnF,KAAKpC,KAAmBoC,KAAxB,aADT,KAELsE,MAAOtE,KAFF,MAGLoF,QAASpF,KAAKoF,QAAU6B,EAAmBjH,KAAD,QAAjC,SAHJ,KAILuB,KAAMvB,KAJD,KAKLgB,SAAUhB,KALL,SAMLqF,OAAsB,UAAdrF,KAAKpC,KAAmBoC,KAAxB,OANH,KAOLuF,WAA0B,UAAdvF,KAAKpC,KAAmBoC,KAAxB,WAPP,KAQLiD,OAAQjD,KARH,YASLmE,MAAOnE,KATF,MAUL6B,OAAQ7B,KAVH,OAWLkD,IAAKlD,KAXA,SAYLmD,IAAKnD,KAZA,SAaLwF,MAAOxF,KAbF,MAcLS,SAAUT,KAAKS,UAdV,UAcsBT,KAAKpC,KAChC6H,WAAYzF,KAfP,WAgBLT,MAAOS,KAhBF,eAiBL0F,UAAW,GAAG9C,EAAI5C,KAAD,cAEnB2L,IApBgD,QAqBhD9K,GAAI,CACFuP,MAAOpQ,KADL,WAEF,oBAAsBT,GAAkBS,KAAK0F,UAF3C,KAGC4K,EAAwBtQ,KAAM,cAIvC,WACE,OAAOA,KAAKK,eAAe,EAAkB,CAC3ChD,MAAO,CACLiH,MAAOtE,KADF,MAELiD,OAAQjD,KAFH,WAGL6B,OAAQ7B,KAHH,OAILkD,IAAKlD,KAJA,QAKLmD,IAAKnD,KALA,QAMLT,MAAOS,KAAKwQ,WAEd3P,GAAI,CACFuP,MAAOpQ,KADL,aAECsQ,EAAwBtQ,KAAM,aAIvC,gBACE,MAAMb,EAAyC,SAA9Ba,KAAKiO,qBAAkC,CACtDjO,KADe,YAEb,CACFA,KADE,iBAE4B,SAA9BA,KAAKiO,qBAAkCjO,KAAvC,eAA6DA,KAJ/D,iBAOA,OAAOA,KAAKK,eAAe,MAAO,CAChCuB,IAAK5B,KAAKiO,sBADZ,IAIF,eACE,GAAIjO,KAAJ,UAAoB,CAClB,MAAMyQ,EAAQzQ,KAAKqP,UAAUzJ,MAA7B,KACA5F,KAAA,UAAiBgJ,SAASyH,EAAD,GAAzB,IACAzQ,KAAA,WAAkBgJ,SAASyH,EAAD,GAAR,IAAlB,EACA,SAAIzQ,KAAKpC,OACPoC,KAAA,SAAgBgJ,SAASyH,EAAD,GAAxB,UAGFzQ,KAAA,UAAiBA,KAAKoO,WAAapO,KAAKgO,IAAxC,cACAhO,KAAA,WAAqC,MAAnBA,KAAKmO,WAAqBnO,KAA1B,WAA4CA,KAAKgO,IAAnE,WACAhO,KAAA,SAAgBA,KAAKkO,UAAYlO,KAAKgO,IAAtC,YAKN,SACE,OAAOhO,KAAK0Q,UAAZ,sB,yHCtgBJ,MAAMxT,EAAc,CAAC,KAAM,KAAM,KAAjC,MAEMyT,EAAkB,KACfzT,EAAA,OAAmB,CAACG,EAAOC,KAChCD,EAAA,GAAa,CACXO,KAAM,CAACgQ,QAASvO,OADL,QAEXxB,SAAS,GAEX,GALF,IADsB,GAUlB+S,EAAc,KACX1T,EAAA,OAAmB,CAACG,EAAOC,KAChCD,EAAM,SAAW,eAAjB,IAAoC,CAClCO,KAAM,CAACyB,OAD2B,QAElCxB,QAAS,MAEX,GALF,IADkB,GAUdgT,EAAa,KACV3T,EAAA,OAAmB,CAACG,EAAOC,KAChCD,EAAM,QAAU,eAAhB,IAAmC,CACjCO,KAAM,CAACyB,OAD0B,QAEjCxB,QAAS,MAEX,GALF,IADiB,GAUbM,EAAU,CACd2M,IAAKzM,OAAA,KADS,GAEdyS,OAAQzS,OAAA,KAFM,GAGd0S,MAAO1S,OAAA,SAGT,SAASI,EAAT,OACE,IAAIC,EAAJ,EACA,GAAI,MAAApB,IAAJ,IAAmBA,EAAnB,CAGA,KAAU,CACR,MAAMqB,EAAaC,EAAA,UAAnB,IACAF,GAAa,IAAIC,EAKnB,MAAI,QAAAf,GAAmB,KAAAN,IAAvB,IAAqCA,GAKrCoB,GAAa,IAAIpB,EACVoB,EAAP,eAJSA,EAAP,eAOJ,MAAMG,EAAQ,IAAd,IAEe,qBAAW,CACxBC,KADwB,QAExBC,YAFwB,EAGxB1B,MAAO,CACLqN,KAAM,CACJ9M,KAAM,CAACgQ,QAASvO,OADZ,QAEJxB,SAAS,MAHN,EAMLiT,OAAQ,CACNlT,KAAM,CAACyB,OADD,QAENxB,QAAS,SARN,EAWLkT,MAAO,CACLnT,KAAM,CAACyB,OADF,QAELxB,QAAS,SAbN,EAgBLmT,UAAW,CACTpT,KADS,OAETC,QAFS,KAGTC,UAAYJ,GAAa,CAAC,OAAQ,QAAS,MAAO,SAAU,WAAY,WAAWkJ,SAASlJ,IAE9FsB,IAAK,CACHpB,KADG,OAEHC,QAAS,QAGb,OAAM,GAAK,iCAAyBoT,IAElC,IAAI7R,EAAJ,GACA,IAAK,MAAL,OACEA,GAAYC,OAAQhC,EAApB,IAEF,IAAIiC,EAAYT,EAAA,IAAhB,GAEA,MAAgB,CAGd,MACA,SAHAS,EADc,GAId,EACEnB,EAAA,WAAsBS,IACpB,MAAMW,EAAoClC,EAA1C,GACMqB,EAAYD,EAAgBb,EAAMgB,EAAxC,GACA,GAAeU,EAAA,UAInB,MAAM4R,EAAgB5R,EAAA,KAAeZ,GAAaA,EAAA,WAAlD,SAEAY,EAAA,KAAe,CAEbwL,KAAMoG,IAAkB7T,EAFX,KAGb,CAAC,OAAOA,EAAMqN,MAASrN,EAHV,KAIb,CAAC,UAAUA,EAAMyT,QAAWzT,EAJf,OAKb,CAAC,SAASA,EAAM0T,OAAU1T,EALb,MAMb,CAAC,cAAcA,EAAM2T,WAAc3T,EAAM2T,YAG3CnS,EAAA,SAGF,OAAOW,EAAEnC,EAAD,IAAY,eAAUoC,EAAM,CAAEE,MAAOL,IAA7C,O,6GCnHW,gBAAW,CACxBR,KADwB,SAGxBqS,cAHwB,EAKxB9T,MAAO,CACL+T,MAAO,CACLxT,KADK,MAELC,QAAS,IAAM,IAEjBwT,QAAS,CACPzT,KADO,OAEPC,QAAS,KAAM,KAEjByT,OAAQ,CACN1T,KAAM,CAACyB,OADD,OAENxB,QAAS,IAAM,IAEjB0T,SAAU,CACR3T,KAAM,CAACgQ,QADC,OAER/P,QAAS,IAAM,IAEjB2T,WAAY,CACV5T,KADU,SAEVC,QAAS,QAEX4T,SArBK,QAsBLC,UAtBK,QAuBLC,KAAM,CACJ/T,KADI,OAEJC,QAAS,GAEX+T,aAAc,CACZhU,KADY,OAEZC,QAAS,IAEXgU,QAAS,CACPjU,KAAM,CAACyB,OADA,OAEPxB,QAAS,IAAM,IAEjBiU,UAAW,CACTlU,KAAM,CAACgQ,QADE,OAET/P,QAAS,IAAM,IAEjBkU,YAAa,CACXnU,KADW,SAEXC,QAAS,QAEXgE,OAAQ,CACNjE,KADM,OAENC,QAAS,SAEXmU,YA/CK,QAgDLC,kBAhDK,QAiDLC,iBAjDK,QAkDLC,OAlDK,OAmDLC,aAAc,CACZxU,KADY,SAEZC,QAAS,QAEXwU,kBAAmB,CACjBzU,KADiB,OAEjBC,SAAU,IAId,OACE,IAAIyU,EAA+B,CACjCX,KAAM3R,KAD2B,KAEjC4R,aAAc5R,KAFmB,aAGjCsR,OAAQ,eAAYtR,KAHa,QAIjCuR,SAAU,eAAYvR,KAJW,UAKjC6R,QAAS,eAAY7R,KALY,SAMjC8R,UAAW,eAAY9R,KANU,WAOjCyR,SAAUzR,KAPuB,SAQjC0R,UAAW1R,KAAK0R,WAGd1R,KAAJ,UACEsS,EAAkBjU,OAAA,SAA+B2B,KAAjD,UAGF,MAAM,wCAA6B8R,GAAnC,EACMS,EAAWjB,EAAA,OAAgBC,EAAjC,OACMiB,EAAYX,EAAA,OAAiBC,EAAnC,OAUA,OARIS,EAAJ,GACED,EAAA,iBAAiC,eAAUC,GAA3C,IAGEC,EAAJ,GACEF,EAAA,kBAAkC,eAAUE,GAA5C,IAGK,CACLF,oBAIJvS,SAAU,CACR,cACE,OAAOC,KAAKqS,mBAAqB,EAAIrS,KAA9B,kBAAuDA,KAAKyS,cAAnE,QAEF,YACE,OAAOzS,KAAKsS,gBAAgBV,cAAgB,EAArC,EAEHnJ,KAAA,KAAUzI,KAAK0S,YAAc1S,KAAKsS,gBAFtC,eAIF,YACE,OAAI,IAAAtS,KAAKsS,gBAAgBV,cAAwB5R,KAAKoR,MAAtD,QAEQpR,KAAKsS,gBAAgBX,KAAtB,GAAkC3R,KAAKsS,gBAA9C,aAF2E,GAI7E,WACE,WAAItS,KAAKsS,gBAAgBV,aAA4B5R,KAAP,YACzCA,KAAKoR,MAAV,OAEO3I,KAAA,IAASzI,KAAT,YAA2BA,KAAKsS,gBAAgBX,KAAO3R,KAAKsS,gBAAnE,cAF+B,GAIjC,YACE,QAAStS,KAAKsS,gBAAgBT,QAA9B,QAEF,aACE,MAAO,CACLF,KAAM3R,KAAKsS,gBADN,KAELV,aAAc5R,KAAKsS,gBAFd,aAGLK,UAAW3S,KAHN,UAIL4S,SAAU5S,KAJL,SAKL6S,UAAW7S,KALN,UAML0S,YAAa1S,KAAK0S,cAGtB,gBACE,IAAItB,EAAQpR,KAAKoR,MAAjB,QAMA,OAJKpR,KAAD,kBAA0BA,KAAKqS,mBAAnC,IACEjB,EAAQpR,KAAKoS,aAAahB,EAAOpR,KAAjC,SAGF,GAEF,gBACE,IAAIoR,EAAQpR,KAAKyS,cAAjB,QAUA,QARMzS,KAAD,aAAqBA,KAAKsS,gBAAgBT,QAA3C,SAA8D7R,KAAKqS,mBAAvE,IACEjB,EAAQpR,KAAK8S,UAAb1B,KAGGpR,KAAD,mBAA2BA,KAAKqS,mBAApC,IACEjB,EAAQpR,KAAK+S,cAAb3B,IAGF,GAEF,eACE,OAAOpR,KAAKgT,UAAYhT,KAAKiT,WAAWjT,KAAjC,eAAP,MAEF,cACE,MAAO,CACLkT,KAAMlT,KADD,KAELmT,UAAWnT,KAFN,UAGLoT,MAAOpT,KAHF,MAILoR,MAAOpR,KAJF,cAKLqR,QAASrR,KALJ,gBAMLqT,cAAerT,KANV,cAOLsT,WAAYtT,KAPP,WAQLuT,aAAcvT,KART,aASLwT,oBAAqBxT,KAAKoR,MAAMhP,SAGpC,kBACE,MAAO,IAAKpC,KAAKqR,WAIrBhQ,MAAO,CACLoS,gBAAiB,CACf,QAAO,KACD,eAAUpC,EAAd,IAEArR,KAAA,kBAEF0T,MANe,EAOfvE,WAAW,GAEbmD,gBAAiB,CACf,QAAO,KACD,eAAUjB,EAAd,IACArR,KAAA,2BAEF0T,MALe,EAMfvE,WAAW,GAEb,KAAI,GACFnP,KAAA,cAAmB,CAAE2R,UAEvB,0BACE3R,KAAA,wBAEF,aAAY,GACVA,KAAA,cAAmB,CAAE4R,kBAEvB,kCACE5R,KAAA,kCAEF,OAAM,GACJA,KAAA,cAAmB,CAAEsR,OAAQ,eAAYA,MAE3C,+BACG,eAAUA,EAAX,IAA2BtR,KAAKyE,MAAM,iBAAkB3D,MAAA,QAAcd,KAAd,UAAsCsR,EAA9F,KAEF,SAAQ,GACNtR,KAAA,cAAmB,CAAEuR,SAAU,eAAYA,MAE7C,iCACG,eAAUA,EAAX,IAA6BvR,KAAKyE,MAAM,mBAAoB3D,MAAA,QAAcd,KAAd,YAA0CuR,EAAtG,KAEF,QAAO,GACLvR,KAAA,cAAmB,CAAE6R,QAAS,eAAYA,MAE5C,gCACG,eAAUA,EAAX,IAA4B7R,KAAKyE,MAAM,kBAAmB3D,MAAA,QAAcd,KAAd,WAAwC6R,EAAlG,KAEF,UAAS,GACP7R,KAAA,cAAmB,CAAE8R,UAAW,eAAYA,MAE9C,kCACG,eAAUA,EAAX,IAA8B9R,KAAKyE,MAAM,oBAAqB3D,MAAA,QAAcd,KAAd,aAA4C8R,EAA1G,KAEF,UAAS,GACP9R,KAAA,cAAmB,CAAE0R,eAEvB,+BACE1R,KAAA,8BAEF,SAAQ,GACNA,KAAA,cAAmB,CAAEyR,cAEvB,8BACEzR,KAAA,6BAEF6S,UAAW,CACT,QAAO,GACL7S,KAAA,uBAEFmP,WAAW,GAEbwE,cAAe,CACb,QAAO,GACL3T,KAAA,0BAEFmP,WAAW,GAEbmE,WAAY,CACV,QAAO,KACD,eAAUA,EAAd,IACAtT,KAAA,mBAAyBA,KAAzB,aAEFmP,WAAW,IAIfhP,QAAS,CACP,OAAM,aACJ,IAAIyT,EAAKC,EAAT,QACIC,EAAOC,EAAX,QACA,MAAMC,EAAUJ,EAAA,UAAcK,GAAcA,IAA5C,GAwBA,OAtBID,EAAJ,GACE,IACEJ,EAAA,GACAE,EAAA,IAGFF,EAAA,QACAE,EAAA,UACSE,GAAA,IAAiBF,EAArB,GACLA,EAAA,MACK,EAILA,EAAA,OAHAF,EAAA,YACAE,EAAA,aAMG,eAAUF,EAAX,IAA0B,eAAUE,EAAxC,KACEnC,EAAA,GAGK,aAAYA,SAErB,MAAK,GACH,MAAQiC,GAAF,EAAeE,KAAf,OAAgCnC,GAAS3R,KAAKmQ,OAAO,EAEzDnQ,KAAKsS,gBAFwC,QAG7CtS,KAAKsS,gBAHwC,UAI7CtS,KAAKsS,gBAJwC,SAA/C,GAQAtS,KAAA,cAAmB,uBAAsB2R,UAE3C,KAAI,GACF,GAAI7Q,MAAA,QAAJ,GAAwB,OAAOd,KAAKmT,UAAZ,GAExB,MAAQS,GAAF,EAAcE,KAAd,OAA8BnC,GAAS3R,KAAKmQ,OAAO,EAEvDnQ,KAAKsS,gBAFsC,OAG3CtS,KAAKsS,gBAHsC,SAI3CtS,KAAKsS,gBAJsC,KAK3CtS,KAAKsS,gBALsC,SAM3CtS,KAAKsS,gBANP,WAQAtS,KAAA,cAAmB,qBAAoB2R,UAEzC,UAAS,GACP,MAAMJ,EAAWD,EAAA,IAAW4C,IAC1B,MAAMhL,EAAIlJ,KAAKsS,gBAAgBhB,OAAO6C,UAAWF,GAAcA,IAA/D,GACA,OAAO/K,GAAA,GAASlJ,KAAKsS,gBAAgBf,SAA9BrI,KAGTlJ,KAAA,cAAmB,UAAUuR,cAE/B,cAAa,GACXvR,KAAA,gBAAuB,IAClBA,KADkB,qBAGrB2R,KAAM3R,KAAKqS,kBAAoB,EAC3B5J,KAAA,MAAYA,KAAA,IAAS4I,EAAA,MAAgBrR,KAAKsS,gBAA9B,KAAoDtS,KAD9D,YAEFqR,EAAA,MAAgBrR,KAAKsS,gBAAgBX,OAG7C,UAAS,GACP,IAAIL,EAAJ,GACIC,EAAJ,GAYA,OAVKvR,KAAL,cACEsR,EAAStR,KAAKsS,gBAAdhB,OACAC,EAAWvR,KAAKsS,gBAAhBf,UAGEvR,KAAKsS,gBAAgBT,QAAzB,SACEP,EAAS,IAAItR,KAAKsS,gBAAT,WAAThB,GACAC,EAAW,IAAIvR,KAAKsS,gBAAT,aAAXf,IAGKvR,KAAKwR,WAAWJ,EAAOE,EAAQC,EAAUvR,KAAhD,SAEF,WAAU,GACR,OAAOA,KAAK+R,YAAYX,EAAOpR,KAAKsS,gBAA7B,QAAsDtS,KAAKsS,gBAAlE,YAEF,cAAa,GAOX,OAJI,IAAAtS,KAAKqS,mBAA4BjB,EAAA,QAAgBpR,KAArD,YACEA,KAAA,qBAA4ByI,KAAA,MAAYA,KAAA,KAAU2I,EAAA,OAAepR,KAAKsS,gBAA1C,gBADuC,GAI9DlB,EAAA,MAAYpR,KAAZ,UAA4BA,KAAnC,YAIJ,SACE,OAAOA,KAAKwM,aAAa3O,SAAWmC,KAAKwM,aAAa3O,QAAQmC,KAA9D,gB,gDC/WW,gBAAW,CACxBlB,KADwB,gBAGxBzB,MAAO,CACLgU,QAAS,CACPzT,KADO,OAEP4F,UAAU,GAEZ8P,WAAY,CACV1V,KADU,OAEV4F,UAAU,GAEZ4Q,oBAAqB,CACnBxW,KADmB,MAEnBC,QAAS,IAAO,CAAC,EAAG,GAAI,IAAR,IAElB0F,SAAU,CACR3F,KADQ,OAERC,QAAS,SAEXwF,SAAU,CACRzF,KADQ,OAERC,QAAS,SAEXwW,UAAW,CACTzW,KADS,OAETC,QAAS,UAEXyW,SAAU,CACR1W,KADQ,OAERC,QAAS,SAEX0W,iBAAkB,CAChB3W,KADgB,OAEhBC,QAAS,wCAEX2W,oBAAqB,CACnB5W,KADmB,OAEnBC,QAAS,uCAEX4W,kBArCK,QAsCLC,gBAtCK,QAuCLzC,kBAvCK,QAwCL0C,oBAxCK,QAyCLC,SAAU,CACRhX,KADQ,OAERC,QAAS,iCAIbkC,SAAU,CACR,sBACE,OAAOC,KAAKqR,QAAQO,cAAgB,GAClC5R,KAAKqR,QAAQM,KAAO3R,KAAKqR,QAAzB,cAAiDrR,KAAKsT,WADjD,aAELtT,KAAKsT,WAAWV,SAFlB,GAIF,kCACE,OAAO5S,KAAKoU,oBAAoB9K,IAAIuL,GAClC,kBAAWA,EAAX,EACY7U,KAAK8U,0BAAZ,MAKX3U,QAAS,CACP,cAAa,GACXH,KAAA,uBAA6B3B,OAAA,UAAkB2B,KAAlB,QAA7B,KAEF,cACEA,KAAA,cAAmB,CAAE2R,KAAM,KAE7B,iBACE3R,KAAA,cAAmB,CAAE2R,KAAM3R,KAAKqR,QAAQM,KAAO,KAEjD,aACE3R,KAAA,cAAmB,CAAE2R,KAAM3R,KAAKqR,QAAQM,KAAO,KAEjD,aACE3R,KAAA,cAAmB,CAAE2R,KAAM3R,KAAKsT,WAAWT,aAE7C,qBAAoB,GAClB7S,KAAA,cAAmB,gBAAgB2R,KAAM,KAE3C,0BAAyB,GACvB,MAAO,CACLoD,MAAM,IAAAF,EAAgB7U,KAAK8B,SAASC,KAAK+B,EAAE9D,KAArC,qBAAiEX,OADlE,GAELE,MAAOsV,IAGX,wBACE,IAAItV,EAAQS,KAAKqR,QAAjB,aACA,MAAM2D,EAAehV,KAArB,gCAEA,OAAIgV,EAAA,QAAJ,EAAqC,MAEhCA,EAAA,KAAkBC,GAAQA,EAAA,QAA/B,KAAsD1V,EAAQyV,EAAR,IAE/ChV,KAAKK,eAAe,MAAO,CAChCX,YAAa,yBACZ,CACDM,KAAK8B,SAASC,KAAK+B,EAAE9D,KADpB,kBAEDA,KAAKK,eAAe6U,EAApB,KAA6B,CAC3BjR,MAAO,CACL,aAAcjE,KAAK8B,SAASC,KAAK+B,EAAE9D,KAArB,mBAEhB3C,MAAO,CACL2D,SAAUhB,KADL,oBAELoR,MAFK,UAIL+D,aAJK,EAKLC,MALK,EAMLC,SAAU,QAEZxU,GAAI,CACFuP,MAAOpQ,KAAKsV,4BAKpB,oBACE,IAAInW,EAAuC,CAA3C,KACA,MAAMuT,EAAsB1S,KAAKsT,WAAjC,YACA,IAAIX,EAAoB3S,KAAKsT,WAA7B,UACIV,EAAmB5S,KAAKsT,WAA5B,SAeA,OAbItT,KAAKsT,WAAWZ,aAAe1S,KAAKsT,WAAxC,cACEX,EAAY3S,KAAKsT,WAAWX,UAA5B,EACAC,EAAWF,EAAc1S,KAAKsT,WAAnB,UAA0CtT,KAAKsT,WAAWV,SAA1D,EAAAF,EAEP1S,KAAKsT,WAFTV,SAIAzT,EAAWa,KAAKwM,aAAa,aACzB,CAACxM,KAAKwM,aAAa,aAAc,wBAAuBkG,iBACxD,CAAC1S,KAAK8B,SAASC,KAAK+B,EAAE9D,KAArB,aAFL,KAGSA,KAAKwM,aAAT,eACLrN,EAAW,CAACa,KAAKwM,aAAa,aAAc,wBAAuBkG,kBAG9D1S,KAAKK,eAAe,MAAO,CAChCV,MAAO,6BADT,IAIF,QAAO,SACL,OAAOK,KAAKK,eAAe2D,EAApB,KAA0B,CAC/B3G,MAAO,CACL2D,SAAUA,GAAYhB,KADjB,kBAELkE,MAFK,EAGL6Q,MAAM,GAIRlU,GAAI,CACFF,SAEFsD,MAAO,CACL,aAAcsR,IAEf,CAACvV,KAAKK,eAAeiB,EAApB,KAdJ,MAgBF,WACE,MAAMkU,EAAN,GACMC,EAAN,GAgCA,OA9BAD,EAAA,KAAYxV,KAAK0V,QACf1V,KADU,mBAEVA,KAAKqR,QAAQM,KACb3R,KAAK8B,SAASC,KAAK+B,EAHT,gCAIV9D,KAAK8B,SAAS6T,IAAM3V,KAApB,SAAoCA,KAJtC,WAOAyV,EAAA,KAAWzV,KAAK0V,QACd1V,KADS,WAETA,KAFS,oBAGTA,KAAK8B,SAASC,KAAK+B,EAHV,gCAIT9D,KAAK8B,SAAS6T,IAAM3V,KAApB,SAAoCA,KAJtC,WAOIA,KAAJ,oBACEwV,EAAA,QAAexV,KAAK0V,QAClB1V,KADa,gBAEbA,KAAKqR,QAAQM,KACb3R,KAAK8B,SAASC,KAAK+B,EAHN,iCAIb9D,KAAK8B,SAAS6T,IAAM3V,KAApB,SAAoCA,KAJtC,YAOAyV,EAAA,KAAWzV,KAAK0V,QACd1V,KADS,WAETA,KAAKqR,QAAQM,MAAQ3R,KAAKsT,WAA1B,YAFS,IAEyCtT,KAAKqR,QAAQO,aAC/D5R,KAAK8B,SAASC,KAAK+B,EAHV,gCAIT9D,KAAK8B,SAAS6T,IAAM3V,KAApB,UAAqCA,KAJvC,YAQK,CACLA,KAAKK,eAAe,MAAO,CACzBX,YAAa,+BAFV,GAILM,KAAK0U,iBAAmB1U,KAAKK,eAAe,OAAQ,CAACL,KAAKqR,QAAQM,KAJ7D,aAKL3R,KAAKK,eAAe,MAAO,CACzBX,YAAa,8BANjB,MAYJ,SACE,OAAOM,KAAKK,eAAe,MAAO,CAChCX,YAAa,iBACZ,CACD,eAAQM,KADP,WAEDA,KAFC,wBAGDA,KAHC,oBAIDA,KANF,gB,gDCxMW,SAAAQ,EAAA,MAAO,EAAD,KAAN,eAGN,CACP1B,KADO,kBAGPzB,MAAO,IACFuY,EAAA,QADE,MAELC,QAAS,CACPjY,KADO,OAEPC,QAAS,MAEX0B,MAAO,CACL3B,KADK,MAELC,QAAS,IAAM,IAEjBiY,aAVK,QAWLC,SAAU,CACRnY,KADQ,MAERC,QAAS,IAAM,IAEjBmY,iBAAkB,IACb,qBADa,iBAEhBnY,QAAS,KAEXoY,aAnBK,QAoBLC,QAAS,CAACtI,QApBL,QAqBLuI,cAAe,CACbvY,KADa,OAEbC,QAAS,uCAEXuY,WAAY,CACVxY,KADU,OAEVC,QAAS,uBAEXwY,YAAa,CACXzY,KADW,OAEXC,QAAS,qCAEXyY,kBAjCK,QAkCLC,YAlCK,OAmCLC,cAAe,CACb5Y,KADa,OAEbC,QAAS,iBAIb4B,KAAM,KAAM,CACVgX,UADW,GAEXC,UAFW,GAGXC,qBAHW,GAIXC,cAJW,EAKXC,WAAY,IAGd9W,SAAU,CACR,YACE,QAASC,KAAK8W,gBAAP,QAAiC9W,KAAK8W,gBAAgBC,MAAO7N,GAAWlJ,KAAK8F,WAApF,KAEF,YACE,OAAO9F,KAAK8W,gBAAgBE,KAAM9N,GAAWlJ,KAAK8F,WAAlD,KAEF,uBACE,OAAO,eAAmB9F,KAA1B,cAEF,kBACE,OAAOA,KAAK2W,qBAAqBjH,OAAOuH,GAAQjX,KAAKkX,aAArD,MAIJ7V,MAAO,CACL9B,MAAO,CACL,QAAO,GACLS,KAAA,UAAiBT,EAAA,OAAa,CAACkX,EAAWQ,KACxCR,EAAU,eAAqBQ,EAAMjX,KAArC,YACA,GAFF,KAKFmP,WAAW,GAEb,UAAS,KACH,eAAU9Q,OAAA,KAAD,GAAqBA,OAAA,KAAlC,KAEA2B,KAAA,cAAoB3B,OAAA,OAApB,KAEF0X,SAAU,CACR,QAAO,GACL/V,KAAA,UAAiBT,EAAA,OAAa,CAACmX,EAAWO,KACxCP,EAAU,eAAqBO,EAAMjX,KAArC,aACA,GAFF,KAKFmP,WAAW,GAEb,UAAS,KACP,GAAI,eAAU5P,EAAd,GAA2B,OAC3B,MAAM4X,EAAO9Y,OAAA,eAA0B4V,GAAK1U,EAA5C,IACMwW,EAAYoB,EAAD,OAAoBnX,KAAKoR,MAAM1B,OAAOxG,GAAKiO,EAAA,SAAc9X,OAAO,eAAqB6J,EAAGlJ,KAAzG,YAAiB,GACjBA,KAAA,6BAIJ,UACE,MAAMoX,EAAgB,CACpB,CAAC,uBADmB,WAEpB,CAAC,SAFmB,iBAGpB,CAAC,aAHmB,WAIpB,CAAC,cAJmB,uBAKpB,CAAC,eALmB,uBAMpB,CAAC,sBANmB,uCAOpB,CAAC,qBAPmB,oCAQpB,CAAC,YARmB,0BASpB,CAAC,YATH,2BAaAA,EAAA,QAAsB,EAAEC,EAAF,MAChBrX,KAAKsX,OAAOC,eAAhB,IAA0C,eAASF,EAAUG,EAAnB,QAG5C,MAAMC,EAAe,CAAC,SAAD,gCAArB,eAQAA,EAAA,QAAqB7Y,IACfoB,KAAKsX,OAAOC,eAAhB,IAAsC,qBAI1C,UACEG,OAAA,2BAAmC1X,KAAnC,WACA0X,OAAA,yBAAiC1X,KAAjC,UAEF,gBACE0X,OAAA,8BAAsC1X,KAAtC,WACA0X,OAAA,4BAAoC1X,KAApC,UAGFG,QAAS,CACP,UAAS,GACH6C,EAAA,UAAc,OAAlB,QACAhD,KAAA,kBAEF,QAAO,GACDgD,EAAA,UAAc,OAAlB,QACAhD,KAAA,kBAEF,gBAAe,GACb,MAAMyW,EAAYpY,OAAA,UAAkB2B,KAApC,WAEA,IAAK,IAAIkJ,EAAT,EAAgBA,EAAIlJ,KAAK8W,gBAAzB,OAAiD5N,IAAK,CACpD,MAAM+N,EAAOjX,KAAK8W,gBAAlB,GAEA,IAAK9W,KAAKkX,aAAV,GAA8B,SAE9B,MAAMtV,EAAM,eAAqBqV,EAAMjX,KAAvC,SACA,EAAWyW,EAAA,GAAX,SACYA,EAAP,GAGPzW,KAAA,YACAA,KAAA,0BAAgC,CAAEoR,MAAOpR,KAAT,qBAAoCT,WAEtE,aAAY,GACV,WAAO,eAAqB0X,EAAMjX,KAA3B,gBAET,WAAU,GACR,QAASA,KAAKyW,UAAU,eAAqBQ,EAAMjX,KAA5C,YAAP,GAEF,OAAM,EAAaT,GAAb,EAA2BoY,GAA3B,GACJ,IAAK3X,KAAKkX,aAAV,GAA8B,OAE9B,MAAMT,EAAYzW,KAAK8V,aAAe,GAAKzX,OAAA,UAAkB2B,KAA7D,WACM4B,EAAM,eAAqBqV,EAAMjX,KAAvC,SAEA,EAAWyW,EAAA,GAAX,SACYA,EAAP,GAEL,MAAMmB,EAAQ5X,KAAK8W,gBAAgB3C,UAAUxE,GAAK,eAAqBA,EAAG3P,KAAxB,WAAlD,GAKA,IAJA,IAAIA,KAAK6W,UAAkB7W,KAAK6W,UAAhC,EACS7W,KAAK4W,eAAiB5W,KAAtB,cAAJ,GAAqDA,KAAK6X,eAAetY,EAAOoY,EAAMlB,EAAWmB,GACtG5X,KAAA,YAEIA,KAAK8V,cAAT,EAA+B,CAC7B,MAAMqB,EAAO9Y,OAAA,KAAY2B,KAAzB,WACM8X,EAAMX,EAAA,QAAe,eAAqBnX,KAAKyW,UAAUU,EAAhB,IAA0BnX,KAAzE,SACA8X,GAAOA,IAAP,GAAsB9X,KAAKyE,MAAM,gBAAiB,CAAEwS,KAAMjX,KAAKyW,UAAb,GAA6BlX,OAAO,IAExFS,KAAA,YACA2X,GAAQ3X,KAAKyE,MAAM,gBAAiB,QAAQlF,WAE9C,eAAgBA,GAAF,EAAgBoY,GAAhB,OACZ,MAAMnV,EAAQoV,EAAQ5X,KAAR,UAAA4X,EAAiC5X,KAA/C,UACM+X,EAAMH,EAAQ5X,KAAR,UAAyBA,KAAzB,UAAZ,EACA,IAAK,IAAIkJ,EAAT,EAAoBA,GAApB,EAA8BA,IAAK,CACjC,MAAM8O,EAAchY,KAAK8W,gBAAzB,GACMlV,EAAM,eAAqBoW,EAAahY,KAA9C,SACA,EAAWyW,EAAA,GAAX,SACYA,EAAP,GACLkB,GAAQ3X,KAAKyE,MAAM,gBAAiB,eAAelF,YAGvD,WAAU,GACR,OAAOS,KAAK0W,UAAU,eAAqBO,EAAMjX,KAA1C,YAAP,GAEF,OAAM,EAAaT,GAAb,GACJ,MAAMmX,EAAY1W,KAAKiW,aAAe,GAAK5X,OAAA,UAAkB2B,KAA7D,WACM4B,EAAM,eAAqBqV,EAAMjX,KAAvC,SAEA,EAAW0W,EAAA,IAAX,SACYA,EAAP,GAEL1W,KAAA,YACAA,KAAA,sBAA4B,QAAQT,WAEtC,gBAAe,KACb,MAAO,gBAGL0Y,OAASxR,GAAezG,KAAKiY,OAAOhB,EAH/B,GAILnR,WAAY9F,KAAK8F,WAJZ,GAKLoS,OAASzR,GAAezG,KAAKkY,OAAOjB,EAL/B,GAMLkB,WAAYnY,KAAKmY,WANZ,GAOLC,SAAUpY,KAAKoY,WAGnB,gBAAe,GACb,OAAOpY,KAAKK,eAAe,MAA3B,IAEF,SAAQ,KACN,GAAI,IAAAmT,GAA6BxT,KAAjC,QAA+C,CAC7C,MAAMkW,EAAUlW,KAAKC,OAAOiW,SAAWlW,KAAK8B,SAASC,KAAK+B,EAAE9D,KAA5D,aACA,OAAOA,KAAKqY,gBAAZ,GACK,OAAI7E,EAA2B,CACpC,MAAM8E,EAAStY,KAAKC,OAAO,YAAcD,KAAK8B,SAASC,KAAK+B,EAAE9D,KAA9D,YACA,OAAOA,KAAKqY,gBAAZ,GACK,OAAIE,EAA2B,CACpC,MAAMC,EAAYxY,KAAKC,OAAO,eAAiBD,KAAK8B,SAASC,KAAK+B,EAAE9D,KAApE,eACA,OAAOA,KAAKqY,gBAAZ,GAGF,aAEF,SAAQ,GACN,MAAMI,EAAQzY,KAAK0Y,SAASrb,EAAd,oBAAyCA,EAAA,WAAvD,aACA,SAAkB,CAAP,GAEP2C,KAAKwM,aAAT,QACSxM,KAAKwM,aAAa3O,QAAQ,MAE/BiI,WAAY9F,KAFmB,WAG/BiY,OAAQjY,KAHuB,OAI/BmY,WAAYnY,KAJmB,WAK/BoY,SAAUpY,KALqB,SAM/BkY,OAAQlY,KAAKkY,SAIblY,KAAKwM,aAAT,KACSnP,EAAA,UAAgB,CAAC4Z,EAAD,IAAsBjX,KAAKwM,aAAayK,KAAMjX,KAAK2Y,gBAAgB,EAA1F,KAMF,IAEF,UAAS,GACP,GAAI3Y,KAAJ,kBAA4B,OAAO,KAEnC,MAAMP,EAAO,CACXpC,MAAO,IACF2C,KADE,qBAELqR,QAAShU,EAFJ,QAGLiW,WAAYjW,EAAMiW,YAEpBzS,GAAI,CACF,iBAAmBtB,GAAelC,EAAA,mBAIhCub,EAAc,eAAuB,UAAW5Y,KAAtD,cAEA,OAAOA,KAAKK,eAAe,EAAa,kBAEnCZ,KAGP,qBAAoB,GAClB,MAAMoZ,EAAa,MAEjBC,UAAW9Y,KAFM,UAGjB+Y,UAAW/Y,KAHM,UAIjBgZ,gBAAiBhZ,KAAKgZ,iBAGxB,OAAOhZ,KAAKK,eAAe,MAAO,CAChCX,YAAa,mBACZ,CACD,eAAQM,KAAM,SAAU6Y,GADvB,GAED7Y,KAAKiZ,SAFJ,GAGDjZ,KAAKkZ,UAHJ,GAID,eAAQlZ,KAAM,SAAU6Y,GAN1B,OAWJ,SACE,OAAO7Y,KAAKK,eAAeuV,EAAO,CAChCvY,MAAO2C,KADyB,OAEhCa,GAAI,CACF,iBAAkB,CAAC4F,EAAD,KAAuB,eAAUA,EAAX,IAAsBzG,KAAKyE,MAAM,iBADvE,GAEF,cAAgBgC,GAAWzG,KAAKyE,MAAM,cAFpC,GAGF,wBAA0BgC,GAAWzG,KAAKyE,MAAM,wBAH9C,GAIF,iBAAmBgC,GAAWzG,KAAKyE,MAAM,iBAJvC,GAKF,mBAAqBgC,GAAWzG,KAAKyE,MAAM,mBALzC,GAMF,kBAAoBgC,GAAWzG,KAAKyE,MAAM,kBANxC,GAOF,oBAAsBgC,GAAWzG,KAAKyE,MAAM,oBAP1C,GAQF6O,WAAY,CAAC7M,EAAD,KAAuB,eAAUA,EAAX,IAAsBzG,KAAKyE,MAAM,aARjE,GASF,gBAAkBgC,IAChBzG,KAAA,uBACAA,KAAA,0BAEF,aAAeyG,GAAczG,KAAKyE,MAAM,aAAcgC,IAExDmS,YAAa,CACX/a,QAASmC,KAAKmZ,2B,gDC7UP,SAAA3Y,EAAA,eAAyB,CAEtCyE,WAAY,CACVmU,SAAA,MAGF/b,MAAO,CACLgc,QAAS,CACPzb,KADO,MAEPC,QAAS,IAAO,IAElBwT,QAAS,CACPzT,KADO,OAEPC,QAAS,KAAM,CACb8T,KADc,EAEdC,aAFc,GAGdN,OAHc,GAIdC,SAJc,GAKdM,QALc,GAMdC,UANc,GAOdJ,WAPc,EAQdD,UAAU,KAGd6H,cAlBK,OAmBLC,SAAU,CACR3b,KADQ,OAERC,QAAS,SAEXkb,UAvBK,QAwBLD,UAxBK,QAyBLU,YAzBK,QA0BL1D,aA1BK,QA2BL9D,YAAapE,SAGfzN,QAAS,CACP,eAAY,MACV,MAAMV,EAAO,CACXpC,MAAO,CACLkC,MAAOS,KADF,UAELyZ,eAAgBzZ,KAAD,WAAmBA,KAF7B,UAGLsE,MAAK,SAAEtE,KAAF,iBAAwB,IAE/Ba,GAAI,CACFuP,MAAQ3J,GAAezG,KAAKyE,MAAM,oBAAqBgC,KAI3D,OAAIzG,KAAKwM,aAAT,qBACSxM,KAAKwM,aAAa,qBAAzB,GAGKxM,KAAKK,eAAeqZ,EAApB,KAAqC,CAC1Cha,YAD0C,4BAEvCD,KAGP,cACE,OAAOO,KAAKK,eAAeiB,EAApB,KAA2B,CAChC5B,YADgC,4BAEhCrC,MAAO,CACLsc,KAAM,KAEP,CAAC3Z,KALJ,eCpES,SAAAQ,EAAA,gBAAsB,CACnC1B,KADmC,6BAGnCzB,MAAO,CACLuc,WAAY,CACVhc,KADU,OAEVC,QAAS,8BAIbsC,QAAS,CACP,YAAW,GACT,MAAMhB,EAAuC,CAAC9B,EAAA,KAA9C,MAEMwc,EAAY7Z,KAAKqR,QAAQC,OAAO6C,UAAUF,GAAKA,IAAM5W,EAAA,KAA3D,OACMyc,EAAcD,GAApB,EACME,EAAS/Z,KAAKqR,QAAQE,SAA5B,GAYA,OAVApS,EAAA,KAAca,KAAKK,eAAe,MAAO,CACvCX,YADuC,gBAEvCC,MAAO,CACLqa,UADK,EAELtZ,OAFK,EAGLuZ,IAAKH,IAHA,EAILhG,KAAMgG,GAAeC,IAEtB,CAAC/Z,KARJ,iBAUOA,KAAKK,eAAe6Z,EAApB,KAA2B,CAChCxa,YADgC,WAEhCmB,GAAI,CACFF,MAAQqC,IACNA,EAAA,kBACAhD,KAAA,aAAmB3C,EAAA,KAAnB,UALN,IAUF,cAAa,GACX,OAAO2C,KAAKK,eAAe6U,EAApB,KAA6B,CAClC7X,MAAO,CACLkY,MAAOvV,KAAK8B,SAASC,KAAK+B,EAAE9D,KADvB,oBAGLmV,aAHK,EAIL/H,SAAUpN,KAAKqR,QAJV,UAKL9R,MAAOS,KAAKqR,QAAQK,UAAY1R,KAAKqR,QAA9B,OAA+CrR,KAAKqR,QAAQC,OAL9D,GAML6I,UAAW,CAAEC,qBAAqB,IAEpCvZ,GAAI,CACF+C,OAAS6C,GAAyBzG,KAAKyE,MAAM,OAAQgC,IAEvDmS,YAAa,CACXnC,UAAWpZ,GAAS2C,KAAKqa,YAAYhd,QAM7C,OAAM,GACJ,MAAM8B,EAAN,GAEMoF,EAASvE,KAAKqZ,QAAQiB,KAAK9a,GAAjC,sBAAsCA,EAAA,OAClC+E,IAAWvE,KAAf,cACEb,EAAA,KAAca,KAAKK,eAAe,MAAO,CACvCV,MAAO,CAAC,wCAEH,eAAY4E,EAHsB,QAKvCN,MAAO,CACL+H,MAAOzH,EAAOyH,QAEf,CAAChM,KARJ,kBAWF,MAAMua,EAAcva,KAAKqZ,QAAL,OACV7Z,IAAK,IAAAA,EAAA,UADK,sBACmBA,EAAA,OADnB,IAEbA,IAAK,CACRuV,KAAMvV,EADG,KAETD,MAAOC,EAAED,UAGRS,KAAD,aAAqBua,EAAzB,QACEpb,EAAA,KAAca,KAAKwa,cAAnB,IAGF,MAAMC,EAAKjb,EAAE,KAAM,CAACA,EAAE,MAAO,CAAEE,YAAa,uCAA5C,KAEMgb,EAAKlb,EAAE,KAAM,CAAnB,IAEA,OAAOA,EAAE,QAAS,CAChBE,YAAa,kDACZ,CAFH,OCzFW,SAAAc,EAAA,gBAAsB,CACnC1B,KADmC,8BAGnCqB,QAAS,CACP,iBAAgB,GACd,OAAOH,KAAKK,eAAe,OAAQ,CACjCQ,GAAI,CACFF,MAAQqC,IACNA,EAAA,kBACAhD,KAAA,cAAoBuE,EAApB,UAGH,CAPH,WASF,QAAO,KACL,MAAMoW,EAAM/Y,GAAgB5B,KAAK8B,SAASC,KAAK+B,EAAE,gCAAgClC,GAEjF,IAAIgZ,EAAJ,OACI/W,EAAY,CACd8W,EADc,YAEdA,EAFF,sBAKA,UAIA,GACEC,EAAA,aACA/W,EAAY,CACV8W,EADU,kBAEVA,EAAG3a,KAAKqR,QAAQI,SAAW,oBAF7B,mBAKAmJ,EAAA,YACA/W,EAAY,CACV8W,EADU,iBAEVA,EAFF,wBAMK,YAAY9W,UAAWA,EAAA,YAjBrB,YAAYA,UAAWA,EAAA,YAmBlC,UAAS,GACP,MAAMpE,EAAsE,CAC1EwE,MAAO,CACL4W,KADK,eAELC,MAFK,MAGL,aAAcvW,EAAA,MAAe,IAE/BjE,MAAO,CACL0L,MAAO,eAAczH,EADhB,OAEL8Q,SAAU,eAAc9Q,EAAD,QAEzB5E,MAAO,CACL,SAAQ4E,EAAA,OAAgB,YACrB,eAAYA,EAFV,OAGLA,EAAA,SAbwE,yBAe1E1D,GAAI,IAEA1B,EAAN,GAEA,GAAI,sBAAAoF,EAAA,QAAyCvE,KAA7C,aACE,OAAOA,KAAKK,eAAe,KAAMZ,EAAM,CAACO,KAAxC,iBASF,GANAb,EAAA,KACEa,KAAKwM,aAAajI,EAAlB,OACIvE,KAAKwM,aAAajI,EAAlB,OAAiC,CAAEA,WACnCvE,KAAKK,eAAe,OAAQ,CAACkE,EAHnC,SAMKvE,KAAD,cAAsBuE,EAAA,WAAoBA,EAAA,eAA9C,aAAkF,CAChF9E,EAAA,SAAgB,IAAMO,KAAKyE,MAAM,OAAQF,EAAzC,OAEA,MAAMsV,EAAY7Z,KAAKqR,QAAQC,OAAO6C,UAAUF,GAAKA,IAAM1P,EAA3D,OACMuV,EAAcD,GAApB,EACME,EAAS/Z,KAAKqR,QAAQE,SAA5B,GAEA9R,EAAA,uBAEA,MAAM,qBAAamb,GAAa5a,KAAK+a,QAAQjB,EAA7C,GAEAra,EAAA,qBAA4B,GAAG8E,EAAA,UAAqB,KAAKV,IACzDpE,EAAA,qBAEA,IACEA,EAAA,qBACAA,EAAA,WAAgBsa,EAAS,OAAzB,QAGF,QAAIxV,EAAA,MAAwBpF,EAAA,QAAiBa,KAA7C,eACKb,EAAA,KAAca,KAAd,eAEDA,KAAKqR,QAAQK,WAAjB,GACEvS,EAAA,KAAca,KAAKK,eAAe,OAAQ,CAAEV,MAAO,mCAAqC,CAACN,OAAOwa,EAAhG,MAMJ,OAFI7Z,KAAKwZ,cAAT,IAAwBjV,EAAA,WAA4BpF,EAAA,KAAca,KAAKgb,iBAAnB,IAE7Chb,KAAKK,eAAe,KAAMZ,EAAjC,KAIJ,SACE,OAAOO,KAAKK,eAAe,QAAS,CAClCX,YAAa,uBACZ,CACDM,KAAKK,eAAe,KAAML,KAAKqZ,QAAQ/P,IAAI/E,GAAUvE,KAAKib,UAH5D,UC1GU,cACZ,GAAIxb,EAAA,OAAcA,EAAd,IAAyBA,EAAA,GAA7B,MACE,GAAIqB,MAAA,QAAcrB,EAAA,GAAlB,OAAkC,CAChC,MAAMyJ,EAAIzJ,EAAA,iBAAsBA,EAAA,MAAhC,UACIyJ,GAAJ,GAAYzJ,EAAA,iCAELA,EAAA,GAAP,M,gBCZQ,gBACZ,MAAMN,EAAN,GAEA,IAAK,MAAL,OACM+b,EAAA,eAAJ,IACE/b,EAAA,KAAcK,EAAE,WAAY,CAAEoN,QAAQsO,EAAtC,KAIJ,SCQa,oBAAW,CACxBpc,KADwB,sBAGxBC,YAHwB,EAKxB1B,MAAO,IACF,UADE,MAEL8d,OAAQvN,SAGV,OAAM,GAAK,qBAAesN,IACxBE,EAAA,GACA,MAAMjc,EAAW,EAAa+b,IAA9B,GAIA,OAFAzb,EAAO,OAAA4b,EAAA,MAAU5b,EAAM,CAAEpC,UAErBA,EAAJ,OACSmC,EAAE8b,EAAwB7b,EAAjC,GAEOD,EAAE+b,EAAyB9b,EAAlC,MC/BS,gBAAW,CACxBX,KADwB,MAGxBC,YAHwB,EAKxB1B,MAAO,CACLgc,QADK,MAELzB,MAFK,OAGLX,KAHK,OAILtB,IAAK/H,SAGP,OAAM,GAAK,qBAAgBnO,IACzB,MAAM+b,EAAgBN,IAEhBO,EAAmBpe,EAAA,YAAmBkH,IAC1C,MAAMpF,EAAN,GACMI,EAAQ,eAAqBlC,EAAD,KAAakH,EAA/C,OAEMmX,EAAWnX,EAAjB,MACMoX,EAAalc,EAAA,aAAoBA,EAAA,YAAvC,GACMmc,EAAcJ,EAApB,GAEA,EACErc,EAAA,KAAcwc,EAAW,CACvB1E,KAAM5Z,EADiB,KAEvB+a,UAFuB,WAIvBR,MAAOva,EAJgB,MAKvBkC,WAEOqc,EACTzc,EAAA,QAEAA,EAAA,KAAc,MAAAI,IAAwBF,OAAtC,IAGF,MAAMwc,EAAY,SAAQtX,EAAA,OAAgB,SAE1C,OAAO/E,EAAE,KAAM,CACbG,MAAO,CAAC,EAEN4E,EAFK,UAGL,CACE,wBAAyBA,EAAOuX,WALtC,KAWF,OAAOtc,EAAE,KAAMC,EAAf,MCvDW,gBAAW,CACxBX,KADwB,YAGxBC,YAHwB,EAKxB1B,MAAO,CACLkC,MAAO,CACL3B,KADK,QAELC,SAAS,GAEXke,YAAa,CACXne,KADW,OAEXC,QAAS,uBAEXme,aATK,OAULC,aAAc,CACZre,KADY,OAEZC,QAAS,yBAIb,OAAM,GAAK,cAASR,IAClB,MAAMme,EAAgBN,IAChB/b,EAAN,GAoBA,OAlBIqc,EAAJ,iBACErc,EAAA,KAAcK,EAAE,KAAM,CACpBE,YAAarC,EAAM0e,aAClBP,EAFH,mBAGSA,EAAJ,eACLrc,EAAA,QAAiBqc,EAAjB,eAGEA,EAAA,gBAAgCne,EAApC,OAAiD8B,EAAA,QAAiBqc,EAAjB,gBAE7CA,EAAJ,kBACErc,EAAA,KAAcK,EAAE,KAAM,CACpBE,YAAarC,EAAM4e,cAClBT,EAFH,oBAGSA,EAAJ,gBACLrc,EAAA,QAAiBqc,EAAjB,gBAGF,K,YCzCW,gBAAW,CACxB1c,KADwB,MAGxBC,YAHwB,EAKxB1B,MAAO,CACLgc,QADK,MAEL6C,kBAFK,QAGLtE,MAHK,OAILX,KAJK,OAKLtB,IAAK/H,SAGP,OAAM,GAAK,qBAAgBnO,IACzB,MAAM+b,EAAgBN,IAEhBO,EAAmBpe,EAAA,YAAmBkH,IAC1C,MAAMhE,EAAU,CACd,4BAA4B,GAGxBpB,EAAN,GACMI,EAAQ,eAAqBlC,EAAD,KAAakH,EAA/C,OAEMmX,EAAWnX,EAAjB,MACMoX,EAAalc,EAAA,aAAoBA,EAAA,YAAvC,GACMmc,EAAcJ,EAApB,GAEA,EACErc,EAAA,KAAcwc,EAAW,CACvB1E,KAAM5Z,EADiB,KAEvB+a,UAFuB,WAIvBR,MAAOva,EAJgB,MAKvBkC,WAEOqc,EACTzc,EAAA,QAEAA,EAAA,KAAc,MAAAI,IAAwBF,OAAtC,IAGF,MAAM8c,EAAoB,CACxB3c,EAAE,MAAO,CACPE,YAAa,kCAFjB,IAcA,MARI,oBAAA6E,EAAA,OAAuClH,EAA3C,mBACE8e,EAAA,QACE3c,EAAE,MAAO,CACPE,YAAa,oCACZ,CAAC6E,EAHN,QAOK/E,EAAE,KAAM,CAAEG,MAAOY,GAAxB,KAGF,OAAOf,EAAE,KAAM,MAAWE,YAAa,kCAAvC,M,YCpBJ,SAAS0c,EAAT,OACE,OAAQ7X,IACN,MAAMhF,EAAQ,eAAqB0X,EAAM1S,EAAzC,OACA,OAAOA,EAAA,OAAgBA,EAAA,WAAhB,GAAqDmL,EAAOnQ,EAAO4S,EAA1E,IAIJ,SAASkK,EAAT,WASE,OAFAlK,EAA2B,kBAAXA,EAAsBA,EAA7B,OAAT,KAEOf,EAAA,OAAa6F,IAGlB,MAAMqF,EAAuBC,EAAA,MAA+BH,EAASnF,EAAM9E,EAHlD,SAOnBqK,GAAqBrK,GAAUsK,EAAA,KAAiCL,EAASnF,EAAM9E,EAArF,IAEA,OAAOmK,GAAP,IAKW,cAAA9b,EAAA,MAAO,EAAP,eAGN,CACP1B,KADO,eAIPmG,WAAY,CACVmU,SAAA,MAGF/b,MAAO,CACLgc,QAAS,CACPzb,KADO,MAEPC,QAAS,IAAM,IAEjB6e,WALK,QAMLpD,cANK,OAOLqD,WAPK,QAQLnD,YARK,QAWL3Z,OAAQ,CAACC,OAXJ,QAYLoc,kBAZK,QAaLU,QAbK,OAcL3d,MAdK,QAeL4d,YAfK,OAgBLC,gBAhBK,QAiBLld,YAjBK,QAkBLmd,cAlBK,OAmBLC,WAAY,CACVpf,KADU,OAEVC,QAAS,WAEXuU,aAAc,CACZxU,KADY,SAEZC,QAAS,QAEXof,UAAW,CACTrf,KAAM,CAACyB,OADE,UAETxB,QAAS,IAAM,IAEjBqf,aAAc,CACZtf,KAAM,CAACkC,OADK,QAEZjC,QAAS,IAIb,OACE,MAAO,CACLsf,gBADK,GAELC,UAFK,GAGLC,OAAQ,KAIZtd,SAAU,CACR,kBACE,IAAKC,KAAL,QAAmB,MAAO,GAC1B,MAAMqZ,EAAUrZ,KAAKqZ,QAAQ3J,OAAOlQ,QAAK,IAAAA,EAAA,QAA0BQ,KAAKmd,gBAAgB7C,KAAK7T,GAAKA,IAAMjH,EAAxG,QACM8d,EAAgB,CAAEvI,KAAF,GAAYiF,UAAZ,EAA6BhO,MAAO,OAE1D,GAAIhM,KAAJ,WAAqB,CACnB,MAAM4X,EAAQyB,EAAA,UAAkB7Z,GAAhC,sBAAqCA,EAAA,OACjCoY,EAAJ,EAAeyB,EAAA,QAAgB,MAAoB9Z,MAAO,sBACrD8Z,EAAA,WAAyB,SAAuBA,EAAQzB,KAG/D,GAAI5X,KAAJ,WAAqB,CACnB,MAAM4X,EAAQyB,EAAA,UAAkB7Z,GAAhC,sBAAqCA,EAAA,OACjCoY,EAAJ,EAAeyB,EAAA,QAAgB,MAAoB9Z,MAAO,sBACrD8Z,EAAA,WAAyB,SAAuBA,EAAQzB,KAG/D,UAEF,eACE,OAAO5X,KAAKoY,cAAWjM,EAAY,CACjCoR,QAASvd,KAAK+c,eAAiB/c,KAAKwd,gBAAgBpb,SAGxD,gBACE,OAAOpC,KAAKwd,gBAAgBC,OAAiD,CAACC,EAAKnZ,KAC7EA,EAAJ,OAAiBmZ,EAAInZ,EAAJ,OAAoBA,EAApB,MACjB,GAFF,KAKF,2BACE,OAAOvE,KAAKqZ,QAAQ3J,OAAOnL,GAAUA,EAAA,UAAmBA,EAAA,eAAD,gBAAvD,IAA+FA,EAAA,cAEjG,8BACE,OAAOvE,KAAKqZ,QAAQ3J,OAAOnL,IAAWA,EAAD,UAAoBA,EAAA,eAAD,gBAAxD,IAAgGA,EAAA,cAElG,uBACE,OAAO,eAAmBvE,KAA1B,cAEF,uBACE,MAAM4R,EAAe5R,KAAKqR,SAAWrR,KAAKqR,QAArB,aAA4CrR,KAAKqR,QAAjD,aAAwErR,KAA7F,aACMoU,EAA4DpU,KAAK2d,qBAAvE,oBAEA,GACEvJ,IACCA,EAAA,KAAyB6C,GAAwB,kBAATA,EAAoBA,IAA3B,EAAmDA,EAAA,QAFvF,GAGE,CACA,MAAM2G,EAAcxJ,EAApB,GACA,MAA8B,kBAAhBwJ,EAA2BA,EAAlC,MAAP,EAGF,WAIJ,UACE,MAAMxG,EAAgB,CACpB,CAAC,YADmB,0BAEpB,CAAC,eAFmB,uBAGpB,CAAC,aAHH,gBAOAA,EAAA,QAAsB,EAAEC,EAAF,MAChBrX,KAAKsX,OAAOC,eAAhB,IAA0C,eAASF,EAAUG,EAAnB,SAI9C,UAMMxX,KAAJ,kBACE0X,OAAA,0BAAkC1X,KAAlC,YACAA,KAAA,eAIJ,gBACMA,KAAJ,iBACE0X,OAAA,6BAAqC1X,KAArC,aAIJG,QAAS,CACP,aACEH,KAAA,OAAcc,MAAA,KAAWd,KAAKkL,IAAI2S,iBAApB,WAAgD7a,GAAKA,EAAnE,cAEF,wBAAuB,KACrB,OAAOqZ,EAAiBjL,EAAOe,EAAQnS,KAAhB,yBAA+CA,KAA/C,4BAAiFA,KAAxG,eAEF,sBAAqB,SACnB,OAAOA,KAAKwR,WAAWJ,EAAOE,EAAQC,EAAU1P,EAAQ7B,KAAxD,gBAEF,gBAAe,KACb,MAAM3C,EAAQygB,EAAA,4CAAd,GAEA,OAAOzf,OAAA,SAAqB,CAAEgb,QAASrZ,KAAKwd,mBAE9C,WAAU,GACR,OAAIxd,KAAJ,QAAyB,CAACA,KAAKK,eAAe,UAAW,CAACL,KAAxC,WAEX,eAAQA,KAAM,UAAW3C,GAAhC,IAEF,YAAW,GACT,OAAO2C,KAAKK,eAAe,WAAYL,KAAKwd,gBAAgBlU,IAAI/E,GACvDvE,KAAKK,eAAe,MAAO,CAChCV,MAAO,CACLmc,QAASvX,EAAOuX,cAKxB,aACE,MAAMrB,EAAKza,KAAKK,eAAe,KAAM,CACnCX,YADmC,SAEnCuE,MAAOjE,KAAK+d,cACX,CAAC/d,KAHJ,gBAKM0a,EAAK1a,KAAKK,eAAe,KAAM,CACnCX,YAAa,0BACZ,CAFH,IAIA,OAAOM,KAAKK,eAAe,QAAS,CAApC,KAEF,WAAU,GACR,MAAMZ,EAAO,CACXpC,MAAO,IACF2C,KADE,qBAELqZ,QAASrZ,KAFJ,gBAGLqR,QAAShU,EAHJ,QAIL8d,OAAQnb,KAJH,SAKLwZ,YAAaxZ,KALR,YAMLsZ,cAAetZ,KANV,cAOL8Y,UAAW9Y,KAPN,UAQL+Y,UAAW/Y,KARN,UASL8V,aAAc9V,KATT,aAULgS,YAAahS,KAAKgS,aAEpBnR,GAAI,CACFqS,KAAM7V,EADJ,KAEF+V,MAAO/V,EAFL,MAGF,oBAAqB2C,KAAKgZ,kBAKxB7Z,EAAuC,CAAC,eAAQa,KAAM,SAAU,MAEpEoY,SAAUpY,KAAKoY,YAGjB,IAAKpY,KAAL,kBAA6B,CAC3B,MAAM4Y,EAAc,eAAuB,UAAW5Y,KAAtD,cACAb,EAAA,KAAca,KAAKK,eAAe,EAAkB,MAElDuY,iBAMJ,OAFI5Y,KAAJ,SAAkBb,EAAA,KAAca,KAAd,cAElB,GAEF,gBAAe,GACb,OAAOA,KAAKK,eAAe,KAAM,CAC/BX,YAAa,+BACZ,CACDM,KAAKK,eAAe,KAAM,CACxB4D,MAAOjE,KAAK+d,cAJhB,MAQF,SAAQ,KACN,MAAMtF,EAAQzY,KAAK0Y,SAASrb,EAAd,oBAAyCA,EAAA,WAAvD,aACA,SAAkB,CAAP,GAEJA,EAAA,aACH2C,KAAKge,eAAe3gB,EAApB,aADGA,GAEH2C,KAAKie,QAAQ7M,EAFjB,IAIF,eAAc,KACZ,OAAOmC,EAAA,IAAiBH,IACjBpT,KAAKod,UAAU7F,eAAenE,EAAnC,OAAgDpT,KAAKke,KAAKle,KAAV,UAA0BoT,EAA1B,SAE5CpT,KAAKwM,aAAT,MACSxM,KAAKwM,aAAa4G,MAAM,CAC7BA,MAAOA,EADsB,KAE7B/B,QAAShU,EAFoB,QAG7B+a,SAAUpY,KAHmB,SAI7BoR,MAAOgC,EAJsB,MAK7BiG,QAASrZ,KAAKwd,kBAGTxd,KAAKme,qBAAqB/K,EAA1B,KAAsCA,EAAtC,MAAP,MAIN,qBAAoB,OAClB,MAAMgL,IAAWpe,KAAKod,UAAtB,GACMje,EAA0B,CAC9Ba,KAAKK,eAAe,WAAY,CAAEuM,KAAM,eAAiB5M,KAAKie,QAAQ7M,EADxE,KAGMiN,EAAW,IAAMre,KAAKke,KAAKle,KAAV,aAAkCA,KAAKod,UAA9D,IACMkB,EAAW,IAAMjhB,EAAA,cAAoB,CAAEwU,QAAF,GAAeC,UAAW,KAErE,GAAI9R,KAAKwM,aAAT,gBACErN,EAAA,QAAiBa,KAAKK,eAAe,WAAY,CAAEuM,KAAM,iBAAmB,CAC1E5M,KAAKwM,aAAa,gBAAiB,SAEjCqF,QAASxU,EAAA,QAFwB,QAGjC+a,SAAUpY,KAHuB,iBAKjCqZ,QAASrZ,KALwB,yBAOjCmQ,OAPiC,EAQjCoO,OAAQD,WAGP,CACL,MAAMnO,EAASnQ,KAAKK,eAAe2D,EAApB,KAA0B,CACvCtE,YADuC,OAEvCrC,MAAO,CACL6G,MADK,EAELsa,OAAO,GAET3d,GAAI,CACFF,MAAO0d,IAER,CAACre,KAAKK,eAAeiB,EAApB,KAA2B,CAAC8c,EAAS,SATzC,YAWMG,EAASve,KAAKK,eAAe2D,EAApB,KAA0B,CACvCtE,YADuC,OAEvCrC,MAAO,CACL6G,MADK,EAELsa,OAAO,GAET3d,GAAI,CACFF,MAAO2d,IAER,CAACte,KAAKK,eAAeiB,EAApB,KAA2B,CAT/B,aAWMmd,EAASze,KAAKK,eAAe,KAAM,CACvCX,YADuC,aAEvCuE,MAAOjE,KAAK+d,cACX,CAAC5N,EAAQ,GAAG9S,EAAA,uBAA6B+V,IAH5C,IAKAjU,EAAA,QAAiBa,KAAKK,eAAe,WAAY,CAAEuM,KAAM,iBAAmB,CAA5E,KAiBF,OAdI5M,KAAKwM,aAAT,kBACErN,EAAA,KAAca,KAAKK,eAAe,WAAY,CAAEuM,KAAM,kBAAoB,CACxE5M,KAAKwM,aAAa,iBAAkB,SAElCqF,QAASxU,EAAA,QAFyB,QAGlC+a,SAAUpY,KAHwB,iBAKlCqZ,QAASrZ,KALyB,yBAOlCmQ,OAAQkO,OAKPre,KAAKK,eAAeqe,EAAU,CACnC9c,IADmC,EAEnCvE,MAAO,CACLkC,MAAO6e,IAHX,IAOF,QAAO,KACL,OAAOpe,KAAKwM,aAAayK,KAAOjX,KAAK2e,cAAcvN,EAA5C,GAA4DpR,KAAK4e,eAAexN,EAAvF,IAEF,cAAa,KACX,MAAMtH,EAAN,GAEA,IAAK,IAAIZ,EAAT,EAAgBA,EAAIkI,EAApB,OAAkClI,IAAK,CACrC,MAAM+N,EAAO7F,EAAb,GACAtH,EAAA,KAAU9J,KAAKwM,aAAayK,KAAM,IAC7BjX,KAAK2Y,gBAAgB1B,EADQ,GAEhCmB,SAAUpY,KAAKoY,YAGbpY,KAAKmY,WAAT,IACErO,EAAA,KAAU9J,KAAKwM,aAAa,iBAAkB,CAC5C6M,QAASrZ,KADmC,gBAE5CoY,SAAUpY,KAFkC,SAG5C4X,MAH4C,EAI5CX,UAKN,UAEF,eAAc,KACZ,OAAOjX,KAAKwM,aAAa,iBACrB4E,EAAA,IAAU,CAAC6F,EAAMW,IAAU5X,KAAK6e,sBAAsB5H,EADnD,IAEH7F,EAAA,IAAU,CAAC6F,EAAMW,IAAU5X,KAAK8e,oBAAoB7H,EAFxD,KAIF,sBAAqB,KACnB,MAAMkB,EAAanY,KAAKmY,WAAxB,GACM5X,EAAU,CACd,qDAAsD4X,GAElD4G,EAAY/e,KAAK8e,oBAAoB7H,EAAMW,EAAjD,GACMoH,EAAchf,KAAKK,eAAe,KAAM,CAC5CX,YAAa,0DACZ,CAACM,KAAKwM,aAAa,iBAAkB,CACtC6M,QAASrZ,KAD6B,gBAEtCoY,SAAUpY,KAF4B,SAGtCiX,WAGF,OAAOjX,KAAKK,eAAeqe,EAAU,CACnCrhB,MAAO,CACLkC,MAAO4Y,IAER,CACDnY,KAAKK,eAAe,WAAY,CAAEuM,KAAM,cAAgB,CADvD,IAED5M,KAAKK,eAAe,WAAY,CAAEuM,KAAM,eAAiB,CAN3D,OASF,oBAAmB,IAA4BrM,EAA5B,IACjB,MAAMqY,EAAc,eAAuB,QAAS5Y,KAApD,cAEMP,EAAOO,KAAK2Y,gBAAgB1B,EAAlC,GAEA,GAAIjX,KAAJ,WAAqB,CACnB,MAAM4M,EAAOgM,EAAb,qBACAA,EAAA,qBAAmChM,EAAO,IAAMA,EAAK,MAEnDwL,SAAUpY,KAAKoY,WACZ,kBAAMpY,KAAKK,eAAeqZ,EAApB,KAAqC,CAC9Cha,YAD8C,yBAE9CrC,MAAO,CACLkC,MAAOE,EADF,WAELuB,UAAWhB,KAAKkX,aAFX,GAGL5S,MAAK,SAAEtE,KAAF,iBAAwB,IAE/Ba,GAAI,CACFuP,MAAQ9S,GAAiBmC,EAAA,cAK/B,GAAIO,KAAJ,WAAqB,CACnB,MAAM4M,EAAOgM,EAAb,qBACAA,EAAA,qBAAmChM,EAAO,IAAMA,EAAT,GAAsB,IAAM5M,KAAKK,eAAeiB,EAApB,KAA2B,CAC5F5B,YAD4F,4BAE5FC,MAAO,CACL,oCAAqCF,EAAK0Y,YAE5CtX,GAAI,CACFF,MAAQqC,IACNA,EAAA,kBACAvD,EAAA,QAAaA,EAAb,eAGH,CAACO,KAXJ,aAcF,OAAOA,KAAKK,eAAeL,KAAKoY,SAAW6G,EAApC,EAAqD,CAC1Drd,IAAK,eAAqBqV,EAAMjX,KAD0B,SAE1DL,MAAO,eACL,MAAc,yBAA0BF,EAAKqG,YAC7C,eAAoBmR,EAAMjX,KAJ8B,YAM1D3C,MAAO,CACLgc,QAASrZ,KADJ,gBAELkc,kBAAmBlc,KAFd,iCAKL2V,IAAK3V,KAAK8B,SAAS6T,KAXqC,cAc1D9U,GAAI,CAGFF,MAAO,IAAMX,KAAKyE,MAAM,YAAawS,EAHnC,GAIFiI,YAActe,GAAsBZ,KAAKyE,MAAM,kBAAmB7D,EAJhE,GAKFue,SAAWve,GAAsBZ,KAAKyE,MAAM,eAAgB7D,EAAOnB,OAIzE,QAAO,GACL,MAAMA,EAAO,MAEXyY,OAAQlY,KAFG,OAGXqZ,QAASrZ,KAHE,gBAIXmY,WAAYnY,KAJD,WAKXoY,SAAUpY,KALC,SAMX8F,WAAY9F,KAND,WAOXiY,OAAQjY,KAAKiY,QAGf,OAAIjY,KAAKwM,aAAT,KACSxM,KAAKwM,aAAaG,KAAzB,GAGK3M,KAAKK,eAAe,QAAS,CAClC,eAAQL,KAAM,eAAgBP,GADI,GAElCO,KAAKiZ,SAAS5b,EAAd,MAFkC,GAGlC,eAAQ2C,KAAM,cAAeP,GAH/B,MAMF,QAAO,GACL,aAAOO,KAAKwM,aAAZ,YAAOxM,KAAA,kBAAP,IAEF,WAAU,GACR,MAAMP,EAAO,CACXpC,MAAO,CACLgU,QAAShU,EADJ,QAELiW,WAAYjW,EAFP,WAGLkX,iBAHK,yCAIFvU,KAAK2d,sBAEV9c,GAAI,CACF,iBAAmBtB,GAAelC,EAAA,kBAEpCggB,OAAQrd,KAVG,OAWXqZ,QAASrZ,KAAKwd,iBAGVre,EAA0B,CAC9B,eAAQa,KAAM,SAAUP,GAD1B,IAWA,OAPKO,KAAL,mBACEb,EAAA,KAAca,KAAKK,eAAe,EAAa,MAE7CuY,YAAa,eAAuB,UAAW5Y,KAAZ,iBAIvC,GAEF,qBAAoB,GAClB,MAAMof,EAAc,CAClBvf,OAAQG,KADU,OAElBJ,YAAaI,KAFK,YAGlBf,MAAOe,KAAKf,OAqBd,OAAOe,KAAKK,eAAegf,EAApB,KAAkC,CACvChiB,MADuC,EAEvCsC,MAAO,CACL,uBAAwBK,KAAKoY,WAE9B,CACDpY,KAAKsf,UAAU,MAAO,eAAQtf,KAAM,MAAO,MAEzCoY,SAAUpY,KAAKoY,WAHhB,IAKDpY,KAAKuf,WALJ,GAMDvf,KAAKwf,YANJ,GAODxf,KAAKyf,WAPJ,GAQDzf,KAAK0f,QARJ,GASD1f,KAAK2f,QATJ,GAUD3f,KAAKsf,UAAU,SAAUtf,KAAK4f,WAfhC,OAkBF,UAAS,KACP,OAAO5f,KAAKK,eAAe,WAAY,CAAEuM,QAAzC,KAIJ,SACE,OAAO5M,KAAKK,eAAeuV,EAAO,CAChCvY,MAAO,IACF2C,KADE,OAELoS,aAAcpS,KAFT,wBAGLwR,WAAYxR,KAHP,sBAIL4R,aAAc5R,KAAK6f,sBAErBhf,GAAI,CACF,iBAAkB,CAAC4F,EAAD,KAChBzG,KAAA,gBAAuByG,EAAA,SAAvB,IACC,eAAUA,EAAX,IAAsBzG,KAAKyE,MAAM,iBAAjC,IAEF,cAAgBgC,GAAczG,KAAKyE,MAAM,cALvC,GAMF,wBAA0BgC,GAAczG,KAAKyE,MAAM,wBANjD,GAOF,iBAAmBgC,GAAyBzG,KAAKyE,MAAM,iBAPrD,GAQF,mBAAqBgC,GAA2BzG,KAAKyE,MAAM,mBARzD,GASF,kBAAoBgC,GAAyBzG,KAAKyE,MAAM,kBATtD,GAUF,oBAAsBgC,GAA2BzG,KAAKyE,MAAM,oBAV1D,GAWF6O,WAAY,CAAC7M,EAAD,KAA6C,eAAUA,EAAX,IAAsBzG,KAAKyE,MAAM,aAXvF,GAYF,gBAAkBgC,IAChBzG,KAAA,uBACAA,KAAA,0BAEF,aAAeyG,GAAczG,KAAKyE,MAAM,aAAcgC,IAExDmS,YAAa,CACX/a,QAASmC,KAAKmZ,4B","file":"js/chunk-cfe31146.a22c993b.js","sourcesContent":["import './VGrid.sass'\n\nimport Vue, { PropOptions } from 'vue'\nimport mergeData from '../../util/mergeData'\nimport { upperFirst } from '../../util/helpers'\n\n// no xs\nconst breakpoints = ['sm', 'md', 'lg', 'xl']\n\nconst ALIGNMENT = ['start', 'end', 'center']\n\nfunction makeProps (prefix: string, def: () => PropOptions) {\n return breakpoints.reduce((props, val) => {\n props[prefix + upperFirst(val)] = def()\n return props\n }, {} as Dictionary)\n}\n\nconst alignValidator = (str: any) => [...ALIGNMENT, 'baseline', 'stretch'].includes(str)\nconst alignProps = makeProps('align', () => ({\n type: String,\n default: null,\n validator: alignValidator,\n}))\n\nconst justifyValidator = (str: any) => [...ALIGNMENT, 'space-between', 'space-around'].includes(str)\nconst justifyProps = makeProps('justify', () => ({\n type: String,\n default: null,\n validator: justifyValidator,\n}))\n\nconst alignContentValidator = (str: any) => [...ALIGNMENT, 'space-between', 'space-around', 'stretch'].includes(str)\nconst alignContentProps = makeProps('alignContent', () => ({\n type: String,\n default: null,\n validator: alignContentValidator,\n}))\n\nconst propMap = {\n align: Object.keys(alignProps),\n justify: Object.keys(justifyProps),\n alignContent: Object.keys(alignContentProps),\n}\n\nconst classMap = {\n align: 'align',\n justify: 'justify',\n alignContent: 'align-content',\n}\n\nfunction breakpointClass (type: keyof typeof propMap, prop: string, val: string) {\n let className = classMap[type]\n if (val == null) {\n return undefined\n }\n if (prop) {\n // alignSm -> Sm\n const breakpoint = prop.replace(type, '')\n className += `-${breakpoint}`\n }\n // .align-items-sm-center\n className += `-${val}`\n return className.toLowerCase()\n}\n\nconst cache = new Map()\n\nexport default Vue.extend({\n name: 'v-row',\n functional: true,\n props: {\n tag: {\n type: String,\n default: 'div',\n },\n dense: Boolean,\n noGutters: Boolean,\n align: {\n type: String,\n default: null,\n validator: alignValidator,\n },\n ...alignProps,\n justify: {\n type: String,\n default: null,\n validator: justifyValidator,\n },\n ...justifyProps,\n alignContent: {\n type: String,\n default: null,\n validator: alignContentValidator,\n },\n ...alignContentProps,\n },\n render (h, { props, data, children }) {\n // Super-fast memoization based on props, 5x faster than JSON.stringify\n let cacheKey = ''\n for (const prop in props) {\n cacheKey += String((props as any)[prop])\n }\n let classList = cache.get(cacheKey)\n\n if (!classList) {\n classList = []\n // Loop through `align`, `justify`, `alignContent` breakpoint props\n let type: keyof typeof propMap\n for (type in propMap) {\n propMap[type].forEach(prop => {\n const value: string = (props as any)[prop]\n const className = breakpointClass(type, prop, value)\n if (className) classList!.push(className)\n })\n }\n\n classList.push({\n 'no-gutters': props.noGutters,\n 'row--dense': props.dense,\n [`align-${props.align}`]: props.align,\n [`justify-${props.justify}`]: props.justify,\n [`align-content-${props.alignContent}`]: props.alignContent,\n })\n\n cache.set(cacheKey, classList)\n }\n\n return h(\n props.tag,\n mergeData(data, {\n staticClass: 'row',\n class: classList,\n }),\n children\n )\n },\n})\n","import './VSimpleTable.sass'\n\nimport { convertToUnit } from '../../util/helpers'\nimport Themeable from '../../mixins/themeable'\nimport mixins from '../../util/mixins'\nimport { VNode } from 'vue'\n\nexport default mixins(Themeable).extend({\n name: 'v-simple-table',\n\n props: {\n dense: Boolean,\n fixedHeader: Boolean,\n height: [Number, String],\n },\n\n computed: {\n classes (): Record {\n return {\n 'v-data-table--dense': this.dense,\n 'v-data-table--fixed-height': !!this.height && !this.fixedHeader,\n 'v-data-table--fixed-header': this.fixedHeader,\n 'v-data-table--has-top': !!this.$slots.top,\n 'v-data-table--has-bottom': !!this.$slots.bottom,\n ...this.themeClasses,\n }\n },\n },\n\n methods: {\n genWrapper () {\n return this.$slots.wrapper || this.$createElement('div', {\n staticClass: 'v-data-table__wrapper',\n style: {\n height: convertToUnit(this.height),\n },\n }, [\n this.$createElement('table', this.$slots.default),\n ])\n },\n },\n\n render (h): VNode {\n return h('div', {\n staticClass: 'v-data-table',\n class: this.classes,\n }, [\n this.$slots.top,\n this.genWrapper(),\n this.$slots.bottom,\n ])\n },\n})\n","// Mixins\nimport Colorable from '../colorable'\n\n// Utilities\nimport mixins from '../../util/mixins'\nimport { kebabCase } from '../../util/helpers'\n\n// Types\nimport { VNodeChildren } from 'vue'\n\n/* @vue/component */\nexport default mixins(\n Colorable\n).extend({\n methods: {\n genPickerButton (\n prop: string,\n value: any,\n content: VNodeChildren,\n readonly = false,\n staticClass = ''\n ) {\n const active = (this as any)[prop] === value\n const click = (event: Event) => {\n event.stopPropagation()\n this.$emit(`update:${kebabCase(prop)}`, value)\n }\n\n return this.$createElement('div', {\n staticClass: `v-picker__title__btn ${staticClass}`.trim(),\n class: {\n 'v-picker__title__btn--active': active,\n 'v-picker__title__btn--readonly': readonly,\n },\n on: (active || readonly) ? undefined : { click },\n }, Array.isArray(content) ? content : [content])\n },\n },\n})\n","import './VDatePickerTitle.sass'\n\n// Components\nimport VIcon from '../VIcon'\n\n// Mixins\nimport PickerButton from '../../mixins/picker-button'\n\n// Utils\nimport mixins from '../../util/mixins'\n\n// Types\nimport { VNode } from 'vue'\n\nexport default mixins(\n PickerButton\n/* @vue/component */\n).extend({\n name: 'v-date-picker-title',\n\n props: {\n date: {\n type: String,\n default: '',\n },\n disabled: Boolean,\n readonly: Boolean,\n selectingYear: Boolean,\n value: {\n type: String,\n },\n year: {\n type: [Number, String],\n default: '',\n },\n yearIcon: {\n type: String,\n },\n },\n\n data: () => ({\n isReversing: false,\n }),\n\n computed: {\n computedTransition (): string {\n return this.isReversing ? 'picker-reverse-transition' : 'picker-transition'\n },\n },\n\n watch: {\n value (val: string, prev: string) {\n this.isReversing = val < prev\n },\n },\n\n methods: {\n genYearIcon (): VNode {\n return this.$createElement(VIcon, {\n props: {\n dark: true,\n },\n }, this.yearIcon)\n },\n getYearBtn (): VNode {\n return this.genPickerButton('selectingYear', true, [\n String(this.year),\n this.yearIcon ? this.genYearIcon() : null,\n ], false, 'v-date-picker-title__year')\n },\n genTitleText (): VNode {\n return this.$createElement('transition', {\n props: {\n name: this.computedTransition,\n },\n }, [\n this.$createElement('div', {\n domProps: { innerHTML: this.date || ' ' },\n key: this.value,\n }),\n ])\n },\n genTitleDate (): VNode {\n return this.genPickerButton('selectingYear', false, [this.genTitleText()], false, 'v-date-picker-title__date')\n },\n },\n\n render (h): VNode {\n return h('div', {\n staticClass: 'v-date-picker-title',\n class: {\n 'v-date-picker-title--disabled': this.disabled,\n },\n }, [\n this.getYearBtn(),\n this.genTitleDate(),\n ])\n },\n})\n","import Vue from 'vue'\n\nexport default Vue.extend({\n name: 'localable',\n\n props: {\n locale: String,\n },\n\n computed: {\n currentLocale (): string {\n return this.locale || this.$vuetify.lang.current\n },\n },\n})\n","const padStart = (string: number | string, targetLength: number, padString: string) => {\n targetLength = targetLength >> 0\n string = String(string)\n padString = String(padString)\n if (string.length > targetLength) {\n return String(string)\n }\n\n targetLength = targetLength - string.length\n if (targetLength > padString.length) {\n padString += padString.repeat(targetLength / padString.length)\n }\n return padString.slice(0, targetLength) + String(string)\n}\n\nexport default (n: string | number, length = 2) => padStart(n, length, '0')\n","import pad from './pad'\nimport { DatePickerFormatter } from 'vuetify/types'\n\ninterface SubstrOptions {\n start?: number\n length: number\n}\n\nfunction createNativeLocaleFormatter (\n local: string | undefined,\n options: Intl.DateTimeFormatOptions\n): DatePickerFormatter | undefined\n\nfunction createNativeLocaleFormatter (\n local: string | undefined,\n options: Intl.DateTimeFormatOptions,\n substrOptions: SubstrOptions\n): DatePickerFormatter\n\nfunction createNativeLocaleFormatter (\n locale: string | undefined,\n options: Intl.DateTimeFormatOptions,\n substrOptions: SubstrOptions = { start: 0, length: 0 }\n): DatePickerFormatter | undefined {\n const makeIsoString = (dateString: string) => {\n const [year, month, date] = dateString.trim().split(' ')[0].split('-')\n return [pad(year, 4), pad(month || 1), pad(date || 1)].join('-')\n }\n\n try {\n const intlFormatter = new Intl.DateTimeFormat(locale || undefined, options)\n return (dateString: string) => intlFormatter.format(new Date(`${makeIsoString(dateString)}T00:00:00+00:00`))\n } catch (e) {\n return (substrOptions.start || substrOptions.length)\n ? (dateString: string) => makeIsoString(dateString).substr(substrOptions.start || 0, substrOptions.length)\n : undefined\n }\n}\n\nexport default createNativeLocaleFormatter\n","import pad from './pad'\n\n/**\n * @param {String} value YYYY-MM format\n * @param {Number} sign -1 or +1\n */\nexport default (value: string, sign: number) => {\n const [year, month] = value.split('-').map(Number)\n\n if (month + sign === 0) {\n return `${year - 1}-12`\n } else if (month + sign === 13) {\n return `${year + 1}-01`\n } else {\n return `${year}-${pad(month + sign)}`\n }\n}\n","import './VDatePickerHeader.sass'\n\n// Components\nimport VBtn from '../VBtn'\nimport VIcon from '../VIcon'\n\n// Mixins\nimport Colorable from '../../mixins/colorable'\nimport Localable from '../../mixins/localable'\nimport Themeable from '../../mixins/themeable'\n\n// Utils\nimport { createNativeLocaleFormatter, monthChange } from './util'\nimport mixins from '../../util/mixins'\n\n// Types\nimport { VNode, PropType } from 'vue'\nimport { DatePickerFormatter } from 'vuetify/types'\n\nexport default mixins(\n Colorable,\n Localable,\n Themeable\n/* @vue/component */\n).extend({\n name: 'v-date-picker-header',\n\n props: {\n disabled: Boolean,\n format: Function as PropType,\n min: String,\n max: String,\n nextAriaLabel: String,\n nextIcon: {\n type: String,\n default: '$next',\n },\n prevAriaLabel: String,\n prevIcon: {\n type: String,\n default: '$prev',\n },\n readonly: Boolean,\n value: {\n type: [Number, String],\n required: true,\n },\n },\n\n data () {\n return {\n isReversing: false,\n }\n },\n\n computed: {\n formatter (): DatePickerFormatter {\n if (this.format) {\n return this.format\n } else if (String(this.value).split('-')[1]) {\n return createNativeLocaleFormatter(this.currentLocale, { month: 'long', year: 'numeric', timeZone: 'UTC' }, { length: 7 })\n } else {\n return createNativeLocaleFormatter(this.currentLocale, { year: 'numeric', timeZone: 'UTC' }, { length: 4 })\n }\n },\n },\n\n watch: {\n value (newVal, oldVal) {\n this.isReversing = newVal < oldVal\n },\n },\n\n methods: {\n genBtn (change: number) {\n const ariaLabelId = change > 0 ? this.nextAriaLabel : this.prevAriaLabel\n const ariaLabel = ariaLabelId ? this.$vuetify.lang.t(ariaLabelId) : undefined\n const disabled = this.disabled ||\n (change < 0 && this.min && this.calculateChange(change) < this.min) ||\n (change > 0 && this.max && this.calculateChange(change) > this.max)\n\n return this.$createElement(VBtn, {\n attrs: { 'aria-label': ariaLabel },\n props: {\n dark: this.dark,\n disabled,\n icon: true,\n light: this.light,\n },\n on: {\n click: (e: Event) => {\n e.stopPropagation()\n this.$emit('input', this.calculateChange(change))\n },\n },\n }, [\n this.$createElement(VIcon, ((change < 0) === !this.$vuetify.rtl) ? this.prevIcon : this.nextIcon),\n ])\n },\n calculateChange (sign: number) {\n const [year, month] = String(this.value).split('-').map(Number)\n\n if (month == null) {\n return `${year + sign}`\n } else {\n return monthChange(String(this.value), sign)\n }\n },\n genHeader () {\n const color = !this.disabled && (this.color || 'accent')\n const header = this.$createElement('div', this.setTextColor(color, {\n key: String(this.value),\n }), [this.$createElement('button', {\n attrs: {\n type: 'button',\n },\n on: {\n click: () => this.$emit('toggle'),\n },\n }, [this.$slots.default || this.formatter(String(this.value))])])\n\n const transition = this.$createElement('transition', {\n props: {\n name: (this.isReversing === !this.$vuetify.rtl) ? 'tab-reverse-transition' : 'tab-transition',\n },\n }, [header])\n\n return this.$createElement('div', {\n staticClass: 'v-date-picker-header__value',\n class: {\n 'v-date-picker-header__value--disabled': this.disabled,\n },\n }, [transition])\n },\n },\n\n render (): VNode {\n return this.$createElement('div', {\n staticClass: 'v-date-picker-header',\n class: {\n 'v-date-picker-header--disabled': this.disabled,\n ...this.themeClasses,\n },\n }, [\n this.genBtn(-1),\n this.genHeader(),\n this.genBtn(+1),\n ])\n },\n})\n","import Vue from 'vue'\n\nexport function createItemTypeNativeListeners (instance: Vue, itemTypeSuffix: string, value: any) {\n return Object.keys(instance.$listeners).reduce((on, eventName) => {\n if (eventName.endsWith(itemTypeSuffix)) {\n on[eventName.slice(0, -itemTypeSuffix.length)] = (event: Event) => instance.$emit(eventName, value, event)\n }\n\n return on\n }, {} as typeof instance.$listeners)\n}\n\nexport function createItemTypeListeners (instance: Vue, itemTypeSuffix: string) {\n return Object.keys(instance.$listeners).reduce((on, eventName) => {\n if (eventName.endsWith(itemTypeSuffix)) {\n on[eventName] = instance.$listeners[eventName]\n }\n\n return on\n }, {} as typeof instance.$listeners)\n}\n","// Adds leading zero to month/day if necessary, returns 'YYYY' if type = 'year',\n// 'YYYY-MM' if 'month' and 'YYYY-MM-DD' if 'date'\nimport pad from './pad'\n\nexport default (dateString: string, type: 'date' | 'month' | 'year'): string => {\n const [year, month = 1, date = 1] = dateString.split('-')\n return `${year}-${pad(month)}-${pad(date)}`.substr(0, { date: 10, month: 7, year: 4 }[type])\n}\n","import { DatePickerAllowedDatesFunction } from 'vuetify/types'\n\nexport default function isDateAllowed (date: string, min: string, max: string, allowedFn: DatePickerAllowedDatesFunction | undefined) {\n return (!allowedFn || allowedFn(date)) &&\n (!min || date >= min.substr(0, 10)) &&\n (!max || date <= max)\n}\n","import '../VDatePickerTable.sass'\n\n// Directives\nimport Touch from '../../../directives/touch'\n\n// Mixins\nimport Colorable from '../../../mixins/colorable'\nimport Localable from '../../../mixins/localable'\nimport Themeable from '../../../mixins/themeable'\n\n// Utils\nimport { createItemTypeNativeListeners, sanitizeDateString } from '../util'\nimport isDateAllowed from '../util/isDateAllowed'\nimport { mergeListeners } from '../../../util/mergeData'\nimport mixins from '../../../util/mixins'\nimport { throttle } from '../../../util/helpers'\n\n// Types\nimport {\n PropType,\n VNodeChildren,\n} from 'vue'\nimport { PropValidator } from 'vue/types/options'\nimport {\n DatePickerAllowedDatesFunction,\n DatePickerEventColors,\n DatePickerEventColorValue,\n DatePickerEvents,\n DatePickerFormatter,\n TouchWrapper,\n} from 'vuetify/types'\n\ntype CalculateTableDateFunction = (v: number) => string\n\nexport default mixins(\n Colorable,\n Localable,\n Themeable\n/* @vue/component */\n).extend({\n directives: { Touch },\n\n props: {\n allowedDates: Function as PropType,\n current: String,\n disabled: Boolean,\n format: Function as PropType,\n events: {\n type: [Array, Function, Object],\n default: () => null,\n } as PropValidator,\n eventColor: {\n type: [Array, Function, Object, String],\n default: () => 'warning',\n } as PropValidator,\n min: String,\n max: String,\n range: Boolean,\n readonly: Boolean,\n scrollable: Boolean,\n tableDate: {\n type: String,\n required: true,\n },\n value: [String, Array] as PropType,\n },\n\n data: () => ({\n isReversing: false,\n wheelThrottle: null as any,\n }),\n\n computed: {\n computedTransition (): string {\n return (this.isReversing === !this.$vuetify.rtl) ? 'tab-reverse-transition' : 'tab-transition'\n },\n displayedMonth (): number {\n return Number(this.tableDate.split('-')[1]) - 1\n },\n displayedYear (): number {\n return Number(this.tableDate.split('-')[0])\n },\n },\n\n watch: {\n tableDate (newVal: string, oldVal: string) {\n this.isReversing = newVal < oldVal\n },\n },\n\n mounted () {\n this.wheelThrottle = throttle(this.wheel, 250)\n },\n\n methods: {\n genButtonClasses (isAllowed: boolean, isFloating: boolean, isSelected: boolean, isCurrent: boolean) {\n return {\n 'v-size--default': !isFloating,\n 'v-date-picker-table__current': isCurrent,\n 'v-btn--active': isSelected,\n 'v-btn--flat': !isAllowed || this.disabled,\n 'v-btn--text': isSelected === isCurrent,\n 'v-btn--rounded': isFloating,\n 'v-btn--disabled': !isAllowed || this.disabled,\n 'v-btn--outlined': isCurrent && !isSelected,\n ...this.themeClasses,\n }\n },\n genButtonEvents (value: string, isAllowed: boolean, mouseEventType: string) {\n if (this.disabled) return undefined\n\n return mergeListeners({\n click: () => {\n if (isAllowed && !this.readonly) this.$emit('input', value)\n },\n }, createItemTypeNativeListeners(this, `:${mouseEventType}`, value))\n },\n genButton (value: string, isFloating: boolean, mouseEventType: string, formatter: DatePickerFormatter, isOtherMonth = false) {\n const isAllowed = isDateAllowed(value, this.min, this.max, this.allowedDates)\n const isSelected = this.isSelected(value) && isAllowed\n const isCurrent = value === this.current\n const setColor = isSelected ? this.setBackgroundColor : this.setTextColor\n const color = (isSelected || isCurrent) && (this.color || 'accent')\n\n return this.$createElement('button', setColor(color, {\n staticClass: 'v-btn',\n class: this.genButtonClasses(isAllowed && !isOtherMonth, isFloating, isSelected, isCurrent),\n attrs: {\n type: 'button',\n },\n domProps: {\n disabled: this.disabled || !isAllowed || isOtherMonth,\n },\n on: this.genButtonEvents(value, isAllowed, mouseEventType),\n }), [\n this.$createElement('div', {\n staticClass: 'v-btn__content',\n }, [formatter(value)]),\n this.genEvents(value),\n ])\n },\n getEventColors (date: string) {\n const arrayize = (v: string | string[]) => Array.isArray(v) ? v : [v]\n let eventData: boolean | DatePickerEventColorValue\n let eventColors: string[] = []\n\n if (Array.isArray(this.events)) {\n eventData = this.events.includes(date)\n } else if (this.events instanceof Function) {\n eventData = this.events(date) || false\n } else if (this.events) {\n eventData = this.events[date] || false\n } else {\n eventData = false\n }\n\n if (!eventData) {\n return []\n } else if (eventData !== true) {\n eventColors = arrayize(eventData)\n } else if (typeof this.eventColor === 'string') {\n eventColors = [this.eventColor]\n } else if (typeof this.eventColor === 'function') {\n eventColors = arrayize(this.eventColor(date))\n } else if (Array.isArray(this.eventColor)) {\n eventColors = this.eventColor\n } else {\n eventColors = arrayize(this.eventColor[date])\n }\n\n return eventColors.filter(v => v)\n },\n genEvents (date: string) {\n const eventColors = this.getEventColors(date)\n\n return eventColors.length ? this.$createElement('div', {\n staticClass: 'v-date-picker-table__events',\n }, eventColors.map(color => this.$createElement('div', this.setBackgroundColor(color)))) : null\n },\n isValidScroll (value: number, calculateTableDate: CalculateTableDateFunction) {\n const tableDate = calculateTableDate(value)\n // tableDate is 'YYYY-MM' for DateTable and 'YYYY' for MonthTable\n const sanitizeType = tableDate.split('-').length === 1 ? 'year' : 'month'\n return (value < 0 && (this.min ? tableDate >= sanitizeDateString(this.min, sanitizeType) : true)) ||\n (value > 0 && (this.max ? tableDate <= sanitizeDateString(this.max, sanitizeType) : true))\n },\n wheel (e: WheelEvent, calculateTableDate: CalculateTableDateFunction) {\n this.$emit('update:table-date', calculateTableDate(e.deltaY))\n },\n touch (value: number, calculateTableDate: CalculateTableDateFunction) {\n this.$emit('update:table-date', calculateTableDate(value))\n },\n genTable (staticClass: string, children: VNodeChildren, calculateTableDate: CalculateTableDateFunction) {\n const transition = this.$createElement('transition', {\n props: { name: this.computedTransition },\n }, [this.$createElement('table', { key: this.tableDate }, children)])\n\n const touchDirective = {\n name: 'touch',\n value: {\n left: (e: TouchWrapper) => (e.offsetX < -15) &&\n (this.isValidScroll(1, calculateTableDate) && this.touch(1, calculateTableDate)),\n right: (e: TouchWrapper) => (e.offsetX > 15) &&\n (this.isValidScroll(-1, calculateTableDate) && this.touch(-1, calculateTableDate)),\n },\n }\n\n return this.$createElement('div', {\n staticClass,\n class: {\n 'v-date-picker-table--disabled': this.disabled,\n ...this.themeClasses,\n },\n on: (!this.disabled && this.scrollable) ? {\n wheel: (e: WheelEvent) => {\n e.preventDefault()\n if (this.isValidScroll(e.deltaY, calculateTableDate)) { this.wheelThrottle(e, calculateTableDate) }\n },\n } : undefined,\n directives: [touchDirective],\n }, [transition])\n },\n isSelected (value: string): boolean {\n if (Array.isArray(this.value)) {\n if (this.range && this.value.length === 2) {\n const [from, to] = [...this.value].sort()\n return from <= value && value <= to\n } else {\n return this.value.indexOf(value) !== -1\n }\n }\n\n return value === this.value\n },\n },\n})\n","function createUTCDate (year: number, month = 0, day = 1) {\n let date\n if (year < 100 && year >= 0) {\n date = new Date(Date.UTC(year, month, day))\n if (isFinite(date.getUTCFullYear())) {\n date.setUTCFullYear(year)\n }\n } else {\n date = new Date(Date.UTC(year, month, day))\n }\n\n return date\n}\n\nfunction firstWeekOffset (year: number, firstDayOfWeek: number, firstDayOfYear: number) {\n const firstWeekDayInFirstWeek = 7 + firstDayOfWeek - firstDayOfYear\n const firstWeekDayOfYear = (7 + createUTCDate(year, 0, firstWeekDayInFirstWeek).getUTCDay() - firstDayOfWeek) % 7\n\n return -firstWeekDayOfYear + firstWeekDayInFirstWeek - 1\n}\n\nfunction dayOfYear (year: number, month: number, day: number, firstDayOfWeek: number) {\n let dayOfYear = [0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334][month]\n if (month > 1 && isLeapYear(year)) {\n dayOfYear++\n }\n\n return dayOfYear + day\n}\n\nfunction weeksInYear (year: number, firstDayOfWeek: number, firstDayOfYear: number) {\n const weekOffset = firstWeekOffset(year, firstDayOfWeek, firstDayOfYear)\n const weekOffsetNext = firstWeekOffset(year + 1, firstDayOfWeek, firstDayOfYear)\n const daysInYear = isLeapYear(year) ? 366 : 365\n\n return (daysInYear - weekOffset + weekOffsetNext) / 7\n}\n\nexport function weekNumber (year: number, month: number, day: number, firstDayOfWeek: number, localeFirstDayOfYear: number): number {\n const weekOffset = firstWeekOffset(year, firstDayOfWeek, localeFirstDayOfYear)\n const week = Math.ceil((dayOfYear(year, month, day, firstDayOfWeek) - weekOffset) / 7)\n\n if (week < 1) {\n return week + weeksInYear(year - 1, firstDayOfWeek, localeFirstDayOfYear)\n } else if (week > weeksInYear(year, firstDayOfWeek, localeFirstDayOfYear)) {\n return week - weeksInYear(year, firstDayOfWeek, localeFirstDayOfYear)\n } else {\n return week\n }\n}\n\nexport function isLeapYear (year: number): boolean {\n return ((year % 4 === 0) && (year % 100 !== 0)) || (year % 400 === 0)\n}\n","// Mixins\nimport DatePickerTable from './mixins/date-picker-table'\n\n// Utils\nimport { weekNumber } from '../../util/dateTimeUtils'\nimport { pad, createNativeLocaleFormatter, monthChange } from './util'\nimport { createRange } from '../../util/helpers'\nimport mixins from '../../util/mixins'\n\n// Types\nimport { VNode, VNodeChildren, PropType } from 'vue'\nimport { DatePickerFormatter } from 'vuetify/types'\n\nexport default mixins(\n DatePickerTable\n/* @vue/component */\n).extend({\n name: 'v-date-picker-date-table',\n\n props: {\n firstDayOfWeek: {\n type: [String, Number],\n default: 0,\n },\n localeFirstDayOfYear: {\n type: [String, Number],\n default: 0,\n },\n showAdjacentMonths: Boolean,\n showWeek: Boolean,\n weekdayFormat: Function as PropType,\n },\n\n computed: {\n formatter (): DatePickerFormatter {\n return this.format || createNativeLocaleFormatter(this.currentLocale, { day: 'numeric', timeZone: 'UTC' }, { start: 8, length: 2 })\n },\n weekdayFormatter (): DatePickerFormatter | undefined {\n return this.weekdayFormat || createNativeLocaleFormatter(this.currentLocale, { weekday: 'narrow', timeZone: 'UTC' })\n },\n weekDays (): string[] {\n const first = parseInt(this.firstDayOfWeek, 10)\n\n return this.weekdayFormatter\n ? createRange(7).map(i => this.weekdayFormatter!(`2017-01-${first + i + 15}`)) // 2017-01-15 is Sunday\n : createRange(7).map(i => ['S', 'M', 'T', 'W', 'T', 'F', 'S'][(i + first) % 7])\n },\n },\n\n methods: {\n calculateTableDate (delta: number) {\n return monthChange(this.tableDate, Math.sign(delta || 1))\n },\n genTHead () {\n const days = this.weekDays.map(day => this.$createElement('th', day))\n if (this.showWeek) {\n days.unshift(this.$createElement('th'))\n }\n\n return this.$createElement('thead', this.genTR(days))\n },\n // Returns number of the days from the firstDayOfWeek to the first day of the current month\n weekDaysBeforeFirstDayOfTheMonth () {\n const firstDayOfTheMonth = new Date(`${this.displayedYear}-${pad(this.displayedMonth + 1)}-01T00:00:00+00:00`)\n const weekDay = firstDayOfTheMonth.getUTCDay()\n\n return (weekDay - parseInt(this.firstDayOfWeek) + 7) % 7\n },\n getWeekNumber (dayInMonth: number) {\n return weekNumber(\n this.displayedYear,\n this.displayedMonth,\n dayInMonth,\n parseInt(this.firstDayOfWeek),\n parseInt(this.localeFirstDayOfYear)\n )\n },\n genWeekNumber (weekNumber: number) {\n return this.$createElement('td', [\n this.$createElement('small', {\n staticClass: 'v-date-picker-table--date__week',\n }, String(weekNumber).padStart(2, '0')),\n ])\n },\n // eslint-disable-next-line max-statements\n genTBody () {\n const children = []\n const daysInMonth = new Date(this.displayedYear, this.displayedMonth + 1, 0).getDate()\n let rows = []\n let day = this.weekDaysBeforeFirstDayOfTheMonth()\n\n if (this.showWeek) {\n rows.push(this.genWeekNumber(this.getWeekNumber(1)))\n }\n\n const prevMonthYear = this.displayedMonth ? this.displayedYear : this.displayedYear - 1\n const prevMonth = (this.displayedMonth + 11) % 12\n const firstDayFromPreviousMonth = new Date(this.displayedYear, this.displayedMonth, 0).getDate()\n const cellsInRow = this.showWeek ? 8 : 7\n\n while (day--) {\n const date = `${prevMonthYear}-${pad(prevMonth + 1)}-${pad(firstDayFromPreviousMonth - day)}`\n\n rows.push(this.$createElement('td', this.showAdjacentMonths ? [\n this.genButton(date, true, 'date', this.formatter, true),\n ] : []))\n }\n\n for (day = 1; day <= daysInMonth; day++) {\n const date = `${this.displayedYear}-${pad(this.displayedMonth + 1)}-${pad(day)}`\n\n rows.push(this.$createElement('td', [\n this.genButton(date, true, 'date', this.formatter),\n ]))\n\n if (rows.length % cellsInRow === 0) {\n children.push(this.genTR(rows))\n rows = []\n if (this.showWeek && (day < daysInMonth || this.showAdjacentMonths)) {\n rows.push(this.genWeekNumber(this.getWeekNumber(day + 7)))\n }\n }\n }\n\n const nextMonthYear = this.displayedMonth === 11 ? this.displayedYear + 1 : this.displayedYear\n const nextMonth = (this.displayedMonth + 1) % 12\n let nextMonthDay = 1\n\n while (rows.length < cellsInRow) {\n const date = `${nextMonthYear}-${pad(nextMonth + 1)}-${pad(nextMonthDay++)}`\n\n rows.push(this.$createElement('td', this.showAdjacentMonths ? [\n this.genButton(date, true, 'date', this.formatter, true),\n ] : []))\n }\n\n if (rows.length) {\n children.push(this.genTR(rows))\n }\n\n return this.$createElement('tbody', children)\n },\n genTR (children: VNodeChildren) {\n return [this.$createElement('tr', children)]\n },\n },\n\n render (): VNode {\n return this.genTable('v-date-picker-table v-date-picker-table--date', [\n this.genTHead(),\n this.genTBody(),\n ], this.calculateTableDate)\n },\n})\n","// Mixins\nimport DatePickerTable from './mixins/date-picker-table'\n\n// Utils\nimport { pad, createNativeLocaleFormatter } from './util'\nimport mixins from '../../util/mixins'\n\n// Types\nimport { VNode } from 'vue'\nimport { DatePickerFormatter } from 'vuetify/types'\n\nexport default mixins(\n DatePickerTable\n/* @vue/component */\n).extend({\n name: 'v-date-picker-month-table',\n\n computed: {\n formatter (): DatePickerFormatter {\n return this.format || createNativeLocaleFormatter(this.currentLocale, { month: 'short', timeZone: 'UTC' }, { start: 5, length: 2 })\n },\n },\n\n methods: {\n calculateTableDate (delta: number) {\n return `${parseInt(this.tableDate, 10) + Math.sign(delta || 1)}`\n },\n genTBody () {\n const children = []\n const cols = Array(3).fill(null)\n const rows = 12 / cols.length\n\n for (let row = 0; row < rows; row++) {\n const tds = cols.map((_, col) => {\n const month = row * cols.length + col\n const date = `${this.displayedYear}-${pad(month + 1)}`\n return this.$createElement('td', {\n key: month,\n }, [\n this.genButton(date, false, 'month', this.formatter),\n ])\n })\n\n children.push(this.$createElement('tr', {\n key: row,\n }, tds))\n }\n\n return this.$createElement('tbody', children)\n },\n },\n\n render (): VNode {\n return this.genTable('v-date-picker-table v-date-picker-table--month', [\n this.genTBody(),\n ], this.calculateTableDate)\n },\n})\n","import './VDatePickerYears.sass'\n\n// Mixins\nimport Colorable from '../../mixins/colorable'\nimport Localable from '../../mixins/localable'\n\n// Utils\nimport {\n createItemTypeNativeListeners,\n createNativeLocaleFormatter,\n} from './util'\nimport { mergeListeners } from '../../util/mergeData'\nimport mixins, { ExtractVue } from '../../util/mixins'\n\n// Types\nimport Vue, { VNode, PropType } from 'vue'\nimport { DatePickerFormatter } from 'vuetify/types'\n\ninterface options extends Vue {\n $el: HTMLElement\n}\n\nexport default mixins\n/* eslint-enable indent */\n>(\n Colorable,\n Localable\n/* @vue/component */\n).extend({\n name: 'v-date-picker-years',\n\n props: {\n format: Function as PropType,\n min: [Number, String],\n max: [Number, String],\n readonly: Boolean,\n value: [Number, String],\n },\n\n data () {\n return {\n defaultColor: 'primary',\n }\n },\n\n computed: {\n formatter (): DatePickerFormatter {\n return this.format || createNativeLocaleFormatter(this.currentLocale, { year: 'numeric', timeZone: 'UTC' }, { length: 4 })\n },\n },\n\n mounted () {\n setTimeout(() => {\n const activeItem = this.$el.getElementsByClassName('active')[0]\n if (activeItem) {\n this.$el.scrollTop = activeItem.offsetTop - this.$el.offsetHeight / 2 + activeItem.offsetHeight / 2\n } else if (this.min && !this.max) {\n this.$el.scrollTop = this.$el.scrollHeight\n } else if (!this.min && this.max) {\n this.$el.scrollTop = 0\n } else {\n this.$el.scrollTop = this.$el.scrollHeight / 2 - this.$el.offsetHeight / 2\n }\n })\n },\n\n methods: {\n genYearItem (year: number): VNode {\n const formatted = this.formatter(`${year}`)\n const active = parseInt(this.value, 10) === year\n const color = active && (this.color || 'primary')\n\n return this.$createElement('li', this.setTextColor(color, {\n key: year,\n class: { active },\n on: mergeListeners({\n click: () => this.$emit('input', year),\n }, createItemTypeNativeListeners(this, ':year', year)),\n }), formatted)\n },\n\n genYearItems (): VNode[] {\n const children = []\n const selectedYear = this.value ? parseInt(this.value, 10) : new Date().getFullYear()\n const maxYear = this.max ? parseInt(this.max, 10) : (selectedYear + 100)\n const minYear = Math.min(maxYear, this.min ? parseInt(this.min, 10) : (selectedYear - 100))\n\n for (let year = maxYear; year >= minYear; year--) {\n children.push(this.genYearItem(year))\n }\n\n return children\n },\n },\n\n render (): VNode {\n return this.$createElement('ul', {\n staticClass: 'v-date-picker-years',\n ref: 'years',\n }, this.genYearItems())\n },\n})\n","import './VPicker.sass'\nimport '../VCard/VCard.sass'\n\n// Mixins\nimport Colorable from '../../mixins/colorable'\nimport Elevatable from '../../mixins/elevatable'\nimport Themeable from '../../mixins/themeable'\n\n// Helpers\nimport { convertToUnit } from '../../util/helpers'\n\n// Types\nimport { VNode } from 'vue/types'\nimport mixins from '../../util/mixins'\n\n/* @vue/component */\nexport default mixins(\n Colorable,\n Elevatable,\n Themeable\n).extend({\n name: 'v-picker',\n\n props: {\n flat: Boolean,\n fullWidth: Boolean,\n landscape: Boolean,\n noTitle: Boolean,\n transition: {\n type: String,\n default: 'fade-transition',\n },\n width: {\n type: [Number, String],\n default: 290,\n },\n },\n\n computed: {\n computedTitleColor (): string | false {\n const defaultTitleColor = this.isDark ? false : (this.color || 'primary')\n return this.color || defaultTitleColor\n },\n },\n\n methods: {\n genTitle () {\n return this.$createElement('div', this.setBackgroundColor(this.computedTitleColor, {\n staticClass: 'v-picker__title',\n class: {\n 'v-picker__title--landscape': this.landscape,\n },\n }), this.$slots.title)\n },\n genBodyTransition () {\n return this.$createElement('transition', {\n props: {\n name: this.transition,\n },\n }, this.$slots.default)\n },\n genBody () {\n return this.$createElement('div', {\n staticClass: 'v-picker__body',\n class: {\n 'v-picker__body--no-title': this.noTitle,\n ...this.themeClasses,\n },\n style: this.fullWidth ? undefined : {\n width: convertToUnit(this.width),\n },\n }, [\n this.genBodyTransition(),\n ])\n },\n genActions () {\n return this.$createElement('div', {\n staticClass: 'v-picker__actions v-card__actions',\n class: {\n 'v-picker__actions--no-title': this.noTitle,\n },\n }, this.$slots.actions)\n },\n },\n\n render (h): VNode {\n return h('div', {\n staticClass: 'v-picker v-card',\n class: {\n 'v-picker--flat': this.flat,\n 'v-picker--landscape': this.landscape,\n 'v-picker--full-width': this.fullWidth,\n ...this.themeClasses,\n ...this.elevationClasses,\n },\n }, [\n this.$slots.title ? this.genTitle() : null,\n this.genBody(),\n this.$slots.actions ? this.genActions() : null,\n ])\n },\n})\n","import VPicker from './VPicker'\n\nexport { VPicker }\nexport default VPicker\n","// Components\nimport VPicker from '../../components/VPicker'\n\n// Mixins\nimport Colorable from '../colorable'\nimport Elevatable from '../../mixins/elevatable'\nimport Themeable from '../themeable'\n\n// Utils\nimport mixins from '../../util/mixins'\n\n// Types\nimport { VNode } from 'vue'\n\nexport default mixins(\n Colorable,\n Elevatable,\n Themeable\n/* @vue/component */\n).extend({\n name: 'picker',\n\n props: {\n flat: Boolean,\n fullWidth: Boolean,\n headerColor: String,\n landscape: Boolean,\n noTitle: Boolean,\n width: {\n type: [Number, String],\n default: 290,\n },\n },\n\n methods: {\n genPickerTitle (): VNode | null {\n return null\n },\n genPickerBody (): VNode | null {\n return null\n },\n genPickerActionsSlot () {\n return this.$scopedSlots.default ? this.$scopedSlots.default({\n save: (this as any).save,\n cancel: (this as any).cancel,\n }) : this.$slots.default\n },\n genPicker (staticClass: string) {\n const children: VNode[] = []\n\n if (!this.noTitle) {\n const title = this.genPickerTitle()\n title && children.push(title)\n }\n\n const body = this.genPickerBody()\n body && children.push(body)\n\n children.push(this.$createElement('template', { slot: 'actions' }, [this.genPickerActionsSlot()]))\n\n return this.$createElement(VPicker, {\n staticClass,\n props: {\n color: this.headerColor || this.color,\n dark: this.dark,\n elevation: this.elevation,\n flat: this.flat,\n fullWidth: this.fullWidth,\n landscape: this.landscape,\n light: this.light,\n width: this.width,\n noTitle: this.noTitle,\n },\n }, children)\n },\n },\n})\n","import { CalendarTimestamp, CalendarFormatter } from 'vuetify/types'\nimport { isLeapYear } from '../../../util/dateTimeUtils'\n\nexport const PARSE_REGEX = /^(\\d{4})-(\\d{1,2})(-(\\d{1,2}))?([^\\d]+(\\d{1,2}))?(:(\\d{1,2}))?(:(\\d{1,2}))?$/\nexport const PARSE_TIME = /(\\d\\d?)(:(\\d\\d?)|)(:(\\d\\d?)|)/\n\nexport const DAYS_IN_MONTH: number[] = [0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]\nexport const DAYS_IN_MONTH_LEAP: number[] = [0, 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]\nexport const DAYS_IN_MONTH_MIN = 28\nexport const DAYS_IN_MONTH_MAX = 31\nexport const MONTH_MAX = 12\nexport const MONTH_MIN = 1\nexport const DAY_MIN = 1\nexport const DAYS_IN_WEEK = 7\nexport const MINUTES_IN_HOUR = 60\nexport const MINUTE_MAX = 59\nexport const MINUTES_IN_DAY = 24 * 60\nexport const HOURS_IN_DAY = 24\nexport const HOUR_MAX = 23\nexport const FIRST_HOUR = 0\nexport const OFFSET_YEAR = 10000\nexport const OFFSET_MONTH = 100\nexport const OFFSET_HOUR = 100\nexport const OFFSET_TIME = 10000\n\ntype CalendarTimestampFormatOptions = (timestamp: CalendarTimestamp, short: boolean) => object\ntype CalendarTimestampOperation = (timestamp: CalendarTimestamp) => CalendarTimestamp\nexport type VTime = number | string | {\n hour: number\n minute: number\n}\n\nexport type VTimestampInput = number | string | Date;\n\nexport function getStartOfWeek (timestamp: CalendarTimestamp, weekdays: number[], today?: CalendarTimestamp): CalendarTimestamp {\n const start = copyTimestamp(timestamp)\n findWeekday(start, weekdays[0], prevDay)\n updateFormatted(start)\n if (today) {\n updateRelative(start, today, start.hasTime)\n }\n\n return start\n}\n\nexport function getEndOfWeek (timestamp: CalendarTimestamp, weekdays: number[], today?: CalendarTimestamp): CalendarTimestamp {\n const end = copyTimestamp(timestamp)\n findWeekday(end, weekdays[weekdays.length - 1])\n updateFormatted(end)\n if (today) {\n updateRelative(end, today, end.hasTime)\n }\n\n return end\n}\n\nexport function getStartOfMonth (timestamp: CalendarTimestamp): CalendarTimestamp {\n const start = copyTimestamp(timestamp)\n start.day = DAY_MIN\n updateWeekday(start)\n updateFormatted(start)\n\n return start\n}\n\nexport function getEndOfMonth (timestamp: CalendarTimestamp): CalendarTimestamp {\n const end = copyTimestamp(timestamp)\n end.day = daysInMonth(end.year, end.month)\n updateWeekday(end)\n updateFormatted(end)\n\n return end\n}\n\nexport function validateTime (input: any): input is VTime {\n return (typeof input === 'number' && isFinite(input)) ||\n (!!PARSE_TIME.exec(input)) ||\n (typeof input === 'object' && isFinite(input.hour) && isFinite(input.minute))\n}\n\nexport function parseTime (input: any): number | false {\n if (typeof input === 'number') {\n // when a number is given, it's minutes since 12:00am\n return input\n } else if (typeof input === 'string') {\n // when a string is given, it's a hh:mm:ss format where seconds are optional\n const parts = PARSE_TIME.exec(input)\n if (!parts) {\n return false\n }\n\n return parseInt(parts[1]) * 60 + parseInt(parts[3] || 0)\n } else if (typeof input === 'object') {\n // when an object is given, it must have hour and minute\n if (typeof input.hour !== 'number' || typeof input.minute !== 'number') {\n return false\n }\n\n return input.hour * 60 + input.minute\n } else {\n // unsupported type\n return false\n }\n}\n\nexport function validateTimestamp (input: any): input is VTimestampInput {\n return (typeof input === 'number' && isFinite(input)) ||\n (typeof input === 'string' && !!PARSE_REGEX.exec(input)) ||\n (input instanceof Date)\n}\n\nexport function parseTimestamp (input: VTimestampInput, required?: false, now?: CalendarTimestamp): CalendarTimestamp | null\nexport function parseTimestamp (input: VTimestampInput, required: true, now?: CalendarTimestamp): CalendarTimestamp\nexport function parseTimestamp (input: VTimestampInput, required = false, now?: CalendarTimestamp): CalendarTimestamp | null {\n if (typeof input === 'number' && isFinite(input)) {\n input = new Date(input)\n }\n\n if (input instanceof Date) {\n const date: CalendarTimestamp = parseDate(input)\n\n if (now) {\n updateRelative(date, now, date.hasTime)\n }\n\n return date\n }\n\n if (typeof input !== 'string') {\n if (required) {\n throw new Error(`${input} is not a valid timestamp. It must be a Date, number of seconds since Epoch, or a string in the format of YYYY-MM-DD or YYYY-MM-DD hh:mm. Zero-padding is optional and seconds are ignored.`)\n }\n return null\n }\n\n // YYYY-MM-DD hh:mm:ss\n const parts = PARSE_REGEX.exec(input)\n\n if (!parts) {\n if (required) {\n throw new Error(`${input} is not a valid timestamp. It must be a Date, number of seconds since Epoch, or a string in the format of YYYY-MM-DD or YYYY-MM-DD hh:mm. Zero-padding is optional and seconds are ignored.`)\n }\n\n return null\n }\n\n const timestamp: CalendarTimestamp = {\n date: input,\n time: '',\n year: parseInt(parts[1]),\n month: parseInt(parts[2]),\n day: parseInt(parts[4]) || 1,\n hour: parseInt(parts[6]) || 0,\n minute: parseInt(parts[8]) || 0,\n weekday: 0,\n hasDay: !!parts[4],\n hasTime: !!(parts[6] && parts[8]),\n past: false,\n present: false,\n future: false,\n }\n\n updateWeekday(timestamp)\n updateFormatted(timestamp)\n\n if (now) {\n updateRelative(timestamp, now, timestamp.hasTime)\n }\n\n return timestamp\n}\n\nexport function parseDate (date: Date): CalendarTimestamp {\n return updateFormatted({\n date: '',\n time: '',\n year: date.getFullYear(),\n month: date.getMonth() + 1,\n day: date.getDate(),\n weekday: date.getDay(),\n hour: date.getHours(),\n minute: date.getMinutes(),\n hasDay: true,\n hasTime: true,\n past: false,\n present: true,\n future: false,\n })\n}\n\nexport function getDayIdentifier (timestamp: { year: number, month: number, day: number }): number {\n return timestamp.year * OFFSET_YEAR + timestamp.month * OFFSET_MONTH + timestamp.day\n}\n\nexport function getTimeIdentifier (timestamp: { hour: number, minute: number }): number {\n return timestamp.hour * OFFSET_HOUR + timestamp.minute\n}\n\nexport function getTimestampIdentifier (timestamp: CalendarTimestamp): number {\n return getDayIdentifier(timestamp) * OFFSET_TIME + getTimeIdentifier(timestamp)\n}\n\nexport function updateRelative (timestamp: CalendarTimestamp, now: CalendarTimestamp, time = false): CalendarTimestamp {\n let a = getDayIdentifier(now)\n let b = getDayIdentifier(timestamp)\n let present = a === b\n\n if (timestamp.hasTime && time && present) {\n a = getTimeIdentifier(now)\n b = getTimeIdentifier(timestamp)\n present = a === b\n }\n\n timestamp.past = b < a\n timestamp.present = present\n timestamp.future = b > a\n\n return timestamp\n}\n\nexport function isTimedless (input: VTimestampInput): input is (Date | number) {\n return (input instanceof Date) || (typeof input === 'number' && isFinite(input))\n}\n\nexport function updateHasTime (timestamp: CalendarTimestamp, hasTime: boolean, now?: CalendarTimestamp): CalendarTimestamp {\n if (timestamp.hasTime !== hasTime) {\n timestamp.hasTime = hasTime\n if (!hasTime) {\n timestamp.hour = HOUR_MAX\n timestamp.minute = MINUTE_MAX\n timestamp.time = getTime(timestamp)\n }\n if (now) {\n updateRelative(timestamp, now, timestamp.hasTime)\n }\n }\n\n return timestamp\n}\n\nexport function updateMinutes (timestamp: CalendarTimestamp, minutes: number, now?: CalendarTimestamp): CalendarTimestamp {\n timestamp.hasTime = true\n timestamp.hour = Math.floor(minutes / MINUTES_IN_HOUR)\n timestamp.minute = minutes % MINUTES_IN_HOUR\n timestamp.time = getTime(timestamp)\n if (now) {\n updateRelative(timestamp, now, true)\n }\n\n return timestamp\n}\n\nexport function updateWeekday (timestamp: CalendarTimestamp): CalendarTimestamp {\n timestamp.weekday = getWeekday(timestamp)\n\n return timestamp\n}\n\nexport function updateFormatted (timestamp: CalendarTimestamp): CalendarTimestamp {\n timestamp.time = getTime(timestamp)\n timestamp.date = getDate(timestamp)\n\n return timestamp\n}\n\nexport function getWeekday (timestamp: CalendarTimestamp): number {\n if (timestamp.hasDay) {\n const _ = Math.floor\n const k = timestamp.day\n const m = ((timestamp.month + 9) % MONTH_MAX) + 1\n const C = _(timestamp.year / 100)\n const Y = (timestamp.year % 100) - (timestamp.month <= 2 ? 1 : 0)\n\n return (((k + _(2.6 * m - 0.2) - 2 * C + Y + _(Y / 4) + _(C / 4)) % 7) + 7) % 7\n }\n\n return timestamp.weekday\n}\n\nexport function daysInMonth (year: number, month: number) {\n return isLeapYear(year) ? DAYS_IN_MONTH_LEAP[month] : DAYS_IN_MONTH[month]\n}\n\nexport function copyTimestamp (timestamp: CalendarTimestamp): CalendarTimestamp {\n const { date, time, year, month, day, weekday, hour, minute, hasDay, hasTime, past, present, future } = timestamp\n\n return { date, time, year, month, day, weekday, hour, minute, hasDay, hasTime, past, present, future }\n}\n\nexport function padNumber (x: number, length: number): string {\n let padded = String(x)\n while (padded.length < length) {\n padded = '0' + padded\n }\n\n return padded\n}\n\nexport function getDate (timestamp: CalendarTimestamp): string {\n let str = `${padNumber(timestamp.year, 4)}-${padNumber(timestamp.month, 2)}`\n\n if (timestamp.hasDay) str += `-${padNumber(timestamp.day, 2)}`\n\n return str\n}\n\nexport function getTime (timestamp: CalendarTimestamp): string {\n if (!timestamp.hasTime) {\n return ''\n }\n\n return `${padNumber(timestamp.hour, 2)}:${padNumber(timestamp.minute, 2)}`\n}\n\nexport function nextMinutes (timestamp: CalendarTimestamp, minutes: number): CalendarTimestamp {\n timestamp.minute += minutes\n while (timestamp.minute > MINUTES_IN_HOUR) {\n timestamp.minute -= MINUTES_IN_HOUR\n timestamp.hour++\n if (timestamp.hour >= HOURS_IN_DAY) {\n nextDay(timestamp)\n timestamp.hour = FIRST_HOUR\n }\n }\n\n return timestamp\n}\n\nexport function nextDay (timestamp: CalendarTimestamp): CalendarTimestamp {\n timestamp.day++\n timestamp.weekday = (timestamp.weekday + 1) % DAYS_IN_WEEK\n if (timestamp.day > DAYS_IN_MONTH_MIN && timestamp.day > daysInMonth(timestamp.year, timestamp.month)) {\n timestamp.day = DAY_MIN\n timestamp.month++\n if (timestamp.month > MONTH_MAX) {\n timestamp.month = MONTH_MIN\n timestamp.year++\n }\n }\n\n return timestamp\n}\n\nexport function prevDay (timestamp: CalendarTimestamp): CalendarTimestamp {\n timestamp.day--\n timestamp.weekday = (timestamp.weekday + 6) % DAYS_IN_WEEK\n if (timestamp.day < DAY_MIN) {\n timestamp.month--\n if (timestamp.month < MONTH_MIN) {\n timestamp.year--\n timestamp.month = MONTH_MAX\n }\n timestamp.day = daysInMonth(timestamp.year, timestamp.month)\n }\n\n return timestamp\n}\n\nexport function relativeDays (\n timestamp: CalendarTimestamp,\n mover: CalendarTimestampOperation = nextDay,\n days = 1\n): CalendarTimestamp {\n while (--days >= 0) mover(timestamp)\n\n return timestamp\n}\n\nexport function diffMinutes (min: CalendarTimestamp, max: CalendarTimestamp) {\n const Y = (max.year - min.year) * 525600\n const M = (max.month - min.month) * 43800\n const D = (max.day - min.day) * 1440\n const h = (max.hour - min.hour) * 60\n const m = (max.minute - min.minute)\n\n return Y + M + D + h + m\n}\n\nexport function findWeekday (timestamp: CalendarTimestamp, weekday: number,\n mover: CalendarTimestampOperation = nextDay, maxDays = 6): CalendarTimestamp {\n while (timestamp.weekday !== weekday && --maxDays >= 0) mover(timestamp)\n\n return timestamp\n}\n\nexport function getWeekdaySkips (weekdays: number[]): number[] {\n const skips: number[] = [1, 1, 1, 1, 1, 1, 1]\n const filled: number[] = [0, 0, 0, 0, 0, 0, 0]\n for (let i = 0; i < weekdays.length; i++) {\n filled[weekdays[i]] = 1\n }\n for (let k = 0; k < DAYS_IN_WEEK; k++) {\n let skip = 1\n for (let j = 1; j < DAYS_IN_WEEK; j++) {\n const next = (k + j) % DAYS_IN_WEEK\n if (filled[next]) {\n break\n }\n skip++\n }\n skips[k] = filled[k] * skip\n }\n\n return skips\n}\n\nexport function timestampToDate (timestamp: CalendarTimestamp): Date {\n const time = `${padNumber(timestamp.hour, 2)}:${padNumber(timestamp.minute, 2)}`\n const date = timestamp.date\n\n return new Date(`${date}T${time}:00+00:00`)\n}\n\nexport function createDayList (\n start: CalendarTimestamp,\n end: CalendarTimestamp,\n now: CalendarTimestamp,\n weekdaySkips: number[],\n max = 42,\n min = 0\n): CalendarTimestamp[] {\n const stop = getDayIdentifier(end)\n const days: CalendarTimestamp[] = []\n let current = copyTimestamp(start)\n let currentIdentifier = 0\n let stopped = currentIdentifier === stop\n\n if (stop < getDayIdentifier(start)) {\n throw new Error('End date is earlier than start date.')\n }\n\n while ((!stopped || days.length < min) && days.length < max) {\n currentIdentifier = getDayIdentifier(current)\n stopped = stopped || currentIdentifier === stop\n if (weekdaySkips[current.weekday] === 0) {\n current = nextDay(current)\n continue\n }\n const day = copyTimestamp(current)\n updateFormatted(day)\n updateRelative(day, now)\n days.push(day)\n current = relativeDays(current, nextDay, weekdaySkips[current.weekday])\n }\n\n if (!days.length) throw new Error('No dates found using specified start date, end date, and weekdays.')\n\n return days\n}\n\nexport function createIntervalList (timestamp: CalendarTimestamp, first: number,\n minutes: number, count: number, now?: CalendarTimestamp): CalendarTimestamp[] {\n const intervals: CalendarTimestamp[] = []\n\n for (let i = 0; i < count; i++) {\n const mins = first + (i * minutes)\n const int = copyTimestamp(timestamp)\n intervals.push(updateMinutes(int, mins, now))\n }\n\n return intervals\n}\n\nexport function createNativeLocaleFormatter (locale: string, getOptions: CalendarTimestampFormatOptions): CalendarFormatter {\n const emptyFormatter: CalendarFormatter = (_t, _s) => ''\n\n if (typeof Intl === 'undefined' || typeof Intl.DateTimeFormat === 'undefined') {\n return emptyFormatter\n }\n\n return (timestamp, short) => {\n try {\n const intlFormatter = new Intl.DateTimeFormat(locale || undefined, getOptions(timestamp, short))\n\n return intlFormatter.format(timestampToDate(timestamp))\n } catch (e) {\n return ''\n }\n }\n}\n","// Components\nimport VDatePickerTitle from './VDatePickerTitle'\nimport VDatePickerHeader from './VDatePickerHeader'\nimport VDatePickerDateTable from './VDatePickerDateTable'\nimport VDatePickerMonthTable from './VDatePickerMonthTable'\nimport VDatePickerYears from './VDatePickerYears'\n\n// Mixins\nimport Localable from '../../mixins/localable'\nimport Picker from '../../mixins/picker'\n\n// Utils\nimport isDateAllowed from './util/isDateAllowed'\nimport mixins from '../../util/mixins'\nimport { wrapInArray } from '../../util/helpers'\nimport { daysInMonth } from '../VCalendar/util/timestamp'\nimport { consoleWarn } from '../../util/console'\nimport {\n createItemTypeListeners,\n createNativeLocaleFormatter,\n pad,\n sanitizeDateString,\n} from './util'\n\n// Types\nimport {\n PropType,\n PropValidator,\n} from 'vue/types/options'\nimport { VNode } from 'vue'\nimport {\n DatePickerFormatter,\n DatePickerMultipleFormatter,\n DatePickerAllowedDatesFunction,\n DatePickerEventColors,\n DatePickerEvents,\n DatePickerType,\n} from 'vuetify/types'\n\ntype DatePickerValue = string | string[] | undefined\ninterface Formatters {\n year: DatePickerFormatter\n titleDate: DatePickerFormatter | DatePickerMultipleFormatter\n}\n\ntype ActivePicker = 'DATE' | 'MONTH' | 'YEAR';\n\nexport default mixins(\n Localable,\n Picker,\n/* @vue/component */\n).extend({\n name: 'v-date-picker',\n\n props: {\n activePicker: String as PropType,\n allowedDates: Function as PropType,\n // Function formatting the day in date picker table\n dayFormat: Function as PropType,\n disabled: Boolean,\n events: {\n type: [Array, Function, Object],\n default: () => null,\n } as PropValidator,\n eventColor: {\n type: [Array, Function, Object, String],\n default: () => 'warning',\n } as PropValidator,\n firstDayOfWeek: {\n type: [String, Number],\n default: 0,\n },\n // Function formatting the tableDate in the day/month table header\n headerDateFormat: Function as PropType,\n localeFirstDayOfYear: {\n type: [String, Number],\n default: 0,\n },\n max: String,\n min: String,\n // Function formatting month in the months table\n monthFormat: Function as PropType,\n multiple: Boolean,\n nextIcon: {\n type: String,\n default: '$next',\n },\n nextMonthAriaLabel: {\n type: String,\n default: '$vuetify.datePicker.nextMonthAriaLabel',\n },\n nextYearAriaLabel: {\n type: String,\n default: '$vuetify.datePicker.nextYearAriaLabel',\n },\n pickerDate: String,\n prevIcon: {\n type: String,\n default: '$prev',\n },\n prevMonthAriaLabel: {\n type: String,\n default: '$vuetify.datePicker.prevMonthAriaLabel',\n },\n prevYearAriaLabel: {\n type: String,\n default: '$vuetify.datePicker.prevYearAriaLabel',\n },\n range: Boolean,\n reactive: Boolean,\n readonly: Boolean,\n scrollable: Boolean,\n showCurrent: {\n type: [Boolean, String],\n default: true,\n },\n selectedItemsText: {\n type: String,\n default: '$vuetify.datePicker.itemsSelected',\n },\n showAdjacentMonths: Boolean,\n showWeek: Boolean,\n // Function formatting currently selected date in the picker title\n titleDateFormat: Function as PropType,\n type: {\n type: String,\n default: 'date',\n validator: (type: any) => ['date', 'month'].includes(type), // TODO: year\n } as PropValidator,\n value: [Array, String] as PropType,\n weekdayFormat: Function as PropType,\n // Function formatting the year in table header and pickup title\n yearFormat: Function as PropType,\n yearIcon: String,\n },\n\n data () {\n const now = new Date()\n return {\n internalActivePicker: this.type.toUpperCase(),\n inputDay: null as number | null,\n inputMonth: null as number | null,\n inputYear: null as number | null,\n isReversing: false,\n now,\n // tableDate is a string in 'YYYY' / 'YYYY-M' format (leading zero for month is not required)\n tableDate: (() => {\n if (this.pickerDate) {\n return this.pickerDate\n }\n\n const multipleValue = wrapInArray(this.value)\n const date = multipleValue[multipleValue.length - 1] ||\n (typeof this.showCurrent === 'string' ? this.showCurrent : `${now.getFullYear()}-${now.getMonth() + 1}`)\n return sanitizeDateString(date as string, this.type === 'date' ? 'month' : 'year')\n })(),\n }\n },\n\n computed: {\n multipleValue (): string[] {\n return wrapInArray(this.value)\n },\n isMultiple (): boolean {\n return this.multiple || this.range\n },\n lastValue (): string | null {\n return this.isMultiple ? this.multipleValue[this.multipleValue.length - 1] : (this.value as string | null)\n },\n selectedMonths (): string | string[] | undefined {\n if (!this.value || this.type === 'month') {\n return this.value\n } else if (this.isMultiple) {\n return this.multipleValue.map(val => val.substr(0, 7))\n } else {\n return (this.value as string).substr(0, 7)\n }\n },\n current (): string | null {\n if (this.showCurrent === true) {\n return sanitizeDateString(`${this.now.getFullYear()}-${this.now.getMonth() + 1}-${this.now.getDate()}`, this.type)\n }\n\n return this.showCurrent || null\n },\n inputDate (): string {\n return this.type === 'date'\n ? `${this.inputYear}-${pad(this.inputMonth! + 1)}-${pad(this.inputDay!)}`\n : `${this.inputYear}-${pad(this.inputMonth! + 1)}`\n },\n tableMonth (): number {\n return Number((this.pickerDate || this.tableDate).split('-')[1]) - 1\n },\n tableYear (): number {\n return Number((this.pickerDate || this.tableDate).split('-')[0])\n },\n minMonth (): string | null {\n return this.min ? sanitizeDateString(this.min, 'month') : null\n },\n maxMonth (): string | null {\n return this.max ? sanitizeDateString(this.max, 'month') : null\n },\n minYear (): string | null {\n return this.min ? sanitizeDateString(this.min, 'year') : null\n },\n maxYear (): string | null {\n return this.max ? sanitizeDateString(this.max, 'year') : null\n },\n formatters (): Formatters {\n return {\n year: this.yearFormat || createNativeLocaleFormatter(this.currentLocale, { year: 'numeric', timeZone: 'UTC' }, { length: 4 }),\n titleDate: this.titleDateFormat ||\n (this.isMultiple ? this.defaultTitleMultipleDateFormatter : this.defaultTitleDateFormatter),\n }\n },\n defaultTitleMultipleDateFormatter (): DatePickerMultipleFormatter {\n return dates => {\n if (!dates.length) {\n return '-'\n }\n\n if (dates.length === 1) {\n return this.defaultTitleDateFormatter(dates[0])\n }\n\n return this.$vuetify.lang.t(this.selectedItemsText, dates.length)\n }\n },\n defaultTitleDateFormatter (): DatePickerFormatter {\n const titleFormats = {\n year: { year: 'numeric', timeZone: 'UTC' },\n month: { month: 'long', timeZone: 'UTC' },\n date: { weekday: 'short', month: 'short', day: 'numeric', timeZone: 'UTC' },\n }\n\n const titleDateFormatter = createNativeLocaleFormatter(this.currentLocale, titleFormats[this.type], {\n start: 0,\n length: { date: 10, month: 7, year: 4 }[this.type],\n })\n\n const landscapeFormatter = (date: string) => titleDateFormatter(date)\n .replace(/([^\\d\\s])([\\d])/g, (match, nonDigit, digit) => `${nonDigit} ${digit}`)\n .replace(', ', ',
')\n\n return this.landscape ? landscapeFormatter : titleDateFormatter\n },\n },\n\n watch: {\n internalActivePicker: {\n immediate: true,\n handler (val: ActivePicker) {\n this.$emit('update:active-picker', val)\n },\n },\n activePicker (val: ActivePicker) {\n this.internalActivePicker = val\n },\n tableDate (val: string, prev: string) {\n // Make a ISO 8601 strings from val and prev for comparision, otherwise it will incorrectly\n // compare for example '2000-9' and '2000-10'\n const sanitizeType = this.type === 'month' ? 'year' : 'month'\n this.isReversing = sanitizeDateString(val, sanitizeType) < sanitizeDateString(prev, sanitizeType)\n this.$emit('update:picker-date', val)\n },\n pickerDate (val: string | null) {\n if (val) {\n this.tableDate = val\n } else if (this.lastValue && this.type === 'date') {\n this.tableDate = sanitizeDateString(this.lastValue, 'month')\n } else if (this.lastValue && this.type === 'month') {\n this.tableDate = sanitizeDateString(this.lastValue, 'year')\n }\n },\n value (newValue: DatePickerValue, oldValue: DatePickerValue) {\n this.checkMultipleProp()\n this.setInputDate()\n\n if (\n (!this.isMultiple && this.value && !this.pickerDate) ||\n (this.isMultiple && this.multipleValue.length && (!oldValue || !oldValue.length) && !this.pickerDate)\n ) {\n this.tableDate = sanitizeDateString(this.inputDate, this.type === 'month' ? 'year' : 'month')\n }\n },\n type (type: DatePickerType) {\n this.internalActivePicker = type.toUpperCase()\n\n if (this.value && this.value.length) {\n const output = this.multipleValue\n .map((val: string) => sanitizeDateString(val, type))\n .filter(this.isDateAllowed)\n this.$emit('input', this.isMultiple ? output : output[0])\n }\n },\n },\n\n created () {\n this.checkMultipleProp()\n\n if (this.pickerDate !== this.tableDate) {\n this.$emit('update:picker-date', this.tableDate)\n }\n this.setInputDate()\n },\n\n methods: {\n emitInput (newInput: string) {\n if (this.range) {\n if (this.multipleValue.length !== 1) {\n this.$emit('input', [newInput])\n } else {\n const output = [this.multipleValue[0], newInput]\n this.$emit('input', output)\n this.$emit('change', output)\n }\n return\n }\n\n const output = this.multiple\n ? (\n this.multipleValue.indexOf(newInput) === -1\n ? this.multipleValue.concat([newInput])\n : this.multipleValue.filter(x => x !== newInput)\n )\n : newInput\n\n this.$emit('input', output)\n this.multiple || this.$emit('change', newInput)\n },\n checkMultipleProp () {\n if (this.value == null) return\n const valueType = this.value.constructor.name\n const expected = this.isMultiple ? 'Array' : 'String'\n if (valueType !== expected) {\n consoleWarn(`Value must be ${this.isMultiple ? 'an' : 'a'} ${expected}, got ${valueType}`, this)\n }\n },\n isDateAllowed (value: string): boolean {\n return isDateAllowed(value, this.min, this.max, this.allowedDates)\n },\n yearClick (value: number) {\n this.inputYear = value\n if (this.type === 'month') {\n this.tableDate = `${value}`\n } else {\n this.tableDate = `${value}-${pad((this.tableMonth || 0) + 1)}`\n }\n this.internalActivePicker = 'MONTH'\n if (this.reactive && !this.readonly && !this.isMultiple && this.isDateAllowed(this.inputDate)) {\n this.$emit('input', this.inputDate)\n }\n },\n monthClick (value: string) {\n this.inputYear = parseInt(value.split('-')[0], 10)\n this.inputMonth = parseInt(value.split('-')[1], 10) - 1\n if (this.type === 'date') {\n if (this.inputDay) {\n this.inputDay = Math.min(this.inputDay, daysInMonth(this.inputYear, this.inputMonth + 1))\n }\n\n this.tableDate = value\n this.internalActivePicker = 'DATE'\n if (this.reactive && !this.readonly && !this.isMultiple && this.isDateAllowed(this.inputDate)) {\n this.$emit('input', this.inputDate)\n }\n } else {\n this.emitInput(this.inputDate)\n }\n },\n dateClick (value: string) {\n this.inputYear = parseInt(value.split('-')[0], 10)\n this.inputMonth = parseInt(value.split('-')[1], 10) - 1\n this.inputDay = parseInt(value.split('-')[2], 10)\n this.emitInput(this.inputDate)\n },\n genPickerTitle (): VNode {\n return this.$createElement(VDatePickerTitle, {\n props: {\n date: this.value ? (this.formatters.titleDate as (value: any) => string)(this.isMultiple ? this.multipleValue : this.value) : '',\n disabled: this.disabled,\n readonly: this.readonly,\n selectingYear: this.internalActivePicker === 'YEAR',\n year: this.formatters.year(this.multipleValue.length ? `${this.inputYear}` : this.tableDate),\n yearIcon: this.yearIcon,\n value: this.multipleValue[0],\n },\n slot: 'title',\n on: {\n 'update:selecting-year': (value: boolean) => this.internalActivePicker = value ? 'YEAR' : this.type.toUpperCase(),\n },\n })\n },\n genTableHeader (): VNode {\n return this.$createElement(VDatePickerHeader, {\n props: {\n nextIcon: this.nextIcon,\n color: this.color,\n dark: this.dark,\n disabled: this.disabled,\n format: this.headerDateFormat,\n light: this.light,\n locale: this.locale,\n min: this.internalActivePicker === 'DATE' ? this.minMonth : this.minYear,\n max: this.internalActivePicker === 'DATE' ? this.maxMonth : this.maxYear,\n nextAriaLabel: this.internalActivePicker === 'DATE' ? this.nextMonthAriaLabel : this.nextYearAriaLabel,\n prevAriaLabel: this.internalActivePicker === 'DATE' ? this.prevMonthAriaLabel : this.prevYearAriaLabel,\n prevIcon: this.prevIcon,\n readonly: this.readonly,\n value: this.internalActivePicker === 'DATE' ? `${pad(this.tableYear, 4)}-${pad(this.tableMonth + 1)}` : `${pad(this.tableYear, 4)}`,\n },\n on: {\n toggle: () => this.internalActivePicker = (this.internalActivePicker === 'DATE' ? 'MONTH' : 'YEAR'),\n input: (value: string) => this.tableDate = value,\n },\n })\n },\n genDateTable (): VNode {\n return this.$createElement(VDatePickerDateTable, {\n props: {\n allowedDates: this.allowedDates,\n color: this.color,\n current: this.current,\n dark: this.dark,\n disabled: this.disabled,\n events: this.events,\n eventColor: this.eventColor,\n firstDayOfWeek: this.firstDayOfWeek,\n format: this.dayFormat,\n light: this.light,\n locale: this.locale,\n localeFirstDayOfYear: this.localeFirstDayOfYear,\n min: this.min,\n max: this.max,\n range: this.range,\n readonly: this.readonly,\n scrollable: this.scrollable,\n showAdjacentMonths: this.showAdjacentMonths,\n showWeek: this.showWeek,\n tableDate: `${pad(this.tableYear, 4)}-${pad(this.tableMonth + 1)}`,\n value: this.value,\n weekdayFormat: this.weekdayFormat,\n },\n ref: 'table',\n on: {\n input: this.dateClick,\n 'update:table-date': (value: string) => this.tableDate = value,\n ...createItemTypeListeners(this, ':date'),\n },\n })\n },\n genMonthTable (): VNode {\n return this.$createElement(VDatePickerMonthTable, {\n props: {\n allowedDates: this.type === 'month' ? this.allowedDates : null,\n color: this.color,\n current: this.current ? sanitizeDateString(this.current, 'month') : null,\n dark: this.dark,\n disabled: this.disabled,\n events: this.type === 'month' ? this.events : null,\n eventColor: this.type === 'month' ? this.eventColor : null,\n format: this.monthFormat,\n light: this.light,\n locale: this.locale,\n min: this.minMonth,\n max: this.maxMonth,\n range: this.range,\n readonly: this.readonly && this.type === 'month',\n scrollable: this.scrollable,\n value: this.selectedMonths,\n tableDate: `${pad(this.tableYear, 4)}`,\n },\n ref: 'table',\n on: {\n input: this.monthClick,\n 'update:table-date': (value: string) => this.tableDate = value,\n ...createItemTypeListeners(this, ':month'),\n },\n })\n },\n genYears (): VNode {\n return this.$createElement(VDatePickerYears, {\n props: {\n color: this.color,\n format: this.yearFormat,\n locale: this.locale,\n min: this.minYear,\n max: this.maxYear,\n value: this.tableYear,\n },\n on: {\n input: this.yearClick,\n ...createItemTypeListeners(this, ':year'),\n },\n })\n },\n genPickerBody (): VNode {\n const children = this.internalActivePicker === 'YEAR' ? [\n this.genYears(),\n ] : [\n this.genTableHeader(),\n this.internalActivePicker === 'DATE' ? this.genDateTable() : this.genMonthTable(),\n ]\n\n return this.$createElement('div', {\n key: this.internalActivePicker,\n }, children)\n },\n setInputDate () {\n if (this.lastValue) {\n const array = this.lastValue.split('-')\n this.inputYear = parseInt(array[0], 10)\n this.inputMonth = parseInt(array[1], 10) - 1\n if (this.type === 'date') {\n this.inputDay = parseInt(array[2], 10)\n }\n } else {\n this.inputYear = this.inputYear || this.now.getFullYear()\n this.inputMonth = this.inputMonth == null ? this.inputMonth : this.now.getMonth()\n this.inputDay = this.inputDay || this.now.getDate()\n }\n },\n },\n\n render (): VNode {\n return this.genPicker('v-picker--date')\n },\n})\n","import './VGrid.sass'\n\nimport Vue, { VNode, PropOptions } from 'vue'\nimport mergeData from '../../util/mergeData'\nimport { upperFirst } from '../../util/helpers'\n\n// no xs\nconst breakpoints = ['sm', 'md', 'lg', 'xl']\n\nconst breakpointProps = (() => {\n return breakpoints.reduce((props, val) => {\n props[val] = {\n type: [Boolean, String, Number],\n default: false,\n }\n return props\n }, {} as Dictionary)\n})()\n\nconst offsetProps = (() => {\n return breakpoints.reduce((props, val) => {\n props['offset' + upperFirst(val)] = {\n type: [String, Number],\n default: null,\n }\n return props\n }, {} as Dictionary)\n})()\n\nconst orderProps = (() => {\n return breakpoints.reduce((props, val) => {\n props['order' + upperFirst(val)] = {\n type: [String, Number],\n default: null,\n }\n return props\n }, {} as Dictionary)\n})()\n\nconst propMap = {\n col: Object.keys(breakpointProps),\n offset: Object.keys(offsetProps),\n order: Object.keys(orderProps),\n}\n\nfunction breakpointClass (type: keyof typeof propMap, prop: string, val: boolean | string | number) {\n let className = type\n if (val == null || val === false) {\n return undefined\n }\n if (prop) {\n const breakpoint = prop.replace(type, '')\n className += `-${breakpoint}`\n }\n // Handling the boolean style prop when accepting [Boolean, String, Number]\n // means Vue will not convert to sm: true for us.\n // Since the default is false, an empty string indicates the prop's presence.\n if (type === 'col' && (val === '' || val === true)) {\n // .col-md\n return className.toLowerCase()\n }\n // .order-md-6\n className += `-${val}`\n return className.toLowerCase()\n}\n\nconst cache = new Map()\n\nexport default Vue.extend({\n name: 'v-col',\n functional: true,\n props: {\n cols: {\n type: [Boolean, String, Number],\n default: false,\n },\n ...breakpointProps,\n offset: {\n type: [String, Number],\n default: null,\n },\n ...offsetProps,\n order: {\n type: [String, Number],\n default: null,\n },\n ...orderProps,\n alignSelf: {\n type: String,\n default: null,\n validator: (str: any) => ['auto', 'start', 'end', 'center', 'baseline', 'stretch'].includes(str),\n },\n tag: {\n type: String,\n default: 'div',\n },\n },\n render (h, { props, data, children, parent }): VNode {\n // Super-fast memoization based on props, 5x faster than JSON.stringify\n let cacheKey = ''\n for (const prop in props) {\n cacheKey += String((props as any)[prop])\n }\n let classList = cache.get(cacheKey)\n\n if (!classList) {\n classList = []\n // Loop through `col`, `offset`, `order` breakpoint props\n let type: keyof typeof propMap\n for (type in propMap) {\n propMap[type].forEach(prop => {\n const value: string | number | boolean = (props as any)[prop]\n const className = breakpointClass(type, prop, value)\n if (className) classList!.push(className)\n })\n }\n\n const hasColClasses = classList.some(className => className.startsWith('col-'))\n\n classList.push({\n // Default to .col if no other col-{bp}-* classes generated nor `cols` specified.\n col: !hasColClasses || !props.cols,\n [`col-${props.cols}`]: props.cols,\n [`offset-${props.offset}`]: props.offset,\n [`order-${props.order}`]: props.order,\n [`align-self-${props.alignSelf}`]: props.alignSelf,\n })\n\n cache.set(cacheKey, classList)\n }\n\n return h(props.tag, mergeData(data, { class: classList }), children)\n },\n})\n","// Helpers\nimport { wrapInArray, sortItems, deepEqual, groupItems, searchItems, fillArray } from '../../util/helpers'\nimport Vue, { VNode } from 'vue'\n\n// Types\nimport {\n DataOptions,\n DataPagination,\n DataScopeProps,\n DataSortFunction,\n DataGroupFunction,\n DataSearchFunction,\n ItemGroup,\n} from 'vuetify/types'\nimport { PropValidator } from 'vue/types/options'\n\nexport default Vue.extend({\n name: 'v-data',\n\n inheritAttrs: false,\n\n props: {\n items: {\n type: Array,\n default: () => [],\n } as PropValidator,\n options: {\n type: Object,\n default: () => ({}),\n } as PropValidator>,\n sortBy: {\n type: [String, Array],\n default: () => [],\n } as PropValidator,\n sortDesc: {\n type: [Boolean, Array],\n default: () => [],\n } as PropValidator,\n customSort: {\n type: Function,\n default: sortItems,\n } as PropValidator,\n mustSort: Boolean,\n multiSort: Boolean,\n page: {\n type: Number,\n default: 1,\n },\n itemsPerPage: {\n type: Number,\n default: 10,\n },\n groupBy: {\n type: [String, Array],\n default: () => [],\n } as PropValidator,\n groupDesc: {\n type: [Boolean, Array],\n default: () => [],\n } as PropValidator,\n customGroup: {\n type: Function,\n default: groupItems,\n } as PropValidator,\n locale: {\n type: String,\n default: 'en-US',\n },\n disableSort: Boolean,\n disablePagination: Boolean,\n disableFiltering: Boolean,\n search: String,\n customFilter: {\n type: Function,\n default: searchItems,\n } as PropValidator,\n serverItemsLength: {\n type: Number,\n default: -1,\n },\n },\n\n data () {\n let internalOptions: DataOptions = {\n page: this.page,\n itemsPerPage: this.itemsPerPage,\n sortBy: wrapInArray(this.sortBy),\n sortDesc: wrapInArray(this.sortDesc),\n groupBy: wrapInArray(this.groupBy),\n groupDesc: wrapInArray(this.groupDesc),\n mustSort: this.mustSort,\n multiSort: this.multiSort,\n }\n\n if (this.options) {\n internalOptions = Object.assign(internalOptions, this.options)\n }\n\n const { sortBy, sortDesc, groupBy, groupDesc } = internalOptions\n const sortDiff = sortBy.length - sortDesc.length\n const groupDiff = groupBy.length - groupDesc.length\n\n if (sortDiff > 0) {\n internalOptions.sortDesc.push(...fillArray(sortDiff, false))\n }\n\n if (groupDiff > 0) {\n internalOptions.groupDesc.push(...fillArray(groupDiff, false))\n }\n\n return {\n internalOptions,\n }\n },\n\n computed: {\n itemsLength (): number {\n return this.serverItemsLength >= 0 ? this.serverItemsLength : this.filteredItems.length\n },\n pageCount (): number {\n return this.internalOptions.itemsPerPage <= 0\n ? 1\n : Math.ceil(this.itemsLength / this.internalOptions.itemsPerPage)\n },\n pageStart (): number {\n if (this.internalOptions.itemsPerPage === -1 || !this.items.length) return 0\n\n return (this.internalOptions.page - 1) * this.internalOptions.itemsPerPage\n },\n pageStop (): number {\n if (this.internalOptions.itemsPerPage === -1) return this.itemsLength\n if (!this.items.length) return 0\n\n return Math.min(this.itemsLength, this.internalOptions.page * this.internalOptions.itemsPerPage)\n },\n isGrouped (): boolean {\n return !!this.internalOptions.groupBy.length\n },\n pagination (): DataPagination {\n return {\n page: this.internalOptions.page,\n itemsPerPage: this.internalOptions.itemsPerPage,\n pageStart: this.pageStart,\n pageStop: this.pageStop,\n pageCount: this.pageCount,\n itemsLength: this.itemsLength,\n }\n },\n filteredItems (): any[] {\n let items = this.items.slice()\n\n if (!this.disableFiltering && this.serverItemsLength <= 0) {\n items = this.customFilter(items, this.search)\n }\n\n return items\n },\n computedItems (): any[] {\n let items = this.filteredItems.slice()\n\n if ((!this.disableSort || this.internalOptions.groupBy.length) && this.serverItemsLength <= 0) {\n items = this.sortItems(items)\n }\n\n if (!this.disablePagination && this.serverItemsLength <= 0) {\n items = this.paginateItems(items)\n }\n\n return items\n },\n groupedItems (): ItemGroup[] | null {\n return this.isGrouped ? this.groupItems(this.computedItems) : null\n },\n scopedProps (): DataScopeProps {\n return {\n sort: this.sort,\n sortArray: this.sortArray,\n group: this.group,\n items: this.computedItems,\n options: this.internalOptions,\n updateOptions: this.updateOptions,\n pagination: this.pagination,\n groupedItems: this.groupedItems,\n originalItemsLength: this.items.length,\n }\n },\n computedOptions (): DataOptions {\n return { ...this.options } as DataOptions\n },\n },\n\n watch: {\n computedOptions: {\n handler (options: DataOptions, old: DataOptions) {\n if (deepEqual(options, old)) return\n\n this.updateOptions(options)\n },\n deep: true,\n immediate: true,\n },\n internalOptions: {\n handler (options: DataOptions, old: DataOptions) {\n if (deepEqual(options, old)) return\n this.$emit('update:options', options)\n },\n deep: true,\n immediate: true,\n },\n page (page: number) {\n this.updateOptions({ page })\n },\n 'internalOptions.page' (page: number) {\n this.$emit('update:page', page)\n },\n itemsPerPage (itemsPerPage: number) {\n this.updateOptions({ itemsPerPage })\n },\n 'internalOptions.itemsPerPage' (itemsPerPage: number) {\n this.$emit('update:items-per-page', itemsPerPage)\n },\n sortBy (sortBy: string | string[]) {\n this.updateOptions({ sortBy: wrapInArray(sortBy) })\n },\n 'internalOptions.sortBy' (sortBy: string[], old: string[]) {\n !deepEqual(sortBy, old) && this.$emit('update:sort-by', Array.isArray(this.sortBy) ? sortBy : sortBy[0])\n },\n sortDesc (sortDesc: boolean | boolean[]) {\n this.updateOptions({ sortDesc: wrapInArray(sortDesc) })\n },\n 'internalOptions.sortDesc' (sortDesc: boolean[], old: boolean[]) {\n !deepEqual(sortDesc, old) && this.$emit('update:sort-desc', Array.isArray(this.sortDesc) ? sortDesc : sortDesc[0])\n },\n groupBy (groupBy: string | string[]) {\n this.updateOptions({ groupBy: wrapInArray(groupBy) })\n },\n 'internalOptions.groupBy' (groupBy: string[], old: string[]) {\n !deepEqual(groupBy, old) && this.$emit('update:group-by', Array.isArray(this.groupBy) ? groupBy : groupBy[0])\n },\n groupDesc (groupDesc: boolean | boolean[]) {\n this.updateOptions({ groupDesc: wrapInArray(groupDesc) })\n },\n 'internalOptions.groupDesc' (groupDesc: boolean[], old: boolean[]) {\n !deepEqual(groupDesc, old) && this.$emit('update:group-desc', Array.isArray(this.groupDesc) ? groupDesc : groupDesc[0])\n },\n multiSort (multiSort: boolean) {\n this.updateOptions({ multiSort })\n },\n 'internalOptions.multiSort' (multiSort: boolean) {\n this.$emit('update:multi-sort', multiSort)\n },\n mustSort (mustSort: boolean) {\n this.updateOptions({ mustSort })\n },\n 'internalOptions.mustSort' (mustSort: boolean) {\n this.$emit('update:must-sort', mustSort)\n },\n pageCount: {\n handler (pageCount: number) {\n this.$emit('page-count', pageCount)\n },\n immediate: true,\n },\n computedItems: {\n handler (computedItems: any[]) {\n this.$emit('current-items', computedItems)\n },\n immediate: true,\n },\n pagination: {\n handler (pagination: DataPagination, old: DataPagination) {\n if (deepEqual(pagination, old)) return\n this.$emit('pagination', this.pagination)\n },\n immediate: true,\n },\n },\n\n methods: {\n toggle (key: string, oldBy: string[], oldDesc: boolean[], page: number, mustSort: boolean, multiSort: boolean) {\n let by = oldBy.slice()\n let desc = oldDesc.slice()\n const byIndex = by.findIndex((k: string) => k === key)\n\n if (byIndex < 0) {\n if (!multiSort) {\n by = []\n desc = []\n }\n\n by.push(key)\n desc.push(false)\n } else if (byIndex >= 0 && !desc[byIndex]) {\n desc[byIndex] = true\n } else if (!mustSort) {\n by.splice(byIndex, 1)\n desc.splice(byIndex, 1)\n } else {\n desc[byIndex] = false\n }\n\n // Reset page to 1 if sortBy or sortDesc have changed\n if (!deepEqual(by, oldBy) || !deepEqual(desc, oldDesc)) {\n page = 1\n }\n\n return { by, desc, page }\n },\n group (key: string): void {\n const { by: groupBy, desc: groupDesc, page } = this.toggle(\n key,\n this.internalOptions.groupBy,\n this.internalOptions.groupDesc,\n this.internalOptions.page,\n true,\n false\n )\n this.updateOptions({ groupBy, groupDesc, page })\n },\n sort (key: string | string[]): void {\n if (Array.isArray(key)) return this.sortArray(key)\n\n const { by: sortBy, desc: sortDesc, page } = this.toggle(\n key,\n this.internalOptions.sortBy,\n this.internalOptions.sortDesc,\n this.internalOptions.page,\n this.internalOptions.mustSort,\n this.internalOptions.multiSort\n )\n this.updateOptions({ sortBy, sortDesc, page })\n },\n sortArray (sortBy: string[]) {\n const sortDesc = sortBy.map(s => {\n const i = this.internalOptions.sortBy.findIndex((k: string) => k === s)\n return i > -1 ? this.internalOptions.sortDesc[i] : false\n })\n\n this.updateOptions({ sortBy, sortDesc })\n },\n updateOptions (options: any) {\n this.internalOptions = {\n ...this.internalOptions,\n ...options,\n page: this.serverItemsLength < 0\n ? Math.max(1, Math.min(options.page || this.internalOptions.page, this.pageCount))\n : options.page || this.internalOptions.page,\n }\n },\n sortItems (items: any[]): any[] {\n let sortBy: string[] = []\n let sortDesc: boolean[] = []\n\n if (!this.disableSort) {\n sortBy = this.internalOptions.sortBy\n sortDesc = this.internalOptions.sortDesc\n }\n\n if (this.internalOptions.groupBy.length) {\n sortBy = [...this.internalOptions.groupBy, ...sortBy]\n sortDesc = [...this.internalOptions.groupDesc, ...sortDesc]\n }\n\n return this.customSort(items, sortBy, sortDesc, this.locale)\n },\n groupItems (items: any[]): ItemGroup[] {\n return this.customGroup(items, this.internalOptions.groupBy, this.internalOptions.groupDesc)\n },\n paginateItems (items: any[]): any[] {\n // Make sure we don't try to display non-existant page if items suddenly change\n // TODO: Could possibly move this to pageStart/pageStop?\n if (this.serverItemsLength === -1 && items.length <= this.pageStart) {\n this.internalOptions.page = Math.max(1, Math.ceil(items.length / this.internalOptions.itemsPerPage)) || 1 // Prevent NaN\n }\n\n return items.slice(this.pageStart, this.pageStop)\n },\n },\n\n render (): VNode {\n return this.$scopedSlots.default && this.$scopedSlots.default(this.scopedProps) as any\n },\n})\n","import './VDataFooter.sass'\n\n// Components\nimport VSelect from '../VSelect/VSelect'\nimport VIcon from '../VIcon'\nimport VBtn from '../VBtn'\n\n// Types\nimport Vue, { VNode, VNodeChildrenArrayContents, PropType } from 'vue'\nimport { DataPagination, DataOptions, DataItemsPerPageOption } from 'vuetify/types'\nimport { PropValidator } from 'vue/types/options'\nimport { getSlot } from '../../util/helpers'\n\nexport default Vue.extend({\n name: 'v-data-footer',\n\n props: {\n options: {\n type: Object as PropType,\n required: true,\n },\n pagination: {\n type: Object as PropType,\n required: true,\n },\n itemsPerPageOptions: {\n type: Array,\n default: () => ([5, 10, 15, -1]),\n } as PropValidator,\n prevIcon: {\n type: String,\n default: '$prev',\n },\n nextIcon: {\n type: String,\n default: '$next',\n },\n firstIcon: {\n type: String,\n default: '$first',\n },\n lastIcon: {\n type: String,\n default: '$last',\n },\n itemsPerPageText: {\n type: String,\n default: '$vuetify.dataFooter.itemsPerPageText',\n },\n itemsPerPageAllText: {\n type: String,\n default: '$vuetify.dataFooter.itemsPerPageAll',\n },\n showFirstLastPage: Boolean,\n showCurrentPage: Boolean,\n disablePagination: Boolean,\n disableItemsPerPage: Boolean,\n pageText: {\n type: String,\n default: '$vuetify.dataFooter.pageText',\n },\n },\n\n computed: {\n disableNextPageIcon (): boolean {\n return this.options.itemsPerPage <= 0 ||\n this.options.page * this.options.itemsPerPage >= this.pagination.itemsLength ||\n this.pagination.pageStop < 0\n },\n computedDataItemsPerPageOptions (): any[] {\n return this.itemsPerPageOptions.map(option => {\n if (typeof option === 'object') return option\n else return this.genDataItemsPerPageOption(option)\n })\n },\n },\n\n methods: {\n updateOptions (obj: object) {\n this.$emit('update:options', Object.assign({}, this.options, obj))\n },\n onFirstPage () {\n this.updateOptions({ page: 1 })\n },\n onPreviousPage () {\n this.updateOptions({ page: this.options.page - 1 })\n },\n onNextPage () {\n this.updateOptions({ page: this.options.page + 1 })\n },\n onLastPage () {\n this.updateOptions({ page: this.pagination.pageCount })\n },\n onChangeItemsPerPage (itemsPerPage: number) {\n this.updateOptions({ itemsPerPage, page: 1 })\n },\n genDataItemsPerPageOption (option: number) {\n return {\n text: option === -1 ? this.$vuetify.lang.t(this.itemsPerPageAllText) : String(option),\n value: option,\n }\n },\n genItemsPerPageSelect () {\n let value = this.options.itemsPerPage\n const computedIPPO = this.computedDataItemsPerPageOptions\n\n if (computedIPPO.length <= 1) return null\n\n if (!computedIPPO.find(ippo => ippo.value === value)) value = computedIPPO[0]\n\n return this.$createElement('div', {\n staticClass: 'v-data-footer__select',\n }, [\n this.$vuetify.lang.t(this.itemsPerPageText),\n this.$createElement(VSelect, {\n attrs: {\n 'aria-label': this.$vuetify.lang.t(this.itemsPerPageText),\n },\n props: {\n disabled: this.disableItemsPerPage,\n items: computedIPPO,\n value,\n hideDetails: true,\n auto: true,\n minWidth: '75px',\n },\n on: {\n input: this.onChangeItemsPerPage,\n },\n }),\n ])\n },\n genPaginationInfo () {\n let children: VNodeChildrenArrayContents = ['–']\n const itemsLength: number = this.pagination.itemsLength\n let pageStart: number = this.pagination.pageStart\n let pageStop: number = this.pagination.pageStop\n\n if (this.pagination.itemsLength && this.pagination.itemsPerPage) {\n pageStart = this.pagination.pageStart + 1\n pageStop = itemsLength < this.pagination.pageStop || this.pagination.pageStop < 0\n ? itemsLength\n : this.pagination.pageStop\n\n children = this.$scopedSlots['page-text']\n ? [this.$scopedSlots['page-text']!({ pageStart, pageStop, itemsLength })]\n : [this.$vuetify.lang.t(this.pageText, pageStart, pageStop, itemsLength)]\n } else if (this.$scopedSlots['page-text']) {\n children = [this.$scopedSlots['page-text']!({ pageStart, pageStop, itemsLength })]\n }\n\n return this.$createElement('div', {\n class: 'v-data-footer__pagination',\n }, children)\n },\n genIcon (click: Function, disabled: boolean, label: string, icon: string): VNode {\n return this.$createElement(VBtn, {\n props: {\n disabled: disabled || this.disablePagination,\n icon: true,\n text: true,\n // dark: this.dark, // TODO: add mixin\n // light: this.light // TODO: add mixin\n },\n on: {\n click,\n },\n attrs: {\n 'aria-label': label, // TODO: Localization\n },\n }, [this.$createElement(VIcon, icon)])\n },\n genIcons () {\n const before: VNodeChildrenArrayContents = []\n const after: VNodeChildrenArrayContents = []\n\n before.push(this.genIcon(\n this.onPreviousPage,\n this.options.page === 1,\n this.$vuetify.lang.t('$vuetify.dataFooter.prevPage'),\n this.$vuetify.rtl ? this.nextIcon : this.prevIcon\n ))\n\n after.push(this.genIcon(\n this.onNextPage,\n this.disableNextPageIcon,\n this.$vuetify.lang.t('$vuetify.dataFooter.nextPage'),\n this.$vuetify.rtl ? this.prevIcon : this.nextIcon\n ))\n\n if (this.showFirstLastPage) {\n before.unshift(this.genIcon(\n this.onFirstPage,\n this.options.page === 1,\n this.$vuetify.lang.t('$vuetify.dataFooter.firstPage'),\n this.$vuetify.rtl ? this.lastIcon : this.firstIcon\n ))\n\n after.push(this.genIcon(\n this.onLastPage,\n this.options.page >= this.pagination.pageCount || this.options.itemsPerPage === -1,\n this.$vuetify.lang.t('$vuetify.dataFooter.lastPage'),\n this.$vuetify.rtl ? this.firstIcon : this.lastIcon\n ))\n }\n\n return [\n this.$createElement('div', {\n staticClass: 'v-data-footer__icons-before',\n }, before),\n this.showCurrentPage && this.$createElement('span', [this.options.page.toString()]),\n this.$createElement('div', {\n staticClass: 'v-data-footer__icons-after',\n }, after),\n ]\n },\n },\n\n render (): VNode {\n return this.$createElement('div', {\n staticClass: 'v-data-footer',\n }, [\n getSlot(this, 'prepend'),\n this.genItemsPerPageSelect(),\n this.genPaginationInfo(),\n this.genIcons(),\n ])\n },\n})\n","// Components\nimport { VData } from '../VData'\nimport VDataFooter from './VDataFooter'\n\n// Mixins\nimport Mobile from '../../mixins/mobile'\nimport Themeable from '../../mixins/themeable'\n\n// Helpers\nimport mixins from '../../util/mixins'\nimport { deepEqual, getObjectValueByPath, getPrefixedScopedSlots, getSlot, camelizeObjectKeys, keyCodes } from '../../util/helpers'\nimport { breaking, removed } from '../../util/console'\n\n// Types\nimport { VNode, VNodeChildren } from 'vue'\nimport { PropValidator } from 'vue/types/options'\nimport { DataItemProps, DataScopeProps } from 'vuetify/types'\n\n/* @vue/component */\nexport default mixins(\n Mobile,\n Themeable\n).extend({\n name: 'v-data-iterator',\n\n props: {\n ...VData.options.props, // TODO: filter out props not used\n itemKey: {\n type: String,\n default: 'id',\n },\n value: {\n type: Array,\n default: () => [],\n } as PropValidator,\n singleSelect: Boolean,\n expanded: {\n type: Array,\n default: () => [],\n } as PropValidator,\n mobileBreakpoint: {\n ...Mobile.options.props.mobileBreakpoint,\n default: 600,\n },\n singleExpand: Boolean,\n loading: [Boolean, String],\n noResultsText: {\n type: String,\n default: '$vuetify.dataIterator.noResultsText',\n },\n noDataText: {\n type: String,\n default: '$vuetify.noDataText',\n },\n loadingText: {\n type: String,\n default: '$vuetify.dataIterator.loadingText',\n },\n hideDefaultFooter: Boolean,\n footerProps: Object,\n selectableKey: {\n type: String,\n default: 'isSelectable',\n },\n },\n\n data: () => ({\n selection: {} as Record,\n expansion: {} as Record,\n internalCurrentItems: [] as any[],\n shiftKeyDown: false,\n lastEntry: -1,\n }),\n\n computed: {\n everyItem (): boolean {\n return !!this.selectableItems.length && this.selectableItems.every((i: any) => this.isSelected(i))\n },\n someItems (): boolean {\n return this.selectableItems.some((i: any) => this.isSelected(i))\n },\n sanitizedFooterProps (): Record {\n return camelizeObjectKeys(this.footerProps)\n },\n selectableItems (): any[] {\n return this.internalCurrentItems.filter(item => this.isSelectable(item))\n },\n },\n\n watch: {\n value: {\n handler (value: any[]) {\n this.selection = value.reduce((selection, item) => {\n selection[getObjectValueByPath(item, this.itemKey)] = item\n return selection\n }, {})\n },\n immediate: true,\n },\n selection (value: Record, old: Record) {\n if (deepEqual(Object.keys(value), Object.keys(old))) return\n\n this.$emit('input', Object.values(value))\n },\n expanded: {\n handler (value: any[]) {\n this.expansion = value.reduce((expansion, item) => {\n expansion[getObjectValueByPath(item, this.itemKey)] = true\n return expansion\n }, {})\n },\n immediate: true,\n },\n expansion (value: Record, old: Record) {\n if (deepEqual(value, old)) return\n const keys = Object.keys(value).filter(k => value[k])\n const expanded = !keys.length ? [] : this.items.filter(i => keys.includes(String(getObjectValueByPath(i, this.itemKey))))\n this.$emit('update:expanded', expanded)\n },\n },\n\n created () {\n const breakingProps = [\n ['disable-initial-sort', 'sort-by'],\n ['filter', 'custom-filter'],\n ['pagination', 'options'],\n ['total-items', 'server-items-length'],\n ['hide-actions', 'hide-default-footer'],\n ['rows-per-page-items', 'footer-props.items-per-page-options'],\n ['rows-per-page-text', 'footer-props.items-per-page-text'],\n ['prev-icon', 'footer-props.prev-icon'],\n ['next-icon', 'footer-props.next-icon'],\n ]\n\n /* istanbul ignore next */\n breakingProps.forEach(([original, replacement]) => {\n if (this.$attrs.hasOwnProperty(original)) breaking(original, replacement, this)\n })\n\n const removedProps = [\n 'expand',\n 'content-class',\n 'content-props',\n 'content-tag',\n ]\n\n /* istanbul ignore next */\n removedProps.forEach(prop => {\n if (this.$attrs.hasOwnProperty(prop)) removed(prop)\n })\n },\n\n mounted () {\n window.addEventListener('keydown', this.onKeyDown)\n window.addEventListener('keyup', this.onKeyUp)\n },\n beforeDestroy () {\n window.removeEventListener('keydown', this.onKeyDown)\n window.removeEventListener('keyup', this.onKeyUp)\n },\n\n methods: {\n onKeyDown (e: KeyboardEvent): void {\n if (e.keyCode !== keyCodes.shift) return\n this.shiftKeyDown = true\n },\n onKeyUp (e: KeyboardEvent): void {\n if (e.keyCode !== keyCodes.shift) return\n this.shiftKeyDown = false\n },\n toggleSelectAll (value: boolean): void {\n const selection = Object.assign({}, this.selection)\n\n for (let i = 0; i < this.selectableItems.length; i++) {\n const item = this.selectableItems[i]\n\n if (!this.isSelectable(item)) continue\n\n const key = getObjectValueByPath(item, this.itemKey)\n if (value) selection[key] = item\n else delete selection[key]\n }\n\n this.selection = selection\n this.$emit('toggle-select-all', { items: this.internalCurrentItems, value })\n },\n isSelectable (item: any): boolean {\n return getObjectValueByPath(item, this.selectableKey) !== false\n },\n isSelected (item: any): boolean {\n return !!this.selection[getObjectValueByPath(item, this.itemKey)] || false\n },\n select (item: any, value = true, emit = true): void {\n if (!this.isSelectable(item)) return\n\n const selection = this.singleSelect ? {} : Object.assign({}, this.selection)\n const key = getObjectValueByPath(item, this.itemKey)\n\n if (value) selection[key] = item\n else delete selection[key]\n\n const index = this.selectableItems.findIndex(x => getObjectValueByPath(x, this.itemKey) === key)\n if (this.lastEntry === -1) this.lastEntry = index\n else if (this.shiftKeyDown && !this.singleSelect && emit) this.multipleSelect(value, emit, selection, index)\n this.lastEntry = index\n\n if (this.singleSelect && emit) {\n const keys = Object.keys(this.selection)\n const old = keys.length && getObjectValueByPath(this.selection[keys[0]], this.itemKey)\n old && old !== key && this.$emit('item-selected', { item: this.selection[old], value: false })\n }\n this.selection = selection\n emit && this.$emit('item-selected', { item, value })\n },\n multipleSelect (value = true, emit = true, selection: any, index: number): void {\n const start = index < this.lastEntry ? index : this.lastEntry\n const end = index < this.lastEntry ? this.lastEntry : index\n for (let i = start; i <= end; i++) {\n const currentItem = this.selectableItems[i]\n const key = getObjectValueByPath(currentItem, this.itemKey)\n if (value) selection[key] = currentItem\n else delete selection[key]\n emit && this.$emit('item-selected', { currentItem, value })\n }\n },\n isExpanded (item: any): boolean {\n return this.expansion[getObjectValueByPath(item, this.itemKey)] || false\n },\n expand (item: any, value = true): void {\n const expansion = this.singleExpand ? {} : Object.assign({}, this.expansion)\n const key = getObjectValueByPath(item, this.itemKey)\n\n if (value) expansion[key] = true\n else delete expansion[key]\n\n this.expansion = expansion\n this.$emit('item-expanded', { item, value })\n },\n createItemProps (item: any, index: number): DataItemProps {\n return {\n item,\n index,\n select: (v: boolean) => this.select(item, v),\n isSelected: this.isSelected(item),\n expand: (v: boolean) => this.expand(item, v),\n isExpanded: this.isExpanded(item),\n isMobile: this.isMobile,\n }\n },\n genEmptyWrapper (content: VNodeChildren) {\n return this.$createElement('div', content)\n },\n genEmpty (originalItemsLength: number, filteredItemsLength: number) {\n if (originalItemsLength === 0 && this.loading) {\n const loading = this.$slots.loading || this.$vuetify.lang.t(this.loadingText)\n return this.genEmptyWrapper(loading)\n } else if (originalItemsLength === 0) {\n const noData = this.$slots['no-data'] || this.$vuetify.lang.t(this.noDataText)\n return this.genEmptyWrapper(noData)\n } else if (filteredItemsLength === 0) {\n const noResults = this.$slots['no-results'] || this.$vuetify.lang.t(this.noResultsText)\n return this.genEmptyWrapper(noResults)\n }\n\n return null\n },\n genItems (props: DataScopeProps) {\n const empty = this.genEmpty(props.originalItemsLength, props.pagination.itemsLength)\n if (empty) return [empty]\n\n if (this.$scopedSlots.default) {\n return this.$scopedSlots.default({\n ...props,\n isSelected: this.isSelected,\n select: this.select,\n isExpanded: this.isExpanded,\n isMobile: this.isMobile,\n expand: this.expand,\n })\n }\n\n if (this.$scopedSlots.item) {\n return props.items.map((item: any, index) => this.$scopedSlots.item!(this.createItemProps(\n item,\n index\n )))\n }\n\n return []\n },\n genFooter (props: DataScopeProps) {\n if (this.hideDefaultFooter) return null\n\n const data = {\n props: {\n ...this.sanitizedFooterProps,\n options: props.options,\n pagination: props.pagination,\n },\n on: {\n 'update:options': (value: any) => props.updateOptions(value),\n },\n }\n\n const scopedSlots = getPrefixedScopedSlots('footer.', this.$scopedSlots)\n\n return this.$createElement(VDataFooter, {\n scopedSlots,\n ...data,\n })\n },\n genDefaultScopedSlot (props: any) {\n const outerProps = {\n ...props,\n someItems: this.someItems,\n everyItem: this.everyItem,\n toggleSelectAll: this.toggleSelectAll,\n }\n\n return this.$createElement('div', {\n staticClass: 'v-data-iterator',\n }, [\n getSlot(this, 'header', outerProps, true),\n this.genItems(props),\n this.genFooter(props),\n getSlot(this, 'footer', outerProps, true),\n ])\n },\n },\n\n render (): VNode {\n return this.$createElement(VData, {\n props: this.$props,\n on: {\n 'update:options': (v: any, old: any) => !deepEqual(v, old) && this.$emit('update:options', v),\n 'update:page': (v: any) => this.$emit('update:page', v),\n 'update:items-per-page': (v: any) => this.$emit('update:items-per-page', v),\n 'update:sort-by': (v: any) => this.$emit('update:sort-by', v),\n 'update:sort-desc': (v: any) => this.$emit('update:sort-desc', v),\n 'update:group-by': (v: any) => this.$emit('update:group-by', v),\n 'update:group-desc': (v: any) => this.$emit('update:group-desc', v),\n pagination: (v: any, old: any) => !deepEqual(v, old) && this.$emit('pagination', v),\n 'current-items': (v: any[]) => {\n this.internalCurrentItems = v\n this.$emit('current-items', v)\n },\n 'page-count': (v: number) => this.$emit('page-count', v),\n },\n scopedSlots: {\n default: this.genDefaultScopedSlot,\n },\n })\n },\n})\n","import { VDataTable } from '../'\nimport VIcon from '../../VIcon'\nimport VSimpleCheckbox from '../../VCheckbox/VSimpleCheckbox'\nimport ripple from '../../../directives/ripple'\n\nimport Vue from 'vue'\nimport { PropValidator } from 'vue/types/options'\nimport mixins from '../../../util/mixins'\nimport { DataOptions, DataTableHeader } from 'vuetify/types'\n\ntype VDataTableInstance = InstanceType\n\ninterface options extends Vue {\n dataTable: VDataTableInstance\n}\n\nexport default mixins().extend({\n // https://github.com/vuejs/vue/issues/6872\n directives: {\n ripple,\n },\n\n props: {\n headers: {\n type: Array,\n default: () => ([]),\n } as PropValidator,\n options: {\n type: Object,\n default: () => ({\n page: 1,\n itemsPerPage: 10,\n sortBy: [],\n sortDesc: [],\n groupBy: [],\n groupDesc: [],\n multiSort: false,\n mustSort: false,\n }),\n } as PropValidator,\n checkboxColor: String,\n sortIcon: {\n type: String,\n default: '$sort',\n },\n everyItem: Boolean,\n someItems: Boolean,\n showGroupBy: Boolean,\n singleSelect: Boolean,\n disableSort: Boolean,\n },\n\n methods: {\n genSelectAll () {\n const data = {\n props: {\n value: this.everyItem,\n indeterminate: !this.everyItem && this.someItems,\n color: this.checkboxColor ?? '',\n },\n on: {\n input: (v: boolean) => this.$emit('toggle-select-all', v),\n },\n }\n\n if (this.$scopedSlots['data-table-select']) {\n return this.$scopedSlots['data-table-select']!(data)\n }\n\n return this.$createElement(VSimpleCheckbox, {\n staticClass: 'v-data-table__checkbox',\n ...data,\n })\n },\n genSortIcon () {\n return this.$createElement(VIcon, {\n staticClass: 'v-data-table-header__icon',\n props: {\n size: 18,\n },\n }, [this.sortIcon])\n },\n },\n})\n","import { VNode, VNodeChildrenArrayContents } from 'vue'\nimport mixins from '../../util/mixins'\nimport VSelect from '../VSelect/VSelect'\nimport VChip from '../VChip'\nimport header from './mixins/header'\nimport { wrapInArray } from '../../util/helpers'\n\nexport default mixins(header).extend({\n name: 'v-data-table-header-mobile',\n\n props: {\n sortByText: {\n type: String,\n default: '$vuetify.dataTable.sortBy',\n },\n },\n\n methods: {\n genSortChip (props: any) {\n const children: VNodeChildrenArrayContents = [props.item.text]\n\n const sortIndex = this.options.sortBy.findIndex(k => k === props.item.value)\n const beingSorted = sortIndex >= 0\n const isDesc = this.options.sortDesc[sortIndex]\n\n children.push(this.$createElement('div', {\n staticClass: 'v-chip__close',\n class: {\n sortable: true,\n active: beingSorted,\n asc: beingSorted && !isDesc,\n desc: beingSorted && isDesc,\n },\n }, [this.genSortIcon()]))\n\n return this.$createElement(VChip, {\n staticClass: 'sortable',\n on: {\n click: (e: MouseEvent) => {\n e.stopPropagation()\n this.$emit('sort', props.item.value)\n },\n },\n }, children)\n },\n genSortSelect (items: any[]) {\n return this.$createElement(VSelect, {\n props: {\n label: this.$vuetify.lang.t(this.sortByText),\n items,\n hideDetails: true,\n multiple: this.options.multiSort,\n value: this.options.multiSort ? this.options.sortBy : this.options.sortBy[0],\n menuProps: { closeOnContentClick: true },\n },\n on: {\n change: (v: string | string[]) => this.$emit('sort', v),\n },\n scopedSlots: {\n selection: props => this.genSortChip(props),\n },\n })\n },\n },\n\n render (h): VNode {\n const children: VNodeChildrenArrayContents = []\n\n const header = this.headers.find(h => h.value === 'data-table-select')\n if (header && !this.singleSelect) {\n children.push(this.$createElement('div', {\n class: [\n 'v-data-table-header-mobile__select',\n ...wrapInArray(header.class),\n ],\n attrs: {\n width: header.width,\n },\n }, [this.genSelectAll()]))\n }\n\n const sortHeaders = this.headers\n .filter(h => h.sortable !== false && h.value !== 'data-table-select')\n .map(h => ({\n text: h.text,\n value: h.value,\n }))\n\n if (!this.disableSort && sortHeaders.length) {\n children.push(this.genSortSelect(sortHeaders))\n }\n\n const th = h('th', [h('div', { staticClass: 'v-data-table-header-mobile__wrapper' }, children)])\n\n const tr = h('tr', [th])\n\n return h('thead', {\n staticClass: 'v-data-table-header v-data-table-header-mobile',\n }, [tr])\n },\n})\n","// Helpers\nimport { VNode, VNodeData } from 'vue'\nimport mixins from '../../util/mixins'\nimport header from './mixins/header'\nimport { wrapInArray, convertToUnit } from '../../util/helpers'\nimport { DataTableHeader } from 'vuetify/types'\n\nexport default mixins(header).extend({\n name: 'v-data-table-header-desktop',\n\n methods: {\n genGroupByToggle (header: DataTableHeader) {\n return this.$createElement('span', {\n on: {\n click: (e: MouseEvent) => {\n e.stopPropagation()\n this.$emit('group', header.value)\n },\n },\n }, ['group'])\n },\n getAria (beingSorted: boolean, isDesc: boolean) {\n const $t = (key: string) => this.$vuetify.lang.t(`$vuetify.dataTable.ariaLabel.${key}`)\n\n let ariaSort = 'none'\n let ariaLabel = [\n $t('sortNone'),\n $t('activateAscending'),\n ]\n\n if (!beingSorted) {\n return { ariaSort, ariaLabel: ariaLabel.join(' ') }\n }\n\n if (isDesc) {\n ariaSort = 'descending'\n ariaLabel = [\n $t('sortDescending'),\n $t(this.options.mustSort ? 'activateAscending' : 'activateNone'),\n ]\n } else {\n ariaSort = 'ascending'\n ariaLabel = [\n $t('sortAscending'),\n $t('activateDescending'),\n ]\n }\n\n return { ariaSort, ariaLabel: ariaLabel.join(' ') }\n },\n genHeader (header: DataTableHeader) {\n const data: Required> = {\n attrs: {\n role: 'columnheader',\n scope: 'col',\n 'aria-label': header.text || '',\n },\n style: {\n width: convertToUnit(header.width),\n minWidth: convertToUnit(header.width),\n },\n class: [\n `text-${header.align || 'start'}`,\n ...wrapInArray(header.class),\n header.divider && 'v-data-table__divider',\n ],\n on: {},\n }\n const children = []\n\n if (header.value === 'data-table-select' && !this.singleSelect) {\n return this.$createElement('th', data, [this.genSelectAll()])\n }\n\n children.push(\n this.$scopedSlots[header.value]\n ? this.$scopedSlots[header.value]!({ header })\n : this.$createElement('span', [header.text])\n )\n\n if (!this.disableSort && (header.sortable || !header.hasOwnProperty('sortable'))) {\n data.on.click = () => this.$emit('sort', header.value)\n\n const sortIndex = this.options.sortBy.findIndex(k => k === header.value)\n const beingSorted = sortIndex >= 0\n const isDesc = this.options.sortDesc[sortIndex]\n\n data.class.push('sortable')\n\n const { ariaLabel, ariaSort } = this.getAria(beingSorted, isDesc)\n\n data.attrs['aria-label'] += `${header.text ? ': ' : ''}${ariaLabel}`\n data.attrs['aria-sort'] = ariaSort\n\n if (beingSorted) {\n data.class.push('active')\n data.class.push(isDesc ? 'desc' : 'asc')\n }\n\n if (header.align === 'end') children.unshift(this.genSortIcon())\n else children.push(this.genSortIcon())\n\n if (this.options.multiSort && beingSorted) {\n children.push(this.$createElement('span', { class: 'v-data-table-header__sort-badge' }, [String(sortIndex + 1)]))\n }\n }\n\n if (this.showGroupBy && header.groupable !== false) children.push(this.genGroupByToggle(header))\n\n return this.$createElement('th', data, children)\n },\n },\n\n render (): VNode {\n return this.$createElement('thead', {\n staticClass: 'v-data-table-header',\n }, [\n this.$createElement('tr', this.headers.map(header => this.genHeader(header))),\n ])\n },\n})\n","import { VNodeData } from 'vue'\n\n/**\n * Removes duplicate `@input` listeners when\n * using v-model with functional components\n *\n * @see https://github.com/vuetifyjs/vuetify/issues/4460\n */\nexport default function dedupeModelListeners (data: VNodeData): void {\n if (data.model && data.on && data.on.input) {\n if (Array.isArray(data.on.input)) {\n const i = data.on.input.indexOf(data.model.callback)\n if (i > -1) data.on.input.splice(i, 1)\n } else {\n delete data.on.input\n }\n }\n}\n","import { CreateElement, VNode } from 'vue'\n\nexport default function rebuildFunctionalSlots (slots: { [key: string]: VNode[] | undefined }, h: CreateElement) {\n const children: VNode[] = []\n\n for (const slot in slots) {\n if (slots.hasOwnProperty(slot)) {\n children.push(h('template', { slot }, slots[slot]))\n }\n }\n\n return children\n}\n","// Styles\nimport './VDataTableHeader.sass'\n\n// Components\nimport VDataTableHeaderMobile from './VDataTableHeaderMobile'\nimport VDataTableHeaderDesktop from './VDataTableHeaderDesktop'\n\n// Mixins\nimport header from './mixins/header'\n\n// Utilities\nimport dedupeModelListeners from '../../util/dedupeModelListeners'\nimport mergeData from '../../util/mergeData'\nimport rebuildSlots from '../../util/rebuildFunctionalSlots'\n\n// Types\nimport Vue from 'vue'\n\n/* @vue/component */\nexport default Vue.extend({\n name: 'v-data-table-header',\n\n functional: true,\n\n props: {\n ...header.options.props,\n mobile: Boolean,\n },\n\n render (h, { props, data, slots }) {\n dedupeModelListeners(data)\n const children = rebuildSlots(slots(), h)\n\n data = mergeData(data, { props })\n\n if (props.mobile) {\n return h(VDataTableHeaderMobile, data, children)\n } else {\n return h(VDataTableHeaderDesktop, data, children)\n }\n },\n})\n","// Types\nimport Vue, { VNode, PropType } from 'vue'\nimport { DataTableHeader } from 'vuetify/types'\n\n// Utils\nimport { getObjectValueByPath } from '../../util/helpers'\n\nexport default Vue.extend({\n name: 'row',\n\n functional: true,\n\n props: {\n headers: Array as PropType,\n index: Number,\n item: Object,\n rtl: Boolean,\n },\n\n render (h, { props, slots, data }): VNode {\n const computedSlots = slots()\n\n const columns: VNode[] = props.headers.map((header: DataTableHeader) => {\n const children = []\n const value = getObjectValueByPath(props.item, header.value)\n\n const slotName = header.value\n const scopedSlot = data.scopedSlots && data.scopedSlots[slotName]\n const regularSlot = computedSlots[slotName]\n\n if (scopedSlot) {\n children.push(scopedSlot({\n item: props.item,\n isMobile: false,\n header,\n index: props.index,\n value,\n }))\n } else if (regularSlot) {\n children.push(regularSlot)\n } else {\n children.push(value == null ? value : String(value))\n }\n\n const textAlign = `text-${header.align || 'start'}`\n\n return h('td', {\n class: [\n textAlign,\n header.cellClass,\n {\n 'v-data-table__divider': header.divider,\n },\n ],\n }, children)\n })\n\n return h('tr', data, columns)\n },\n})\n","import Vue, { VNode } from 'vue'\n\nexport default Vue.extend({\n name: 'row-group',\n\n functional: true,\n\n props: {\n value: {\n type: Boolean,\n default: true,\n },\n headerClass: {\n type: String,\n default: 'v-row-group__header',\n },\n contentClass: String,\n summaryClass: {\n type: String,\n default: 'v-row-group__summary',\n },\n },\n\n render (h, { slots, props }): VNode {\n const computedSlots = slots()\n const children = []\n\n if (computedSlots['column.header']) {\n children.push(h('tr', {\n staticClass: props.headerClass,\n }, computedSlots['column.header']))\n } else if (computedSlots['row.header']) {\n children.push(...computedSlots['row.header'])\n }\n\n if (computedSlots['row.content'] && props.value) children.push(...computedSlots['row.content'])\n\n if (computedSlots['column.summary']) {\n children.push(h('tr', {\n staticClass: props.summaryClass,\n }, computedSlots['column.summary']))\n } else if (computedSlots['row.summary']) {\n children.push(...computedSlots['row.summary'])\n }\n\n return children as any\n },\n})\n","import Vue, { VNode, PropType } from 'vue'\nimport { getObjectValueByPath } from '../../util/helpers'\nimport { DataTableHeader } from 'vuetify/types'\n\nexport default Vue.extend({\n name: 'row',\n\n functional: true,\n\n props: {\n headers: Array as PropType,\n hideDefaultHeader: Boolean,\n index: Number,\n item: Object,\n rtl: Boolean,\n },\n\n render (h, { props, slots, data }): VNode {\n const computedSlots = slots()\n\n const columns: VNode[] = props.headers.map((header: DataTableHeader) => {\n const classes = {\n 'v-data-table__mobile-row': true,\n }\n\n const children = []\n const value = getObjectValueByPath(props.item, header.value)\n\n const slotName = header.value\n const scopedSlot = data.scopedSlots && data.scopedSlots[slotName]\n const regularSlot = computedSlots[slotName]\n\n if (scopedSlot) {\n children.push(scopedSlot({\n item: props.item,\n isMobile: true,\n header,\n index: props.index,\n value,\n }))\n } else if (regularSlot) {\n children.push(regularSlot)\n } else {\n children.push(value == null ? value : String(value))\n }\n\n const mobileRowChildren = [\n h('div', {\n staticClass: 'v-data-table__mobile-row__cell',\n }, children),\n ]\n\n if (header.value !== 'dataTableSelect' && !props.hideDefaultHeader) {\n mobileRowChildren.unshift(\n h('div', {\n staticClass: 'v-data-table__mobile-row__header',\n }, [header.text])\n )\n }\n\n return h('td', { class: classes }, mobileRowChildren)\n })\n\n return h('tr', { ...data, staticClass: 'v-data-table__mobile-table-row' }, columns)\n },\n})\n","import './VDataTable.sass'\n\n// Types\nimport { VNode, VNodeChildrenArrayContents, VNodeChildren } from 'vue'\nimport { PropValidator } from 'vue/types/options'\nimport {\n DataTableHeader,\n DataTableFilterFunction,\n DataScopeProps,\n DataOptions,\n DataPagination,\n DataTableCompareFunction,\n DataItemsPerPageOption,\n ItemGroup,\n RowClassFunction,\n DataTableItemProps,\n} from 'vuetify/types'\n\n// Components\nimport { VData } from '../VData'\nimport { VDataFooter, VDataIterator } from '../VDataIterator'\nimport VBtn from '../VBtn'\nimport VDataTableHeader from './VDataTableHeader'\n// import VVirtualTable from './VVirtualTable'\nimport VIcon from '../VIcon'\nimport Row from './Row'\nimport RowGroup from './RowGroup'\nimport VSimpleCheckbox from '../VCheckbox/VSimpleCheckbox'\nimport VSimpleTable from './VSimpleTable'\nimport MobileRow from './MobileRow'\n\n// Mixins\nimport Loadable from '../../mixins/loadable'\n\n// Directives\nimport ripple from '../../directives/ripple'\n\n// Helpers\nimport mixins from '../../util/mixins'\nimport { deepEqual, getObjectValueByPath, getPrefixedScopedSlots, getSlot, defaultFilter, camelizeObjectKeys, getPropertyFromItem } from '../../util/helpers'\nimport { breaking } from '../../util/console'\nimport { mergeClasses } from '../../util/mergeData'\n\nfunction filterFn (item: any, search: string | null, filter: DataTableFilterFunction) {\n return (header: DataTableHeader) => {\n const value = getObjectValueByPath(item, header.value)\n return header.filter ? header.filter(value, search, item) : filter(value, search, item)\n }\n}\n\nfunction searchTableItems (\n items: any[],\n search: string | null,\n headersWithCustomFilters: DataTableHeader[],\n headersWithoutCustomFilters: DataTableHeader[],\n customFilter: DataTableFilterFunction\n) {\n search = typeof search === 'string' ? search.trim() : null\n\n return items.filter(item => {\n // Headers with custom filters are evaluated whether or not a search term has been provided.\n // We need to match every filter to be included in the results.\n const matchesColumnFilters = headersWithCustomFilters.every(filterFn(item, search, defaultFilter))\n\n // Headers without custom filters are only filtered by the `search` property if it is defined.\n // We only need a single column to match the search term to be included in the results.\n const matchesSearchTerm = !search || headersWithoutCustomFilters.some(filterFn(item, search, customFilter))\n\n return matchesColumnFilters && matchesSearchTerm\n })\n}\n\n/* @vue/component */\nexport default mixins(\n VDataIterator,\n Loadable,\n).extend({\n name: 'v-data-table',\n\n // https://github.com/vuejs/vue/issues/6872\n directives: {\n ripple,\n },\n\n props: {\n headers: {\n type: Array,\n default: () => [],\n } as PropValidator,\n showSelect: Boolean,\n checkboxColor: String,\n showExpand: Boolean,\n showGroupBy: Boolean,\n // TODO: Fix\n // virtualRows: Boolean,\n height: [Number, String],\n hideDefaultHeader: Boolean,\n caption: String,\n dense: Boolean,\n headerProps: Object,\n calculateWidths: Boolean,\n fixedHeader: Boolean,\n headersLength: Number,\n expandIcon: {\n type: String,\n default: '$expand',\n },\n customFilter: {\n type: Function,\n default: defaultFilter,\n } as PropValidator,\n itemClass: {\n type: [String, Function],\n default: () => '',\n } as PropValidator,\n loaderHeight: {\n type: [Number, String],\n default: 4,\n },\n },\n\n data () {\n return {\n internalGroupBy: [] as string[],\n openCache: {} as { [key: string]: boolean },\n widths: [] as number[],\n }\n },\n\n computed: {\n computedHeaders (): DataTableHeader[] {\n if (!this.headers) return []\n const headers = this.headers.filter(h => h.value === undefined || !this.internalGroupBy.find(v => v === h.value))\n const defaultHeader = { text: '', sortable: false, width: '1px' }\n\n if (this.showSelect) {\n const index = headers.findIndex(h => h.value === 'data-table-select')\n if (index < 0) headers.unshift({ ...defaultHeader, value: 'data-table-select' })\n else headers.splice(index, 1, { ...defaultHeader, ...headers[index] })\n }\n\n if (this.showExpand) {\n const index = headers.findIndex(h => h.value === 'data-table-expand')\n if (index < 0) headers.unshift({ ...defaultHeader, value: 'data-table-expand' })\n else headers.splice(index, 1, { ...defaultHeader, ...headers[index] })\n }\n\n return headers\n },\n colspanAttrs (): object | undefined {\n return this.isMobile ? undefined : {\n colspan: this.headersLength || this.computedHeaders.length,\n }\n },\n columnSorters (): Record {\n return this.computedHeaders.reduce>((acc, header) => {\n if (header.sort) acc[header.value] = header.sort\n return acc\n }, {})\n },\n headersWithCustomFilters (): DataTableHeader[] {\n return this.headers.filter(header => header.filter && (!header.hasOwnProperty('filterable') || header.filterable === true))\n },\n headersWithoutCustomFilters (): DataTableHeader[] {\n return this.headers.filter(header => !header.filter && (!header.hasOwnProperty('filterable') || header.filterable === true))\n },\n sanitizedHeaderProps (): Record {\n return camelizeObjectKeys(this.headerProps)\n },\n computedItemsPerPage (): number {\n const itemsPerPage = this.options && this.options.itemsPerPage ? this.options.itemsPerPage : this.itemsPerPage\n const itemsPerPageOptions: DataItemsPerPageOption[] | undefined = this.sanitizedFooterProps.itemsPerPageOptions\n\n if (\n itemsPerPageOptions &&\n !itemsPerPageOptions.find(item => typeof item === 'number' ? item === itemsPerPage : item.value === itemsPerPage)\n ) {\n const firstOption = itemsPerPageOptions[0]\n return typeof firstOption === 'object' ? firstOption.value : firstOption\n }\n\n return itemsPerPage\n },\n },\n\n created () {\n const breakingProps = [\n ['sort-icon', 'header-props.sort-icon'],\n ['hide-headers', 'hide-default-header'],\n ['select-all', 'show-select'],\n ]\n\n /* istanbul ignore next */\n breakingProps.forEach(([original, replacement]) => {\n if (this.$attrs.hasOwnProperty(original)) breaking(original, replacement, this)\n })\n },\n\n mounted () {\n // if ((!this.sortBy || !this.sortBy.length) && (!this.options.sortBy || !this.options.sortBy.length)) {\n // const firstSortable = this.headers.find(h => !('sortable' in h) || !!h.sortable)\n // if (firstSortable) this.updateOptions({ sortBy: [firstSortable.value], sortDesc: [false] })\n // }\n\n if (this.calculateWidths) {\n window.addEventListener('resize', this.calcWidths)\n this.calcWidths()\n }\n },\n\n beforeDestroy () {\n if (this.calculateWidths) {\n window.removeEventListener('resize', this.calcWidths)\n }\n },\n\n methods: {\n calcWidths () {\n this.widths = Array.from(this.$el.querySelectorAll('th')).map(e => e.clientWidth)\n },\n customFilterWithColumns (items: any[], search: string) {\n return searchTableItems(items, search, this.headersWithCustomFilters, this.headersWithoutCustomFilters, this.customFilter)\n },\n customSortWithHeaders (items: any[], sortBy: string[], sortDesc: boolean[], locale: string) {\n return this.customSort(items, sortBy, sortDesc, locale, this.columnSorters)\n },\n createItemProps (item: any, index: number): DataTableItemProps {\n const props = VDataIterator.options.methods.createItemProps.call(this, item, index)\n\n return Object.assign(props, { headers: this.computedHeaders })\n },\n genCaption (props: DataScopeProps) {\n if (this.caption) return [this.$createElement('caption', [this.caption])]\n\n return getSlot(this, 'caption', props, true)\n },\n genColgroup (props: DataScopeProps) {\n return this.$createElement('colgroup', this.computedHeaders.map(header => {\n return this.$createElement('col', {\n class: {\n divider: header.divider,\n },\n })\n }))\n },\n genLoading () {\n const th = this.$createElement('th', {\n staticClass: 'column',\n attrs: this.colspanAttrs,\n }, [this.genProgress()])\n\n const tr = this.$createElement('tr', {\n staticClass: 'v-data-table__progress',\n }, [th])\n\n return this.$createElement('thead', [tr])\n },\n genHeaders (props: DataScopeProps) {\n const data = {\n props: {\n ...this.sanitizedHeaderProps,\n headers: this.computedHeaders,\n options: props.options,\n mobile: this.isMobile,\n showGroupBy: this.showGroupBy,\n checkboxColor: this.checkboxColor,\n someItems: this.someItems,\n everyItem: this.everyItem,\n singleSelect: this.singleSelect,\n disableSort: this.disableSort,\n },\n on: {\n sort: props.sort,\n group: props.group,\n 'toggle-select-all': this.toggleSelectAll,\n },\n }\n\n // TODO: rename to 'head'? (thead, tbody, tfoot)\n const children: VNodeChildrenArrayContents = [getSlot(this, 'header', {\n ...data,\n isMobile: this.isMobile,\n })]\n\n if (!this.hideDefaultHeader) {\n const scopedSlots = getPrefixedScopedSlots('header.', this.$scopedSlots)\n children.push(this.$createElement(VDataTableHeader, {\n ...data,\n scopedSlots,\n }))\n }\n\n if (this.loading) children.push(this.genLoading())\n\n return children\n },\n genEmptyWrapper (content: VNodeChildrenArrayContents) {\n return this.$createElement('tr', {\n staticClass: 'v-data-table__empty-wrapper',\n }, [\n this.$createElement('td', {\n attrs: this.colspanAttrs,\n }, content),\n ])\n },\n genItems (items: any[], props: DataScopeProps) {\n const empty = this.genEmpty(props.originalItemsLength, props.pagination.itemsLength)\n if (empty) return [empty]\n\n return props.groupedItems\n ? this.genGroupedRows(props.groupedItems, props)\n : this.genRows(items, props)\n },\n genGroupedRows (groupedItems: ItemGroup[], props: DataScopeProps) {\n return groupedItems.map(group => {\n if (!this.openCache.hasOwnProperty(group.name)) this.$set(this.openCache, group.name, true)\n\n if (this.$scopedSlots.group) {\n return this.$scopedSlots.group({\n group: group.name,\n options: props.options,\n isMobile: this.isMobile,\n items: group.items,\n headers: this.computedHeaders,\n })\n } else {\n return this.genDefaultGroupedRow(group.name, group.items, props)\n }\n })\n },\n genDefaultGroupedRow (group: string, items: any[], props: DataScopeProps) {\n const isOpen = !!this.openCache[group]\n const children: VNodeChildren = [\n this.$createElement('template', { slot: 'row.content' }, this.genRows(items, props)),\n ]\n const toggleFn = () => this.$set(this.openCache, group, !this.openCache[group])\n const removeFn = () => props.updateOptions({ groupBy: [], groupDesc: [] })\n\n if (this.$scopedSlots['group.header']) {\n children.unshift(this.$createElement('template', { slot: 'column.header' }, [\n this.$scopedSlots['group.header']!({\n group,\n groupBy: props.options.groupBy,\n isMobile: this.isMobile,\n items,\n headers: this.computedHeaders,\n isOpen,\n toggle: toggleFn,\n remove: removeFn,\n }),\n ]))\n } else {\n const toggle = this.$createElement(VBtn, {\n staticClass: 'ma-0',\n props: {\n icon: true,\n small: true,\n },\n on: {\n click: toggleFn,\n },\n }, [this.$createElement(VIcon, [isOpen ? '$minus' : '$plus'])])\n\n const remove = this.$createElement(VBtn, {\n staticClass: 'ma-0',\n props: {\n icon: true,\n small: true,\n },\n on: {\n click: removeFn,\n },\n }, [this.$createElement(VIcon, ['$close'])])\n\n const column = this.$createElement('td', {\n staticClass: 'text-start',\n attrs: this.colspanAttrs,\n }, [toggle, `${props.options.groupBy[0]}: ${group}`, remove])\n\n children.unshift(this.$createElement('template', { slot: 'column.header' }, [column]))\n }\n\n if (this.$scopedSlots['group.summary']) {\n children.push(this.$createElement('template', { slot: 'column.summary' }, [\n this.$scopedSlots['group.summary']!({\n group,\n groupBy: props.options.groupBy,\n isMobile: this.isMobile,\n items,\n headers: this.computedHeaders,\n isOpen,\n toggle: toggleFn,\n }),\n ]))\n }\n\n return this.$createElement(RowGroup, {\n key: group,\n props: {\n value: isOpen,\n },\n }, children)\n },\n genRows (items: any[], props: DataScopeProps) {\n return this.$scopedSlots.item ? this.genScopedRows(items, props) : this.genDefaultRows(items, props)\n },\n genScopedRows (items: any[], props: DataScopeProps) {\n const rows = []\n\n for (let i = 0; i < items.length; i++) {\n const item = items[i]\n rows.push(this.$scopedSlots.item!({\n ...this.createItemProps(item, i),\n isMobile: this.isMobile,\n }))\n\n if (this.isExpanded(item)) {\n rows.push(this.$scopedSlots['expanded-item']!({\n headers: this.computedHeaders,\n isMobile: this.isMobile,\n index: i,\n item,\n }))\n }\n }\n\n return rows\n },\n genDefaultRows (items: any[], props: DataScopeProps) {\n return this.$scopedSlots['expanded-item']\n ? items.map((item, index) => this.genDefaultExpandedRow(item, index))\n : items.map((item, index) => this.genDefaultSimpleRow(item, index))\n },\n genDefaultExpandedRow (item: any, index: number): VNode {\n const isExpanded = this.isExpanded(item)\n const classes = {\n 'v-data-table__expanded v-data-table__expanded__row': isExpanded,\n }\n const headerRow = this.genDefaultSimpleRow(item, index, classes)\n const expandedRow = this.$createElement('tr', {\n staticClass: 'v-data-table__expanded v-data-table__expanded__content',\n }, [this.$scopedSlots['expanded-item']!({\n headers: this.computedHeaders,\n isMobile: this.isMobile,\n item,\n })])\n\n return this.$createElement(RowGroup, {\n props: {\n value: isExpanded,\n },\n }, [\n this.$createElement('template', { slot: 'row.header' }, [headerRow]),\n this.$createElement('template', { slot: 'row.content' }, [expandedRow]),\n ])\n },\n genDefaultSimpleRow (item: any, index: number, classes: Record = {}): VNode {\n const scopedSlots = getPrefixedScopedSlots('item.', this.$scopedSlots)\n\n const data = this.createItemProps(item, index)\n\n if (this.showSelect) {\n const slot = scopedSlots['data-table-select']\n scopedSlots['data-table-select'] = slot ? () => slot({\n ...data,\n isMobile: this.isMobile,\n }) : () => this.$createElement(VSimpleCheckbox, {\n staticClass: 'v-data-table__checkbox',\n props: {\n value: data.isSelected,\n disabled: !this.isSelectable(item),\n color: this.checkboxColor ?? '',\n },\n on: {\n input: (val: boolean) => data.select(val),\n },\n })\n }\n\n if (this.showExpand) {\n const slot = scopedSlots['data-table-expand']\n scopedSlots['data-table-expand'] = slot ? () => slot(data) : () => this.$createElement(VIcon, {\n staticClass: 'v-data-table__expand-icon',\n class: {\n 'v-data-table__expand-icon--active': data.isExpanded,\n },\n on: {\n click: (e: MouseEvent) => {\n e.stopPropagation()\n data.expand(!data.isExpanded)\n },\n },\n }, [this.expandIcon])\n }\n\n return this.$createElement(this.isMobile ? MobileRow : Row, {\n key: getObjectValueByPath(item, this.itemKey),\n class: mergeClasses(\n { ...classes, 'v-data-table__selected': data.isSelected },\n getPropertyFromItem(item, this.itemClass)\n ),\n props: {\n headers: this.computedHeaders,\n hideDefaultHeader: this.hideDefaultHeader,\n index,\n item,\n rtl: this.$vuetify.rtl,\n },\n scopedSlots,\n on: {\n // TODO: for click, the first argument should be the event, and the second argument should be data,\n // but this is a breaking change so it's for v3\n click: () => this.$emit('click:row', item, data),\n contextmenu: (event: MouseEvent) => this.$emit('contextmenu:row', event, data),\n dblclick: (event: MouseEvent) => this.$emit('dblclick:row', event, data),\n },\n })\n },\n genBody (props: DataScopeProps): VNode | string | VNodeChildren {\n const data = {\n ...props,\n expand: this.expand,\n headers: this.computedHeaders,\n isExpanded: this.isExpanded,\n isMobile: this.isMobile,\n isSelected: this.isSelected,\n select: this.select,\n }\n\n if (this.$scopedSlots.body) {\n return this.$scopedSlots.body!(data)\n }\n\n return this.$createElement('tbody', [\n getSlot(this, 'body.prepend', data, true),\n this.genItems(props.items, props),\n getSlot(this, 'body.append', data, true),\n ])\n },\n genFoot (props: DataScopeProps): VNode[] | undefined {\n return this.$scopedSlots.foot?.(props)\n },\n genFooters (props: DataScopeProps) {\n const data = {\n props: {\n options: props.options,\n pagination: props.pagination,\n itemsPerPageText: '$vuetify.dataTable.itemsPerPageText',\n ...this.sanitizedFooterProps,\n },\n on: {\n 'update:options': (value: any) => props.updateOptions(value),\n },\n widths: this.widths,\n headers: this.computedHeaders,\n }\n\n const children: VNodeChildren = [\n getSlot(this, 'footer', data, true),\n ]\n\n if (!this.hideDefaultFooter) {\n children.push(this.$createElement(VDataFooter, {\n ...data,\n scopedSlots: getPrefixedScopedSlots('footer.', this.$scopedSlots),\n }))\n }\n\n return children\n },\n genDefaultScopedSlot (props: DataScopeProps): VNode {\n const simpleProps = {\n height: this.height,\n fixedHeader: this.fixedHeader,\n dense: this.dense,\n }\n\n // if (this.virtualRows) {\n // return this.$createElement(VVirtualTable, {\n // props: Object.assign(simpleProps, {\n // items: props.items,\n // height: this.height,\n // rowHeight: this.dense ? 24 : 48,\n // headerHeight: this.dense ? 32 : 48,\n // // TODO: expose rest of props from virtual table?\n // }),\n // scopedSlots: {\n // items: ({ items }) => this.genItems(items, props) as any,\n // },\n // }, [\n // this.proxySlot('body.before', [this.genCaption(props), this.genHeaders(props)]),\n // this.proxySlot('bottom', this.genFooters(props)),\n // ])\n // }\n\n return this.$createElement(VSimpleTable, {\n props: simpleProps,\n class: {\n 'v-data-table--mobile': this.isMobile,\n },\n }, [\n this.proxySlot('top', getSlot(this, 'top', {\n ...props,\n isMobile: this.isMobile,\n }, true)),\n this.genCaption(props),\n this.genColgroup(props),\n this.genHeaders(props),\n this.genBody(props),\n this.genFoot(props),\n this.proxySlot('bottom', this.genFooters(props)),\n ])\n },\n proxySlot (slot: string, content: VNodeChildren) {\n return this.$createElement('template', { slot }, content)\n },\n },\n\n render (): VNode {\n return this.$createElement(VData, {\n props: {\n ...this.$props,\n customFilter: this.customFilterWithColumns,\n customSort: this.customSortWithHeaders,\n itemsPerPage: this.computedItemsPerPage,\n },\n on: {\n 'update:options': (v: DataOptions, old: DataOptions) => {\n this.internalGroupBy = v.groupBy || []\n !deepEqual(v, old) && this.$emit('update:options', v)\n },\n 'update:page': (v: number) => this.$emit('update:page', v),\n 'update:items-per-page': (v: number) => this.$emit('update:items-per-page', v),\n 'update:sort-by': (v: string | string[]) => this.$emit('update:sort-by', v),\n 'update:sort-desc': (v: boolean | boolean[]) => this.$emit('update:sort-desc', v),\n 'update:group-by': (v: string | string[]) => this.$emit('update:group-by', v),\n 'update:group-desc': (v: boolean | boolean[]) => this.$emit('update:group-desc', v),\n pagination: (v: DataPagination, old: DataPagination) => !deepEqual(v, old) && this.$emit('pagination', v),\n 'current-items': (v: any[]) => {\n this.internalCurrentItems = v\n this.$emit('current-items', v)\n },\n 'page-count': (v: number) => this.$emit('page-count', v),\n },\n scopedSlots: {\n default: this.genDefaultScopedSlot,\n },\n })\n },\n})\n"],"sourceRoot":""}