{"version":3,"sources":["webpack:///../../../src/components/VDialog/VDialog.ts","webpack:///../../../src/components/VOverlay/VOverlay.ts","webpack:///../../../src/components/VOverlay/index.ts","webpack:///../../../src/mixins/overlayable/index.ts"],"names":["baseMixins","mixins","Dependent","Detachable","Overlayable","Returnable","Stackable","Activatable","extend","name","directives","ClickOutside","props","dark","Boolean","disabled","fullscreen","light","maxWidth","String","Number","noClickAnimation","origin","type","default","persistent","retainFocus","scrollable","transition","width","data","activatedBy","animate","animateTimeout","stackMinZIndex","previousActiveElement","computed","classes","this","contentClass","trim","isActive","contentClasses","hasActivator","$slots","activator","$scopedSlots","watch","val","show","hideScroll","removeOverlay","unbind","_a","focus","showScroll","genOverlay","created","$attrs","hasOwnProperty","removed","beforeMount","$nextTick","isBooted","beforeDestroy","window","methods","animateClick","clearTimeout","setTimeout","closeConditional","e","target","_isDestroyed","$refs","content","contains","overlay","$el","activeZIndex","getMaxZIndex","document","documentElement","classList","add","options","call","hideOverlay","dialog","activeElement","_b","bind","addEventListener","onFocusin","removeEventListener","onClickOutside","$emit","onKeydown","keyCode","keyCodes","esc","getOpenDependents","length","getActivator","includes","getOpenDependentElements","some","el","focusable","querySelectorAll","find","hasAttribute","genContent","showLazyContent","$createElement","VThemeProvider","root","class","attrs","role","undefined","getScopeIdAttrs","on","keydown","style","zIndex","ref","genTransition","genInnerContent","appear","tabindex","value","handler","include","transformOrigin","convertToUnit","getContentSlot","render","h","staticClass","attach","genActivator","Colorable","Themeable","Toggleable","absolute","color","opacity","__scrim","setBackgroundColor","computedOpacity","themeClasses","styles","children","push","$listeners","VOverlay","Vue","overlayColor","overlayOpacity","animationFrame","createOverlay","propsData","$mount","parent","parentNode","querySelector","insertBefore","firstChild","requestAnimationFrame","getZIndex","addOnceEventListener","removeChild","$destroy","cancelAnimationFrame","scrollListener","tagName","isContentEditable","up","pageup","down","pagedown","deltaY","body","checkPath","preventDefault","hasScrollbar","nodeType","Node","ELEMENT_NODE","getComputedStyle","overflowY","scrollHeight","clientHeight","overflowX","scrollWidth","clientWidth","shouldScroll","dir","shiftKey","deltaX","delta","alreadyAtStart","alreadyAtEnd","scrollTop","scrollLeft","scrollingUp","scrollingDown","isInside","path","composedPath","selected","getSelection","anchorNode","index","$vuetify","breakpoint","smAndDown","addPassiveEventListener","passive","remove"],"mappings":"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","file":"js/chunk-4657f0a2.19caa4eb.js","sourcesContent":["// Styles\nimport './VDialog.sass'\n\n// Components\nimport { VThemeProvider } from '../VThemeProvider'\n\n// Mixins\nimport Activatable from '../../mixins/activatable'\nimport Dependent from '../../mixins/dependent'\nimport Detachable from '../../mixins/detachable'\nimport Overlayable from '../../mixins/overlayable'\nimport Returnable from '../../mixins/returnable'\nimport Stackable from '../../mixins/stackable'\n\n// Directives\nimport ClickOutside from '../../directives/click-outside'\n\n// Helpers\nimport mixins from '../../util/mixins'\nimport { removed } from '../../util/console'\nimport {\n convertToUnit,\n keyCodes,\n} from '../../util/helpers'\n\n// Types\nimport { VNode, VNodeData } from 'vue'\n\nconst baseMixins = mixins(\n Dependent,\n Detachable,\n Overlayable,\n Returnable,\n Stackable,\n Activatable,\n)\n\n/* @vue/component */\nexport default baseMixins.extend({\n name: 'v-dialog',\n\n directives: { ClickOutside },\n\n props: {\n dark: Boolean,\n disabled: Boolean,\n fullscreen: Boolean,\n light: Boolean,\n maxWidth: [String, Number],\n noClickAnimation: Boolean,\n origin: {\n type: String,\n default: 'center center',\n },\n persistent: Boolean,\n retainFocus: {\n type: Boolean,\n default: true,\n },\n scrollable: Boolean,\n transition: {\n type: [String, Boolean],\n default: 'dialog-transition',\n },\n width: [String, Number],\n },\n\n data () {\n return {\n activatedBy: null as EventTarget | null,\n animate: false,\n animateTimeout: -1,\n stackMinZIndex: 200,\n previousActiveElement: null as HTMLElement | null,\n }\n },\n\n computed: {\n classes (): object {\n return {\n [(`v-dialog ${this.contentClass}`).trim()]: true,\n 'v-dialog--active': this.isActive,\n 'v-dialog--persistent': this.persistent,\n 'v-dialog--fullscreen': this.fullscreen,\n 'v-dialog--scrollable': this.scrollable,\n 'v-dialog--animated': this.animate,\n }\n },\n contentClasses (): object {\n return {\n 'v-dialog__content': true,\n 'v-dialog__content--active': this.isActive,\n }\n },\n hasActivator (): boolean {\n return Boolean(\n !!this.$slots.activator ||\n !!this.$scopedSlots.activator\n )\n },\n },\n\n watch: {\n isActive (val) {\n if (val) {\n this.show()\n this.hideScroll()\n } else {\n this.removeOverlay()\n this.unbind()\n this.previousActiveElement?.focus()\n }\n },\n fullscreen (val) {\n if (!this.isActive) return\n\n if (val) {\n this.hideScroll()\n this.removeOverlay(false)\n } else {\n this.showScroll()\n this.genOverlay()\n }\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 beforeMount () {\n this.$nextTick(() => {\n this.isBooted = this.isActive\n this.isActive && this.show()\n })\n },\n\n beforeDestroy () {\n if (typeof window !== 'undefined') this.unbind()\n },\n\n methods: {\n animateClick () {\n this.animate = false\n // Needed for when clicking very fast\n // outside of the dialog\n this.$nextTick(() => {\n this.animate = true\n window.clearTimeout(this.animateTimeout)\n this.animateTimeout = window.setTimeout(() => (this.animate = false), 150)\n })\n },\n closeConditional (e: Event) {\n const target = e.target as HTMLElement\n // Ignore the click if the dialog is closed or destroyed,\n // if it was on an element inside the content,\n // if it was dragged onto the overlay (#6969),\n // or if this isn't the topmost dialog (#9907)\n return !(\n this._isDestroyed ||\n !this.isActive ||\n this.$refs.content.contains(target) ||\n (this.overlay && target && !this.overlay.$el.contains(target))\n ) && this.activeZIndex >= this.getMaxZIndex()\n },\n hideScroll () {\n if (this.fullscreen) {\n document.documentElement.classList.add('overflow-y-hidden')\n } else {\n Overlayable.options.methods.hideScroll.call(this)\n }\n },\n show () {\n !this.fullscreen && !this.hideOverlay && this.genOverlay()\n // Double nextTick to wait for lazy content to be generated\n this.$nextTick(() => {\n this.$nextTick(() => {\n if (!this.$refs.dialog?.contains(document.activeElement)) {\n this.previousActiveElement = document.activeElement as HTMLElement\n this.$refs.dialog?.focus()\n }\n this.bind()\n })\n })\n },\n bind () {\n window.addEventListener('focusin', this.onFocusin)\n },\n unbind () {\n window.removeEventListener('focusin', this.onFocusin)\n },\n onClickOutside (e: Event) {\n this.$emit('click:outside', e)\n\n if (this.persistent) {\n this.noClickAnimation || this.animateClick()\n } else {\n this.isActive = false\n }\n },\n onKeydown (e: KeyboardEvent) {\n if (e.keyCode === keyCodes.esc && !this.getOpenDependents().length) {\n if (!this.persistent) {\n this.isActive = false\n const activator = this.getActivator()\n this.$nextTick(() => activator && (activator as HTMLElement).focus())\n } else if (!this.noClickAnimation) {\n this.animateClick()\n }\n }\n this.$emit('keydown', e)\n },\n // On focus change, wrap focus to stay inside the dialog\n // https://github.com/vuetifyjs/vuetify/issues/6892\n onFocusin (e: Event) {\n if (!e || !this.retainFocus) return\n\n const target = e.target as HTMLElement\n\n if (\n !!target &&\n this.$refs.dialog &&\n // It isn't the document or the dialog body\n ![document, this.$refs.dialog].includes(target) &&\n // It isn't inside the dialog body\n !this.$refs.dialog.contains(target) &&\n // We're the topmost dialog\n this.activeZIndex >= this.getMaxZIndex() &&\n // It isn't inside a dependent element (like a menu)\n !this.getOpenDependentElements().some(el => el.contains(target))\n // So we must have focused something outside the dialog and its children\n ) {\n // Find and focus the first available element inside the dialog\n const focusable = this.$refs.dialog.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"])')\n const el = [...focusable].find(el => !el.hasAttribute('disabled')) as HTMLElement | undefined\n el && el.focus()\n }\n },\n genContent () {\n return this.showLazyContent(() => [\n this.$createElement(VThemeProvider, {\n props: {\n root: true,\n light: this.light,\n dark: this.dark,\n },\n }, [\n this.$createElement('div', {\n class: this.contentClasses,\n attrs: {\n role: 'dialog',\n 'aria-modal': this.hideOverlay ? undefined : 'true',\n ...this.getScopeIdAttrs(),\n },\n on: { keydown: this.onKeydown },\n style: { zIndex: this.activeZIndex },\n ref: 'content',\n }, [this.genTransition()]),\n ]),\n ])\n },\n genTransition () {\n const content = this.genInnerContent()\n\n if (!this.transition) return content\n\n return this.$createElement('transition', {\n props: {\n name: this.transition,\n origin: this.origin,\n appear: true,\n },\n }, [content])\n },\n genInnerContent () {\n const data: VNodeData = {\n class: this.classes,\n attrs: {\n tabindex: this.isActive ? 0 : undefined,\n },\n ref: 'dialog',\n directives: [\n {\n name: 'click-outside',\n value: {\n handler: this.onClickOutside,\n closeConditional: this.closeConditional,\n include: this.getOpenDependentElements,\n },\n },\n { name: 'show', value: this.isActive },\n ],\n style: {\n transformOrigin: this.origin,\n },\n }\n\n if (!this.fullscreen) {\n data.style = {\n ...data.style as object,\n maxWidth: convertToUnit(this.maxWidth),\n width: convertToUnit(this.width),\n }\n }\n\n return this.$createElement('div', data, this.getContentSlot())\n },\n },\n\n render (h): VNode {\n return h('div', {\n staticClass: 'v-dialog__container',\n class: {\n 'v-dialog__container--attached':\n this.attach === '' ||\n this.attach === true ||\n this.attach === 'attach',\n },\n }, [\n this.genActivator(),\n this.genContent(),\n ])\n },\n})\n","// Styles\nimport './VOverlay.sass'\n\n// Mixins\nimport Colorable from './../../mixins/colorable'\nimport Themeable from '../../mixins/themeable'\nimport Toggleable from './../../mixins/toggleable'\n\n// Utilities\nimport mixins from '../../util/mixins'\n\n// Types\nimport { VNode } from 'vue'\n\n/* @vue/component */\nexport default mixins(\n Colorable,\n Themeable,\n Toggleable\n).extend({\n name: 'v-overlay',\n\n props: {\n absolute: Boolean,\n color: {\n type: String,\n default: '#212121',\n },\n dark: {\n type: Boolean,\n default: true,\n },\n opacity: {\n type: [Number, String],\n default: 0.46,\n },\n value: {\n default: true,\n },\n zIndex: {\n type: [Number, String],\n default: 5,\n },\n },\n\n computed: {\n __scrim (): VNode {\n const data = this.setBackgroundColor(this.color, {\n staticClass: 'v-overlay__scrim',\n style: {\n opacity: this.computedOpacity,\n },\n })\n\n return this.$createElement('div', data)\n },\n classes (): object {\n return {\n 'v-overlay--absolute': this.absolute,\n 'v-overlay--active': this.isActive,\n ...this.themeClasses,\n }\n },\n computedOpacity (): number {\n return Number(this.isActive ? this.opacity : 0)\n },\n styles (): object {\n return {\n zIndex: this.zIndex,\n }\n },\n },\n\n methods: {\n genContent () {\n return this.$createElement('div', {\n staticClass: 'v-overlay__content',\n }, this.$slots.default)\n },\n },\n\n render (h): VNode {\n const children = [this.__scrim]\n\n if (this.isActive) children.push(this.genContent())\n\n return h('div', {\n staticClass: 'v-overlay',\n on: this.$listeners,\n class: this.classes,\n style: this.styles,\n }, children)\n },\n})\n","import VOverlay from './VOverlay'\n\nexport { VOverlay }\n\nexport default VOverlay\n","// Components\nimport VOverlay from '../../components/VOverlay'\n\n// Utilities\nimport {\n keyCodes,\n addOnceEventListener,\n addPassiveEventListener,\n getZIndex,\n composedPath,\n} from '../../util/helpers'\n\n// Types\nimport Vue from 'vue'\n\ninterface Toggleable extends Vue {\n isActive?: boolean\n}\n\ninterface Stackable extends Vue {\n activeZIndex: number\n}\n\ninterface options {\n absolute?: boolean\n $refs: {\n dialog?: HTMLElement\n content?: HTMLElement\n }\n}\n\n/* @vue/component */\nexport default Vue.extend().extend({\n name: 'overlayable',\n\n props: {\n hideOverlay: Boolean,\n overlayColor: String,\n overlayOpacity: [Number, String],\n },\n\n data () {\n return {\n animationFrame: 0,\n overlay: null as InstanceType | null,\n }\n },\n\n watch: {\n hideOverlay (value) {\n if (!this.isActive) return\n\n if (value) this.removeOverlay()\n else this.genOverlay()\n },\n },\n\n beforeDestroy () {\n this.removeOverlay()\n },\n\n methods: {\n createOverlay () {\n const overlay = new VOverlay({\n propsData: {\n absolute: this.absolute,\n value: false,\n color: this.overlayColor,\n opacity: this.overlayOpacity,\n },\n })\n\n overlay.$mount()\n\n const parent = this.absolute\n ? this.$el.parentNode\n : document.querySelector('[data-app]')\n\n parent && parent.insertBefore(overlay.$el, parent.firstChild)\n\n this.overlay = overlay\n },\n genOverlay () {\n this.hideScroll()\n\n if (this.hideOverlay) return\n\n if (!this.overlay) this.createOverlay()\n\n this.animationFrame = requestAnimationFrame(() => {\n if (!this.overlay) return\n\n if (this.activeZIndex !== undefined) {\n this.overlay.zIndex = String(this.activeZIndex - 1)\n } else if (this.$el) {\n this.overlay.zIndex = getZIndex(this.$el)\n }\n\n this.overlay.value = true\n })\n\n return true\n },\n /** removeOverlay(false) will not restore the scollbar afterwards */\n removeOverlay (showScroll = true) {\n if (this.overlay) {\n addOnceEventListener(this.overlay.$el, 'transitionend', () => {\n if (\n !this.overlay ||\n !this.overlay.$el ||\n !this.overlay.$el.parentNode ||\n this.overlay.value ||\n this.isActive\n ) return\n\n this.overlay.$el.parentNode.removeChild(this.overlay.$el)\n this.overlay.$destroy()\n this.overlay = null\n })\n\n // Cancel animation frame in case\n // overlay is removed before it\n // has finished its animation\n cancelAnimationFrame(this.animationFrame)\n\n this.overlay.value = false\n }\n\n showScroll && this.showScroll()\n },\n scrollListener (e: WheelEvent | KeyboardEvent) {\n if ('key' in e) {\n if (\n ['INPUT', 'TEXTAREA', 'SELECT'].includes((e.target as Element).tagName) ||\n // https://github.com/vuetifyjs/vuetify/issues/4715\n (e.target as HTMLElement).isContentEditable\n ) return\n\n const up = [keyCodes.up, keyCodes.pageup]\n const down = [keyCodes.down, keyCodes.pagedown]\n\n if (up.includes(e.keyCode)) {\n (e as any).deltaY = -1\n } else if (down.includes(e.keyCode)) {\n (e as any).deltaY = 1\n } else {\n return\n }\n }\n\n if (e.target === this.overlay ||\n (e.type !== 'keydown' && e.target === document.body) ||\n this.checkPath(e as WheelEvent)) e.preventDefault()\n },\n hasScrollbar (el?: Element) {\n if (!el || el.nodeType !== Node.ELEMENT_NODE) return false\n\n const style = window.getComputedStyle(el)\n return ((['auto', 'scroll'].includes(style.overflowY!) || el.tagName === 'SELECT') && el.scrollHeight > el.clientHeight) ||\n ((['auto', 'scroll'].includes(style.overflowX!)) && el.scrollWidth > el.clientWidth)\n },\n shouldScroll (el: Element, e: WheelEvent): boolean {\n if (el.hasAttribute('data-app')) return false\n\n const dir = e.shiftKey || e.deltaX ? 'x' : 'y'\n const delta = dir === 'y' ? e.deltaY : e.deltaX || e.deltaY\n\n let alreadyAtStart: boolean\n let alreadyAtEnd: boolean\n if (dir === 'y') {\n alreadyAtStart = el.scrollTop === 0\n alreadyAtEnd = el.scrollTop + el.clientHeight === el.scrollHeight\n } else {\n alreadyAtStart = el.scrollLeft === 0\n alreadyAtEnd = el.scrollLeft + el.clientWidth === el.scrollWidth\n }\n\n const scrollingUp = delta < 0\n const scrollingDown = delta > 0\n\n if (!alreadyAtStart && scrollingUp) return true\n if (!alreadyAtEnd && scrollingDown) return true\n if ((alreadyAtStart || alreadyAtEnd)) {\n return this.shouldScroll(el.parentNode as Element, e)\n }\n\n return false\n },\n isInside (el: Element, parent: Element): boolean {\n if (el === parent) {\n return true\n } else if (el === null || el === document.body) {\n return false\n } else {\n return this.isInside(el.parentNode as Element, parent)\n }\n },\n checkPath (e: WheelEvent) {\n const path = composedPath(e)\n\n if (e.type === 'keydown' && path[0] === document.body) {\n const dialog = this.$refs.dialog\n // getSelection returns null in firefox in some edge cases, can be ignored\n const selected = window.getSelection()!.anchorNode as Element\n if (dialog && this.hasScrollbar(dialog) && this.isInside(selected, dialog)) {\n return !this.shouldScroll(dialog, e)\n }\n return true\n }\n\n for (let index = 0; index < path.length; index++) {\n const el = path[index]\n\n if (el === document) return true\n if (el === document.documentElement) return true\n if (el === this.$refs.content) return true\n\n if (this.hasScrollbar(el as Element)) return !this.shouldScroll(el as Element, e)\n }\n\n return true\n },\n hideScroll () {\n if (this.$vuetify.breakpoint.smAndDown) {\n document.documentElement!.classList.add('overflow-y-hidden')\n } else {\n addPassiveEventListener(window, 'wheel', this.scrollListener, { passive: false })\n window.addEventListener('keydown', this.scrollListener)\n }\n },\n showScroll () {\n document.documentElement!.classList.remove('overflow-y-hidden')\n window.removeEventListener('wheel', this.scrollListener)\n window.removeEventListener('keydown', this.scrollListener)\n },\n },\n})\n"],"sourceRoot":""}