{"version":3,"sources":["webpack:///../../../src/components/VTabs/VTab.ts","webpack:///../../../src/components/VTabs/VTabsSlider.ts","webpack:///../../../src/components/VWindow/VWindow.ts","webpack:///../../../src/components/VTabs/VTabsItems.ts","webpack:///../../../src/components/VWindow/VWindowItem.ts","webpack:///../../../src/components/VTabs/VTabItem.ts","webpack:///../../../src/components/VSlideGroup/VSlideGroup.ts","webpack:///../../../src/components/VTabs/VTabsBar.ts","webpack:///../../../src/components/VTabs/VTabs.ts"],"names":["baseMixins","mixins","Routable","GroupableFactory","Themeable","extend","name","props","ripple","type","Boolean","Object","default","data","proxyClass","computed","classes","options","call","this","disabled","groupClasses","value","to","href","$router","resolve","$route","append","replace","methods","click","e","preventDefault","indexOf","detail","$el","blur","$emit","toggle","isActive","tabsBar","mandatory","render","h","generateRouteLink","tag","attrs","String","role","tabindex","on","keydown","keyCode","keyCodes","enter","$slots","Colorable","setBackgroundColor","color","staticClass","BaseItemGroup","directives","Touch","provide","windowGroup","activeClass","continuous","nextIcon","prevIcon","reverse","showArrows","showArrowsOnHover","touch","touchless","required","vertical","changedByDelimiters","internalHeight","undefined","transitionHeight","transitionCount","isBooted","isReverse","computedTransition","axis","internalReverse","direction","hasActiveItems","items","find","item","hasNext","internalIndex","length","hasPrev","findIndex","i","internalValue","getValue","$vuetify","rtl","watch","val","oldVal","updateReverse","mounted","window","requestAnimationFrame","genDefaultSlot","genContainer","children","push","genControlIcons","$createElement","class","style","height","genIcon","icon","stopPropagation","lang","t","$scopedSlots","_b","_c","VBtn","VIcon","large","icons","prev","next","getNextIndex","index","nextIndex","getPrevIndex","prevIndex","lastIndex","itemsLength","left","right","end","start","VWindow","isDark","rootIsDark","id","Bootable","reverseTransition","transition","inTransition","genWindowItem","$listeners","onAfterTransition","onBeforeTransition","convertToUnit","clientHeight","onTransitionCancelled","onEnter","el","$nextTick","beforeEnter","afterEnter","enterCancelled","beforeLeave","afterLeave","leaveCancelled","showLazyContent","VWindowItem","domProps","bias","c","x","Math","abs","sign","calculateUpdatedOffset","selectedElement","widths","currentScrollOffset","clientWidth","offsetLeft","content","totalWidth","wrapper","itemOffset","additionalOffset","max","min","calculateCenteredOffset","offsetCentered","BaseSlideGroup","Mobile","Resize","centerActive","validator","v","includes","isOverflowing","resizeTimeout","startX","isSwipingHorizontal","isSwiping","scrollOffset","canTouch","__cachedNext","genTransition","__cachedPrev","hasAffixes","isMobile","scroll","$refs","transform","ResizeObserver","obs","onResize","observe","$on","disconnect","_a","setWidths","onScroll","scrollLeft","onFocusin","composedPath","vm","genNext","slot","onAffixClick","key","genContent","ref","focusin","genData","location","upperLocation","toUpperCase","slice","hasAffix","genPrev","VFadeTransition","genWrapper","overflowCheck","onTouchStart","move","onTouchMove","onTouchEnd","calculateNewOffset","newAbosluteOffset","scrollTo","_isDestroyed","touchstartX","setProperty","diffX","touchmoveX","diffY","touchmoveY","touchstartY","document","documentElement","overflowY","maxScrollOffset","removeProperty","fn","scrollIntoView","selectedItem","lastItemPosition","getBoundingClientRect","wrapperPosition","selectedIndex","slideGroup","SSRBootable","themeClasses","callSlider","onRouteChange","newPath","path","oldPath","hasNew","hasOld","Proxyable","alignWithTitle","backgroundColor","centered","fixedTabs","grow","Number","hideSlider","iconsAndText","mobileBreakpoint","optional","sliderColor","sliderSize","slider","top","width","transitionTime","isReversed","sliderStyles","computedColor","appIsDark","setTimeout","selectedItems","activeTab","scrollHeight","offsetWidth","offsetTop","scrollWidth","genBar","dark","light","change","setTextColor","VTabsBar","genSlider","genItems","VTabsItems","VTabsSlider","clearTimeout","parseNodes","tab","vnode","componentOptions","Ctor","modifiers","quiet"],"mappings":"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","file":"js/chunk-209a3d91.e12c21a1.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\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 },\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 (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, 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","// Styles\nimport './VWindow.sass'\n\n// Types\nimport { VNode, VNodeDirective } from 'vue/types/vnode'\nimport { PropType } from 'vue'\nimport { TouchHandlers } from 'vuetify/types'\n\n// Directives\nimport Touch from '../../directives/touch'\n\n// Components\nimport VBtn from '../VBtn'\nimport VIcon from '../VIcon'\nimport { BaseItemGroup } from '../VItemGroup/VItemGroup'\n\n/* @vue/component */\nexport default BaseItemGroup.extend({\n name: 'v-window',\n\n directives: { Touch },\n\n provide (): object {\n return {\n windowGroup: this,\n }\n },\n\n props: {\n activeClass: {\n type: String,\n default: 'v-window-item--active',\n },\n continuous: Boolean,\n mandatory: {\n type: Boolean,\n default: true,\n },\n nextIcon: {\n type: [Boolean, String],\n default: '$next',\n },\n prevIcon: {\n type: [Boolean, String],\n default: '$prev',\n },\n reverse: Boolean,\n showArrows: Boolean,\n showArrowsOnHover: Boolean,\n touch: Object as PropType,\n touchless: Boolean,\n value: {\n required: false,\n },\n vertical: Boolean,\n },\n\n data () {\n return {\n changedByDelimiters: false,\n internalHeight: undefined as undefined | string, // This can be fixed by child class.\n transitionHeight: undefined as undefined | string, // Intermediate height during transition.\n transitionCount: 0, // Number of windows in transition state.\n isBooted: false,\n isReverse: false,\n }\n },\n\n computed: {\n isActive (): boolean {\n return this.transitionCount > 0\n },\n classes (): object {\n return {\n ...BaseItemGroup.options.computed.classes.call(this),\n 'v-window--show-arrows-on-hover': this.showArrowsOnHover,\n }\n },\n computedTransition (): string {\n if (!this.isBooted) return ''\n\n const axis = this.vertical ? 'y' : 'x'\n const reverse = this.internalReverse ? !this.isReverse : this.isReverse\n const direction = reverse ? '-reverse' : ''\n\n return `v-window-${axis}${direction}-transition`\n },\n hasActiveItems (): boolean {\n return Boolean(\n this.items.find(item => !item.disabled)\n )\n },\n hasNext (): boolean {\n return this.continuous || this.internalIndex < this.items.length - 1\n },\n hasPrev (): boolean {\n return this.continuous || this.internalIndex > 0\n },\n internalIndex (): number {\n return this.items.findIndex((item, i) => {\n return this.internalValue === this.getValue(item, i)\n })\n },\n internalReverse (): boolean {\n return this.$vuetify.rtl ? !this.reverse : this.reverse\n },\n },\n\n watch: {\n internalIndex (val, oldVal) {\n this.isReverse = this.updateReverse(val, oldVal)\n },\n },\n\n mounted () {\n window.requestAnimationFrame(() => (this.isBooted = true))\n },\n\n methods: {\n genDefaultSlot () {\n return this.$slots.default\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","// 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","// 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 } 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 this.$slots.default\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","// 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 './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 } 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 '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 // 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 : 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 on: {\n focusin: this.onFocusin,\n },\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 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","// Styles\nimport './VTabs.sass'\n\n// Components\nimport VTabsBar from './VTabsBar'\nimport VTabsItems from './VTabsItems'\nimport VTabsSlider from './VTabsSlider'\n\n// Mixins\nimport Colorable from '../../mixins/colorable'\nimport Proxyable from '../../mixins/proxyable'\nimport Themeable from '../../mixins/themeable'\n\n// Directives\nimport Resize from '../../directives/resize'\n\n// Utilities\nimport { convertToUnit } from '../../util/helpers'\nimport { ExtractVue } from './../../util/mixins'\nimport mixins from '../../util/mixins'\n\n// Types\nimport { VNode } from 'vue/types'\n\nconst baseMixins = mixins(\n Colorable,\n Proxyable,\n Themeable\n)\n\ninterface options extends ExtractVue {\n $refs: {\n items: InstanceType\n }\n}\n\nexport default baseMixins.extend().extend({\n name: 'v-tabs',\n\n directives: {\n Resize,\n },\n\n props: {\n activeClass: {\n type: String,\n default: '',\n },\n alignWithTitle: Boolean,\n backgroundColor: String,\n centerActive: Boolean,\n centered: Boolean,\n fixedTabs: Boolean,\n grow: Boolean,\n height: {\n type: [Number, String],\n default: undefined,\n },\n hideSlider: Boolean,\n iconsAndText: Boolean,\n mobileBreakpoint: [String, Number],\n nextIcon: {\n type: String,\n default: '$next',\n },\n optional: Boolean,\n prevIcon: {\n type: String,\n default: '$prev',\n },\n right: Boolean,\n showArrows: [Boolean, String],\n sliderColor: String,\n sliderSize: {\n type: [Number, String],\n default: 2,\n },\n vertical: Boolean,\n },\n\n data () {\n return {\n resizeTimeout: 0,\n slider: {\n height: null as null | number,\n left: null as null | number,\n right: null as null | number,\n top: null as null | number,\n width: null as null | number,\n },\n transitionTime: 300,\n }\n },\n\n computed: {\n classes (): object {\n return {\n 'v-tabs--align-with-title': this.alignWithTitle,\n 'v-tabs--centered': this.centered,\n 'v-tabs--fixed-tabs': this.fixedTabs,\n 'v-tabs--grow': this.grow,\n 'v-tabs--icons-and-text': this.iconsAndText,\n 'v-tabs--right': this.right,\n 'v-tabs--vertical': this.vertical,\n ...this.themeClasses,\n }\n },\n isReversed (): boolean {\n return this.$vuetify.rtl && this.vertical\n },\n sliderStyles (): object {\n return {\n height: convertToUnit(this.slider.height),\n left: this.isReversed ? undefined : convertToUnit(this.slider.left),\n right: this.isReversed ? convertToUnit(this.slider.right) : undefined,\n top: this.vertical ? convertToUnit(this.slider.top) : undefined,\n transition: this.slider.left != null ? null : 'none',\n width: convertToUnit(this.slider.width),\n }\n },\n computedColor (): string {\n if (this.color) return this.color\n else if (this.isDark && !this.appIsDark) return 'white'\n else return 'primary'\n },\n },\n\n watch: {\n alignWithTitle: 'callSlider',\n centered: 'callSlider',\n centerActive: 'callSlider',\n fixedTabs: 'callSlider',\n grow: 'callSlider',\n iconsAndText: 'callSlider',\n right: 'callSlider',\n showArrows: 'callSlider',\n vertical: 'callSlider',\n '$vuetify.application.left': 'onResize',\n '$vuetify.application.right': 'onResize',\n '$vuetify.rtl': 'onResize',\n },\n\n mounted () {\n 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 = 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":""}