{"version":3,"sources":["webpack:///../../../src/components/VWindow/VWindow.ts","webpack:///../../../src/components/VTabs/VTabsItems.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":["name","provide","windowGroup","this","directives","Touch","props","activeClass","type","default","continuous","mandatory","nextIcon","Boolean","prevIcon","reverse","undefined","showArrows","showArrowsOnHover","touch","touchless","value","required","vertical","data","changedByDelimiters","internalHeight","transitionHeight","transitionCount","isBooted","isReverse","computed","isActive","classes","computedTransition","axis","$vuetify","rtl","direction","hasActiveItems","items","find","item","hasNext","internalIndex","length","hasPrev","findIndex","internalReverse","watch","mounted","window","methods","genContainer","children","$slots","$createElement","staticClass","class","style","height","genIcon","VBtn","icon","attrs","lang","t","on","click","fn","VIcon","large","genControlIcons","icons","getNextIndex","nextIndex","index","getPrevIndex","prevIndex","next","getValue","prev","lastIndex","updateReverse","val","render","left","right","end","e","start","h","isDark","BaseSlideGroup","mixins","Resize","centerActive","validator","v","internalItemsLength","isOverflowing","resizeTimeout","startX","scrollOffset","widths","content","wrapper","__cachedNext","genTransition","__cachedPrev","hasAffixes","isMobile","Math","internalValue","beforeUpdate","$children","updated","genNext","slot","$scopedSlots","key","genContent","ref","genData","onResize","location","upperLocation","hasAffix","disabled","genPrev","genWrapper","move","calculateNewOffset","sign","newAbosluteOffset","onAffixClick","onTouchStart","onTouchMove","onTouchEnd","maxScrollOffset","overflowCheck","scrollIntoView","selectedIndex","calculateCenteredOffset","selectedItem","calculateUpdatedOffset","clientWidth","selectedElement","offsetLeft","currentScrollOffset","totalWidth","itemOffset","additionalOffset","offsetCentered","scrollTo","$refs","setWidths","slideGroup","tabsBar","themeClasses","$route","callSlider","onRouteChange","newPath","oldPath","oldVal","hasNew","hasOld","role","setBackgroundColor","baseMixins","alignWithTitle","backgroundColor","centered","fixedTabs","grow","Number","hideSlider","iconsAndText","mobileBreakpoint","String","optional","sliderColor","sliderSize","slider","top","width","transitionTime","isReversed","sliderStyles","transition","computedColor","selectedItems","activeTab","el","scrollWidth","genBar","dark","light","change","VTabsBar","genSlider","genItems","VTabsItems","VTabsSlider","color","clearTimeout","parseNodes","tab","i","vnode","modifiers","quiet"],"mappings":"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","file":"js/chunk-5d990c52.303531b7.js","sourcesContent":["// 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 provide (): object {\n return {\n windowGroup: this,\n }\n },\n\n directives: { Touch },\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: {\n type: Boolean,\n default: undefined,\n },\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.$vuetify.rtl && axis === 'x' ? !this.internalReverse : this.internalReverse\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.reverse ? !this.isReverse : this.isReverse\n },\n },\n\n watch: {\n internalIndex: 'updateReverse',\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 fn: () => void\n ) {\n return this.$createElement('div', {\n staticClass: `v-window__${direction}`,\n }, [\n this.$createElement(VBtn, {\n props: { icon: true },\n attrs: {\n 'aria-label': this.$vuetify.lang.t(`$vuetify.carousel.${direction}`),\n },\n on: {\n click: () => {\n this.changedByDelimiters = true\n fn()\n },\n },\n }, [\n this.$createElement(VIcon, {\n props: { large: true },\n }, icon),\n ]),\n ])\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 this.isReverse = this.$vuetify.rtl\n\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 this.isReverse = !this.$vuetify.rtl\n\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 if (this.changedByDelimiters) {\n this.changedByDelimiters = false\n return\n }\n\n this.isReverse = val < oldVal\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 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 './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 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","// 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 } 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":""}