{"version":3,"sources":["webpack:///../../../src/components/VTabs/VTab.ts","webpack:///../../../src/components/VTabs/VTabsSlider.ts","webpack:///../../../src/components/VTabs/VTabsItems.ts","webpack:///../../../src/components/VTabs/VTabItem.ts","webpack:///../../../src/mixins/ssr-bootable/index.ts","webpack:///../../../src/mixins/mobile/index.ts","webpack:///../../../src/components/VSlideGroup/VSlideGroup.ts","webpack:///../../../src/components/VTabs/VTabsBar.ts","webpack:///../../../src/components/VTabs/VTabs.ts"],"names":["baseMixins","name","props","ripple","type","Boolean","default","data","proxyClass","computed","classes","this","groupClasses","value","to","$router","Object","resolve","mounted","methods","click","href","indexOf","e","$el","blur","render","String","role","tabindex","keydown","h","tag","$slots","setBackgroundColor","staticClass","mandatory","isDark","getValue","item","id","genWindowItem","isBooted","window","mobileBreakpoint","Number","$vuetify","breakpoint","validator","v","isNaN","includes","isMobile","mobile","mobileWidth","parseInt","isNumber","width","created","$attrs","hasOwnProperty","BaseSlideGroup","mixins","directives","Resize","Touch","activeClass","centerActive","nextIcon","prevIcon","showArrows","internalItemsLength","isOverflowing","resizeTimeout","startX","scrollOffset","widths","content","wrapper","__cachedNext","genTransition","__cachedPrev","hasAffixes","hasNext","Math","hasPrev","watch","internalValue","beforeUpdate","$children","updated","genNext","slot","$scopedSlots","next","$createElement","class","on","key","genContent","ref","genData","onResize","genIcon","icon","rtl","location","upperLocation","hasAffix","VIcon","disabled","genPrev","prev","genWrapper","start","move","end","calculateNewOffset","sign","newAbosluteOffset","direction","onAffixClick","onTouchStart","onTouchMove","onTouchEnd","maxScrollOffset","overflowCheck","fn","scrollIntoView","selectedIndex","calculateCenteredOffset","selectedItem","calculateUpdatedOffset","clientWidth","selectedElement","offsetLeft","currentScrollOffset","totalWidth","itemOffset","additionalOffset","offsetCentered","scrollTo","$refs","setWidths","provide","slideGroup","tabsBar","themeClasses","items","$route","callSlider","onRouteChange","newPath","val","oldPath","oldVal","hasNew","hasOld","undefined","alignWithTitle","backgroundColor","centered","fixedTabs","grow","height","hideSlider","iconsAndText","optional","right","sliderColor","sliderSize","vertical","slider","left","top","transitionTime","isReversed","sliderStyles","transition","computedColor","selectedItems","activeTab","el","scrollWidth","genBar","style","dark","light","change","VTabsBar","genSlider","genItems","VTabsItems","VTabsSlider","color","clearTimeout","parseNodes","tab","length","i","vnode","modifiers","quiet"],"mappings":"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","file":"js/chunk-1afcf701.b4cb0e58.js","sourcesContent":["// 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","// 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","// 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","import Vue from 'vue'\n\n/**\n * SSRBootable\n *\n * @mixin\n *\n * Used in layout components (drawer, toolbar, content)\n * to avoid an entry animation when using SSR\n */\nexport default Vue.extend({\n name: 'ssr-bootable',\n\n data: () => ({\n isBooted: false,\n }),\n\n mounted () {\n // Use setAttribute instead of dataset\n // because dataset does not work well\n // with unit tests\n window.requestAnimationFrame(() => {\n this.$el.setAttribute('data-booted', 'true')\n this.isBooted = true\n })\n },\n})\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 './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\n\n // Always show on mobile\n case 'mobile': return (\n this.isMobile ||\n this.isOverflowing\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\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) {\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","// 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","// 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 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":""}