{"version":3,"sources":["webpack:///../../../src/components/VWindow/VWindowItem.ts","webpack:///../../../src/components/VSkeletonLoader/VSkeletonLoader.ts","webpack:///../../../src/components/VTabs/VTab.ts","webpack:///../../../src/components/VTabs/VTabsItems.ts","webpack:///../../../src/components/VTabs/VTabItem.ts","webpack:///../../../src/components/VWindow/VWindow.ts","webpack:///../../../src/components/VSlideGroup/VSlideGroup.ts","webpack:///../../../src/components/VTabs/VTabsBar.ts","webpack:///../../../src/components/VTabs/VTabsSlider.ts","webpack:///../../../src/components/VTabs/VTabs.ts"],"names":["baseMixins","extend","name","directives","Touch","props","disabled","Boolean","reverseTransition","type","String","default","undefined","transition","value","required","isActive","inTransition","computed","this","groupClasses","windowGroup","internalReverse","computedTransition","methods","$createElement","staticClass","class","classes","on","$listeners","genDefaultSlot","transitionCount","transitionHeight","$el","clientHeight","onAfterTransition","el","$nextTick","h","beforeEnter","onBeforeTransition","afterEnter","enterCancelled","onTransitionCancelled","beforeLeave","afterLeave","leaveCancelled","enter","onEnter","showLazyContent","genWindowItem","boilerplate","loading","loadingText","tile","types","Object","isLoading","$vuetify","lang","t","role","$attrs","themeClasses","elevationClasses","$scopedSlots","actions","article","avatar","button","card","chip","heading","image","paragraph","sentences","table","text","children","bone","length","split","generator","genStructure","Array","from","map","rootTypes","indexOf","mapBones","genBones","push","genBone","resetStyles","onBeforeEnter","onBeforeLeave","bones","replace","_initialStyle","display","style","setProperty","attrs","measurableStyles","genSkeleton","ripple","tabValue","data","proxyClass","options","call","to","href","$router","resolve","$route","append","e","preventDefault","detail","blur","$emit","toggle","tabsBar","mandatory","tag","generateRouteLink","tabindex","keydown","keyCode","click","rootIsDark","item","i","id","getValue","domProps","activeClass","continuous","nextIcon","prevIcon","reverse","showArrows","showArrowsOnHover","touch","touchless","vertical","changedByDelimiters","internalHeight","isBooted","isReverse","axis","direction","items","find","internalIndex","findIndex","internalValue","rtl","watch","val","oldVal","updateReverse","window","requestAnimationFrame","genControlIcons","height","icon","stopPropagation","large","icons","hasPrev","genIcon","prev","hasNext","next","index","nextIndex","getNextIndex","prevIndex","getPrevIndex","hasActiveItems","lastIndex","itemsLength","left","right","end","start","genContainer","bias","c","x","Math","abs","sign","calculateUpdatedOffset","selectedElement","widths","currentScrollOffset","clientWidth","offsetLeft","content","totalWidth","wrapper","itemOffset","additionalOffset","max","min","calculateCenteredOffset","offsetCentered","BaseSlideGroup","mixins","Resize","centerActive","validator","v","includes","isOverflowing","resizeTimeout","startX","isSwipingHorizontal","isSwiping","scrollOffset","genTransition","hasAffixes","isMobile","scroll","$refs","transform","ResizeObserver","obs","onResize","observe","$on","disconnect","setWidths","scrollLeft","vm","slot","__cachedNext","onAffixClick","key","ref","focusin","onFocusin","location","upperLocation","toUpperCase","slice","hasAffix","VIcon","__cachedPrev","overflowCheck","onTouchStart","move","onTouchMove","onTouchEnd","onScroll","genContent","newAbosluteOffset","scrollTo","_isDestroyed","touchstartX","canTouch","diffX","touchmoveX","diffY","touchmoveY","touchstartY","document","documentElement","overflowY","maxScrollOffset","removeProperty","fn","selectedItem","lastItemPosition","getBoundingClientRect","wrapperPosition","selectedIndex","calculateNewOffset","scrollIntoView","genData","genPrev","genWrapper","genNext","slideGroup","render","newPath","path","oldPath","hasNew","hasOld","setBackgroundColor","color","alignWithTitle","backgroundColor","centered","fixedTabs","grow","Number","hideSlider","iconsAndText","mobileBreakpoint","optional","sliderColor","sliderSize","slider","top","width","transitionTime","isReversed","isDark","appIsDark","setTimeout","callSlider","selectedItems","activeTab","scrollHeight","offsetWidth","offsetTop","scrollWidth","dark","light","change","setTextColor","computedColor","VTabsBar","genSlider","VTabsItems","VTabsSlider","sliderStyles","clearTimeout","tab","vnode","componentOptions","Ctor","parseNodes","modifiers","quiet","genBar","genItems"],"mappings":"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","file":"js/chunk-3ba6dbef.faf67b64.js","sourcesContent":["// Components\nimport VWindow from './VWindow'\n\n// Mixins\nimport Bootable from '../../mixins/bootable'\nimport { factory as GroupableFactory } from '../../mixins/groupable'\n\n// Directives\nimport Touch from '../../directives/touch'\n\n// Utilities\nimport { convertToUnit, getSlot } from '../../util/helpers'\nimport mixins, { ExtractVue } from '../../util/mixins'\n\n// Types\nimport { VNode } from 'vue'\n\nconst baseMixins = mixins(\n Bootable,\n GroupableFactory('windowGroup', 'v-window-item', 'v-window')\n)\n\ninterface options extends ExtractVue {\n $el: HTMLElement\n windowGroup: InstanceType\n}\n\nexport default baseMixins.extend().extend(\n /* @vue/component */\n).extend({\n name: 'v-window-item',\n\n directives: {\n Touch,\n },\n\n props: {\n disabled: Boolean,\n reverseTransition: {\n type: [Boolean, String],\n default: undefined,\n },\n transition: {\n type: [Boolean, String],\n default: undefined,\n },\n value: {\n required: false,\n },\n },\n\n data () {\n return {\n isActive: false,\n inTransition: false,\n }\n },\n\n computed: {\n classes (): object {\n return this.groupClasses\n },\n computedTransition (): string | boolean {\n if (!this.windowGroup.internalReverse) {\n return typeof this.transition !== 'undefined'\n ? this.transition || ''\n : this.windowGroup.computedTransition\n }\n\n return typeof this.reverseTransition !== 'undefined'\n ? this.reverseTransition || ''\n : this.windowGroup.computedTransition\n },\n },\n\n methods: {\n genDefaultSlot () {\n return getSlot(this)\n },\n genWindowItem () {\n return this.$createElement('div', {\n staticClass: 'v-window-item',\n class: this.classes,\n directives: [{\n name: 'show',\n value: this.isActive,\n }],\n on: this.$listeners,\n }, this.genDefaultSlot())\n },\n onAfterTransition () {\n if (!this.inTransition) {\n return\n }\n\n // Finalize transition state.\n this.inTransition = false\n if (this.windowGroup.transitionCount > 0) {\n this.windowGroup.transitionCount--\n\n // Remove container height if we are out of transition.\n if (this.windowGroup.transitionCount === 0) {\n this.windowGroup.transitionHeight = undefined\n }\n }\n },\n onBeforeTransition () {\n if (this.inTransition) {\n return\n }\n\n // Initialize transition state here.\n this.inTransition = true\n if (this.windowGroup.transitionCount === 0) {\n // Set initial height for height transition.\n this.windowGroup.transitionHeight = convertToUnit(this.windowGroup.$el.clientHeight)\n }\n this.windowGroup.transitionCount++\n },\n onTransitionCancelled () {\n this.onAfterTransition() // This should have the same path as normal transition end.\n },\n onEnter (el: HTMLElement) {\n if (!this.inTransition) {\n return\n }\n\n this.$nextTick(() => {\n // Do not set height if no transition or cancelled.\n if (!this.computedTransition || !this.inTransition) {\n return\n }\n\n // Set transition target height.\n this.windowGroup.transitionHeight = convertToUnit(el.clientHeight)\n })\n },\n },\n\n render (h): VNode {\n return h('transition', {\n props: {\n name: this.computedTransition,\n },\n on: {\n // Handlers for enter windows.\n beforeEnter: this.onBeforeTransition,\n afterEnter: this.onAfterTransition,\n enterCancelled: this.onTransitionCancelled,\n\n // Handlers for leave windows.\n beforeLeave: this.onBeforeTransition,\n afterLeave: this.onAfterTransition,\n leaveCancelled: this.onTransitionCancelled,\n\n // Enter handler for height transition.\n enter: this.onEnter,\n },\n }, this.showLazyContent(() => [this.genWindowItem()]))\n },\n})\n","// Styles\nimport './VSkeletonLoader.sass'\n\n// Mixins\nimport Elevatable from '../../mixins/elevatable'\nimport Measurable from '../../mixins/measurable'\nimport Themeable from '../../mixins/themeable'\n\n// Utilities\nimport mixins from '../../util/mixins'\n\n// Types\nimport { VNode } from 'vue'\nimport { getSlot } from '../../util/helpers'\nimport { PropValidator } from 'vue/types/options'\n\nexport interface HTMLSkeletonLoaderElement extends HTMLElement {\n _initialStyle?: {\n display: string | null\n transition: string\n }\n}\n\n/* @vue/component */\nexport default mixins(\n Elevatable,\n Measurable,\n Themeable,\n).extend({\n name: 'VSkeletonLoader',\n\n props: {\n boilerplate: Boolean,\n loading: Boolean,\n loadingText: {\n type: String,\n default: '$vuetify.loading',\n },\n tile: Boolean,\n transition: String,\n type: String,\n types: {\n type: Object,\n default: () => ({}),\n } as PropValidator>,\n },\n\n computed: {\n attrs (): object {\n if (!this.isLoading) return this.$attrs\n\n return {\n 'aria-busy': !this.boilerplate ? true : undefined,\n 'aria-live': !this.boilerplate ? 'polite' : undefined,\n 'aria-label': !this.boilerplate ? this.$vuetify.lang.t(this.loadingText) : undefined,\n role: !this.boilerplate ? 'alert' : undefined,\n ...this.$attrs,\n }\n },\n classes (): object {\n return {\n 'v-skeleton-loader--boilerplate': this.boilerplate,\n 'v-skeleton-loader--is-loading': this.isLoading,\n 'v-skeleton-loader--tile': this.tile,\n ...this.themeClasses,\n ...this.elevationClasses,\n }\n },\n isLoading (): boolean {\n return !('default' in this.$scopedSlots) || this.loading\n },\n rootTypes (): Record {\n return {\n actions: 'button@2',\n article: 'heading, paragraph',\n avatar: 'avatar',\n button: 'button',\n card: 'image, card-heading',\n 'card-avatar': 'image, list-item-avatar',\n 'card-heading': 'heading',\n chip: 'chip',\n 'date-picker': 'list-item, card-heading, divider, date-picker-options, date-picker-days, actions',\n 'date-picker-options': 'text, avatar@2',\n 'date-picker-days': 'avatar@28',\n heading: 'heading',\n image: 'image',\n 'list-item': 'text',\n 'list-item-avatar': 'avatar, text',\n 'list-item-two-line': 'sentences',\n 'list-item-avatar-two-line': 'avatar, sentences',\n 'list-item-three-line': 'paragraph',\n 'list-item-avatar-three-line': 'avatar, paragraph',\n paragraph: 'text@3',\n sentences: 'text@2',\n table: 'table-heading, table-thead, table-tbody, table-tfoot',\n 'table-heading': 'heading, text',\n 'table-thead': 'heading@6',\n 'table-tbody': 'table-row-divider@6',\n 'table-row-divider': 'table-row, divider',\n 'table-row': 'table-cell@6',\n 'table-cell': 'text',\n 'table-tfoot': 'text@2, avatar@2',\n text: 'text',\n ...this.types,\n }\n },\n },\n\n methods: {\n genBone (text: string, children: VNode[]) {\n return this.$createElement('div', {\n staticClass: `v-skeleton-loader__${text} v-skeleton-loader__bone`,\n }, children)\n },\n genBones (bone: string): VNode[] {\n // e.g. 'text@3'\n const [type, length] = bone.split('@') as [string, number]\n const generator = () => this.genStructure(type)\n\n // Generate a length array based upon\n // value after @ in the bone string\n return Array.from({ length }).map(generator)\n },\n // Fix type when this is merged\n // https://github.com/microsoft/TypeScript/pull/33050\n genStructure (type?: string): any {\n let children = []\n type = type || this.type || ''\n const bone = this.rootTypes[type] || ''\n\n // End of recursion, do nothing\n /* eslint-disable-next-line no-empty, brace-style */\n if (type === bone) {}\n // Array of values - e.g. 'heading, paragraph, text@2'\n else if (type.indexOf(',') > -1) return this.mapBones(type)\n // Array of values - e.g. 'paragraph@4'\n else if (type.indexOf('@') > -1) return this.genBones(type)\n // Array of values - e.g. 'card@2'\n else if (bone.indexOf(',') > -1) children = this.mapBones(bone)\n // Array of values - e.g. 'list-item@2'\n else if (bone.indexOf('@') > -1) children = this.genBones(bone)\n // Single value - e.g. 'card-heading'\n else if (bone) children.push(this.genStructure(bone))\n\n return [this.genBone(type, children)]\n },\n genSkeleton () {\n const children = []\n\n if (!this.isLoading) children.push(getSlot(this))\n else children.push(this.genStructure())\n\n /* istanbul ignore else */\n if (!this.transition) return children\n\n /* istanbul ignore next */\n return this.$createElement('transition', {\n props: {\n name: this.transition,\n },\n // Only show transition when\n // content has been loaded\n on: {\n afterEnter: this.resetStyles,\n beforeEnter: this.onBeforeEnter,\n beforeLeave: this.onBeforeLeave,\n leaveCancelled: this.resetStyles,\n },\n }, children)\n },\n mapBones (bones: string) {\n // Remove spaces and return array of structures\n return bones.replace(/\\s/g, '').split(',').map(this.genStructure)\n },\n onBeforeEnter (el: HTMLSkeletonLoaderElement) {\n this.resetStyles(el)\n\n if (!this.isLoading) return\n\n el._initialStyle = {\n display: el.style.display,\n transition: el.style.transition,\n }\n\n el.style.setProperty('transition', 'none', 'important')\n },\n onBeforeLeave (el: HTMLSkeletonLoaderElement) {\n el.style.setProperty('display', 'none', 'important')\n },\n resetStyles (el: HTMLSkeletonLoaderElement) {\n if (!el._initialStyle) return\n\n el.style.display = el._initialStyle.display || ''\n el.style.transition = el._initialStyle.transition\n\n delete el._initialStyle\n },\n },\n\n render (h): VNode {\n return h('div', {\n staticClass: 'v-skeleton-loader',\n attrs: this.attrs,\n on: this.$listeners,\n class: this.classes,\n style: this.isLoading ? this.measurableStyles : undefined,\n }, [this.genSkeleton()])\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 { getSlot, keyCodes } from './../../util/helpers'\nimport mixins from '../../util/mixins'\nimport { ExtractVue } from './../../util/mixins'\n\n// Types\nimport { VNode } from 'vue/types'\n\n// Components\nimport VTabsBar from '../VTabs/VTabsBar'\n\nconst baseMixins = mixins(\n Routable,\n // Must be after routable\n // to overwrite activeClass\n GroupableFactory('tabsBar'),\n Themeable\n)\n\ntype VTabBarInstance = InstanceType\n\ninterface options extends ExtractVue {\n $el: HTMLElement\n tabsBar: VTabBarInstance\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 tabValue: {\n required: false,\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 if (this.tabValue != null) return this.tabValue\n\n let to = this.to || this.href\n\n if (to == null) return to\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 methods: {\n click (e: KeyboardEvent | MouseEvent): void {\n // Prevent keyboard actions\n // from children elements\n // within disabled tabs\n if (this.disabled) {\n e.preventDefault()\n return\n }\n\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 toggle () {\n // VItemGroup treats a change event as a click\n if (!this.isActive || (!this.tabsBar.mandatory && !this.to)) {\n this.$emit('change')\n }\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: this.disabled ? -1 : 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, getSlot(this))\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","// Extensions\nimport VWindowItem from '../VWindow/VWindowItem'\n\n/* @vue/component */\nexport default VWindowItem.extend({\n name: 'v-tab-item',\n\n props: {\n id: String,\n },\n\n methods: {\n genWindowItem () {\n const item = VWindowItem.options.methods.genWindowItem.call(this)\n\n item.data!.domProps = item.data!.domProps || {}\n item.data!.domProps.id = this.id || this.value\n\n return item\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'\nimport { getSlot } from '../../util/helpers'\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 genDefaultSlot () {\n return getSlot(this)\n },\n genContainer (): VNode {\n const children = [this.genDefaultSlot()]\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","// 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'\nimport { composedPath, getSlot } from '../../util/helpers'\n\ninterface TouchEvent {\n touchstartX: number\n touchstartY: number\n touchmoveX: number\n touchmoveY: 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\nfunction bias (val: number) {\n const c = 0.501\n const x = Math.abs(val)\n return Math.sign(val) * (x / ((1 / c - 2) * (1 - x) + 1))\n}\n\nexport function calculateUpdatedOffset (\n selectedElement: HTMLElement,\n widths: Widths,\n rtl: boolean,\n currentScrollOffset: number\n): 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\nexport function calculateCenteredOffset (\n selectedElement: HTMLElement,\n widths: Widths,\n rtl: boolean\n): 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\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: any) => (\n typeof v === 'boolean' || [\n 'always',\n 'never',\n 'desktop',\n 'mobile',\n ].includes(v)\n ),\n },\n },\n\n data: () => ({\n isOverflowing: false,\n resizeTimeout: 0,\n startX: 0,\n isSwipingHorizontal: false,\n isSwiping: false,\n scrollOffset: 0,\n widths: {\n content: 0,\n wrapper: 0,\n },\n }),\n\n computed: {\n canTouch (): boolean {\n return typeof window !== 'undefined'\n },\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 // Always hide arrows\n case 'never': return false\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 if (this.$vuetify.rtl) val = -val\n\n let scroll =\n val <= 0\n ? bias(-val)\n : val > this.widths.content - this.widths.wrapper\n ? -(this.widths.content - this.widths.wrapper) + bias(this.widths.content - this.widths.wrapper - val)\n : -val\n\n if (this.$vuetify.rtl) scroll = -scroll\n\n this.$refs.content.style.transform = `translateX(${scroll}px)`\n },\n },\n\n mounted () {\n if (typeof ResizeObserver !== 'undefined') {\n const obs = new ResizeObserver(() => {\n this.onResize()\n })\n obs.observe(this.$el)\n obs.observe(this.$refs.content)\n this.$on('hook:destroyed', () => {\n obs.disconnect()\n })\n } else {\n let itemsLength = 0\n this.$on('hook:beforeUpdate', () => {\n itemsLength = (this.$refs.content?.children || []).length\n })\n this.$on('hook:updated', () => {\n if (itemsLength === (this.$refs.content?.children || []).length) return\n this.setWidths()\n })\n }\n },\n\n methods: {\n onScroll () {\n this.$refs.wrapper.scrollLeft = 0\n },\n onFocusin (e: FocusEvent) {\n if (!this.isOverflowing) return\n\n // Focused element is likely to be the root of an item, so a\n // breadth-first search will probably find it in the first iteration\n for (const el of composedPath(e)) {\n for (const vm of this.items) {\n if (vm.$el === el) {\n this.scrollOffset = calculateUpdatedOffset(\n vm.$el as HTMLElement,\n this.widths,\n this.$vuetify.rtl,\n this.scrollOffset\n )\n return\n }\n }\n }\n },\n // Always generate next for scrollable hint\n genNext (): VNode | null {\n const slot = this.$scopedSlots.next\n ? this.$scopedSlots.next({})\n : getSlot(this, '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 on: {\n focusin: this.onFocusin,\n },\n }, getSlot(this))\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 : getSlot(this, '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 on: {\n scroll: this.onScroll,\n },\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 if (!this.canTouch) return\n\n if (!this.isSwiping) {\n // only calculate disableSwipeHorizontal during the first onTouchMove invoke\n // in order to ensure disableSwipeHorizontal value is consistent between onTouchStart and onTouchEnd\n const diffX = e.touchmoveX - e.touchstartX\n const diffY = e.touchmoveY - e.touchstartY\n this.isSwipingHorizontal = Math.abs(diffX) > Math.abs(diffY)\n this.isSwiping = true\n }\n\n if (this.isSwipingHorizontal) {\n // sliding horizontally\n this.scrollOffset = this.startX - e.touchmoveX\n // temporarily disable window vertical scrolling\n document.documentElement.style.overflowY = 'hidden'\n }\n },\n onTouchEnd () {\n if (!this.canTouch) return\n\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 this.isSwiping = false\n // rollback whole page scrolling to default\n document.documentElement.style.removeProperty('overflow-y')\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 = calculateCenteredOffset(\n this.selectedItem.$el as HTMLElement,\n this.widths,\n this.$vuetify.rtl\n )\n } else if (this.isOverflowing) {\n this.scrollOffset = calculateUpdatedOffset(\n this.selectedItem.$el as HTMLElement,\n this.widths,\n this.$vuetify.rtl,\n this.scrollOffset\n )\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 () {\n window.requestAnimationFrame(() => {\n if (this._isDestroyed) return\n\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 // https://github.com/vuetifyjs/vuetify/issues/13212\n // We add +1 to the wrappers width to prevent an issue where the `clientWidth`\n // gets calculated wrongly by the browser if using a different zoom-level.\n this.isOverflowing = this.widths.wrapper + 1 < 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","// 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 === oldPath) hasOld = true\n else if (item.to === newPath) hasNew = 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","// 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","// 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, getSlot } 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 if (typeof ResizeObserver !== 'undefined') {\n const obs = new ResizeObserver(() => {\n this.onResize()\n })\n obs.observe(this.$el)\n this.$on('hook:destroyed', () => {\n obs.disconnect()\n })\n }\n\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 = getSlot(this) || []\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":""}