{"version":3,"sources":["webpack:///../../../src/components/VMenu/index.ts","webpack:///../../../src/components/VChip/index.ts","webpack:///../../../src/components/VThemeProvider/VThemeProvider.ts","webpack:///../../../src/mixins/comparable/index.ts","webpack:///../../../src/components/VCheckbox/VSimpleCheckbox.ts","webpack:///../../../src/components/VDivider/index.ts","webpack:///../../../src/components/VSubheader/VSubheader.ts","webpack:///../../../src/components/VSubheader/index.ts","webpack:///../../../src/components/VSelect/VSelectList.ts","webpack:///../../../src/mixins/filterable/index.ts","webpack:///../../../src/components/VSelect/VSelect.ts","webpack:///../../../src/components/VChip/VChip.ts","webpack:///../../../src/components/VMenu/VMenu.ts","webpack:///../../../src/mixins/returnable/index.ts"],"names":["name","props","root","Boolean","computed","isDark","this","render","$slots","default","node","valueComparator","type","functional","directives","ripple","disabled","value","indeterminate","indeterminateIcon","onIcon","offIcon","children","listeners","h","staticClass","center","icon","dark","light","classes","data","class","on","click","e","f","mixins","inset","themeClasses","attrs","$listeners","action","dense","hideSelected","items","itemDisabled","String","Array","itemText","itemValue","noDataText","noFilter","searchInput","selectedItems","parsedItems","map","item","tileActiveClass","Object","setTextColor","staticNoDataTile","tile","role","undefined","mousedown","$createElement","VListItem","genTileContent","methods","genAction","VListItemAction","VSimpleCheckbox","color","inputValue","input","genDivider","VDivider","genFilteredText","text","getMaskedCharacters","end","start","genHighlight","middle","genHeader","index","genTile","hasItem","getDisabled","id","_uid","activeClass","$scopedSlots","length","parent","scopedSlot","needsTile","innerHTML","getText","VList","domProps","indexOf","getValue","slot","itemsLength","tabindex","defaultMenuProps","closeOnClick","closeOnContentClick","disableKeys","openOnClick","maxHeight","baseMixins","ClickOutside","appendIcon","attach","cacheItems","chips","clearable","deletableChips","disableLookup","eager","itemColor","menuProps","multiple","openOnClear","returnObject","smallChips","cachedItems","menuIsBooted","isMenuActive","lastItem","lazyValue","selectedIndex","keyboardLookupPrefix","keyboardLookupLastTime","allItems","filterDuplicates","concat","computedItems","computedOwns","computedCounterValue","isFocused","handler","closeConditional","dynamicHeight","hasChips","hasSlot","isDirty","listData","scopeId","$vnode","context","$vuetify","lang","t","select","selectItem","scopedSlots","staticList","console","VSelectList","virtualizedItems","$_menuProps","slice","menuCanShow","normalisedProps","split","acc","p","nudgeBottom","watch","internalValue","window","immediate","blur","activateMenu","clearableCallback","getContent","contains","$el","uniqueValues","arr","val","findExistingIndex","i","$refs","menu","genChipSelection","isDisabled","VChip","close","small","key","JSON","genCommaSelection","last","genDefaultSlot","selections","prefix","genAffix","suffix","genIcon","VInput","mergeData","genInput","readonly","autocomplete","keypress","onKeyPress","genHiddenInput","attrs$","genInputSlot","genList","genListWithSlot","slots","slotName","genMenu","VMenu","scroll","onScroll","ref","genSelections","genSelection","genSlotSelection","selection","selected","isInteractive","getMenuIndex","onBlur","$emit","onChipInput","setValue","onClick","isAppendInner","onEscDown","KEYBOARD_LOOKUP_THRESHOLD","now","performance","findIndex","Math","setTimeout","onKeyDown","isReadonly","keyCode","onUpDown","onTabDown","onSpaceDown","onMenuActiveChange","onMouseUp","hasMouseDown","showMoreItems","scrollHeight","scrollTop","requestAnimationFrame","activeTile","listIndex","setMenuIndex","setSelectedItems","values","v","oldValue","appendInner","active","chipGroup","closeIcon","draggable","filter","filterIcon","label","link","outlined","pill","tag","textColor","proxyClass","groupClasses","hasClose","isClickable","created","breakingProps","original","replacement","genFilter","left","genClose","right","size","genContent","setBackgroundColor","provide","isInMenu","theme","Resize","auto","Number","offsetX","offsetY","openOnHover","origin","transition","calculatedTopAuto","defaultOffset","hasJustFocused","resizeTimeout","tiles","calculatedLeft","menuWidth","dimensions","content","parseFloat","calcXOverflow","calcLeft","calculatedMaxHeight","height","calculatedMaxWidth","calculatedMinWidth","minWidth","activator","width","pageWidth","isNaN","parseInt","calculatedTop","top","calcYOverflow","hasClickableTiles","find","styles","maxWidth","transformOrigin","zIndex","activeZIndex","isActive","isContentActive","next","prev","classList","remove","$attrs","hasOwnProperty","mounted","activate","calcScrollPosition","maxScrollTop","calcLeftAuto","calcTopAuto","tileDistanceFromMenuTop","firstTileOffsetTop","computedTop","changeListIndex","target","genActivatorAttributes","attributes","genActivatorListeners","genTransition","genDirectives","include","options","menuable__content__active","contentClass","style","keydown","getTiles","querySelectorAll","mouseEnterHandler","mouseLeaveHandler","nextTile","prevTile","onResize","clearTimeout","arg","showLazyContent","returnValue","originalValue","save"],"mappings":"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","file":"js/chunk-2a0309b2.5e1e0f3d.js","sourcesContent":["import VMenu from './VMenu'\n\nexport { VMenu }\nexport default VMenu\n","import VChip from './VChip'\n\nexport { VChip }\nexport default VChip\n","// Mixins\nimport Themeable from '../../mixins/themeable'\n\n// Types\nimport { VNode } from 'vue'\n\n/* @vue/component */\nexport default Themeable.extend({\n name: 'v-theme-provider',\n\n props: { root: Boolean },\n\n computed: {\n isDark (): boolean {\n return this.root\n ? this.rootIsDark\n : Themeable.options.computed.isDark.call(this)\n },\n },\n\n render (): VNode {\n /* istanbul ignore next */\n return (\n this.$slots.default! &&\n this.$slots.default!.find(node => !node.isComment && node.text !== ' ')!\n )\n },\n})\n","import Vue from 'vue'\nimport { PropValidator } from 'vue/types/options'\nimport { deepEqual } from '../../util/helpers'\n\nexport default Vue.extend({\n name: 'comparable',\n props: {\n valueComparator: {\n type: Function,\n default: deepEqual,\n } as PropValidator<typeof deepEqual>,\n },\n})\n","import './VSimpleCheckbox.sass'\n\nimport ripple from '../../directives/ripple'\n\nimport Vue, { VNode, VNodeDirective } from 'vue'\nimport { VIcon } from '../VIcon'\n\n// Mixins\nimport Colorable from '../../mixins/colorable'\nimport Themeable from '../../mixins/themeable'\n\n// Utilities\nimport mergeData from '../../util/mergeData'\nimport { wrapInArray } from '../../util/helpers'\n\nexport default Vue.extend({\n name: 'v-simple-checkbox',\n\n functional: true,\n\n directives: {\n ripple,\n },\n\n props: {\n ...Colorable.options.props,\n ...Themeable.options.props,\n disabled: Boolean,\n ripple: {\n type: Boolean,\n default: true,\n },\n value: Boolean,\n indeterminate: Boolean,\n indeterminateIcon: {\n type: String,\n default: '$checkboxIndeterminate',\n },\n onIcon: {\n type: String,\n default: '$checkboxOn',\n },\n offIcon: {\n type: String,\n default: '$checkboxOff',\n },\n },\n\n render (h, { props, data, listeners }): VNode {\n const children = []\n\n if (props.ripple && !props.disabled) {\n const ripple = h('div', Colorable.options.methods.setTextColor(props.color, {\n staticClass: 'v-input--selection-controls__ripple',\n directives: [{\n name: 'ripple',\n value: { center: true },\n }] as VNodeDirective[],\n }))\n\n children.push(ripple)\n }\n\n let icon = props.offIcon\n if (props.indeterminate) icon = props.indeterminateIcon\n else if (props.value) icon = props.onIcon\n\n children.push(h(VIcon, Colorable.options.methods.setTextColor(props.value && props.color, {\n props: {\n disabled: props.disabled,\n dark: props.dark,\n light: props.light,\n },\n }), icon))\n\n const classes = {\n 'v-simple-checkbox': true,\n 'v-simple-checkbox--disabled': props.disabled,\n }\n\n return h('div',\n mergeData(data, {\n class: classes,\n on: {\n click: (e: MouseEvent) => {\n e.stopPropagation()\n\n if (data.on && data.on.input && !props.disabled) {\n wrapInArray(data.on.input).forEach(f => f(!props.value))\n }\n },\n },\n }), children)\n },\n})\n","import VDivider from './VDivider'\n\nexport { VDivider }\nexport default VDivider\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","// 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<any[]>,\n itemDisabled: {\n type: [String, Array, Function] as PropType<SelectItemKey>,\n default: 'disabled',\n },\n itemText: {\n type: [String, Array, Function] as PropType<SelectItemKey>,\n default: 'text',\n },\n itemValue: {\n type: [String, Array, Function] as PropType<SelectItemKey>,\n default: 'value',\n },\n noDataText: String,\n noFilter: Boolean,\n searchInput: null as unknown as PropType<any>,\n selectedItems: {\n type: Array,\n default: () => [],\n } as PropValidator<any[]>,\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 },\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 `<span class=\"v-list-item__mask\">${escapeHTML(text)}</span>`\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: '', middle: text, 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","import Vue from 'vue'\n\n/* @vue/component */\nexport default Vue.extend({\n name: 'filterable',\n\n props: {\n noDataText: {\n type: String,\n default: '$vuetify.noDataText',\n },\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 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 Filterable\n)\n\ninterface options extends InstanceType<typeof baseMixins> {\n $refs: {\n menu: InstanceType<typeof VMenu>\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<options>().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<string | boolean | Element | VNode>,\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<any[]>,\n itemColor: {\n type: String,\n default: 'primary',\n },\n itemDisabled: {\n type: [String, Array, Function] as PropType<SelectItemKey>,\n default: 'disabled',\n },\n itemText: {\n type: [String, Array, Function] as PropType<SelectItemKey>,\n default: 'text',\n },\n itemValue: {\n type: [String, Array, Function] as PropType<SelectItemKey>,\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 return this.multiple\n ? this.selectedItems.length\n : (this.getText(this.selectedItems[0]) || '').toString().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 },\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 },\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 ? [] : undefined)\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 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.isInteractive ||\n this.getDisabled(item)\n )\n\n return this.$createElement(VChip, {\n staticClass: 'v-chip--select',\n attrs: { tabindex: -1 },\n props: {\n close: this.deletableChips && !isDisabled,\n disabled: isDisabled,\n inputValue: index === this.selectedIndex,\n small: this.smallChips,\n },\n on: {\n click: (e: MouseEvent) => {\n if (isDisabled) 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.isInteractive ||\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 },\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 (<v-menu attach>)\n this.attach === true || // If bound to a boolean (<v-menu :attach=\"true\">)\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 and down 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].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 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 // If user is clicking in the container\n // and field is enclosed, activate it\n } else if (this.isEnclosed) {\n this.isMenuActive = true\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 keyCodes.up === keyCode ? menu.prevTile() : menu.nextTile()\n menu.activeTile && menu.activeTile.click()\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 oldValue = this.internalValue\n this.internalValue = value\n value !== oldValue && this.$emit('change', value)\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","// Styles\nimport './VChip.sass'\n\n// Types\nimport { VNode } from 'vue'\nimport mixins from '../../util/mixins'\n\n// Components\nimport { VExpandXTransition } from '../transitions'\nimport VIcon from '../VIcon'\n\n// Mixins\nimport Colorable from '../../mixins/colorable'\nimport { factory as GroupableFactory } from '../../mixins/groupable'\nimport Themeable from '../../mixins/themeable'\nimport { factory as ToggleableFactory } from '../../mixins/toggleable'\nimport Routable from '../../mixins/routable'\nimport Sizeable from '../../mixins/sizeable'\n\n// Utilities\nimport { breaking } from '../../util/console'\n\n// Types\nimport { PropValidator, PropType } from 'vue/types/options'\n\n/* @vue/component */\nexport default mixins(\n Colorable,\n Sizeable,\n Routable,\n Themeable,\n GroupableFactory('chipGroup'),\n ToggleableFactory('inputValue')\n).extend({\n name: 'v-chip',\n\n props: {\n active: {\n type: Boolean,\n default: true,\n },\n activeClass: {\n type: String,\n default (): string | undefined {\n if (!this.chipGroup) return ''\n\n return this.chipGroup.activeClass\n },\n } as any as PropValidator<string>,\n close: Boolean,\n closeIcon: {\n type: String,\n default: '$delete',\n },\n disabled: Boolean,\n draggable: Boolean,\n filter: Boolean,\n filterIcon: {\n type: String,\n default: '$complete',\n },\n label: Boolean,\n link: Boolean,\n outlined: Boolean,\n pill: Boolean,\n tag: {\n type: String,\n default: 'span',\n },\n textColor: String,\n value: null as any as PropType<any>,\n },\n\n data: () => ({\n proxyClass: 'v-chip--active',\n }),\n\n computed: {\n classes (): object {\n return {\n 'v-chip': true,\n ...Routable.options.computed.classes.call(this),\n 'v-chip--clickable': this.isClickable,\n 'v-chip--disabled': this.disabled,\n 'v-chip--draggable': this.draggable,\n 'v-chip--label': this.label,\n 'v-chip--link': this.isLink,\n 'v-chip--no-color': !this.color,\n 'v-chip--outlined': this.outlined,\n 'v-chip--pill': this.pill,\n 'v-chip--removable': this.hasClose,\n ...this.themeClasses,\n ...this.sizeableClasses,\n ...this.groupClasses,\n }\n },\n hasClose (): boolean {\n return Boolean(this.close)\n },\n isClickable (): boolean {\n return Boolean(\n Routable.options.computed.isClickable.call(this) ||\n this.chipGroup\n )\n },\n },\n\n created () {\n const breakingProps = [\n ['outline', 'outlined'],\n ['selected', 'input-value'],\n ['value', 'active'],\n ['@input', '@active.sync'],\n ]\n\n /* istanbul ignore next */\n breakingProps.forEach(([original, replacement]) => {\n if (this.$attrs.hasOwnProperty(original)) breaking(original, replacement, this)\n })\n },\n\n methods: {\n click (e: MouseEvent): void {\n this.$emit('click', e)\n\n this.chipGroup && this.toggle()\n },\n genFilter (): VNode {\n const children = []\n\n if (this.isActive) {\n children.push(\n this.$createElement(VIcon, {\n staticClass: 'v-chip__filter',\n props: { left: true },\n }, this.filterIcon)\n )\n }\n\n return this.$createElement(VExpandXTransition, children)\n },\n genClose (): VNode {\n return this.$createElement(VIcon, {\n staticClass: 'v-chip__close',\n props: {\n right: true,\n size: 18,\n },\n on: {\n click: (e: Event) => {\n e.stopPropagation()\n e.preventDefault()\n\n this.$emit('click:close')\n this.$emit('update:active', false)\n },\n },\n }, this.closeIcon)\n },\n genContent (): VNode {\n return this.$createElement('span', {\n staticClass: 'v-chip__content',\n }, [\n this.filter && this.genFilter(),\n this.$slots.default,\n this.hasClose && this.genClose(),\n ])\n },\n },\n\n render (h): VNode {\n const children = [this.genContent()]\n let { tag, data } = this.generateRouteLink()\n\n data.attrs = {\n ...data.attrs,\n draggable: this.draggable ? 'true' : undefined,\n tabindex: this.chipGroup && !this.disabled ? 0 : data.attrs!.tabindex,\n }\n data.directives!.push({\n name: 'show',\n value: this.active,\n })\n data = this.setBackgroundColor(this.color, data)\n\n const color = this.textColor || (this.outlined && this.color)\n\n return h(tag, this.setTextColor(color, data), children)\n },\n})\n","// Styles\nimport './VMenu.sass'\n\n// Components\nimport { VThemeProvider } from '../VThemeProvider'\n\n// Mixins\nimport Activatable from '../../mixins/activatable'\nimport Delayable from '../../mixins/delayable'\nimport Dependent from '../../mixins/dependent'\nimport Detachable from '../../mixins/detachable'\nimport Menuable from '../../mixins/menuable'\nimport Returnable from '../../mixins/returnable'\nimport Roundable from '../../mixins/roundable'\nimport Toggleable from '../../mixins/toggleable'\nimport Themeable from '../../mixins/themeable'\n\n// Directives\nimport ClickOutside from '../../directives/click-outside'\nimport Resize from '../../directives/resize'\n\n// Utilities\nimport mixins from '../../util/mixins'\nimport { removed } from '../../util/console'\nimport {\n convertToUnit,\n keyCodes,\n} from '../../util/helpers'\n\n// Types\nimport { VNode, VNodeDirective, VNodeData } from 'vue'\n\nconst baseMixins = mixins(\n Dependent,\n Delayable,\n Detachable,\n Menuable,\n Returnable,\n Roundable,\n Toggleable,\n Themeable\n)\n\n/* @vue/component */\nexport default baseMixins.extend({\n name: 'v-menu',\n\n provide (): object {\n return {\n isInMenu: true,\n // Pass theme through to default slot\n theme: this.theme,\n }\n },\n\n directives: {\n ClickOutside,\n Resize,\n },\n\n props: {\n auto: Boolean,\n closeOnClick: {\n type: Boolean,\n default: true,\n },\n closeOnContentClick: {\n type: Boolean,\n default: true,\n },\n disabled: Boolean,\n disableKeys: Boolean,\n maxHeight: {\n type: [Number, String],\n default: 'auto',\n },\n offsetX: Boolean,\n offsetY: Boolean,\n openOnClick: {\n type: Boolean,\n default: true,\n },\n openOnHover: Boolean,\n origin: {\n type: String,\n default: 'top left',\n },\n transition: {\n type: [Boolean, String],\n default: 'v-menu-transition',\n },\n },\n\n data () {\n return {\n calculatedTopAuto: 0,\n defaultOffset: 8,\n hasJustFocused: false,\n listIndex: -1,\n resizeTimeout: 0,\n selectedIndex: null as null | number,\n tiles: [] as HTMLElement[],\n }\n },\n\n computed: {\n activeTile (): HTMLElement | undefined {\n return this.tiles[this.listIndex]\n },\n calculatedLeft (): string {\n const menuWidth = Math.max(this.dimensions.content.width, parseFloat(this.calculatedMinWidth))\n\n if (!this.auto) return this.calcLeft(menuWidth) || '0'\n\n return convertToUnit(this.calcXOverflow(this.calcLeftAuto(), menuWidth)) || '0'\n },\n calculatedMaxHeight (): string {\n const height = this.auto\n ? '200px'\n : convertToUnit(this.maxHeight)\n\n return height || '0'\n },\n calculatedMaxWidth (): string {\n return convertToUnit(this.maxWidth) || '0'\n },\n calculatedMinWidth (): string {\n if (this.minWidth) {\n return convertToUnit(this.minWidth) || '0'\n }\n\n const minWidth = Math.min(\n this.dimensions.activator.width +\n Number(this.nudgeWidth) +\n (this.auto ? 16 : 0),\n Math.max(this.pageWidth - 24, 0)\n )\n\n const calculatedMaxWidth = isNaN(parseInt(this.calculatedMaxWidth))\n ? minWidth\n : parseInt(this.calculatedMaxWidth)\n\n return convertToUnit(Math.min(\n calculatedMaxWidth,\n minWidth\n )) || '0'\n },\n calculatedTop (): string {\n const top = !this.auto\n ? this.calcTop()\n : convertToUnit(this.calcYOverflow(this.calculatedTopAuto))\n\n return top || '0'\n },\n hasClickableTiles (): boolean {\n return Boolean(this.tiles.find(tile => tile.tabIndex > -1))\n },\n styles (): object {\n return {\n maxHeight: this.calculatedMaxHeight,\n minWidth: this.calculatedMinWidth,\n maxWidth: this.calculatedMaxWidth,\n top: this.calculatedTop,\n left: this.calculatedLeft,\n transformOrigin: this.origin,\n zIndex: this.zIndex || this.activeZIndex,\n }\n },\n },\n\n watch: {\n isActive (val) {\n if (!val) this.listIndex = -1\n },\n isContentActive (val) {\n this.hasJustFocused = val\n },\n listIndex (next, prev) {\n if (next in this.tiles) {\n const tile = this.tiles[next]\n tile.classList.add('v-list-item--highlighted')\n this.$refs.content.scrollTop = tile.offsetTop - tile.clientHeight\n }\n\n prev in this.tiles &&\n this.tiles[prev].classList.remove('v-list-item--highlighted')\n },\n },\n\n created () {\n /* istanbul ignore next */\n if (this.$attrs.hasOwnProperty('full-width')) {\n removed('full-width', this)\n }\n },\n\n mounted () {\n this.isActive && this.callActivate()\n },\n\n methods: {\n activate () {\n // Update coordinates and dimensions of menu\n // and its activator\n this.updateDimensions()\n // Start the transition\n requestAnimationFrame(() => {\n // Once transitioning, calculate scroll and top position\n this.startTransition().then(() => {\n if (this.$refs.content) {\n this.calculatedTopAuto = this.calcTopAuto()\n this.auto && (this.$refs.content.scrollTop = this.calcScrollPosition())\n }\n })\n })\n },\n calcScrollPosition () {\n const $el = this.$refs.content\n const activeTile = $el.querySelector('.v-list-item--active') as HTMLElement\n const maxScrollTop = $el.scrollHeight - $el.offsetHeight\n\n return activeTile\n ? Math.min(maxScrollTop, Math.max(0, activeTile.offsetTop - $el.offsetHeight / 2 + activeTile.offsetHeight / 2))\n : $el.scrollTop\n },\n calcLeftAuto () {\n return parseInt(this.dimensions.activator.left - this.defaultOffset * 2)\n },\n calcTopAuto () {\n const $el = this.$refs.content\n const activeTile = $el.querySelector('.v-list-item--active') as HTMLElement | null\n\n if (!activeTile) {\n this.selectedIndex = null\n }\n\n if (this.offsetY || !activeTile) {\n return this.computedTop\n }\n\n this.selectedIndex = Array.from(this.tiles).indexOf(activeTile)\n\n const tileDistanceFromMenuTop = activeTile.offsetTop - this.calcScrollPosition()\n const firstTileOffsetTop = ($el.querySelector('.v-list-item') as HTMLElement).offsetTop\n\n return this.computedTop - tileDistanceFromMenuTop - firstTileOffsetTop - 1\n },\n changeListIndex (e: KeyboardEvent) {\n // For infinite scroll and autocomplete, re-evaluate children\n this.getTiles()\n\n if (!this.isActive || !this.hasClickableTiles) {\n return\n } else if (e.keyCode === keyCodes.tab) {\n this.isActive = false\n return\n } else if (e.keyCode === keyCodes.down) {\n this.nextTile()\n } else if (e.keyCode === keyCodes.up) {\n this.prevTile()\n } else if (e.keyCode === keyCodes.enter && this.listIndex !== -1) {\n this.tiles[this.listIndex].click()\n } else { return }\n // One of the conditions was met, prevent default action (#2988)\n e.preventDefault()\n },\n closeConditional (e: Event) {\n const target = e.target as HTMLElement\n\n return this.isActive &&\n !this._isDestroyed &&\n this.closeOnClick &&\n !this.$refs.content.contains(target)\n },\n genActivatorAttributes () {\n const attributes = Activatable.options.methods.genActivatorAttributes.call(this)\n\n if (this.activeTile && this.activeTile.id) {\n return {\n ...attributes,\n 'aria-activedescendant': this.activeTile.id,\n }\n }\n\n return attributes\n },\n genActivatorListeners () {\n const listeners = Menuable.options.methods.genActivatorListeners.call(this)\n\n if (!this.disableKeys) {\n listeners.keydown = this.onKeyDown\n }\n\n return listeners\n },\n genTransition (): VNode {\n const content = this.genContent()\n\n if (!this.transition) return content\n\n return this.$createElement('transition', {\n props: {\n name: this.transition,\n },\n }, [content])\n },\n genDirectives (): VNodeDirective[] {\n const directives: VNodeDirective[] = [{\n name: 'show',\n value: this.isContentActive,\n }]\n\n // Do not add click outside for hover menu\n if (!this.openOnHover && this.closeOnClick) {\n directives.push({\n name: 'click-outside',\n value: {\n handler: () => { this.isActive = false },\n closeConditional: this.closeConditional,\n include: () => [this.$el, ...this.getOpenDependentElements()],\n },\n })\n }\n\n return directives\n },\n genContent (): VNode {\n const options = {\n attrs: {\n ...this.getScopeIdAttrs(),\n role: 'role' in this.$attrs ? this.$attrs.role : 'menu',\n },\n staticClass: 'v-menu__content',\n class: {\n ...this.rootThemeClasses,\n ...this.roundedClasses,\n 'v-menu__content--auto': this.auto,\n 'v-menu__content--fixed': this.activatorFixed,\n menuable__content__active: this.isActive,\n [this.contentClass.trim()]: true,\n },\n style: this.styles,\n directives: this.genDirectives(),\n ref: 'content',\n on: {\n click: (e: Event) => {\n const target = e.target as HTMLElement\n\n if (target.getAttribute('disabled')) return\n if (this.closeOnContentClick) this.isActive = false\n },\n keydown: this.onKeyDown,\n },\n } as VNodeData\n\n if (this.$listeners.scroll) {\n options.on = options.on || {}\n options.on.scroll = this.$listeners.scroll\n }\n\n if (!this.disabled && this.openOnHover) {\n options.on = options.on || {}\n options.on.mouseenter = this.mouseEnterHandler\n }\n\n if (this.openOnHover) {\n options.on = options.on || {}\n options.on.mouseleave = this.mouseLeaveHandler\n }\n\n return this.$createElement('div', options, this.getContentSlot())\n },\n getTiles () {\n if (!this.$refs.content) return\n\n this.tiles = Array.from(this.$refs.content.querySelectorAll('.v-list-item'))\n },\n mouseEnterHandler () {\n this.runDelay('open', () => {\n if (this.hasJustFocused) return\n\n this.hasJustFocused = true\n this.isActive = true\n })\n },\n mouseLeaveHandler (e: MouseEvent) {\n // Prevent accidental re-activation\n this.runDelay('close', () => {\n if (this.$refs.content.contains(e.relatedTarget as HTMLElement)) return\n\n requestAnimationFrame(() => {\n this.isActive = false\n this.callDeactivate()\n })\n })\n },\n nextTile () {\n const tile = this.tiles[this.listIndex + 1]\n\n if (!tile) {\n if (!this.tiles.length) return\n\n this.listIndex = -1\n this.nextTile()\n\n return\n }\n\n this.listIndex++\n if (tile.tabIndex === -1) this.nextTile()\n },\n prevTile () {\n const tile = this.tiles[this.listIndex - 1]\n\n if (!tile) {\n if (!this.tiles.length) return\n\n this.listIndex = this.tiles.length\n this.prevTile()\n\n return\n }\n\n this.listIndex--\n if (tile.tabIndex === -1) this.prevTile()\n },\n onKeyDown (e: KeyboardEvent) {\n if (e.keyCode === keyCodes.esc) {\n // Wait for dependent elements to close first\n setTimeout(() => { this.isActive = false })\n const activator = this.getActivator()\n this.$nextTick(() => activator && activator.focus())\n } else if (\n !this.isActive &&\n [keyCodes.up, keyCodes.down].includes(e.keyCode)\n ) {\n this.isActive = true\n }\n\n // Allow for isActive watcher to generate tile list\n this.$nextTick(() => this.changeListIndex(e))\n },\n onResize () {\n if (!this.isActive) return\n\n // Account for screen resize\n // and orientation change\n // eslint-disable-next-line no-unused-expressions\n this.$refs.content.offsetWidth\n this.updateDimensions()\n\n // When resizing to a smaller width\n // content width is evaluated before\n // the new activator width has been\n // set, causing it to not size properly\n // hacky but will revisit in the future\n clearTimeout(this.resizeTimeout)\n this.resizeTimeout = window.setTimeout(this.updateDimensions, 100)\n },\n },\n\n render (h): VNode {\n const data = {\n staticClass: 'v-menu',\n class: {\n 'v-menu--attached':\n this.attach === '' ||\n this.attach === true ||\n this.attach === 'attach',\n },\n directives: [{\n arg: '500',\n name: 'resize',\n value: this.onResize,\n }],\n }\n\n return h('div', data, [\n !this.activator && this.genActivator(),\n this.showLazyContent(() => [\n this.$createElement(VThemeProvider, {\n props: {\n root: true,\n light: this.light,\n dark: this.dark,\n },\n }, [this.genTransition()]),\n ]),\n ])\n },\n})\n","import Vue from 'vue'\n\n/* @vue/component */\nexport default Vue.extend({\n name: 'returnable',\n\n props: {\n returnValue: null as any,\n },\n\n data: () => ({\n isActive: false,\n originalValue: null as any,\n }),\n\n watch: {\n isActive (val) {\n if (val) {\n this.originalValue = this.returnValue\n } else {\n this.$emit('update:return-value', this.originalValue)\n }\n },\n },\n\n methods: {\n save (value: any) {\n this.originalValue = value\n setTimeout(() => {\n this.isActive = false\n })\n },\n },\n})\n"],"sourceRoot":""}