{"version":3,"sources":["webpack:///./node_modules/core-js/modules/es.math.sign.js","webpack:///../../../src/components/VTabs/VTab.ts","webpack:///../../../src/components/VSlideGroup/VSlideGroup.ts","webpack:///../../../src/components/VTabs/VTabsSlider.ts","webpack:///../../../src/components/VTabs/VTabsItems.ts","webpack:///../../../src/components/VTabs/VTabsBar.ts","webpack:///../../../src/components/VTabs/VTabs.ts"],"names":["$","sign","target","stat","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","bias","val","c","x","Math","abs","calculateUpdatedOffset","selectedElement","widths","rtl","currentScrollOffset","clientWidth","offsetLeft","content","totalWidth","wrapper","itemOffset","additionalOffset","max","min","calculateCenteredOffset","offsetCentered","BaseSlideGroup","BaseItemGroup","Mobile","directives","Resize","Touch","activeClass","centerActive","nextIcon","prevIcon","showArrows","validator","v","includes","isOverflowing","resizeTimeout","startX","isSwipingHorizontal","isSwiping","scrollOffset","canTouch","window","__cachedNext","genTransition","__cachedPrev","hasAffixes","isMobile","hasNext","hasPrev","watch","internalValue","$vuetify","scroll","$refs","style","transform","mounted","ResizeObserver","obs","onResize","observe","$on","disconnect","itemsLength","_a","children","length","setWidths","onScroll","scrollLeft","onFocusin","composedPath","el","items","vm","genNext","slot","$scopedSlots","next","$createElement","staticClass","class","onAffixClick","key","genContent","ref","focusin","genData","genIcon","location","icon","upperLocation","toUpperCase","slice","hasAffix","VIcon","genPrev","prev","VFadeTransition","genWrapper","start","overflowCheck","onTouchStart","move","onTouchMove","end","onTouchEnd","calculateNewOffset","direction","newAbosluteOffset","scrollTo","_isDestroyed","touchstartX","setProperty","diffX","touchmoveX","diffY","touchmoveY","touchstartY","document","documentElement","overflowY","maxScrollOffset","removeProperty","fn","stopPropagation","scrollIntoView","selectedItem","lastItemPosition","getBoundingClientRect","wrapperPosition","right","left","selectedIndex","requestAnimationFrame","provide","slideGroup","Colorable","setBackgroundColor","color","VWindow","isDark","rootIsDark","getValue","item","i","id","SSRBootable","themeClasses","callSlider","isBooted","onRouteChange","oldVal","newPath","path","oldPath","hasNew","hasOld","undefined","Proxyable","alignWithTitle","backgroundColor","centered","fixedTabs","grow","height","Number","hideSlider","iconsAndText","mobileBreakpoint","optional","sliderColor","sliderSize","vertical","slider","top","width","transitionTime","isReversed","sliderStyles","convertToUnit","transition","computedColor","appIsDark","$nextTick","setTimeout","selectedItems","activeTab","scrollHeight","offsetWidth","offsetTop","scrollWidth","genBar","dark","light","change","setTextColor","VTabsBar","genSlider","genItems","VTabsItems","VTabsSlider","clearTimeout","parseNodes","tab","vnode","componentOptions","Ctor","push","modifiers","quiet"],"mappings":"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","file":"static/js/chunk-464b0c7a.5ba2100d.js","sourcesContent":["var $ = require('../internals/export');\nvar sign = require('../internals/math-sign');\n\n// `Math.sign` method\n// https://tc39.es/ecma262/#sec-math.sign\n$({ target: 'Math', stat: true }, {\n sign: sign\n});\n","// Mixins\nimport { 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","// 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","// 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 { 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":""}