{"version":3,"sources":["webpack:///../../../src/components/VWindow/VWindowItem.ts","webpack:///../../../src/components/VToolbar/index.ts","webpack:///../../../src/components/VGrid/VSpacer.ts","webpack:///../../../src/components/VSkeletonLoader/VSkeletonLoader.ts","webpack:///../../../src/components/VTabs/VTab.ts","webpack:///../../../src/components/VTabs/VTabsItems.ts","webpack:///../../../src/mixins/mobile/index.ts","webpack:///../../../src/components/VWindow/VWindow.ts","webpack:///../../../src/components/VSlideGroup/VSlideGroup.ts","webpack:///../../../src/components/VTabs/VTabsBar.ts","webpack:///../../../src/components/VTabs/VTabsSlider.ts","webpack:///../../../src/components/VTabs/VTabs.ts"],"names":["baseMixins","name","directives","Touch","props","disabled","reverseTransition","type","Boolean","default","undefined","transition","value","required","data","isActive","inTransition","computed","classes","this","computedTransition","windowGroup","methods","genDefaultSlot","$slots","genWindowItem","$createElement","staticClass","class","on","$listeners","onAfterTransition","transitionCount","onBeforeTransition","$el","onTransitionCancelled","onEnter","el","render","h","beforeEnter","afterEnter","enterCancelled","beforeLeave","afterLeave","leaveCancelled","enter","showLazyContent","VToolbarTitle","VToolbarItems","boilerplate","loading","tile","types","attrs","role","$attrs","elevationClasses","isLoading","rootTypes","actions","article","avatar","button","card","chip","heading","image","paragraph","sentences","table","text","genBone","genBones","bone","generator","Array","length","genStructure","children","mapBones","genSkeleton","resetStyles","bones","onBeforeEnter","display","onBeforeLeave","style","ripple","proxyClass","groupClasses","to","$router","Object","resolve","mounted","click","href","indexOf","e","blur","String","tabindex","keydown","tag","mandatory","isDark","getValue","item","mobileBreakpoint","Number","$vuetify","breakpoint","validator","v","isNaN","includes","isMobile","mobile","mobileWidth","parseInt","isNumber","width","created","hasOwnProperty","provide","activeClass","continuous","nextIcon","prevIcon","reverse","showArrows","showArrowsOnHover","touch","touchless","vertical","changedByDelimiters","internalHeight","transitionHeight","isBooted","isReverse","axis","rtl","direction","hasActiveItems","items","find","hasNext","internalIndex","hasPrev","findIndex","internalReverse","watch","window","genContainer","height","genIcon","icon","lang","t","fn","large","genControlIcons","icons","getNextIndex","nextIndex","index","getPrevIndex","prevIndex","next","prev","lastIndex","updateReverse","val","left","right","end","start","BaseSlideGroup","mixins","Resize","centerActive","internalItemsLength","isOverflowing","resizeTimeout","startX","scrollOffset","widths","content","wrapper","__cachedNext","genTransition","__cachedPrev","hasAffixes","Math","internalValue","beforeUpdate","$children","updated","genNext","slot","$scopedSlots","key","genContent","ref","genData","onResize","location","upperLocation","hasAffix","VIcon","genPrev","genWrapper","move","calculateNewOffset","sign","newAbosluteOffset","onAffixClick","onTouchStart","onTouchMove","onTouchEnd","maxScrollOffset","overflowCheck","scrollIntoView","selectedIndex","calculateCenteredOffset","selectedItem","calculateUpdatedOffset","clientWidth","selectedElement","offsetLeft","currentScrollOffset","totalWidth","itemOffset","additionalOffset","offsetCentered","scrollTo","$refs","setWidths","slideGroup","tabsBar","themeClasses","$route","callSlider","onRouteChange","newPath","oldPath","oldVal","hasNew","hasOld","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","vnode","modifiers","quiet"],"mappings":"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","file":"js/forms~patients-detail~website~website-container-home~website-container-therapy~website-container-wall.3166a1f0.js","sourcesContent":["// 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","// Components\nimport VToolbar from './VToolbar'\n\n// Utilities\nimport { createSimpleFunctional } from '../../util/helpers'\n\nconst VToolbarTitle = createSimpleFunctional('v-toolbar__title')\nconst VToolbarItems = createSimpleFunctional('v-toolbar__items')\n\nexport {\n VToolbar,\n VToolbarItems,\n VToolbarTitle,\n}\n\nexport default {\n $_vuetify_subcomponents: {\n VToolbar,\n VToolbarItems,\n VToolbarTitle,\n },\n}\n","import './_grid.sass'\nimport { createSimpleFunctional } from '../../util/helpers'\n\nexport default createSimpleFunctional('spacer', 'div', 'v-spacer')\n","// Styles\nimport './VSkeletonLoader.sass'\n\n// Mixins\nimport Elevatable from '../../mixins/elevatable'\nimport Measurable from '../../mixins/measurable'\nimport Themeable from '../../mixins/themeable'\n\n// Utilities\nimport mixins from '../../util/mixins'\n\n// Types\nimport { VNode } from 'vue'\nimport { getSlot } from '../../util/helpers'\nimport { PropValidator } from 'vue/types/options'\n\nexport interface HTMLSkeletonLoaderElement extends HTMLElement {\n _initialStyle?: {\n display: string | null\n transition: string\n }\n}\n\n/* @vue/component */\nexport default mixins(\n Elevatable,\n Measurable,\n Themeable,\n).extend({\n name: 'VSkeletonLoader',\n\n props: {\n boilerplate: Boolean,\n loading: Boolean,\n tile: Boolean,\n transition: String,\n type: String,\n types: {\n type: Object,\n default: () => ({}),\n } as PropValidator>,\n },\n\n computed: {\n attrs (): object {\n if (!this.isLoading) return this.$attrs\n\n return !this.boilerplate ? {\n 'aria-busy': true,\n 'aria-live': 'polite',\n role: 'alert',\n ...this.$attrs,\n } : {}\n },\n classes (): object {\n return {\n 'v-skeleton-loader--boilerplate': this.boilerplate,\n 'v-skeleton-loader--is-loading': this.isLoading,\n 'v-skeleton-loader--tile': this.tile,\n ...this.themeClasses,\n ...this.elevationClasses,\n }\n },\n isLoading (): boolean {\n return !('default' in this.$scopedSlots) || this.loading\n },\n rootTypes (): Record {\n return {\n actions: 'button@2',\n article: 'heading, paragraph',\n avatar: 'avatar',\n button: 'button',\n card: 'image, card-heading',\n 'card-avatar': 'image, list-item-avatar',\n 'card-heading': 'heading',\n chip: 'chip',\n 'date-picker': 'list-item, card-heading, divider, date-picker-options, date-picker-days, actions',\n 'date-picker-options': 'text, avatar@2',\n 'date-picker-days': 'avatar@28',\n heading: 'heading',\n image: 'image',\n 'list-item': 'text',\n 'list-item-avatar': 'avatar, text',\n 'list-item-two-line': 'sentences',\n 'list-item-avatar-two-line': 'avatar, sentences',\n 'list-item-three-line': 'paragraph',\n 'list-item-avatar-three-line': 'avatar, paragraph',\n paragraph: 'text@3',\n sentences: 'text@2',\n table: 'table-heading, table-thead, table-tbody, table-tfoot',\n 'table-heading': 'heading, text',\n 'table-thead': 'heading@6',\n 'table-tbody': 'table-row-divider@6',\n 'table-row-divider': 'table-row, divider',\n 'table-row': 'table-cell@6',\n 'table-cell': 'text',\n 'table-tfoot': 'text@2, avatar@2',\n text: 'text',\n ...this.types,\n }\n },\n },\n\n methods: {\n genBone (text: string, children: VNode[]) {\n return this.$createElement('div', {\n staticClass: `v-skeleton-loader__${text} v-skeleton-loader__bone`,\n }, children)\n },\n genBones (bone: string): VNode[] {\n // e.g. 'text@3'\n const [type, length] = bone.split('@') as [string, number]\n const generator = () => this.genStructure(type)\n\n // Generate a length array based upon\n // value after @ in the bone string\n return Array.from({ length }).map(generator)\n },\n // Fix type when this is merged\n // https://github.com/microsoft/TypeScript/pull/33050\n genStructure (type?: string): any {\n let children = []\n type = type || this.type || ''\n const bone = this.rootTypes[type] || ''\n\n // End of recursion, do nothing\n /* eslint-disable-next-line no-empty, brace-style */\n if (type === bone) {}\n // Array of values - e.g. 'heading, paragraph, text@2'\n else if (type.indexOf(',') > -1) return this.mapBones(type)\n // Array of values - e.g. 'paragraph@4'\n else if (type.indexOf('@') > -1) return this.genBones(type)\n // Array of values - e.g. 'card@2'\n else if (bone.indexOf(',') > -1) children = this.mapBones(bone)\n // Array of values - e.g. 'list-item@2'\n else if (bone.indexOf('@') > -1) children = this.genBones(bone)\n // Single value - e.g. 'card-heading'\n else if (bone) children.push(this.genStructure(bone))\n\n return [this.genBone(type, children)]\n },\n genSkeleton () {\n const children = []\n\n if (!this.isLoading) children.push(getSlot(this))\n else children.push(this.genStructure())\n\n /* istanbul ignore else */\n if (!this.transition) return children\n\n /* istanbul ignore next */\n return this.$createElement('transition', {\n props: {\n name: this.transition,\n },\n // Only show transition when\n // content has been loaded\n on: {\n afterEnter: this.resetStyles,\n beforeEnter: this.onBeforeEnter,\n beforeLeave: this.onBeforeLeave,\n leaveCancelled: this.resetStyles,\n },\n }, children)\n },\n mapBones (bones: string) {\n // Remove spaces and return array of structures\n return bones.replace(/\\s/g, '').split(',').map(this.genStructure)\n },\n onBeforeEnter (el: HTMLSkeletonLoaderElement) {\n this.resetStyles(el)\n\n if (!this.isLoading) return\n\n el._initialStyle = {\n display: el.style.display,\n transition: el.style.transition,\n }\n\n el.style.setProperty('transition', 'none', 'important')\n },\n onBeforeLeave (el: HTMLSkeletonLoaderElement) {\n el.style.setProperty('display', 'none', 'important')\n },\n resetStyles (el: HTMLSkeletonLoaderElement) {\n if (!el._initialStyle) return\n\n el.style.display = el._initialStyle.display || ''\n el.style.transition = el._initialStyle.transition\n\n delete el._initialStyle\n },\n },\n\n render (h): VNode {\n return h('div', {\n staticClass: 'v-skeleton-loader',\n attrs: this.attrs,\n on: this.$listeners,\n class: this.classes,\n style: this.isLoading ? this.measurableStyles : undefined,\n }, [this.genSkeleton()])\n },\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\nconst baseMixins = mixins(\n Routable,\n // Must be after routable\n // to overwrite activeClass\n GroupableFactory('tabsBar'),\n Themeable\n)\n\ninterface options extends ExtractVue {\n $el: HTMLElement\n}\n\nexport default baseMixins.extend().extend(\n /* @vue/component */\n).extend({\n name: 'v-tab',\n\n props: {\n ripple: {\n type: [Boolean, Object],\n default: true,\n },\n },\n\n data: () => ({\n proxyClass: 'v-tab--active',\n }),\n\n computed: {\n classes (): object {\n return {\n 'v-tab': true,\n ...Routable.options.computed.classes.call(this),\n 'v-tab--disabled': this.disabled,\n ...this.groupClasses,\n }\n },\n value (): any {\n let to = this.to || this.href || ''\n\n if (this.$router &&\n this.to === Object(this.to)\n ) {\n const resolve = this.$router.resolve(\n this.to,\n this.$route,\n this.append\n )\n\n to = resolve.href\n }\n\n return to.replace('#', '')\n },\n },\n\n mounted () {\n this.onRouteChange()\n },\n\n methods: {\n click (e: KeyboardEvent | MouseEvent): void {\n // If user provides an\n // actual link, do not\n // prevent default\n if (this.href &&\n this.href.indexOf('#') > -1\n ) e.preventDefault()\n\n if (e.detail) this.$el.blur()\n\n this.$emit('click', e)\n\n this.to || this.toggle()\n },\n },\n\n render (h): VNode {\n const { tag, data } = this.generateRouteLink()\n\n data.attrs = {\n ...data.attrs,\n 'aria-selected': String(this.isActive),\n role: 'tab',\n tabindex: 0,\n }\n data.on = {\n ...data.on,\n keydown: (e: KeyboardEvent) => {\n if (e.keyCode === keyCodes.enter) this.click(e)\n\n this.$emit('keydown', e)\n },\n }\n\n return h(tag, data, this.$slots.default)\n },\n})\n","// 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","// 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 './VWindow.sass'\n\n// Types\nimport { VNode, VNodeDirective } from 'vue/types/vnode'\nimport { PropType } from 'vue'\nimport { TouchHandlers } from 'vuetify/types'\n\n// Directives\nimport Touch from '../../directives/touch'\n\n// Components\nimport VBtn from '../VBtn'\nimport VIcon from '../VIcon'\nimport { BaseItemGroup } from '../VItemGroup/VItemGroup'\n\n/* @vue/component */\nexport default BaseItemGroup.extend({\n name: 'v-window',\n\n provide (): object {\n return {\n windowGroup: this,\n }\n },\n\n directives: { Touch },\n\n props: {\n activeClass: {\n type: String,\n default: 'v-window-item--active',\n },\n continuous: Boolean,\n mandatory: {\n type: Boolean,\n default: true,\n },\n nextIcon: {\n type: [Boolean, String],\n default: '$next',\n },\n prevIcon: {\n type: [Boolean, String],\n default: '$prev',\n },\n reverse: {\n type: Boolean,\n default: undefined,\n },\n showArrows: Boolean,\n showArrowsOnHover: Boolean,\n touch: Object as PropType,\n touchless: Boolean,\n value: {\n required: false,\n },\n vertical: Boolean,\n },\n\n data () {\n return {\n changedByDelimiters: false,\n internalHeight: undefined as undefined | string, // This can be fixed by child class.\n transitionHeight: undefined as undefined | string, // Intermediate height during transition.\n transitionCount: 0, // Number of windows in transition state.\n isBooted: false,\n isReverse: false,\n }\n },\n\n computed: {\n isActive (): boolean {\n return this.transitionCount > 0\n },\n classes (): object {\n return {\n ...BaseItemGroup.options.computed.classes.call(this),\n 'v-window--show-arrows-on-hover': this.showArrowsOnHover,\n }\n },\n computedTransition (): string {\n if (!this.isBooted) return ''\n\n const axis = this.vertical ? 'y' : 'x'\n const reverse = this.$vuetify.rtl && axis === 'x' ? !this.internalReverse : this.internalReverse\n const direction = reverse ? '-reverse' : ''\n\n return `v-window-${axis}${direction}-transition`\n },\n hasActiveItems (): boolean {\n return Boolean(\n this.items.find(item => !item.disabled)\n )\n },\n hasNext (): boolean {\n return this.continuous || this.internalIndex < this.items.length - 1\n },\n hasPrev (): boolean {\n return this.continuous || this.internalIndex > 0\n },\n internalIndex (): number {\n return this.items.findIndex((item, i) => {\n return this.internalValue === this.getValue(item, i)\n })\n },\n internalReverse (): boolean {\n return this.reverse ? !this.isReverse : this.isReverse\n },\n },\n\n watch: {\n internalIndex: 'updateReverse',\n },\n\n mounted () {\n window.requestAnimationFrame(() => (this.isBooted = true))\n },\n\n methods: {\n genContainer (): VNode {\n const children = [this.$slots.default]\n\n if (this.showArrows) {\n children.push(this.genControlIcons())\n }\n\n return this.$createElement('div', {\n staticClass: 'v-window__container',\n class: {\n 'v-window__container--is-active': this.isActive,\n },\n style: {\n height: this.internalHeight || this.transitionHeight,\n },\n }, children)\n },\n genIcon (\n direction: 'prev' | 'next',\n icon: string,\n fn: () => void\n ) {\n return this.$createElement('div', {\n staticClass: `v-window__${direction}`,\n }, [\n this.$createElement(VBtn, {\n props: { icon: true },\n attrs: {\n 'aria-label': this.$vuetify.lang.t(`$vuetify.carousel.${direction}`),\n },\n on: {\n click: () => {\n this.changedByDelimiters = true\n fn()\n },\n },\n }, [\n this.$createElement(VIcon, {\n props: { large: true },\n }, icon),\n ]),\n ])\n },\n genControlIcons () {\n const icons = []\n\n const prevIcon = this.$vuetify.rtl\n ? this.nextIcon\n : this.prevIcon\n\n /* istanbul ignore else */\n if (\n this.hasPrev &&\n prevIcon &&\n typeof prevIcon === 'string'\n ) {\n const icon = this.genIcon('prev', prevIcon, this.prev)\n icon && icons.push(icon)\n }\n\n const nextIcon = this.$vuetify.rtl\n ? this.prevIcon\n : this.nextIcon\n\n /* istanbul ignore else */\n if (\n this.hasNext &&\n nextIcon &&\n typeof nextIcon === 'string'\n ) {\n const icon = this.genIcon('next', nextIcon, this.next)\n icon && icons.push(icon)\n }\n\n return icons\n },\n getNextIndex (index: number): number {\n const nextIndex = (index + 1) % this.items.length\n const item = this.items[nextIndex]\n\n if (item.disabled) return this.getNextIndex(nextIndex)\n\n return nextIndex\n },\n getPrevIndex (index: number): number {\n const prevIndex = (index + this.items.length - 1) % this.items.length\n const item = this.items[prevIndex]\n\n if (item.disabled) return this.getPrevIndex(prevIndex)\n\n return prevIndex\n },\n next () {\n this.isReverse = this.$vuetify.rtl\n\n /* istanbul ignore if */\n if (!this.hasActiveItems || !this.hasNext) return\n\n const nextIndex = this.getNextIndex(this.internalIndex)\n const item = this.items[nextIndex]\n\n this.internalValue = this.getValue(item, nextIndex)\n },\n prev () {\n this.isReverse = !this.$vuetify.rtl\n\n /* istanbul ignore if */\n if (!this.hasActiveItems || !this.hasPrev) return\n\n const lastIndex = this.getPrevIndex(this.internalIndex)\n const item = this.items[lastIndex]\n\n this.internalValue = this.getValue(item, lastIndex)\n },\n updateReverse (val: number, oldVal: number) {\n if (this.changedByDelimiters) {\n this.changedByDelimiters = false\n return\n }\n\n this.isReverse = val < oldVal\n },\n },\n\n render (h): VNode {\n const data = {\n staticClass: 'v-window',\n class: this.classes,\n directives: [] as VNodeDirective[],\n }\n\n if (!this.touchless) {\n const value = this.touch || {\n left: () => {\n this.$vuetify.rtl ? this.prev() : this.next()\n },\n right: () => {\n this.$vuetify.rtl ? this.next() : this.prev()\n },\n end: (e: TouchEvent) => {\n e.stopPropagation()\n },\n start: (e: TouchEvent) => {\n e.stopPropagation()\n },\n }\n\n data.directives.push({\n name: 'touch',\n value,\n })\n }\n\n return h('div', data, [this.genContainer()])\n },\n})\n","// Styles\nimport './VSlideGroup.sass'\n\n// Components\nimport VIcon from '../VIcon'\nimport { VFadeTransition } from '../transitions'\n\n// Extensions\nimport { BaseItemGroup } from '../VItemGroup/VItemGroup'\n\n// Mixins\nimport Mobile from '../../mixins/mobile'\n\n// Directives\nimport Resize from '../../directives/resize'\nimport Touch from '../../directives/touch'\n\n// Utilities\nimport mixins, { ExtractVue } from '../../util/mixins'\n\n// Types\nimport Vue, { VNode } from 'vue'\n\ninterface TouchEvent {\n touchstartX: number\n touchmoveX: number\n stopPropagation: Function\n}\n\ninterface Widths {\n content: number\n wrapper: number\n}\n\ninterface options extends Vue {\n $refs: {\n content: HTMLElement\n wrapper: HTMLElement\n }\n}\n\nexport const BaseSlideGroup = mixins\n/* eslint-enable indent */\n>(\n BaseItemGroup,\n Mobile,\n /* @vue/component */\n).extend({\n name: 'base-slide-group',\n\n directives: {\n Resize,\n Touch,\n },\n\n props: {\n activeClass: {\n type: String,\n default: 'v-slide-item--active',\n },\n centerActive: Boolean,\n nextIcon: {\n type: String,\n default: '$next',\n },\n prevIcon: {\n type: String,\n default: '$prev',\n },\n showArrows: {\n type: [Boolean, String],\n validator: v => (\n typeof v === 'boolean' || [\n 'always',\n 'desktop',\n 'mobile',\n ].includes(v)\n ),\n },\n },\n\n data: () => ({\n internalItemsLength: 0,\n isOverflowing: false,\n resizeTimeout: 0,\n startX: 0,\n scrollOffset: 0,\n widths: {\n content: 0,\n wrapper: 0,\n },\n }),\n\n computed: {\n __cachedNext (): VNode {\n return this.genTransition('next')\n },\n __cachedPrev (): VNode {\n return this.genTransition('prev')\n },\n classes (): object {\n return {\n ...BaseItemGroup.options.computed.classes.call(this),\n 'v-slide-group': true,\n 'v-slide-group--has-affixes': this.hasAffixes,\n 'v-slide-group--is-overflowing': this.isOverflowing,\n }\n },\n hasAffixes (): Boolean {\n switch (this.showArrows) {\n // Always show arrows on desktop & mobile\n case 'always': return true\n\n // Always show arrows on desktop\n case 'desktop': return !this.isMobile\n\n // Show arrows on mobile when overflowing.\n // This matches the default 2.2 behavior\n case true: return this.isOverflowing\n\n // Always show on mobile\n case 'mobile': return (\n this.isMobile ||\n this.isOverflowing\n )\n\n // https://material.io/components/tabs#scrollable-tabs\n // Always show arrows when\n // overflowed on desktop\n default: return (\n !this.isMobile &&\n this.isOverflowing\n )\n }\n },\n hasNext (): boolean {\n if (!this.hasAffixes) return false\n\n const { content, wrapper } = this.widths\n\n // Check one scroll ahead to know the width of right-most item\n return content > Math.abs(this.scrollOffset) + wrapper\n },\n hasPrev (): boolean {\n return this.hasAffixes && this.scrollOffset !== 0\n },\n },\n\n watch: {\n internalValue: 'setWidths',\n // When overflow changes, the arrows alter\n // the widths of the content and wrapper\n // and need to be recalculated\n isOverflowing: 'setWidths',\n scrollOffset (val) {\n this.$refs.content.style.transform = `translateX(${-val}px)`\n },\n },\n\n beforeUpdate () {\n this.internalItemsLength = (this.$children || []).length\n },\n\n updated () {\n if (this.internalItemsLength === (this.$children || []).length) return\n this.setWidths()\n },\n\n methods: {\n // Always generate next for scrollable hint\n genNext (): VNode | null {\n const slot = this.$scopedSlots.next\n ? this.$scopedSlots.next({})\n : this.$slots.next || this.__cachedNext\n\n return this.$createElement('div', {\n staticClass: 'v-slide-group__next',\n class: {\n 'v-slide-group__next--disabled': !this.hasNext,\n },\n on: {\n click: () => this.onAffixClick('next'),\n },\n key: 'next',\n }, [slot])\n },\n genContent (): VNode {\n return this.$createElement('div', {\n staticClass: 'v-slide-group__content',\n ref: 'content',\n }, this.$slots.default)\n },\n genData (): object {\n return {\n class: this.classes,\n directives: [{\n name: 'resize',\n value: this.onResize,\n }],\n }\n },\n genIcon (location: 'prev' | 'next'): VNode | null {\n let icon = location\n\n if (this.$vuetify.rtl && location === 'prev') {\n icon = 'next'\n } else if (this.$vuetify.rtl && location === 'next') {\n icon = 'prev'\n }\n\n const upperLocation = `${location[0].toUpperCase()}${location.slice(1)}`\n const hasAffix = (this as any)[`has${upperLocation}`]\n\n if (\n !this.showArrows &&\n !hasAffix\n ) return null\n\n return this.$createElement(VIcon, {\n props: {\n disabled: !hasAffix,\n },\n }, (this as any)[`${icon}Icon`])\n },\n // Always generate prev for scrollable hint\n genPrev (): VNode | null {\n const slot = this.$scopedSlots.prev\n ? this.$scopedSlots.prev({})\n : this.$slots.prev || this.__cachedPrev\n\n return this.$createElement('div', {\n staticClass: 'v-slide-group__prev',\n class: {\n 'v-slide-group__prev--disabled': !this.hasPrev,\n },\n on: {\n click: () => this.onAffixClick('prev'),\n },\n key: 'prev',\n }, [slot])\n },\n genTransition (location: 'prev' | 'next') {\n return this.$createElement(VFadeTransition, [this.genIcon(location)])\n },\n genWrapper (): VNode {\n return this.$createElement('div', {\n staticClass: 'v-slide-group__wrapper',\n directives: [{\n name: 'touch',\n value: {\n start: (e: TouchEvent) => this.overflowCheck(e, this.onTouchStart),\n move: (e: TouchEvent) => this.overflowCheck(e, this.onTouchMove),\n end: (e: TouchEvent) => this.overflowCheck(e, this.onTouchEnd),\n },\n }],\n ref: 'wrapper',\n }, [this.genContent()])\n },\n calculateNewOffset (direction: 'prev' | 'next', widths: Widths, rtl: boolean, currentScrollOffset: number) {\n const sign = rtl ? -1 : 1\n const newAbosluteOffset = sign * currentScrollOffset +\n (direction === 'prev' ? -1 : 1) * widths.wrapper\n\n return sign * Math.max(Math.min(newAbosluteOffset, widths.content - widths.wrapper), 0)\n },\n onAffixClick (location: 'prev' | 'next') {\n this.$emit(`click:${location}`)\n this.scrollTo(location)\n },\n onResize () {\n /* istanbul ignore next */\n if (this._isDestroyed) return\n\n this.setWidths()\n },\n onTouchStart (e: TouchEvent) {\n const { content } = this.$refs\n\n this.startX = this.scrollOffset + e.touchstartX as number\n\n content.style.setProperty('transition', 'none')\n content.style.setProperty('willChange', 'transform')\n },\n onTouchMove (e: TouchEvent) {\n this.scrollOffset = this.startX - e.touchmoveX\n },\n onTouchEnd () {\n const { content, wrapper } = this.$refs\n const maxScrollOffset = content.clientWidth - wrapper.clientWidth\n\n content.style.setProperty('transition', null)\n content.style.setProperty('willChange', null)\n\n if (this.$vuetify.rtl) {\n /* istanbul ignore else */\n if (this.scrollOffset > 0 || !this.isOverflowing) {\n this.scrollOffset = 0\n } else if (this.scrollOffset <= -maxScrollOffset) {\n this.scrollOffset = -maxScrollOffset\n }\n } else {\n /* istanbul ignore else */\n if (this.scrollOffset < 0 || !this.isOverflowing) {\n this.scrollOffset = 0\n } else if (this.scrollOffset >= maxScrollOffset) {\n this.scrollOffset = maxScrollOffset\n }\n }\n },\n overflowCheck (e: TouchEvent, fn: (e: TouchEvent) => void) {\n e.stopPropagation()\n this.isOverflowing && fn(e)\n },\n scrollIntoView /* istanbul ignore next */ () {\n if (!this.selectedItem) {\n return\n }\n\n if (\n this.selectedIndex === 0 ||\n (!this.centerActive && !this.isOverflowing)\n ) {\n this.scrollOffset = 0\n } else if (this.centerActive) {\n this.scrollOffset = this.calculateCenteredOffset(\n this.selectedItem.$el as HTMLElement,\n this.widths,\n this.$vuetify.rtl\n )\n } else if (this.isOverflowing) {\n this.scrollOffset = this.calculateUpdatedOffset(\n this.selectedItem.$el as HTMLElement,\n this.widths,\n this.$vuetify.rtl,\n this.scrollOffset\n )\n }\n },\n calculateUpdatedOffset (selectedElement: HTMLElement, widths: Widths, rtl: boolean, currentScrollOffset: number): number {\n const clientWidth = selectedElement.clientWidth\n const offsetLeft = rtl\n ? (widths.content - selectedElement.offsetLeft - clientWidth)\n : selectedElement.offsetLeft\n\n if (rtl) {\n currentScrollOffset = -currentScrollOffset\n }\n\n const totalWidth = widths.wrapper + currentScrollOffset\n const itemOffset = clientWidth + offsetLeft\n const additionalOffset = clientWidth * 0.4\n\n if (offsetLeft <= currentScrollOffset) {\n currentScrollOffset = Math.max(offsetLeft - additionalOffset, 0)\n } else if (totalWidth <= itemOffset) {\n currentScrollOffset = Math.min(currentScrollOffset - (totalWidth - itemOffset - additionalOffset), widths.content - widths.wrapper)\n }\n\n return rtl ? -currentScrollOffset : currentScrollOffset\n },\n calculateCenteredOffset (selectedElement: HTMLElement, widths: Widths, rtl: boolean): number {\n const { offsetLeft, clientWidth } = selectedElement\n\n if (rtl) {\n const offsetCentered = widths.content - offsetLeft - clientWidth / 2 - widths.wrapper / 2\n return -Math.min(widths.content - widths.wrapper, Math.max(0, offsetCentered))\n } else {\n const offsetCentered = offsetLeft + clientWidth / 2 - widths.wrapper / 2\n return Math.min(widths.content - widths.wrapper, Math.max(0, offsetCentered))\n }\n },\n scrollTo /* istanbul ignore next */ (location: 'prev' | 'next') {\n this.scrollOffset = this.calculateNewOffset(location, {\n // Force reflow\n content: this.$refs.content ? this.$refs.content.clientWidth : 0,\n wrapper: this.$refs.wrapper ? this.$refs.wrapper.clientWidth : 0,\n }, this.$vuetify.rtl, this.scrollOffset)\n },\n setWidths /* istanbul ignore next */ () {\n window.requestAnimationFrame(() => {\n const { content, wrapper } = this.$refs\n\n this.widths = {\n content: content ? content.clientWidth : 0,\n wrapper: wrapper ? wrapper.clientWidth : 0,\n }\n\n this.isOverflowing = this.widths.wrapper < this.widths.content\n\n this.scrollIntoView()\n })\n },\n },\n\n render (h): VNode {\n return h('div', this.genData(), [\n this.genPrev(),\n this.genWrapper(),\n this.genNext(),\n ])\n },\n})\n\nexport default BaseSlideGroup.extend({\n name: 'v-slide-group',\n\n provide (): object {\n return {\n slideGroup: this,\n }\n },\n})\n","// Extensions\nimport { BaseSlideGroup } from '../VSlideGroup/VSlideGroup'\n\n// Components\nimport VTab from './VTab'\n\n// Mixins\nimport Themeable from '../../mixins/themeable'\nimport SSRBootable from '../../mixins/ssr-bootable'\n\n// Utilities\nimport mixins from '../../util/mixins'\n\n// Types\nimport { Route } from 'vue-router'\nimport { VNode } from 'vue'\n\ntype VTabInstance = InstanceType\n\nexport default mixins(\n BaseSlideGroup,\n SSRBootable,\n Themeable\n /* @vue/component */\n).extend({\n name: 'v-tabs-bar',\n\n provide () {\n return {\n tabsBar: this,\n }\n },\n\n computed: {\n classes () {\n return {\n ...BaseSlideGroup.options.computed.classes.call(this),\n 'v-tabs-bar': true,\n 'v-tabs-bar--is-mobile': this.isMobile,\n // TODO: Remove this and move to v-slide-group\n 'v-tabs-bar--show-arrows': this.showArrows,\n ...this.themeClasses,\n }\n },\n },\n\n watch: {\n items: 'callSlider',\n internalValue: 'callSlider',\n $route: 'onRouteChange',\n },\n\n methods: {\n callSlider () {\n if (!this.isBooted) return\n\n this.$emit('call:slider')\n },\n genContent () {\n const render = BaseSlideGroup.options.methods.genContent.call(this)\n\n render.data = render.data || {}\n render.data.staticClass += ' v-tabs-bar__content'\n\n return render\n },\n onRouteChange (val: Route, oldVal: Route) {\n /* istanbul ignore next */\n if (this.mandatory) return\n\n const items = this.items as unknown as VTabInstance[]\n const newPath = val.path\n const oldPath = oldVal.path\n\n let hasNew = false\n let hasOld = false\n\n for (const item of items) {\n if (item.to === newPath) hasNew = true\n else if (item.to === oldPath) hasOld = true\n\n if (hasNew && hasOld) break\n }\n\n // If we have an old item and not a new one\n // it's assumed that the user navigated to\n // a path that is not present in the items\n if (!hasNew && hasOld) this.internalValue = undefined\n },\n },\n\n render (h): VNode {\n const render = BaseSlideGroup.options.render.call(this, h)\n\n render.data!.attrs = {\n role: 'tablist',\n }\n\n return render\n },\n})\n","// Mixins\nimport Colorable from '../../mixins/colorable'\n\n// Utilities\nimport mixins from '../../util/mixins'\n\n// Types\nimport { VNode } from 'vue/types'\n\n/* @vue/component */\nexport default mixins(Colorable).extend({\n name: 'v-tabs-slider',\n\n render (h): VNode {\n return h('div', this.setBackgroundColor(this.color, {\n staticClass: 'v-tabs-slider',\n }))\n },\n})\n","// Styles\nimport './VTabs.sass'\n\n// Components\nimport VTabsBar from './VTabsBar'\nimport VTabsItems from './VTabsItems'\nimport VTabsSlider from './VTabsSlider'\n\n// Mixins\nimport Colorable from '../../mixins/colorable'\nimport Proxyable from '../../mixins/proxyable'\nimport Themeable from '../../mixins/themeable'\n\n// Directives\nimport Resize from '../../directives/resize'\n\n// Utilities\nimport { convertToUnit } from '../../util/helpers'\nimport { ExtractVue } from './../../util/mixins'\nimport mixins from '../../util/mixins'\n\n// Types\nimport { VNode } from 'vue/types'\n\nconst baseMixins = mixins(\n Colorable,\n Proxyable,\n Themeable\n)\n\ninterface options extends ExtractVue {\n $refs: {\n items: InstanceType\n }\n}\n\nexport default baseMixins.extend().extend({\n name: 'v-tabs',\n\n directives: {\n Resize,\n },\n\n props: {\n activeClass: {\n type: String,\n default: '',\n },\n alignWithTitle: Boolean,\n backgroundColor: String,\n centerActive: Boolean,\n centered: Boolean,\n fixedTabs: Boolean,\n grow: Boolean,\n height: {\n type: [Number, String],\n default: undefined,\n },\n hideSlider: Boolean,\n iconsAndText: Boolean,\n mobileBreakpoint: [String, Number],\n nextIcon: {\n type: String,\n default: '$next',\n },\n optional: Boolean,\n prevIcon: {\n type: String,\n default: '$prev',\n },\n right: Boolean,\n showArrows: [Boolean, String],\n sliderColor: String,\n sliderSize: {\n type: [Number, String],\n default: 2,\n },\n vertical: Boolean,\n },\n\n data () {\n return {\n resizeTimeout: 0,\n slider: {\n height: null as null | number,\n left: null as null | number,\n right: null as null | number,\n top: null as null | number,\n width: null as null | number,\n },\n transitionTime: 300,\n }\n },\n\n computed: {\n classes (): object {\n return {\n 'v-tabs--align-with-title': this.alignWithTitle,\n 'v-tabs--centered': this.centered,\n 'v-tabs--fixed-tabs': this.fixedTabs,\n 'v-tabs--grow': this.grow,\n 'v-tabs--icons-and-text': this.iconsAndText,\n 'v-tabs--right': this.right,\n 'v-tabs--vertical': this.vertical,\n ...this.themeClasses,\n }\n },\n isReversed (): boolean {\n return this.$vuetify.rtl && this.vertical\n },\n sliderStyles (): object {\n return {\n height: convertToUnit(this.slider.height),\n left: this.isReversed ? undefined : convertToUnit(this.slider.left),\n right: this.isReversed ? convertToUnit(this.slider.right) : undefined,\n top: this.vertical ? convertToUnit(this.slider.top) : undefined,\n transition: this.slider.left != null ? null : 'none',\n width: convertToUnit(this.slider.width),\n }\n },\n computedColor (): string {\n if (this.color) return this.color\n else if (this.isDark && !this.appIsDark) return 'white'\n else return 'primary'\n },\n },\n\n watch: {\n alignWithTitle: 'callSlider',\n centered: 'callSlider',\n centerActive: 'callSlider',\n fixedTabs: 'callSlider',\n grow: 'callSlider',\n right: 'callSlider',\n showArrows: 'callSlider',\n vertical: 'callSlider',\n '$vuetify.application.left': 'onResize',\n '$vuetify.application.right': 'onResize',\n '$vuetify.rtl': 'onResize',\n },\n\n mounted () {\n this.$nextTick(() => {\n window.setTimeout(this.callSlider, 30)\n })\n },\n\n methods: {\n callSlider () {\n if (\n this.hideSlider ||\n !this.$refs.items ||\n !this.$refs.items.selectedItems.length\n ) {\n this.slider.width = 0\n return false\n }\n\n this.$nextTick(() => {\n // Give screen time to paint\n const activeTab = this.$refs.items.selectedItems[0]\n /* istanbul ignore if */\n if (!activeTab || !activeTab.$el) {\n this.slider.width = 0\n this.slider.left = 0\n return\n }\n const el = activeTab.$el as HTMLElement\n\n this.slider = {\n height: !this.vertical ? Number(this.sliderSize) : el.scrollHeight,\n left: this.vertical ? 0 : el.offsetLeft,\n right: this.vertical ? 0 : el.offsetLeft + el.offsetWidth,\n top: el.offsetTop,\n width: this.vertical ? Number(this.sliderSize) : el.scrollWidth,\n }\n })\n\n return true\n },\n genBar (items: VNode[], slider: VNode | null) {\n const data = {\n style: {\n height: convertToUnit(this.height),\n },\n props: {\n activeClass: this.activeClass,\n centerActive: this.centerActive,\n dark: this.dark,\n light: this.light,\n mandatory: !this.optional,\n mobileBreakpoint: this.mobileBreakpoint,\n nextIcon: this.nextIcon,\n prevIcon: this.prevIcon,\n showArrows: this.showArrows,\n value: this.internalValue,\n },\n on: {\n 'call:slider': this.callSlider,\n change: (val: any) => {\n this.internalValue = val\n },\n },\n ref: 'items',\n }\n\n this.setTextColor(this.computedColor, data)\n this.setBackgroundColor(this.backgroundColor, data)\n\n return this.$createElement(VTabsBar, data, [\n this.genSlider(slider),\n items,\n ])\n },\n genItems (items: VNode | null, item: VNode[]) {\n // If user provides items\n // opt to use theirs\n if (items) return items\n\n // If no tabs are provided\n // render nothing\n if (!item.length) return null\n\n return this.$createElement(VTabsItems, {\n props: {\n value: this.internalValue,\n },\n on: {\n change: (val: any) => {\n this.internalValue = val\n },\n },\n }, item)\n },\n genSlider (slider: VNode | null) {\n if (this.hideSlider) return null\n\n if (!slider) {\n slider = this.$createElement(VTabsSlider, {\n props: { color: this.sliderColor },\n })\n }\n\n return this.$createElement('div', {\n staticClass: 'v-tabs-slider-wrapper',\n style: this.sliderStyles,\n }, [slider])\n },\n onResize () {\n if (this._isDestroyed) return\n\n clearTimeout(this.resizeTimeout)\n this.resizeTimeout = window.setTimeout(this.callSlider, 0)\n },\n parseNodes () {\n let items = null\n let slider = null\n const item = []\n const tab = []\n const slot = this.$slots.default || []\n const length = slot.length\n\n for (let i = 0; i < length; i++) {\n const vnode = slot[i]\n\n if (vnode.componentOptions) {\n switch (vnode.componentOptions.Ctor.options.name) {\n case 'v-tabs-slider': slider = vnode\n break\n case 'v-tabs-items': items = vnode\n break\n case 'v-tab-item': item.push(vnode)\n break\n // case 'v-tab' - intentionally omitted\n default: tab.push(vnode)\n }\n } else {\n tab.push(vnode)\n }\n }\n\n /**\n * tab: array of `v-tab`\n * slider: single `v-tabs-slider`\n * items: single `v-tabs-items`\n * item: array of `v-tab-item`\n */\n return { tab, slider, items, item }\n },\n },\n\n render (h): VNode {\n const { tab, slider, items, item } = this.parseNodes()\n\n return h('div', {\n staticClass: 'v-tabs',\n class: this.classes,\n directives: [{\n name: 'resize',\n modifiers: { quiet: true },\n value: this.onResize,\n }],\n }, [\n this.genBar(tab, slider),\n this.genItems(items, item),\n ])\n },\n})\n"],"sourceRoot":""}