{"version":3,"sources":["webpack:///../../../src/components/VMenu/index.ts","webpack:///../../../src/components/VChip/VChip.ts","webpack:///../../../src/components/VChip/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/comparable/index.ts","webpack:///../../../src/mixins/filterable/index.ts","webpack:///../../../src/components/VSelect/VSelect.ts","webpack:///./src/assets/logo.png"],"names":["mixins","name","props","active","type","default","activeClass","this","chipGroup","close","closeIcon","disabled","draggable","filter","filterIcon","label","link","outlined","pill","tag","textColor","value","data","proxyClass","computed","groupClasses","Boolean","breakingProps","original","$attrs","hasOwnProperty","replacement","methods","children","$createElement","VIcon","staticClass","left","right","size","on","click","e","$slots","hasClose","tabindex","setBackgroundColor","color","h","setTextColor","functional","directives","ripple","indeterminate","indeterminateIcon","onIcon","offIcon","listeners","center","icon","dark","light","classes","class","f","inset","themeClasses","attrs","$listeners","action","dense","hideSelected","items","itemDisabled","String","Array","itemText","itemValue","noDataText","noFilter","searchInput","selectedItems","map","item","getValue","Object","tile","role","undefined","mousedown","VListItem","genTileContent","VListItemAction","VSimpleCheckbox","inputValue","input","$emit","VDivider","text","end","getMaskedCharacters","start","genHighlight","middle","index","hasItem","getDisabled","id","_uid","$scopedSlots","length","genAction","parent","scopedSlot","needsTile","innerHTML","genFilteredText","getText","VList","domProps","parsedItems","indexOf","slot","itemsLength","genTile","genHeader","genDivider","valueComparator","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","filterDuplicates","concat","isFocused","handler","closeConditional","hasChips","scopeId","$vnode","context","computedOwns","$vuetify","lang","t","select","selectItem","scopedSlots","console","VSelectList","$_menuProps","computedItems","slice","menuCanShow","normalisedProps","split","acc","p","nudgeBottom","watch","window","getContent","onMenuActiveChange","immediate","$refs","contains","$el","uniqueValues","arr","val","internalValue","i","menu","isDisabled","VChip","small","onChipInput","key","JSON","last","selections","prefix","genAffix","suffix","VInput","mergeData","readonly","autocomplete","keypress","onKeyPress","attrs$","render","slots","slotName","listData","VMenu","ref","genSelection","selection","selected","isInteractive","setValue","isAppendInner","KEYBOARD_LOOKUP_THRESHOLD","now","performance","allItems","findIndex","Math","setTimeout","setMenuIndex","isReadonly","keyCode","activateMenu","onUpDown","onEscDown","onTabDown","onSpaceDown","getMenuIndex","hasMouseDown","showMoreItems","scrollHeight","scrollTop","requestAnimationFrame","activeTile","findExistingIndex","listIndex","values","v","oldValue","appendInner","module","exports"],"mappings":"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","file":"js/chunk-52ef62dc.7aa56acd.js","sourcesContent":["import VMenu from './VMenu'\n\nexport { VMenu }\nexport default VMenu\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,\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,\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","import VChip from './VChip'\n\nexport { VChip }\nexport default VChip\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 { mergeListeners } 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 ...data,\n class: classes,\n on: mergeListeners({\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 }, listeners),\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 { 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 as PropType,\n default: () => [],\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 noDataText: String,\n noFilter: Boolean,\n searchInput: null as unknown as PropType,\n selectedItems: {\n type: Array as PropType,\n default: () => [],\n },\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 `${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: '', 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, { PropType } from 'vue'\nimport { deepEqual } from '../../util/helpers'\n\nexport default Vue.extend({\n name: 'comparable',\n props: {\n valueComparator: {\n type: Function as PropType,\n default: deepEqual,\n },\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 { 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 {\n $refs: {\n menu: InstanceType\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 },\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 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 menuIsBooted () {\n window.setTimeout(() => {\n if (this.getContent() && this.getContent().addEventListener) {\n this.getContent().addEventListener('scroll', this.onScroll, false)\n }\n })\n },\n isMenuActive (val) {\n window.setTimeout(() => this.onMenuActiveChange(val))\n\n if (!val) return\n\n this.menuIsBooted = true\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 ()\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 },\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","module.exports = __webpack_public_path__ + \"img/logo.952e4681.png\";"],"sourceRoot":""}