{"version":3,"sources":["webpack:///../../../src/components/VSheet/index.ts","webpack:///../../../src/components/VTextarea/VTextarea.ts","webpack:///../../../src/components/VSlideGroup/VSlideItem.ts","webpack:///../../../src/components/VSlideGroup/index.ts","webpack:///../../../src/components/VSpeedDial/VSpeedDial.ts","webpack:///../../../src/components/VProgressCircular/index.ts","webpack:///../../../src/components/VSubheader/VSubheader.ts","webpack:///../../../src/components/VSubheader/index.ts","webpack:///../../../src/components/VTextField/index.ts","webpack:///../../../src/components/VProgressLinear/VProgressLinear.ts","webpack:///../../../src/components/VProgressLinear/index.ts","webpack:///../../../src/components/VTabs/VTabItem.ts","webpack:///../../../src/components/VTabs/index.ts","webpack:///../../../src/components/VProgressCircular/VProgressCircular.ts","webpack:///../../../src/components/VSkeletonLoader/VSkeletonLoader.ts","webpack:///../../../src/components/VSystemBar/VSystemBar.ts","webpack:///../../../src/components/VRadioGroup/VRadioGroup.ts","webpack:///../../../src/components/VRadioGroup/VRadio.ts","webpack:///../../../src/components/VTabs/VTab.ts","webpack:///../../../src/components/VRangeSlider/VRangeSlider.ts","webpack:///../../../src/components/VResponsive/VResponsive.ts","webpack:///../../../src/components/VResponsive/index.ts","webpack:///../../../src/components/VSlideGroup/VSlideGroup.ts","webpack:///../../../src/components/VRating/VRating.ts","webpack:///../../../src/components/VTextField/VTextField.ts","webpack:///../../../src/components/VSnackbar/VSnackbar.ts","webpack:///../../../src/components/VSheet/VSheet.ts","webpack:///../../../src/components/VSlider/index.ts","webpack:///../../../src/components/VTabs/VTabsSlider.ts","webpack:///../../../src/components/VStepper/VStepper.ts","webpack:///../../../src/components/VStepper/VStepperStep.ts","webpack:///../../../src/components/VStepper/VStepperContent.ts","webpack:///../../../src/components/VStepper/index.ts","webpack:///../../../src/components/VTabs/VTabsItems.ts","webpack:///../../../src/components/VSwitch/VSwitch.ts","webpack:///../../../src/components/VSelect/index.ts","webpack:///../../../src/components/VSelect/VSelectList.ts","webpack:///../../../src/components/VSelect/VSelect.ts","webpack:///../../../src/components/VSlider/VSlider.ts","webpack:///../../../../src/components/VSparkline/helpers/core.ts","webpack:///../../../../src/components/VSparkline/helpers/math.ts","webpack:///../../../../src/components/VSparkline/helpers/path.ts","webpack:///../../../src/components/VSparkline/VSparkline.ts","webpack:///../../../src/components/VTabs/VTabsBar.ts","webpack:///../../../src/components/VTabs/VTabs.ts"],"names":["baseMixins","mixins","name","props","autoGrow","noResize","rowHeight","type","Number","default","validator","v","isNaN","parseFloat","rows","parseInt","computed","classes","this","VTextField","noResizeHandle","watch","lazyValue","$nextTick","mounted","setTimeout","methods","calculateInputHeight","input","$refs","height","minHeight","Math","genInput","onInput","onKeyDown","isFocused","e","VSlideGroup","directives","ClickOutside","direction","val","includes","openOnHover","transition","isActive","render","children","data","class","value","on","click","btnCount","$slots","b","h","style","transitionDelay","key","i","list","mode","origin","tag","inset","Boolean","staticClass","themeClasses","attrs","$listeners","intersect","active","backgroundColor","backgroundOpacity","bufferValue","color","indeterminate","query","reverse","rounded","stream","striped","internalLazyValue","isVisible","__cachedBackground","$createElement","setBackgroundColor","backgroundStyle","__cachedBar","__cachedBarType","__cachedBuffer","styles","__cachedDeterminate","width","__cachedIndeterminate","genProgressBar","__cachedStream","setTextColor","opacity","isReversed","normalizedBuffer","computedTransition","$vuetify","rtl","normalize","normalizedValue","reactive","genContent","slot","genListeners","listeners","onClick","$el","onObserve","role","undefined","bottom","top","VWindowItem","id","String","genWindowItem","item","VTabs","VTab","VTabsItems","VTabsSlider","button","rotate","size","radius","calculatedSize","circumference","strokeDashArray","strokeDashOffset","strokeWidth","svgStyles","transform","viewBoxSize","genCircle","fill","cx","cy","r","offset","genSvg","xmlns","viewBox","genInfo","boilerplate","loading","tile","types","$attrs","elevationClasses","isLoading","rootTypes","actions","article","avatar","card","chip","heading","image","paragraph","sentences","table","text","genBone","genBones","bone","generator","Array","length","genStructure","mapBones","genSkeleton","afterEnter","beforeEnter","beforeLeave","leaveCancelled","resetStyles","bones","onBeforeEnter","el","display","onBeforeLeave","lightsOut","window","app","computedHeight","updateApplication","provide","radioGroup","column","row","VInput","genDefaultSlot","computedId","genInputSlot","genLabel","label","inheritAttrs","disabled","offIcon","onIcon","readonly","groupClasses","computedColor","computedIcon","hasLabel","hasState","isDisabled","isReadonly","computedName","rippleState","validationState","VLabel","for","focused","genRadio","radioAttrs","VIcon","dense","genRipple","onFocus","onBlur","onChange","onKeydown","title","attrs$","ripple","proxyClass","to","$router","Object","resolve","href","indexOf","blur","tabindex","keydown","VSlider","activeThumb","internalValue","get","set","toFocus","$emit","inputWidth","map","getTrackStyle","startPadding","endPadding","startDir","vertical","endDir","start","startLength","end","endLength","getIndexOfClosestValue","arr","genTrackContainer","padding","sections","section","ref","genChildren","index","valueWidth","reevaluateSelected","refName","thumbRef","onSliderMouseDown","parseMouseMove","mouseUpOptions","passive","capture","mouseMoveOptions","isTouchEvent","onSliderClick","onMouseMove","parseKeyDown","setInternalValue","aspectRatio","contentClass","computedAspectRatio","aspectStyle","paddingBottom","__cachedSizer","BaseSlideGroup","Resize","Touch","activeClass","centerActive","nextIcon","prevIcon","showArrows","internalItemsLength","isOverflowing","resizeTimeout","startX","isSwipingHorizontal","isSwiping","scrollOffset","widths","content","wrapper","canTouch","__cachedNext","genTransition","__cachedPrev","hasAffixes","isMobile","hasNext","hasPrev","beforeUpdate","$children","updated","genNext","$scopedSlots","next","genData","onResize","genIcon","icon","location","upperLocation","hasAffix","genPrev","prev","genWrapper","move","calculateNewOffset","sign","newAbosluteOffset","onAffixClick","onTouchStart","onTouchMove","diffX","diffY","document","onTouchEnd","maxScrollOffset","overflowCheck","fn","scrollIntoView","items","lastItemPosition","wrapperPosition","selectedIndex","calculateCenteredOffset","selectedItem","calculateUpdatedOffset","clientWidth","selectedElement","offsetLeft","currentScrollOffset","totalWidth","itemOffset","additionalOffset","offsetCentered","scrollTo","setWidths","slideGroup","clearable","emptyIcon","fullIcon","halfIcon","halfIncrements","hover","iconLabel","hoverIndex","circle","iconProps","xSmall","dark","large","light","medium","small","xLarge","isHovering","createClickFn","newValue","createProps","isFilled","isHovered","genHoverIndex","isHalf","isHalfEvent","getIconName","isFull","getColor","rect","onMouseEnter","onMouseLeave","genItem","lang","t","onVisible","dirtyTypes","resize","appendOuterIcon","autofocus","clearIcon","counter","counterValue","filled","flat","fullWidth","outlined","placeholder","prefix","prependInnerIcon","persistentPlaceholder","shaped","singleLine","solo","soloInverted","suffix","badInput","labelWidth","prefixWidth","prependWidth","initialValue","isBooted","isClearing","computedCounterValue","hasCounter","hasDetails","isDirty","isEnclosed","isLabelActive","isSingle","isSolo","labelPosition","labelValue","left","right","showLabel","created","hasOwnProperty","requestAnimationFrame","focus","clearableCallback","genAppendSlot","genSlot","genPrependInnerSlot","genIconSlot","prepend","genClearIcon","genCounter","max","genControl","genFieldset","absolute","genLegend","span","domProps","innerHTML","inputAttrs","modifiers","quiet","genMessages","messagesNode","counterNode","genTextFieldSlot","genAffix","root","target","onMouseDown","onMouseUp","setLabelWidth","scrollWidth","setPrefixWidth","setPrependWidth","tryAutofocus","updateValue","centered","multiLine","timeout","activeTimeout","hasBackground","isDark","paddingLeft","paddingRight","paddingTop","bar","genActions","setColor","VSheet","mouseenter","mouseleave","roundedClasses","listeners$","stepClick","isVertical","altLabels","nonLinear","steps","isReverse","oldVal","register","unregister","filter","updateView","inject","complete","completeIcon","editable","editIcon","errorIcon","rules","step","isInactive","hasError","some","validate","stepper","beforeDestroy","genStep","genStepContent","toggle","isVerticalProvided","from","required","current","previous","leave","onTransition","enter","scrollHeight","contentData","wrapperData","VStepperHeader","VStepperItems","mandatory","getValue","hasColor","switchData","genSwitch","switchAttrs","onSwipeRight","genProgress","progress","VProgressCircular","onSwipeLeft","action","hideSelected","itemDisabled","itemText","itemValue","noDataText","noFilter","searchInput","selectedItems","parsedItems","tileActiveClass","staticNoDataTile","mousedown","VListItem","genTileContent","genAction","VListItemAction","VSimpleCheckbox","genDivider","VDivider","genFilteredText","getMaskedCharacters","genHighlight","middle","genHeader","VSubheader","genTile","hasItem","getDisabled","_uid","inputValue","parent","scopedSlot","needsTile","getText","VList","itemsLength","defaultMenuProps","closeOnClick","closeOnContentClick","disableKeys","openOnClick","maxHeight","appendIcon","attach","cacheItems","chips","deletableChips","disableLookup","eager","itemColor","menuProps","multiple","openOnClear","returnObject","smallChips","cachedItems","menuIsBooted","isMenuActive","lastItem","keyboardLookupPrefix","keyboardLookupLastTime","allItems","filterDuplicates","concat","computedItems","computedOwns","handler","closeConditional","include","dynamicHeight","hasChips","hasSlot","listData","scopeId","$vnode","context","select","selectItem","scopedSlots","staticList","console","VSelectList","virtualizedItems","$_menuProps","slice","menuCanShow","normalisedProps","split","acc","p","nudgeBottom","immediate","activateMenu","getContent","contains","uniqueValues","findExistingIndex","menu","genChipSelection","isInteractive","VChip","close","JSON","genCommaSelection","last","selections","mergeData","autocomplete","keypress","onKeyPress","genHiddenInput","genList","genListWithSlot","slots","slotName","genMenu","VMenu","scroll","onScroll","genSelections","genSelection","genSlotSelection","selection","selected","getMenuIndex","onChipInput","setValue","isAppendInner","onEscDown","KEYBOARD_LOOKUP_THRESHOLD","now","performance","findIndex","keyCode","onUpDown","onTabDown","onSpaceDown","onMenuActiveChange","hasMouseDown","showMoreItems","scrollTop","activeTile","listIndex","setMenuIndex","setSelectedItems","values","oldValue","valueComparator","appendInner","inverseLabel","min","thumbColor","thumbLabel","thumbSize","tickLabels","ticks","tickSize","trackColor","trackFillColor","thumbPressed","mouseTimeout","noClick","roundValue","trackTransition","showTicks","minValue","maxValue","stepNumeric","trackFillStyles","valueDir","trackStyles","numTicks","showThumbLabel","computedTrackColor","computedTrackFillColor","computedThumbColor","parsed","beforeMount","slider","genSlider","touchstart","genThumbContainer","genSteps","range","offsetDirection","thumbLabelContent","genThumbLabelContent","genThumbLabel","getThumbContainerStyles","genThumb","onSliderMouseUp","thumb","track","trackLength","clickOffset","clickPos","up","pageup","pagedown","home","down","increase","multiplier","trimmedStep","toString","decimals","maxY","totalValues","gridX","maxX","gridY","x","minX","y","horizonY","p0","p2","p1","vector","unitVector","points","isCollinear","checkCollinear","point","threshold","getDistance","isTooCloseForRadius","radiusForPoint","before","moveTo","after","autoDraw","autoDrawDuration","autoDrawEasing","autoLineWidth","gradient","gradientDirection","labels","labelSize","lineWidth","showLabels","smooth","lastLength","parsedPadding","parsedWidth","parsedHeight","parsedLabelSize","totalHeight","_lineWidth","totalPadding","boundary","minY","hasLabels","parsedLabels","len","normalizedValues","_values","genPoints","textY","_radius","path","genGradient","stops","gradientUnits","x1","y1","x2","y2","genG","fontSize","textAnchor","dominantBaseline","genPath","d","stroke","genLabels","genBars","bars","offsetX","genClipPath","rounding","rx","ry","attributeName","dur","genTrend","tabsBar","$route","callSlider","onRouteChange","newPath","oldPath","hasNew","hasOld","alignWithTitle","fixedTabs","grow","hideSlider","iconsAndText","mobileBreakpoint","optional","sliderColor","sliderSize","transitionTime","sliderStyles","activeTab","genBar","change","VTabsBar","genItems","clearTimeout","parseNodes","tab","vnode"],"mappings":"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","file":"js/chunk-vendors~cbab912d.d6abb1e5.js","sourcesContent":["import VSheet from './VSheet'\n\nexport { VSheet }\nexport default VSheet\n","// Styles\nimport './VTextarea.sass'\n\n// Extensions\nimport VTextField from '../VTextField/VTextField'\n\n// Utilities\nimport mixins from '../../util/mixins'\n\n// Types\nimport Vue from 'vue'\n\ninterface options extends Vue {\n $refs: {\n input: HTMLTextAreaElement\n }\n}\n\nconst baseMixins = mixins\n>(\n VTextField\n)\n\n/* @vue/component */\nexport default baseMixins.extend({\n name: 'v-textarea',\n\n props: {\n autoGrow: Boolean,\n noResize: Boolean,\n rowHeight: {\n type: [Number, String],\n default: 24,\n validator: (v: any) => !isNaN(parseFloat(v)),\n },\n rows: {\n type: [Number, String],\n default: 5,\n validator: (v: any) => !isNaN(parseInt(v, 10)),\n },\n },\n\n computed: {\n classes (): object {\n return {\n 'v-textarea': true,\n 'v-textarea--auto-grow': this.autoGrow,\n 'v-textarea--no-resize': this.noResizeHandle,\n ...VTextField.options.computed.classes.call(this),\n }\n },\n noResizeHandle (): boolean {\n return this.noResize || this.autoGrow\n },\n },\n\n watch: {\n lazyValue () {\n this.autoGrow && this.$nextTick(this.calculateInputHeight)\n },\n rowHeight () {\n this.autoGrow && this.$nextTick(this.calculateInputHeight)\n },\n },\n\n mounted () {\n setTimeout(() => {\n this.autoGrow && this.calculateInputHeight()\n }, 0)\n },\n\n methods: {\n calculateInputHeight () {\n const input = this.$refs.input\n if (!input) return\n\n input.style.height = '0'\n const height = input.scrollHeight\n const minHeight = parseInt(this.rows, 10) * parseFloat(this.rowHeight)\n // This has to be done ASAP, waiting for Vue\n // to update the DOM causes ugly layout jumping\n input.style.height = Math.max(minHeight, height) + 'px'\n },\n genInput () {\n const input = VTextField.options.methods.genInput.call(this)\n\n input.tag = 'textarea'\n delete input.data!.attrs!.type\n input.data!.attrs!.rows = this.rows\n\n return input\n },\n onInput (e: Event) {\n VTextField.options.methods.onInput.call(this, e)\n this.autoGrow && this.calculateInputHeight()\n },\n onKeyDown (e: KeyboardEvent) {\n // Prevents closing of a\n // dialog when pressing\n // enter\n if (this.isFocused && e.keyCode === 13) {\n e.stopPropagation()\n }\n\n this.$emit('keydown', e)\n },\n },\n})\n","// Extensions\nimport { BaseItem } from '../VItemGroup/VItem'\n\n// Mixins\nimport { factory as GroupableFactory } from '../../mixins/groupable'\nimport mixins from '../../util/mixins'\n\nexport default mixins(\n BaseItem,\n GroupableFactory('slideGroup')\n /* @vue/component */\n).extend({\n name: 'v-slide-item',\n})\n","import VSlideGroup from './VSlideGroup'\nimport VSlideItem from './VSlideItem'\n\nexport {\n VSlideGroup,\n VSlideItem,\n}\n\nexport default {\n $_vuetify_subcomponents: {\n VSlideGroup,\n VSlideItem,\n },\n}\n","// Styles\nimport './VSpeedDial.sass'\n\n// Mixins\nimport Toggleable from '../../mixins/toggleable'\nimport Positionable from '../../mixins/positionable'\nimport Transitionable from '../../mixins/transitionable'\n\n// Directives\nimport ClickOutside from '../../directives/click-outside'\n\n// Types\nimport mixins from '../../util/mixins'\nimport { VNode, VNodeData } from 'vue'\nimport { Prop } from 'vue/types/options'\n\n/* @vue/component */\nexport default mixins(Positionable, Toggleable, Transitionable).extend({\n name: 'v-speed-dial',\n\n directives: { ClickOutside },\n\n props: {\n direction: {\n type: String as Prop<'top' | 'right' | 'bottom' | 'left'>,\n default: 'top',\n validator: (val: string) => {\n return ['top', 'right', 'bottom', 'left'].includes(val)\n },\n },\n openOnHover: Boolean,\n transition: {\n type: String,\n default: 'scale-transition',\n },\n },\n\n computed: {\n classes (): object {\n return {\n 'v-speed-dial': true,\n 'v-speed-dial--top': this.top,\n 'v-speed-dial--right': this.right,\n 'v-speed-dial--bottom': this.bottom,\n 'v-speed-dial--left': this.left,\n 'v-speed-dial--absolute': this.absolute,\n 'v-speed-dial--fixed': this.fixed,\n [`v-speed-dial--direction-${this.direction}`]: true,\n 'v-speed-dial--is-active': this.isActive,\n }\n },\n },\n\n render (h): VNode {\n let children: VNode[] = []\n const data: VNodeData = {\n class: this.classes,\n directives: [{\n name: 'click-outside',\n value: () => (this.isActive = false),\n }],\n on: {\n click: () => (this.isActive = !this.isActive),\n },\n }\n\n if (this.openOnHover) {\n data.on!.mouseenter = () => (this.isActive = true)\n data.on!.mouseleave = () => (this.isActive = false)\n }\n\n if (this.isActive) {\n let btnCount = 0\n children = (this.$slots.default || []).map((b, i) => {\n if (b.tag && typeof b.componentOptions !== 'undefined' && (b.componentOptions.Ctor.options.name === 'v-btn' || b.componentOptions.Ctor.options.name === 'v-tooltip')) {\n btnCount++\n return h('div', {\n style: {\n transitionDelay: btnCount * 0.05 + 's',\n },\n key: i,\n }, [b])\n } else {\n b.key = i\n return b\n }\n })\n }\n\n const list = h('transition-group', {\n class: 'v-speed-dial__list',\n props: {\n name: this.transition,\n mode: this.mode,\n origin: this.origin,\n tag: 'div',\n },\n }, children)\n\n return h('div', data, [this.$slots.activator, list])\n },\n})\n","import VProgressCircular from './VProgressCircular'\n\nexport { VProgressCircular }\nexport default VProgressCircular\n","// Styles\nimport './VSubheader.sass'\n\n// Mixins\nimport Themeable from '../../mixins/themeable'\nimport mixins from '../../util/mixins'\n\n// Types\nimport { VNode } from 'vue'\n\nexport default mixins(\n Themeable\n /* @vue/component */\n).extend({\n name: 'v-subheader',\n\n props: {\n inset: Boolean,\n },\n\n render (h): VNode {\n return h('div', {\n staticClass: 'v-subheader',\n class: {\n 'v-subheader--inset': this.inset,\n ...this.themeClasses,\n },\n attrs: this.$attrs,\n on: this.$listeners,\n }, this.$slots.default)\n },\n})\n","import VSubheader from './VSubheader'\n\nexport { VSubheader }\nexport default VSubheader\n","import VTextField from './VTextField'\n\nexport { VTextField }\nexport default VTextField\n","import './VProgressLinear.sass'\n\n// Components\nimport {\n VFadeTransition,\n VSlideXTransition,\n} from '../transitions'\n\n// Directives\nimport intersect from '../../directives/intersect'\n\n// Mixins\nimport Colorable from '../../mixins/colorable'\nimport { factory as PositionableFactory } from '../../mixins/positionable'\nimport Proxyable from '../../mixins/proxyable'\nimport Themeable from '../../mixins/themeable'\n\n// Utilities\nimport { convertToUnit, getSlot } from '../../util/helpers'\nimport mixins from '../../util/mixins'\n\n// Types\nimport { FunctionalComponentOptions } from 'vue/types'\nimport { VNode } from 'vue'\n\nconst baseMixins = mixins(\n Colorable,\n PositionableFactory(['absolute', 'fixed', 'top', 'bottom']),\n Proxyable,\n Themeable\n)\n\n/* @vue/component */\nexport default baseMixins.extend({\n name: 'v-progress-linear',\n\n directives: { intersect },\n\n props: {\n active: {\n type: Boolean,\n default: true,\n },\n backgroundColor: {\n type: String,\n default: null,\n },\n backgroundOpacity: {\n type: [Number, String],\n default: null,\n },\n bufferValue: {\n type: [Number, String],\n default: 100,\n },\n color: {\n type: String,\n default: 'primary',\n },\n height: {\n type: [Number, String],\n default: 4,\n },\n indeterminate: Boolean,\n query: Boolean,\n reverse: Boolean,\n rounded: Boolean,\n stream: Boolean,\n striped: Boolean,\n value: {\n type: [Number, String],\n default: 0,\n },\n },\n\n data () {\n return {\n internalLazyValue: this.value || 0,\n isVisible: true,\n }\n },\n\n computed: {\n __cachedBackground (): VNode {\n return this.$createElement('div', this.setBackgroundColor(this.backgroundColor || this.color, {\n staticClass: 'v-progress-linear__background',\n style: this.backgroundStyle,\n }))\n },\n __cachedBar (): VNode {\n return this.$createElement(this.computedTransition, [this.__cachedBarType])\n },\n __cachedBarType (): VNode {\n return this.indeterminate ? this.__cachedIndeterminate : this.__cachedDeterminate\n },\n __cachedBuffer (): VNode {\n return this.$createElement('div', {\n staticClass: 'v-progress-linear__buffer',\n style: this.styles,\n })\n },\n __cachedDeterminate (): VNode {\n return this.$createElement('div', this.setBackgroundColor(this.color, {\n staticClass: `v-progress-linear__determinate`,\n style: {\n width: convertToUnit(this.normalizedValue, '%'),\n },\n }))\n },\n __cachedIndeterminate (): VNode {\n return this.$createElement('div', {\n staticClass: 'v-progress-linear__indeterminate',\n class: {\n 'v-progress-linear__indeterminate--active': this.active,\n },\n }, [\n this.genProgressBar('long'),\n this.genProgressBar('short'),\n ])\n },\n __cachedStream (): VNode | null {\n if (!this.stream) return null\n\n return this.$createElement('div', this.setTextColor(this.color, {\n staticClass: 'v-progress-linear__stream',\n style: {\n width: convertToUnit(100 - this.normalizedBuffer, '%'),\n },\n }))\n },\n backgroundStyle (): object {\n const backgroundOpacity = this.backgroundOpacity == null\n ? (this.backgroundColor ? 1 : 0.3)\n : parseFloat(this.backgroundOpacity)\n\n return {\n opacity: backgroundOpacity,\n [this.isReversed ? 'right' : 'left']: convertToUnit(this.normalizedValue, '%'),\n width: convertToUnit(Math.max(0, this.normalizedBuffer - this.normalizedValue), '%'),\n }\n },\n classes (): object {\n return {\n 'v-progress-linear--absolute': this.absolute,\n 'v-progress-linear--fixed': this.fixed,\n 'v-progress-linear--query': this.query,\n 'v-progress-linear--reactive': this.reactive,\n 'v-progress-linear--reverse': this.isReversed,\n 'v-progress-linear--rounded': this.rounded,\n 'v-progress-linear--striped': this.striped,\n 'v-progress-linear--visible': this.isVisible,\n ...this.themeClasses,\n }\n },\n computedTransition (): FunctionalComponentOptions {\n return this.indeterminate ? VFadeTransition : VSlideXTransition\n },\n isReversed (): boolean {\n return this.$vuetify.rtl !== this.reverse\n },\n normalizedBuffer (): number {\n return this.normalize(this.bufferValue)\n },\n normalizedValue (): number {\n return this.normalize(this.internalLazyValue)\n },\n reactive (): boolean {\n return Boolean(this.$listeners.change)\n },\n styles (): object {\n const styles: Record = {}\n\n if (!this.active) {\n styles.height = 0\n }\n\n if (!this.indeterminate && parseFloat(this.normalizedBuffer) !== 100) {\n styles.width = convertToUnit(this.normalizedBuffer, '%')\n }\n\n return styles\n },\n },\n\n methods: {\n genContent () {\n const slot = getSlot(this, 'default', { value: this.internalLazyValue })\n\n if (!slot) return null\n\n return this.$createElement('div', {\n staticClass: 'v-progress-linear__content',\n }, slot)\n },\n genListeners () {\n const listeners = this.$listeners\n\n if (this.reactive) {\n listeners.click = this.onClick\n }\n\n return listeners\n },\n genProgressBar (name: 'long' | 'short') {\n return this.$createElement('div', this.setBackgroundColor(this.color, {\n staticClass: 'v-progress-linear__indeterminate',\n class: {\n [name]: true,\n },\n }))\n },\n onClick (e: MouseEvent) {\n if (!this.reactive) return\n\n const { width } = this.$el.getBoundingClientRect()\n\n this.internalValue = e.offsetX / width * 100\n },\n onObserve (entries: IntersectionObserverEntry[], observer: IntersectionObserver, isIntersecting: boolean) {\n this.isVisible = isIntersecting\n },\n normalize (value: string | number) {\n if (value < 0) return 0\n if (value > 100) return 100\n return parseFloat(value)\n },\n },\n\n render (h): VNode {\n const data = {\n staticClass: 'v-progress-linear',\n attrs: {\n role: 'progressbar',\n 'aria-valuemin': 0,\n 'aria-valuemax': this.normalizedBuffer,\n 'aria-valuenow': this.indeterminate ? undefined : this.normalizedValue,\n },\n class: this.classes,\n directives: [{\n name: 'intersect',\n value: this.onObserve,\n }],\n style: {\n bottom: this.bottom ? 0 : undefined,\n height: this.active ? convertToUnit(this.height) : 0,\n top: this.top ? 0 : undefined,\n },\n on: this.genListeners(),\n }\n\n return h('div', data, [\n this.__cachedStream,\n this.__cachedBackground,\n this.__cachedBuffer,\n this.__cachedBar,\n this.genContent(),\n ])\n },\n})\n","import VProgressLinear from './VProgressLinear'\n\nexport { VProgressLinear }\nexport default VProgressLinear\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 VTabs from './VTabs'\nimport VTab from './VTab'\nimport VTabsItems from './VTabsItems'\nimport VTabItem from './VTabItem'\nimport VTabsSlider from './VTabsSlider'\n\nexport { VTabs, VTab, VTabItem, VTabsItems, VTabsSlider }\n\nexport default {\n $_vuetify_subcomponents: {\n VTabs,\n VTab,\n VTabsItems,\n VTabItem,\n VTabsSlider,\n },\n}\n","// Styles\nimport './VProgressCircular.sass'\n\n// Directives\nimport intersect from '../../directives/intersect'\n\n// Mixins\nimport Colorable from '../../mixins/colorable'\n\n// Utils\nimport { convertToUnit } from '../../util/helpers'\n\n// Types\nimport { VNode, VNodeChildren } from 'vue'\n\n/* @vue/component */\nexport default Colorable.extend({\n name: 'v-progress-circular',\n\n directives: { intersect },\n\n props: {\n button: Boolean,\n indeterminate: Boolean,\n rotate: {\n type: [Number, String],\n default: 0,\n },\n size: {\n type: [Number, String],\n default: 32,\n },\n width: {\n type: [Number, String],\n default: 4,\n },\n value: {\n type: [Number, String],\n default: 0,\n },\n },\n\n data: () => ({\n radius: 20,\n isVisible: true,\n }),\n\n computed: {\n calculatedSize (): number {\n return Number(this.size) + (this.button ? 8 : 0)\n },\n\n circumference (): number {\n return 2 * Math.PI * this.radius\n },\n\n classes (): object {\n return {\n 'v-progress-circular--visible': this.isVisible,\n 'v-progress-circular--indeterminate': this.indeterminate,\n 'v-progress-circular--button': this.button,\n }\n },\n\n normalizedValue (): number {\n if (this.value < 0) {\n return 0\n }\n\n if (this.value > 100) {\n return 100\n }\n\n return parseFloat(this.value)\n },\n\n strokeDashArray (): number {\n return Math.round(this.circumference * 1000) / 1000\n },\n\n strokeDashOffset (): string {\n return ((100 - this.normalizedValue) / 100) * this.circumference + 'px'\n },\n\n strokeWidth (): number {\n return Number(this.width) / +this.size * this.viewBoxSize * 2\n },\n\n styles (): object {\n return {\n height: convertToUnit(this.calculatedSize),\n width: convertToUnit(this.calculatedSize),\n }\n },\n\n svgStyles (): object {\n return {\n transform: `rotate(${Number(this.rotate)}deg)`,\n }\n },\n\n viewBoxSize (): number {\n return this.radius / (1 - Number(this.width) / +this.size)\n },\n },\n\n methods: {\n genCircle (name: string, offset: string | number): VNode {\n return this.$createElement('circle', {\n class: `v-progress-circular__${name}`,\n attrs: {\n fill: 'transparent',\n cx: 2 * this.viewBoxSize,\n cy: 2 * this.viewBoxSize,\n r: this.radius,\n 'stroke-width': this.strokeWidth,\n 'stroke-dasharray': this.strokeDashArray,\n 'stroke-dashoffset': offset,\n },\n })\n },\n genSvg (): VNode {\n const children = [\n this.indeterminate || this.genCircle('underlay', 0),\n this.genCircle('overlay', this.strokeDashOffset),\n ] as VNodeChildren\n\n return this.$createElement('svg', {\n style: this.svgStyles,\n attrs: {\n xmlns: 'http://www.w3.org/2000/svg',\n viewBox: `${this.viewBoxSize} ${this.viewBoxSize} ${2 * this.viewBoxSize} ${2 * this.viewBoxSize}`,\n },\n }, children)\n },\n genInfo (): VNode {\n return this.$createElement('div', {\n staticClass: 'v-progress-circular__info',\n }, this.$slots.default)\n },\n onObserve (entries: IntersectionObserverEntry[], observer: IntersectionObserver, isIntersecting: boolean) {\n this.isVisible = isIntersecting\n },\n },\n\n render (h): VNode {\n return h('div', this.setTextColor(this.color, {\n staticClass: 'v-progress-circular',\n attrs: {\n role: 'progressbar',\n 'aria-valuemin': 0,\n 'aria-valuemax': 100,\n 'aria-valuenow': this.indeterminate ? undefined : this.normalizedValue,\n },\n class: this.classes,\n directives: [{\n name: 'intersect',\n value: this.onObserve,\n }],\n style: this.styles,\n on: this.$listeners,\n }), [\n this.genSvg(),\n this.genInfo(),\n ])\n },\n})\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","// Styles\nimport './VSystemBar.sass'\n\n// Mixins\nimport Applicationable from '../../mixins/applicationable'\nimport Colorable from '../../mixins/colorable'\nimport Themeable from '../../mixins/themeable'\n\n// Utilities\nimport mixins from '../../util/mixins'\nimport { convertToUnit, getSlot } from '../../util/helpers'\n\n// Types\nimport { VNode } from 'vue/types'\n\nexport default mixins(\n Applicationable('bar', [\n 'height',\n 'window',\n ]),\n Colorable,\n Themeable\n/* @vue/component */\n).extend({\n name: 'v-system-bar',\n\n props: {\n height: [Number, String],\n lightsOut: Boolean,\n window: Boolean,\n },\n\n computed: {\n classes (): object {\n return {\n 'v-system-bar--lights-out': this.lightsOut,\n 'v-system-bar--absolute': this.absolute,\n 'v-system-bar--fixed': !this.absolute && (this.app || this.fixed),\n 'v-system-bar--window': this.window,\n ...this.themeClasses,\n }\n },\n computedHeight (): number | string {\n if (this.height) {\n return isNaN(parseInt(this.height)) ? this.height : parseInt(this.height)\n }\n\n return this.window ? 32 : 24\n },\n styles (): object {\n return {\n height: convertToUnit(this.computedHeight),\n }\n },\n },\n\n methods: {\n updateApplication () {\n return this.$el\n ? this.$el.clientHeight\n : this.computedHeight\n },\n },\n\n render (h): VNode {\n const data = {\n staticClass: 'v-system-bar',\n class: this.classes,\n style: this.styles,\n on: this.$listeners,\n }\n\n return h('div', this.setBackgroundColor(this.color, data), getSlot(this))\n },\n})\n","// Styles\nimport '../../styles/components/_selection-controls.sass'\nimport './VRadioGroup.sass'\n\n// Extensions\nimport VInput from '../VInput'\nimport { BaseItemGroup } from '../VItemGroup/VItemGroup'\n\n// Mixins\nimport Comparable from '../../mixins/comparable'\n\n// Types\nimport mixins from '../../util/mixins'\nimport { PropType } from 'vue'\n\nconst baseMixins = mixins(\n Comparable,\n BaseItemGroup,\n VInput\n)\n\n/* @vue/component */\nexport default baseMixins.extend({\n name: 'v-radio-group',\n\n provide () {\n return {\n radioGroup: this,\n }\n },\n\n props: {\n column: {\n type: Boolean,\n default: true,\n },\n height: {\n type: [Number, String],\n default: 'auto',\n },\n name: String,\n row: Boolean,\n // If no value set on VRadio\n // will match valueComparator\n // force default to null\n value: null as unknown as PropType,\n },\n\n computed: {\n classes (): object {\n return {\n ...VInput.options.computed.classes.call(this),\n 'v-input--selection-controls v-input--radio-group': true,\n 'v-input--radio-group--column': this.column && !this.row,\n 'v-input--radio-group--row': this.row,\n }\n },\n },\n\n methods: {\n genDefaultSlot () {\n return this.$createElement('div', {\n staticClass: 'v-input--radio-group__input',\n attrs: {\n id: this.id,\n role: 'radiogroup',\n 'aria-labelledby': this.computedId,\n },\n }, VInput.options.methods.genDefaultSlot.call(this))\n },\n genInputSlot () {\n const render = VInput.options.methods.genInputSlot.call(this)\n\n delete render.data!.on!.click\n\n return render\n },\n genLabel () {\n const label = VInput.options.methods.genLabel.call(this)\n\n if (!label) return null\n\n label.data!.attrs!.id = this.computedId\n // WAI considers this an orphaned label\n delete label.data!.attrs!.for\n label.tag = 'legend'\n\n return label\n },\n onClick: BaseItemGroup.options.methods.onClick,\n },\n})\n","// Styles\nimport './VRadio.sass'\n\n// Components\nimport VRadioGroup from './VRadioGroup'\nimport VLabel from '../VLabel'\nimport VIcon from '../VIcon'\nimport VInput from '../VInput'\n\n// Mixins\nimport BindsAttrs from '../../mixins/binds-attrs'\nimport Colorable from '../../mixins/colorable'\nimport { factory as GroupableFactory } from '../../mixins/groupable'\nimport Rippleable from '../../mixins/rippleable'\nimport Themeable from '../../mixins/themeable'\nimport Selectable, { prevent } from '../../mixins/selectable'\n\n// Utilities\nimport { getSlot } from '../../util/helpers'\n\n// Types\nimport { VNode, VNodeData } from 'vue'\nimport mixins from '../../util/mixins'\nimport { mergeListeners } from '../../util/mergeData'\n\nconst baseMixins = mixins(\n BindsAttrs,\n Colorable,\n Rippleable,\n GroupableFactory('radioGroup'),\n Themeable\n)\n\ninterface options extends InstanceType {\n radioGroup: InstanceType\n}\n\n/* @vue/component */\nexport default baseMixins.extend().extend({\n name: 'v-radio',\n\n inheritAttrs: false,\n\n props: {\n disabled: Boolean,\n id: String,\n label: String,\n name: String,\n offIcon: {\n type: String,\n default: '$radioOff',\n },\n onIcon: {\n type: String,\n default: '$radioOn',\n },\n readonly: Boolean,\n value: {\n default: null,\n },\n },\n\n data: () => ({\n isFocused: false,\n }),\n\n computed: {\n classes (): object {\n return {\n 'v-radio--is-disabled': this.isDisabled,\n 'v-radio--is-focused': this.isFocused,\n ...this.themeClasses,\n ...this.groupClasses,\n }\n },\n computedColor (): string | undefined {\n return Selectable.options.computed.computedColor.call(this)\n },\n computedIcon (): string {\n return this.isActive\n ? this.onIcon\n : this.offIcon\n },\n computedId (): string {\n return VInput.options.computed.computedId.call(this)\n },\n hasLabel: VInput.options.computed.hasLabel,\n hasState (): boolean {\n return (this.radioGroup || {}).hasState\n },\n isDisabled (): boolean {\n return this.disabled || (\n !!this.radioGroup &&\n this.radioGroup.isDisabled\n )\n },\n isReadonly (): boolean {\n return this.readonly || (\n !!this.radioGroup &&\n this.radioGroup.isReadonly\n )\n },\n computedName (): string {\n if (this.name || !this.radioGroup) {\n return this.name\n }\n\n return this.radioGroup.name || `radio-${this.radioGroup._uid}`\n },\n rippleState (): string | undefined {\n return Selectable.options.computed.rippleState.call(this)\n },\n validationState (): string | undefined {\n return (this.radioGroup || {}).validationState || this.computedColor\n },\n },\n\n methods: {\n genInput (args: any) {\n // We can't actually use the mixin directly because\n // it's made for standalone components, but its\n // genInput method is exactly what we need\n return Selectable.options.methods.genInput.call(this, 'radio', args)\n },\n genLabel () {\n if (!this.hasLabel) return null\n\n return this.$createElement(VLabel, {\n on: {\n // Label shouldn't cause the input to focus\n click: prevent,\n },\n attrs: {\n for: this.computedId,\n },\n props: {\n color: this.validationState,\n focused: this.hasState,\n },\n }, getSlot(this, 'label') || this.label)\n },\n genRadio () {\n const { title, ...radioAttrs } = this.attrs$\n\n return this.$createElement('div', {\n staticClass: 'v-input--selection-controls__input',\n }, [\n this.$createElement(VIcon, this.setTextColor(this.validationState, {\n props: {\n dense: this.radioGroup && this.radioGroup.dense,\n },\n }), this.computedIcon),\n this.genInput({\n name: this.computedName,\n value: this.value,\n ...radioAttrs,\n }),\n this.genRipple(this.setTextColor(this.rippleState)),\n ])\n },\n onFocus (e: Event) {\n this.isFocused = true\n this.$emit('focus', e)\n },\n onBlur (e: Event) {\n this.isFocused = false\n this.$emit('blur', e)\n },\n onChange () {\n if (this.isDisabled || this.isReadonly || this.isActive) return\n\n this.toggle()\n },\n onKeydown: () => {}, // Override default with noop\n },\n\n render (h): VNode {\n const data: VNodeData = {\n staticClass: 'v-radio',\n class: this.classes,\n on: mergeListeners({\n click: this.onChange,\n }, this.listeners$),\n attrs: { title: this.attrs$.title },\n }\n\n return h('div', data, [\n this.genRadio(),\n this.genLabel(),\n ])\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","// Styles\nimport './VRangeSlider.sass'\n\n// Components\nimport VSlider from '../VSlider'\n\n// Helpers\nimport {\n addOnceEventListener,\n createRange,\n deepEqual,\n passiveSupported,\n} from '../../util/helpers'\n\n// Types\nimport { PropValidator } from 'vue/types/options'\n\n/* @vue/component */\nexport default VSlider.extend({\n name: 'v-range-slider',\n\n props: {\n value: {\n type: Array,\n default: () => ([0, 0]),\n } as unknown as PropValidator<[number, number]>,\n },\n\n data () {\n return {\n activeThumb: null as null | number,\n lazyValue: this.value,\n }\n },\n\n computed: {\n classes (): object {\n return {\n ...VSlider.options.computed.classes.call(this),\n 'v-input--range-slider': true,\n }\n },\n internalValue: {\n get (): number[] {\n return this.lazyValue\n },\n set (val: number[]) {\n // Round value to ensure the\n // entire slider range can\n // be selected with step\n let value = val.map((v = 0) => this.roundValue(Math.min(Math.max(v, this.minValue), this.maxValue)))\n\n // Switch values if range and wrong order\n if (value[0] > value[1] || value[1] < value[0]) {\n if (this.activeThumb !== null) {\n const toFocus = this.activeThumb === 1 ? 0 : 1\n const el = this.$refs[`thumb_${toFocus}`] as HTMLElement\n el.focus()\n }\n value = [value[1], value[0]]\n }\n\n this.lazyValue = value\n if (!deepEqual(value, this.value)) this.$emit('input', value)\n\n this.validate()\n },\n },\n inputWidth (): number[] {\n return this.internalValue.map((v: number) => (\n this.roundValue(v) - this.minValue) / (this.maxValue - this.minValue) * 100\n )\n },\n },\n\n methods: {\n getTrackStyle (startLength: number, endLength: number, startPadding = 0, endPadding = 0) {\n const startDir = this.vertical ? this.$vuetify.rtl ? 'top' : 'bottom' : this.$vuetify.rtl ? 'right' : 'left'\n const endDir = this.vertical ? 'height' : 'width'\n\n const start = `calc(${startLength}% + ${startPadding}px)`\n const end = `calc(${endLength}% + ${endPadding}px)`\n\n return {\n transition: this.trackTransition,\n [startDir]: start,\n [endDir]: end,\n }\n },\n getIndexOfClosestValue (arr: number[], v: number) {\n if (Math.abs(arr[0] - v) < Math.abs(arr[1] - v)) return 0\n else return 1\n },\n genInput () {\n return createRange(2).map(i => {\n const input = VSlider.options.methods.genInput.call(this)\n\n input.data = input.data || {}\n input.data.attrs = input.data.attrs || {}\n input.data.attrs.value = this.internalValue[i]\n input.data.attrs.id = `input-${i ? 'max' : 'min'}-${this._uid}`\n\n return input\n })\n },\n genTrackContainer () {\n const children = []\n\n const padding = this.isDisabled ? 10 : 0\n const sections: { class: string, color: string | undefined, styles: [number, number, number, number] }[] = [\n {\n class: 'v-slider__track-background',\n color: this.computedTrackColor,\n styles: [0, this.inputWidth[0], 0, -padding],\n },\n {\n class: this.isDisabled ? 'v-slider__track-background' : 'v-slider__track-fill',\n color: this.isDisabled ? this.computedTrackColor : this.computedTrackFillColor,\n styles: [this.inputWidth[0], Math.abs(this.inputWidth[1] - this.inputWidth[0]), padding, padding * -2],\n },\n {\n class: 'v-slider__track-background',\n color: this.computedTrackColor,\n styles: [this.inputWidth[1], Math.abs(100 - this.inputWidth[1]), padding, -padding],\n },\n ]\n\n if (this.$vuetify.rtl) sections.reverse()\n\n children.push(...sections.map(section => this.$createElement('div', this.setBackgroundColor(section.color, {\n staticClass: section.class,\n style: this.getTrackStyle(...section.styles),\n }))))\n\n return this.$createElement('div', {\n staticClass: 'v-slider__track-container',\n ref: 'track',\n }, children)\n },\n genChildren () {\n return [\n this.genInput(),\n this.genTrackContainer(),\n this.genSteps(),\n createRange(2).map(index => {\n const value = this.internalValue[index]\n const onFocus = (e: Event) => {\n this.isFocused = true\n this.activeThumb = index\n\n this.$emit('focus', e)\n }\n\n const onBlur = (e: Event) => {\n this.isFocused = false\n this.activeThumb = null\n\n this.$emit('blur', e)\n }\n\n const valueWidth = this.inputWidth[index]\n const isActive = this.isActive && this.activeThumb === index\n const isFocused = this.isFocused && this.activeThumb === index\n\n return this.genThumbContainer(value, valueWidth, isActive, isFocused, onFocus, onBlur, `thumb_${index}`)\n }),\n ]\n },\n reevaluateSelected (value: number) {\n this.activeThumb = this.getIndexOfClosestValue(this.internalValue, value)\n const refName = `thumb_${this.activeThumb}`\n const thumbRef = this.$refs[refName] as HTMLElement\n thumbRef.focus()\n },\n onSliderMouseDown (e: MouseEvent) {\n const value = this.parseMouseMove(e)\n\n this.reevaluateSelected(value)\n\n this.oldValue = this.internalValue\n this.isActive = true\n\n if ((e.target as Element)?.matches('.v-slider__thumb-container, .v-slider__thumb-container *')) {\n this.thumbPressed = true\n } else {\n window.clearTimeout(this.mouseTimeout)\n this.mouseTimeout = window.setTimeout(() => {\n this.thumbPressed = true\n }, 300)\n }\n\n const mouseUpOptions = passiveSupported ? { passive: true, capture: true } : true\n const mouseMoveOptions = passiveSupported ? { passive: true } : false\n\n const isTouchEvent = 'touches' in e\n\n this.onMouseMove(e)\n this.app.addEventListener(isTouchEvent ? 'touchmove' : 'mousemove', this.onMouseMove, mouseMoveOptions)\n addOnceEventListener(this.app, isTouchEvent ? 'touchend' : 'mouseup', this.onSliderMouseUp, mouseUpOptions)\n\n this.$emit('start', this.internalValue)\n },\n onSliderClick (e: MouseEvent) {\n if (!this.isActive) {\n if (this.noClick) {\n this.noClick = false\n return\n }\n\n const value = this.parseMouseMove(e)\n\n this.reevaluateSelected(value)\n\n this.setInternalValue(value)\n\n this.$emit('change', this.internalValue)\n }\n },\n onMouseMove (e: MouseEvent) {\n const value = this.parseMouseMove(e)\n\n if (e.type === 'mousemove') {\n this.thumbPressed = true\n }\n\n this.activeThumb = this.getIndexOfClosestValue(this.internalValue, value)\n\n this.setInternalValue(value)\n },\n onKeyDown (e: KeyboardEvent) {\n if (this.activeThumb === null) return\n\n const value = this.parseKeyDown(e, this.internalValue[this.activeThumb])\n\n if (value == null) return\n\n this.setInternalValue(value)\n this.$emit('change', this.internalValue)\n },\n setInternalValue (value: number) {\n this.internalValue = this.internalValue.map((v: number, i: number) => {\n if (i === this.activeThumb) return value\n else return Number(v)\n })\n },\n },\n})\n","import './VResponsive.sass'\n\n// Mixins\nimport Measurable, { NumberOrNumberString } from '../../mixins/measurable'\n\n// Types\nimport { VNode } from 'vue'\n\n// Utils\nimport mixins from '../../util/mixins'\n\n/* @vue/component */\nexport default mixins(Measurable).extend({\n name: 'v-responsive',\n\n props: {\n aspectRatio: [String, Number] as NumberOrNumberString,\n contentClass: String,\n },\n\n computed: {\n computedAspectRatio (): number {\n return Number(this.aspectRatio)\n },\n aspectStyle (): object | undefined {\n return this.computedAspectRatio\n ? { paddingBottom: (1 / this.computedAspectRatio) * 100 + '%' }\n : undefined\n },\n __cachedSizer (): VNode | [] {\n if (!this.aspectStyle) return []\n\n return this.$createElement('div', {\n style: this.aspectStyle,\n staticClass: 'v-responsive__sizer',\n })\n },\n },\n\n methods: {\n genContent (): VNode {\n return this.$createElement('div', {\n staticClass: 'v-responsive__content',\n class: this.contentClass,\n }, this.$slots.default)\n },\n },\n\n render (h): VNode {\n return h('div', {\n staticClass: 'v-responsive',\n style: this.measurableStyles,\n on: this.$listeners,\n }, [\n this.__cachedSizer,\n this.genContent(),\n ])\n },\n})\n","import VResponsive from './VResponsive'\n\nexport { VResponsive }\nexport default VResponsive\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 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\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 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 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 = 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 // 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","// Styles\nimport './VRating.sass'\n\n// Components\nimport VIcon from '../VIcon'\n\n// Mixins\nimport Colorable from '../../mixins/colorable'\nimport Delayable from '../../mixins/delayable'\nimport Sizeable from '../../mixins/sizeable'\nimport Rippleable from '../../mixins/rippleable'\nimport Themeable from '../../mixins/themeable'\n\n// Utilities\nimport { createRange } from '../../util/helpers'\nimport mixins from '../../util/mixins'\n\n// Types\nimport { VNode, VNodeDirective, VNodeChildren } from 'vue'\n\ntype ItemSlotProps = {\n index: number\n value: number\n isFilled: boolean\n isHalfFilled?: boolean | undefined\n isHovered: boolean\n isHalfHovered?: boolean | undefined\n click: Function\n}\n\n/* @vue/component */\nexport default mixins(\n Colorable,\n Delayable,\n Rippleable,\n Sizeable,\n Themeable\n).extend({\n name: 'v-rating',\n\n props: {\n backgroundColor: {\n type: String,\n default: 'accent',\n },\n color: {\n type: String,\n default: 'primary',\n },\n clearable: Boolean,\n dense: Boolean,\n emptyIcon: {\n type: String,\n default: '$ratingEmpty',\n },\n fullIcon: {\n type: String,\n default: '$ratingFull',\n },\n halfIcon: {\n type: String,\n default: '$ratingHalf',\n },\n halfIncrements: Boolean,\n hover: Boolean,\n length: {\n type: [Number, String],\n default: 5,\n },\n readonly: Boolean,\n size: [Number, String],\n value: {\n type: Number,\n default: 0,\n },\n iconLabel: {\n type: String,\n default: '$vuetify.rating.ariaLabel.icon',\n },\n },\n\n data () {\n return {\n hoverIndex: -1,\n internalValue: this.value,\n }\n },\n\n computed: {\n directives (): VNodeDirective[] {\n if (this.readonly || !this.ripple) return []\n\n return [{\n name: 'ripple',\n value: { circle: true },\n } as VNodeDirective]\n },\n iconProps (): object {\n const {\n dark,\n large,\n light,\n medium,\n small,\n size,\n xLarge,\n xSmall,\n } = this.$props\n\n return {\n dark,\n large,\n light,\n medium,\n size,\n small,\n xLarge,\n xSmall,\n }\n },\n isHovering (): boolean {\n return this.hover && this.hoverIndex >= 0\n },\n },\n\n watch: {\n internalValue (val) {\n val !== this.value && this.$emit('input', val)\n },\n value (val) {\n this.internalValue = val\n },\n },\n\n methods: {\n createClickFn (i: number): Function {\n return (e: MouseEvent) => {\n if (this.readonly) return\n\n const newValue = this.genHoverIndex(e, i)\n if (this.clearable && this.internalValue === newValue) {\n this.internalValue = 0\n } else {\n this.internalValue = newValue\n }\n }\n },\n createProps (i: number): ItemSlotProps {\n const props: ItemSlotProps = {\n index: i,\n value: this.internalValue,\n click: this.createClickFn(i),\n isFilled: Math.floor(this.internalValue) > i,\n isHovered: Math.floor(this.hoverIndex) > i,\n }\n\n if (this.halfIncrements) {\n props.isHalfHovered = !props.isHovered && (this.hoverIndex - i) % 1 > 0\n props.isHalfFilled = !props.isFilled && (this.internalValue - i) % 1 > 0\n }\n\n return props\n },\n genHoverIndex (e: MouseEvent, i: number) {\n let isHalf = this.isHalfEvent(e)\n\n if (\n this.halfIncrements &&\n this.$vuetify.rtl\n ) {\n isHalf = !isHalf\n }\n\n return i + (isHalf ? 0.5 : 1)\n },\n getIconName (props: ItemSlotProps): string {\n const isFull = this.isHovering ? props.isHovered : props.isFilled\n const isHalf = this.isHovering ? props.isHalfHovered : props.isHalfFilled\n\n return isFull ? this.fullIcon : isHalf ? this.halfIcon : this.emptyIcon\n },\n getColor (props: ItemSlotProps): string {\n if (this.isHovering) {\n if (props.isHovered || props.isHalfHovered) return this.color\n } else {\n if (props.isFilled || props.isHalfFilled) return this.color\n }\n\n return this.backgroundColor\n },\n isHalfEvent (e: MouseEvent): boolean {\n if (this.halfIncrements) {\n const rect = e.target && (e.target as HTMLElement).getBoundingClientRect()\n if (rect && (e.pageX - rect.left) < rect.width / 2) return true\n }\n\n return false\n },\n onMouseEnter (e: MouseEvent, i: number): void {\n this.runDelay('open', () => {\n this.hoverIndex = this.genHoverIndex(e, i)\n })\n },\n onMouseLeave (): void {\n this.runDelay('close', () => (this.hoverIndex = -1))\n },\n genItem (i: number): VNode | VNodeChildren | string {\n const props = this.createProps(i)\n\n if (this.$scopedSlots.item) return this.$scopedSlots.item(props)\n\n const listeners: Record = {\n click: props.click,\n }\n\n if (this.hover) {\n listeners.mouseenter = (e: MouseEvent) => this.onMouseEnter(e, i)\n listeners.mouseleave = this.onMouseLeave\n\n if (this.halfIncrements) {\n listeners.mousemove = (e: MouseEvent) => this.onMouseEnter(e, i)\n }\n }\n\n return this.$createElement(VIcon, this.setTextColor(this.getColor(props), {\n attrs: {\n 'aria-label': this.$vuetify.lang.t(this.iconLabel, i + 1, Number(this.length)),\n },\n directives: this.directives,\n props: this.iconProps,\n on: listeners,\n }), [this.getIconName(props)])\n },\n },\n\n render (h): VNode {\n const children = createRange(Number(this.length)).map(i => this.genItem(i))\n\n return h('div', {\n staticClass: 'v-rating',\n class: {\n 'v-rating--readonly': this.readonly,\n 'v-rating--dense': this.dense,\n },\n }, children)\n },\n})\n","// Styles\nimport './VTextField.sass'\n\n// Extensions\nimport VInput from '../VInput'\n\n// Components\nimport VCounter from '../VCounter'\nimport VLabel from '../VLabel'\n\n// Mixins\nimport Intersectable from '../../mixins/intersectable'\nimport Loadable from '../../mixins/loadable'\nimport Validatable from '../../mixins/validatable'\n\n// Directives\nimport resize from '../../directives/resize'\nimport ripple from '../../directives/ripple'\n\n// Utilities\nimport { attachedRoot } from '../../util/dom'\nimport { convertToUnit, keyCodes } from '../../util/helpers'\nimport { breaking, consoleWarn } from '../../util/console'\n\n// Types\nimport mixins from '../../util/mixins'\nimport { VNode, PropType } from 'vue/types'\n\nconst baseMixins = mixins(\n VInput,\n Intersectable({\n onVisible: [\n 'onResize',\n 'tryAutofocus',\n ],\n }),\n Loadable,\n)\ninterface options extends InstanceType {\n $refs: {\n label: HTMLElement\n input: HTMLInputElement\n 'prepend-inner': HTMLElement\n prefix: HTMLElement\n suffix: HTMLElement\n }\n}\n\nconst dirtyTypes = ['color', 'file', 'time', 'date', 'datetime-local', 'week', 'month']\n\n/* @vue/component */\nexport default baseMixins.extend().extend({\n name: 'v-text-field',\n\n directives: {\n resize,\n ripple,\n },\n\n inheritAttrs: false,\n\n props: {\n appendOuterIcon: String,\n autofocus: Boolean,\n clearable: Boolean,\n clearIcon: {\n type: String,\n default: '$clear',\n },\n counter: [Boolean, Number, String],\n counterValue: Function as PropType<(value: any) => number>,\n filled: Boolean,\n flat: Boolean,\n fullWidth: Boolean,\n label: String,\n outlined: Boolean,\n placeholder: String,\n prefix: String,\n prependInnerIcon: String,\n persistentPlaceholder: Boolean,\n reverse: Boolean,\n rounded: Boolean,\n shaped: Boolean,\n singleLine: Boolean,\n solo: Boolean,\n soloInverted: Boolean,\n suffix: String,\n type: {\n type: String,\n default: 'text',\n },\n },\n\n data: () => ({\n badInput: false,\n labelWidth: 0,\n prefixWidth: 0,\n prependWidth: 0,\n initialValue: null,\n isBooted: false,\n isClearing: false,\n }),\n\n computed: {\n classes (): object {\n return {\n ...VInput.options.computed.classes.call(this),\n 'v-text-field': true,\n 'v-text-field--full-width': this.fullWidth,\n 'v-text-field--prefix': this.prefix,\n 'v-text-field--single-line': this.isSingle,\n 'v-text-field--solo': this.isSolo,\n 'v-text-field--solo-inverted': this.soloInverted,\n 'v-text-field--solo-flat': this.flat,\n 'v-text-field--filled': this.filled,\n 'v-text-field--is-booted': this.isBooted,\n 'v-text-field--enclosed': this.isEnclosed,\n 'v-text-field--reverse': this.reverse,\n 'v-text-field--outlined': this.outlined,\n 'v-text-field--placeholder': this.placeholder,\n 'v-text-field--rounded': this.rounded,\n 'v-text-field--shaped': this.shaped,\n }\n },\n computedColor (): string | undefined {\n const computedColor = Validatable.options.computed.computedColor.call(this)\n\n if (!this.soloInverted || !this.isFocused) return computedColor\n\n return this.color || 'primary'\n },\n computedCounterValue (): number {\n if (typeof this.counterValue === 'function') {\n return this.counterValue(this.internalValue)\n }\n return [...(this.internalValue || '').toString()].length\n },\n hasCounter (): boolean {\n return this.counter !== false && this.counter != null\n },\n hasDetails (): boolean {\n return VInput.options.computed.hasDetails.call(this) || this.hasCounter\n },\n internalValue: {\n get (): any {\n return this.lazyValue\n },\n set (val: any) {\n this.lazyValue = val\n this.$emit('input', this.lazyValue)\n },\n },\n isDirty (): boolean {\n return this.lazyValue?.toString().length > 0 || this.badInput\n },\n isEnclosed (): boolean {\n return (\n this.filled ||\n this.isSolo ||\n this.outlined\n )\n },\n isLabelActive (): boolean {\n return this.isDirty || dirtyTypes.includes(this.type)\n },\n isSingle (): boolean {\n return (\n this.isSolo ||\n this.singleLine ||\n this.fullWidth ||\n // https://material.io/components/text-fields/#filled-text-field\n (this.filled && !this.hasLabel)\n )\n },\n isSolo (): boolean {\n return this.solo || this.soloInverted\n },\n labelPosition (): Record<'left' | 'right', string | number | undefined> {\n let offset = (this.prefix && !this.labelValue) ? this.prefixWidth : 0\n\n if (this.labelValue && this.prependWidth) offset -= this.prependWidth\n\n return (this.$vuetify.rtl === this.reverse) ? {\n left: offset,\n right: 'auto',\n } : {\n left: 'auto',\n right: offset,\n }\n },\n showLabel (): boolean {\n return this.hasLabel && !(this.isSingle && this.labelValue)\n },\n labelValue (): boolean {\n return this.isFocused || this.isLabelActive || this.persistentPlaceholder\n },\n },\n\n watch: {\n // labelValue: 'setLabelWidth', // moved to mounted, see #11533\n outlined: 'setLabelWidth',\n label () {\n this.$nextTick(this.setLabelWidth)\n },\n prefix () {\n this.$nextTick(this.setPrefixWidth)\n },\n isFocused: 'updateValue',\n value (val) {\n this.lazyValue = val\n },\n },\n\n created () {\n /* istanbul ignore next */\n if (this.$attrs.hasOwnProperty('box')) {\n breaking('box', 'filled', this)\n }\n\n /* istanbul ignore next */\n if (this.$attrs.hasOwnProperty('browser-autocomplete')) {\n breaking('browser-autocomplete', 'autocomplete', this)\n }\n\n /* istanbul ignore if */\n if (this.shaped && !(this.filled || this.outlined || this.isSolo)) {\n consoleWarn('shaped should be used with either filled or outlined', this)\n }\n },\n\n mounted () {\n // #11533\n this.$watch(() => this.labelValue, this.setLabelWidth)\n\n this.autofocus && this.tryAutofocus()\n\n requestAnimationFrame(() => (this.isBooted = true))\n },\n\n methods: {\n /** @public */\n focus () {\n this.onFocus()\n },\n /** @public */\n blur (e?: Event) {\n // https://github.com/vuetifyjs/vuetify/issues/5913\n // Safari tab order gets broken if called synchronous\n window.requestAnimationFrame(() => {\n this.$refs.input && this.$refs.input.blur()\n })\n },\n clearableCallback () {\n this.$refs.input && this.$refs.input.focus()\n this.$nextTick(() => this.internalValue = null)\n },\n genAppendSlot () {\n const slot = []\n\n if (this.$slots['append-outer']) {\n slot.push(this.$slots['append-outer'] as VNode[])\n } else if (this.appendOuterIcon) {\n slot.push(this.genIcon('appendOuter'))\n }\n\n return this.genSlot('append', 'outer', slot)\n },\n genPrependInnerSlot () {\n const slot = []\n\n if (this.$slots['prepend-inner']) {\n slot.push(this.$slots['prepend-inner'] as VNode[])\n } else if (this.prependInnerIcon) {\n slot.push(this.genIcon('prependInner'))\n }\n\n return this.genSlot('prepend', 'inner', slot)\n },\n genIconSlot () {\n const slot = []\n\n if (this.$slots.append) {\n slot.push(this.$slots.append as VNode[])\n } else if (this.appendIcon) {\n slot.push(this.genIcon('append'))\n }\n\n return this.genSlot('append', 'inner', slot)\n },\n genInputSlot () {\n const input = VInput.options.methods.genInputSlot.call(this)\n\n const prepend = this.genPrependInnerSlot()\n\n if (prepend) {\n input.children = input.children || []\n input.children.unshift(prepend)\n }\n\n return input\n },\n genClearIcon () {\n if (!this.clearable) return null\n\n const data = this.isDirty ? undefined : { attrs: { disabled: true } }\n\n return this.genSlot('append', 'inner', [\n this.genIcon('clear', this.clearableCallback, data),\n ])\n },\n genCounter () {\n if (!this.hasCounter) return null\n\n const max = this.counter === true ? this.attrs$.maxlength : this.counter\n\n const props = {\n dark: this.dark,\n light: this.light,\n max,\n value: this.computedCounterValue,\n }\n\n return this.$scopedSlots.counter?.({ props }) ?? this.$createElement(VCounter, { props })\n },\n genControl () {\n return VInput.options.methods.genControl.call(this)\n },\n genDefaultSlot () {\n return [\n this.genFieldset(),\n this.genTextFieldSlot(),\n this.genClearIcon(),\n this.genIconSlot(),\n this.genProgress(),\n ]\n },\n genFieldset () {\n if (!this.outlined) return null\n\n return this.$createElement('fieldset', {\n attrs: {\n 'aria-hidden': true,\n },\n }, [this.genLegend()])\n },\n genLabel () {\n if (!this.showLabel) return null\n\n const data = {\n props: {\n absolute: true,\n color: this.validationState,\n dark: this.dark,\n disabled: this.isDisabled,\n focused: !this.isSingle && (this.isFocused || !!this.validationState),\n for: this.computedId,\n left: this.labelPosition.left,\n light: this.light,\n right: this.labelPosition.right,\n value: this.labelValue,\n },\n }\n\n return this.$createElement(VLabel, data, this.$slots.label || this.label)\n },\n genLegend () {\n const width = !this.singleLine && (this.labelValue || this.isDirty) ? this.labelWidth : 0\n const span = this.$createElement('span', {\n domProps: { innerHTML: '​' },\n })\n\n return this.$createElement('legend', {\n style: {\n width: !this.isSingle ? convertToUnit(width) : undefined,\n },\n }, [span])\n },\n genInput () {\n const listeners = Object.assign({}, this.listeners$)\n delete listeners.change // Change should not be bound externally\n const { title, ...inputAttrs } = this.attrs$\n\n return this.$createElement('input', {\n style: {},\n domProps: {\n value: (this.type === 'number' && Object.is(this.lazyValue, -0)) ? '-0' : this.lazyValue,\n },\n attrs: {\n ...inputAttrs,\n autofocus: this.autofocus,\n disabled: this.isDisabled,\n id: this.computedId,\n placeholder: this.persistentPlaceholder || this.isFocused || !this.hasLabel ? this.placeholder : undefined,\n readonly: this.isReadonly,\n type: this.type,\n },\n on: Object.assign(listeners, {\n blur: this.onBlur,\n input: this.onInput,\n focus: this.onFocus,\n keydown: this.onKeyDown,\n }),\n ref: 'input',\n directives: [{\n name: 'resize',\n modifiers: { quiet: true },\n value: this.onResize,\n }],\n })\n },\n genMessages () {\n if (!this.showDetails) return null\n\n const messagesNode = VInput.options.methods.genMessages.call(this)\n const counterNode = this.genCounter()\n\n return this.$createElement('div', {\n staticClass: 'v-text-field__details',\n }, [\n messagesNode,\n counterNode,\n ])\n },\n genTextFieldSlot () {\n return this.$createElement('div', {\n staticClass: 'v-text-field__slot',\n }, [\n this.genLabel(),\n this.prefix ? this.genAffix('prefix') : null,\n this.genInput(),\n this.suffix ? this.genAffix('suffix') : null,\n ])\n },\n genAffix (type: 'prefix' | 'suffix') {\n return this.$createElement('div', {\n class: `v-text-field__${type}`,\n ref: type,\n }, this[type])\n },\n onBlur (e?: Event) {\n this.isFocused = false\n e && this.$nextTick(() => this.$emit('blur', e))\n },\n onClick () {\n if (this.isFocused || this.isDisabled || !this.$refs.input) return\n\n this.$refs.input.focus()\n },\n onFocus (e?: Event) {\n if (!this.$refs.input) return\n\n const root = attachedRoot(this.$el)\n if (!root) return\n\n if (root.activeElement !== this.$refs.input) {\n return this.$refs.input.focus()\n }\n\n if (!this.isFocused) {\n this.isFocused = true\n e && this.$emit('focus', e)\n }\n },\n onInput (e: Event) {\n const target = e.target as HTMLInputElement\n this.internalValue = target.value\n this.badInput = target.validity && target.validity.badInput\n },\n onKeyDown (e: KeyboardEvent) {\n if (e.keyCode === keyCodes.enter) this.$emit('change', this.internalValue)\n\n this.$emit('keydown', e)\n },\n onMouseDown (e: Event) {\n // Prevent input from being blurred\n if (e.target !== this.$refs.input) {\n e.preventDefault()\n e.stopPropagation()\n }\n\n VInput.options.methods.onMouseDown.call(this, e)\n },\n onMouseUp (e: Event) {\n if (this.hasMouseDown) this.focus()\n\n VInput.options.methods.onMouseUp.call(this, e)\n },\n setLabelWidth () {\n if (!this.outlined) return\n\n this.labelWidth = this.$refs.label\n ? Math.min(this.$refs.label.scrollWidth * 0.75 + 6, (this.$el as HTMLElement).offsetWidth - 24)\n : 0\n },\n setPrefixWidth () {\n if (!this.$refs.prefix) return\n\n this.prefixWidth = this.$refs.prefix.offsetWidth\n },\n setPrependWidth () {\n if (!this.outlined || !this.$refs['prepend-inner']) return\n\n this.prependWidth = this.$refs['prepend-inner'].offsetWidth\n },\n tryAutofocus () {\n if (\n !this.autofocus ||\n typeof document === 'undefined' ||\n !this.$refs.input) return false\n\n const root = attachedRoot(this.$el)\n if (!root || root.activeElement === this.$refs.input) return false\n\n this.$refs.input.focus()\n\n return true\n },\n updateValue (val: boolean) {\n // Sets validationState from validatable\n this.hasColor = val\n\n if (val) {\n this.initialValue = this.lazyValue\n } else if (this.initialValue !== this.lazyValue) {\n this.$emit('change', this.lazyValue)\n }\n },\n onResize () {\n this.setLabelWidth()\n this.setPrefixWidth()\n this.setPrependWidth()\n },\n },\n})\n","// Styles\nimport './VSnackbar.sass'\n\n// Components\nimport VSheet from '../VSheet/VSheet'\n\n// Mixins\nimport Colorable from '../../mixins/colorable'\nimport Themeable from '../../mixins/themeable'\nimport Toggleable from '../../mixins/toggleable'\nimport { factory as PositionableFactory } from '../../mixins/positionable'\n\n// Utilities\nimport mixins from '../../util/mixins'\nimport { convertToUnit, getSlot } from '../../util/helpers'\nimport { deprecate, removed } from '../../util/console'\n\n// Types\nimport { PropType, VNode } from 'vue'\n\nexport default mixins(\n VSheet,\n Colorable,\n Toggleable,\n PositionableFactory([\n 'absolute',\n 'bottom',\n 'left',\n 'right',\n 'top',\n ])\n/* @vue/component */\n).extend({\n name: 'v-snackbar',\n\n props: {\n app: Boolean,\n centered: Boolean,\n contentClass: {\n type: String,\n default: '',\n },\n multiLine: Boolean,\n text: Boolean,\n timeout: {\n type: [Number, String],\n default: 5000,\n },\n transition: {\n type: [Boolean, String] as PropType,\n default: 'v-snack-transition',\n validator: v => typeof v === 'string' || v === false,\n },\n vertical: Boolean,\n },\n\n data: () => ({\n activeTimeout: -1,\n }),\n\n computed: {\n classes (): object {\n return {\n 'v-snack--absolute': this.absolute,\n 'v-snack--active': this.isActive,\n 'v-snack--bottom': this.bottom || !this.top,\n 'v-snack--centered': this.centered,\n 'v-snack--has-background': this.hasBackground,\n 'v-snack--left': this.left,\n 'v-snack--multi-line': this.multiLine && !this.vertical,\n 'v-snack--right': this.right,\n 'v-snack--text': this.text,\n 'v-snack--top': this.top,\n 'v-snack--vertical': this.vertical,\n }\n },\n // Text and outlined styles both\n // use transparent backgrounds\n hasBackground (): boolean {\n return (\n !this.text &&\n !this.outlined\n )\n },\n // Snackbar is dark by default\n // override themeable logic.\n isDark (): boolean {\n return this.hasBackground\n ? !this.light\n : Themeable.options.computed.isDark.call(this)\n },\n styles (): object {\n // Styles are not needed when\n // using the absolute prop.\n if (this.absolute) return {}\n\n const {\n bar,\n bottom,\n footer,\n insetFooter,\n left,\n right,\n top,\n } = this.$vuetify.application\n\n // Should always move for y-axis\n // applicationable components.\n return {\n paddingBottom: convertToUnit(bottom + footer + insetFooter),\n paddingLeft: !this.app ? undefined : convertToUnit(left),\n paddingRight: !this.app ? undefined : convertToUnit(right),\n paddingTop: convertToUnit(bar + top),\n }\n },\n },\n\n watch: {\n isActive: 'setTimeout',\n timeout: 'setTimeout',\n },\n\n mounted () {\n if (this.isActive) this.setTimeout()\n },\n\n created () {\n /* istanbul ignore next */\n if (this.$attrs.hasOwnProperty('auto-height')) {\n removed('auto-height', this)\n }\n\n /* istanbul ignore next */\n // eslint-disable-next-line eqeqeq\n if (this.timeout == 0) {\n deprecate('timeout=\"0\"', '-1', this)\n }\n },\n\n methods: {\n genActions () {\n return this.$createElement('div', {\n staticClass: 'v-snack__action ',\n }, [\n getSlot(this, 'action', {\n attrs: { class: 'v-snack__btn' },\n }),\n ])\n },\n genContent () {\n return this.$createElement('div', {\n staticClass: 'v-snack__content',\n class: {\n [this.contentClass]: true,\n },\n attrs: {\n role: 'status',\n 'aria-live': 'polite',\n },\n }, [getSlot(this)])\n },\n genWrapper () {\n const setColor = this.hasBackground\n ? this.setBackgroundColor\n : this.setTextColor\n\n const data = setColor(this.color, {\n staticClass: 'v-snack__wrapper',\n class: VSheet.options.computed.classes.call(this),\n style: VSheet.options.computed.styles.call(this),\n directives: [{\n name: 'show',\n value: this.isActive,\n }],\n on: {\n mouseenter: () => window.clearTimeout(this.activeTimeout),\n mouseleave: this.setTimeout,\n },\n })\n\n return this.$createElement('div', data, [\n this.genContent(),\n this.genActions(),\n ])\n },\n genTransition () {\n return this.$createElement('transition', {\n props: { name: this.transition },\n }, [this.genWrapper()])\n },\n setTimeout () {\n window.clearTimeout(this.activeTimeout)\n\n const timeout = Number(this.timeout)\n\n if (\n !this.isActive ||\n // TODO: remove 0 in v3\n [0, -1].includes(timeout)\n ) {\n return\n }\n\n this.activeTimeout = window.setTimeout(() => {\n this.isActive = false\n }, timeout)\n },\n },\n\n render (h): VNode {\n return h('div', {\n staticClass: 'v-snack',\n class: this.classes,\n style: this.styles,\n }, [\n this.transition !== false\n ? this.genTransition()\n : this.genWrapper(),\n ])\n },\n})\n","// Styles\nimport './VSheet.sass'\n\n// Mixins\nimport BindsAttrs from '../../mixins/binds-attrs'\nimport Colorable from '../../mixins/colorable'\nimport Elevatable from '../../mixins/elevatable'\nimport Measurable from '../../mixins/measurable'\nimport Roundable from '../../mixins/roundable'\nimport Themeable from '../../mixins/themeable'\n\n// Helpers\nimport mixins from '../../util/mixins'\n\n// Types\nimport { VNode } from 'vue'\n\n/* @vue/component */\nexport default mixins(\n BindsAttrs,\n Colorable,\n Elevatable,\n Measurable,\n Roundable,\n Themeable\n).extend({\n name: 'v-sheet',\n\n props: {\n outlined: Boolean,\n shaped: Boolean,\n tag: {\n type: String,\n default: 'div',\n },\n },\n\n computed: {\n classes (): object {\n return {\n 'v-sheet': true,\n 'v-sheet--outlined': this.outlined,\n 'v-sheet--shaped': this.shaped,\n ...this.themeClasses,\n ...this.elevationClasses,\n ...this.roundedClasses,\n }\n },\n styles (): object {\n return this.measurableStyles\n },\n },\n\n render (h): VNode {\n const data = {\n class: this.classes,\n style: this.styles,\n on: this.listeners$,\n }\n\n return h(\n this.tag,\n this.setBackgroundColor(this.color, data),\n this.$slots.default\n )\n },\n})\n","import VSlider from './VSlider'\n\nexport { VSlider }\nexport default VSlider\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 './VStepper.sass'\n\n// Extensions\nimport VSheet from '../VSheet'\n\n// Components\nimport VStepperStep from './VStepperStep'\nimport VStepperContent from './VStepperContent'\n\n// Mixins\nimport { provide as RegistrableProvide } from '../../mixins/registrable'\nimport Proxyable from '../../mixins/proxyable'\n\n// Utilities\nimport mixins from '../../util/mixins'\nimport { breaking } from '../../util/console'\n\n// Types\nimport { VNode } from 'vue'\n\nconst baseMixins = mixins(\n VSheet,\n RegistrableProvide('stepper'),\n Proxyable,\n)\n\ntype VStepperStepInstance = InstanceType\ntype VStepperContentInstance = InstanceType\n\n/* @vue/component */\nexport default baseMixins.extend({\n name: 'v-stepper',\n\n provide (): object {\n return {\n stepClick: this.stepClick,\n isVertical: this.vertical,\n }\n },\n\n props: {\n altLabels: Boolean,\n nonLinear: Boolean,\n flat: Boolean,\n vertical: Boolean,\n },\n\n data () {\n const data: Dictionary = {\n isBooted: false,\n steps: [] as VStepperStepInstance[],\n content: [] as VStepperContentInstance[],\n isReverse: false,\n }\n\n data.internalLazyValue = this.value != null\n ? this.value\n : (data[0] || {}).step || 1\n\n return data\n },\n\n computed: {\n classes (): object {\n return {\n 'v-stepper--flat': this.flat,\n 'v-stepper--is-booted': this.isBooted,\n 'v-stepper--vertical': this.vertical,\n 'v-stepper--alt-labels': this.altLabels,\n 'v-stepper--non-linear': this.nonLinear,\n ...VSheet.options.computed.classes.call(this),\n }\n },\n styles (): object {\n return {\n ...VSheet.options.computed.styles.call(this),\n }\n },\n },\n\n watch: {\n internalValue (val, oldVal) {\n this.isReverse = Number(val) < Number(oldVal)\n\n oldVal && (this.isBooted = true)\n\n this.updateView()\n },\n },\n\n created () {\n /* istanbul ignore next */\n if (this.$listeners.input) {\n breaking('@input', '@change', this)\n }\n },\n\n mounted () {\n this.updateView()\n },\n\n methods: {\n register (item: VStepperStepInstance | VStepperContentInstance) {\n if (item.$options.name === 'v-stepper-step') {\n this.steps.push(item as VStepperStepInstance)\n } else if (item.$options.name === 'v-stepper-content') {\n (item as VStepperContentInstance).isVertical = this.vertical\n this.content.push(item as VStepperContentInstance)\n }\n },\n unregister (item: VStepperStepInstance | VStepperContentInstance) {\n if (item.$options.name === 'v-stepper-step') {\n this.steps = this.steps.filter((i: VStepperStepInstance) => i !== item)\n } else if (item.$options.name === 'v-stepper-content') {\n (item as VStepperContentInstance).isVertical = this.vertical\n this.content = this.content.filter((i: VStepperContentInstance) => i !== item)\n }\n },\n stepClick (step: string | number) {\n this.$nextTick(() => (this.internalValue = step))\n },\n updateView () {\n for (let index = this.steps.length; --index >= 0;) {\n this.steps[index].toggle(this.internalValue as any)\n }\n for (let index = this.content.length; --index >= 0;) {\n this.content[index].toggle(this.internalValue as any, this.isReverse)\n }\n },\n },\n\n render (h): VNode {\n return h(this.tag, {\n staticClass: 'v-stepper',\n class: this.classes,\n style: this.styles,\n }, this.$slots.default)\n },\n})\n","// Components\nimport VIcon from '../VIcon'\n\n// Mixins\nimport Colorable from '../../mixins/colorable'\nimport { inject as RegistrableInject } from '../../mixins/registrable'\n\n// Directives\nimport ripple from '../../directives/ripple'\n\n// Utilities\nimport mixins from '../../util/mixins'\n\n// Types\nimport { VNode } from 'vue'\nimport { PropValidator } from 'vue/types/options'\n\ntype VuetifyStepperRuleValidator = () => string | boolean\n\nconst baseMixins = mixins(\n Colorable,\n RegistrableInject('stepper', 'v-stepper-step', 'v-stepper')\n)\n\ninterface options extends InstanceType {\n stepClick: (step: number | string) => void\n}\n/* @vue/component */\nexport default baseMixins.extend().extend({\n name: 'v-stepper-step',\n\n directives: { ripple },\n\n inject: ['stepClick'],\n\n props: {\n color: {\n type: String,\n default: 'primary',\n },\n complete: Boolean,\n completeIcon: {\n type: String,\n default: '$complete',\n },\n editable: Boolean,\n editIcon: {\n type: String,\n default: '$edit',\n },\n errorIcon: {\n type: String,\n default: '$error',\n },\n rules: {\n type: Array,\n default: () => [],\n } as PropValidator,\n step: [Number, String],\n },\n\n data () {\n return {\n isActive: false,\n isInactive: true,\n }\n },\n\n computed: {\n classes (): object {\n return {\n 'v-stepper__step--active': this.isActive,\n 'v-stepper__step--editable': this.editable,\n 'v-stepper__step--inactive': this.isInactive,\n 'v-stepper__step--error error--text': this.hasError,\n 'v-stepper__step--complete': this.complete,\n }\n },\n hasError (): boolean {\n return this.rules.some(validate => validate() !== true)\n },\n },\n\n mounted () {\n this.stepper && this.stepper.register(this)\n },\n\n beforeDestroy () {\n this.stepper && this.stepper.unregister(this)\n },\n\n methods: {\n click (e: MouseEvent) {\n e.stopPropagation()\n\n this.$emit('click', e)\n\n if (this.editable) {\n this.stepClick(this.step)\n }\n },\n genIcon (icon: string) {\n return this.$createElement(VIcon, icon)\n },\n genLabel () {\n return this.$createElement('div', {\n staticClass: 'v-stepper__label',\n }, this.$slots.default)\n },\n genStep () {\n const color = (!this.hasError && (this.complete || this.isActive)) ? this.color : false\n\n return this.$createElement('span', this.setBackgroundColor(color, {\n staticClass: 'v-stepper__step__step',\n }), this.genStepContent())\n },\n genStepContent () {\n const children = []\n\n if (this.hasError) {\n children.push(this.genIcon(this.errorIcon))\n } else if (this.complete) {\n if (this.editable) {\n children.push(this.genIcon(this.editIcon))\n } else {\n children.push(this.genIcon(this.completeIcon))\n }\n } else {\n children.push(String(this.step))\n }\n\n return children\n },\n toggle (step: number | string) {\n this.isActive = step.toString() === this.step.toString()\n this.isInactive = Number(step) < Number(this.step)\n },\n },\n\n render (h): VNode {\n return h('div', {\n staticClass: 'v-stepper__step',\n class: this.classes,\n directives: [{\n name: 'ripple',\n value: this.editable,\n }],\n on: { click: this.click },\n }, [\n this.genStep(),\n this.genLabel(),\n ])\n },\n})\n","// Components\nimport {\n VTabTransition,\n VTabReverseTransition,\n} from '../transitions'\n\n// Mixins\nimport { inject as RegistrableInject } from '../../mixins/registrable'\n\n// Helpers\nimport { convertToUnit } from '../../util/helpers'\n\n// Utilities\nimport mixins from '../../util/mixins'\n\n// Types\nimport { VNode, FunctionalComponentOptions, VNodeData } from 'vue'\n\nconst baseMixins = mixins(\n RegistrableInject('stepper', 'v-stepper-content', 'v-stepper')\n)\n\ninterface options extends InstanceType {\n $refs: {\n wrapper: HTMLElement\n }\n isVerticalProvided: boolean\n}\n\n/* @vue/component */\nexport default baseMixins.extend().extend({\n name: 'v-stepper-content',\n\n inject: {\n isVerticalProvided: {\n from: 'isVertical',\n },\n },\n\n props: {\n step: {\n type: [Number, String],\n required: true,\n },\n },\n\n data () {\n return {\n height: 0 as number | string,\n // Must be null to allow\n // previous comparison\n isActive: null as boolean | null,\n isReverse: false,\n isVertical: this.isVerticalProvided,\n }\n },\n\n computed: {\n computedTransition (): FunctionalComponentOptions {\n // Fix for #8978\n const reverse = this.$vuetify.rtl ? !this.isReverse : this.isReverse\n\n return reverse\n ? VTabReverseTransition\n : VTabTransition\n },\n styles (): object {\n if (!this.isVertical) return {}\n\n return {\n height: convertToUnit(this.height),\n }\n },\n },\n\n watch: {\n isActive (current, previous) {\n // If active and the previous state\n // was null, is just booting up\n if (current && previous == null) {\n this.height = 'auto'\n return\n }\n\n if (!this.isVertical) return\n\n if (this.isActive) this.enter()\n else this.leave()\n },\n },\n\n mounted () {\n this.$refs.wrapper.addEventListener(\n 'transitionend',\n this.onTransition,\n false\n )\n this.stepper && this.stepper.register(this)\n },\n\n beforeDestroy () {\n this.$refs.wrapper.removeEventListener(\n 'transitionend',\n this.onTransition,\n false\n )\n this.stepper && this.stepper.unregister(this)\n },\n\n methods: {\n onTransition (e: TransitionEvent) {\n if (!this.isActive ||\n e.propertyName !== 'height'\n ) return\n\n this.height = 'auto'\n },\n enter () {\n let scrollHeight = 0\n\n // Render bug with height\n requestAnimationFrame(() => {\n scrollHeight = this.$refs.wrapper.scrollHeight\n })\n\n this.height = 0\n\n // Give the collapsing element time to collapse\n setTimeout(() => this.isActive && (this.height = (scrollHeight || 'auto')), 450)\n },\n leave () {\n this.height = this.$refs.wrapper.clientHeight\n setTimeout(() => (this.height = 0), 10)\n },\n toggle (step: string | number, reverse: boolean) {\n this.isActive = step.toString() === this.step.toString()\n this.isReverse = reverse\n },\n },\n\n render (h): VNode {\n const contentData = {\n staticClass: 'v-stepper__content',\n } as VNodeData\n const wrapperData = {\n staticClass: 'v-stepper__wrapper',\n style: this.styles,\n ref: 'wrapper',\n }\n\n if (!this.isVertical) {\n contentData.directives = [{\n name: 'show',\n value: this.isActive,\n }]\n }\n\n const wrapper = h('div', wrapperData, [this.$slots.default])\n const content = h('div', contentData, [wrapper])\n\n return h(this.computedTransition, {\n on: this.$listeners,\n }, [content])\n },\n})\n","import { createSimpleFunctional } from '../../util/helpers'\nimport VStepper from './VStepper'\nimport VStepperStep from './VStepperStep'\nimport VStepperContent from './VStepperContent'\n\nconst VStepperHeader = createSimpleFunctional('v-stepper__header')\nconst VStepperItems = createSimpleFunctional('v-stepper__items')\n\nexport {\n VStepper,\n VStepperContent,\n VStepperStep,\n VStepperHeader,\n VStepperItems,\n}\n\nexport default {\n $_vuetify_subcomponents: {\n VStepper,\n VStepperContent,\n VStepperStep,\n VStepperHeader,\n VStepperItems,\n },\n}\n","// Extensions\nimport VWindow from '../VWindow/VWindow'\n\n// Types & Components\nimport { BaseItemGroup, GroupableInstance } from './../VItemGroup/VItemGroup'\n\n/* @vue/component */\nexport default VWindow.extend({\n name: 'v-tabs-items',\n\n props: {\n mandatory: {\n type: Boolean,\n default: false,\n },\n },\n\n computed: {\n classes (): object {\n return {\n ...VWindow.options.computed.classes.call(this),\n 'v-tabs-items': true,\n }\n },\n isDark (): boolean {\n return this.rootIsDark\n },\n },\n\n methods: {\n getValue (item: GroupableInstance, i: number) {\n return item.id || BaseItemGroup.options.methods.getValue.call(this, item, i)\n },\n },\n})\n","// Styles\nimport '../../styles/components/_selection-controls.sass'\nimport './VSwitch.sass'\n\n// Mixins\nimport Selectable from '../../mixins/selectable'\nimport VInput from '../VInput'\n\n// Directives\nimport Touch from '../../directives/touch'\n\n// Components\nimport { VFabTransition } from '../transitions'\nimport VProgressCircular from '../VProgressCircular/VProgressCircular'\n\n// Helpers\nimport { keyCodes } from '../../util/helpers'\n\n// Types\nimport { VNode, VNodeData } from 'vue'\n\n/* @vue/component */\nexport default Selectable.extend({\n name: 'v-switch',\n\n directives: { Touch },\n\n props: {\n inset: Boolean,\n loading: {\n type: [Boolean, String],\n default: false,\n },\n flat: {\n type: Boolean,\n default: false,\n },\n },\n\n computed: {\n classes (): object {\n return {\n ...VInput.options.computed.classes.call(this),\n 'v-input--selection-controls v-input--switch': true,\n 'v-input--switch--flat': this.flat,\n 'v-input--switch--inset': this.inset,\n }\n },\n attrs (): object {\n return {\n 'aria-checked': String(this.isActive),\n 'aria-disabled': String(this.isDisabled),\n role: 'switch',\n }\n },\n // Do not return undefined if disabled,\n // according to spec, should still show\n // a color when disabled and active\n validationState (): string | undefined {\n if (this.hasError && this.shouldValidate) return 'error'\n if (this.hasSuccess) return 'success'\n if (this.hasColor !== null) return this.computedColor\n return undefined\n },\n switchData (): VNodeData {\n return this.setTextColor(this.loading ? undefined : this.validationState, {\n class: this.themeClasses,\n })\n },\n },\n\n methods: {\n genDefaultSlot (): (VNode | null)[] {\n return [\n this.genSwitch(),\n this.genLabel(),\n ]\n },\n genSwitch (): VNode {\n const { title, ...switchAttrs } = this.attrs$\n\n return this.$createElement('div', {\n staticClass: 'v-input--selection-controls__input',\n }, [\n this.genInput('checkbox', {\n ...this.attrs,\n ...switchAttrs,\n }),\n this.genRipple(this.setTextColor(this.validationState, {\n directives: [{\n name: 'touch',\n value: {\n left: this.onSwipeLeft,\n right: this.onSwipeRight,\n },\n }],\n })),\n this.$createElement('div', {\n staticClass: 'v-input--switch__track',\n ...this.switchData,\n }),\n this.$createElement('div', {\n staticClass: 'v-input--switch__thumb',\n ...this.switchData,\n }, [this.genProgress()]),\n ])\n },\n genProgress (): VNode {\n return this.$createElement(VFabTransition, {}, [\n this.loading === false\n ? null\n : this.$slots.progress || this.$createElement(VProgressCircular, {\n props: {\n color: (this.loading === true || this.loading === '')\n ? (this.color || 'primary')\n : this.loading,\n size: 16,\n width: 2,\n indeterminate: true,\n },\n }),\n ])\n },\n onSwipeLeft () {\n if (this.isActive) this.onChange()\n },\n onSwipeRight () {\n if (!this.isActive) this.onChange()\n },\n onKeydown (e: KeyboardEvent) {\n if (\n (e.keyCode === keyCodes.left && this.isActive) ||\n (e.keyCode === keyCodes.right && !this.isActive)\n ) this.onChange()\n },\n },\n})\n","import VSelect from './VSelect'\n\nexport { VSelect }\nexport default VSelect\n","// Components\nimport VSimpleCheckbox from '../VCheckbox/VSimpleCheckbox'\nimport VDivider from '../VDivider'\nimport VSubheader from '../VSubheader'\nimport {\n VList,\n VListItem,\n VListItemAction,\n VListItemContent,\n VListItemTitle,\n} from '../VList'\n\n// Directives\nimport ripple from '../../directives/ripple'\n\n// Mixins\nimport Colorable from '../../mixins/colorable'\nimport Themeable from '../../mixins/themeable'\n\n// Helpers\nimport {\n escapeHTML,\n getPropertyFromItem,\n} from '../../util/helpers'\n\n// Types\nimport mixins from '../../util/mixins'\nimport { VNode, PropType, VNodeChildren } from 'vue'\nimport { PropValidator } from 'vue/types/options'\nimport { SelectItemKey } from 'vuetify/types'\n\ntype ListTile = { item: any, disabled?: null | boolean, value?: boolean, index: number };\n\n/* @vue/component */\nexport default mixins(Colorable, Themeable).extend({\n name: 'v-select-list',\n\n // https://github.com/vuejs/vue/issues/6872\n directives: {\n ripple,\n },\n\n props: {\n action: Boolean,\n dense: Boolean,\n hideSelected: Boolean,\n items: {\n type: Array,\n default: () => [],\n } as PropValidator,\n itemDisabled: {\n type: [String, Array, Function] as PropType,\n default: 'disabled',\n },\n itemText: {\n type: [String, Array, Function] as PropType,\n default: 'text',\n },\n itemValue: {\n type: [String, Array, Function] as PropType,\n default: 'value',\n },\n noDataText: String,\n noFilter: Boolean,\n searchInput: null as unknown as PropType,\n selectedItems: {\n type: Array,\n default: () => [],\n } as PropValidator,\n },\n\n computed: {\n parsedItems (): any[] {\n return this.selectedItems.map(item => this.getValue(item))\n },\n tileActiveClass (): string {\n return Object.keys(this.setTextColor(this.color).class || {}).join(' ')\n },\n staticNoDataTile (): VNode {\n const tile = {\n attrs: {\n role: undefined,\n },\n on: {\n mousedown: (e: Event) => e.preventDefault(), // Prevent onBlur from being called\n },\n }\n\n return this.$createElement(VListItem, tile, [\n this.genTileContent(this.noDataText),\n ])\n },\n },\n\n methods: {\n genAction (item: object, inputValue: any): VNode {\n return this.$createElement(VListItemAction, [\n this.$createElement(VSimpleCheckbox, {\n props: {\n color: this.color,\n value: inputValue,\n ripple: false,\n },\n on: {\n input: () => this.$emit('select', item),\n },\n }),\n ])\n },\n genDivider (props: { [key: string]: any }) {\n return this.$createElement(VDivider, { props })\n },\n genFilteredText (text: string) {\n text = text || ''\n\n if (!this.searchInput || this.noFilter) return escapeHTML(text)\n\n const { start, middle, end } = this.getMaskedCharacters(text)\n\n return `${escapeHTML(start)}${this.genHighlight(middle)}${escapeHTML(end)}`\n },\n genHeader (props: { [key: string]: any }): VNode {\n return this.$createElement(VSubheader, { props }, props.header)\n },\n genHighlight (text: string): string {\n return `${escapeHTML(text)}`\n },\n getMaskedCharacters (text: string): {\n start: string\n middle: string\n end: string\n } {\n const searchInput = (this.searchInput || '').toString().toLocaleLowerCase()\n const index = text.toLocaleLowerCase().indexOf(searchInput)\n\n if (index < 0) return { start: text, middle: '', end: '' }\n\n const start = text.slice(0, index)\n const middle = text.slice(index, index + searchInput.length)\n const end = text.slice(index + searchInput.length)\n return { start, middle, end }\n },\n genTile ({\n item,\n index,\n disabled = null,\n value = false,\n }: ListTile): VNode | VNode[] | undefined {\n if (!value) value = this.hasItem(item)\n\n if (item === Object(item)) {\n disabled = disabled !== null\n ? disabled\n : this.getDisabled(item)\n }\n\n const tile = {\n attrs: {\n // Default behavior in list does not\n // contain aria-selected by default\n 'aria-selected': String(value),\n id: `list-item-${this._uid}-${index}`,\n role: 'option',\n },\n on: {\n mousedown: (e: Event) => {\n // Prevent onBlur from being called\n e.preventDefault()\n },\n click: () => disabled || this.$emit('select', item),\n },\n props: {\n activeClass: this.tileActiveClass,\n disabled,\n ripple: true,\n inputValue: value,\n },\n }\n\n if (!this.$scopedSlots.item) {\n return this.$createElement(VListItem, tile, [\n this.action && !this.hideSelected && this.items.length > 0\n ? this.genAction(item, value)\n : null,\n this.genTileContent(item, index),\n ])\n }\n\n const parent = this\n const scopedSlot = this.$scopedSlots.item({\n parent,\n item,\n attrs: {\n ...tile.attrs,\n ...tile.props,\n },\n on: tile.on,\n })\n\n return this.needsTile(scopedSlot)\n ? this.$createElement(VListItem, tile, scopedSlot)\n : scopedSlot\n },\n genTileContent (item: any, index = 0): VNode {\n const innerHTML = this.genFilteredText(this.getText(item))\n\n return this.$createElement(VListItemContent,\n [this.$createElement(VListItemTitle, {\n domProps: { innerHTML },\n })]\n )\n },\n hasItem (item: object) {\n return this.parsedItems.indexOf(this.getValue(item)) > -1\n },\n needsTile (slot: VNode[] | undefined) {\n return slot!.length !== 1 ||\n slot![0].componentOptions == null ||\n slot![0].componentOptions.Ctor.options.name !== 'v-list-item'\n },\n getDisabled (item: object) {\n return Boolean(getPropertyFromItem(item, this.itemDisabled, false))\n },\n getText (item: object) {\n return String(getPropertyFromItem(item, this.itemText, item))\n },\n getValue (item: object) {\n return getPropertyFromItem(item, this.itemValue, this.getText(item))\n },\n },\n\n render (): VNode {\n const children: VNodeChildren = []\n const itemsLength = this.items.length\n for (let index = 0; index < itemsLength; index++) {\n const item = this.items[index]\n\n if (this.hideSelected &&\n this.hasItem(item)\n ) continue\n\n if (item == null) children.push(this.genTile({ item, index }))\n else if (item.header) children.push(this.genHeader(item))\n else if (item.divider) children.push(this.genDivider(item))\n else children.push(this.genTile({ item, index }))\n }\n\n children.length || children.push(this.$slots['no-data'] || this.staticNoDataTile)\n\n this.$slots['prepend-item'] && children.unshift(this.$slots['prepend-item'])\n\n this.$slots['append-item'] && children.push(this.$slots['append-item'])\n\n return this.$createElement(VList, {\n staticClass: 'v-select-list',\n class: this.themeClasses,\n attrs: {\n role: 'listbox',\n tabindex: -1,\n },\n props: { dense: this.dense },\n }, children)\n },\n})\n","// Styles\nimport '../VTextField/VTextField.sass'\nimport './VSelect.sass'\n\n// Components\nimport VChip from '../VChip'\nimport VMenu from '../VMenu'\nimport VSelectList from './VSelectList'\n\n// Extensions\nimport VInput from '../VInput'\nimport VTextField from '../VTextField/VTextField'\n\n// Mixins\nimport Comparable from '../../mixins/comparable'\nimport Dependent from '../../mixins/dependent'\nimport Filterable from '../../mixins/filterable'\n\n// Directives\nimport ClickOutside from '../../directives/click-outside'\n\n// Utilities\nimport mergeData from '../../util/mergeData'\nimport { getPropertyFromItem, getObjectValueByPath, keyCodes } from '../../util/helpers'\nimport { consoleError } from '../../util/console'\n\n// Types\nimport mixins from '../../util/mixins'\nimport { VNode, VNodeDirective, PropType, VNodeData } from 'vue'\nimport { PropValidator } from 'vue/types/options'\nimport { SelectItemKey } from 'vuetify/types'\n\nexport const defaultMenuProps = {\n closeOnClick: false,\n closeOnContentClick: false,\n disableKeys: true,\n openOnClick: false,\n maxHeight: 304,\n}\n\n// Types\nconst baseMixins = mixins(\n VTextField,\n Comparable,\n Dependent,\n Filterable\n)\n\ninterface options extends InstanceType {\n $refs: {\n menu: InstanceType\n content: HTMLElement\n label: HTMLElement\n input: HTMLInputElement\n 'prepend-inner': HTMLElement\n 'append-inner': HTMLElement\n prefix: HTMLElement\n suffix: HTMLElement\n }\n}\n\n/* @vue/component */\nexport default baseMixins.extend().extend({\n name: 'v-select',\n\n directives: {\n ClickOutside,\n },\n\n props: {\n appendIcon: {\n type: String,\n default: '$dropdown',\n },\n attach: {\n type: null as unknown as PropType,\n default: false,\n },\n cacheItems: Boolean,\n chips: Boolean,\n clearable: Boolean,\n deletableChips: Boolean,\n disableLookup: Boolean,\n eager: Boolean,\n hideSelected: Boolean,\n items: {\n type: Array,\n default: () => [],\n } as PropValidator,\n itemColor: {\n type: String,\n default: 'primary',\n },\n itemDisabled: {\n type: [String, Array, Function] as PropType,\n default: 'disabled',\n },\n itemText: {\n type: [String, Array, Function] as PropType,\n default: 'text',\n },\n itemValue: {\n type: [String, Array, Function] as PropType,\n default: 'value',\n },\n menuProps: {\n type: [String, Array, Object],\n default: () => defaultMenuProps,\n },\n multiple: Boolean,\n openOnClear: Boolean,\n returnObject: Boolean,\n smallChips: Boolean,\n },\n\n data () {\n return {\n cachedItems: this.cacheItems ? this.items : [],\n menuIsBooted: false,\n isMenuActive: false,\n lastItem: 20,\n // As long as a value is defined, show it\n // Otherwise, check if multiple\n // to determine which default to provide\n lazyValue: this.value !== undefined\n ? this.value\n : this.multiple ? [] : undefined,\n selectedIndex: -1,\n selectedItems: [] as any[],\n keyboardLookupPrefix: '',\n keyboardLookupLastTime: 0,\n }\n },\n\n computed: {\n /* All items that the select has */\n allItems (): object[] {\n return this.filterDuplicates(this.cachedItems.concat(this.items))\n },\n classes (): object {\n return {\n ...VTextField.options.computed.classes.call(this),\n 'v-select': true,\n 'v-select--chips': this.hasChips,\n 'v-select--chips--small': this.smallChips,\n 'v-select--is-menu-active': this.isMenuActive,\n 'v-select--is-multi': this.multiple,\n }\n },\n /* Used by other components to overwrite */\n computedItems (): object[] {\n return this.allItems\n },\n computedOwns (): string {\n return `list-${this._uid}`\n },\n computedCounterValue (): number {\n const value = this.multiple\n ? this.selectedItems\n : (this.getText(this.selectedItems[0]) || '').toString()\n\n if (typeof this.counterValue === 'function') {\n return this.counterValue(value)\n }\n\n return value.length\n },\n directives (): VNodeDirective[] | undefined {\n return this.isFocused ? [{\n name: 'click-outside',\n value: {\n handler: this.blur,\n closeConditional: this.closeConditional,\n include: () => this.getOpenDependentElements(),\n },\n }] : undefined\n },\n dynamicHeight () {\n return 'auto'\n },\n hasChips (): boolean {\n return this.chips || this.smallChips\n },\n hasSlot (): boolean {\n return Boolean(this.hasChips || this.$scopedSlots.selection)\n },\n isDirty (): boolean {\n return this.selectedItems.length > 0\n },\n listData (): object {\n const scopeId = this.$vnode && (this.$vnode.context!.$options as { [key: string]: any })._scopeId\n const attrs = scopeId ? {\n [scopeId]: true,\n } : {}\n\n return {\n attrs: {\n ...attrs,\n id: this.computedOwns,\n },\n props: {\n action: this.multiple,\n color: this.itemColor,\n dense: this.dense,\n hideSelected: this.hideSelected,\n items: this.virtualizedItems,\n itemDisabled: this.itemDisabled,\n itemText: this.itemText,\n itemValue: this.itemValue,\n noDataText: this.$vuetify.lang.t(this.noDataText),\n selectedItems: this.selectedItems,\n },\n on: {\n select: this.selectItem,\n },\n scopedSlots: {\n item: this.$scopedSlots.item,\n },\n }\n },\n staticList (): VNode {\n if (this.$slots['no-data'] || this.$slots['prepend-item'] || this.$slots['append-item']) {\n consoleError('assert: staticList should not be called if slots are used')\n }\n\n return this.$createElement(VSelectList, this.listData)\n },\n virtualizedItems (): object[] {\n return (this.$_menuProps as any).auto\n ? this.computedItems\n : this.computedItems.slice(0, this.lastItem)\n },\n menuCanShow: () => true,\n $_menuProps (): object {\n let normalisedProps = typeof this.menuProps === 'string'\n ? this.menuProps.split(',')\n : this.menuProps\n\n if (Array.isArray(normalisedProps)) {\n normalisedProps = normalisedProps.reduce((acc, p) => {\n acc[p.trim()] = true\n return acc\n }, {})\n }\n\n return {\n ...defaultMenuProps,\n eager: this.eager,\n value: this.menuCanShow && this.isMenuActive,\n nudgeBottom: normalisedProps.offsetY ? 1 : 0, // convert to int\n ...normalisedProps,\n }\n },\n },\n\n watch: {\n internalValue (val) {\n this.initialValue = val\n this.setSelectedItems()\n },\n isMenuActive (val) {\n window.setTimeout(() => this.onMenuActiveChange(val))\n },\n items: {\n immediate: true,\n handler (val) {\n if (this.cacheItems) {\n // Breaks vue-test-utils if\n // this isn't calculated\n // on the next tick\n this.$nextTick(() => {\n this.cachedItems = this.filterDuplicates(this.cachedItems.concat(val))\n })\n }\n\n this.setSelectedItems()\n },\n },\n },\n\n methods: {\n /** @public */\n blur (e?: Event) {\n VTextField.options.methods.blur.call(this, e)\n this.isMenuActive = false\n this.isFocused = false\n this.selectedIndex = -1\n this.setMenuIndex(-1)\n },\n /** @public */\n activateMenu () {\n if (\n !this.isInteractive ||\n this.isMenuActive\n ) return\n\n this.isMenuActive = true\n },\n clearableCallback () {\n this.setValue(this.multiple ? [] : null)\n this.setMenuIndex(-1)\n this.$nextTick(() => this.$refs.input && this.$refs.input.focus())\n\n if (this.openOnClear) this.isMenuActive = true\n },\n closeConditional (e: Event) {\n if (!this.isMenuActive) return true\n\n return (\n !this._isDestroyed &&\n\n // Click originates from outside the menu content\n // Multiple selects don't close when an item is clicked\n (!this.getContent() ||\n !this.getContent().contains(e.target as Node)) &&\n\n // Click originates from outside the element\n this.$el &&\n !this.$el.contains(e.target as Node) &&\n e.target !== this.$el\n )\n },\n filterDuplicates (arr: any[]) {\n const uniqueValues = new Map()\n for (let index = 0; index < arr.length; ++index) {\n const item = arr[index]\n\n // Do not deduplicate headers or dividers (#12517)\n if (item.header || item.divider) {\n uniqueValues.set(item, item)\n continue\n }\n\n const val = this.getValue(item)\n\n // TODO: comparator\n !uniqueValues.has(val) && uniqueValues.set(val, item)\n }\n return Array.from(uniqueValues.values())\n },\n findExistingIndex (item: object) {\n const itemValue = this.getValue(item)\n\n return (this.internalValue || []).findIndex((i: object) => this.valueComparator(this.getValue(i), itemValue))\n },\n getContent () {\n return this.$refs.menu && this.$refs.menu.$refs.content\n },\n genChipSelection (item: object, index: number) {\n const isDisabled = (\n this.isDisabled ||\n this.getDisabled(item)\n )\n const isInteractive = !isDisabled && this.isInteractive\n\n return this.$createElement(VChip, {\n staticClass: 'v-chip--select',\n attrs: { tabindex: -1 },\n props: {\n close: this.deletableChips && isInteractive,\n disabled: isDisabled,\n inputValue: index === this.selectedIndex,\n small: this.smallChips,\n },\n on: {\n click: (e: MouseEvent) => {\n if (!isInteractive) return\n\n e.stopPropagation()\n\n this.selectedIndex = index\n },\n 'click:close': () => this.onChipInput(item),\n },\n key: JSON.stringify(this.getValue(item)),\n }, this.getText(item))\n },\n genCommaSelection (item: object, index: number, last: boolean) {\n const color = index === this.selectedIndex && this.computedColor\n const isDisabled = (\n this.isDisabled ||\n this.getDisabled(item)\n )\n\n return this.$createElement('div', this.setTextColor(color, {\n staticClass: 'v-select__selection v-select__selection--comma',\n class: {\n 'v-select__selection--disabled': isDisabled,\n },\n key: JSON.stringify(this.getValue(item)),\n }), `${this.getText(item)}${last ? '' : ', '}`)\n },\n genDefaultSlot (): (VNode | VNode[] | null)[] {\n const selections = this.genSelections()\n const input = this.genInput()\n\n // If the return is an empty array\n // push the input\n if (Array.isArray(selections)) {\n selections.push(input)\n // Otherwise push it into children\n } else {\n selections.children = selections.children || []\n selections.children.push(input)\n }\n\n return [\n this.genFieldset(),\n this.$createElement('div', {\n staticClass: 'v-select__slot',\n directives: this.directives,\n }, [\n this.genLabel(),\n this.prefix ? this.genAffix('prefix') : null,\n selections,\n this.suffix ? this.genAffix('suffix') : null,\n this.genClearIcon(),\n this.genIconSlot(),\n this.genHiddenInput(),\n ]),\n this.genMenu(),\n this.genProgress(),\n ]\n },\n genIcon (\n type: string,\n cb?: (e: Event) => void,\n extraData?: VNodeData\n ) {\n const icon = VInput.options.methods.genIcon.call(this, type, cb, extraData)\n\n if (type === 'append') {\n // Don't allow the dropdown icon to be focused\n icon.children![0].data = mergeData(icon.children![0].data!, {\n attrs: {\n tabindex: icon.children![0].componentOptions!.listeners && '-1',\n 'aria-hidden': 'true',\n 'aria-label': undefined,\n },\n })\n }\n\n return icon\n },\n genInput (): VNode {\n const input = VTextField.options.methods.genInput.call(this)\n\n delete input.data!.attrs!.name\n\n input.data = mergeData(input.data!, {\n domProps: { value: null },\n attrs: {\n readonly: true,\n type: 'text',\n 'aria-readonly': String(this.isReadonly),\n 'aria-activedescendant': getObjectValueByPath(this.$refs.menu, 'activeTile.id'),\n autocomplete: getObjectValueByPath(input.data!, 'attrs.autocomplete', 'off'),\n placeholder: (!this.isDirty && (this.isFocused || !this.hasLabel)) ? this.placeholder : undefined,\n },\n on: { keypress: this.onKeyPress },\n })\n\n return input\n },\n genHiddenInput (): VNode {\n return this.$createElement('input', {\n domProps: { value: this.lazyValue },\n attrs: {\n type: 'hidden',\n name: this.attrs$.name,\n },\n })\n },\n genInputSlot (): VNode {\n const render = VTextField.options.methods.genInputSlot.call(this)\n\n render.data!.attrs = {\n ...render.data!.attrs,\n role: 'button',\n 'aria-haspopup': 'listbox',\n 'aria-expanded': String(this.isMenuActive),\n 'aria-owns': this.computedOwns,\n }\n\n return render\n },\n genList (): VNode {\n // If there's no slots, we can use a cached VNode to improve performance\n if (this.$slots['no-data'] || this.$slots['prepend-item'] || this.$slots['append-item']) {\n return this.genListWithSlot()\n } else {\n return this.staticList\n }\n },\n genListWithSlot (): VNode {\n const slots = ['prepend-item', 'no-data', 'append-item']\n .filter(slotName => this.$slots[slotName])\n .map(slotName => this.$createElement('template', {\n slot: slotName,\n }, this.$slots[slotName]))\n // Requires destructuring due to Vue\n // modifying the `on` property when passed\n // as a referenced object\n return this.$createElement(VSelectList, {\n ...this.listData,\n }, slots)\n },\n genMenu (): VNode {\n const props = this.$_menuProps as any\n props.activator = this.$refs['input-slot']\n\n // Attach to root el so that\n // menu covers prepend/append icons\n if (\n // TODO: make this a computed property or helper or something\n this.attach === '' || // If used as a boolean prop ()\n this.attach === true || // If bound to a boolean ()\n this.attach === 'attach' // If bound as boolean prop in pug (v-menu(attach))\n ) {\n props.attach = this.$el\n } else {\n props.attach = this.attach\n }\n\n return this.$createElement(VMenu, {\n attrs: { role: undefined },\n props,\n on: {\n input: (val: boolean) => {\n this.isMenuActive = val\n this.isFocused = val\n },\n scroll: this.onScroll,\n },\n ref: 'menu',\n }, [this.genList()])\n },\n genSelections (): VNode {\n let length = this.selectedItems.length\n const children = new Array(length)\n\n let genSelection\n if (this.$scopedSlots.selection) {\n genSelection = this.genSlotSelection\n } else if (this.hasChips) {\n genSelection = this.genChipSelection\n } else {\n genSelection = this.genCommaSelection\n }\n\n while (length--) {\n children[length] = genSelection(\n this.selectedItems[length],\n length,\n length === children.length - 1\n )\n }\n\n return this.$createElement('div', {\n staticClass: 'v-select__selections',\n }, children)\n },\n genSlotSelection (item: object, index: number): VNode[] | undefined {\n return this.$scopedSlots.selection!({\n attrs: {\n class: 'v-chip--select',\n },\n parent: this,\n item,\n index,\n select: (e: Event) => {\n e.stopPropagation()\n this.selectedIndex = index\n },\n selected: index === this.selectedIndex,\n disabled: !this.isInteractive,\n })\n },\n getMenuIndex () {\n return this.$refs.menu ? (this.$refs.menu as { [key: string]: any }).listIndex : -1\n },\n getDisabled (item: object) {\n return getPropertyFromItem(item, this.itemDisabled, false)\n },\n getText (item: object) {\n return getPropertyFromItem(item, this.itemText, item)\n },\n getValue (item: object) {\n return getPropertyFromItem(item, this.itemValue, this.getText(item))\n },\n onBlur (e?: Event) {\n e && this.$emit('blur', e)\n },\n onChipInput (item: object) {\n if (this.multiple) this.selectItem(item)\n else this.setValue(null)\n // If all items have been deleted,\n // open `v-menu`\n if (this.selectedItems.length === 0) {\n this.isMenuActive = true\n } else {\n this.isMenuActive = false\n }\n this.selectedIndex = -1\n },\n onClick (e: MouseEvent) {\n if (!this.isInteractive) return\n\n if (!this.isAppendInner(e.target)) {\n this.isMenuActive = true\n }\n\n if (!this.isFocused) {\n this.isFocused = true\n this.$emit('focus')\n }\n\n this.$emit('click', e)\n },\n onEscDown (e: Event) {\n e.preventDefault()\n if (this.isMenuActive) {\n e.stopPropagation()\n this.isMenuActive = false\n }\n },\n onKeyPress (e: KeyboardEvent) {\n if (\n this.multiple ||\n !this.isInteractive ||\n this.disableLookup\n ) return\n\n const KEYBOARD_LOOKUP_THRESHOLD = 1000 // milliseconds\n const now = performance.now()\n if (now - this.keyboardLookupLastTime > KEYBOARD_LOOKUP_THRESHOLD) {\n this.keyboardLookupPrefix = ''\n }\n this.keyboardLookupPrefix += e.key.toLowerCase()\n this.keyboardLookupLastTime = now\n\n const index = this.allItems.findIndex(item => {\n const text = (this.getText(item) || '').toString()\n\n return text.toLowerCase().startsWith(this.keyboardLookupPrefix)\n })\n const item = this.allItems[index]\n if (index !== -1) {\n this.lastItem = Math.max(this.lastItem, index + 5)\n this.setValue(this.returnObject ? item : this.getValue(item))\n this.$nextTick(() => this.$refs.menu.getTiles())\n setTimeout(() => this.setMenuIndex(index))\n }\n },\n onKeyDown (e: KeyboardEvent) {\n if (this.isReadonly && e.keyCode !== keyCodes.tab) return\n\n const keyCode = e.keyCode\n const menu = this.$refs.menu\n\n // If enter, space, open menu\n if ([\n keyCodes.enter,\n keyCodes.space,\n ].includes(keyCode)) this.activateMenu()\n\n this.$emit('keydown', e)\n\n if (!menu) return\n\n // If menu is active, allow default\n // listIndex change from menu\n if (this.isMenuActive && keyCode !== keyCodes.tab) {\n this.$nextTick(() => {\n menu.changeListIndex(e)\n this.$emit('update:list-index', menu.listIndex)\n })\n }\n\n // If menu is not active, up/down/home/end can do\n // one of 2 things. If multiple, opens the\n // menu, if not, will cycle through all\n // available options\n if (\n !this.isMenuActive &&\n [keyCodes.up, keyCodes.down, keyCodes.home, keyCodes.end].includes(keyCode)\n ) return this.onUpDown(e)\n\n // If escape deactivate the menu\n if (keyCode === keyCodes.esc) return this.onEscDown(e)\n\n // If tab - select item or close menu\n if (keyCode === keyCodes.tab) return this.onTabDown(e)\n\n // If space preventDefault\n if (keyCode === keyCodes.space) return this.onSpaceDown(e)\n },\n onMenuActiveChange (val: boolean) {\n // If menu is closing and mulitple\n // or menuIndex is already set\n // skip menu index recalculation\n if (\n (this.multiple && !val) ||\n this.getMenuIndex() > -1\n ) return\n\n const menu = this.$refs.menu\n\n if (!menu || !this.isDirty) return\n\n // When menu opens, set index of first active item\n for (let i = 0; i < menu.tiles.length; i++) {\n if (menu.tiles[i].getAttribute('aria-selected') === 'true') {\n this.setMenuIndex(i)\n break\n }\n }\n },\n onMouseUp (e: MouseEvent) {\n // eslint-disable-next-line sonarjs/no-collapsible-if\n if (\n this.hasMouseDown &&\n e.which !== 3 &&\n this.isInteractive\n ) {\n // If append inner is present\n // and the target is itself\n // or inside, toggle menu\n if (this.isAppendInner(e.target)) {\n this.$nextTick(() => (this.isMenuActive = !this.isMenuActive))\n }\n }\n\n VTextField.options.methods.onMouseUp.call(this, e)\n },\n onScroll () {\n if (!this.isMenuActive) {\n requestAnimationFrame(() => (this.getContent().scrollTop = 0))\n } else {\n if (this.lastItem > this.computedItems.length) return\n\n const showMoreItems = (\n this.getContent().scrollHeight -\n (this.getContent().scrollTop +\n this.getContent().clientHeight)\n ) < 200\n\n if (showMoreItems) {\n this.lastItem += 20\n }\n }\n },\n onSpaceDown (e: KeyboardEvent) {\n e.preventDefault()\n },\n onTabDown (e: KeyboardEvent) {\n const menu = this.$refs.menu\n\n if (!menu) return\n\n const activeTile = menu.activeTile\n\n // An item that is selected by\n // menu-index should toggled\n if (\n !this.multiple &&\n activeTile &&\n this.isMenuActive\n ) {\n e.preventDefault()\n e.stopPropagation()\n\n activeTile.click()\n } else {\n // If we make it here,\n // the user has no selected indexes\n // and is probably tabbing out\n this.blur(e)\n }\n },\n onUpDown (e: KeyboardEvent) {\n const menu = this.$refs.menu\n\n if (!menu) return\n\n e.preventDefault()\n\n // Multiple selects do not cycle their value\n // when pressing up or down, instead activate\n // the menu\n if (this.multiple) return this.activateMenu()\n\n const keyCode = e.keyCode\n\n // Cycle through available values to achieve\n // select native behavior\n menu.isBooted = true\n\n window.requestAnimationFrame(() => {\n menu.getTiles()\n\n if (!menu.hasClickableTiles) return this.activateMenu()\n\n switch (keyCode) {\n case keyCodes.up:\n menu.prevTile()\n break\n case keyCodes.down:\n menu.nextTile()\n break\n case keyCodes.home:\n menu.firstTile()\n break\n case keyCodes.end:\n menu.lastTile()\n break\n }\n this.selectItem(this.allItems[this.getMenuIndex()])\n })\n },\n selectItem (item: object) {\n if (!this.multiple) {\n this.setValue(this.returnObject ? item : this.getValue(item))\n this.isMenuActive = false\n } else {\n const internalValue = (this.internalValue || []).slice()\n const i = this.findExistingIndex(item)\n\n i !== -1 ? internalValue.splice(i, 1) : internalValue.push(item)\n this.setValue(internalValue.map((i: object) => {\n return this.returnObject ? i : this.getValue(i)\n }))\n\n // When selecting multiple\n // adjust menu after each\n // selection\n this.$nextTick(() => {\n this.$refs.menu &&\n (this.$refs.menu as { [key: string]: any }).updateDimensions()\n })\n\n // We only need to reset list index for multiple\n // to keep highlight when an item is toggled\n // on and off\n if (!this.multiple) return\n\n const listIndex = this.getMenuIndex()\n\n this.setMenuIndex(-1)\n\n // There is no item to re-highlight\n // when selections are hidden\n if (this.hideSelected) return\n\n this.$nextTick(() => this.setMenuIndex(listIndex))\n }\n },\n setMenuIndex (index: number) {\n this.$refs.menu && ((this.$refs.menu as { [key: string]: any }).listIndex = index)\n },\n setSelectedItems () {\n const selectedItems = []\n const values = !this.multiple || !Array.isArray(this.internalValue)\n ? [this.internalValue]\n : this.internalValue\n\n for (const value of values) {\n const index = this.allItems.findIndex(v => this.valueComparator(\n this.getValue(v),\n this.getValue(value)\n ))\n\n if (index > -1) {\n selectedItems.push(this.allItems[index])\n }\n }\n\n this.selectedItems = selectedItems\n },\n setValue (value: any) {\n const newValue = this.returnObject ? value : this.getValue(value)\n const oldValue = this.returnObject ? this.internalValue : this.getValue(this.internalValue)\n\n if (!this.valueComparator(newValue, oldValue)) {\n this.internalValue = value\n this.$emit('change', value)\n }\n },\n isAppendInner (target: any) {\n // return true if append inner is present\n // and the target is itself or inside\n const appendInner = this.$refs['append-inner']\n\n return appendInner && (appendInner === target || appendInner.contains(target))\n },\n },\n})\n","import './VSlider.sass'\n\n// Components\nimport VInput from '../VInput'\nimport { VScaleTransition } from '../transitions'\n\n// Mixins\nimport mixins, { ExtractVue } from '../../util/mixins'\nimport Loadable from '../../mixins/loadable'\n\n// Directives\nimport ClickOutside from '../../directives/click-outside'\n\n// Helpers\nimport { addOnceEventListener, deepEqual, keyCodes, createRange, convertToUnit, passiveSupported } from '../../util/helpers'\nimport { consoleWarn } from '../../util/console'\n\n// Types\nimport Vue, { VNode, VNodeChildrenArrayContents, PropType } from 'vue'\nimport { ScopedSlotChildren } from 'vue/types/vnode'\nimport { PropValidator } from 'vue/types/options'\n\ninterface options extends Vue {\n $refs: {\n track: HTMLElement\n }\n}\n\nexport default mixins\n/* eslint-enable indent */\n>(\n VInput,\n Loadable\n/* @vue/component */\n).extend({\n name: 'v-slider',\n\n directives: {\n ClickOutside,\n },\n\n mixins: [Loadable],\n\n props: {\n disabled: Boolean,\n inverseLabel: Boolean,\n max: {\n type: [Number, String],\n default: 100,\n },\n min: {\n type: [Number, String],\n default: 0,\n },\n step: {\n type: [Number, String],\n default: 1,\n },\n thumbColor: String,\n thumbLabel: {\n type: [Boolean, String] as PropType,\n default: undefined,\n validator: v => typeof v === 'boolean' || v === 'always',\n },\n thumbSize: {\n type: [Number, String],\n default: 32,\n },\n tickLabels: {\n type: Array,\n default: () => ([]),\n } as PropValidator,\n ticks: {\n type: [Boolean, String] as PropType,\n default: false,\n validator: v => typeof v === 'boolean' || v === 'always',\n },\n tickSize: {\n type: [Number, String],\n default: 2,\n },\n trackColor: String,\n trackFillColor: String,\n value: [Number, String],\n vertical: Boolean,\n },\n\n data: () => ({\n app: null as any,\n oldValue: null as any,\n thumbPressed: false,\n mouseTimeout: -1,\n isFocused: false,\n isActive: false,\n noClick: false, // Prevent click event if dragging took place, hack for #7915\n }),\n\n computed: {\n classes (): object {\n return {\n ...VInput.options.computed.classes.call(this),\n 'v-input__slider': true,\n 'v-input__slider--vertical': this.vertical,\n 'v-input__slider--inverse-label': this.inverseLabel,\n }\n },\n internalValue: {\n get (): number {\n return this.lazyValue\n },\n set (val: number) {\n val = isNaN(val) ? this.minValue : val\n // Round value to ensure the\n // entire slider range can\n // be selected with step\n const value = this.roundValue(Math.min(Math.max(val, this.minValue), this.maxValue))\n\n if (value === this.lazyValue) return\n\n this.lazyValue = value\n\n this.$emit('input', value)\n },\n },\n trackTransition (): string {\n return this.thumbPressed\n ? this.showTicks || this.stepNumeric\n ? '0.1s cubic-bezier(0.25, 0.8, 0.5, 1)'\n : 'none'\n : ''\n },\n minValue (): number {\n return parseFloat(this.min)\n },\n maxValue (): number {\n return parseFloat(this.max)\n },\n stepNumeric (): number {\n return this.step > 0 ? parseFloat(this.step) : 0\n },\n inputWidth (): number {\n return (this.roundValue(this.internalValue) - this.minValue) / (this.maxValue - this.minValue) * 100\n },\n trackFillStyles (): Partial {\n const startDir = this.vertical ? 'bottom' : 'left'\n const endDir = this.vertical ? 'top' : 'right'\n const valueDir = this.vertical ? 'height' : 'width'\n\n const start = this.$vuetify.rtl ? 'auto' : '0'\n const end = this.$vuetify.rtl ? '0' : 'auto'\n const value = this.isDisabled ? `calc(${this.inputWidth}% - 10px)` : `${this.inputWidth}%`\n\n return {\n transition: this.trackTransition,\n [startDir]: start,\n [endDir]: end,\n [valueDir]: value,\n }\n },\n trackStyles (): Partial {\n const startDir = this.vertical ? this.$vuetify.rtl ? 'bottom' : 'top' : this.$vuetify.rtl ? 'left' : 'right'\n const endDir = this.vertical ? 'height' : 'width'\n\n const start = '0px'\n const end = this.isDisabled ? `calc(${100 - this.inputWidth}% - 10px)` : `calc(${100 - this.inputWidth}%)`\n\n return {\n transition: this.trackTransition,\n [startDir]: start,\n [endDir]: end,\n }\n },\n showTicks (): boolean {\n return this.tickLabels.length > 0 ||\n !!(!this.isDisabled && this.stepNumeric && this.ticks)\n },\n numTicks (): number {\n return Math.ceil((this.maxValue - this.minValue) / this.stepNumeric)\n },\n showThumbLabel (): boolean {\n return !this.isDisabled && !!(\n this.thumbLabel ||\n this.$scopedSlots['thumb-label']\n )\n },\n computedTrackColor (): string | undefined {\n if (this.isDisabled) return undefined\n if (this.trackColor) return this.trackColor\n if (this.isDark) return this.validationState\n return this.validationState || 'primary lighten-3'\n },\n computedTrackFillColor (): string | undefined {\n if (this.isDisabled) return undefined\n if (this.trackFillColor) return this.trackFillColor\n return this.validationState || this.computedColor\n },\n computedThumbColor (): string | undefined {\n if (this.thumbColor) return this.thumbColor\n return this.validationState || this.computedColor\n },\n },\n\n watch: {\n min (val) {\n const parsed = parseFloat(val)\n parsed > this.internalValue && this.$emit('input', parsed)\n },\n max (val) {\n const parsed = parseFloat(val)\n parsed < this.internalValue && this.$emit('input', parsed)\n },\n value: {\n handler (v: number) {\n this.internalValue = v\n },\n },\n },\n\n // If done in as immediate in\n // value watcher, causes issues\n // with vue-test-utils\n beforeMount () {\n this.internalValue = this.value\n },\n\n mounted () {\n // Without a v-app, iOS does not work with body selectors\n this.app = document.querySelector('[data-app]') ||\n consoleWarn('Missing v-app or a non-body wrapping element with the [data-app] attribute', this)\n },\n\n methods: {\n genDefaultSlot (): VNodeChildrenArrayContents {\n const children: VNodeChildrenArrayContents = [this.genLabel()]\n const slider = this.genSlider()\n this.inverseLabel\n ? children.unshift(slider)\n : children.push(slider)\n\n children.push(this.genProgress())\n\n return children\n },\n genSlider (): VNode {\n return this.$createElement('div', {\n class: {\n 'v-slider': true,\n 'v-slider--horizontal': !this.vertical,\n 'v-slider--vertical': this.vertical,\n 'v-slider--focused': this.isFocused,\n 'v-slider--active': this.isActive,\n 'v-slider--disabled': this.isDisabled,\n 'v-slider--readonly': this.isReadonly,\n ...this.themeClasses,\n },\n directives: [{\n name: 'click-outside',\n value: this.onBlur,\n }],\n on: {\n click: this.onSliderClick,\n mousedown: this.onSliderMouseDown,\n touchstart: this.onSliderMouseDown,\n },\n }, this.genChildren())\n },\n genChildren (): VNodeChildrenArrayContents {\n return [\n this.genInput(),\n this.genTrackContainer(),\n this.genSteps(),\n this.genThumbContainer(\n this.internalValue,\n this.inputWidth,\n this.isActive,\n this.isFocused,\n this.onFocus,\n this.onBlur,\n ),\n ]\n },\n genInput (): VNode {\n return this.$createElement('input', {\n attrs: {\n value: this.internalValue,\n id: this.computedId,\n disabled: true,\n readonly: true,\n tabindex: -1,\n ...this.$attrs,\n },\n // on: this.genListeners(), // TODO: do we need to attach the listeners to input?\n })\n },\n genTrackContainer (): VNode {\n const children = [\n this.$createElement('div', this.setBackgroundColor(this.computedTrackColor, {\n staticClass: 'v-slider__track-background',\n style: this.trackStyles,\n })),\n this.$createElement('div', this.setBackgroundColor(this.computedTrackFillColor, {\n staticClass: 'v-slider__track-fill',\n style: this.trackFillStyles,\n })),\n ]\n\n return this.$createElement('div', {\n staticClass: 'v-slider__track-container',\n ref: 'track',\n }, children)\n },\n genSteps (): VNode | null {\n if (!this.step || !this.showTicks) return null\n\n const tickSize = parseFloat(this.tickSize)\n const range = createRange(this.numTicks + 1)\n const direction = this.vertical ? 'bottom' : (this.$vuetify.rtl ? 'right' : 'left')\n const offsetDirection = this.vertical ? (this.$vuetify.rtl ? 'left' : 'right') : 'top'\n\n if (this.vertical) range.reverse()\n\n const ticks = range.map(index => {\n const children = []\n\n if (this.tickLabels[index]) {\n children.push(this.$createElement('div', {\n staticClass: 'v-slider__tick-label',\n }, this.tickLabels[index]))\n }\n\n const width = index * (100 / this.numTicks)\n const filled = this.$vuetify.rtl ? (100 - this.inputWidth) < width : width < this.inputWidth\n\n return this.$createElement('span', {\n key: index,\n staticClass: 'v-slider__tick',\n class: {\n 'v-slider__tick--filled': filled,\n },\n style: {\n width: `${tickSize}px`,\n height: `${tickSize}px`,\n [direction]: `calc(${width}% - ${tickSize / 2}px)`,\n [offsetDirection]: `calc(50% - ${tickSize / 2}px)`,\n },\n }, children)\n })\n\n return this.$createElement('div', {\n staticClass: 'v-slider__ticks-container',\n class: {\n 'v-slider__ticks-container--always-show': this.ticks === 'always' || this.tickLabels.length > 0,\n },\n }, ticks)\n },\n genThumbContainer (\n value: number,\n valueWidth: number,\n isActive: boolean,\n isFocused: boolean,\n onFocus: Function,\n onBlur: Function,\n ref = 'thumb'\n ): VNode {\n const children = [this.genThumb()]\n\n const thumbLabelContent = this.genThumbLabelContent(value)\n this.showThumbLabel && children.push(this.genThumbLabel(thumbLabelContent))\n\n return this.$createElement('div', this.setTextColor(this.computedThumbColor, {\n ref,\n key: ref,\n staticClass: 'v-slider__thumb-container',\n class: {\n 'v-slider__thumb-container--active': isActive,\n 'v-slider__thumb-container--focused': isFocused,\n 'v-slider__thumb-container--show-label': this.showThumbLabel,\n },\n style: this.getThumbContainerStyles(valueWidth),\n attrs: {\n role: 'slider',\n tabindex: this.isDisabled ? -1 : this.$attrs.tabindex ? this.$attrs.tabindex : 0,\n 'aria-label': this.label,\n 'aria-valuemin': this.min,\n 'aria-valuemax': this.max,\n 'aria-valuenow': this.internalValue,\n 'aria-readonly': String(this.isReadonly),\n 'aria-orientation': this.vertical ? 'vertical' : 'horizontal',\n ...this.$attrs,\n },\n on: {\n focus: onFocus,\n blur: onBlur,\n keydown: this.onKeyDown,\n },\n }), children)\n },\n genThumbLabelContent (value: number | string): ScopedSlotChildren {\n return this.$scopedSlots['thumb-label']\n ? this.$scopedSlots['thumb-label']!({ value })\n : [this.$createElement('span', [String(value)])]\n },\n genThumbLabel (content: ScopedSlotChildren): VNode {\n const size = convertToUnit(this.thumbSize)\n\n const transform = this.vertical\n ? `translateY(20%) translateY(${(Number(this.thumbSize) / 3) - 1}px) translateX(55%) rotate(135deg)`\n : `translateY(-20%) translateY(-12px) translateX(-50%) rotate(45deg)`\n\n return this.$createElement(VScaleTransition, {\n props: { origin: 'bottom center' },\n }, [\n this.$createElement('div', {\n staticClass: 'v-slider__thumb-label-container',\n directives: [{\n name: 'show',\n value: this.isFocused || this.isActive || this.thumbLabel === 'always',\n }],\n }, [\n this.$createElement('div', this.setBackgroundColor(this.computedThumbColor, {\n staticClass: 'v-slider__thumb-label',\n style: {\n height: size,\n width: size,\n transform,\n },\n }), [this.$createElement('div', content)]),\n ]),\n ])\n },\n genThumb (): VNode {\n return this.$createElement('div', this.setBackgroundColor(this.computedThumbColor, {\n staticClass: 'v-slider__thumb',\n }))\n },\n getThumbContainerStyles (width: number): object {\n const direction = this.vertical ? 'top' : 'left'\n let value = this.$vuetify.rtl ? 100 - width : width\n value = this.vertical ? 100 - value : value\n\n return {\n transition: this.trackTransition,\n [direction]: `${value}%`,\n }\n },\n onSliderMouseDown (e: MouseEvent) {\n e.preventDefault()\n\n this.oldValue = this.internalValue\n this.isActive = true\n\n const mouseUpOptions = passiveSupported ? { passive: true, capture: true } : true\n const mouseMoveOptions = passiveSupported ? { passive: true } : false\n\n if ((e.target as Element)?.matches('.v-slider__thumb-container, .v-slider__thumb-container *')) {\n this.thumbPressed = true\n } else {\n window.clearTimeout(this.mouseTimeout)\n this.mouseTimeout = window.setTimeout(() => {\n this.thumbPressed = true\n }, 300)\n }\n\n const isTouchEvent = 'touches' in e\n\n this.onMouseMove(e)\n this.app.addEventListener(isTouchEvent ? 'touchmove' : 'mousemove', this.onMouseMove, mouseMoveOptions)\n addOnceEventListener(this.app, isTouchEvent ? 'touchend' : 'mouseup', this.onSliderMouseUp, mouseUpOptions)\n\n this.$emit('start', this.internalValue)\n },\n onSliderMouseUp (e: Event) {\n e.stopPropagation()\n window.clearTimeout(this.mouseTimeout)\n this.thumbPressed = false\n const mouseMoveOptions = passiveSupported ? { passive: true } : false\n this.app.removeEventListener('touchmove', this.onMouseMove, mouseMoveOptions)\n this.app.removeEventListener('mousemove', this.onMouseMove, mouseMoveOptions)\n\n this.$emit('mouseup', e)\n this.$emit('end', this.internalValue)\n if (!deepEqual(this.oldValue, this.internalValue)) {\n this.$emit('change', this.internalValue)\n this.noClick = true\n }\n\n this.isActive = false\n },\n onMouseMove (e: MouseEvent) {\n if (e.type === 'mousemove') {\n this.thumbPressed = true\n }\n this.internalValue = this.parseMouseMove(e)\n },\n onKeyDown (e: KeyboardEvent) {\n if (!this.isInteractive) return\n\n const value = this.parseKeyDown(e, this.internalValue)\n\n if (\n value == null ||\n value < this.minValue ||\n value > this.maxValue\n ) return\n\n this.internalValue = value\n this.$emit('change', value)\n },\n onSliderClick (e: MouseEvent) {\n if (this.noClick) {\n this.noClick = false\n return\n }\n const thumb = this.$refs.thumb as HTMLElement\n thumb.focus()\n\n this.onMouseMove(e)\n this.$emit('change', this.internalValue)\n },\n onBlur (e: Event) {\n this.isFocused = false\n\n this.$emit('blur', e)\n },\n onFocus (e: Event) {\n this.isFocused = true\n\n this.$emit('focus', e)\n },\n parseMouseMove (e: MouseEvent) {\n const start = this.vertical ? 'top' : 'left'\n const length = this.vertical ? 'height' : 'width'\n const click = this.vertical ? 'clientY' : 'clientX'\n\n const {\n [start]: trackStart,\n [length]: trackLength,\n } = this.$refs.track.getBoundingClientRect() as any\n const clickOffset = 'touches' in e ? (e as any).touches[0][click] : e[click] // Can we get rid of any here?\n\n // It is possible for left to be NaN, force to number\n let clickPos = Math.min(Math.max((clickOffset - trackStart) / trackLength, 0), 1) || 0\n\n if (this.vertical) clickPos = 1 - clickPos\n if (this.$vuetify.rtl) clickPos = 1 - clickPos\n\n return parseFloat(this.min) + clickPos * (this.maxValue - this.minValue)\n },\n parseKeyDown (e: KeyboardEvent, value: number) {\n if (!this.isInteractive) return\n\n const { pageup, pagedown, end, home, left, right, down, up } = keyCodes\n\n if (![pageup, pagedown, end, home, left, right, down, up].includes(e.keyCode)) return\n\n e.preventDefault()\n const step = this.stepNumeric || 1\n const steps = (this.maxValue - this.minValue) / step\n if ([left, right, down, up].includes(e.keyCode)) {\n const increase = this.$vuetify.rtl ? [left, up] : [right, up]\n const direction = increase.includes(e.keyCode) ? 1 : -1\n const multiplier = e.shiftKey ? 3 : (e.ctrlKey ? 2 : 1)\n\n value = value + (direction * step * multiplier)\n } else if (e.keyCode === home) {\n value = this.minValue\n } else if (e.keyCode === end) {\n value = this.maxValue\n } else {\n const direction = e.keyCode === pagedown ? 1 : -1\n value = value - (direction * step * (steps > 100 ? steps / 10 : 10))\n }\n\n return value\n },\n roundValue (value: number): number {\n if (!this.stepNumeric) return value\n // Format input value using the same number\n // of decimals places as in the step prop\n const trimmedStep = this.step.toString().trim()\n const decimals = trimmedStep.indexOf('.') > -1\n ? (trimmedStep.length - trimmedStep.indexOf('.') - 1)\n : 0\n const offset = this.minValue % this.stepNumeric\n\n const newValue = Math.round((value - offset) / this.stepNumeric) * this.stepNumeric + offset\n\n return parseFloat(Math.min(newValue, this.maxValue).toFixed(decimals))\n },\n },\n})\n","import { Point, Boundary, Bar } from '../VSparkline'\n\nexport function genPoints (\n values: number[],\n boundary: Boundary\n): Point[] {\n const { minX, maxX, minY, maxY } = boundary\n const totalValues = values.length\n const maxValue = Math.max(...values)\n const minValue = Math.min(...values)\n\n const gridX = (maxX - minX) / (totalValues - 1)\n const gridY = (maxY - minY) / ((maxValue - minValue) || 1)\n\n return values.map((value, index) => {\n return {\n x: minX + index * gridX,\n y: maxY - (value - minValue) * gridY,\n value,\n }\n })\n}\n\nexport function genBars (\n values: number[],\n boundary: Boundary\n): Bar[] {\n const { minX, maxX, minY, maxY } = boundary\n const totalValues = values.length\n let maxValue = Math.max(...values)\n let minValue = Math.min(...values)\n\n if (minValue > 0) minValue = 0\n if (maxValue < 0) maxValue = 0\n\n const gridX = maxX / totalValues\n const gridY = (maxY - minY) / ((maxValue - minValue) || 1)\n const horizonY = maxY - Math.abs(minValue * gridY)\n\n return values.map((value, index) => {\n const height = Math.abs(gridY * value)\n\n return {\n x: minX + index * gridX,\n y: horizonY - height +\n +(value < 0) * height,\n height,\n value,\n }\n })\n}\n","import { Point } from '../VSparkline'\n\nfunction int (value: string | number): number {\n return parseInt(value, 10)\n}\n\n/**\n * https://en.wikipedia.org/wiki/Collinearity\n * x=(x1+x2)/2\n * y=(y1+y2)/2\n */\nexport function checkCollinear (p0: Point, p1: Point, p2: Point): boolean {\n return int(p0.x + p2.x) === int(2 * p1.x) && int(p0.y + p2.y) === int(2 * p1.y)\n}\n\nexport function getDistance (p1: Point, p2: Point): number {\n return Math.sqrt(\n Math.pow(p2.x - p1.x, 2) + Math.pow(p2.y - p1.y, 2)\n )\n}\n\nexport function moveTo (to: Point, from: Point, radius: number) {\n const vector = { x: to.x - from.x, y: to.y - from.y }\n const length = Math.sqrt((vector.x * vector.x) + (vector.y * vector.y))\n const unitVector = { x: vector.x / length, y: vector.y / length }\n\n return {\n x: from.x + unitVector.x * radius,\n y: from.y + unitVector.y * radius,\n }\n}\n","import { Point } from '../VSparkline'\nimport { checkCollinear, getDistance, moveTo } from './math'\n\n/**\n * From https://github.com/unsplash/react-trend/blob/master/src/helpers/DOM.helpers.js#L18\n */\nexport function genPath (points: Point[], radius: number, fill = false, height = 75) {\n const start = points.shift()!\n const end = points[points.length - 1]\n\n return (\n (fill ? `M${start.x} ${height - start.x + 2} L${start.x} ${start.y}` : `M${start.x} ${start.y}`) +\n points\n .map((point, index) => {\n const next = points[index + 1]\n const prev = points[index - 1] || start\n const isCollinear = next && checkCollinear(next, point, prev)\n\n if (!next || isCollinear) {\n return `L${point.x} ${point.y}`\n }\n\n const threshold = Math.min(\n getDistance(prev, point),\n getDistance(next, point)\n )\n const isTooCloseForRadius = threshold / 2 < radius\n const radiusForPoint = isTooCloseForRadius ? threshold / 2 : radius\n\n const before = moveTo(prev, point, radiusForPoint)\n const after = moveTo(next, point, radiusForPoint)\n\n return `L${before.x} ${before.y}S${point.x} ${point.y} ${after.x} ${after.y}`\n })\n .join('') +\n (fill ? `L${end.x} ${height - start.x + 2} Z` : '')\n )\n}\n","// Mixins\nimport Colorable from '../../mixins/colorable'\n\n// Utilities\nimport mixins, { ExtractVue } from '../../util/mixins'\nimport { genPoints, genBars } from './helpers/core'\nimport { genPath } from './helpers/path'\n\n// Types\nimport Vue, { VNode } from 'vue'\nimport { Prop, PropValidator } from 'vue/types/options'\n\nexport type SparklineItem = number | { value: number }\n\nexport type SparklineText = {\n x: number\n value: string\n}\n\nexport interface Boundary {\n minX: number\n minY: number\n maxX: number\n maxY: number\n}\n\nexport interface Point {\n x: number\n y: number\n value: number\n}\n\nexport interface Bar {\n x: number\n y: number\n height: number\n value: number\n}\n\ninterface options extends Vue {\n $refs: {\n path: SVGPathElement\n }\n}\n\nexport default mixins\n/* eslint-enable indent */\n>(\n Colorable\n).extend({\n name: 'VSparkline',\n\n inheritAttrs: false,\n\n props: {\n autoDraw: Boolean,\n autoDrawDuration: {\n type: Number,\n default: 2000,\n },\n autoDrawEasing: {\n type: String,\n default: 'ease',\n },\n autoLineWidth: {\n type: Boolean,\n default: false,\n },\n color: {\n type: String,\n default: 'primary',\n },\n fill: {\n type: Boolean,\n default: false,\n },\n gradient: {\n type: Array,\n default: () => ([]),\n } as PropValidator,\n gradientDirection: {\n type: String as Prop<'top' | 'bottom' | 'left' | 'right'>,\n validator: (val: string) => ['top', 'bottom', 'left', 'right'].includes(val),\n default: 'top',\n },\n height: {\n type: [String, Number],\n default: 75,\n },\n labels: {\n type: Array,\n default: () => ([]),\n } as PropValidator,\n labelSize: {\n type: [Number, String],\n default: 7,\n },\n lineWidth: {\n type: [String, Number],\n default: 4,\n },\n padding: {\n type: [String, Number],\n default: 8,\n },\n showLabels: Boolean,\n smooth: {\n type: [Boolean, Number, String],\n default: false,\n },\n type: {\n type: String as Prop<'trend' | 'bar'>,\n default: 'trend',\n validator: (val: string) => ['trend', 'bar'].includes(val),\n },\n value: {\n type: Array,\n default: () => ([]),\n } as PropValidator,\n width: {\n type: [Number, String],\n default: 300,\n },\n },\n\n data: () => ({\n lastLength: 0,\n }),\n\n computed: {\n parsedPadding (): number {\n return Number(this.padding)\n },\n parsedWidth (): number {\n return Number(this.width)\n },\n parsedHeight (): number {\n return parseInt(this.height, 10)\n },\n parsedLabelSize (): number {\n return parseInt(this.labelSize, 10) || 7\n },\n totalHeight (): number {\n let height = this.parsedHeight\n\n if (this.hasLabels) height += parseInt(this.labelSize, 10) * 1.5\n\n return height\n },\n totalWidth (): number {\n let width = this.parsedWidth\n if (this.type === 'bar') width = Math.max(this.value.length * this._lineWidth, width)\n\n return width\n },\n totalValues (): number {\n return this.value.length\n },\n _lineWidth (): number {\n if (this.autoLineWidth && this.type !== 'trend') {\n const totalPadding = this.parsedPadding * (this.totalValues + 1)\n return (this.parsedWidth - totalPadding) / this.totalValues\n } else {\n return parseFloat(this.lineWidth) || 4\n }\n },\n boundary (): Boundary {\n if (this.type === 'bar') return { minX: 0, maxX: this.totalWidth, minY: 0, maxY: this.parsedHeight }\n\n const padding = this.parsedPadding\n\n return {\n minX: padding,\n maxX: this.totalWidth - padding,\n minY: padding,\n maxY: this.parsedHeight - padding,\n }\n },\n hasLabels (): boolean {\n return Boolean(\n this.showLabels ||\n this.labels.length > 0 ||\n this.$scopedSlots.label\n )\n },\n parsedLabels (): SparklineText[] {\n const labels = []\n const points = this._values\n const len = points.length\n\n for (let i = 0; labels.length < len; i++) {\n const item = points[i]\n let value = this.labels[i]\n\n if (!value) {\n value = typeof item === 'object'\n ? item.value\n : item\n }\n\n labels.push({\n x: item.x,\n value: String(value),\n })\n }\n\n return labels\n },\n normalizedValues (): number[] {\n return this.value.map(item => (typeof item === 'number' ? item : item.value))\n },\n _values (): Point[] | Bar[] {\n return this.type === 'trend' ? genPoints(this.normalizedValues, this.boundary) : genBars(this.normalizedValues, this.boundary)\n },\n textY (): number {\n let y = this.parsedHeight\n if (this.type === 'trend') y -= 4\n return y\n },\n _radius (): number {\n return this.smooth === true ? 8 : Number(this.smooth)\n },\n },\n\n watch: {\n value: {\n immediate: true,\n handler () {\n this.$nextTick(() => {\n if (\n !this.autoDraw ||\n this.type === 'bar' ||\n !this.$refs.path\n ) return\n\n const path = this.$refs.path\n const length = path.getTotalLength()\n\n if (!this.fill) {\n path.style.transition = 'none'\n path.style.strokeDasharray = length + ' ' + length\n path.style.strokeDashoffset = Math.abs(length - (this.lastLength || 0)).toString()\n path.getBoundingClientRect()\n path.style.transition = `stroke-dashoffset ${this.autoDrawDuration}ms ${this.autoDrawEasing}`\n path.style.strokeDashoffset = '0'\n } else {\n path.style.transformOrigin = 'bottom center'\n path.style.transition = 'none'\n path.style.transform = `scaleY(0)`\n path.getBoundingClientRect()\n path.style.transition = `transform ${this.autoDrawDuration}ms ${this.autoDrawEasing}`\n path.style.transform = `scaleY(1)`\n }\n this.lastLength = length\n })\n },\n },\n },\n\n methods: {\n genGradient () {\n const gradientDirection = this.gradientDirection\n const gradient = this.gradient.slice()\n\n // Pushes empty string to force\n // a fallback to currentColor\n if (!gradient.length) gradient.push('')\n\n const len = Math.max(gradient.length - 1, 1)\n const stops = gradient.reverse().map((color, index) =>\n this.$createElement('stop', {\n attrs: {\n offset: index / len,\n 'stop-color': color || 'currentColor',\n },\n })\n )\n\n return this.$createElement('defs', [\n this.$createElement('linearGradient', {\n attrs: {\n id: this._uid,\n gradientUnits: 'userSpaceOnUse',\n x1: gradientDirection === 'left' ? '100%' : '0',\n y1: gradientDirection === 'top' ? '100%' : '0',\n x2: gradientDirection === 'right' ? '100%' : '0',\n y2: gradientDirection === 'bottom' ? '100%' : '0',\n },\n }, stops),\n ])\n },\n genG (children: VNode[]) {\n return this.$createElement('g', {\n style: {\n fontSize: '8',\n textAnchor: 'middle',\n dominantBaseline: 'mathematical',\n fill: 'currentColor',\n } as object, // TODO: TS 3.5 is too eager with the array type here\n }, children)\n },\n genPath () {\n const points = genPoints(this.normalizedValues, this.boundary)\n\n return this.$createElement('path', {\n attrs: {\n d: genPath(points, this._radius, this.fill, this.parsedHeight),\n fill: this.fill ? `url(#${this._uid})` : 'none',\n stroke: this.fill ? 'none' : `url(#${this._uid})`,\n },\n ref: 'path',\n })\n },\n genLabels (offsetX: number) {\n const children = this.parsedLabels.map((item, i) => (\n this.$createElement('text', {\n attrs: {\n x: item.x + offsetX + this._lineWidth / 2,\n y: this.textY + (this.parsedLabelSize * 0.75),\n 'font-size': Number(this.labelSize) || 7,\n },\n }, [this.genLabel(item, i)])\n ))\n\n return this.genG(children)\n },\n genLabel (item: SparklineText, index: number) {\n return this.$scopedSlots.label\n ? this.$scopedSlots.label({ index, value: item.value })\n : item.value\n },\n genBars () {\n if (!this.value || this.totalValues < 2) return undefined as never\n\n const bars = genBars(this.normalizedValues, this.boundary)\n const offsetX = (Math.abs(bars[0].x - bars[1].x) - this._lineWidth) / 2\n\n return this.$createElement('svg', {\n attrs: {\n display: 'block',\n viewBox: `0 0 ${this.totalWidth} ${this.totalHeight}`,\n },\n }, [\n this.genGradient(),\n this.genClipPath(bars, offsetX, this._lineWidth, 'sparkline-bar-' + this._uid),\n this.hasLabels ? this.genLabels(offsetX) : undefined as never,\n this.$createElement('g', {\n attrs: {\n 'clip-path': `url(#sparkline-bar-${this._uid}-clip)`,\n fill: `url(#${this._uid})`,\n },\n }, [\n this.$createElement('rect', {\n attrs: {\n x: 0,\n y: 0,\n width: this.totalWidth,\n height: this.height,\n },\n }),\n ]),\n ])\n },\n genClipPath (bars: Bar[], offsetX: number, lineWidth: number, id: string) {\n const rounding = typeof this.smooth === 'number'\n ? this.smooth\n : this.smooth ? 2 : 0\n\n return this.$createElement('clipPath', {\n attrs: {\n id: `${id}-clip`,\n },\n }, bars.map(item => {\n return this.$createElement('rect', {\n attrs: {\n x: item.x + offsetX,\n y: item.y,\n width: lineWidth,\n height: item.height,\n rx: rounding,\n ry: rounding,\n },\n }, [\n this.autoDraw ? this.$createElement('animate', {\n attrs: {\n attributeName: 'height',\n from: 0,\n to: item.height,\n dur: `${this.autoDrawDuration}ms`,\n fill: 'freeze',\n },\n }) : undefined as never,\n ])\n }))\n },\n genTrend () {\n return this.$createElement('svg', this.setTextColor(this.color, {\n attrs: {\n ...this.$attrs,\n display: 'block',\n 'stroke-width': this._lineWidth || 1,\n viewBox: `0 0 ${this.width} ${this.totalHeight}`,\n },\n }), [\n this.genGradient(),\n this.hasLabels && this.genLabels(-(this._lineWidth / 2)),\n this.genPath(),\n ])\n },\n },\n\n render (h): VNode {\n if (this.totalValues < 2) return undefined as never\n\n return this.type === 'trend' ? this.genTrend() : this.genBars()\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","// 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":""}