{"version":3,"sources":["webpack:///./node_modules/core-js/internals/string-pad.js","webpack:///./node_modules/core-js/modules/es.math.sign.js","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:///./node_modules/core-js/modules/es.string.pad-start.js","webpack:///../../../src/components/VTabs/VTab.ts","webpack:///../../../src/components/VSlideGroup/VSlideGroup.ts","webpack:///./node_modules/core-js/internals/string-pad-webkit-bug.js","webpack:///../../../src/components/VTabs/VTabsSlider.ts","webpack:///../../../src/components/VBtn/index.ts","webpack:///../../../src/directives/touch/index.ts","webpack:///../../../src/mixins/mobile/index.ts","webpack:///../../../src/components/VWindow/VWindow.ts","webpack:///../../../src/components/VTabs/VTabsBar.ts","webpack:///../../../src/components/VTabs/VTabsItems.ts","webpack:///../../../src/components/VTabs/VTabs.ts"],"names":["toLength","repeat","requireObjectCoercible","ceil","Math","createMethod","IS_END","$this","maxLength","fillString","fillLen","stringFiller","S","String","stringLength","length","fillStr","undefined","intMaxLength","call","slice","module","exports","start","end","$","sign","target","stat","mixins","methods","genPickerButton","readonly","staticClass","active","this","click","event","$createElement","class","on","Array","name","props","date","type","default","disabled","selectingYear","value","year","Number","yearIcon","data","isReversing","computed","computedTransition","watch","val","genYearIcon","VIcon","dark","getYearBtn","genTitleText","domProps","innerHTML","key","genTitleDate","render","h","locale","currentLocale","$vuetify","lang","padStart","string","targetLength","padString","n","createNativeLocaleFormatter","substrOptions","makeIsoString","dateString","pad","month","intlFormatter","Intl","Date","e","format","min","max","nextAriaLabel","nextIcon","prevAriaLabel","prevIcon","required","formatter","timeZone","newVal","genBtn","ariaLabelId","change","ariaLabel","t","calculateChange","VBtn","attrs","icon","light","monthChange","genHeader","color","header","setTextColor","$slots","transition","themeClasses","Object","instance","eventName","itemTypeSuffix","allowedFn","directives","Touch","allowedDates","current","events","Function","eventColor","range","scrollable","tableDate","wheelThrottle","displayedMonth","split","displayedYear","mounted","genButtonClasses","isAllowed","isSelected","isCurrent","genButtonEvents","createItemTypeNativeListeners","genButton","isOtherMonth","setColor","mouseEventType","genEvents","getEventColors","arrayize","v","eventColors","eventData","includes","isValidScroll","calculateTableDate","sanitizeType","sanitizeDateString","wheel","touch","genTable","touchDirective","left","right","from","indexOf","createUTCDate","day","isFinite","firstWeekOffset","firstWeekDayInFirstWeek","firstDayOfWeek","firstWeekDayOfYear","dayOfYear","isLeapYear","weeksInYear","weekOffset","weekOffsetNext","daysInYear","week","localeFirstDayOfYear","showAdjacentMonths","showWeek","weekdayFormat","weekdayFormatter","weekday","weekDays","first","parseInt","i","delta","genTHead","days","map","genTR","weekDaysBeforeFirstDayOfTheMonth","firstDayOfTheMonth","weekDay","getWeekNumber","weekNumber","genWeekNumber","genTBody","children","daysInMonth","rows","prevMonthYear","prevMonth","firstDayFromPreviousMonth","cellsInRow","nextMonthYear","nextMonth","nextMonthDay","cols","row","tds","defaultColor","setTimeout","activeItem","genYearItem","formatted","genYearItems","selectedYear","maxYear","minYear","ref","flat","fullWidth","landscape","noTitle","width","computedTitleColor","defaultTitleColor","isDark","genTitle","setBackgroundColor","genBodyTransition","genBody","style","genActions","elevationClasses","title","actions","headerColor","genPickerTitle","genPickerBody","genPickerActionsSlot","$scopedSlots","save","cancel","genPicker","body","slot","elevation","DAYS_IN_MONTH","DAYS_IN_MONTH_LEAP","dayFormat","headerDateFormat","monthFormat","multiple","nextMonthAriaLabel","nextYearAriaLabel","pickerDate","prevMonthAriaLabel","prevYearAriaLabel","reactive","showCurrent","Boolean","selectedItemsText","titleDateFormat","validator","yearFormat","now","activePicker","inputDay","inputMonth","inputYear","multipleValue","isMultiple","lastValue","selectedMonths","getFullYear","getMonth","inputDate","tableMonth","tableYear","minMonth","maxMonth","formatters","titleDate","defaultTitleMultipleDateFormatter","dates","defaultTitleDateFormatter","titleFormats","titleDateFormatter","landscapeFormatter","nonDigit","prev","oldValue","output","created","emitInput","newInput","concat","filter","x","$emit","checkMultipleProp","valueType","constructor","expected","console","isDateAllowed","yearClick","monthClick","dateClick","genTableHeader","toggle","input","genDateTable","VDatePickerDateTable","createItemTypeListeners","genMonthTable","VDatePickerMonthTable","genYears","setInputDate","array","$padStart","WEBKIT_BUG","proto","forced","arguments","baseMixins","ripple","proxyClass","classes","groupClasses","to","$router","resolve","href","$el","blur","role","tabindex","keydown","tag","BaseSlideGroup","Resize","activeClass","centerActive","showArrows","internalItemsLength","isOverflowing","resizeTimeout","startX","scrollOffset","widths","content","wrapper","__cachedNext","genTransition","__cachedPrev","hasAffixes","isMobile","hasNext","hasPrev","internalValue","beforeUpdate","$children","updated","genNext","next","genContent","genData","onResize","genIcon","rtl","location","upperLocation","hasAffix","genPrev","genWrapper","move","calculateNewOffset","newAbosluteOffset","direction","onAffixClick","onTouchStart","onTouchMove","onTouchEnd","maxScrollOffset","overflowCheck","fn","scrollIntoView","items","lastItemPosition","wrapperPosition","$refs","selectedIndex","calculateCenteredOffset","selectedItem","calculateUpdatedOffset","clientWidth","selectedElement","offsetLeft","currentScrollOffset","totalWidth","itemOffset","additionalOffset","offsetCentered","scrollTo","setWidths","window","provide","slideGroup","userAgent","test","handleGesture","touchendY","dirRatio","minDistance","touchendX","touchstartX","touchstartY","createHandlers","touchmoveX","touchmoveY","offsetX","offsetY","up","down","touchstart","touchend","touchmove","inserted","binding","el","options","passive","handlers","vnode","unbind","mobileBreakpoint","breakpoint","isNaN","mobile","mobileWidth","isNumber","$attrs","hasOwnProperty","windowGroup","continuous","mandatory","reverse","showArrowsOnHover","touchless","vertical","changedByDelimiters","internalHeight","transitionHeight","transitionCount","isBooted","isReverse","isActive","axis","internalReverse","hasActiveItems","find","item","internalIndex","findIndex","updateReverse","genContainer","height","large","genControlIcons","icons","getNextIndex","nextIndex","index","getPrevIndex","prevIndex","getValue","lastIndex","itemsLength","oldVal","tabsBar","$route","callSlider","onRouteChange","newPath","oldPath","hasNew","hasOld","VWindow","alignWithTitle","backgroundColor","centered","fixedTabs","grow","hideSlider","iconsAndText","optional","sliderColor","sliderSize","slider","top","transitionTime","isReversed","sliderStyles","computedColor","selectedItems","activeTab","scrollWidth","genBar","VTabsBar","genSlider","genItems","VTabsItems","VTabsSlider","clearTimeout","parseNodes","tab","modifiers","quiet"],"mappings":"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","file":"js/chunk-54995e3e.76df24f6.js","sourcesContent":["// https://github.com/tc39/proposal-string-pad-start-end\nvar toLength = require('../internals/to-length');\nvar repeat = require('../internals/string-repeat');\nvar requireObjectCoercible = require('../internals/require-object-coercible');\n\nvar ceil = Math.ceil;\n\n// `String.prototype.{ padStart, padEnd }` methods implementation\nvar createMethod = function (IS_END) {\n return function ($this, maxLength, fillString) {\n var S = String(requireObjectCoercible($this));\n var stringLength = S.length;\n var fillStr = fillString === undefined ? ' ' : String(fillString);\n var intMaxLength = toLength(maxLength);\n var fillLen, stringFiller;\n if (intMaxLength <= stringLength || fillStr == '') return S;\n fillLen = intMaxLength - stringLength;\n stringFiller = repeat.call(fillStr, ceil(fillLen / fillStr.length));\n if (stringFiller.length > fillLen) stringFiller = stringFiller.slice(0, fillLen);\n return IS_END ? S + stringFiller : stringFiller + S;\n };\n};\n\nmodule.exports = {\n // `String.prototype.padStart` method\n // https://tc39.es/ecma262/#sec-string.prototype.padstart\n start: createMethod(false),\n // `String.prototype.padEnd` method\n // https://tc39.es/ecma262/#sec-string.prototype.padend\n end: createMethod(true)\n};\n","var $ = require('../internals/export');\nvar sign = require('../internals/math-sign');\n\n// `Math.sign` method\n// https://tc39.es/ecma262/#sec-math.sign\n$({ target: 'Math', stat: true }, {\n sign: sign\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 (e: WheelEvent, calculateTableDate: CalculateTableDateFunction) {\n const tableDate = calculateTableDate(e.deltaY)\n // tableDate is 'YYYY-MM' for DateTable and 'YYYY' for MonthTable\n const sanitizeType = tableDate.split('-').length === 1 ? 'year' : 'month'\n return (e.deltaY === 0) ||\n (e.deltaY < 0 && (this.min ? tableDate >= sanitizeDateString(this.min, sanitizeType) : true)) ||\n (e.deltaY > 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) && this.touch(1, calculateTableDate),\n right: (e: TouchWrapper) => (e.offsetX > 15) && 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, 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\nexport default mixins(\n Localable,\n Picker,\n/* @vue/component */\n).extend({\n name: 'v-date-picker',\n\n props: {\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 activePicker: 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 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.activePicker = 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.activePicker = '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.activePicker = '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.activePicker === '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.activePicker = 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.activePicker === 'DATE' ? this.minMonth : this.minYear,\n max: this.activePicker === 'DATE' ? this.maxMonth : this.maxYear,\n nextAriaLabel: this.activePicker === 'DATE' ? this.nextMonthAriaLabel : this.nextYearAriaLabel,\n prevAriaLabel: this.activePicker === 'DATE' ? this.prevMonthAriaLabel : this.prevYearAriaLabel,\n prevIcon: this.prevIcon,\n readonly: this.readonly,\n value: this.activePicker === 'DATE' ? `${pad(this.tableYear, 4)}-${pad(this.tableMonth + 1)}` : `${pad(this.tableYear, 4)}`,\n },\n on: {\n toggle: () => this.activePicker = (this.activePicker === '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.activePicker === 'YEAR' ? [\n this.genYears(),\n ] : [\n this.genTableHeader(),\n this.activePicker === 'DATE' ? this.genDateTable() : this.genMonthTable(),\n ]\n\n return this.$createElement('div', {\n key: this.activePicker,\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","'use strict';\nvar $ = require('../internals/export');\nvar $padStart = require('../internals/string-pad').start;\nvar WEBKIT_BUG = require('../internals/string-pad-webkit-bug');\n\n// `String.prototype.padStart` method\n// https://tc39.es/ecma262/#sec-string.prototype.padstart\n$({ target: 'String', proto: true, forced: WEBKIT_BUG }, {\n padStart: function padStart(maxLength /* , fillString = ' ' */) {\n return $padStart(this, maxLength, arguments.length > 1 ? arguments[1] : undefined);\n }\n});\n","// Mixins\nimport { factory as GroupableFactory } from '../../mixins/groupable'\nimport Routable from '../../mixins/routable'\nimport Themeable from '../../mixins/themeable'\n\n// Utilities\nimport { keyCodes } from './../../util/helpers'\nimport mixins from '../../util/mixins'\nimport { ExtractVue } from './../../util/mixins'\n\n// Types\nimport { VNode } from 'vue/types'\n\nconst baseMixins = mixins(\n Routable,\n // Must be after routable\n // to overwrite activeClass\n GroupableFactory('tabsBar'),\n Themeable\n)\n\ninterface options extends ExtractVue {\n $el: HTMLElement\n}\n\nexport default baseMixins.extend().extend(\n /* @vue/component */\n).extend({\n name: 'v-tab',\n\n props: {\n ripple: {\n type: [Boolean, Object],\n default: true,\n },\n },\n\n data: () => ({\n proxyClass: 'v-tab--active',\n }),\n\n computed: {\n classes (): object {\n return {\n 'v-tab': true,\n ...Routable.options.computed.classes.call(this),\n 'v-tab--disabled': this.disabled,\n ...this.groupClasses,\n }\n },\n value (): any {\n let to = this.to || this.href || ''\n\n if (this.$router &&\n this.to === Object(this.to)\n ) {\n const resolve = this.$router.resolve(\n this.to,\n this.$route,\n this.append\n )\n\n to = resolve.href\n }\n\n return to.replace('#', '')\n },\n },\n\n mounted () {\n this.onRouteChange()\n },\n\n methods: {\n click (e: KeyboardEvent | MouseEvent): void {\n // If user provides an\n // actual link, do not\n // prevent default\n if (this.href &&\n this.href.indexOf('#') > -1\n ) e.preventDefault()\n\n if (e.detail) this.$el.blur()\n\n this.$emit('click', e)\n\n this.to || this.toggle()\n },\n },\n\n render (h): VNode {\n const { tag, data } = this.generateRouteLink()\n\n data.attrs = {\n ...data.attrs,\n 'aria-selected': String(this.isActive),\n role: 'tab',\n tabindex: 0,\n }\n data.on = {\n ...data.on,\n keydown: (e: KeyboardEvent) => {\n if (e.keyCode === keyCodes.enter) this.click(e)\n\n this.$emit('keydown', e)\n },\n }\n\n return h(tag, data, this.$slots.default)\n },\n})\n","// Styles\nimport './VSlideGroup.sass'\n\n// Components\nimport VIcon from '../VIcon'\nimport { VFadeTransition } from '../transitions'\n\n// Extensions\nimport { BaseItemGroup } from '../VItemGroup/VItemGroup'\n\n// Mixins\nimport Mobile from '../../mixins/mobile'\n\n// Directives\nimport Resize from '../../directives/resize'\nimport Touch from '../../directives/touch'\n\n// Utilities\nimport mixins, { ExtractVue } from '../../util/mixins'\n\n// Types\nimport Vue, { VNode } from 'vue'\n\ninterface TouchEvent {\n touchstartX: number\n touchmoveX: number\n stopPropagation: Function\n}\n\ninterface Widths {\n content: number\n wrapper: number\n}\n\ninterface options extends Vue {\n $refs: {\n content: HTMLElement\n wrapper: HTMLElement\n }\n}\n\nexport const BaseSlideGroup = mixins\n/* eslint-enable indent */\n>(\n BaseItemGroup,\n Mobile,\n /* @vue/component */\n).extend({\n name: 'base-slide-group',\n\n directives: {\n Resize,\n Touch,\n },\n\n props: {\n activeClass: {\n type: String,\n default: 'v-slide-item--active',\n },\n centerActive: Boolean,\n nextIcon: {\n type: String,\n default: '$next',\n },\n prevIcon: {\n type: String,\n default: '$prev',\n },\n showArrows: {\n type: [Boolean, String],\n validator: v => (\n typeof v === 'boolean' || [\n 'always',\n 'desktop',\n 'mobile',\n ].includes(v)\n ),\n },\n },\n\n data: () => ({\n internalItemsLength: 0,\n isOverflowing: false,\n resizeTimeout: 0,\n startX: 0,\n scrollOffset: 0,\n widths: {\n content: 0,\n wrapper: 0,\n },\n }),\n\n computed: {\n __cachedNext (): VNode {\n return this.genTransition('next')\n },\n __cachedPrev (): VNode {\n return this.genTransition('prev')\n },\n classes (): object {\n return {\n ...BaseItemGroup.options.computed.classes.call(this),\n 'v-slide-group': true,\n 'v-slide-group--has-affixes': this.hasAffixes,\n 'v-slide-group--is-overflowing': this.isOverflowing,\n }\n },\n hasAffixes (): Boolean {\n switch (this.showArrows) {\n // Always show arrows on desktop & mobile\n case 'always': return true\n\n // Always show arrows on desktop\n case 'desktop': return !this.isMobile\n\n // Show arrows on mobile when overflowing.\n // This matches the default 2.2 behavior\n case true: return this.isOverflowing || Math.abs(this.scrollOffset) > 0\n\n // Always show on mobile\n case 'mobile': return (\n this.isMobile ||\n (this.isOverflowing || Math.abs(this.scrollOffset) > 0)\n )\n\n // https://material.io/components/tabs#scrollable-tabs\n // Always show arrows when\n // overflowed on desktop\n default: return (\n !this.isMobile &&\n (this.isOverflowing || Math.abs(this.scrollOffset) > 0)\n )\n }\n },\n hasNext (): boolean {\n if (!this.hasAffixes) return false\n\n const { content, wrapper } = this.widths\n\n // Check one scroll ahead to know the width of right-most item\n return content > Math.abs(this.scrollOffset) + wrapper\n },\n hasPrev (): boolean {\n return this.hasAffixes && this.scrollOffset !== 0\n },\n },\n\n watch: {\n internalValue: 'setWidths',\n // When overflow changes, the arrows alter\n // the widths of the content and wrapper\n // and need to be recalculated\n isOverflowing: 'setWidths',\n scrollOffset (val) {\n this.$refs.content.style.transform = `translateX(${-val}px)`\n },\n },\n\n beforeUpdate () {\n this.internalItemsLength = (this.$children || []).length\n },\n\n updated () {\n if (this.internalItemsLength === (this.$children || []).length) return\n this.setWidths()\n },\n\n methods: {\n // Always generate next for scrollable hint\n genNext (): VNode | null {\n const slot = this.$scopedSlots.next\n ? this.$scopedSlots.next({})\n : this.$slots.next || this.__cachedNext\n\n return this.$createElement('div', {\n staticClass: 'v-slide-group__next',\n class: {\n 'v-slide-group__next--disabled': !this.hasNext,\n },\n on: {\n click: () => this.onAffixClick('next'),\n },\n key: 'next',\n }, [slot])\n },\n genContent (): VNode {\n return this.$createElement('div', {\n staticClass: 'v-slide-group__content',\n ref: 'content',\n }, this.$slots.default)\n },\n genData (): object {\n return {\n class: this.classes,\n directives: [{\n name: 'resize',\n value: this.onResize,\n }],\n }\n },\n genIcon (location: 'prev' | 'next'): VNode | null {\n let icon = location\n\n if (this.$vuetify.rtl && location === 'prev') {\n icon = 'next'\n } else if (this.$vuetify.rtl && location === 'next') {\n icon = 'prev'\n }\n\n const upperLocation = `${location[0].toUpperCase()}${location.slice(1)}`\n const hasAffix = (this as any)[`has${upperLocation}`]\n\n if (\n !this.showArrows &&\n !hasAffix\n ) return null\n\n return this.$createElement(VIcon, {\n props: {\n disabled: !hasAffix,\n },\n }, (this as any)[`${icon}Icon`])\n },\n // Always generate prev for scrollable hint\n genPrev (): VNode | null {\n const slot = this.$scopedSlots.prev\n ? this.$scopedSlots.prev({})\n : this.$slots.prev || this.__cachedPrev\n\n return this.$createElement('div', {\n staticClass: 'v-slide-group__prev',\n class: {\n 'v-slide-group__prev--disabled': !this.hasPrev,\n },\n on: {\n click: () => this.onAffixClick('prev'),\n },\n key: 'prev',\n }, [slot])\n },\n genTransition (location: 'prev' | 'next') {\n return this.$createElement(VFadeTransition, [this.genIcon(location)])\n },\n genWrapper (): VNode {\n return this.$createElement('div', {\n staticClass: 'v-slide-group__wrapper',\n directives: [{\n name: 'touch',\n value: {\n start: (e: TouchEvent) => this.overflowCheck(e, this.onTouchStart),\n move: (e: TouchEvent) => this.overflowCheck(e, this.onTouchMove),\n end: (e: TouchEvent) => this.overflowCheck(e, this.onTouchEnd),\n },\n }],\n ref: 'wrapper',\n }, [this.genContent()])\n },\n calculateNewOffset (direction: 'prev' | 'next', widths: Widths, rtl: boolean, currentScrollOffset: number) {\n const sign = rtl ? -1 : 1\n const newAbosluteOffset = sign * currentScrollOffset +\n (direction === 'prev' ? -1 : 1) * widths.wrapper\n\n return sign * Math.max(Math.min(newAbosluteOffset, widths.content - widths.wrapper), 0)\n },\n onAffixClick (location: 'prev' | 'next') {\n this.$emit(`click:${location}`)\n this.scrollTo(location)\n },\n onResize () {\n /* istanbul ignore next */\n if (this._isDestroyed) return\n\n this.setWidths()\n },\n onTouchStart (e: TouchEvent) {\n const { content } = this.$refs\n\n this.startX = this.scrollOffset + e.touchstartX as number\n\n content.style.setProperty('transition', 'none')\n content.style.setProperty('willChange', 'transform')\n },\n onTouchMove (e: TouchEvent) {\n this.scrollOffset = this.startX - e.touchmoveX\n },\n onTouchEnd () {\n const { content, wrapper } = this.$refs\n const maxScrollOffset = content.clientWidth - wrapper.clientWidth\n\n content.style.setProperty('transition', null)\n content.style.setProperty('willChange', null)\n\n if (this.$vuetify.rtl) {\n /* istanbul ignore else */\n if (this.scrollOffset > 0 || !this.isOverflowing) {\n this.scrollOffset = 0\n } else if (this.scrollOffset <= -maxScrollOffset) {\n this.scrollOffset = -maxScrollOffset\n }\n } else {\n /* istanbul ignore else */\n if (this.scrollOffset < 0 || !this.isOverflowing) {\n this.scrollOffset = 0\n } else if (this.scrollOffset >= maxScrollOffset) {\n this.scrollOffset = maxScrollOffset\n }\n }\n },\n overflowCheck (e: TouchEvent, fn: (e: TouchEvent) => void) {\n e.stopPropagation()\n this.isOverflowing && fn(e)\n },\n scrollIntoView /* istanbul ignore next */ () {\n if (!this.selectedItem && this.items.length) {\n const lastItemPosition = this.items[this.items.length - 1].$el.getBoundingClientRect()\n const wrapperPosition = this.$refs.wrapper.getBoundingClientRect()\n\n if (\n (this.$vuetify.rtl && wrapperPosition.right < lastItemPosition.right) ||\n (!this.$vuetify.rtl && wrapperPosition.left > lastItemPosition.left)\n ) {\n this.scrollTo('prev')\n }\n }\n\n if (!this.selectedItem) {\n return\n }\n\n if (\n this.selectedIndex === 0 ||\n (!this.centerActive && !this.isOverflowing)\n ) {\n this.scrollOffset = 0\n } else if (this.centerActive) {\n this.scrollOffset = this.calculateCenteredOffset(\n this.selectedItem.$el as HTMLElement,\n this.widths,\n this.$vuetify.rtl\n )\n } else if (this.isOverflowing) {\n this.scrollOffset = this.calculateUpdatedOffset(\n this.selectedItem.$el as HTMLElement,\n this.widths,\n this.$vuetify.rtl,\n this.scrollOffset\n )\n }\n },\n calculateUpdatedOffset (selectedElement: HTMLElement, widths: Widths, rtl: boolean, currentScrollOffset: number): number {\n const clientWidth = selectedElement.clientWidth\n const offsetLeft = rtl\n ? (widths.content - selectedElement.offsetLeft - clientWidth)\n : selectedElement.offsetLeft\n\n if (rtl) {\n currentScrollOffset = -currentScrollOffset\n }\n\n const totalWidth = widths.wrapper + currentScrollOffset\n const itemOffset = clientWidth + offsetLeft\n const additionalOffset = clientWidth * 0.4\n\n if (offsetLeft <= currentScrollOffset) {\n currentScrollOffset = Math.max(offsetLeft - additionalOffset, 0)\n } else if (totalWidth <= itemOffset) {\n currentScrollOffset = Math.min(currentScrollOffset - (totalWidth - itemOffset - additionalOffset), widths.content - widths.wrapper)\n }\n\n return rtl ? -currentScrollOffset : currentScrollOffset\n },\n calculateCenteredOffset (selectedElement: HTMLElement, widths: Widths, rtl: boolean): number {\n const { offsetLeft, clientWidth } = selectedElement\n\n if (rtl) {\n const offsetCentered = widths.content - offsetLeft - clientWidth / 2 - widths.wrapper / 2\n return -Math.min(widths.content - widths.wrapper, Math.max(0, offsetCentered))\n } else {\n const offsetCentered = offsetLeft + clientWidth / 2 - widths.wrapper / 2\n return Math.min(widths.content - widths.wrapper, Math.max(0, offsetCentered))\n }\n },\n scrollTo /* istanbul ignore next */ (location: 'prev' | 'next') {\n this.scrollOffset = this.calculateNewOffset(location, {\n // Force reflow\n content: this.$refs.content ? this.$refs.content.clientWidth : 0,\n wrapper: this.$refs.wrapper ? this.$refs.wrapper.clientWidth : 0,\n }, this.$vuetify.rtl, this.scrollOffset)\n },\n setWidths /* istanbul ignore next */ () {\n window.requestAnimationFrame(() => {\n const { content, wrapper } = this.$refs\n\n this.widths = {\n content: content ? content.clientWidth : 0,\n wrapper: wrapper ? wrapper.clientWidth : 0,\n }\n\n this.isOverflowing = this.widths.wrapper < this.widths.content\n\n this.scrollIntoView()\n })\n },\n },\n\n render (h): VNode {\n return h('div', this.genData(), [\n this.genPrev(),\n this.genWrapper(),\n this.genNext(),\n ])\n },\n})\n\nexport default BaseSlideGroup.extend({\n name: 'v-slide-group',\n\n provide (): object {\n return {\n slideGroup: this,\n }\n },\n})\n","// https://github.com/zloirock/core-js/issues/280\nvar userAgent = require('../internals/engine-user-agent');\n\n// eslint-disable-next-line unicorn/no-unsafe-regex -- safe\nmodule.exports = /Version\\/10\\.\\d+(\\.\\d+)?( Mobile\\/\\w+)? Safari\\//.test(userAgent);\n","// Mixins\nimport Colorable from '../../mixins/colorable'\n\n// Utilities\nimport mixins from '../../util/mixins'\n\n// Types\nimport { VNode } from 'vue/types'\n\n/* @vue/component */\nexport default mixins(Colorable).extend({\n name: 'v-tabs-slider',\n\n render (h): VNode {\n return h('div', this.setBackgroundColor(this.color, {\n staticClass: 'v-tabs-slider',\n }))\n },\n})\n","import VBtn from './VBtn'\n\nexport { VBtn }\nexport default VBtn\n","import { VNodeDirective, VNode } from 'vue/types/vnode'\nimport { keys } from '../../util/helpers'\nimport { TouchHandlers, TouchValue, TouchWrapper } from 'vuetify/types'\n\nexport interface TouchStoredHandlers {\n touchstart: (e: TouchEvent) => void\n touchend: (e: TouchEvent) => void\n touchmove: (e: TouchEvent) => void\n}\n\ninterface TouchVNodeDirective extends VNodeDirective {\n value?: TouchValue\n}\n\nconst handleGesture = (wrapper: TouchWrapper) => {\n const { touchstartX, touchendX, touchstartY, touchendY } = wrapper\n const dirRatio = 0.5\n const minDistance = 16\n wrapper.offsetX = touchendX - touchstartX\n wrapper.offsetY = touchendY - touchstartY\n\n if (Math.abs(wrapper.offsetY) < dirRatio * Math.abs(wrapper.offsetX)) {\n wrapper.left && (touchendX < touchstartX - minDistance) && wrapper.left(wrapper)\n wrapper.right && (touchendX > touchstartX + minDistance) && wrapper.right(wrapper)\n }\n\n if (Math.abs(wrapper.offsetX) < dirRatio * Math.abs(wrapper.offsetY)) {\n wrapper.up && (touchendY < touchstartY - minDistance) && wrapper.up(wrapper)\n wrapper.down && (touchendY > touchstartY + minDistance) && wrapper.down(wrapper)\n }\n}\n\nfunction touchstart (event: TouchEvent, wrapper: TouchWrapper) {\n const touch = event.changedTouches[0]\n wrapper.touchstartX = touch.clientX\n wrapper.touchstartY = touch.clientY\n\n wrapper.start &&\n wrapper.start(Object.assign(event, wrapper))\n}\n\nfunction touchend (event: TouchEvent, wrapper: TouchWrapper) {\n const touch = event.changedTouches[0]\n wrapper.touchendX = touch.clientX\n wrapper.touchendY = touch.clientY\n\n wrapper.end &&\n wrapper.end(Object.assign(event, wrapper))\n\n handleGesture(wrapper)\n}\n\nfunction touchmove (event: TouchEvent, wrapper: TouchWrapper) {\n const touch = event.changedTouches[0]\n wrapper.touchmoveX = touch.clientX\n wrapper.touchmoveY = touch.clientY\n\n wrapper.move && wrapper.move(Object.assign(event, wrapper))\n}\n\nfunction createHandlers (value: TouchHandlers): TouchStoredHandlers {\n const wrapper = {\n touchstartX: 0,\n touchstartY: 0,\n touchendX: 0,\n touchendY: 0,\n touchmoveX: 0,\n touchmoveY: 0,\n offsetX: 0,\n offsetY: 0,\n left: value.left,\n right: value.right,\n up: value.up,\n down: value.down,\n start: value.start,\n move: value.move,\n end: value.end,\n }\n\n return {\n touchstart: (e: TouchEvent) => touchstart(e, wrapper),\n touchend: (e: TouchEvent) => touchend(e, wrapper),\n touchmove: (e: TouchEvent) => touchmove(e, wrapper),\n }\n}\n\nfunction inserted (el: HTMLElement, binding: TouchVNodeDirective, vnode: VNode) {\n const value = binding.value!\n const target = value.parent ? el.parentElement : el\n const options = value.options || { passive: true }\n\n // Needed to pass unit tests\n if (!target) return\n\n const handlers = createHandlers(binding.value!)\n target._touchHandlers = Object(target._touchHandlers)\n target._touchHandlers![vnode.context!._uid] = handlers\n\n keys(handlers).forEach(eventName => {\n target.addEventListener(eventName, handlers[eventName] as EventListener, options)\n })\n}\n\nfunction unbind (el: HTMLElement, binding: TouchVNodeDirective, vnode: VNode) {\n const target = binding.value!.parent ? el.parentElement : el\n if (!target || !target._touchHandlers) return\n\n const handlers = target._touchHandlers[vnode.context!._uid]\n keys(handlers).forEach(eventName => {\n target.removeEventListener(eventName, handlers[eventName])\n })\n delete target._touchHandlers[vnode.context!._uid]\n}\n\nexport const Touch = {\n inserted,\n unbind,\n}\n\nexport default Touch\n","// Types\nimport { BreakpointName } from 'vuetify/types/services/breakpoint'\nimport { deprecate } from '../../util/console'\nimport Vue, { PropType } from 'vue'\n\n/* @vue/component */\nexport default Vue.extend({\n name: 'mobile',\n\n props: {\n mobileBreakpoint: {\n type: [Number, String] as PropType,\n default (): number | BreakpointName | undefined {\n // Avoid destroying unit\n // tests for users\n return this.$vuetify\n ? this.$vuetify.breakpoint.mobileBreakpoint\n : undefined\n },\n validator: v => (\n !isNaN(Number(v)) ||\n ['xs', 'sm', 'md', 'lg', 'xl'].includes(String(v))\n ),\n },\n },\n\n computed: {\n isMobile (): boolean {\n const {\n mobile,\n width,\n name,\n mobileBreakpoint,\n } = this.$vuetify.breakpoint\n\n // Check if local mobileBreakpoint matches\n // the application's mobileBreakpoint\n if (mobileBreakpoint === this.mobileBreakpoint) return mobile\n\n const mobileWidth = parseInt(this.mobileBreakpoint, 10)\n const isNumber = !isNaN(mobileWidth)\n\n return isNumber\n ? width < mobileWidth\n : name === this.mobileBreakpoint\n },\n },\n\n created () {\n /* istanbul ignore next */\n if (this.$attrs.hasOwnProperty('mobile-break-point')) {\n deprecate('mobile-break-point', 'mobile-breakpoint', this)\n }\n },\n})\n","// Styles\nimport './VWindow.sass'\n\n// Types\nimport { VNode, VNodeDirective } from 'vue/types/vnode'\nimport { PropType } from 'vue'\nimport { TouchHandlers } from 'vuetify/types'\n\n// Directives\nimport Touch from '../../directives/touch'\n\n// Components\nimport VBtn from '../VBtn'\nimport VIcon from '../VIcon'\nimport { BaseItemGroup } from '../VItemGroup/VItemGroup'\n\n/* @vue/component */\nexport default BaseItemGroup.extend({\n name: 'v-window',\n\n directives: { Touch },\n\n provide (): object {\n return {\n windowGroup: this,\n }\n },\n\n props: {\n activeClass: {\n type: String,\n default: 'v-window-item--active',\n },\n continuous: Boolean,\n mandatory: {\n type: Boolean,\n default: true,\n },\n nextIcon: {\n type: [Boolean, String],\n default: '$next',\n },\n prevIcon: {\n type: [Boolean, String],\n default: '$prev',\n },\n reverse: Boolean,\n showArrows: Boolean,\n showArrowsOnHover: Boolean,\n touch: Object as PropType,\n touchless: Boolean,\n value: {\n required: false,\n },\n vertical: Boolean,\n },\n\n data () {\n return {\n changedByDelimiters: false,\n internalHeight: undefined as undefined | string, // This can be fixed by child class.\n transitionHeight: undefined as undefined | string, // Intermediate height during transition.\n transitionCount: 0, // Number of windows in transition state.\n isBooted: false,\n isReverse: false,\n }\n },\n\n computed: {\n isActive (): boolean {\n return this.transitionCount > 0\n },\n classes (): object {\n return {\n ...BaseItemGroup.options.computed.classes.call(this),\n 'v-window--show-arrows-on-hover': this.showArrowsOnHover,\n }\n },\n computedTransition (): string {\n if (!this.isBooted) return ''\n\n const axis = this.vertical ? 'y' : 'x'\n const reverse = this.internalReverse ? !this.isReverse : this.isReverse\n const direction = reverse ? '-reverse' : ''\n\n return `v-window-${axis}${direction}-transition`\n },\n hasActiveItems (): boolean {\n return Boolean(\n this.items.find(item => !item.disabled)\n )\n },\n hasNext (): boolean {\n return this.continuous || this.internalIndex < this.items.length - 1\n },\n hasPrev (): boolean {\n return this.continuous || this.internalIndex > 0\n },\n internalIndex (): number {\n return this.items.findIndex((item, i) => {\n return this.internalValue === this.getValue(item, i)\n })\n },\n internalReverse (): boolean {\n return this.$vuetify.rtl ? !this.reverse : this.reverse\n },\n },\n\n watch: {\n internalIndex (val, oldVal) {\n this.isReverse = this.updateReverse(val, oldVal)\n },\n },\n\n mounted () {\n window.requestAnimationFrame(() => (this.isBooted = true))\n },\n\n methods: {\n genContainer (): VNode {\n const children = [this.$slots.default]\n\n if (this.showArrows) {\n children.push(this.genControlIcons())\n }\n\n return this.$createElement('div', {\n staticClass: 'v-window__container',\n class: {\n 'v-window__container--is-active': this.isActive,\n },\n style: {\n height: this.internalHeight || this.transitionHeight,\n },\n }, children)\n },\n genIcon (\n direction: 'prev' | 'next',\n icon: string,\n click: () => void\n ) {\n const on = {\n click: (e: Event) => {\n e.stopPropagation()\n this.changedByDelimiters = true\n click()\n },\n }\n const attrs = {\n 'aria-label': this.$vuetify.lang.t(`$vuetify.carousel.${direction}`),\n }\n const children = this.$scopedSlots[direction]?.({\n on,\n attrs,\n }) ?? [this.$createElement(VBtn, {\n props: { icon: true },\n attrs,\n on,\n }, [\n this.$createElement(VIcon, {\n props: { large: true },\n }, icon),\n ])]\n\n return this.$createElement('div', {\n staticClass: `v-window__${direction}`,\n }, children)\n },\n genControlIcons () {\n const icons = []\n\n const prevIcon = this.$vuetify.rtl\n ? this.nextIcon\n : this.prevIcon\n\n /* istanbul ignore else */\n if (\n this.hasPrev &&\n prevIcon &&\n typeof prevIcon === 'string'\n ) {\n const icon = this.genIcon('prev', prevIcon, this.prev)\n icon && icons.push(icon)\n }\n\n const nextIcon = this.$vuetify.rtl\n ? this.prevIcon\n : this.nextIcon\n\n /* istanbul ignore else */\n if (\n this.hasNext &&\n nextIcon &&\n typeof nextIcon === 'string'\n ) {\n const icon = this.genIcon('next', nextIcon, this.next)\n icon && icons.push(icon)\n }\n\n return icons\n },\n getNextIndex (index: number): number {\n const nextIndex = (index + 1) % this.items.length\n const item = this.items[nextIndex]\n\n if (item.disabled) return this.getNextIndex(nextIndex)\n\n return nextIndex\n },\n getPrevIndex (index: number): number {\n const prevIndex = (index + this.items.length - 1) % this.items.length\n const item = this.items[prevIndex]\n\n if (item.disabled) return this.getPrevIndex(prevIndex)\n\n return prevIndex\n },\n next () {\n /* istanbul ignore if */\n if (!this.hasActiveItems || !this.hasNext) return\n\n const nextIndex = this.getNextIndex(this.internalIndex)\n const item = this.items[nextIndex]\n\n this.internalValue = this.getValue(item, nextIndex)\n },\n prev () {\n /* istanbul ignore if */\n if (!this.hasActiveItems || !this.hasPrev) return\n\n const lastIndex = this.getPrevIndex(this.internalIndex)\n const item = this.items[lastIndex]\n\n this.internalValue = this.getValue(item, lastIndex)\n },\n updateReverse (val: number, oldVal: number) {\n const itemsLength = this.items.length\n const lastIndex = itemsLength - 1\n\n if (itemsLength <= 2) return val < oldVal\n\n if (val === lastIndex && oldVal === 0) {\n return true\n } else if (val === 0 && oldVal === lastIndex) {\n return false\n } else {\n return val < oldVal\n }\n },\n },\n\n render (h): VNode {\n const data = {\n staticClass: 'v-window',\n class: this.classes,\n directives: [] as VNodeDirective[],\n }\n\n if (!this.touchless) {\n const value = this.touch || {\n left: () => {\n this.$vuetify.rtl ? this.prev() : this.next()\n },\n right: () => {\n this.$vuetify.rtl ? this.next() : this.prev()\n },\n end: (e: TouchEvent) => {\n e.stopPropagation()\n },\n start: (e: TouchEvent) => {\n e.stopPropagation()\n },\n }\n\n data.directives.push({\n name: 'touch',\n value,\n })\n }\n\n return h('div', data, [this.genContainer()])\n },\n})\n","// Extensions\nimport { BaseSlideGroup } from '../VSlideGroup/VSlideGroup'\n\n// Components\nimport VTab from './VTab'\n\n// Mixins\nimport Themeable from '../../mixins/themeable'\nimport SSRBootable from '../../mixins/ssr-bootable'\n\n// Utilities\nimport mixins from '../../util/mixins'\n\n// Types\nimport { Route } from 'vue-router'\nimport { VNode } from 'vue'\n\ntype VTabInstance = InstanceType\n\nexport default mixins(\n BaseSlideGroup,\n SSRBootable,\n Themeable\n /* @vue/component */\n).extend({\n name: 'v-tabs-bar',\n\n provide () {\n return {\n tabsBar: this,\n }\n },\n\n computed: {\n classes () {\n return {\n ...BaseSlideGroup.options.computed.classes.call(this),\n 'v-tabs-bar': true,\n 'v-tabs-bar--is-mobile': this.isMobile,\n // TODO: Remove this and move to v-slide-group\n 'v-tabs-bar--show-arrows': this.showArrows,\n ...this.themeClasses,\n }\n },\n },\n\n watch: {\n items: 'callSlider',\n internalValue: 'callSlider',\n $route: 'onRouteChange',\n },\n\n methods: {\n callSlider () {\n if (!this.isBooted) return\n\n this.$emit('call:slider')\n },\n genContent () {\n const render = BaseSlideGroup.options.methods.genContent.call(this)\n\n render.data = render.data || {}\n render.data.staticClass += ' v-tabs-bar__content'\n\n return render\n },\n onRouteChange (val: Route, oldVal: Route) {\n /* istanbul ignore next */\n if (this.mandatory) return\n\n const items = this.items as unknown as VTabInstance[]\n const newPath = val.path\n const oldPath = oldVal.path\n\n let hasNew = false\n let hasOld = false\n\n for (const item of items) {\n if (item.to === newPath) hasNew = true\n else if (item.to === oldPath) hasOld = true\n\n if (hasNew && hasOld) break\n }\n\n // If we have an old item and not a new one\n // it's assumed that the user navigated to\n // a path that is not present in the items\n if (!hasNew && hasOld) this.internalValue = undefined\n },\n },\n\n render (h): VNode {\n const render = BaseSlideGroup.options.render.call(this, h)\n\n render.data!.attrs = {\n role: 'tablist',\n }\n\n return render\n },\n})\n","// Extensions\nimport VWindow from '../VWindow/VWindow'\n\n// Types & Components\nimport { BaseItemGroup, GroupableInstance } from './../VItemGroup/VItemGroup'\n\n/* @vue/component */\nexport default VWindow.extend({\n name: 'v-tabs-items',\n\n props: {\n mandatory: {\n type: Boolean,\n default: false,\n },\n },\n\n computed: {\n classes (): object {\n return {\n ...VWindow.options.computed.classes.call(this),\n 'v-tabs-items': true,\n }\n },\n isDark (): boolean {\n return this.rootIsDark\n },\n },\n\n methods: {\n getValue (item: GroupableInstance, i: number) {\n return item.id || BaseItemGroup.options.methods.getValue.call(this, item, i)\n },\n },\n})\n","// Styles\nimport './VTabs.sass'\n\n// Components\nimport VTabsBar from './VTabsBar'\nimport VTabsItems from './VTabsItems'\nimport VTabsSlider from './VTabsSlider'\n\n// Mixins\nimport Colorable from '../../mixins/colorable'\nimport Proxyable from '../../mixins/proxyable'\nimport Themeable from '../../mixins/themeable'\n\n// Directives\nimport Resize from '../../directives/resize'\n\n// Utilities\nimport { convertToUnit } from '../../util/helpers'\nimport { ExtractVue } from './../../util/mixins'\nimport mixins from '../../util/mixins'\n\n// Types\nimport { VNode } from 'vue/types'\n\nconst baseMixins = mixins(\n Colorable,\n Proxyable,\n Themeable\n)\n\ninterface options extends ExtractVue {\n $refs: {\n items: InstanceType\n }\n}\n\nexport default baseMixins.extend().extend({\n name: 'v-tabs',\n\n directives: {\n Resize,\n },\n\n props: {\n activeClass: {\n type: String,\n default: '',\n },\n alignWithTitle: Boolean,\n backgroundColor: String,\n centerActive: Boolean,\n centered: Boolean,\n fixedTabs: Boolean,\n grow: Boolean,\n height: {\n type: [Number, String],\n default: undefined,\n },\n hideSlider: Boolean,\n iconsAndText: Boolean,\n mobileBreakpoint: [String, Number],\n nextIcon: {\n type: String,\n default: '$next',\n },\n optional: Boolean,\n prevIcon: {\n type: String,\n default: '$prev',\n },\n right: Boolean,\n showArrows: [Boolean, String],\n sliderColor: String,\n sliderSize: {\n type: [Number, String],\n default: 2,\n },\n vertical: Boolean,\n },\n\n data () {\n return {\n resizeTimeout: 0,\n slider: {\n height: null as null | number,\n left: null as null | number,\n right: null as null | number,\n top: null as null | number,\n width: null as null | number,\n },\n transitionTime: 300,\n }\n },\n\n computed: {\n classes (): object {\n return {\n 'v-tabs--align-with-title': this.alignWithTitle,\n 'v-tabs--centered': this.centered,\n 'v-tabs--fixed-tabs': this.fixedTabs,\n 'v-tabs--grow': this.grow,\n 'v-tabs--icons-and-text': this.iconsAndText,\n 'v-tabs--right': this.right,\n 'v-tabs--vertical': this.vertical,\n ...this.themeClasses,\n }\n },\n isReversed (): boolean {\n return this.$vuetify.rtl && this.vertical\n },\n sliderStyles (): object {\n return {\n height: convertToUnit(this.slider.height),\n left: this.isReversed ? undefined : convertToUnit(this.slider.left),\n right: this.isReversed ? convertToUnit(this.slider.right) : undefined,\n top: this.vertical ? convertToUnit(this.slider.top) : undefined,\n transition: this.slider.left != null ? null : 'none',\n width: convertToUnit(this.slider.width),\n }\n },\n computedColor (): string {\n if (this.color) return this.color\n else if (this.isDark && !this.appIsDark) return 'white'\n else return 'primary'\n },\n },\n\n watch: {\n alignWithTitle: 'callSlider',\n centered: 'callSlider',\n centerActive: 'callSlider',\n fixedTabs: 'callSlider',\n grow: 'callSlider',\n iconsAndText: 'callSlider',\n right: 'callSlider',\n showArrows: 'callSlider',\n vertical: 'callSlider',\n '$vuetify.application.left': 'onResize',\n '$vuetify.application.right': 'onResize',\n '$vuetify.rtl': 'onResize',\n },\n\n mounted () {\n this.$nextTick(() => {\n window.setTimeout(this.callSlider, 30)\n })\n },\n\n methods: {\n callSlider () {\n if (\n this.hideSlider ||\n !this.$refs.items ||\n !this.$refs.items.selectedItems.length\n ) {\n this.slider.width = 0\n return false\n }\n\n this.$nextTick(() => {\n // Give screen time to paint\n const activeTab = this.$refs.items.selectedItems[0]\n /* istanbul ignore if */\n if (!activeTab || !activeTab.$el) {\n this.slider.width = 0\n this.slider.left = 0\n return\n }\n const el = activeTab.$el as HTMLElement\n\n this.slider = {\n height: !this.vertical ? Number(this.sliderSize) : el.scrollHeight,\n left: this.vertical ? 0 : el.offsetLeft,\n right: this.vertical ? 0 : el.offsetLeft + el.offsetWidth,\n top: el.offsetTop,\n width: this.vertical ? Number(this.sliderSize) : el.scrollWidth,\n }\n })\n\n return true\n },\n genBar (items: VNode[], slider: VNode | null) {\n const data = {\n style: {\n height: convertToUnit(this.height),\n },\n props: {\n activeClass: this.activeClass,\n centerActive: this.centerActive,\n dark: this.dark,\n light: this.light,\n mandatory: !this.optional,\n mobileBreakpoint: this.mobileBreakpoint,\n nextIcon: this.nextIcon,\n prevIcon: this.prevIcon,\n showArrows: this.showArrows,\n value: this.internalValue,\n },\n on: {\n 'call:slider': this.callSlider,\n change: (val: any) => {\n this.internalValue = val\n },\n },\n ref: 'items',\n }\n\n this.setTextColor(this.computedColor, data)\n this.setBackgroundColor(this.backgroundColor, data)\n\n return this.$createElement(VTabsBar, data, [\n this.genSlider(slider),\n items,\n ])\n },\n genItems (items: VNode | null, item: VNode[]) {\n // If user provides items\n // opt to use theirs\n if (items) return items\n\n // If no tabs are provided\n // render nothing\n if (!item.length) return null\n\n return this.$createElement(VTabsItems, {\n props: {\n value: this.internalValue,\n },\n on: {\n change: (val: any) => {\n this.internalValue = val\n },\n },\n }, item)\n },\n genSlider (slider: VNode | null) {\n if (this.hideSlider) return null\n\n if (!slider) {\n slider = this.$createElement(VTabsSlider, {\n props: { color: this.sliderColor },\n })\n }\n\n return this.$createElement('div', {\n staticClass: 'v-tabs-slider-wrapper',\n style: this.sliderStyles,\n }, [slider])\n },\n onResize () {\n if (this._isDestroyed) return\n\n clearTimeout(this.resizeTimeout)\n this.resizeTimeout = window.setTimeout(this.callSlider, 0)\n },\n parseNodes () {\n let items = null\n let slider = null\n const item = []\n const tab = []\n const slot = this.$slots.default || []\n const length = slot.length\n\n for (let i = 0; i < length; i++) {\n const vnode = slot[i]\n\n if (vnode.componentOptions) {\n switch (vnode.componentOptions.Ctor.options.name) {\n case 'v-tabs-slider': slider = vnode\n break\n case 'v-tabs-items': items = vnode\n break\n case 'v-tab-item': item.push(vnode)\n break\n // case 'v-tab' - intentionally omitted\n default: tab.push(vnode)\n }\n } else {\n tab.push(vnode)\n }\n }\n\n /**\n * tab: array of `v-tab`\n * slider: single `v-tabs-slider`\n * items: single `v-tabs-items`\n * item: array of `v-tab-item`\n */\n return { tab, slider, items, item }\n },\n },\n\n render (h): VNode {\n const { tab, slider, items, item } = this.parseNodes()\n\n return h('div', {\n staticClass: 'v-tabs',\n class: this.classes,\n directives: [{\n name: 'resize',\n modifiers: { quiet: true },\n value: this.onResize,\n }],\n }, [\n this.genBar(tab, slider),\n this.genItems(items, item),\n ])\n },\n})\n"],"sourceRoot":""}