@vueuse/integrations 10.2.0 → 10.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/index.d.cts +437 -0
- package/index.d.mts +437 -0
- package/package.json +7 -23
- package/useAsyncValidator/component.d.cts +27 -0
- package/useAsyncValidator/component.d.mts +27 -0
- package/useAsyncValidator.d.cts +48 -0
- package/useAsyncValidator.d.mts +48 -0
- package/useAsyncValidator.iife.min.js +1 -1
- package/useAxios.d.cts +94 -0
- package/useAxios.d.mts +94 -0
- package/useAxios.iife.min.js +1 -1
- package/useChangeCase.d.cts +36 -0
- package/useChangeCase.d.mts +36 -0
- package/useCookies.d.cts +54 -0
- package/useCookies.d.mts +54 -0
- package/useCookies.iife.min.js +1 -1
- package/useDrauu.d.cts +32 -0
- package/useDrauu.d.mts +32 -0
- package/useDrauu.iife.min.js +1 -1
- package/useFocusTrap/component.d.cts +17 -0
- package/useFocusTrap/component.d.mts +17 -0
- package/useFocusTrap.d.cts +57 -0
- package/useFocusTrap.d.mts +57 -0
- package/useFocusTrap.iife.min.js +1 -1
- package/useFuse.d.cts +25 -0
- package/useFuse.d.mts +25 -0
- package/useIDBKeyval.d.cts +41 -0
- package/useIDBKeyval.d.mts +41 -0
- package/useIDBKeyval.iife.min.js +1 -1
- package/useJwt.d.cts +29 -0
- package/useJwt.d.mts +29 -0
- package/useNProgress.d.cts +20 -0
- package/useNProgress.d.mts +20 -0
- package/useQRCode.d.cts +14 -0
- package/useQRCode.d.mts +14 -0
- package/useQRCode.iife.min.js +1 -1
- package/useSortable/component.d.cts +40 -0
- package/useSortable/component.d.mts +40 -0
- package/useSortable.d.cts +26 -0
- package/useSortable.d.mts +26 -0
- package/useSortable.iife.min.js +1 -1
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { Fn, MaybeElementRef } from '@vueuse/core';
|
|
2
|
+
import { Ref } from 'vue-demi';
|
|
3
|
+
import { Options, ActivateOptions, DeactivateOptions } from 'focus-trap';
|
|
4
|
+
|
|
5
|
+
interface UseFocusTrapOptions extends Options {
|
|
6
|
+
/**
|
|
7
|
+
* Immediately activate the trap
|
|
8
|
+
*/
|
|
9
|
+
immediate?: boolean;
|
|
10
|
+
}
|
|
11
|
+
interface UseFocusTrapReturn {
|
|
12
|
+
/**
|
|
13
|
+
* Indicates if the focus trap is currently active
|
|
14
|
+
*/
|
|
15
|
+
hasFocus: Ref<boolean>;
|
|
16
|
+
/**
|
|
17
|
+
* Indicates if the focus trap is currently paused
|
|
18
|
+
*/
|
|
19
|
+
isPaused: Ref<boolean>;
|
|
20
|
+
/**
|
|
21
|
+
* Activate the focus trap
|
|
22
|
+
*
|
|
23
|
+
* @see https://github.com/focus-trap/focus-trap#trapactivateactivateoptions
|
|
24
|
+
* @param opts Activate focus trap options
|
|
25
|
+
*/
|
|
26
|
+
activate: (opts?: ActivateOptions) => void;
|
|
27
|
+
/**
|
|
28
|
+
* Deactivate the focus trap
|
|
29
|
+
*
|
|
30
|
+
* @see https://github.com/focus-trap/focus-trap#trapdeactivatedeactivateoptions
|
|
31
|
+
* @param opts Deactivate focus trap options
|
|
32
|
+
*/
|
|
33
|
+
deactivate: (opts?: DeactivateOptions) => void;
|
|
34
|
+
/**
|
|
35
|
+
* Pause the focus trap
|
|
36
|
+
*
|
|
37
|
+
* @see https://github.com/focus-trap/focus-trap#trappause
|
|
38
|
+
*/
|
|
39
|
+
pause: Fn;
|
|
40
|
+
/**
|
|
41
|
+
* Unpauses the focus trap
|
|
42
|
+
*
|
|
43
|
+
* @see https://github.com/focus-trap/focus-trap#trapunpause
|
|
44
|
+
*/
|
|
45
|
+
unpause: Fn;
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Reactive focus-trap
|
|
49
|
+
*
|
|
50
|
+
* @see https://vueuse.org/useFocusTrap
|
|
51
|
+
* @param target The target element to trap focus within
|
|
52
|
+
* @param options Focus trap options
|
|
53
|
+
* @param autoFocus Focus trap automatically when mounted
|
|
54
|
+
*/
|
|
55
|
+
declare function useFocusTrap(target: MaybeElementRef, options?: UseFocusTrapOptions): UseFocusTrapReturn;
|
|
56
|
+
|
|
57
|
+
export { UseFocusTrapOptions, UseFocusTrapReturn, useFocusTrap };
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { Fn, MaybeElementRef } from '@vueuse/core';
|
|
2
|
+
import { Ref } from 'vue-demi';
|
|
3
|
+
import { Options, ActivateOptions, DeactivateOptions } from 'focus-trap';
|
|
4
|
+
|
|
5
|
+
interface UseFocusTrapOptions extends Options {
|
|
6
|
+
/**
|
|
7
|
+
* Immediately activate the trap
|
|
8
|
+
*/
|
|
9
|
+
immediate?: boolean;
|
|
10
|
+
}
|
|
11
|
+
interface UseFocusTrapReturn {
|
|
12
|
+
/**
|
|
13
|
+
* Indicates if the focus trap is currently active
|
|
14
|
+
*/
|
|
15
|
+
hasFocus: Ref<boolean>;
|
|
16
|
+
/**
|
|
17
|
+
* Indicates if the focus trap is currently paused
|
|
18
|
+
*/
|
|
19
|
+
isPaused: Ref<boolean>;
|
|
20
|
+
/**
|
|
21
|
+
* Activate the focus trap
|
|
22
|
+
*
|
|
23
|
+
* @see https://github.com/focus-trap/focus-trap#trapactivateactivateoptions
|
|
24
|
+
* @param opts Activate focus trap options
|
|
25
|
+
*/
|
|
26
|
+
activate: (opts?: ActivateOptions) => void;
|
|
27
|
+
/**
|
|
28
|
+
* Deactivate the focus trap
|
|
29
|
+
*
|
|
30
|
+
* @see https://github.com/focus-trap/focus-trap#trapdeactivatedeactivateoptions
|
|
31
|
+
* @param opts Deactivate focus trap options
|
|
32
|
+
*/
|
|
33
|
+
deactivate: (opts?: DeactivateOptions) => void;
|
|
34
|
+
/**
|
|
35
|
+
* Pause the focus trap
|
|
36
|
+
*
|
|
37
|
+
* @see https://github.com/focus-trap/focus-trap#trappause
|
|
38
|
+
*/
|
|
39
|
+
pause: Fn;
|
|
40
|
+
/**
|
|
41
|
+
* Unpauses the focus trap
|
|
42
|
+
*
|
|
43
|
+
* @see https://github.com/focus-trap/focus-trap#trapunpause
|
|
44
|
+
*/
|
|
45
|
+
unpause: Fn;
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Reactive focus-trap
|
|
49
|
+
*
|
|
50
|
+
* @see https://vueuse.org/useFocusTrap
|
|
51
|
+
* @param target The target element to trap focus within
|
|
52
|
+
* @param options Focus trap options
|
|
53
|
+
* @param autoFocus Focus trap automatically when mounted
|
|
54
|
+
*/
|
|
55
|
+
declare function useFocusTrap(target: MaybeElementRef, options?: UseFocusTrapOptions): UseFocusTrapReturn;
|
|
56
|
+
|
|
57
|
+
export { UseFocusTrapOptions, UseFocusTrapReturn, useFocusTrap };
|
package/useFocusTrap.iife.min.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
var VueDemi=function(n,r,u){if(n.install)return n;if(!r)return console.error("[vue-demi] no Vue instance found, please be sure to import `vue` before `vue-demi`."),n;if(r.version.slice(0,4)==="2.7."){let s=function(a,f){var c,_={},O={config:r.config,use:r.use.bind(r),mixin:r.mixin.bind(r),component:r.component.bind(r),provide:function(l,p){return _[l]=p,this},directive:function(l,p){return p?(r.directive(l,p),O):r.directive(l)},mount:function(l,p){return c||(c=new r(Object.assign({propsData:f},a,{provide:Object.assign(_,a.provide)})),c.$mount(l,p),c)},unmount:function(){c&&(c.$destroy(),c=void 0)}};return O};var
|
|
1
|
+
var VueDemi=function(n,r,u){if(n.install)return n;if(!r)return console.error("[vue-demi] no Vue instance found, please be sure to import `vue` before `vue-demi`."),n;if(r.version.slice(0,4)==="2.7."){let s=function(a,f){var c,_={},O={config:r.config,use:r.use.bind(r),mixin:r.mixin.bind(r),component:r.component.bind(r),provide:function(l,p){return _[l]=p,this},directive:function(l,p){return p?(r.directive(l,p),O):r.directive(l)},mount:function(l,p){return c||(c=new r(Object.assign({propsData:f},a,{provide:Object.assign(_,a.provide)})),c.$mount(l,p),c)},unmount:function(){c&&(c.$destroy(),c=void 0)}};return O};var b=s;for(var v in r)n[v]=r[v];n.isVue2=!0,n.isVue3=!1,n.install=function(){},n.Vue=r,n.Vue2=r,n.version=r.version,n.warn=r.util.warn,n.hasInjectionContext=()=>!!n.getCurrentInstance(),n.createApp=s}else if(r.version.slice(0,2)==="2.")if(u){for(var v in u)n[v]=u[v];n.isVue2=!0,n.isVue3=!1,n.install=function(){},n.Vue=r,n.Vue2=r,n.version=r.version,n.hasInjectionContext=()=>!!n.getCurrentInstance()}else console.error("[vue-demi] no VueCompositionAPI instance found, please be sure to import `@vue/composition-api` before `vue-demi`.");else if(r.version.slice(0,2)==="3."){for(var v in r)n[v]=r[v];n.isVue2=!1,n.isVue3=!0,n.install=function(){},n.Vue=r,n.Vue2=void 0,n.version=r.version,n.set=function(s,a,f){return Array.isArray(s)?(s.length=Math.max(s.length,a),s.splice(a,1,f),f):(s[a]=f,f)},n.del=function(s,a){if(Array.isArray(s)){s.splice(a,1);return}delete s[a]}}else console.error("[vue-demi] Vue version "+r.version+" is unsupported.");return n}(this.VueDemi=this.VueDemi||(typeof VueDemi<"u"?VueDemi:{}),this.Vue||(typeof Vue<"u"?Vue:void 0),this.VueCompositionAPI||(typeof VueCompositionAPI<"u"?VueCompositionAPI:void 0));(function(n,r,u,v){"use strict";var b=Object.defineProperty,s=Object.defineProperties,a=Object.getOwnPropertyDescriptors,f=Object.getOwnPropertySymbols,c=Object.prototype.hasOwnProperty,_=Object.prototype.propertyIsEnumerable,O=(i,t,e)=>t in i?b(i,t,{enumerable:!0,configurable:!0,writable:!0,value:e}):i[t]=e,l=(i,t)=>{for(var e in t||(t={}))c.call(t,e)&&O(i,e,t[e]);if(f)for(var e of f(t))_.call(t,e)&&O(i,e,t[e]);return i},p=(i,t)=>s(i,a(t)),A=(i,t)=>{var e={};for(var o in i)c.call(i,o)&&t.indexOf(o)<0&&(e[o]=i[o]);if(i!=null&&f)for(var o of f(i))t.indexOf(o)<0&&_.call(i,o)&&(e[o]=i[o]);return e};function j(i,t={}){let e;const o=t,{immediate:g}=o,I=A(o,["immediate"]),h=u.ref(!1),P=u.ref(!1),y=d=>e&&e.activate(d),w=d=>e&&e.deactivate(d),x=()=>{e&&(e.pause(),P.value=!0)},C=()=>{e&&(e.unpause(),P.value=!1)};return u.watch(()=>r.unrefElement(i),d=>{d&&(e=v.createFocusTrap(d,p(l({},I),{onActivate(){h.value=!0,t.onActivate&&t.onActivate()},onDeactivate(){h.value=!1,t.onDeactivate&&t.onDeactivate()}})),g&&y())},{flush:"post"}),r.tryOnScopeDispose(()=>w()),{hasFocus:h,isPaused:P,activate:y,deactivate:w,pause:x,unpause:C}}n.useFocusTrap=j})(this.VueUse=this.VueUse||{},VueUse,VueDemi,focusTrap);
|
package/useFuse.d.cts
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import * as vue_demi from 'vue-demi';
|
|
2
|
+
import { ComputedRef } from 'vue-demi';
|
|
3
|
+
import Fuse from 'fuse.js';
|
|
4
|
+
import { MaybeRefOrGetter } from '@vueuse/shared';
|
|
5
|
+
|
|
6
|
+
type FuseOptions<T> = Fuse.IFuseOptions<T>;
|
|
7
|
+
interface UseFuseOptions<T> {
|
|
8
|
+
fuseOptions?: FuseOptions<T>;
|
|
9
|
+
resultLimit?: number;
|
|
10
|
+
matchAllWhenSearchEmpty?: boolean;
|
|
11
|
+
}
|
|
12
|
+
declare function useFuse<DataItem>(search: MaybeRefOrGetter<string>, data: MaybeRefOrGetter<DataItem[]>, options?: MaybeRefOrGetter<UseFuseOptions<DataItem>>): {
|
|
13
|
+
fuse: vue_demi.Ref<{
|
|
14
|
+
search: <R = DataItem>(pattern: string | Fuse.Expression, options?: Fuse.FuseSearchOptions | undefined) => Fuse.FuseResult<R>[];
|
|
15
|
+
setCollection: (docs: readonly DataItem[], index?: Fuse.FuseIndex<DataItem> | undefined) => void;
|
|
16
|
+
add: (doc: DataItem) => void;
|
|
17
|
+
remove: (predicate: (doc: DataItem, idx: number) => boolean) => DataItem[];
|
|
18
|
+
removeAt: (idx: number) => void;
|
|
19
|
+
getIndex: () => Fuse.FuseIndex<DataItem>;
|
|
20
|
+
}>;
|
|
21
|
+
results: ComputedRef<Fuse.FuseResult<DataItem>[]>;
|
|
22
|
+
};
|
|
23
|
+
type UseFuseReturn = ReturnType<typeof useFuse>;
|
|
24
|
+
|
|
25
|
+
export { FuseOptions, UseFuseOptions, UseFuseReturn, useFuse };
|
package/useFuse.d.mts
ADDED
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import * as vue_demi from 'vue-demi';
|
|
2
|
+
import { ComputedRef } from 'vue-demi';
|
|
3
|
+
import Fuse from 'fuse.js';
|
|
4
|
+
import { MaybeRefOrGetter } from '@vueuse/shared';
|
|
5
|
+
|
|
6
|
+
type FuseOptions<T> = Fuse.IFuseOptions<T>;
|
|
7
|
+
interface UseFuseOptions<T> {
|
|
8
|
+
fuseOptions?: FuseOptions<T>;
|
|
9
|
+
resultLimit?: number;
|
|
10
|
+
matchAllWhenSearchEmpty?: boolean;
|
|
11
|
+
}
|
|
12
|
+
declare function useFuse<DataItem>(search: MaybeRefOrGetter<string>, data: MaybeRefOrGetter<DataItem[]>, options?: MaybeRefOrGetter<UseFuseOptions<DataItem>>): {
|
|
13
|
+
fuse: vue_demi.Ref<{
|
|
14
|
+
search: <R = DataItem>(pattern: string | Fuse.Expression, options?: Fuse.FuseSearchOptions | undefined) => Fuse.FuseResult<R>[];
|
|
15
|
+
setCollection: (docs: readonly DataItem[], index?: Fuse.FuseIndex<DataItem> | undefined) => void;
|
|
16
|
+
add: (doc: DataItem) => void;
|
|
17
|
+
remove: (predicate: (doc: DataItem, idx: number) => boolean) => DataItem[];
|
|
18
|
+
removeAt: (idx: number) => void;
|
|
19
|
+
getIndex: () => Fuse.FuseIndex<DataItem>;
|
|
20
|
+
}>;
|
|
21
|
+
results: ComputedRef<Fuse.FuseResult<DataItem>[]>;
|
|
22
|
+
};
|
|
23
|
+
type UseFuseReturn = ReturnType<typeof useFuse>;
|
|
24
|
+
|
|
25
|
+
export { FuseOptions, UseFuseOptions, UseFuseReturn, useFuse };
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { ConfigurableFlush, MaybeRefOrGetter, RemovableRef } from '@vueuse/shared';
|
|
2
|
+
import { Ref } from 'vue-demi';
|
|
3
|
+
|
|
4
|
+
interface UseIDBOptions extends ConfigurableFlush {
|
|
5
|
+
/**
|
|
6
|
+
* Watch for deep changes
|
|
7
|
+
*
|
|
8
|
+
* @default true
|
|
9
|
+
*/
|
|
10
|
+
deep?: boolean;
|
|
11
|
+
/**
|
|
12
|
+
* On error callback
|
|
13
|
+
*
|
|
14
|
+
* Default log error to `console.error`
|
|
15
|
+
*/
|
|
16
|
+
onError?: (error: unknown) => void;
|
|
17
|
+
/**
|
|
18
|
+
* Use shallow ref as reference
|
|
19
|
+
*
|
|
20
|
+
* @default false
|
|
21
|
+
*/
|
|
22
|
+
shallow?: boolean;
|
|
23
|
+
/**
|
|
24
|
+
* Write the default value to the storage when it does not exist
|
|
25
|
+
*
|
|
26
|
+
* @default true
|
|
27
|
+
*/
|
|
28
|
+
writeDefaults?: boolean;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
*
|
|
32
|
+
* @param key
|
|
33
|
+
* @param initialValue
|
|
34
|
+
* @param options
|
|
35
|
+
*/
|
|
36
|
+
declare function useIDBKeyval<T>(key: IDBValidKey, initialValue: MaybeRefOrGetter<T>, options?: UseIDBOptions): {
|
|
37
|
+
data: RemovableRef<T>;
|
|
38
|
+
isFinished: Ref<boolean>;
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
export { UseIDBOptions, useIDBKeyval };
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { ConfigurableFlush, MaybeRefOrGetter, RemovableRef } from '@vueuse/shared';
|
|
2
|
+
import { Ref } from 'vue-demi';
|
|
3
|
+
|
|
4
|
+
interface UseIDBOptions extends ConfigurableFlush {
|
|
5
|
+
/**
|
|
6
|
+
* Watch for deep changes
|
|
7
|
+
*
|
|
8
|
+
* @default true
|
|
9
|
+
*/
|
|
10
|
+
deep?: boolean;
|
|
11
|
+
/**
|
|
12
|
+
* On error callback
|
|
13
|
+
*
|
|
14
|
+
* Default log error to `console.error`
|
|
15
|
+
*/
|
|
16
|
+
onError?: (error: unknown) => void;
|
|
17
|
+
/**
|
|
18
|
+
* Use shallow ref as reference
|
|
19
|
+
*
|
|
20
|
+
* @default false
|
|
21
|
+
*/
|
|
22
|
+
shallow?: boolean;
|
|
23
|
+
/**
|
|
24
|
+
* Write the default value to the storage when it does not exist
|
|
25
|
+
*
|
|
26
|
+
* @default true
|
|
27
|
+
*/
|
|
28
|
+
writeDefaults?: boolean;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
*
|
|
32
|
+
* @param key
|
|
33
|
+
* @param initialValue
|
|
34
|
+
* @param options
|
|
35
|
+
*/
|
|
36
|
+
declare function useIDBKeyval<T>(key: IDBValidKey, initialValue: MaybeRefOrGetter<T>, options?: UseIDBOptions): {
|
|
37
|
+
data: RemovableRef<T>;
|
|
38
|
+
isFinished: Ref<boolean>;
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
export { UseIDBOptions, useIDBKeyval };
|
package/useIDBKeyval.iife.min.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
var VueDemi=function(n,r,c){if(n.install)return n;if(!r)return console.error("[vue-demi] no Vue instance found, please be sure to import `vue` before `vue-demi`."),n;if(r.version.slice(0,4)==="2.7."){let s=function(a,u){var f,d={},v={config:r.config,use:r.use.bind(r),mixin:r.mixin.bind(r),component:r.component.bind(r),provide:function(e,t){return d[e]=t,this},directive:function(e,t){return t?(r.directive(e,t),v):r.directive(e)},mount:function(e,t){return f||(f=new r(Object.assign({propsData:u},a,{provide:Object.assign(d,a.provide)})),f.$mount(e,t),f)},unmount:function(){f&&(f.$destroy(),f=void 0)}};return v};var
|
|
1
|
+
var VueDemi=function(n,r,c){if(n.install)return n;if(!r)return console.error("[vue-demi] no Vue instance found, please be sure to import `vue` before `vue-demi`."),n;if(r.version.slice(0,4)==="2.7."){let s=function(a,u){var f,d={},v={config:r.config,use:r.use.bind(r),mixin:r.mixin.bind(r),component:r.component.bind(r),provide:function(e,t){return d[e]=t,this},directive:function(e,t){return t?(r.directive(e,t),v):r.directive(e)},mount:function(e,t){return f||(f=new r(Object.assign({propsData:u},a,{provide:Object.assign(d,a.provide)})),f.$mount(e,t),f)},unmount:function(){f&&(f.$destroy(),f=void 0)}};return v};var w=s;for(var o in r)n[o]=r[o];n.isVue2=!0,n.isVue3=!1,n.install=function(){},n.Vue=r,n.Vue2=r,n.version=r.version,n.warn=r.util.warn,n.hasInjectionContext=()=>!!n.getCurrentInstance(),n.createApp=s}else if(r.version.slice(0,2)==="2.")if(c){for(var o in c)n[o]=c[o];n.isVue2=!0,n.isVue3=!1,n.install=function(){},n.Vue=r,n.Vue2=r,n.version=r.version,n.hasInjectionContext=()=>!!n.getCurrentInstance()}else console.error("[vue-demi] no VueCompositionAPI instance found, please be sure to import `@vue/composition-api` before `vue-demi`.");else if(r.version.slice(0,2)==="3."){for(var o in r)n[o]=r[o];n.isVue2=!1,n.isVue3=!0,n.install=function(){},n.Vue=r,n.Vue2=void 0,n.version=r.version,n.set=function(s,a,u){return Array.isArray(s)?(s.length=Math.max(s.length,a),s.splice(a,1,u),u):(s[a]=u,u)},n.del=function(s,a){if(Array.isArray(s)){s.splice(a,1);return}delete s[a]}}else console.error("[vue-demi] Vue version "+r.version+" is unsupported.");return n}(this.VueDemi=this.VueDemi||(typeof VueDemi<"u"?VueDemi:{}),this.Vue||(typeof Vue<"u"?Vue:void 0),this.VueCompositionAPI||(typeof VueCompositionAPI<"u"?VueCompositionAPI:void 0));(function(n,r,c,o){"use strict";var w=Object.defineProperty,s=Object.getOwnPropertySymbols,a=Object.prototype.hasOwnProperty,u=Object.prototype.propertyIsEnumerable,f=(e,t,i)=>t in e?w(e,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):e[t]=i,d=(e,t)=>{for(var i in t||(t={}))a.call(t,i)&&f(e,i,t[i]);if(s)for(var i of s(t))u.call(t,i)&&f(e,i,t[i]);return e};function v(e,t,i={}){const{flush:_="pre",deep:I=!0,shallow:A=!1,onError:y=p=>{console.error(p)},writeDefaults:P=!0}=i,O=c.ref(!1),l=(A?c.shallowRef:c.ref)(t),h=r.toValue(t);async function b(){try{const p=await o.get(e);p===void 0?h!=null&&P&&await o.set(e,h):l.value=p}catch(p){y(p)}O.value=!0}b();async function g(){try{l.value==null?await o.del(e):Array.isArray(l.value)?await o.update(e,()=>JSON.parse(JSON.stringify(l.value))):typeof l.value=="object"?await o.update(e,()=>d({},l.value)):await o.update(e,()=>l.value)}catch(p){y(p)}}return c.watch(l,()=>g(),{flush:_,deep:I}),{isFinished:O,data:l}}n.useIDBKeyval=v})(this.VueUse=this.VueUse||{},VueUse,VueDemi,idbKeyval);
|
package/useJwt.d.cts
ADDED
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { ComputedRef } from 'vue-demi';
|
|
2
|
+
import { MaybeRefOrGetter } from '@vueuse/shared';
|
|
3
|
+
import { JwtPayload, JwtHeader } from 'jwt-decode';
|
|
4
|
+
|
|
5
|
+
interface UseJwtOptions<Fallback> {
|
|
6
|
+
/**
|
|
7
|
+
* Value returned when encounter error on decoding
|
|
8
|
+
*
|
|
9
|
+
* @default null
|
|
10
|
+
*/
|
|
11
|
+
fallbackValue?: Fallback;
|
|
12
|
+
/**
|
|
13
|
+
* Error callback for decoding
|
|
14
|
+
*/
|
|
15
|
+
onError?: (error: unknown) => void;
|
|
16
|
+
}
|
|
17
|
+
interface UseJwtReturn<Payload, Header, Fallback> {
|
|
18
|
+
header: ComputedRef<Header | Fallback>;
|
|
19
|
+
payload: ComputedRef<Payload | Fallback>;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Reactive decoded jwt token.
|
|
23
|
+
*
|
|
24
|
+
* @see https://vueuse.org/useJwt
|
|
25
|
+
* @param jwt
|
|
26
|
+
*/
|
|
27
|
+
declare function useJwt<Payload extends object = JwtPayload, Header extends object = JwtHeader, Fallback = null>(encodedJwt: MaybeRefOrGetter<string>, options?: UseJwtOptions<Fallback>): UseJwtReturn<Payload, Header, Fallback>;
|
|
28
|
+
|
|
29
|
+
export { UseJwtOptions, UseJwtReturn, useJwt };
|
package/useJwt.d.mts
ADDED
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { ComputedRef } from 'vue-demi';
|
|
2
|
+
import { MaybeRefOrGetter } from '@vueuse/shared';
|
|
3
|
+
import { JwtPayload, JwtHeader } from 'jwt-decode';
|
|
4
|
+
|
|
5
|
+
interface UseJwtOptions<Fallback> {
|
|
6
|
+
/**
|
|
7
|
+
* Value returned when encounter error on decoding
|
|
8
|
+
*
|
|
9
|
+
* @default null
|
|
10
|
+
*/
|
|
11
|
+
fallbackValue?: Fallback;
|
|
12
|
+
/**
|
|
13
|
+
* Error callback for decoding
|
|
14
|
+
*/
|
|
15
|
+
onError?: (error: unknown) => void;
|
|
16
|
+
}
|
|
17
|
+
interface UseJwtReturn<Payload, Header, Fallback> {
|
|
18
|
+
header: ComputedRef<Header | Fallback>;
|
|
19
|
+
payload: ComputedRef<Payload | Fallback>;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Reactive decoded jwt token.
|
|
23
|
+
*
|
|
24
|
+
* @see https://vueuse.org/useJwt
|
|
25
|
+
* @param jwt
|
|
26
|
+
*/
|
|
27
|
+
declare function useJwt<Payload extends object = JwtPayload, Header extends object = JwtHeader, Fallback = null>(encodedJwt: MaybeRefOrGetter<string>, options?: UseJwtOptions<Fallback>): UseJwtReturn<Payload, Header, Fallback>;
|
|
28
|
+
|
|
29
|
+
export { UseJwtOptions, UseJwtReturn, useJwt };
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import * as vue_demi from 'vue-demi';
|
|
2
|
+
import nprogress, { NProgressOptions } from 'nprogress';
|
|
3
|
+
import { MaybeRefOrGetter } from '@vueuse/shared';
|
|
4
|
+
|
|
5
|
+
type UseNProgressOptions = Partial<NProgressOptions>;
|
|
6
|
+
/**
|
|
7
|
+
* Reactive progress bar.
|
|
8
|
+
*
|
|
9
|
+
* @see https://vueuse.org/useNProgress
|
|
10
|
+
*/
|
|
11
|
+
declare function useNProgress(currentProgress?: MaybeRefOrGetter<number | null | undefined>, options?: UseNProgressOptions): {
|
|
12
|
+
isLoading: vue_demi.WritableComputedRef<boolean>;
|
|
13
|
+
progress: vue_demi.Ref<number | (() => number | null | undefined) | null | undefined>;
|
|
14
|
+
start: () => nprogress.NProgress;
|
|
15
|
+
done: (force?: boolean | undefined) => nprogress.NProgress;
|
|
16
|
+
remove: () => void;
|
|
17
|
+
};
|
|
18
|
+
type UseNProgressReturn = ReturnType<typeof useNProgress>;
|
|
19
|
+
|
|
20
|
+
export { UseNProgressOptions, UseNProgressReturn, useNProgress };
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import * as vue_demi from 'vue-demi';
|
|
2
|
+
import nprogress, { NProgressOptions } from 'nprogress';
|
|
3
|
+
import { MaybeRefOrGetter } from '@vueuse/shared';
|
|
4
|
+
|
|
5
|
+
type UseNProgressOptions = Partial<NProgressOptions>;
|
|
6
|
+
/**
|
|
7
|
+
* Reactive progress bar.
|
|
8
|
+
*
|
|
9
|
+
* @see https://vueuse.org/useNProgress
|
|
10
|
+
*/
|
|
11
|
+
declare function useNProgress(currentProgress?: MaybeRefOrGetter<number | null | undefined>, options?: UseNProgressOptions): {
|
|
12
|
+
isLoading: vue_demi.WritableComputedRef<boolean>;
|
|
13
|
+
progress: vue_demi.Ref<number | (() => number | null | undefined) | null | undefined>;
|
|
14
|
+
start: () => nprogress.NProgress;
|
|
15
|
+
done: (force?: boolean | undefined) => nprogress.NProgress;
|
|
16
|
+
remove: () => void;
|
|
17
|
+
};
|
|
18
|
+
type UseNProgressReturn = ReturnType<typeof useNProgress>;
|
|
19
|
+
|
|
20
|
+
export { UseNProgressOptions, UseNProgressReturn, useNProgress };
|
package/useQRCode.d.cts
ADDED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import * as vue_demi from 'vue-demi';
|
|
2
|
+
import { MaybeRefOrGetter } from '@vueuse/shared';
|
|
3
|
+
import QRCode from 'qrcode';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Wrapper for qrcode.
|
|
7
|
+
*
|
|
8
|
+
* @see https://vueuse.org/useQRCode
|
|
9
|
+
* @param text
|
|
10
|
+
* @param options
|
|
11
|
+
*/
|
|
12
|
+
declare function useQRCode(text: MaybeRefOrGetter<string>, options?: QRCode.QRCodeToDataURLOptions): vue_demi.Ref<string>;
|
|
13
|
+
|
|
14
|
+
export { useQRCode };
|
package/useQRCode.d.mts
ADDED
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import * as vue_demi from 'vue-demi';
|
|
2
|
+
import { MaybeRefOrGetter } from '@vueuse/shared';
|
|
3
|
+
import QRCode from 'qrcode';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Wrapper for qrcode.
|
|
7
|
+
*
|
|
8
|
+
* @see https://vueuse.org/useQRCode
|
|
9
|
+
* @param text
|
|
10
|
+
* @param options
|
|
11
|
+
*/
|
|
12
|
+
declare function useQRCode(text: MaybeRefOrGetter<string>, options?: QRCode.QRCodeToDataURLOptions): vue_demi.Ref<string>;
|
|
13
|
+
|
|
14
|
+
export { useQRCode };
|
package/useQRCode.iife.min.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
var VueDemi=function(n,i,f){if(n.install)return n;if(!i)return console.error("[vue-demi] no Vue instance found, please be sure to import `vue` before `vue-demi`."),n;if(i.version.slice(0,4)==="2.7."){let r=function(s,e){var t,a={},
|
|
1
|
+
var VueDemi=function(n,i,f){if(n.install)return n;if(!i)return console.error("[vue-demi] no Vue instance found, please be sure to import `vue` before `vue-demi`."),n;if(i.version.slice(0,4)==="2.7."){let r=function(s,e){var t,a={},v={config:i.config,use:i.use.bind(i),mixin:i.mixin.bind(i),component:i.component.bind(i),provide:function(c,d){return a[c]=d,this},directive:function(c,d){return d?(i.directive(c,d),v):i.directive(c)},mount:function(c,d){return t||(t=new i(Object.assign({propsData:e},s,{provide:Object.assign(a,s.provide)})),t.$mount(c,d),t)},unmount:function(){t&&(t.$destroy(),t=void 0)}};return v};var l=r;for(var o in i)n[o]=i[o];n.isVue2=!0,n.isVue3=!1,n.install=function(){},n.Vue=i,n.Vue2=i,n.version=i.version,n.warn=i.util.warn,n.hasInjectionContext=()=>!!n.getCurrentInstance(),n.createApp=r}else if(i.version.slice(0,2)==="2.")if(f){for(var o in f)n[o]=f[o];n.isVue2=!0,n.isVue3=!1,n.install=function(){},n.Vue=i,n.Vue2=i,n.version=i.version,n.hasInjectionContext=()=>!!n.getCurrentInstance()}else console.error("[vue-demi] no VueCompositionAPI instance found, please be sure to import `@vue/composition-api` before `vue-demi`.");else if(i.version.slice(0,2)==="3."){for(var o in i)n[o]=i[o];n.isVue2=!1,n.isVue3=!0,n.install=function(){},n.Vue=i,n.Vue2=void 0,n.version=i.version,n.set=function(r,s,e){return Array.isArray(r)?(r.length=Math.max(r.length,s),r.splice(s,1,e),e):(r[s]=e,e)},n.del=function(r,s){if(Array.isArray(r)){r.splice(s,1);return}delete r[s]}}else console.error("[vue-demi] Vue version "+i.version+" is unsupported.");return n}(this.VueDemi=this.VueDemi||(typeof VueDemi<"u"?VueDemi:{}),this.Vue||(typeof Vue<"u"?Vue:void 0),this.VueCompositionAPI||(typeof VueCompositionAPI<"u"?VueCompositionAPI:void 0));(function(n,i,f,o){"use strict";function l(r,s){const e=i.toRef(r),t=f.ref("");return f.watch(e,async a=>{e.value&&i.isClient&&(t.value=await o.toDataURL(a,s))},{immediate:!0}),t}n.useQRCode=l})(this.VueUse=this.VueUse||{},VueUse,VueDemi,QRCode);
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import * as vue_demi from 'vue-demi';
|
|
2
|
+
import { PropType } from 'vue-demi';
|
|
3
|
+
import { ConfigurableDocument } from '@vueuse/core';
|
|
4
|
+
import { Options } from 'sortablejs';
|
|
5
|
+
|
|
6
|
+
type UseSortableOptions = Options & ConfigurableDocument;
|
|
7
|
+
|
|
8
|
+
declare const UseSortable: vue_demi.DefineComponent<{
|
|
9
|
+
modelValue: {
|
|
10
|
+
type: PropType<any[]>;
|
|
11
|
+
required: true;
|
|
12
|
+
};
|
|
13
|
+
tag: {
|
|
14
|
+
type: StringConstructor;
|
|
15
|
+
default: string;
|
|
16
|
+
};
|
|
17
|
+
options: {
|
|
18
|
+
type: PropType<UseSortableOptions>;
|
|
19
|
+
required: true;
|
|
20
|
+
};
|
|
21
|
+
}, () => vue_demi.VNode<vue_demi.RendererNode, vue_demi.RendererElement, {
|
|
22
|
+
[key: string]: any;
|
|
23
|
+
}> | undefined, unknown, {}, {}, vue_demi.ComponentOptionsMixin, vue_demi.ComponentOptionsMixin, {}, string, vue_demi.VNodeProps & vue_demi.AllowedComponentProps & vue_demi.ComponentCustomProps, Readonly<vue_demi.ExtractPropTypes<{
|
|
24
|
+
modelValue: {
|
|
25
|
+
type: PropType<any[]>;
|
|
26
|
+
required: true;
|
|
27
|
+
};
|
|
28
|
+
tag: {
|
|
29
|
+
type: StringConstructor;
|
|
30
|
+
default: string;
|
|
31
|
+
};
|
|
32
|
+
options: {
|
|
33
|
+
type: PropType<UseSortableOptions>;
|
|
34
|
+
required: true;
|
|
35
|
+
};
|
|
36
|
+
}>>, {
|
|
37
|
+
tag: string;
|
|
38
|
+
}, {}>;
|
|
39
|
+
|
|
40
|
+
export { UseSortable };
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import * as vue_demi from 'vue-demi';
|
|
2
|
+
import { PropType } from 'vue-demi';
|
|
3
|
+
import { ConfigurableDocument } from '@vueuse/core';
|
|
4
|
+
import { Options } from 'sortablejs';
|
|
5
|
+
|
|
6
|
+
type UseSortableOptions = Options & ConfigurableDocument;
|
|
7
|
+
|
|
8
|
+
declare const UseSortable: vue_demi.DefineComponent<{
|
|
9
|
+
modelValue: {
|
|
10
|
+
type: PropType<any[]>;
|
|
11
|
+
required: true;
|
|
12
|
+
};
|
|
13
|
+
tag: {
|
|
14
|
+
type: StringConstructor;
|
|
15
|
+
default: string;
|
|
16
|
+
};
|
|
17
|
+
options: {
|
|
18
|
+
type: PropType<UseSortableOptions>;
|
|
19
|
+
required: true;
|
|
20
|
+
};
|
|
21
|
+
}, () => vue_demi.VNode<vue_demi.RendererNode, vue_demi.RendererElement, {
|
|
22
|
+
[key: string]: any;
|
|
23
|
+
}> | undefined, unknown, {}, {}, vue_demi.ComponentOptionsMixin, vue_demi.ComponentOptionsMixin, {}, string, vue_demi.VNodeProps & vue_demi.AllowedComponentProps & vue_demi.ComponentCustomProps, Readonly<vue_demi.ExtractPropTypes<{
|
|
24
|
+
modelValue: {
|
|
25
|
+
type: PropType<any[]>;
|
|
26
|
+
required: true;
|
|
27
|
+
};
|
|
28
|
+
tag: {
|
|
29
|
+
type: StringConstructor;
|
|
30
|
+
default: string;
|
|
31
|
+
};
|
|
32
|
+
options: {
|
|
33
|
+
type: PropType<UseSortableOptions>;
|
|
34
|
+
required: true;
|
|
35
|
+
};
|
|
36
|
+
}>>, {
|
|
37
|
+
tag: string;
|
|
38
|
+
}, {}>;
|
|
39
|
+
|
|
40
|
+
export { UseSortable };
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { ConfigurableDocument, MaybeRefOrGetter } from '@vueuse/core';
|
|
2
|
+
import Sortable, { Options } from 'sortablejs';
|
|
3
|
+
|
|
4
|
+
interface UseSortableReturn {
|
|
5
|
+
/**
|
|
6
|
+
* start sortable instance
|
|
7
|
+
*/
|
|
8
|
+
start: () => void;
|
|
9
|
+
/**
|
|
10
|
+
* destroy sortable instance
|
|
11
|
+
*/
|
|
12
|
+
stop: () => void;
|
|
13
|
+
/**
|
|
14
|
+
* Options getter/setter
|
|
15
|
+
* @param name a Sortable.Options property.
|
|
16
|
+
* @param value a value.
|
|
17
|
+
*/
|
|
18
|
+
option<K extends keyof Sortable.Options>(name: K, value: Sortable.Options[K]): void;
|
|
19
|
+
option<K extends keyof Sortable.Options>(name: K): Sortable.Options[K];
|
|
20
|
+
}
|
|
21
|
+
type UseSortableOptions = Options & ConfigurableDocument;
|
|
22
|
+
declare function useSortable<T>(selector: string, list: MaybeRefOrGetter<T[]>, options?: UseSortableOptions): UseSortableReturn;
|
|
23
|
+
declare function useSortable<T>(el: MaybeRefOrGetter<HTMLElement | null | undefined>, list: MaybeRefOrGetter<T[]>, options?: UseSortableOptions): UseSortableReturn;
|
|
24
|
+
declare function moveArrayElement<T>(list: MaybeRefOrGetter<T[]>, from: number, to: number): void;
|
|
25
|
+
|
|
26
|
+
export { UseSortableOptions, UseSortableReturn, moveArrayElement, useSortable };
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { ConfigurableDocument, MaybeRefOrGetter } from '@vueuse/core';
|
|
2
|
+
import Sortable, { Options } from 'sortablejs';
|
|
3
|
+
|
|
4
|
+
interface UseSortableReturn {
|
|
5
|
+
/**
|
|
6
|
+
* start sortable instance
|
|
7
|
+
*/
|
|
8
|
+
start: () => void;
|
|
9
|
+
/**
|
|
10
|
+
* destroy sortable instance
|
|
11
|
+
*/
|
|
12
|
+
stop: () => void;
|
|
13
|
+
/**
|
|
14
|
+
* Options getter/setter
|
|
15
|
+
* @param name a Sortable.Options property.
|
|
16
|
+
* @param value a value.
|
|
17
|
+
*/
|
|
18
|
+
option<K extends keyof Sortable.Options>(name: K, value: Sortable.Options[K]): void;
|
|
19
|
+
option<K extends keyof Sortable.Options>(name: K): Sortable.Options[K];
|
|
20
|
+
}
|
|
21
|
+
type UseSortableOptions = Options & ConfigurableDocument;
|
|
22
|
+
declare function useSortable<T>(selector: string, list: MaybeRefOrGetter<T[]>, options?: UseSortableOptions): UseSortableReturn;
|
|
23
|
+
declare function useSortable<T>(el: MaybeRefOrGetter<HTMLElement | null | undefined>, list: MaybeRefOrGetter<T[]>, options?: UseSortableOptions): UseSortableReturn;
|
|
24
|
+
declare function moveArrayElement<T>(list: MaybeRefOrGetter<T[]>, from: number, to: number): void;
|
|
25
|
+
|
|
26
|
+
export { UseSortableOptions, UseSortableReturn, moveArrayElement, useSortable };
|
package/useSortable.iife.min.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
var VueDemi=function(n,t,u){if(n.install)return n;if(!t)return console.error("[vue-demi] no Vue instance found, please be sure to import `vue` before `vue-demi`."),n;if(t.version.slice(0,4)==="2.7."){let s=function(f,c){var l,y={},b={config:t.config,use:t.use.bind(t),mixin:t.mixin.bind(t),component:t.component.bind(t),provide:function(p,d){return y[p]=d,this},directive:function(p,d){return d?(t.directive(p,d),b):t.directive(p)},mount:function(p,d){return l||(l=new t(Object.assign({propsData:c},f,{provide:Object.assign(y,f.provide)})),l.$mount(p,d),l)},unmount:function(){l&&(l.$destroy(),l=void 0)}};return b};var
|
|
1
|
+
var VueDemi=function(n,t,u){if(n.install)return n;if(!t)return console.error("[vue-demi] no Vue instance found, please be sure to import `vue` before `vue-demi`."),n;if(t.version.slice(0,4)==="2.7."){let s=function(f,c){var l,y={},b={config:t.config,use:t.use.bind(t),mixin:t.mixin.bind(t),component:t.component.bind(t),provide:function(p,d){return y[p]=d,this},directive:function(p,d){return d?(t.directive(p,d),b):t.directive(p)},mount:function(p,d){return l||(l=new t(Object.assign({propsData:c},f,{provide:Object.assign(y,f.provide)})),l.$mount(p,d),l)},unmount:function(){l&&(l.$destroy(),l=void 0)}};return b};var h=s;for(var a in t)n[a]=t[a];n.isVue2=!0,n.isVue3=!1,n.install=function(){},n.Vue=t,n.Vue2=t,n.version=t.version,n.warn=t.util.warn,n.hasInjectionContext=()=>!!n.getCurrentInstance(),n.createApp=s}else if(t.version.slice(0,2)==="2.")if(u){for(var a in u)n[a]=u[a];n.isVue2=!0,n.isVue3=!1,n.install=function(){},n.Vue=t,n.Vue2=t,n.version=t.version,n.hasInjectionContext=()=>!!n.getCurrentInstance()}else console.error("[vue-demi] no VueCompositionAPI instance found, please be sure to import `@vue/composition-api` before `vue-demi`.");else if(t.version.slice(0,2)==="3."){for(var a in t)n[a]=t[a];n.isVue2=!1,n.isVue3=!0,n.install=function(){},n.Vue=t,n.Vue2=void 0,n.version=t.version,n.set=function(s,f,c){return Array.isArray(s)?(s.length=Math.max(s.length,f),s.splice(f,1,c),c):(s[f]=c,c)},n.del=function(s,f){if(Array.isArray(s)){s.splice(f,1);return}delete s[f]}}else console.error("[vue-demi] Vue version "+t.version+" is unsupported.");return n}(this.VueDemi=this.VueDemi||(typeof VueDemi<"u"?VueDemi:{}),this.Vue||(typeof Vue<"u"?Vue:void 0),this.VueCompositionAPI||(typeof VueCompositionAPI<"u"?VueCompositionAPI:void 0));(function(n,t,u,a){"use strict";var h=Object.defineProperty,s=Object.getOwnPropertySymbols,f=Object.prototype.hasOwnProperty,c=Object.prototype.propertyIsEnumerable,l=(r,i,o)=>i in r?h(r,i,{enumerable:!0,configurable:!0,writable:!0,value:o}):r[i]=o,y=(r,i)=>{for(var o in i||(i={}))f.call(i,o)&&l(r,o,i[o]);if(s)for(var o of s(i))c.call(i,o)&&l(r,o,i[o]);return r},b=(r,i)=>{var o={};for(var e in r)f.call(r,e)&&i.indexOf(e)<0&&(o[e]=r[e]);if(r!=null&&s)for(var e of s(r))i.indexOf(e)<0&&c.call(r,e)&&(o[e]=r[e]);return o};function p(r,i,o={}){let e;const O=o,{document:_=t.defaultDocument}=O,A=b(O,["document"]),P={onUpdate:v=>{d(i,v.oldIndex,v.newIndex)}},w=()=>{const v=typeof r=="string"?_?.querySelector(r):t.unrefElement(r);v&&(e=new u(v,y(y({},P),A)))},I=()=>e?.destroy(),x=(v,g)=>{if(g!==void 0)e?.option(v,g);else return e?.option(v)};return t.tryOnMounted(w),t.tryOnScopeDispose(I),{stop:I,start:w,option:x}}function d(r,i,o){const e=t.toValue(r);if(o>=0&&o<e.length){const O=e.splice(i,1)[0];a.nextTick(()=>e.splice(o,0,O))}}n.moveArrayElement=d,n.useSortable=p})(this.VueUse=this.VueUse||{},VueUse,Sortable,VueDemi);
|