{"version":3,"sources":["webpack:///../../../ClientApp/src/components/VGrid/VFlex.ts?undefined","webpack:///../../../ClientApp/src/components/VList/VListItemAction.ts?undefined","webpack:///../../../ClientApp/src/components/VList/VListItemIcon.ts?undefined","webpack:///../../../ClientApp/src/components/VList/VListGroup.ts?undefined","webpack:///../../../ClientApp/src/components/VItemGroup/VItemGroup.ts?undefined","webpack:///../../../ClientApp/src/components/VList/VListItemGroup.ts?undefined","webpack:///../../../ClientApp/src/components/VList/index.ts?undefined","webpack:///./src/views/Privacy.vue?e272","webpack:///./ClientApp/src/views/Privacy.vue?undefined","webpack:///./src/views/Privacy.vue?55f2","webpack:///../../../ClientApp/src/components/VChip/VChip.ts?undefined","webpack:///../../../ClientApp/src/components/VChip/index.ts?undefined","webpack:///../../../ClientApp/src/mixins/menuable/index.ts?undefined","webpack:///../../../ClientApp/src/components/VMenu/VMenu.ts?undefined","webpack:///../../../ClientApp/src/components/VMenu/index.ts?undefined","webpack:///../../../ClientApp/src/components/VCheckbox/VSimpleCheckbox.ts?undefined","webpack:///../../../ClientApp/src/components/VSubheader/VSubheader.ts?undefined","webpack:///../../../ClientApp/src/components/VSubheader/index.ts?undefined","webpack:///../../../ClientApp/src/components/VSelect/VSelectList.ts?undefined","webpack:///../../../ClientApp/src/mixins/filterable/index.ts?undefined","webpack:///../../../ClientApp/src/components/VSelect/VSelect.ts?undefined","webpack:///./src/views/Privacy.vue?df4e","webpack:///../../../ClientApp/src/components/VAvatar/VAvatar.ts?undefined","webpack:///../../../ClientApp/src/components/VAvatar/index.ts?undefined","webpack:///../../../ClientApp/src/components/VList/VListItemAvatar.ts?undefined","webpack:///../../../ClientApp/src/components/VList/VList.ts?undefined","webpack:///../../../ClientApp/src/components/VDivider/index.ts?undefined","webpack:///./node_modules/core-js/modules/es.array.find-index.js?undefined","webpack:///../../../ClientApp/src/components/VList/VListItem.ts?undefined","webpack:///../../../ClientApp/src/directives/resize/index.ts?undefined"],"names":["name","functional","render","children","data","filteredChild","VNode","h","baseMixins","mixins","directives","ripple","props","activeClass","type","default","appendIcon","color","disabled","group","noAction","prependIcon","Boolean","subGroup","computed","classes","this","watch","isActive","list","listClick","$route","created","register","value","matchRoute","beforeDestroy","unregister","methods","click","genIcon","$createElement","VIcon","genAppendIcon","icon","$slots","VListItemIcon","staticClass","genHeader","VListItem","attrs","String","role","class","inputValue","on","genItems","showLazyContent","genPrependIcon","onRouteChange","to","toggle","_uid","isBooted","setTextColor","BaseItemGroup","mandatory","max","Number","multiple","internalLazyValue","undefined","items","themeClasses","selectedIndex","selectedItem","indexOf","selectedItems","filter","selectedValues","internalValue","Array","toggleMethod","v","console","genData","getValue","item","i","onClick","index","push","valueIndex","updateInternalValue","updateItem","updateItemsState","updateMultiple","updateSingle","updateMandatory","defaultValue","val","isSame","provide","itemGroup","isInGroup","listItemGroup","VListItemActionText","VListItemContent","VListItemTitle","VListItemSubtitle","VList","VListItemAction","VListItemAvatar","_vm","_h","_c","_self","_v","model","callback","$$v","expression","Page","staticRenderFns","backgroundColor","groups","title","fields","Headline","content","Paragraph","Image","Video","Button","action","Submit","label","Link","fileList","log","components","PageGenerator","FileDrop","active","chipGroup","close","closeIcon","draggable","filterIcon","link","outlined","pill","tag","textColor","proxyClass","groupClasses","hasClose","isClickable","breakingProps","original","replacement","genFilter","left","genClose","right","size","e","genContent","tabindex","setBackgroundColor","allowOverflow","light","dark","maxWidth","minWidth","nudgeBottom","nudgeLeft","nudgeRight","nudgeTop","nudgeWidth","offsetOverflow","openOnClick","positionX","positionY","zIndex","absoluteX","absoluteY","activatedBy","activatorFixed","dimensions","activator","top","bottom","width","height","offsetTop","scrollHeight","offsetLeft","hasJustFocused","hasWindow","inputActivator","isContentActive","pageWidth","pageYOffset","stackClass","stackMinZIndex","computedLeft","a","c","activatorLeft","attach","Math","isNaN","parseInt","computedTop","hasActivator","$scopedSlots","beforeMount","window","absolutePosition","activate","calcLeft","calcXOverflow","calcTop","calcYOverflow","xOverflow","documentHeight","toTop","contentHeight","totalHeight","isOverflowing","callActivate","callDeactivate","checkForPageYOffset","checkActivatorFixed","el","deactivate","genActivatorListeners","listeners","getInnerHeight","document","getOffsetLeft","getOffsetTop","getRoundedBoundedClientRect","rect","measure","style","sneakPeek","requestAnimationFrame","cb","startTransition","Promise","resolve","updateDimensions","isInMenu","theme","ClickOutside","Resize","auto","closeOnClick","closeOnContentClick","disableKeys","maxHeight","offsetX","offsetY","openOnHover","origin","transition","calculatedTopAuto","defaultOffset","listIndex","resizeTimeout","tiles","activeTile","calculatedLeft","menuWidth","parseFloat","calculatedMaxHeight","calculatedMaxWidth","calculatedMinWidth","calculatedTop","hasClickableTiles","find","tile","styles","transformOrigin","activeZIndex","next","prev","classList","remove","$attrs","hasOwnProperty","mounted","calcScrollPosition","$el","$refs","maxScrollTop","calcLeftAuto","calcTopAuto","tileDistanceFromMenuTop","firstTileOffsetTop","changeListIndex","closeConditional","target","contains","genActivatorAttributes","attributes","id","genTransition","genDirectives","handler","include","options","menuable__content__active","contentClass","ref","keydown","onKeyDown","getTiles","querySelectorAll","mouseEnterHandler","mouseLeaveHandler","nextTile","prevTile","setTimeout","onResize","clearTimeout","arg","root","indeterminate","indeterminateIcon","onIcon","offIcon","center","f","inset","$listeners","dense","hideSelected","itemDisabled","itemText","itemValue","noDataText","noFilter","searchInput","parsedItems","map","tileActiveClass","Object","staticNoDataTile","mousedown","genTileContent","genAction","input","genDivider","VDivider","genFilteredText","text","getMaskedCharacters","end","start","genHighlight","middle","genTile","hasItem","getDisabled","length","parent","scopedSlot","needsTile","innerHTML","getText","domProps","slot","itemsLength","defaultMenuProps","cacheItems","chips","clearable","deletableChips","disableLookup","eager","itemColor","menuProps","openOnClear","returnObject","smallChips","cachedItems","menuIsBooted","isMenuActive","lastItem","lazyValue","keyboardLookupPrefix","keyboardLookupLastTime","allItems","filterDuplicates","concat","computedItems","computedOwns","computedCounterValue","isFocused","dynamicHeight","hasChips","hasSlot","isDirty","listData","scopeId","$vnode","context","$vuetify","lang","t","select","selectItem","scopedSlots","staticList","VSelectList","virtualizedItems","$_menuProps","slice","menuCanShow","normalisedProps","split","acc","p","immediate","blur","activateMenu","clearableCallback","getContent","uniqueValues","arr","findExistingIndex","menu","genChipSelection","isDisabled","small","key","JSON","genCommaSelection","last","genDefaultSlot","selections","prefix","genAffix","suffix","VInput","mergeData","genInput","readonly","autocomplete","keypress","onKeyPress","genHiddenInput","attrs$","genInputSlot","genList","genListWithSlot","slots","slotName","genMenu","genSelections","genSelection","genSlotSelection","selection","selected","isInteractive","getMenuIndex","onBlur","$emit","onChipInput","setValue","isAppendInner","onEscDown","KEYBOARD_LOOKUP_THRESHOLD","now","performance","findIndex","isReadonly","keyCode","onUpDown","onTabDown","onSpaceDown","onMenuActiveChange","onMouseUp","hasMouseDown","onScroll","showMoreItems","scrollTop","setMenuIndex","setSelectedItems","values","oldValue","appendInner","component","VCol","VContainer","VRow","VSelect","roundedClasses","measurableStyles","horizontal","isInList","inject","isInNav","expand","flat","nav","rounded","subheader","threeLine","twoLine","g","splice","$","$findIndex","addToUnscopables","arrayMethodUsesToLength","FIND_INDEX","SKIPS_HOLES","USES_TO_LENGTH","proto","forced","callbackfn","arguments","Ripple","inheritAttrs","inactive","selectable","genAttrs","inserted","binding","passive","unbind"],"mappings":"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","file":"js/Core~Manage.96c2b1e5.js","sourcesContent":["import './_grid.sass'\n\nimport Grid from './grid'\n\nexport default Grid('flex')\n","// Types\nimport Vue, { VNode } from 'vue'\n\n/* @vue/component */\nexport default Vue.extend({\n name: 'v-list-item-action',\n\n functional: true,\n\n render (h, { data, children = [] }): VNode {\n data.staticClass = data.staticClass ? `v-list-item__action ${data.staticClass}` : 'v-list-item__action'\n const filteredChild = children.filter(VNode => {\n return VNode.isComment === false && VNode.text !== ' '\n })\n if (filteredChild.length > 1) data.staticClass += ' v-list-item__action--stack'\n\n return h('div', data, children)\n },\n})\n","// Types\nimport Vue, { VNode } from 'vue'\n\n/* @vue/component */\nexport default Vue.extend({\n name: 'v-list-item-icon',\n\n functional: true,\n\n render (h, { data, children }): VNode {\n data.staticClass = (`v-list-item__icon ${data.staticClass || ''}`).trim()\n\n return h('div', data, children)\n },\n})\n","// Styles\nimport './VListGroup.sass'\n\n// Components\nimport VIcon from '../VIcon'\nimport VList from './VList'\nimport VListItem from './VListItem'\nimport VListItemIcon from './VListItemIcon'\n\n// Mixins\nimport BindsAttrs from '../../mixins/binds-attrs'\nimport Bootable from '../../mixins/bootable'\nimport Colorable from '../../mixins/colorable'\nimport Toggleable from '../../mixins/toggleable'\nimport { inject as RegistrableInject } from '../../mixins/registrable'\n\n// Directives\nimport ripple from '../../directives/ripple'\n\n// Transitions\nimport { VExpandTransition } from '../transitions'\n\n// Utils\nimport mixins, { ExtractVue } from '../../util/mixins'\nimport { getSlot } from '../../util/helpers'\n\n// Types\nimport { VNode } from 'vue'\nimport { Route } from 'vue-router'\n\nconst baseMixins = mixins(\n BindsAttrs,\n Bootable,\n Colorable,\n RegistrableInject('list'),\n Toggleable\n)\n\ntype VListInstance = InstanceType\n\ninterface options extends ExtractVue {\n list: VListInstance\n $refs: {\n group: HTMLElement\n }\n $route: Route\n}\n\nexport default baseMixins.extend().extend({\n name: 'v-list-group',\n\n directives: { ripple },\n\n props: {\n activeClass: {\n type: String,\n default: '',\n },\n appendIcon: {\n type: String,\n default: '$expand',\n },\n color: {\n type: String,\n default: 'primary',\n },\n disabled: Boolean,\n group: String,\n noAction: Boolean,\n prependIcon: String,\n ripple: {\n type: [Boolean, Object],\n default: true,\n },\n subGroup: Boolean,\n },\n\n computed: {\n classes (): object {\n return {\n 'v-list-group--active': this.isActive,\n 'v-list-group--disabled': this.disabled,\n 'v-list-group--no-action': this.noAction,\n 'v-list-group--sub-group': this.subGroup,\n }\n },\n },\n\n watch: {\n isActive (val: boolean) {\n /* istanbul ignore else */\n if (!this.subGroup && val) {\n this.list && this.list.listClick(this._uid)\n }\n },\n $route: 'onRouteChange',\n },\n\n created () {\n this.list && this.list.register(this)\n\n if (this.group &&\n this.$route &&\n this.value == null\n ) {\n this.isActive = this.matchRoute(this.$route.path)\n }\n },\n\n beforeDestroy () {\n this.list && this.list.unregister(this)\n },\n\n methods: {\n click (e: Event) {\n if (this.disabled) return\n\n this.isBooted = true\n\n this.$emit('click', e)\n this.$nextTick(() => (this.isActive = !this.isActive))\n },\n genIcon (icon: string | false): VNode {\n return this.$createElement(VIcon, icon)\n },\n genAppendIcon (): VNode | null {\n const icon = !this.subGroup ? this.appendIcon : false\n\n if (!icon && !this.$slots.appendIcon) return null\n\n return this.$createElement(VListItemIcon, {\n staticClass: 'v-list-group__header__append-icon',\n }, [\n this.$slots.appendIcon || this.genIcon(icon),\n ])\n },\n genHeader (): VNode {\n return this.$createElement(VListItem, {\n staticClass: 'v-list-group__header',\n attrs: {\n 'aria-expanded': String(this.isActive),\n role: 'button',\n },\n class: {\n [this.activeClass]: this.isActive,\n },\n props: {\n inputValue: this.isActive,\n },\n directives: [{\n name: 'ripple',\n value: this.ripple,\n }],\n on: {\n ...this.listeners$,\n click: this.click,\n },\n }, [\n this.genPrependIcon(),\n this.$slots.activator,\n this.genAppendIcon(),\n ])\n },\n genItems (): VNode[] {\n return this.showLazyContent(() => [\n this.$createElement('div', {\n staticClass: 'v-list-group__items',\n directives: [{\n name: 'show',\n value: this.isActive,\n }],\n }, getSlot(this)),\n ])\n },\n genPrependIcon (): VNode | null {\n const icon = this.subGroup && this.prependIcon == null\n ? '$subgroup'\n : this.prependIcon\n\n if (!icon && !this.$slots.prependIcon) return null\n\n return this.$createElement(VListItemIcon, {\n staticClass: 'v-list-group__header__prepend-icon',\n }, [\n this.$slots.prependIcon || this.genIcon(icon),\n ])\n },\n onRouteChange (to: Route) {\n /* istanbul ignore if */\n if (!this.group) return\n\n const isActive = this.matchRoute(to.path)\n\n /* istanbul ignore else */\n if (isActive && this.isActive !== isActive) {\n this.list && this.list.listClick(this._uid)\n }\n\n this.isActive = isActive\n },\n toggle (uid: number) {\n const isActive = this._uid === uid\n\n if (isActive) this.isBooted = true\n this.$nextTick(() => (this.isActive = isActive))\n },\n matchRoute (to: string) {\n return to.match(this.group) !== null\n },\n },\n\n render (h): VNode {\n return h('div', this.setTextColor(this.isActive && this.color, {\n staticClass: 'v-list-group',\n class: this.classes,\n }), [\n this.genHeader(),\n h(VExpandTransition, this.genItems()),\n ])\n },\n})\n","// Styles\nimport './VItemGroup.sass'\n\n// Mixins\nimport Groupable from '../../mixins/groupable'\nimport Proxyable from '../../mixins/proxyable'\nimport Themeable from '../../mixins/themeable'\n\n// Utilities\nimport mixins from '../../util/mixins'\nimport { consoleWarn } from '../../util/console'\n\n// Types\nimport { VNode } from 'vue/types'\n\nexport type GroupableInstance = InstanceType & {\n id?: string\n to?: any\n value?: any\n }\n\nexport const BaseItemGroup = mixins(\n Proxyable,\n Themeable\n).extend({\n name: 'base-item-group',\n\n props: {\n activeClass: {\n type: String,\n default: 'v-item--active',\n },\n mandatory: Boolean,\n max: {\n type: [Number, String],\n default: null,\n },\n multiple: Boolean,\n },\n\n data () {\n return {\n // As long as a value is defined, show it\n // Otherwise, check if multiple\n // to determine which default to provide\n internalLazyValue: this.value !== undefined\n ? this.value\n : this.multiple ? [] : undefined,\n items: [] as GroupableInstance[],\n }\n },\n\n computed: {\n classes (): Record {\n return {\n 'v-item-group': true,\n ...this.themeClasses,\n }\n },\n selectedIndex (): number {\n return (this.selectedItem && this.items.indexOf(this.selectedItem)) || -1\n },\n selectedItem (): GroupableInstance | undefined {\n if (this.multiple) return undefined\n\n return this.selectedItems[0]\n },\n selectedItems (): GroupableInstance[] {\n return this.items.filter((item, index) => {\n return this.toggleMethod(this.getValue(item, index))\n })\n },\n selectedValues (): any[] {\n if (this.internalValue == null) return []\n\n return Array.isArray(this.internalValue)\n ? this.internalValue\n : [this.internalValue]\n },\n toggleMethod (): (v: any) => boolean {\n if (!this.multiple) {\n return (v: any) => this.internalValue === v\n }\n\n const internalValue = this.internalValue\n if (Array.isArray(internalValue)) {\n return (v: any) => internalValue.includes(v)\n }\n\n return () => false\n },\n },\n\n watch: {\n internalValue: 'updateItemsState',\n items: 'updateItemsState',\n },\n\n created () {\n if (this.multiple && !Array.isArray(this.internalValue)) {\n consoleWarn('Model must be bound to an array if the multiple property is true.', this)\n }\n },\n\n methods: {\n\n genData (): object {\n return {\n class: this.classes,\n }\n },\n getValue (item: GroupableInstance, i: number): unknown {\n return item.value == null || item.value === ''\n ? i\n : item.value\n },\n onClick (item: GroupableInstance) {\n this.updateInternalValue(\n this.getValue(item, this.items.indexOf(item))\n )\n },\n register (item: GroupableInstance) {\n const index = this.items.push(item) - 1\n\n item.$on('change', () => this.onClick(item))\n\n // If no value provided and mandatory,\n // assign first registered item\n if (this.mandatory && !this.selectedValues.length) {\n this.updateMandatory()\n }\n\n this.updateItem(item, index)\n },\n unregister (item: GroupableInstance) {\n if (this._isDestroyed) return\n\n const index = this.items.indexOf(item)\n const value = this.getValue(item, index)\n\n this.items.splice(index, 1)\n\n const valueIndex = this.selectedValues.indexOf(value)\n\n // Items is not selected, do nothing\n if (valueIndex < 0) return\n\n // If not mandatory, use regular update process\n if (!this.mandatory) {\n return this.updateInternalValue(value)\n }\n\n // Remove the value\n if (this.multiple && Array.isArray(this.internalValue)) {\n this.internalValue = this.internalValue.filter(v => v !== value)\n } else {\n this.internalValue = undefined\n }\n\n // If mandatory and we have no selection\n // add the last item as value\n /* istanbul ignore else */\n if (!this.selectedItems.length) {\n this.updateMandatory(true)\n }\n },\n updateItem (item: GroupableInstance, index: number) {\n const value = this.getValue(item, index)\n\n item.isActive = this.toggleMethod(value)\n },\n // https://github.com/vuetifyjs/vuetify/issues/5352\n updateItemsState () {\n this.$nextTick(() => {\n if (this.mandatory &&\n !this.selectedItems.length\n ) {\n return this.updateMandatory()\n }\n\n // TODO: Make this smarter so it\n // doesn't have to iterate every\n // child in an update\n this.items.forEach(this.updateItem)\n })\n },\n updateInternalValue (value: any) {\n this.multiple\n ? this.updateMultiple(value)\n : this.updateSingle(value)\n },\n updateMandatory (last?: boolean) {\n if (!this.items.length) return\n\n const items = this.items.slice()\n\n if (last) items.reverse()\n\n const item = items.find(item => !item.disabled)\n\n // If no tabs are available\n // aborts mandatory value\n if (!item) return\n\n const index = this.items.indexOf(item)\n\n this.updateInternalValue(\n this.getValue(item, index)\n )\n },\n updateMultiple (value: any) {\n const defaultValue = Array.isArray(this.internalValue)\n ? this.internalValue\n : []\n const internalValue = defaultValue.slice()\n const index = internalValue.findIndex(val => val === value)\n\n if (\n this.mandatory &&\n // Item already exists\n index > -1 &&\n // value would be reduced below min\n internalValue.length - 1 < 1\n ) return\n\n if (\n // Max is set\n this.max != null &&\n // Item doesn't exist\n index < 0 &&\n // value would be increased above max\n internalValue.length + 1 > this.max\n ) return\n\n index > -1\n ? internalValue.splice(index, 1)\n : internalValue.push(value)\n\n this.internalValue = internalValue\n },\n updateSingle (value: any) {\n const isSame = value === this.internalValue\n\n if (this.mandatory && isSame) return\n\n this.internalValue = isSame ? undefined : value\n },\n },\n\n render (h): VNode {\n return h('div', this.genData(), this.$slots.default)\n },\n})\n\nexport default BaseItemGroup.extend({\n name: 'v-item-group',\n\n provide (): object {\n return {\n itemGroup: this,\n }\n },\n})\n","// Styles\nimport './VListItemGroup.sass'\n\n// Extensions\nimport { BaseItemGroup } from '../VItemGroup/VItemGroup'\n\n// Mixins\nimport Colorable from '../../mixins/colorable'\n\n// Utilities\nimport mixins from '../../util/mixins'\n\nexport default mixins(\n BaseItemGroup,\n Colorable\n).extend({\n name: 'v-list-item-group',\n\n provide () {\n return {\n isInGroup: true,\n listItemGroup: this,\n }\n },\n\n computed: {\n classes (): object {\n return {\n ...BaseItemGroup.options.computed.classes.call(this),\n 'v-list-item-group': true,\n }\n },\n },\n\n methods: {\n genData (): object {\n return this.setTextColor(this.color, {\n ...BaseItemGroup.options.methods.genData.call(this),\n attrs: {\n role: 'listbox',\n },\n })\n },\n },\n})\n","import { createSimpleFunctional } from '../../util/helpers'\n\nimport VList from './VList'\nimport VListGroup from './VListGroup'\nimport VListItem from './VListItem'\nimport VListItemGroup from './VListItemGroup'\nimport VListItemAction from './VListItemAction'\nimport VListItemAvatar from './VListItemAvatar'\nimport VListItemIcon from './VListItemIcon'\n\nexport const VListItemActionText = createSimpleFunctional('v-list-item__action-text', 'span')\nexport const VListItemContent = createSimpleFunctional('v-list-item__content', 'div')\nexport const VListItemTitle = createSimpleFunctional('v-list-item__title', 'div')\nexport const VListItemSubtitle = createSimpleFunctional('v-list-item__subtitle', 'div')\n\nexport {\n VList,\n VListGroup,\n VListItem,\n VListItemAction,\n VListItemAvatar,\n VListItemIcon,\n VListItemGroup,\n}\n\nexport default {\n $_vuetify_subcomponents: {\n VList,\n VListGroup,\n VListItem,\n VListItemAction,\n VListItemActionText,\n VListItemAvatar,\n VListItemContent,\n VListItemGroup,\n VListItemIcon,\n VListItemSubtitle,\n VListItemTitle,\n },\n}\n","var render = function () {var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;return _c('v-container',[_c('v-row',[_c('v-col',[_c('h1',[_vm._v(\"You know, privacy...\")]),_c('v-select',{attrs:{\"items\":_vm.items,\"multiple\":\"\"},model:{value:(_vm.model),callback:function ($$v) {_vm.model=$$v},expression:\"model\"}})],1)],1),_c('v-row',[_c('v-col'),_c('v-col',[_c('PageGenerator',{attrs:{\"page\":_vm.Page}})],1),_c('v-col')],1)],1)}\nvar staticRenderFns = []\n\nexport { render, staticRenderFns }","\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\nimport FileDrop from \"@/components/FileDrop.vue\";\nimport { ButtonAction, PageScheme, StaticFieldType } from \"@/components/pageGenerator/models\";\nimport PageGenerator from \"@/components/pageGenerator/PageGenerator.vue\";\nimport { Component, Vue } from \"vue-property-decorator\";\n\n@Component({\n name : \"Privacy\",\n components: {\n PageGenerator,\n FileDrop\n }\n})\nexport default class Privacy extends Vue {\n private model = [];\n private Page: PageScheme = {\n backgroundColor: \"#ff00ff\",\n groups : [\n {\n title : \"Form Group Title\",\n fields: [\n {\n type : StaticFieldType.Headline,\n name : \"Headline\",\n content: \"Headline Field\"\n },\n {\n type : StaticFieldType.Paragraph,\n name : \"Paragraph\",\n content: \"Paragraph Field\"\n },\n {\n type : StaticFieldType.Image,\n name : \"Image\",\n content: \"https://picsum.photos/200/75\"\n },\n {\n type : StaticFieldType.Video,\n name : \"Video\",\n content: \"\"\n },\n {\n type : StaticFieldType.Button,\n name : \"SendButton\",\n action: ButtonAction.Submit,\n label : \"Submit\"\n },\n {\n type : StaticFieldType.Button,\n name : \"LinkButton\",\n action : ButtonAction.Link,\n label : \"www.a-blok.com\",\n content: \"http://a-blok.com\"\n }\n ]\n }\n ]\n };\n\n\n private items = [\"Foo\", \"Bar\", \"Fizz\", \"Buzz\"];\n\n handleFiles(fileList: FileList): void {\n for (const item of fileList) {\n console.log(item.name);\n }\n }\n}\n","import mod from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--14-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/ts-loader/index.js??ref--14-3!../../node_modules/vuetify-loader/lib/loader.js??ref--20-0!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Privacy.vue?vue&type=script&lang=ts&\"; export default mod; export * from \"-!../../node_modules/cache-loader/dist/cjs.js??ref--14-0!../../node_modules/thread-loader/dist/cjs.js!../../node_modules/babel-loader/lib/index.js!../../node_modules/ts-loader/index.js??ref--14-3!../../node_modules/vuetify-loader/lib/loader.js??ref--20-0!../../node_modules/cache-loader/dist/cjs.js??ref--0-0!../../node_modules/vue-loader/lib/index.js??vue-loader-options!./Privacy.vue?vue&type=script&lang=ts&\"","// 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","// Mixins\nimport Positionable from '../positionable'\nimport Stackable from '../stackable'\nimport Activatable from '../activatable'\n\n// Utilities\nimport mixins, { ExtractVue } from '../../util/mixins'\nimport { convertToUnit } from '../../util/helpers'\n\n// Types\nconst baseMixins = mixins(\n Stackable,\n Positionable,\n Activatable\n)\n\ninterface options extends ExtractVue {\n attach: boolean | string | Element\n offsetY: boolean\n offsetX: boolean\n $refs: {\n content: HTMLElement\n activator: HTMLElement\n }\n}\n\n/* @vue/component */\nexport default baseMixins.extend().extend({\n name: 'menuable',\n\n props: {\n allowOverflow: Boolean,\n light: Boolean,\n dark: Boolean,\n maxWidth: {\n type: [Number, String],\n default: 'auto',\n },\n minWidth: [Number, String],\n nudgeBottom: {\n type: [Number, String],\n default: 0,\n },\n nudgeLeft: {\n type: [Number, String],\n default: 0,\n },\n nudgeRight: {\n type: [Number, String],\n default: 0,\n },\n nudgeTop: {\n type: [Number, String],\n default: 0,\n },\n nudgeWidth: {\n type: [Number, String],\n default: 0,\n },\n offsetOverflow: Boolean,\n openOnClick: Boolean,\n positionX: {\n type: Number,\n default: null,\n },\n positionY: {\n type: Number,\n default: null,\n },\n zIndex: {\n type: [Number, String],\n default: null,\n },\n },\n\n data: () => ({\n absoluteX: 0,\n absoluteY: 0,\n activatedBy: null as EventTarget | null,\n activatorFixed: false,\n dimensions: {\n activator: {\n top: 0,\n left: 0,\n bottom: 0,\n right: 0,\n width: 0,\n height: 0,\n offsetTop: 0,\n scrollHeight: 0,\n offsetLeft: 0,\n },\n content: {\n top: 0,\n left: 0,\n bottom: 0,\n right: 0,\n width: 0,\n height: 0,\n offsetTop: 0,\n scrollHeight: 0,\n },\n },\n hasJustFocused: false,\n hasWindow: false,\n inputActivator: false,\n isContentActive: false,\n pageWidth: 0,\n pageYOffset: 0,\n stackClass: 'v-menu__content--active',\n stackMinZIndex: 6,\n }),\n\n computed: {\n computedLeft () {\n const a = this.dimensions.activator\n const c = this.dimensions.content\n const activatorLeft = (this.attach !== false ? a.offsetLeft : a.left) || 0\n const minWidth = Math.max(a.width, c.width)\n let left = 0\n left += this.left ? activatorLeft - (minWidth - a.width) : activatorLeft\n if (this.offsetX) {\n const maxWidth = isNaN(Number(this.maxWidth))\n ? a.width\n : Math.min(a.width, Number(this.maxWidth))\n\n left += this.left ? -maxWidth : a.width\n }\n if (this.nudgeLeft) left -= parseInt(this.nudgeLeft)\n if (this.nudgeRight) left += parseInt(this.nudgeRight)\n\n return left\n },\n computedTop () {\n const a = this.dimensions.activator\n const c = this.dimensions.content\n let top = 0\n\n if (this.top) top += a.height - c.height\n if (this.attach !== false) top += a.offsetTop\n else top += a.top + this.pageYOffset\n if (this.offsetY) top += this.top ? -a.height : a.height\n if (this.nudgeTop) top -= parseInt(this.nudgeTop)\n if (this.nudgeBottom) top += parseInt(this.nudgeBottom)\n\n return top\n },\n hasActivator (): boolean {\n return !!this.$slots.activator || !!this.$scopedSlots.activator || !!this.activator || !!this.inputActivator\n },\n },\n\n watch: {\n disabled (val) {\n val && this.callDeactivate()\n },\n isActive (val) {\n if (this.disabled) return\n\n val ? this.callActivate() : this.callDeactivate()\n },\n positionX: 'updateDimensions',\n positionY: 'updateDimensions',\n },\n\n beforeMount () {\n this.hasWindow = typeof window !== 'undefined'\n },\n\n methods: {\n absolutePosition () {\n return {\n offsetTop: 0,\n offsetLeft: 0,\n scrollHeight: 0,\n top: this.positionY || this.absoluteY,\n bottom: this.positionY || this.absoluteY,\n left: this.positionX || this.absoluteX,\n right: this.positionX || this.absoluteX,\n height: 0,\n width: 0,\n }\n },\n activate () {},\n calcLeft (menuWidth: number) {\n return convertToUnit(this.attach !== false\n ? this.computedLeft\n : this.calcXOverflow(this.computedLeft, menuWidth))\n },\n calcTop () {\n return convertToUnit(this.attach !== false\n ? this.computedTop\n : this.calcYOverflow(this.computedTop))\n },\n calcXOverflow (left: number, menuWidth: number) {\n const xOverflow = left + menuWidth - this.pageWidth + 12\n\n if ((!this.left || this.right) && xOverflow > 0) {\n left = Math.max(left - xOverflow, 0)\n } else {\n left = Math.max(left, 12)\n }\n\n return left + this.getOffsetLeft()\n },\n calcYOverflow (top: number) {\n const documentHeight = this.getInnerHeight()\n const toTop = this.pageYOffset + documentHeight\n const activator = this.dimensions.activator\n const contentHeight = this.dimensions.content.height\n const totalHeight = top + contentHeight\n const isOverflowing = toTop < totalHeight\n\n // If overflowing bottom and offset\n // TODO: set 'bottom' position instead of 'top'\n if (isOverflowing &&\n this.offsetOverflow &&\n // If we don't have enough room to offset\n // the overflow, don't offset\n activator.top > contentHeight\n ) {\n top = this.pageYOffset + (activator.top - contentHeight)\n // If overflowing bottom\n } else if (isOverflowing && !this.allowOverflow) {\n top = toTop - contentHeight - 12\n // If overflowing top\n } else if (top < this.pageYOffset && !this.allowOverflow) {\n top = this.pageYOffset + 12\n }\n\n return top < 12 ? 12 : top\n },\n callActivate () {\n if (!this.hasWindow) return\n\n this.activate()\n },\n callDeactivate () {\n this.isContentActive = false\n\n this.deactivate()\n },\n checkForPageYOffset () {\n if (this.hasWindow) {\n this.pageYOffset = this.activatorFixed ? 0 : this.getOffsetTop()\n }\n },\n checkActivatorFixed () {\n if (this.attach !== false) return\n let el = this.getActivator()\n while (el) {\n if (window.getComputedStyle(el).position === 'fixed') {\n this.activatorFixed = true\n return\n }\n el = el.offsetParent as HTMLElement\n }\n this.activatorFixed = false\n },\n deactivate () {},\n genActivatorListeners () {\n const listeners = Activatable.options.methods.genActivatorListeners.call(this)\n\n const onClick = listeners.click\n\n listeners.click = (e: MouseEvent & KeyboardEvent & FocusEvent) => {\n if (this.openOnClick) {\n onClick && onClick(e)\n }\n\n this.absoluteX = e.clientX\n this.absoluteY = e.clientY\n }\n\n return listeners\n },\n getInnerHeight () {\n if (!this.hasWindow) return 0\n\n return window.innerHeight ||\n document.documentElement.clientHeight\n },\n getOffsetLeft () {\n if (!this.hasWindow) return 0\n\n return window.pageXOffset ||\n document.documentElement.scrollLeft\n },\n getOffsetTop () {\n if (!this.hasWindow) return 0\n\n return window.pageYOffset ||\n document.documentElement.scrollTop\n },\n getRoundedBoundedClientRect (el: Element) {\n const rect = el.getBoundingClientRect()\n return {\n top: Math.round(rect.top),\n left: Math.round(rect.left),\n bottom: Math.round(rect.bottom),\n right: Math.round(rect.right),\n width: Math.round(rect.width),\n height: Math.round(rect.height),\n }\n },\n measure (el: HTMLElement) {\n if (!el || !this.hasWindow) return null\n\n const rect = this.getRoundedBoundedClientRect(el)\n\n // Account for activator margin\n if (this.attach !== false) {\n const style = window.getComputedStyle(el)\n\n rect.left = parseInt(style.marginLeft!)\n rect.top = parseInt(style.marginTop!)\n }\n\n return rect\n },\n sneakPeek (cb: () => void) {\n requestAnimationFrame(() => {\n const el = this.$refs.content\n\n if (!el || el.style.display !== 'none') {\n cb()\n return\n }\n\n el.style.display = 'inline-block'\n cb()\n el.style.display = 'none'\n })\n },\n startTransition () {\n return new Promise(resolve => requestAnimationFrame(() => {\n this.isContentActive = this.hasJustFocused = this.isActive\n resolve()\n }))\n },\n updateDimensions () {\n this.hasWindow = typeof window !== 'undefined'\n this.checkActivatorFixed()\n this.checkForPageYOffset()\n this.pageWidth = document.documentElement.clientWidth\n\n const dimensions: any = {\n activator: { ...this.dimensions.activator },\n content: { ...this.dimensions.content },\n }\n\n // Activator should already be shown\n if (!this.hasActivator || this.absolute) {\n dimensions.activator = this.absolutePosition()\n } else {\n const activator = this.getActivator()\n if (!activator) return\n\n dimensions.activator = this.measure(activator)\n dimensions.activator.offsetLeft = activator.offsetLeft\n if (this.attach !== false) {\n // account for css padding causing things to not line up\n // this is mostly for v-autocomplete, hopefully it won't break anything\n dimensions.activator.offsetTop = activator.offsetTop\n } else {\n dimensions.activator.offsetTop = 0\n }\n }\n\n // Display and hide to get dimensions\n this.sneakPeek(() => {\n this.$refs.content && (dimensions.content = this.measure(this.$refs.content))\n\n this.dimensions = dimensions\n })\n },\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.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 VMenu from './VMenu'\n\nexport { VMenu }\nexport default VMenu\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","// 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 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","import { render, staticRenderFns } from \"./Privacy.vue?vue&type=template&id=db7dd3ac&\"\nimport script from \"./Privacy.vue?vue&type=script&lang=ts&\"\nexport * from \"./Privacy.vue?vue&type=script&lang=ts&\"\n\n\n/* normalize component */\nimport normalizer from \"!../../node_modules/vue-loader/lib/runtime/componentNormalizer.js\"\nvar component = normalizer(\n script,\n render,\n staticRenderFns,\n false,\n null,\n null,\n null\n \n)\n\nexport default component.exports\n\n/* vuetify-loader */\nimport installComponents from \"!../../node_modules/vuetify-loader/lib/runtime/installComponents.js\"\nimport { VCol } from 'vuetify/lib/components/VGrid';\nimport { VContainer } from 'vuetify/lib/components/VGrid';\nimport { VRow } from 'vuetify/lib/components/VGrid';\nimport { VSelect } from 'vuetify/lib/components/VSelect';\ninstallComponents(component, {VCol,VContainer,VRow,VSelect})\n","import './VAvatar.sass'\n\n// Mixins\nimport Colorable from '../../mixins/colorable'\nimport Measurable from '../../mixins/measurable'\nimport Roundable from '../../mixins/roundable'\n\n// Utilities\nimport { convertToUnit } from '../../util/helpers'\n\n// Types\nimport { VNode } from 'vue'\nimport mixins from '../../util/mixins'\n\nexport default mixins(\n Colorable,\n Measurable,\n Roundable,\n /* @vue/component */\n).extend({\n name: 'v-avatar',\n\n props: {\n left: Boolean,\n right: Boolean,\n size: {\n type: [Number, String],\n default: 48,\n },\n },\n\n computed: {\n classes (): object {\n return {\n 'v-avatar--left': this.left,\n 'v-avatar--right': this.right,\n ...this.roundedClasses,\n }\n },\n styles (): object {\n return {\n height: convertToUnit(this.size),\n minWidth: convertToUnit(this.size),\n width: convertToUnit(this.size),\n ...this.measurableStyles,\n }\n },\n },\n\n render (h): VNode {\n const data = {\n staticClass: 'v-avatar',\n class: this.classes,\n style: this.styles,\n on: this.$listeners,\n }\n\n return h('div', this.setBackgroundColor(this.color, data), this.$slots.default)\n },\n})\n","import VAvatar from './VAvatar'\n\nexport { VAvatar }\nexport default VAvatar\n","// Components\nimport VAvatar from '../VAvatar'\n\n// Types\nimport { VNode } from 'vue'\n\n/* @vue/component */\nexport default VAvatar.extend({\n name: 'v-list-item-avatar',\n\n props: {\n horizontal: Boolean,\n size: {\n type: [Number, String],\n default: 40,\n },\n },\n\n computed: {\n classes (): object {\n return {\n 'v-list-item__avatar--horizontal': this.horizontal,\n ...VAvatar.options.computed.classes.call(this),\n 'v-avatar--tile': this.tile || this.horizontal,\n }\n },\n },\n\n render (h): VNode {\n const render = VAvatar.options.render.call(this, h)\n\n render.data = render.data || {}\n render.data.staticClass += ' v-list-item__avatar'\n\n return render\n },\n})\n","// Styles\nimport './VList.sass'\nimport VListGroup from './VListGroup'\n\n// Components\nimport VSheet from '../VSheet/VSheet'\n\n// Types\nimport { VNode } from 'vue'\n\ntype VListGroupInstance = InstanceType\n\ninterface options extends InstanceType {\n isInMenu: boolean\n isInNav: boolean\n}\n\n/* @vue/component */\nexport default VSheet.extend().extend({\n name: 'v-list',\n\n provide (): object {\n return {\n isInList: true,\n list: this,\n }\n },\n\n inject: {\n isInMenu: {\n default: false,\n },\n isInNav: {\n default: false,\n },\n },\n\n props: {\n dense: Boolean,\n disabled: Boolean,\n expand: Boolean,\n flat: Boolean,\n nav: Boolean,\n rounded: Boolean,\n subheader: Boolean,\n threeLine: Boolean,\n twoLine: Boolean,\n },\n\n data: () => ({\n groups: [] as VListGroupInstance[],\n }),\n\n computed: {\n classes (): object {\n return {\n ...VSheet.options.computed.classes.call(this),\n 'v-list--dense': this.dense,\n 'v-list--disabled': this.disabled,\n 'v-list--flat': this.flat,\n 'v-list--nav': this.nav,\n 'v-list--rounded': this.rounded,\n 'v-list--subheader': this.subheader,\n 'v-list--two-line': this.twoLine,\n 'v-list--three-line': this.threeLine,\n }\n },\n },\n\n methods: {\n register (content: VListGroupInstance) {\n this.groups.push(content)\n },\n unregister (content: VListGroupInstance) {\n const index = this.groups.findIndex(g => g._uid === content._uid)\n\n if (index > -1) this.groups.splice(index, 1)\n },\n listClick (uid: number) {\n if (this.expand) return\n\n for (const group of this.groups) {\n group.toggle(uid)\n }\n },\n },\n\n render (h): VNode {\n const data = {\n staticClass: 'v-list',\n class: this.classes,\n style: this.styles,\n attrs: {\n role: this.isInNav || this.isInMenu ? undefined : 'list',\n ...this.attrs$,\n },\n }\n\n return h(this.tag, this.setBackgroundColor(this.color, data), [this.$slots.default])\n },\n})\n","import VDivider from './VDivider'\n\nexport { VDivider }\nexport default VDivider\n","'use strict';\nvar $ = require('../internals/export');\nvar $findIndex = require('../internals/array-iteration').findIndex;\nvar addToUnscopables = require('../internals/add-to-unscopables');\nvar arrayMethodUsesToLength = require('../internals/array-method-uses-to-length');\n\nvar FIND_INDEX = 'findIndex';\nvar SKIPS_HOLES = true;\n\nvar USES_TO_LENGTH = arrayMethodUsesToLength(FIND_INDEX);\n\n// Shouldn't skip holes\nif (FIND_INDEX in []) Array(1)[FIND_INDEX](function () { SKIPS_HOLES = false; });\n\n// `Array.prototype.findIndex` method\n// https://tc39.github.io/ecma262/#sec-array.prototype.findindex\n$({ target: 'Array', proto: true, forced: SKIPS_HOLES || !USES_TO_LENGTH }, {\n findIndex: function findIndex(callbackfn /* , that = undefined */) {\n return $findIndex(this, callbackfn, arguments.length > 1 ? arguments[1] : undefined);\n }\n});\n\n// https://tc39.github.io/ecma262/#sec-array.prototype-@@unscopables\naddToUnscopables(FIND_INDEX);\n","// Styles\nimport './VListItem.sass'\n\n// Mixins\nimport Colorable from '../../mixins/colorable'\nimport Routable from '../../mixins/routable'\nimport { factory as GroupableFactory } from '../../mixins/groupable'\nimport Themeable from '../../mixins/themeable'\nimport { factory as ToggleableFactory } from '../../mixins/toggleable'\n\n// Directives\nimport Ripple from '../../directives/ripple'\n\n// Utilities\nimport { keyCodes } from './../../util/helpers'\nimport { ExtractVue } from './../../util/mixins'\nimport { removed } from '../../util/console'\n\n// Types\nimport mixins from '../../util/mixins'\nimport { VNode } from 'vue'\nimport { PropType, PropValidator } from 'vue/types/options'\n\nconst baseMixins = mixins(\n Colorable,\n Routable,\n Themeable,\n GroupableFactory('listItemGroup'),\n ToggleableFactory('inputValue')\n)\n\ninterface options extends ExtractVue {\n $el: HTMLElement\n isInGroup: boolean\n isInList: boolean\n isInMenu: boolean\n isInNav: boolean\n}\n\n/* @vue/component */\nexport default baseMixins.extend().extend({\n name: 'v-list-item',\n\n directives: {\n Ripple,\n },\n\n inheritAttrs: false,\n\n inject: {\n isInGroup: {\n default: false,\n },\n isInList: {\n default: false,\n },\n isInMenu: {\n default: false,\n },\n isInNav: {\n default: false,\n },\n },\n\n props: {\n activeClass: {\n type: String,\n default (): string | undefined {\n if (!this.listItemGroup) return ''\n\n return this.listItemGroup.activeClass\n },\n } as any as PropValidator,\n dense: Boolean,\n inactive: Boolean,\n link: Boolean,\n selectable: {\n type: Boolean,\n },\n tag: {\n type: String,\n default: 'div',\n },\n threeLine: Boolean,\n twoLine: Boolean,\n value: null as any as PropType,\n },\n\n data: () => ({\n proxyClass: 'v-list-item--active',\n }),\n\n computed: {\n classes (): object {\n return {\n 'v-list-item': true,\n ...Routable.options.computed.classes.call(this),\n 'v-list-item--dense': this.dense,\n 'v-list-item--disabled': this.disabled,\n 'v-list-item--link': this.isClickable && !this.inactive,\n 'v-list-item--selectable': this.selectable,\n 'v-list-item--three-line': this.threeLine,\n 'v-list-item--two-line': this.twoLine,\n ...this.themeClasses,\n }\n },\n isClickable (): boolean {\n return Boolean(\n Routable.options.computed.isClickable.call(this) ||\n this.listItemGroup\n )\n },\n },\n\n created () {\n /* istanbul ignore next */\n if (this.$attrs.hasOwnProperty('avatar')) {\n removed('avatar', this)\n }\n },\n\n methods: {\n click (e: MouseEvent | KeyboardEvent) {\n if (e.detail) this.$el.blur()\n\n this.$emit('click', e)\n\n this.to || this.toggle()\n },\n genAttrs () {\n const attrs: Record = {\n 'aria-disabled': this.disabled ? true : undefined,\n tabindex: this.isClickable && !this.disabled ? 0 : -1,\n ...this.$attrs,\n }\n\n if (this.$attrs.hasOwnProperty('role')) {\n // do nothing, role already provided\n } else if (this.isInNav) {\n // do nothing, role is inherit\n } else if (this.isInGroup) {\n attrs.role = 'listitem'\n attrs['aria-selected'] = String(this.isActive)\n } else if (this.isInMenu) {\n attrs.role = this.isClickable ? 'menuitem' : undefined\n attrs.id = attrs.id || `list-item-${this._uid}`\n } else if (this.isInList) {\n attrs.role = 'listitem'\n }\n\n return attrs\n },\n },\n\n render (h): VNode {\n let { tag, data } = this.generateRouteLink()\n\n data.attrs = {\n ...data.attrs,\n ...this.genAttrs(),\n }\n data[this.to ? 'nativeOn' : 'on'] = {\n ...data[this.to ? 'nativeOn' : 'on'],\n keydown: (e: KeyboardEvent) => {\n /* istanbul ignore else */\n if (e.keyCode === keyCodes.enter) this.click(e)\n\n this.$emit('keydown', e)\n },\n }\n\n if (this.inactive) tag = 'div'\n if (this.inactive && this.to) {\n data.on = data.nativeOn\n delete data.nativeOn\n }\n\n const children = this.$scopedSlots.default\n ? this.$scopedSlots.default({\n active: this.isActive,\n toggle: this.toggle,\n })\n : this.$slots.default\n\n return h(tag, this.setTextColor(this.color, data), children)\n },\n})\n","import { VNodeDirective } from 'vue/types/vnode'\n\ninterface ResizeVNodeDirective extends VNodeDirective {\n value?: () => void\n options?: boolean | AddEventListenerOptions\n}\n\nfunction inserted (el: HTMLElement, binding: ResizeVNodeDirective) {\n const callback = binding.value!\n const options = binding.options || { passive: true }\n\n window.addEventListener('resize', callback, options)\n el._onResize = {\n callback,\n options,\n }\n\n if (!binding.modifiers || !binding.modifiers.quiet) {\n callback()\n }\n}\n\nfunction unbind (el: HTMLElement) {\n if (!el._onResize) return\n\n const { callback, options } = el._onResize\n window.removeEventListener('resize', callback, options)\n delete el._onResize\n}\n\nexport const Resize = {\n inserted,\n unbind,\n}\n\nexport default Resize\n"],"sourceRoot":""}