{"version":3,"sources":["webpack:///../../../src/directives/ripple/index.ts","webpack:///../../../src/directives/intersect/index.ts","webpack:///../../../src/directives/click-outside/index.ts","webpack:///../../../src/directives/touch/index.ts","webpack:///../../../src/directives/resize/index.ts","webpack:///../src/install.ts","webpack:///../src/framework.ts","webpack:///../../../src/directives/scroll/index.ts"],"names":["rippleStop","Symbol","DELAY_RIPPLE","transform","el","opacity","value","isTouchEvent","e","isKeyboardEvent","calculate","localX","localY","offset","target","radius","scale","Math","centerX","centerY","x","y","ripples","container","document","animation","class","size","computed","window","String","performance","setTimeout","diff","Number","delay","isRippleEnabled","rippleShow","element","rippleHide","rippleCancelShow","keyboardRipple","keyboardRippleShow","keyboardRippleHide","focusRippleHide","updateRipple","enabled","binding","passive","removeListeners","directive","unbind","update","wasEnabled","Ripple","bind","inserted","modifiers","options","handler","observer","IntersectionObserver","entries","isIntersecting","Boolean","entry","init","observe","Intersect","defaultConditional","isActive","elements","ClickOutside","onClick","app","handleGesture","wrapper","touchendY","dirRatio","minDistance","touchendX","touchstartX","touchstartY","touchstart","touch","event","Object","touchend","touchmove","createHandlers","touchmoveX","touchmoveY","offsetX","offsetY","left","right","up","down","start","move","end","handlers","vnode","eventName","Touch","callback","Resize","args","install","console","components","directives","Vue","registerComponents","component","this","$options","vuetify","$el","hasAttribute","$vuetify","userPreset","framework","isHydrating","installed","preset","property","service","Service","includes","version","config","silent","self","undefined","Scroll"],"mappings":"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","file":"js/chunk-vendors~85da75cb.2a51a404.js","sourcesContent":["// Styles\nimport './VRipple.sass'\n\n// Utilities\nimport { consoleWarn } from '../../util/console'\nimport { keyCodes } from '../../util/helpers'\n\n// Types\nimport { VNode, VNodeDirective } from 'vue'\n\nconst rippleStop = Symbol('rippleStop')\n\ntype VuetifyRippleEvent = (MouseEvent | TouchEvent | KeyboardEvent) & { [rippleStop]?: boolean }\n\nconst DELAY_RIPPLE = 80\n\nfunction transform (el: HTMLElement, value: string) {\n el.style.transform = value\n el.style.webkitTransform = value\n}\n\nfunction opacity (el: HTMLElement, value: number) {\n el.style.opacity = value.toString()\n}\n\nexport interface RippleOptions {\n class?: string\n center?: boolean\n circle?: boolean\n}\n\nfunction isTouchEvent (e: VuetifyRippleEvent): e is TouchEvent {\n return e.constructor.name === 'TouchEvent'\n}\n\nfunction isKeyboardEvent (e: VuetifyRippleEvent): e is KeyboardEvent {\n return e.constructor.name === 'KeyboardEvent'\n}\n\nconst calculate = (\n e: VuetifyRippleEvent,\n el: HTMLElement,\n value: RippleOptions = {}\n) => {\n let localX = 0\n let localY = 0\n\n if (!isKeyboardEvent(e)) {\n const offset = el.getBoundingClientRect()\n const target = isTouchEvent(e) ? e.touches[e.touches.length - 1] : e\n\n localX = target.clientX - offset.left\n localY = target.clientY - offset.top\n }\n\n let radius = 0\n let scale = 0.3\n if (el._ripple && el._ripple.circle) {\n scale = 0.15\n radius = el.clientWidth / 2\n radius = value.center ? radius : radius + Math.sqrt((localX - radius) ** 2 + (localY - radius) ** 2) / 4\n } else {\n radius = Math.sqrt(el.clientWidth ** 2 + el.clientHeight ** 2) / 2\n }\n\n const centerX = `${(el.clientWidth - (radius * 2)) / 2}px`\n const centerY = `${(el.clientHeight - (radius * 2)) / 2}px`\n\n const x = value.center ? centerX : `${localX - radius}px`\n const y = value.center ? centerY : `${localY - radius}px`\n\n return { radius, scale, x, y, centerX, centerY }\n}\n\nconst ripples = {\n /* eslint-disable max-statements */\n show (\n e: VuetifyRippleEvent,\n el: HTMLElement,\n value: RippleOptions = {}\n ) {\n if (!el._ripple || !el._ripple.enabled) {\n return\n }\n\n const container = document.createElement('span')\n const animation = document.createElement('span')\n\n container.appendChild(animation)\n container.className = 'v-ripple__container'\n\n if (value.class) {\n container.className += ` ${value.class}`\n }\n\n const { radius, scale, x, y, centerX, centerY } = calculate(e, el, value)\n\n const size = `${radius * 2}px`\n animation.className = 'v-ripple__animation'\n animation.style.width = size\n animation.style.height = size\n\n el.appendChild(container)\n\n const computed = window.getComputedStyle(el)\n if (computed && computed.position === 'static') {\n el.style.position = 'relative'\n el.dataset.previousPosition = 'static'\n }\n\n animation.classList.add('v-ripple__animation--enter')\n animation.classList.add('v-ripple__animation--visible')\n transform(animation, `translate(${x}, ${y}) scale3d(${scale},${scale},${scale})`)\n opacity(animation, 0)\n animation.dataset.activated = String(performance.now())\n\n setTimeout(() => {\n animation.classList.remove('v-ripple__animation--enter')\n animation.classList.add('v-ripple__animation--in')\n transform(animation, `translate(${centerX}, ${centerY}) scale3d(1,1,1)`)\n opacity(animation, 0.25)\n }, 0)\n },\n\n hide (el: HTMLElement | null) {\n if (!el || !el._ripple || !el._ripple.enabled) return\n\n const ripples = el.getElementsByClassName('v-ripple__animation')\n\n if (ripples.length === 0) return\n const animation = ripples[ripples.length - 1]\n\n if (animation.dataset.isHiding) return\n else animation.dataset.isHiding = 'true'\n\n const diff = performance.now() - Number(animation.dataset.activated)\n const delay = Math.max(250 - diff, 0)\n\n setTimeout(() => {\n animation.classList.remove('v-ripple__animation--in')\n animation.classList.add('v-ripple__animation--out')\n opacity(animation, 0)\n\n setTimeout(() => {\n const ripples = el.getElementsByClassName('v-ripple__animation')\n if (ripples.length === 1 && el.dataset.previousPosition) {\n el.style.position = el.dataset.previousPosition\n delete el.dataset.previousPosition\n }\n\n animation.parentNode && el.removeChild(animation.parentNode)\n }, 300)\n }, delay)\n },\n}\n\nfunction isRippleEnabled (value: any): value is true {\n return typeof value === 'undefined' || !!value\n}\n\nfunction rippleShow (e: VuetifyRippleEvent) {\n const value: RippleOptions = {}\n const element = e.currentTarget as HTMLElement\n\n if (!element || !element._ripple || element._ripple.touched || e[rippleStop]) return\n\n // Don't allow the event to trigger ripples on any other elements\n e[rippleStop] = true\n\n if (isTouchEvent(e)) {\n element._ripple.touched = true\n element._ripple.isTouch = true\n } else {\n // It's possible for touch events to fire\n // as mouse events on Android/iOS, this\n // will skip the event call if it has\n // already been registered as touch\n if (element._ripple.isTouch) return\n }\n value.center = element._ripple.centered || isKeyboardEvent(e)\n if (element._ripple.class) {\n value.class = element._ripple.class\n }\n\n if (isTouchEvent(e)) {\n // already queued that shows or hides the ripple\n if (element._ripple.showTimerCommit) return\n\n element._ripple.showTimerCommit = () => {\n ripples.show(e, element, value)\n }\n element._ripple.showTimer = window.setTimeout(() => {\n if (element && element._ripple && element._ripple.showTimerCommit) {\n element._ripple.showTimerCommit()\n element._ripple.showTimerCommit = null\n }\n }, DELAY_RIPPLE)\n } else {\n ripples.show(e, element, value)\n }\n}\n\nfunction rippleHide (e: Event) {\n const element = e.currentTarget as HTMLElement | null\n if (!element || !element._ripple) return\n\n window.clearTimeout(element._ripple.showTimer)\n\n // The touch interaction occurs before the show timer is triggered.\n // We still want to show ripple effect.\n if (e.type === 'touchend' && element._ripple.showTimerCommit) {\n element._ripple.showTimerCommit()\n element._ripple.showTimerCommit = null\n\n // re-queue ripple hiding\n element._ripple.showTimer = setTimeout(() => {\n rippleHide(e)\n })\n return\n }\n\n window.setTimeout(() => {\n if (element._ripple) {\n element._ripple.touched = false\n }\n })\n ripples.hide(element)\n}\n\nfunction rippleCancelShow (e: MouseEvent | TouchEvent) {\n const element = e.currentTarget as HTMLElement | undefined\n\n if (!element || !element._ripple) return\n\n if (element._ripple.showTimerCommit) {\n element._ripple.showTimerCommit = null\n }\n\n window.clearTimeout(element._ripple.showTimer)\n}\n\nlet keyboardRipple = false\n\nfunction keyboardRippleShow (e: KeyboardEvent) {\n if (!keyboardRipple && (e.keyCode === keyCodes.enter || e.keyCode === keyCodes.space)) {\n keyboardRipple = true\n rippleShow(e)\n }\n}\n\nfunction keyboardRippleHide (e: KeyboardEvent) {\n keyboardRipple = false\n rippleHide(e)\n}\n\nfunction focusRippleHide (e: FocusEvent) {\n if (keyboardRipple === true) {\n keyboardRipple = false\n rippleHide(e)\n }\n}\n\nfunction updateRipple (el: HTMLElement, binding: VNodeDirective, wasEnabled: boolean) {\n const enabled = isRippleEnabled(binding.value)\n if (!enabled) {\n ripples.hide(el)\n }\n el._ripple = el._ripple || {}\n el._ripple.enabled = enabled\n const value = binding.value || {}\n if (value.center) {\n el._ripple.centered = true\n }\n if (value.class) {\n el._ripple.class = binding.value.class\n }\n if (value.circle) {\n el._ripple.circle = value.circle\n }\n if (enabled && !wasEnabled) {\n el.addEventListener('touchstart', rippleShow, { passive: true })\n el.addEventListener('touchend', rippleHide, { passive: true })\n el.addEventListener('touchmove', rippleCancelShow, { passive: true })\n el.addEventListener('touchcancel', rippleHide)\n\n el.addEventListener('mousedown', rippleShow)\n el.addEventListener('mouseup', rippleHide)\n el.addEventListener('mouseleave', rippleHide)\n\n el.addEventListener('keydown', keyboardRippleShow)\n el.addEventListener('keyup', keyboardRippleHide)\n\n el.addEventListener('blur', focusRippleHide)\n\n // Anchor tags can be dragged, causes other hides to fail - #1537\n el.addEventListener('dragstart', rippleHide, { passive: true })\n } else if (!enabled && wasEnabled) {\n removeListeners(el)\n }\n}\n\nfunction removeListeners (el: HTMLElement) {\n el.removeEventListener('mousedown', rippleShow)\n el.removeEventListener('touchstart', rippleShow)\n el.removeEventListener('touchend', rippleHide)\n el.removeEventListener('touchmove', rippleCancelShow)\n el.removeEventListener('touchcancel', rippleHide)\n el.removeEventListener('mouseup', rippleHide)\n el.removeEventListener('mouseleave', rippleHide)\n el.removeEventListener('keydown', keyboardRippleShow)\n el.removeEventListener('keyup', keyboardRippleHide)\n el.removeEventListener('dragstart', rippleHide)\n el.removeEventListener('blur', focusRippleHide)\n}\n\nfunction directive (el: HTMLElement, binding: VNodeDirective, node: VNode) {\n updateRipple(el, binding, false)\n\n if (process.env.NODE_ENV === 'development') {\n // warn if an inline element is used, waiting for el to be in the DOM first\n node.context && node.context.$nextTick(() => {\n const computed = window.getComputedStyle(el)\n if (computed && computed.display === 'inline') {\n const context = (node as any).fnOptions ? [(node as any).fnOptions, node.context] : [node.componentInstance]\n consoleWarn('v-ripple can only be used on block-level elements', ...context)\n }\n })\n }\n}\n\nfunction unbind (el: HTMLElement) {\n delete el._ripple\n removeListeners(el)\n}\n\nfunction update (el: HTMLElement, binding: VNodeDirective) {\n if (binding.value === binding.oldValue) {\n return\n }\n\n const wasEnabled = isRippleEnabled(binding.oldValue)\n updateRipple(el, binding, wasEnabled)\n}\n\nexport const Ripple = {\n bind: directive,\n unbind,\n update,\n}\n\nexport default Ripple\n","import { VNodeDirective } from 'vue/types/vnode'\n\ntype ObserveHandler = (\n entries: IntersectionObserverEntry[],\n observer: IntersectionObserver,\n isIntersecting: boolean,\n) => void\n\ninterface ObserveVNodeDirective extends Omit {\n value?: ObserveHandler | { handler: ObserveHandler, options?: IntersectionObserverInit }\n modifiers?: {\n once?: boolean\n quiet?: boolean\n }\n}\n\nfunction inserted (el: HTMLElement, binding: ObserveVNodeDirective) {\n const modifiers = binding.modifiers || {}\n const value = binding.value\n const { handler, options } = typeof value === 'object'\n ? value\n : { handler: value, options: {} }\n const observer = new IntersectionObserver((\n entries: IntersectionObserverEntry[] = [],\n observer: IntersectionObserver\n ) => {\n /* istanbul ignore if */\n if (!el._observe) return // Just in case, should never fire\n\n // If is not quiet or has already been\n // initted, invoke the user callback\n if (\n handler && (\n !modifiers.quiet ||\n el._observe.init\n )\n ) {\n const isIntersecting = Boolean(entries.find(entry => entry.isIntersecting))\n\n handler(entries, observer, isIntersecting)\n }\n\n // If has already been initted and\n // has the once modifier, unbind\n if (el._observe.init && modifiers.once) unbind(el)\n // Otherwise, mark the observer as initted\n else (el._observe.init = true)\n }, options)\n\n el._observe = { init: false, observer }\n\n observer.observe(el)\n}\n\nfunction unbind (el: HTMLElement) {\n /* istanbul ignore if */\n if (!el._observe) return\n\n el._observe.observer.unobserve(el)\n delete el._observe\n}\n\nexport const Intersect = {\n inserted,\n unbind,\n}\n\nexport default Intersect\n","import { VNodeDirective } from 'vue/types/vnode'\n\ninterface ClickOutsideBindingArgs {\n handler: (e: Event) => void\n closeConditional?: (e: Event) => boolean\n include?: () => HTMLElement[]\n}\n\ninterface ClickOutsideDirective extends VNodeDirective {\n value?: ((e: Event) => void) | ClickOutsideBindingArgs\n}\n\nfunction defaultConditional () {\n return true\n}\n\nfunction directive (e: PointerEvent, el: HTMLElement, binding: ClickOutsideDirective): void {\n const handler = typeof binding.value === 'function' ? binding.value : binding.value!.handler\n\n const isActive = (typeof binding.value === 'object' && binding.value.closeConditional) || defaultConditional\n\n // The include element callbacks below can be expensive\n // so we should avoid calling them when we're not active.\n // Explicitly check for false to allow fallback compatibility\n // with non-toggleable components\n if (!e || isActive(e) === false) return\n\n // Check if additional elements were passed to be included in check\n // (click must be outside all included elements, if any)\n const elements = ((typeof binding.value === 'object' && binding.value.include) || (() => []))()\n // Add the root element for the component this directive was defined on\n elements.push(el)\n\n // Check if it's a click outside our elements, and then if our callback returns true.\n // Non-toggleable components should take action in their callback and return falsy.\n // Toggleable can return true if it wants to deactivate.\n // Note that, because we're in the capture phase, this callback will occur before\n // the bubbling click event on any outside elements.\n !elements.some(el => el.contains(e.target as Node)) && setTimeout(() => {\n isActive(e) && handler && handler(e)\n }, 0)\n}\n\nexport const ClickOutside = {\n // [data-app] may not be found\n // if using bind, inserted makes\n // sure that the root element is\n // available, iOS does not support\n // clicks on body\n inserted (el: HTMLElement, binding: ClickOutsideDirective) {\n const onClick = (e: Event) => directive(e as PointerEvent, el, binding)\n // iOS does not recognize click events on document\n // or body, this is the entire purpose of the v-app\n // component and [data-app], stop removing this\n const app = document.querySelector('[data-app]') ||\n document.body // This is only for unit tests\n app.addEventListener('click', onClick, true)\n el._clickOutside = onClick\n },\n\n unbind (el: HTMLElement) {\n if (!el._clickOutside) return\n\n const app = document.querySelector('[data-app]') ||\n document.body // This is only for unit tests\n app && app.removeEventListener('click', el._clickOutside, true)\n delete el._clickOutside\n },\n}\n\nexport default ClickOutside\n","import { VNodeDirective, VNode } from 'vue/types/vnode'\nimport { keys } from '../../util/helpers'\nimport { TouchHandlers, TouchValue, TouchWrapper } from 'vuetify/types'\n\nexport interface TouchStoredHandlers {\n touchstart: (e: TouchEvent) => void\n touchend: (e: TouchEvent) => void\n touchmove: (e: TouchEvent) => void\n}\n\ninterface TouchVNodeDirective extends VNodeDirective {\n value?: TouchValue\n}\n\nconst handleGesture = (wrapper: TouchWrapper) => {\n const { touchstartX, touchendX, touchstartY, touchendY } = wrapper\n const dirRatio = 0.5\n const minDistance = 16\n wrapper.offsetX = touchendX - touchstartX\n wrapper.offsetY = touchendY - touchstartY\n\n if (Math.abs(wrapper.offsetY) < dirRatio * Math.abs(wrapper.offsetX)) {\n wrapper.left && (touchendX < touchstartX - minDistance) && wrapper.left(wrapper)\n wrapper.right && (touchendX > touchstartX + minDistance) && wrapper.right(wrapper)\n }\n\n if (Math.abs(wrapper.offsetX) < dirRatio * Math.abs(wrapper.offsetY)) {\n wrapper.up && (touchendY < touchstartY - minDistance) && wrapper.up(wrapper)\n wrapper.down && (touchendY > touchstartY + minDistance) && wrapper.down(wrapper)\n }\n}\n\nfunction touchstart (event: TouchEvent, wrapper: TouchWrapper) {\n const touch = event.changedTouches[0]\n wrapper.touchstartX = touch.clientX\n wrapper.touchstartY = touch.clientY\n\n wrapper.start &&\n wrapper.start(Object.assign(event, wrapper))\n}\n\nfunction touchend (event: TouchEvent, wrapper: TouchWrapper) {\n const touch = event.changedTouches[0]\n wrapper.touchendX = touch.clientX\n wrapper.touchendY = touch.clientY\n\n wrapper.end &&\n wrapper.end(Object.assign(event, wrapper))\n\n handleGesture(wrapper)\n}\n\nfunction touchmove (event: TouchEvent, wrapper: TouchWrapper) {\n const touch = event.changedTouches[0]\n wrapper.touchmoveX = touch.clientX\n wrapper.touchmoveY = touch.clientY\n\n wrapper.move && wrapper.move(Object.assign(event, wrapper))\n}\n\nfunction createHandlers (value: TouchHandlers): TouchStoredHandlers {\n const wrapper = {\n touchstartX: 0,\n touchstartY: 0,\n touchendX: 0,\n touchendY: 0,\n touchmoveX: 0,\n touchmoveY: 0,\n offsetX: 0,\n offsetY: 0,\n left: value.left,\n right: value.right,\n up: value.up,\n down: value.down,\n start: value.start,\n move: value.move,\n end: value.end,\n }\n\n return {\n touchstart: (e: TouchEvent) => touchstart(e, wrapper),\n touchend: (e: TouchEvent) => touchend(e, wrapper),\n touchmove: (e: TouchEvent) => touchmove(e, wrapper),\n }\n}\n\nfunction inserted (el: HTMLElement, binding: TouchVNodeDirective, vnode: VNode) {\n const value = binding.value!\n const target = value.parent ? el.parentElement : el\n const options = value.options || { passive: true }\n\n // Needed to pass unit tests\n if (!target) return\n\n const handlers = createHandlers(binding.value!)\n target._touchHandlers = Object(target._touchHandlers)\n target._touchHandlers![vnode.context!._uid] = handlers\n\n keys(handlers).forEach(eventName => {\n target.addEventListener(eventName, handlers[eventName] as EventListener, options)\n })\n}\n\nfunction unbind (el: HTMLElement, binding: TouchVNodeDirective, vnode: VNode) {\n const target = binding.value!.parent ? el.parentElement : el\n if (!target || !target._touchHandlers) return\n\n const handlers = target._touchHandlers[vnode.context!._uid]\n keys(handlers).forEach(eventName => {\n target.removeEventListener(eventName, handlers[eventName])\n })\n delete target._touchHandlers[vnode.context!._uid]\n}\n\nexport const Touch = {\n inserted,\n unbind,\n}\n\nexport default Touch\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","import OurVue, { VueConstructor } from 'vue'\nimport { VuetifyUseOptions } from 'vuetify/types'\nimport { consoleError } from './util/console'\n\nexport function install (Vue: VueConstructor, args: VuetifyUseOptions = {}) {\n if ((install as any).installed) return\n (install as any).installed = true\n\n if (OurVue !== Vue) {\n consoleError(`Multiple instances of Vue detected\nSee https://github.com/vuetifyjs/vuetify/issues/4068\n\nIf you're seeing \"$attrs is readonly\", it's caused by this`)\n }\n\n const components = args.components || {}\n const directives = args.directives || {}\n\n for (const name in directives) {\n const directive = directives[name]\n\n Vue.directive(name, directive)\n }\n\n (function registerComponents (components: any) {\n if (components) {\n for (const key in components) {\n const component = components[key]\n if (component && !registerComponents(component.$_vuetify_subcomponents)) {\n Vue.component(key, component as typeof Vue)\n }\n }\n return true\n }\n return false\n })(components)\n\n // Used to avoid multiple mixins being setup\n // when in dev mode and hot module reload\n // https://github.com/vuejs/vue/issues/5089#issuecomment-284260111\n if (Vue.$_vuetify_installed) return\n Vue.$_vuetify_installed = true\n\n Vue.mixin({\n beforeCreate () {\n const options = this.$options as any\n\n if (options.vuetify) {\n options.vuetify.init(this, this.$ssrContext)\n this.$vuetify = Vue.observable(options.vuetify.framework)\n } else {\n this.$vuetify = (options.parent && options.parent.$vuetify) || this\n }\n },\n beforeMount () {\n // @ts-ignore\n if (this.$options.vuetify && this.$el && this.$el.hasAttribute('data-server-rendered')) {\n // @ts-ignore\n this.$vuetify.isHydrating = true\n // @ts-ignore\n this.$vuetify.breakpoint.update(true)\n }\n },\n mounted () {\n // @ts-ignore\n if (this.$options.vuetify && this.$vuetify.isHydrating) {\n // @ts-ignore\n this.$vuetify.isHydrating = false\n // @ts-ignore\n this.$vuetify.breakpoint.update()\n }\n },\n })\n}\n","import { install } from './install'\n\n// Types\nimport Vue from 'vue'\nimport {\n UserVuetifyPreset,\n VuetifyPreset,\n} from 'vuetify/types/services/presets'\nimport {\n VuetifyService,\n VuetifyServiceContract,\n} from 'vuetify/types/services'\n\n// Services\nimport * as services from './services'\n\nexport default class Vuetify {\n static install = install\n\n static installed = false\n\n static version = __VUETIFY_VERSION__\n\n static config = {\n silent: false,\n }\n\n public framework: Dictionary = {\n isHydrating: false,\n } as any\n\n public installed: string[] = []\n\n public preset = {} as VuetifyPreset\n\n public userPreset: UserVuetifyPreset = {}\n\n constructor (userPreset: UserVuetifyPreset = {}) {\n this.userPreset = userPreset\n\n this.use(services.Presets)\n this.use(services.Application)\n this.use(services.Breakpoint)\n this.use(services.Goto)\n this.use(services.Icons)\n this.use(services.Lang)\n this.use(services.Theme)\n }\n\n // Called on the new vuetify instance\n // bootstrap in install beforeCreate\n // Exposes ssrContext if available\n init (root: Vue, ssrContext?: object) {\n this.installed.forEach(property => {\n const service = this.framework[property]\n\n service.framework = this.framework\n\n service.init(root, ssrContext)\n })\n\n // rtl is not installed and\n // will never be called by\n // the init process\n this.framework.rtl = Boolean(this.preset.rtl) as any\n }\n\n // Instantiate a VuetifyService\n use (Service: VuetifyService) {\n const property = Service.property\n\n if (this.installed.includes(property)) return\n\n // TODO maybe a specific type for arg 2?\n this.framework[property] = new Service(this.preset, this as any)\n this.installed.push(property)\n }\n}\n","import { VNodeDirective } from 'vue/types/vnode'\nimport { DirectiveOptions } from 'vue'\n\ninterface ScrollVNodeDirective extends Omit {\n value: EventListener | {\n handler: EventListener\n options?: boolean | AddEventListenerOptions\n } | EventListenerObject & { options?: boolean | AddEventListenerOptions }\n modifiers?: {\n self?: boolean\n }\n}\n\nfunction inserted (el: HTMLElement, binding: ScrollVNodeDirective) {\n const { self = false } = binding.modifiers || {}\n const value = binding.value\n const options = (typeof value === 'object' && value.options) || { passive: true }\n const handler = typeof value === 'function' || 'handleEvent' in value ? value : value.handler\n\n const target = self\n ? el\n : binding.arg\n ? document.querySelector(binding.arg)\n : window\n\n if (!target) return\n\n target.addEventListener('scroll', handler, options)\n\n el._onScroll = {\n handler,\n options,\n // Don't reference self\n target: self ? undefined : target,\n }\n}\n\nfunction unbind (el: HTMLElement) {\n if (!el._onScroll) return\n\n const { handler, options, target = el } = el._onScroll\n\n target.removeEventListener('scroll', handler, options)\n delete el._onScroll\n}\n\nexport const Scroll = {\n inserted,\n unbind,\n} as DirectiveOptions\n\nexport default Scroll\n"],"sourceRoot":""}