{"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":["transform","el","opacity","value","isTouchEvent","e","calculate","offset","target","localX","localY","radius","scale","Math","centerX","centerY","x","y","ripples","show","container","document","animation","size","computed","window","String","performance","setTimeout","hide","diff","Number","delay","isRippleEnabled","rippleShow","element","rippleHide","updateRipple","enabled","binding","passive","removeListeners","directive","unbind","update","wasEnabled","Ripple","bind","inserted","modifiers","handler","options","observer","IntersectionObserver","entries","isIntersecting","Boolean","entry","init","observe","Intersect","closeConditional","isActive","elements","ClickOutside","onClick","app","handleGesture","wrapper","touchendY","dirRatio","minDistance","touchendX","touchstartX","touchstartY","touch","event","Object","createHandlers","touchmoveX","touchmoveY","offsetX","offsetY","left","right","up","down","start","move","end","touchstart","touchend","touchmove","handlers","vnode","eventName","Touch","callback","Resize","args","install","console","components","directives","Vue","registerComponents","component","beforeCreate","this","userPreset","framework","installed","preset","property","service","Service","includes","version","Scroll"],"mappings":"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","file":"js/chunk-vendors~85da75cb.d8a5fda7.js","sourcesContent":["// Styles\nimport './VRipple.sass'\n\nimport { VNode, VNodeDirective } from 'vue'\nimport { consoleWarn } from '../../util/console'\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: MouseEvent | TouchEvent): e is TouchEvent {\n return e.constructor.name === 'TouchEvent'\n}\n\nconst calculate = (e: MouseEvent | TouchEvent, el: HTMLElement, value: RippleOptions = {}) => {\n const offset = el.getBoundingClientRect()\n const target = isTouchEvent(e) ? e.touches[e.touches.length - 1] : e\n const localX = target.clientX - offset.left\n const localY = target.clientY - offset.top\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 (e: MouseEvent | TouchEvent, el: HTMLElement, value: RippleOptions = {}) {\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: MouseEvent | TouchEvent) {\n const value: RippleOptions = {}\n const element = e.currentTarget as HTMLElement\n if (!element || !element._ripple || element._ripple.touched) return\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\n if (element._ripple.class) {\n value.class = element._ripple.class\n }\n ripples.show(e, element, value)\n}\n\nfunction rippleHide (e: Event) {\n const element = e.currentTarget as HTMLElement | null\n if (!element) return\n\n window.setTimeout(() => {\n if (element._ripple) {\n element._ripple.touched = false\n }\n })\n ripples.hide(element)\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('touchcancel', rippleHide)\n\n el.addEventListener('mousedown', rippleShow)\n el.addEventListener('mouseup', rippleHide)\n el.addEventListener('mouseleave', rippleHide)\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('touchcancel', rippleHide)\n el.removeEventListener('mouseup', rippleHide)\n el.removeEventListener('mouseleave', rippleHide)\n el.removeEventListener('dragstart', rippleHide)\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 closeConditional?: (e: Event) => boolean\n include?: () => HTMLElement[]\n}\n\ninterface ClickOutsideDirective extends VNodeDirective {\n value?: (e: Event) => void\n args?: ClickOutsideBindingArgs\n}\n\nfunction closeConditional () {\n return false\n}\n\nfunction directive (e: PointerEvent, el: HTMLElement, binding: ClickOutsideDirective): void {\n // Args may not always be supplied\n binding.args = binding.args || {}\n\n // If no closeConditional was supplied assign a default\n const isActive = (binding.args.closeConditional || closeConditional)\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 // If click was triggered programmaticaly (domEl.click()) then\n // it shouldn't be treated as click-outside\n // Chrome/Firefox support isTrusted property\n // IE/Edge support pointerType property (empty if not triggered\n // by pointing device)\n if (('isTrusted' in e && !e.isTrusted) ||\n ('pointerType' in e && !e.pointerType)\n ) 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 = (binding.args.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) && binding.value && binding.value(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 '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 '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, options.ssrContext)\n this.$vuetify = Vue.observable(options.vuetify.framework)\n } else {\n this.$vuetify = (options.parent && options.parent.$vuetify) || this\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 public framework: Dictionary = {}\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 VNodeDirective {\n arg: string\n value: EventListenerOrEventListenerObject\n options?: boolean | AddEventListenerOptions\n}\n\nfunction inserted (el: HTMLElement, binding: ScrollVNodeDirective) {\n const callback = binding.value\n const options = binding.options || { passive: true }\n const target = binding.arg ? document.querySelector(binding.arg) : window\n if (!target) return\n\n target.addEventListener('scroll', callback, options)\n\n el._onScroll = {\n callback,\n options,\n target,\n }\n}\n\nfunction unbind (el: HTMLElement) {\n if (!el._onScroll) return\n\n const { callback, options, target } = el._onScroll\n\n target.removeEventListener('scroll', callback, options)\n delete el._onScroll\n}\n\nexport const Scroll = {\n inserted,\n unbind,\n} as DirectiveOptions\n\nexport default Scroll\n"],"sourceRoot":""}