12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796 |
- var VueDemi = (function (VueDemi, Vue, VueCompositionAPI) {
- if (VueDemi.install) {
- return VueDemi
- }
- if (!Vue) {
- console.error('[vue-demi] no Vue instance found, please be sure to import `vue` before `vue-demi`.')
- return VueDemi
- }
- // Vue 2.7
- if (Vue.version.slice(0, 4) === '2.7.') {
- for (var key in Vue) {
- VueDemi[key] = Vue[key]
- }
- VueDemi.isVue2 = true
- VueDemi.isVue3 = false
- VueDemi.install = function () {}
- VueDemi.Vue = Vue
- VueDemi.Vue2 = Vue
- VueDemi.version = Vue.version
- VueDemi.warn = Vue.util.warn
- function createApp(rootComponent, rootProps) {
- var vm
- var provide = {}
- var app = {
- config: Vue.config,
- use: Vue.use.bind(Vue),
- mixin: Vue.mixin.bind(Vue),
- component: Vue.component.bind(Vue),
- provide: function (key, value) {
- provide[key] = value
- return this
- },
- directive: function (name, dir) {
- if (dir) {
- Vue.directive(name, dir)
- return app
- } else {
- return Vue.directive(name)
- }
- },
- mount: function (el, hydrating) {
- if (!vm) {
- vm = new Vue(Object.assign({ propsData: rootProps }, rootComponent, { provide: Object.assign(provide, rootComponent.provide) }))
- vm.$mount(el, hydrating)
- return vm
- } else {
- return vm
- }
- },
- unmount: function () {
- if (vm) {
- vm.$destroy()
- vm = undefined
- }
- },
- }
- return app
- }
- VueDemi.createApp = createApp
- }
- // Vue 2.6.x
- else if (Vue.version.slice(0, 2) === '2.') {
- if (VueCompositionAPI) {
- for (var key in VueCompositionAPI) {
- VueDemi[key] = VueCompositionAPI[key]
- }
- VueDemi.isVue2 = true
- VueDemi.isVue3 = false
- VueDemi.install = function () {}
- VueDemi.Vue = Vue
- VueDemi.Vue2 = Vue
- VueDemi.version = Vue.version
- } else {
- console.error('[vue-demi] no VueCompositionAPI instance found, please be sure to import `@vue/composition-api` before `vue-demi`.')
- }
- }
- // Vue 3
- else if (Vue.version.slice(0, 2) === '3.') {
- for (var key in Vue) {
- VueDemi[key] = Vue[key]
- }
- VueDemi.isVue2 = false
- VueDemi.isVue3 = true
- VueDemi.install = function () {}
- VueDemi.Vue = Vue
- VueDemi.Vue2 = undefined
- VueDemi.version = Vue.version
- VueDemi.set = function (target, key, val) {
- if (Array.isArray(target)) {
- target.length = Math.max(target.length, key)
- target.splice(key, 1, val)
- return val
- }
- target[key] = val
- return val
- }
- VueDemi.del = function (target, key) {
- if (Array.isArray(target)) {
- target.splice(key, 1)
- return
- }
- delete target[key]
- }
- } else {
- console.error('[vue-demi] Vue version ' + Vue.version + ' is unsupported.')
- }
- return VueDemi
- })(
- (this.VueDemi = this.VueDemi || (typeof VueDemi !== 'undefined' ? VueDemi : {})),
- this.Vue || (typeof Vue !== 'undefined' ? Vue : undefined),
- this.VueCompositionAPI || (typeof VueCompositionAPI !== 'undefined' ? VueCompositionAPI : undefined)
- );
- ;
- ;(function (exports, vueDemi) {
- 'use strict';
- var __defProp$9 = Object.defineProperty;
- var __defProps$6 = Object.defineProperties;
- var __getOwnPropDescs$6 = Object.getOwnPropertyDescriptors;
- var __getOwnPropSymbols$b = Object.getOwnPropertySymbols;
- var __hasOwnProp$b = Object.prototype.hasOwnProperty;
- var __propIsEnum$b = Object.prototype.propertyIsEnumerable;
- var __defNormalProp$9 = (obj, key, value) => key in obj ? __defProp$9(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
- var __spreadValues$9 = (a, b) => {
- for (var prop in b || (b = {}))
- if (__hasOwnProp$b.call(b, prop))
- __defNormalProp$9(a, prop, b[prop]);
- if (__getOwnPropSymbols$b)
- for (var prop of __getOwnPropSymbols$b(b)) {
- if (__propIsEnum$b.call(b, prop))
- __defNormalProp$9(a, prop, b[prop]);
- }
- return a;
- };
- var __spreadProps$6 = (a, b) => __defProps$6(a, __getOwnPropDescs$6(b));
- function computedEager(fn, options) {
- var _a;
- const result = vueDemi.shallowRef();
- vueDemi.watchEffect(() => {
- result.value = fn();
- }, __spreadProps$6(__spreadValues$9({}, options), {
- flush: (_a = options == null ? void 0 : options.flush) != null ? _a : "sync"
- }));
- return vueDemi.readonly(result);
- }
- var _a;
- const isClient = typeof window !== "undefined";
- const isDef = (val) => typeof val !== "undefined";
- const assert = (condition, ...infos) => {
- if (!condition)
- console.warn(...infos);
- };
- const toString = Object.prototype.toString;
- const isBoolean = (val) => typeof val === "boolean";
- const isFunction = (val) => typeof val === "function";
- const isNumber = (val) => typeof val === "number";
- const isString = (val) => typeof val === "string";
- const isObject = (val) => toString.call(val) === "[object Object]";
- const isWindow = (val) => typeof window !== "undefined" && toString.call(val) === "[object Window]";
- const now = () => Date.now();
- const timestamp = () => +Date.now();
- const clamp = (n, min, max) => Math.min(max, Math.max(min, n));
- const noop = () => {
- };
- const rand = (min, max) => {
- min = Math.ceil(min);
- max = Math.floor(max);
- return Math.floor(Math.random() * (max - min + 1)) + min;
- };
- const isIOS = isClient && ((_a = window == null ? void 0 : window.navigator) == null ? void 0 : _a.userAgent) && /iP(ad|hone|od)/.test(window.navigator.userAgent);
- const hasOwn = (val, key) => Object.prototype.hasOwnProperty.call(val, key);
- function resolveUnref(r) {
- return typeof r === "function" ? r() : vueDemi.unref(r);
- }
- function createFilterWrapper(filter, fn) {
- function wrapper(...args) {
- return new Promise((resolve, reject) => {
- Promise.resolve(filter(() => fn.apply(this, args), { fn, thisArg: this, args })).then(resolve).catch(reject);
- });
- }
- return wrapper;
- }
- const bypassFilter = (invoke) => {
- return invoke();
- };
- function debounceFilter(ms, options = {}) {
- let timer;
- let maxTimer;
- let lastRejector = noop;
- const _clearTimeout = (timer2) => {
- clearTimeout(timer2);
- lastRejector();
- lastRejector = noop;
- };
- const filter = (invoke) => {
- const duration = resolveUnref(ms);
- const maxDuration = resolveUnref(options.maxWait);
- if (timer)
- _clearTimeout(timer);
- if (duration <= 0 || maxDuration !== void 0 && maxDuration <= 0) {
- if (maxTimer) {
- _clearTimeout(maxTimer);
- maxTimer = null;
- }
- return Promise.resolve(invoke());
- }
- return new Promise((resolve, reject) => {
- lastRejector = options.rejectOnCancel ? reject : resolve;
- if (maxDuration && !maxTimer) {
- maxTimer = setTimeout(() => {
- if (timer)
- _clearTimeout(timer);
- maxTimer = null;
- resolve(invoke());
- }, maxDuration);
- }
- timer = setTimeout(() => {
- if (maxTimer)
- _clearTimeout(maxTimer);
- maxTimer = null;
- resolve(invoke());
- }, duration);
- });
- };
- return filter;
- }
- function throttleFilter(ms, trailing = true, leading = true, rejectOnCancel = false) {
- let lastExec = 0;
- let timer;
- let isLeading = true;
- let lastRejector = noop;
- let lastValue;
- const clear = () => {
- if (timer) {
- clearTimeout(timer);
- timer = void 0;
- lastRejector();
- lastRejector = noop;
- }
- };
- const filter = (_invoke) => {
- const duration = resolveUnref(ms);
- const elapsed = Date.now() - lastExec;
- const invoke = () => {
- return lastValue = _invoke();
- };
- clear();
- if (duration <= 0) {
- lastExec = Date.now();
- return invoke();
- }
- if (elapsed > duration && (leading || !isLeading)) {
- lastExec = Date.now();
- invoke();
- } else if (trailing) {
- lastValue = new Promise((resolve, reject) => {
- lastRejector = rejectOnCancel ? reject : resolve;
- timer = setTimeout(() => {
- lastExec = Date.now();
- isLeading = true;
- resolve(invoke());
- clear();
- }, Math.max(0, duration - elapsed));
- });
- }
- if (!leading && !timer)
- timer = setTimeout(() => isLeading = true, duration);
- isLeading = false;
- return lastValue;
- };
- return filter;
- }
- function pausableFilter(extendFilter = bypassFilter) {
- const isActive = vueDemi.ref(true);
- function pause() {
- isActive.value = false;
- }
- function resume() {
- isActive.value = true;
- }
- const eventFilter = (...args) => {
- if (isActive.value)
- extendFilter(...args);
- };
- return { isActive: vueDemi.readonly(isActive), pause, resume, eventFilter };
- }
- function __onlyVue3(name = "this function") {
- if (vueDemi.isVue3)
- return;
- throw new Error(`[VueUse] ${name} is only works on Vue 3.`);
- }
- function __onlyVue27Plus(name = "this function") {
- if (vueDemi.isVue3 || vueDemi.version.startsWith("2.7."))
- return;
- throw new Error(`[VueUse] ${name} is only works on Vue 2.7 or above.`);
- }
- const directiveHooks = {
- mounted: vueDemi.isVue3 ? "mounted" : "inserted",
- updated: vueDemi.isVue3 ? "updated" : "componentUpdated",
- unmounted: vueDemi.isVue3 ? "unmounted" : "unbind"
- };
- function promiseTimeout(ms, throwOnTimeout = false, reason = "Timeout") {
- return new Promise((resolve, reject) => {
- if (throwOnTimeout)
- setTimeout(() => reject(reason), ms);
- else
- setTimeout(resolve, ms);
- });
- }
- function identity(arg) {
- return arg;
- }
- function createSingletonPromise(fn) {
- let _promise;
- function wrapper() {
- if (!_promise)
- _promise = fn();
- return _promise;
- }
- wrapper.reset = async () => {
- const _prev = _promise;
- _promise = void 0;
- if (_prev)
- await _prev;
- };
- return wrapper;
- }
- function invoke(fn) {
- return fn();
- }
- function containsProp(obj, ...props) {
- return props.some((k) => k in obj);
- }
- function increaseWithUnit(target, delta) {
- var _a;
- if (typeof target === "number")
- return target + delta;
- const value = ((_a = target.match(/^-?[0-9]+\.?[0-9]*/)) == null ? void 0 : _a[0]) || "";
- const unit = target.slice(value.length);
- const result = parseFloat(value) + delta;
- if (Number.isNaN(result))
- return target;
- return result + unit;
- }
- function objectPick(obj, keys, omitUndefined = false) {
- return keys.reduce((n, k) => {
- if (k in obj) {
- if (!omitUndefined || obj[k] !== void 0)
- n[k] = obj[k];
- }
- return n;
- }, {});
- }
- function computedWithControl(source, fn) {
- let v = void 0;
- let track;
- let trigger;
- const dirty = vueDemi.ref(true);
- const update = () => {
- dirty.value = true;
- trigger();
- };
- vueDemi.watch(source, update, { flush: "sync" });
- const get = isFunction(fn) ? fn : fn.get;
- const set = isFunction(fn) ? void 0 : fn.set;
- const result = vueDemi.customRef((_track, _trigger) => {
- track = _track;
- trigger = _trigger;
- return {
- get() {
- if (dirty.value) {
- v = get();
- dirty.value = false;
- }
- track();
- return v;
- },
- set(v2) {
- set == null ? void 0 : set(v2);
- }
- };
- });
- if (Object.isExtensible(result))
- result.trigger = update;
- return result;
- }
- function tryOnScopeDispose(fn) {
- if (vueDemi.getCurrentScope()) {
- vueDemi.onScopeDispose(fn);
- return true;
- }
- return false;
- }
- function createEventHook() {
- const fns = [];
- const off = (fn) => {
- const index = fns.indexOf(fn);
- if (index !== -1)
- fns.splice(index, 1);
- };
- const on = (fn) => {
- fns.push(fn);
- const offFn = () => off(fn);
- tryOnScopeDispose(offFn);
- return {
- off: offFn
- };
- };
- const trigger = (param) => {
- fns.forEach((fn) => fn(param));
- };
- return {
- on,
- off,
- trigger
- };
- }
- function createGlobalState(stateFactory) {
- let initialized = false;
- let state;
- const scope = vueDemi.effectScope(true);
- return () => {
- if (!initialized) {
- state = scope.run(stateFactory);
- initialized = true;
- }
- return state;
- };
- }
- function createInjectionState(composable) {
- const key = Symbol("InjectionState");
- const useProvidingState = (...args) => {
- const state = composable(...args);
- vueDemi.provide(key, state);
- return state;
- };
- const useInjectedState = () => vueDemi.inject(key);
- return [useProvidingState, useInjectedState];
- }
- function createSharedComposable(composable) {
- let subscribers = 0;
- let state;
- let scope;
- const dispose = () => {
- subscribers -= 1;
- if (scope && subscribers <= 0) {
- scope.stop();
- state = void 0;
- scope = void 0;
- }
- };
- return (...args) => {
- subscribers += 1;
- if (!state) {
- scope = vueDemi.effectScope(true);
- state = scope.run(() => composable(...args));
- }
- tryOnScopeDispose(dispose);
- return state;
- };
- }
- function extendRef(ref, extend, { enumerable = false, unwrap = true } = {}) {
- __onlyVue27Plus();
- for (const [key, value] of Object.entries(extend)) {
- if (key === "value")
- continue;
- if (vueDemi.isRef(value) && unwrap) {
- Object.defineProperty(ref, key, {
- get() {
- return value.value;
- },
- set(v) {
- value.value = v;
- },
- enumerable
- });
- } else {
- Object.defineProperty(ref, key, { value, enumerable });
- }
- }
- return ref;
- }
- function get(obj, key) {
- if (key == null)
- return vueDemi.unref(obj);
- return vueDemi.unref(obj)[key];
- }
- function isDefined(v) {
- return vueDemi.unref(v) != null;
- }
- var __defProp$8 = Object.defineProperty;
- var __getOwnPropSymbols$a = Object.getOwnPropertySymbols;
- var __hasOwnProp$a = Object.prototype.hasOwnProperty;
- var __propIsEnum$a = Object.prototype.propertyIsEnumerable;
- var __defNormalProp$8 = (obj, key, value) => key in obj ? __defProp$8(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
- var __spreadValues$8 = (a, b) => {
- for (var prop in b || (b = {}))
- if (__hasOwnProp$a.call(b, prop))
- __defNormalProp$8(a, prop, b[prop]);
- if (__getOwnPropSymbols$a)
- for (var prop of __getOwnPropSymbols$a(b)) {
- if (__propIsEnum$a.call(b, prop))
- __defNormalProp$8(a, prop, b[prop]);
- }
- return a;
- };
- function makeDestructurable(obj, arr) {
- if (typeof Symbol !== "undefined") {
- const clone = __spreadValues$8({}, obj);
- Object.defineProperty(clone, Symbol.iterator, {
- enumerable: false,
- value() {
- let index = 0;
- return {
- next: () => ({
- value: arr[index++],
- done: index > arr.length
- })
- };
- }
- });
- return clone;
- } else {
- return Object.assign([...arr], obj);
- }
- }
- function reactify(fn, options) {
- const unrefFn = (options == null ? void 0 : options.computedGetter) === false ? vueDemi.unref : resolveUnref;
- return function(...args) {
- return vueDemi.computed(() => fn.apply(this, args.map((i) => unrefFn(i))));
- };
- }
- function reactifyObject(obj, optionsOrKeys = {}) {
- let keys = [];
- let options;
- if (Array.isArray(optionsOrKeys)) {
- keys = optionsOrKeys;
- } else {
- options = optionsOrKeys;
- const { includeOwnProperties = true } = optionsOrKeys;
- keys.push(...Object.keys(obj));
- if (includeOwnProperties)
- keys.push(...Object.getOwnPropertyNames(obj));
- }
- return Object.fromEntries(keys.map((key) => {
- const value = obj[key];
- return [
- key,
- typeof value === "function" ? reactify(value.bind(obj), options) : value
- ];
- }));
- }
- function toReactive(objectRef) {
- if (!vueDemi.isRef(objectRef))
- return vueDemi.reactive(objectRef);
- const proxy = new Proxy({}, {
- get(_, p, receiver) {
- return vueDemi.unref(Reflect.get(objectRef.value, p, receiver));
- },
- set(_, p, value) {
- if (vueDemi.isRef(objectRef.value[p]) && !vueDemi.isRef(value))
- objectRef.value[p].value = value;
- else
- objectRef.value[p] = value;
- return true;
- },
- deleteProperty(_, p) {
- return Reflect.deleteProperty(objectRef.value, p);
- },
- has(_, p) {
- return Reflect.has(objectRef.value, p);
- },
- ownKeys() {
- return Object.keys(objectRef.value);
- },
- getOwnPropertyDescriptor() {
- return {
- enumerable: true,
- configurable: true
- };
- }
- });
- return vueDemi.reactive(proxy);
- }
- function reactiveComputed(fn) {
- return toReactive(vueDemi.computed(fn));
- }
- function reactiveOmit(obj, ...keys) {
- const flatKeys = keys.flat();
- return reactiveComputed(() => Object.fromEntries(Object.entries(vueDemi.toRefs(obj)).filter((e) => !flatKeys.includes(e[0]))));
- }
- function reactivePick(obj, ...keys) {
- const flatKeys = keys.flat();
- return vueDemi.reactive(Object.fromEntries(flatKeys.map((k) => [k, vueDemi.toRef(obj, k)])));
- }
- function refAutoReset(defaultValue, afterMs = 1e4) {
- return vueDemi.customRef((track, trigger) => {
- let value = defaultValue;
- let timer;
- const resetAfter = () => setTimeout(() => {
- value = defaultValue;
- trigger();
- }, resolveUnref(afterMs));
- tryOnScopeDispose(() => {
- clearTimeout(timer);
- });
- return {
- get() {
- track();
- return value;
- },
- set(newValue) {
- value = newValue;
- trigger();
- clearTimeout(timer);
- timer = resetAfter();
- }
- };
- });
- }
- function useDebounceFn(fn, ms = 200, options = {}) {
- return createFilterWrapper(debounceFilter(ms, options), fn);
- }
- function refDebounced(value, ms = 200, options = {}) {
- const debounced = vueDemi.ref(value.value);
- const updater = useDebounceFn(() => {
- debounced.value = value.value;
- }, ms, options);
- vueDemi.watch(value, () => updater());
- return debounced;
- }
- function refDefault(source, defaultValue) {
- return vueDemi.computed({
- get() {
- var _a;
- return (_a = source.value) != null ? _a : defaultValue;
- },
- set(value) {
- source.value = value;
- }
- });
- }
- function useThrottleFn(fn, ms = 200, trailing = false, leading = true, rejectOnCancel = false) {
- return createFilterWrapper(throttleFilter(ms, trailing, leading, rejectOnCancel), fn);
- }
- function refThrottled(value, delay = 200, trailing = true, leading = true) {
- if (delay <= 0)
- return value;
- const throttled = vueDemi.ref(value.value);
- const updater = useThrottleFn(() => {
- throttled.value = value.value;
- }, delay, trailing, leading);
- vueDemi.watch(value, () => updater());
- return throttled;
- }
- function refWithControl(initial, options = {}) {
- let source = initial;
- let track;
- let trigger;
- const ref = vueDemi.customRef((_track, _trigger) => {
- track = _track;
- trigger = _trigger;
- return {
- get() {
- return get();
- },
- set(v) {
- set(v);
- }
- };
- });
- function get(tracking = true) {
- if (tracking)
- track();
- return source;
- }
- function set(value, triggering = true) {
- var _a, _b;
- if (value === source)
- return;
- const old = source;
- if (((_a = options.onBeforeChange) == null ? void 0 : _a.call(options, value, old)) === false)
- return;
- source = value;
- (_b = options.onChanged) == null ? void 0 : _b.call(options, value, old);
- if (triggering)
- trigger();
- }
- const untrackedGet = () => get(false);
- const silentSet = (v) => set(v, false);
- const peek = () => get(false);
- const lay = (v) => set(v, false);
- return extendRef(ref, {
- get,
- set,
- untrackedGet,
- silentSet,
- peek,
- lay
- }, { enumerable: true });
- }
- const controlledRef = refWithControl;
- function resolveRef(r) {
- return typeof r === "function" ? vueDemi.computed(r) : vueDemi.ref(r);
- }
- function set(...args) {
- if (args.length === 2) {
- const [ref, value] = args;
- ref.value = value;
- }
- if (args.length === 3) {
- if (vueDemi.isVue2) {
- vueDemi.set(...args);
- } else {
- const [target, key, value] = args;
- target[key] = value;
- }
- }
- }
- function syncRef(left, right, options = {}) {
- var _a, _b;
- const {
- flush = "sync",
- deep = false,
- immediate = true,
- direction = "both",
- transform = {}
- } = options;
- let watchLeft;
- let watchRight;
- const transformLTR = (_a = transform.ltr) != null ? _a : (v) => v;
- const transformRTL = (_b = transform.rtl) != null ? _b : (v) => v;
- if (direction === "both" || direction === "ltr") {
- watchLeft = vueDemi.watch(left, (newValue) => right.value = transformLTR(newValue), { flush, deep, immediate });
- }
- if (direction === "both" || direction === "rtl") {
- watchRight = vueDemi.watch(right, (newValue) => left.value = transformRTL(newValue), { flush, deep, immediate });
- }
- return () => {
- watchLeft == null ? void 0 : watchLeft();
- watchRight == null ? void 0 : watchRight();
- };
- }
- function syncRefs(source, targets, options = {}) {
- const {
- flush = "sync",
- deep = false,
- immediate = true
- } = options;
- if (!Array.isArray(targets))
- targets = [targets];
- return vueDemi.watch(source, (newValue) => targets.forEach((target) => target.value = newValue), { flush, deep, immediate });
- }
- var __defProp$7 = Object.defineProperty;
- var __defProps$5 = Object.defineProperties;
- var __getOwnPropDescs$5 = Object.getOwnPropertyDescriptors;
- var __getOwnPropSymbols$9 = Object.getOwnPropertySymbols;
- var __hasOwnProp$9 = Object.prototype.hasOwnProperty;
- var __propIsEnum$9 = Object.prototype.propertyIsEnumerable;
- var __defNormalProp$7 = (obj, key, value) => key in obj ? __defProp$7(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
- var __spreadValues$7 = (a, b) => {
- for (var prop in b || (b = {}))
- if (__hasOwnProp$9.call(b, prop))
- __defNormalProp$7(a, prop, b[prop]);
- if (__getOwnPropSymbols$9)
- for (var prop of __getOwnPropSymbols$9(b)) {
- if (__propIsEnum$9.call(b, prop))
- __defNormalProp$7(a, prop, b[prop]);
- }
- return a;
- };
- var __spreadProps$5 = (a, b) => __defProps$5(a, __getOwnPropDescs$5(b));
- function toRefs(objectRef) {
- if (!vueDemi.isRef(objectRef))
- return vueDemi.toRefs(objectRef);
- const result = Array.isArray(objectRef.value) ? new Array(objectRef.value.length) : {};
- for (const key in objectRef.value) {
- result[key] = vueDemi.customRef(() => ({
- get() {
- return objectRef.value[key];
- },
- set(v) {
- if (Array.isArray(objectRef.value)) {
- const copy = [...objectRef.value];
- copy[key] = v;
- objectRef.value = copy;
- } else {
- const newObject = __spreadProps$5(__spreadValues$7({}, objectRef.value), { [key]: v });
- Object.setPrototypeOf(newObject, objectRef.value);
- objectRef.value = newObject;
- }
- }
- }));
- }
- return result;
- }
- function tryOnBeforeMount(fn, sync = true) {
- if (vueDemi.getCurrentInstance())
- vueDemi.onBeforeMount(fn);
- else if (sync)
- fn();
- else
- vueDemi.nextTick(fn);
- }
- function tryOnBeforeUnmount(fn) {
- if (vueDemi.getCurrentInstance())
- vueDemi.onBeforeUnmount(fn);
- }
- function tryOnMounted(fn, sync = true) {
- if (vueDemi.getCurrentInstance())
- vueDemi.onMounted(fn);
- else if (sync)
- fn();
- else
- vueDemi.nextTick(fn);
- }
- function tryOnUnmounted(fn) {
- if (vueDemi.getCurrentInstance())
- vueDemi.onUnmounted(fn);
- }
- function createUntil(r, isNot = false) {
- function toMatch(condition, { flush = "sync", deep = false, timeout, throwOnTimeout } = {}) {
- let stop = null;
- const watcher = new Promise((resolve) => {
- stop = vueDemi.watch(r, (v) => {
- if (condition(v) !== isNot) {
- stop == null ? void 0 : stop();
- resolve(v);
- }
- }, {
- flush,
- deep,
- immediate: true
- });
- });
- const promises = [watcher];
- if (timeout != null) {
- promises.push(promiseTimeout(timeout, throwOnTimeout).then(() => resolveUnref(r)).finally(() => stop == null ? void 0 : stop()));
- }
- return Promise.race(promises);
- }
- function toBe(value, options) {
- if (!vueDemi.isRef(value))
- return toMatch((v) => v === value, options);
- const { flush = "sync", deep = false, timeout, throwOnTimeout } = options != null ? options : {};
- let stop = null;
- const watcher = new Promise((resolve) => {
- stop = vueDemi.watch([r, value], ([v1, v2]) => {
- if (isNot !== (v1 === v2)) {
- stop == null ? void 0 : stop();
- resolve(v1);
- }
- }, {
- flush,
- deep,
- immediate: true
- });
- });
- const promises = [watcher];
- if (timeout != null) {
- promises.push(promiseTimeout(timeout, throwOnTimeout).then(() => resolveUnref(r)).finally(() => {
- stop == null ? void 0 : stop();
- return resolveUnref(r);
- }));
- }
- return Promise.race(promises);
- }
- function toBeTruthy(options) {
- return toMatch((v) => Boolean(v), options);
- }
- function toBeNull(options) {
- return toBe(null, options);
- }
- function toBeUndefined(options) {
- return toBe(void 0, options);
- }
- function toBeNaN(options) {
- return toMatch(Number.isNaN, options);
- }
- function toContains(value, options) {
- return toMatch((v) => {
- const array = Array.from(v);
- return array.includes(value) || array.includes(resolveUnref(value));
- }, options);
- }
- function changed(options) {
- return changedTimes(1, options);
- }
- function changedTimes(n = 1, options) {
- let count = -1;
- return toMatch(() => {
- count += 1;
- return count >= n;
- }, options);
- }
- if (Array.isArray(resolveUnref(r))) {
- const instance = {
- toMatch,
- toContains,
- changed,
- changedTimes,
- get not() {
- return createUntil(r, !isNot);
- }
- };
- return instance;
- } else {
- const instance = {
- toMatch,
- toBe,
- toBeTruthy,
- toBeNull,
- toBeNaN,
- toBeUndefined,
- changed,
- changedTimes,
- get not() {
- return createUntil(r, !isNot);
- }
- };
- return instance;
- }
- }
- function until(r) {
- return createUntil(r);
- }
- function useArrayEvery(list, fn) {
- return vueDemi.computed(() => resolveUnref(list).every((element, index, array) => fn(resolveUnref(element), index, array)));
- }
- function useArrayFilter(list, fn) {
- return vueDemi.computed(() => resolveUnref(list).map((i) => resolveUnref(i)).filter(fn));
- }
- function useArrayFind(list, fn) {
- return vueDemi.computed(() => resolveUnref(resolveUnref(list).find((element, index, array) => fn(resolveUnref(element), index, array))));
- }
- function useArrayFindIndex(list, fn) {
- return vueDemi.computed(() => resolveUnref(list).findIndex((element, index, array) => fn(resolveUnref(element), index, array)));
- }
- function findLast(arr, cb) {
- let index = arr.length;
- while (index-- > 0) {
- if (cb(arr[index], index, arr))
- return arr[index];
- }
- return void 0;
- }
- function useArrayFindLast(list, fn) {
- return vueDemi.computed(() => resolveUnref(!Array.prototype.findLast ? findLast(resolveUnref(list), (element, index, array) => fn(resolveUnref(element), index, array)) : resolveUnref(list).findLast((element, index, array) => fn(resolveUnref(element), index, array))));
- }
- function useArrayJoin(list, separator) {
- return vueDemi.computed(() => resolveUnref(list).map((i) => resolveUnref(i)).join(resolveUnref(separator)));
- }
- function useArrayMap(list, fn) {
- return vueDemi.computed(() => resolveUnref(list).map((i) => resolveUnref(i)).map(fn));
- }
- function useArrayReduce(list, reducer, ...args) {
- const reduceCallback = (sum, value, index) => reducer(resolveUnref(sum), resolveUnref(value), index);
- return vueDemi.computed(() => {
- const resolved = resolveUnref(list);
- return args.length ? resolved.reduce(reduceCallback, resolveUnref(args[0])) : resolved.reduce(reduceCallback);
- });
- }
- function useArraySome(list, fn) {
- return vueDemi.computed(() => resolveUnref(list).some((element, index, array) => fn(resolveUnref(element), index, array)));
- }
- function useArrayUnique(list) {
- return vueDemi.computed(() => [...new Set(resolveUnref(list).map((element) => resolveUnref(element)))]);
- }
- function useCounter(initialValue = 0, options = {}) {
- const count = vueDemi.ref(initialValue);
- const {
- max = Infinity,
- min = -Infinity
- } = options;
- const inc = (delta = 1) => count.value = Math.min(max, count.value + delta);
- const dec = (delta = 1) => count.value = Math.max(min, count.value - delta);
- const get = () => count.value;
- const set = (val) => count.value = Math.max(min, Math.min(max, val));
- const reset = (val = initialValue) => {
- initialValue = val;
- return set(val);
- };
- return { count, inc, dec, get, set, reset };
- }
- const REGEX_PARSE = /^(\d{4})[-/]?(\d{1,2})?[-/]?(\d{0,2})[Tt\s]*(\d{1,2})?:?(\d{1,2})?:?(\d{1,2})?[.:]?(\d+)?$/;
- const REGEX_FORMAT = /\[([^\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a{1,2}|A{1,2}|m{1,2}|s{1,2}|Z{1,2}|SSS/g;
- const defaultMeridiem = (hours, minutes, isLowercase, hasPeriod) => {
- let m = hours < 12 ? "AM" : "PM";
- if (hasPeriod)
- m = m.split("").reduce((acc, curr) => acc += `${curr}.`, "");
- return isLowercase ? m.toLowerCase() : m;
- };
- const formatDate = (date, formatStr, options = {}) => {
- var _a;
- const years = date.getFullYear();
- const month = date.getMonth();
- const days = date.getDate();
- const hours = date.getHours();
- const minutes = date.getMinutes();
- const seconds = date.getSeconds();
- const milliseconds = date.getMilliseconds();
- const day = date.getDay();
- const meridiem = (_a = options.customMeridiem) != null ? _a : defaultMeridiem;
- const matches = {
- YY: () => String(years).slice(-2),
- YYYY: () => years,
- M: () => month + 1,
- MM: () => `${month + 1}`.padStart(2, "0"),
- MMM: () => date.toLocaleDateString(options.locales, { month: "short" }),
- MMMM: () => date.toLocaleDateString(options.locales, { month: "long" }),
- D: () => String(days),
- DD: () => `${days}`.padStart(2, "0"),
- H: () => String(hours),
- HH: () => `${hours}`.padStart(2, "0"),
- h: () => `${hours % 12 || 12}`.padStart(1, "0"),
- hh: () => `${hours % 12 || 12}`.padStart(2, "0"),
- m: () => String(minutes),
- mm: () => `${minutes}`.padStart(2, "0"),
- s: () => String(seconds),
- ss: () => `${seconds}`.padStart(2, "0"),
- SSS: () => `${milliseconds}`.padStart(3, "0"),
- d: () => day,
- dd: () => date.toLocaleDateString(options.locales, { weekday: "narrow" }),
- ddd: () => date.toLocaleDateString(options.locales, { weekday: "short" }),
- dddd: () => date.toLocaleDateString(options.locales, { weekday: "long" }),
- A: () => meridiem(hours, minutes),
- AA: () => meridiem(hours, minutes, false, true),
- a: () => meridiem(hours, minutes, true),
- aa: () => meridiem(hours, minutes, true, true)
- };
- return formatStr.replace(REGEX_FORMAT, (match, $1) => $1 || matches[match]());
- };
- const normalizeDate = (date) => {
- if (date === null)
- return new Date(NaN);
- if (date === void 0)
- return new Date();
- if (date instanceof Date)
- return new Date(date);
- if (typeof date === "string" && !/Z$/i.test(date)) {
- const d = date.match(REGEX_PARSE);
- if (d) {
- const m = d[2] - 1 || 0;
- const ms = (d[7] || "0").substring(0, 3);
- return new Date(d[1], m, d[3] || 1, d[4] || 0, d[5] || 0, d[6] || 0, ms);
- }
- }
- return new Date(date);
- };
- function useDateFormat(date, formatStr = "HH:mm:ss", options = {}) {
- return vueDemi.computed(() => formatDate(normalizeDate(resolveUnref(date)), resolveUnref(formatStr), options));
- }
- function useIntervalFn(cb, interval = 1e3, options = {}) {
- const {
- immediate = true,
- immediateCallback = false
- } = options;
- let timer = null;
- const isActive = vueDemi.ref(false);
- function clean() {
- if (timer) {
- clearInterval(timer);
- timer = null;
- }
- }
- function pause() {
- isActive.value = false;
- clean();
- }
- function resume() {
- const intervalValue = resolveUnref(interval);
- if (intervalValue <= 0)
- return;
- isActive.value = true;
- if (immediateCallback)
- cb();
- clean();
- timer = setInterval(cb, intervalValue);
- }
- if (immediate && isClient)
- resume();
- if (vueDemi.isRef(interval) || isFunction(interval)) {
- const stopWatch = vueDemi.watch(interval, () => {
- if (isActive.value && isClient)
- resume();
- });
- tryOnScopeDispose(stopWatch);
- }
- tryOnScopeDispose(pause);
- return {
- isActive,
- pause,
- resume
- };
- }
- var __defProp$6 = Object.defineProperty;
- var __getOwnPropSymbols$8 = Object.getOwnPropertySymbols;
- var __hasOwnProp$8 = Object.prototype.hasOwnProperty;
- var __propIsEnum$8 = Object.prototype.propertyIsEnumerable;
- var __defNormalProp$6 = (obj, key, value) => key in obj ? __defProp$6(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
- var __spreadValues$6 = (a, b) => {
- for (var prop in b || (b = {}))
- if (__hasOwnProp$8.call(b, prop))
- __defNormalProp$6(a, prop, b[prop]);
- if (__getOwnPropSymbols$8)
- for (var prop of __getOwnPropSymbols$8(b)) {
- if (__propIsEnum$8.call(b, prop))
- __defNormalProp$6(a, prop, b[prop]);
- }
- return a;
- };
- function useInterval(interval = 1e3, options = {}) {
- const {
- controls: exposeControls = false,
- immediate = true,
- callback
- } = options;
- const counter = vueDemi.ref(0);
- const update = () => counter.value += 1;
- const reset = () => {
- counter.value = 0;
- };
- const controls = useIntervalFn(callback ? () => {
- update();
- callback(counter.value);
- } : update, interval, { immediate });
- if (exposeControls) {
- return __spreadValues$6({
- counter,
- reset
- }, controls);
- } else {
- return counter;
- }
- }
- function useLastChanged(source, options = {}) {
- var _a;
- const ms = vueDemi.ref((_a = options.initialValue) != null ? _a : null);
- vueDemi.watch(source, () => ms.value = timestamp(), options);
- return ms;
- }
- function useTimeoutFn(cb, interval, options = {}) {
- const {
- immediate = true
- } = options;
- const isPending = vueDemi.ref(false);
- let timer = null;
- function clear() {
- if (timer) {
- clearTimeout(timer);
- timer = null;
- }
- }
- function stop() {
- isPending.value = false;
- clear();
- }
- function start(...args) {
- clear();
- isPending.value = true;
- timer = setTimeout(() => {
- isPending.value = false;
- timer = null;
- cb(...args);
- }, resolveUnref(interval));
- }
- if (immediate) {
- isPending.value = true;
- if (isClient)
- start();
- }
- tryOnScopeDispose(stop);
- return {
- isPending: vueDemi.readonly(isPending),
- start,
- stop
- };
- }
- var __defProp$5 = Object.defineProperty;
- var __getOwnPropSymbols$7 = Object.getOwnPropertySymbols;
- var __hasOwnProp$7 = Object.prototype.hasOwnProperty;
- var __propIsEnum$7 = Object.prototype.propertyIsEnumerable;
- var __defNormalProp$5 = (obj, key, value) => key in obj ? __defProp$5(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
- var __spreadValues$5 = (a, b) => {
- for (var prop in b || (b = {}))
- if (__hasOwnProp$7.call(b, prop))
- __defNormalProp$5(a, prop, b[prop]);
- if (__getOwnPropSymbols$7)
- for (var prop of __getOwnPropSymbols$7(b)) {
- if (__propIsEnum$7.call(b, prop))
- __defNormalProp$5(a, prop, b[prop]);
- }
- return a;
- };
- function useTimeout(interval = 1e3, options = {}) {
- const {
- controls: exposeControls = false,
- callback
- } = options;
- const controls = useTimeoutFn(callback != null ? callback : noop, interval, options);
- const ready = vueDemi.computed(() => !controls.isPending.value);
- if (exposeControls) {
- return __spreadValues$5({
- ready
- }, controls);
- } else {
- return ready;
- }
- }
- function useToNumber(value, options = {}) {
- const {
- method = "parseFloat",
- radix,
- nanToZero
- } = options;
- return vueDemi.computed(() => {
- let resolved = resolveUnref(value);
- if (typeof resolved === "string")
- resolved = Number[method](resolved, radix);
- if (nanToZero && isNaN(resolved))
- resolved = 0;
- return resolved;
- });
- }
- function useToString(value) {
- return vueDemi.computed(() => `${resolveUnref(value)}`);
- }
- function useToggle(initialValue = false, options = {}) {
- const {
- truthyValue = true,
- falsyValue = false
- } = options;
- const valueIsRef = vueDemi.isRef(initialValue);
- const _value = vueDemi.ref(initialValue);
- function toggle(value) {
- if (arguments.length) {
- _value.value = value;
- return _value.value;
- } else {
- const truthy = resolveUnref(truthyValue);
- _value.value = _value.value === truthy ? resolveUnref(falsyValue) : truthy;
- return _value.value;
- }
- }
- if (valueIsRef)
- return toggle;
- else
- return [_value, toggle];
- }
- function watchArray(source, cb, options) {
- let oldList = (options == null ? void 0 : options.immediate) ? [] : [
- ...source instanceof Function ? source() : Array.isArray(source) ? source : vueDemi.unref(source)
- ];
- return vueDemi.watch(source, (newList, _, onCleanup) => {
- const oldListRemains = new Array(oldList.length);
- const added = [];
- for (const obj of newList) {
- let found = false;
- for (let i = 0; i < oldList.length; i++) {
- if (!oldListRemains[i] && obj === oldList[i]) {
- oldListRemains[i] = true;
- found = true;
- break;
- }
- }
- if (!found)
- added.push(obj);
- }
- const removed = oldList.filter((_2, i) => !oldListRemains[i]);
- cb(newList, oldList, added, removed, onCleanup);
- oldList = [...newList];
- }, options);
- }
- var __getOwnPropSymbols$6 = Object.getOwnPropertySymbols;
- var __hasOwnProp$6 = Object.prototype.hasOwnProperty;
- var __propIsEnum$6 = Object.prototype.propertyIsEnumerable;
- var __objRest$5 = (source, exclude) => {
- var target = {};
- for (var prop in source)
- if (__hasOwnProp$6.call(source, prop) && exclude.indexOf(prop) < 0)
- target[prop] = source[prop];
- if (source != null && __getOwnPropSymbols$6)
- for (var prop of __getOwnPropSymbols$6(source)) {
- if (exclude.indexOf(prop) < 0 && __propIsEnum$6.call(source, prop))
- target[prop] = source[prop];
- }
- return target;
- };
- function watchWithFilter(source, cb, options = {}) {
- const _a = options, {
- eventFilter = bypassFilter
- } = _a, watchOptions = __objRest$5(_a, [
- "eventFilter"
- ]);
- return vueDemi.watch(source, createFilterWrapper(eventFilter, cb), watchOptions);
- }
- var __getOwnPropSymbols$5 = Object.getOwnPropertySymbols;
- var __hasOwnProp$5 = Object.prototype.hasOwnProperty;
- var __propIsEnum$5 = Object.prototype.propertyIsEnumerable;
- var __objRest$4 = (source, exclude) => {
- var target = {};
- for (var prop in source)
- if (__hasOwnProp$5.call(source, prop) && exclude.indexOf(prop) < 0)
- target[prop] = source[prop];
- if (source != null && __getOwnPropSymbols$5)
- for (var prop of __getOwnPropSymbols$5(source)) {
- if (exclude.indexOf(prop) < 0 && __propIsEnum$5.call(source, prop))
- target[prop] = source[prop];
- }
- return target;
- };
- function watchAtMost(source, cb, options) {
- const _a = options, {
- count
- } = _a, watchOptions = __objRest$4(_a, [
- "count"
- ]);
- const current = vueDemi.ref(0);
- const stop = watchWithFilter(source, (...args) => {
- current.value += 1;
- if (current.value >= resolveUnref(count))
- vueDemi.nextTick(() => stop());
- cb(...args);
- }, watchOptions);
- return { count: current, stop };
- }
- var __defProp$4 = Object.defineProperty;
- var __defProps$4 = Object.defineProperties;
- var __getOwnPropDescs$4 = Object.getOwnPropertyDescriptors;
- var __getOwnPropSymbols$4 = Object.getOwnPropertySymbols;
- var __hasOwnProp$4 = Object.prototype.hasOwnProperty;
- var __propIsEnum$4 = Object.prototype.propertyIsEnumerable;
- var __defNormalProp$4 = (obj, key, value) => key in obj ? __defProp$4(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
- var __spreadValues$4 = (a, b) => {
- for (var prop in b || (b = {}))
- if (__hasOwnProp$4.call(b, prop))
- __defNormalProp$4(a, prop, b[prop]);
- if (__getOwnPropSymbols$4)
- for (var prop of __getOwnPropSymbols$4(b)) {
- if (__propIsEnum$4.call(b, prop))
- __defNormalProp$4(a, prop, b[prop]);
- }
- return a;
- };
- var __spreadProps$4 = (a, b) => __defProps$4(a, __getOwnPropDescs$4(b));
- var __objRest$3 = (source, exclude) => {
- var target = {};
- for (var prop in source)
- if (__hasOwnProp$4.call(source, prop) && exclude.indexOf(prop) < 0)
- target[prop] = source[prop];
- if (source != null && __getOwnPropSymbols$4)
- for (var prop of __getOwnPropSymbols$4(source)) {
- if (exclude.indexOf(prop) < 0 && __propIsEnum$4.call(source, prop))
- target[prop] = source[prop];
- }
- return target;
- };
- function watchDebounced(source, cb, options = {}) {
- const _a = options, {
- debounce = 0,
- maxWait = void 0
- } = _a, watchOptions = __objRest$3(_a, [
- "debounce",
- "maxWait"
- ]);
- return watchWithFilter(source, cb, __spreadProps$4(__spreadValues$4({}, watchOptions), {
- eventFilter: debounceFilter(debounce, { maxWait })
- }));
- }
- var __defProp$3 = Object.defineProperty;
- var __defProps$3 = Object.defineProperties;
- var __getOwnPropDescs$3 = Object.getOwnPropertyDescriptors;
- var __getOwnPropSymbols$3 = Object.getOwnPropertySymbols;
- var __hasOwnProp$3 = Object.prototype.hasOwnProperty;
- var __propIsEnum$3 = Object.prototype.propertyIsEnumerable;
- var __defNormalProp$3 = (obj, key, value) => key in obj ? __defProp$3(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
- var __spreadValues$3 = (a, b) => {
- for (var prop in b || (b = {}))
- if (__hasOwnProp$3.call(b, prop))
- __defNormalProp$3(a, prop, b[prop]);
- if (__getOwnPropSymbols$3)
- for (var prop of __getOwnPropSymbols$3(b)) {
- if (__propIsEnum$3.call(b, prop))
- __defNormalProp$3(a, prop, b[prop]);
- }
- return a;
- };
- var __spreadProps$3 = (a, b) => __defProps$3(a, __getOwnPropDescs$3(b));
- var __objRest$2 = (source, exclude) => {
- var target = {};
- for (var prop in source)
- if (__hasOwnProp$3.call(source, prop) && exclude.indexOf(prop) < 0)
- target[prop] = source[prop];
- if (source != null && __getOwnPropSymbols$3)
- for (var prop of __getOwnPropSymbols$3(source)) {
- if (exclude.indexOf(prop) < 0 && __propIsEnum$3.call(source, prop))
- target[prop] = source[prop];
- }
- return target;
- };
- function watchIgnorable(source, cb, options = {}) {
- const _a = options, {
- eventFilter = bypassFilter
- } = _a, watchOptions = __objRest$2(_a, [
- "eventFilter"
- ]);
- const filteredCb = createFilterWrapper(eventFilter, cb);
- let ignoreUpdates;
- let ignorePrevAsyncUpdates;
- let stop;
- if (watchOptions.flush === "sync") {
- const ignore = vueDemi.ref(false);
- ignorePrevAsyncUpdates = () => {
- };
- ignoreUpdates = (updater) => {
- ignore.value = true;
- updater();
- ignore.value = false;
- };
- stop = vueDemi.watch(source, (...args) => {
- if (!ignore.value)
- filteredCb(...args);
- }, watchOptions);
- } else {
- const disposables = [];
- const ignoreCounter = vueDemi.ref(0);
- const syncCounter = vueDemi.ref(0);
- ignorePrevAsyncUpdates = () => {
- ignoreCounter.value = syncCounter.value;
- };
- disposables.push(vueDemi.watch(source, () => {
- syncCounter.value++;
- }, __spreadProps$3(__spreadValues$3({}, watchOptions), { flush: "sync" })));
- ignoreUpdates = (updater) => {
- const syncCounterPrev = syncCounter.value;
- updater();
- ignoreCounter.value += syncCounter.value - syncCounterPrev;
- };
- disposables.push(vueDemi.watch(source, (...args) => {
- const ignore = ignoreCounter.value > 0 && ignoreCounter.value === syncCounter.value;
- ignoreCounter.value = 0;
- syncCounter.value = 0;
- if (ignore)
- return;
- filteredCb(...args);
- }, watchOptions));
- stop = () => {
- disposables.forEach((fn) => fn());
- };
- }
- return { stop, ignoreUpdates, ignorePrevAsyncUpdates };
- }
- function watchOnce(source, cb, options) {
- const stop = vueDemi.watch(source, (...args) => {
- vueDemi.nextTick(() => stop());
- return cb(...args);
- }, options);
- }
- var __defProp$2 = Object.defineProperty;
- var __defProps$2 = Object.defineProperties;
- var __getOwnPropDescs$2 = Object.getOwnPropertyDescriptors;
- var __getOwnPropSymbols$2 = Object.getOwnPropertySymbols;
- var __hasOwnProp$2 = Object.prototype.hasOwnProperty;
- var __propIsEnum$2 = Object.prototype.propertyIsEnumerable;
- var __defNormalProp$2 = (obj, key, value) => key in obj ? __defProp$2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
- var __spreadValues$2 = (a, b) => {
- for (var prop in b || (b = {}))
- if (__hasOwnProp$2.call(b, prop))
- __defNormalProp$2(a, prop, b[prop]);
- if (__getOwnPropSymbols$2)
- for (var prop of __getOwnPropSymbols$2(b)) {
- if (__propIsEnum$2.call(b, prop))
- __defNormalProp$2(a, prop, b[prop]);
- }
- return a;
- };
- var __spreadProps$2 = (a, b) => __defProps$2(a, __getOwnPropDescs$2(b));
- var __objRest$1 = (source, exclude) => {
- var target = {};
- for (var prop in source)
- if (__hasOwnProp$2.call(source, prop) && exclude.indexOf(prop) < 0)
- target[prop] = source[prop];
- if (source != null && __getOwnPropSymbols$2)
- for (var prop of __getOwnPropSymbols$2(source)) {
- if (exclude.indexOf(prop) < 0 && __propIsEnum$2.call(source, prop))
- target[prop] = source[prop];
- }
- return target;
- };
- function watchPausable(source, cb, options = {}) {
- const _a = options, {
- eventFilter: filter
- } = _a, watchOptions = __objRest$1(_a, [
- "eventFilter"
- ]);
- const { eventFilter, pause, resume, isActive } = pausableFilter(filter);
- const stop = watchWithFilter(source, cb, __spreadProps$2(__spreadValues$2({}, watchOptions), {
- eventFilter
- }));
- return { stop, pause, resume, isActive };
- }
- var __defProp$1 = Object.defineProperty;
- var __defProps$1 = Object.defineProperties;
- var __getOwnPropDescs$1 = Object.getOwnPropertyDescriptors;
- var __getOwnPropSymbols$1 = Object.getOwnPropertySymbols;
- var __hasOwnProp$1 = Object.prototype.hasOwnProperty;
- var __propIsEnum$1 = Object.prototype.propertyIsEnumerable;
- var __defNormalProp$1 = (obj, key, value) => key in obj ? __defProp$1(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
- var __spreadValues$1 = (a, b) => {
- for (var prop in b || (b = {}))
- if (__hasOwnProp$1.call(b, prop))
- __defNormalProp$1(a, prop, b[prop]);
- if (__getOwnPropSymbols$1)
- for (var prop of __getOwnPropSymbols$1(b)) {
- if (__propIsEnum$1.call(b, prop))
- __defNormalProp$1(a, prop, b[prop]);
- }
- return a;
- };
- var __spreadProps$1 = (a, b) => __defProps$1(a, __getOwnPropDescs$1(b));
- var __objRest = (source, exclude) => {
- var target = {};
- for (var prop in source)
- if (__hasOwnProp$1.call(source, prop) && exclude.indexOf(prop) < 0)
- target[prop] = source[prop];
- if (source != null && __getOwnPropSymbols$1)
- for (var prop of __getOwnPropSymbols$1(source)) {
- if (exclude.indexOf(prop) < 0 && __propIsEnum$1.call(source, prop))
- target[prop] = source[prop];
- }
- return target;
- };
- function watchThrottled(source, cb, options = {}) {
- const _a = options, {
- throttle = 0,
- trailing = true,
- leading = true
- } = _a, watchOptions = __objRest(_a, [
- "throttle",
- "trailing",
- "leading"
- ]);
- return watchWithFilter(source, cb, __spreadProps$1(__spreadValues$1({}, watchOptions), {
- eventFilter: throttleFilter(throttle, trailing, leading)
- }));
- }
- var __defProp = Object.defineProperty;
- var __defProps = Object.defineProperties;
- var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
- var __hasOwnProp = Object.prototype.hasOwnProperty;
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
- var __spreadValues = (a, b) => {
- for (var prop in b || (b = {}))
- if (__hasOwnProp.call(b, prop))
- __defNormalProp(a, prop, b[prop]);
- if (__getOwnPropSymbols)
- for (var prop of __getOwnPropSymbols(b)) {
- if (__propIsEnum.call(b, prop))
- __defNormalProp(a, prop, b[prop]);
- }
- return a;
- };
- var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
- function watchTriggerable(source, cb, options = {}) {
- let cleanupFn;
- function onEffect() {
- if (!cleanupFn)
- return;
- const fn = cleanupFn;
- cleanupFn = void 0;
- fn();
- }
- function onCleanup(callback) {
- cleanupFn = callback;
- }
- const _cb = (value, oldValue) => {
- onEffect();
- return cb(value, oldValue, onCleanup);
- };
- const res = watchIgnorable(source, _cb, options);
- const { ignoreUpdates } = res;
- const trigger = () => {
- let res2;
- ignoreUpdates(() => {
- res2 = _cb(getWatchSources(source), getOldValue(source));
- });
- return res2;
- };
- return __spreadProps(__spreadValues({}, res), {
- trigger
- });
- }
- function getWatchSources(sources) {
- if (vueDemi.isReactive(sources))
- return sources;
- if (Array.isArray(sources))
- return sources.map((item) => getOneWatchSource(item));
- return getOneWatchSource(sources);
- }
- function getOneWatchSource(source) {
- return typeof source === "function" ? source() : vueDemi.unref(source);
- }
- function getOldValue(source) {
- return Array.isArray(source) ? source.map(() => void 0) : void 0;
- }
- function whenever(source, cb, options) {
- return vueDemi.watch(source, (v, ov, onInvalidate) => {
- if (v)
- cb(v, ov, onInvalidate);
- }, options);
- }
- exports.__onlyVue27Plus = __onlyVue27Plus;
- exports.__onlyVue3 = __onlyVue3;
- exports.assert = assert;
- exports.autoResetRef = refAutoReset;
- exports.bypassFilter = bypassFilter;
- exports.clamp = clamp;
- exports.computedEager = computedEager;
- exports.computedWithControl = computedWithControl;
- exports.containsProp = containsProp;
- exports.controlledComputed = computedWithControl;
- exports.controlledRef = controlledRef;
- exports.createEventHook = createEventHook;
- exports.createFilterWrapper = createFilterWrapper;
- exports.createGlobalState = createGlobalState;
- exports.createInjectionState = createInjectionState;
- exports.createReactiveFn = reactify;
- exports.createSharedComposable = createSharedComposable;
- exports.createSingletonPromise = createSingletonPromise;
- exports.debounceFilter = debounceFilter;
- exports.debouncedRef = refDebounced;
- exports.debouncedWatch = watchDebounced;
- exports.directiveHooks = directiveHooks;
- exports.eagerComputed = computedEager;
- exports.extendRef = extendRef;
- exports.formatDate = formatDate;
- exports.get = get;
- exports.hasOwn = hasOwn;
- exports.identity = identity;
- exports.ignorableWatch = watchIgnorable;
- exports.increaseWithUnit = increaseWithUnit;
- exports.invoke = invoke;
- exports.isBoolean = isBoolean;
- exports.isClient = isClient;
- exports.isDef = isDef;
- exports.isDefined = isDefined;
- exports.isFunction = isFunction;
- exports.isIOS = isIOS;
- exports.isNumber = isNumber;
- exports.isObject = isObject;
- exports.isString = isString;
- exports.isWindow = isWindow;
- exports.makeDestructurable = makeDestructurable;
- exports.noop = noop;
- exports.normalizeDate = normalizeDate;
- exports.now = now;
- exports.objectPick = objectPick;
- exports.pausableFilter = pausableFilter;
- exports.pausableWatch = watchPausable;
- exports.promiseTimeout = promiseTimeout;
- exports.rand = rand;
- exports.reactify = reactify;
- exports.reactifyObject = reactifyObject;
- exports.reactiveComputed = reactiveComputed;
- exports.reactiveOmit = reactiveOmit;
- exports.reactivePick = reactivePick;
- exports.refAutoReset = refAutoReset;
- exports.refDebounced = refDebounced;
- exports.refDefault = refDefault;
- exports.refThrottled = refThrottled;
- exports.refWithControl = refWithControl;
- exports.resolveRef = resolveRef;
- exports.resolveUnref = resolveUnref;
- exports.set = set;
- exports.syncRef = syncRef;
- exports.syncRefs = syncRefs;
- exports.throttleFilter = throttleFilter;
- exports.throttledRef = refThrottled;
- exports.throttledWatch = watchThrottled;
- exports.timestamp = timestamp;
- exports.toReactive = toReactive;
- exports.toRefs = toRefs;
- exports.tryOnBeforeMount = tryOnBeforeMount;
- exports.tryOnBeforeUnmount = tryOnBeforeUnmount;
- exports.tryOnMounted = tryOnMounted;
- exports.tryOnScopeDispose = tryOnScopeDispose;
- exports.tryOnUnmounted = tryOnUnmounted;
- exports.until = until;
- exports.useArrayEvery = useArrayEvery;
- exports.useArrayFilter = useArrayFilter;
- exports.useArrayFind = useArrayFind;
- exports.useArrayFindIndex = useArrayFindIndex;
- exports.useArrayFindLast = useArrayFindLast;
- exports.useArrayJoin = useArrayJoin;
- exports.useArrayMap = useArrayMap;
- exports.useArrayReduce = useArrayReduce;
- exports.useArraySome = useArraySome;
- exports.useArrayUnique = useArrayUnique;
- exports.useCounter = useCounter;
- exports.useDateFormat = useDateFormat;
- exports.useDebounce = refDebounced;
- exports.useDebounceFn = useDebounceFn;
- exports.useInterval = useInterval;
- exports.useIntervalFn = useIntervalFn;
- exports.useLastChanged = useLastChanged;
- exports.useThrottle = refThrottled;
- exports.useThrottleFn = useThrottleFn;
- exports.useTimeout = useTimeout;
- exports.useTimeoutFn = useTimeoutFn;
- exports.useToNumber = useToNumber;
- exports.useToString = useToString;
- exports.useToggle = useToggle;
- exports.watchArray = watchArray;
- exports.watchAtMost = watchAtMost;
- exports.watchDebounced = watchDebounced;
- exports.watchIgnorable = watchIgnorable;
- exports.watchOnce = watchOnce;
- exports.watchPausable = watchPausable;
- exports.watchThrottled = watchThrottled;
- exports.watchTriggerable = watchTriggerable;
- exports.watchWithFilter = watchWithFilter;
- exports.whenever = whenever;
- })(this.VueUse = this.VueUse || {}, VueDemi);
|