{"version":3,"sources":["webpack:///./node_modules/core-js/modules/es.math.sign.js","webpack:///../../../src/components/VTabs/VTab.ts","webpack:///../../../src/components/VBtn/index.ts","webpack:///../../../src/directives/touch/index.ts","webpack:///../../../src/components/VWindow/VWindowItem.ts","webpack:///../../../src/components/VTabs/VTabItem.ts","webpack:///../../../src/mixins/ssr-bootable/index.ts","webpack:///../../../src/mixins/mobile/index.ts","webpack:///../../../src/components/VSlideGroup/VSlideGroup.ts","webpack:///../../../src/components/VTabs/VTabsBar.ts","webpack:///../../../src/components/VWindow/VWindow.ts","webpack:///../../../src/components/VTabs/VTabsItems.ts","webpack:///../../../src/components/VTabs/VTabsSlider.ts","webpack:///../../../src/components/VTabs/VTabs.ts"],"names":["$","sign","target","stat","baseMixins","name","props","ripple","type","Boolean","default","data","proxyClass","computed","classes","this","groupClasses","value","to","$router","Object","resolve","methods","click","e","href","indexOf","$el","blur","toggle","tabsBar","render","String","role","tabindex","keydown","h","tag","$slots","handleGesture","wrapper","touchendY","dirRatio","minDistance","touchendX","Math","touchstartX","touchstartY","touch","event","createHandlers","touchmoveX","touchmoveY","offsetX","offsetY","left","right","up","down","start","move","end","touchstart","touchend","touchmove","inserted","binding","el","options","passive","handlers","vnode","eventName","unbind","Touch","mixins","directives","disabled","reverseTransition","undefined","transition","required","isActive","inTransition","computedTransition","windowGroup","genDefaultSlot","genWindowItem","$createElement","staticClass","class","on","$listeners","onAfterTransition","transitionCount","onBeforeTransition","onTransitionCancelled","onEnter","beforeEnter","afterEnter","enterCancelled","beforeLeave","afterLeave","leaveCancelled","enter","showLazyContent","VWindowItem","id","item","isBooted","mounted","window","mobileBreakpoint","Number","$vuetify","breakpoint","validator","v","isNaN","includes","isMobile","mobile","mobileWidth","parseInt","isNumber","width","created","$attrs","hasOwnProperty","bias","c","x","clientWidth","selectedElement","offsetLeft","rtl","widths","currentScrollOffset","totalWidth","itemOffset","additionalOffset","offsetCentered","BaseSlideGroup","Resize","activeClass","centerActive","nextIcon","prevIcon","showArrows","internalItemsLength","isOverflowing","resizeTimeout","startX","isSwipingHorizontal","isSwiping","scrollOffset","content","canTouch","__cachedNext","genTransition","__cachedPrev","hasAffixes","hasNext","hasPrev","watch","internalValue","val","scroll","beforeUpdate","$children","updated","onScroll","onFocusin","vm","calculateUpdatedOffset","genNext","slot","$scopedSlots","next","key","genContent","ref","focusin","genData","onResize","genIcon","icon","location","upperLocation","hasAffix","VIcon","genPrev","prev","genWrapper","calculateNewOffset","newAbosluteOffset","direction","onAffixClick","onTouchStart","onTouchMove","diffX","diffY","document","onTouchEnd","maxScrollOffset","overflowCheck","fn","scrollIntoView","items","lastItemPosition","length","wrapperPosition","$refs","selectedIndex","calculateCenteredOffset","selectedItem","scrollTo","setWidths","provide","slideGroup","themeClasses","$route","callSlider","onRouteChange","newPath","oldPath","oldVal","hasNew","hasOld","continuous","mandatory","reverse","showArrowsOnHover","touchless","vertical","changedByDelimiters","internalHeight","transitionHeight","isReverse","axis","internalReverse","hasActiveItems","find","internalIndex","findIndex","updateReverse","genContainer","children","style","height","attrs","lang","t","VBtn","large","genControlIcons","icons","getNextIndex","nextIndex","index","getPrevIndex","prevIndex","getValue","lastIndex","itemsLength","isDark","setBackgroundColor","alignWithTitle","backgroundColor","centered","fixedTabs","grow","hideSlider","iconsAndText","optional","sliderColor","sliderSize","slider","top","transitionTime","isReversed","sliderStyles","computedColor","selectedItems","activeTab","scrollWidth","genBar","dark","light","change","VTabsBar","genSlider","genItems","VTabsItems","VTabsSlider","color","clearTimeout","parseNodes","tab","i","modifiers","quiet"],"mappings":"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","file":"js/chunk-10f78286.eaa4750d.js","sourcesContent":["var $ = require('../internals/export');\nvar sign = require('../internals/math-sign');\n\n// `Math.sign` method\n// https://tc39.github.io/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: 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","import VBtn from './VBtn'\n\nexport { VBtn }\nexport default VBtn\n","import { VNodeDirective, VNode } from 'vue/types/vnode'\nimport { keys } from '../../util/helpers'\nimport { TouchHandlers, TouchValue, TouchWrapper } from 'vuetify/types'\n\nexport interface TouchStoredHandlers {\n touchstart: (e: TouchEvent) => void\n touchend: (e: TouchEvent) => void\n touchmove: (e: TouchEvent) => void\n}\n\ninterface TouchVNodeDirective extends VNodeDirective {\n value?: TouchValue\n}\n\nconst handleGesture = (wrapper: TouchWrapper) => {\n const { touchstartX, touchendX, touchstartY, touchendY } = wrapper\n const dirRatio = 0.5\n const minDistance = 16\n wrapper.offsetX = touchendX - touchstartX\n wrapper.offsetY = touchendY - touchstartY\n\n if (Math.abs(wrapper.offsetY) < dirRatio * Math.abs(wrapper.offsetX)) {\n wrapper.left && (touchendX < touchstartX - minDistance) && wrapper.left(wrapper)\n wrapper.right && (touchendX > touchstartX + minDistance) && wrapper.right(wrapper)\n }\n\n if (Math.abs(wrapper.offsetX) < dirRatio * Math.abs(wrapper.offsetY)) {\n wrapper.up && (touchendY < touchstartY - minDistance) && wrapper.up(wrapper)\n wrapper.down && (touchendY > touchstartY + minDistance) && wrapper.down(wrapper)\n }\n}\n\nfunction touchstart (event: TouchEvent, wrapper: TouchWrapper) {\n const touch = event.changedTouches[0]\n wrapper.touchstartX = touch.clientX\n wrapper.touchstartY = touch.clientY\n\n wrapper.start &&\n wrapper.start(Object.assign(event, wrapper))\n}\n\nfunction touchend (event: TouchEvent, wrapper: TouchWrapper) {\n const touch = event.changedTouches[0]\n wrapper.touchendX = touch.clientX\n wrapper.touchendY = touch.clientY\n\n wrapper.end &&\n wrapper.end(Object.assign(event, wrapper))\n\n handleGesture(wrapper)\n}\n\nfunction touchmove (event: TouchEvent, wrapper: TouchWrapper) {\n const touch = event.changedTouches[0]\n wrapper.touchmoveX = touch.clientX\n wrapper.touchmoveY = touch.clientY\n\n wrapper.move && wrapper.move(Object.assign(event, wrapper))\n}\n\nfunction createHandlers (value: TouchHandlers): TouchStoredHandlers {\n const wrapper = {\n touchstartX: 0,\n touchstartY: 0,\n touchendX: 0,\n touchendY: 0,\n touchmoveX: 0,\n touchmoveY: 0,\n offsetX: 0,\n offsetY: 0,\n left: value.left,\n right: value.right,\n up: value.up,\n down: value.down,\n start: value.start,\n move: value.move,\n end: value.end,\n }\n\n return {\n touchstart: (e: TouchEvent) => touchstart(e, wrapper),\n touchend: (e: TouchEvent) => touchend(e, wrapper),\n touchmove: (e: TouchEvent) => touchmove(e, wrapper),\n }\n}\n\nfunction inserted (el: HTMLElement, binding: TouchVNodeDirective, vnode: VNode) {\n const value = binding.value!\n const target = value.parent ? el.parentElement : el\n const options = value.options || { passive: true }\n\n // Needed to pass unit tests\n if (!target) return\n\n const handlers = createHandlers(binding.value!)\n target._touchHandlers = Object(target._touchHandlers)\n target._touchHandlers![vnode.context!._uid] = handlers\n\n keys(handlers).forEach(eventName => {\n target.addEventListener(eventName, handlers[eventName] as EventListener, options)\n })\n}\n\nfunction unbind (el: HTMLElement, binding: TouchVNodeDirective, vnode: VNode) {\n const target = binding.value!.parent ? el.parentElement : el\n if (!target || !target._touchHandlers) return\n\n const handlers = target._touchHandlers[vnode.context!._uid]\n keys(handlers).forEach(eventName => {\n target.removeEventListener(eventName, handlers[eventName])\n })\n delete target._touchHandlers[vnode.context!._uid]\n}\n\nexport const Touch = {\n inserted,\n unbind,\n}\n\nexport default Touch\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","import Vue from 'vue'\n\n/**\n * SSRBootable\n *\n * @mixin\n *\n * Used in layout components (drawer, toolbar, content)\n * to avoid an entry animation when using SSR\n */\nexport default Vue.extend({\n name: 'ssr-bootable',\n\n data: () => ({\n isBooted: false,\n }),\n\n mounted () {\n // Use setAttribute instead of dataset\n // because dataset does not work well\n // with unit tests\n window.requestAnimationFrame(() => {\n this.$el.setAttribute('data-booted', 'true')\n this.isBooted = true\n })\n },\n})\n","// Types\nimport { BreakpointName } from 'vuetify/types/services/breakpoint'\nimport { deprecate } from '../../util/console'\nimport Vue, { PropType } from 'vue'\n\n/* @vue/component */\nexport default Vue.extend({\n name: 'mobile',\n\n props: {\n mobileBreakpoint: {\n type: [Number, String] as PropType,\n default (): number | BreakpointName | undefined {\n // Avoid destroying unit\n // tests for users\n return this.$vuetify\n ? this.$vuetify.breakpoint.mobileBreakpoint\n : undefined\n },\n validator: v => (\n !isNaN(Number(v)) ||\n ['xs', 'sm', 'md', 'lg', 'xl'].includes(String(v))\n ),\n },\n },\n\n computed: {\n isMobile (): boolean {\n const {\n mobile,\n width,\n name,\n mobileBreakpoint,\n } = this.$vuetify.breakpoint\n\n // Check if local mobileBreakpoint matches\n // the application's mobileBreakpoint\n if (mobileBreakpoint === this.mobileBreakpoint) return mobile\n\n const mobileWidth = parseInt(this.mobileBreakpoint, 10)\n const isNumber = !isNaN(mobileWidth)\n\n return isNumber\n ? width < mobileWidth\n : name === this.mobileBreakpoint\n },\n },\n\n created () {\n /* istanbul ignore next */\n if (this.$attrs.hasOwnProperty('mobile-break-point')) {\n deprecate('mobile-break-point', 'mobile-breakpoint', this)\n }\n },\n})\n","// Styles\nimport './VSlideGroup.sass'\n\n// Components\nimport VIcon from '../VIcon'\nimport { VFadeTransition } from '../transitions'\n\n// Extensions\nimport { BaseItemGroup } from '../VItemGroup/VItemGroup'\n\n// Mixins\nimport Mobile from '../../mixins/mobile'\n\n// Directives\nimport Resize from '../../directives/resize'\nimport Touch from '../../directives/touch'\n\n// Utilities\nimport mixins, { ExtractVue } from '../../util/mixins'\n\n// Types\nimport Vue, { VNode } from 'vue'\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 => (\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 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 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 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 './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","// 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 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 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":""}