@v-c/util 0.0.6 → 0.0.9

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/dist/Portal.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("vue"),o=require("./Dom/canUseDom.cjs"),r=e.defineComponent((n,a)=>{const l=e.shallowRef(),t=e.shallowRef(),u=e.shallowRef(!1);return!u.value&&o.default()&&(t.value=n.getContainer(),l.value=t.value?.parentNode,u.value=!0),e.onMounted(()=>{t.value?.parentNode===null&&l.value!==null&&l.value.appendChild(t.value)}),e.onBeforeUnmount(()=>{n.didUpdate?.(n)}),e.onUnmounted(()=>{t.value?.parentNode?.removeChild?.(t.value)}),()=>t.value?e.createVNode(e.Teleport,{to:t.value},{default:()=>[a.slots.default?.()]}):null},{props:{didUpdate:{type:Function,required:!1},getContainer:{type:Function,required:!0}},inheritAttrs:!1});exports.default=r;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("vue"),o=require("./Dom/canUseDom.cjs"),r=e.defineComponent((n,a)=>{const u=e.shallowRef(),t=e.shallowRef(),l=e.shallowRef(!1);return!l.value&&o.default()&&(t.value=n.getContainer(),u.value=t.value?.parentNode,l.value=!0),e.onMounted(()=>{t.value?.parentNode===null&&u.value!==null&&u.value.appendChild(t.value)}),e.onBeforeUnmount(()=>{n.didUpdate?.(n)}),e.onUnmounted(()=>{t.value?.parentNode?.removeChild?.(t.value)}),()=>t.value?e.createVNode(e.Teleport,{to:t.value},{default:()=>[a.slots.default?.()]}):null},{props:{didUpdate:{type:Function,required:!1,default:void 0},getContainer:{type:Function,required:!0,default:void 0}},inheritAttrs:!1});exports.default=r;
package/dist/Portal.js CHANGED
@@ -1,8 +1,8 @@
1
- import { defineComponent as u, shallowRef as a, onMounted as r, onBeforeUnmount as d, onUnmounted as i, createVNode as f, Teleport as v } from "vue";
1
+ import { defineComponent as o, shallowRef as a, onMounted as r, onBeforeUnmount as d, onUnmounted as i, createVNode as f, Teleport as v } from "vue";
2
2
  import p from "./Dom/canUseDom.js";
3
- const m = /* @__PURE__ */ u((t, l) => {
4
- const n = a(), e = a(), o = a(!1);
5
- return !o.value && p() && (e.value = t.getContainer(), n.value = e.value?.parentNode, o.value = !0), r(() => {
3
+ const m = /* @__PURE__ */ o((t, l) => {
4
+ const n = a(), e = a(), u = a(!1);
5
+ return !u.value && p() && (e.value = t.getContainer(), n.value = e.value?.parentNode, u.value = !0), r(() => {
6
6
  e.value?.parentNode === null && n.value !== null && n.value.appendChild(e.value);
7
7
  }), d(() => {
8
8
  t.didUpdate?.(t);
@@ -17,11 +17,13 @@ const m = /* @__PURE__ */ u((t, l) => {
17
17
  props: {
18
18
  didUpdate: {
19
19
  type: Function,
20
- required: !1
20
+ required: !1,
21
+ default: void 0
21
22
  },
22
23
  getContainer: {
23
24
  type: Function,
24
- required: !0
25
+ required: !0,
26
+ default: void 0
25
27
  }
26
28
  },
27
29
  inheritAttrs: !1
@@ -1 +1 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const r=require("vue"),O=require("./Dom/canUseDom.cjs"),R=require("./Dom/scrollLocker.cjs"),k=require("./Portal.cjs"),b=require("./raf.cjs"),q=require("./setStyle.cjs");let l=0;const f=O.default();function N(){return process.env.NODE_ENV==="test"?l:0}let c={};function s(e){if(!f)return null;if(e){if(typeof e=="string")return document.querySelectorAll(e)[0];if(typeof e=="function")return e();if(typeof e=="object"&&e instanceof window.HTMLElement)return e}return document.body}const E=r.defineComponent((e,S)=>{const n=r.shallowRef(),m=r.shallowRef(),C=r.shallowRef(),y=r.shallowRef(),g=()=>{n.value?.parentNode?.removeChild(n.value)},d=t=>{const{visible:o,getContainer:u}=t||{},{visible:a,getContainer:i}=e;a!==o&&f&&s(i)===document.body&&(a&&!o?l+=1:t&&(l-=1)),(typeof i=="function"&&typeof u=="function"?i.toString()!==u.toString():i!==u)&&g()},v=(t=!1)=>{if(t||n.value&&!n.value.parentNode){const o=s(e.getContainer);return o?(o.appendChild(n.value),!0):!1}return!0},h=()=>{const{wrapperClassName:t}=e;n.value&&t&&t!==n.value.className&&(n.value.className=t)},w=()=>f?(n.value||(n.value=document.createElement("div"),v(!0)),h(),n.value):null;r.onMounted(()=>{y.value=new R.default({container:s(e.getContainer)}),d(),v()||(C.value=b.default(()=>{}))}),r.onUpdated(()=>{d(e),d(e),h(),v()}),r.onBeforeUnmount(()=>{const{visible:t,getContainer:o}=e;f&&s(o)===document.body&&(l=t&&l?l-1:l),g(),b.default.cancel(C.value)});const p=()=>{l===1&&!Object.keys(c).length?(p(),c=q.default({overflow:"hidden",overflowX:"hidden",overflowY:"hidden"})):l||(q.default(c),c={},p())};return()=>{const{forceRender:t,visible:o}=e;let u=null;const a={getOpenCount:N,getContainer:w,switchScrollingEffect:p,scrollLocker:y.value};return(t||o||m.value)&&(u=r.createVNode(k.default,{getContainer:w,ref:m},{default:()=>[S?.slots?.default(a)]})),u}},{props:{visible:{type:Boolean,required:!1},getContainer:{type:[String,Function],required:!1,skipCheck:!0},wrapperClassName:{type:String,required:!1},forceRender:{type:Boolean,required:!1}}});exports.default=E;exports.getOpenCount=N;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const r=require("vue"),O=require("./Dom/canUseDom.cjs"),R=require("./Dom/scrollLocker.cjs"),k=require("./Portal.cjs"),b=require("./raf.cjs"),q=require("./setStyle.cjs");let l=0;const s=O.default();function N(){return process.env.NODE_ENV==="test"?l:0}let f={};function c(e){if(!s)return null;if(e){if(typeof e=="string")return document.querySelectorAll(e)[0];if(typeof e=="function")return e();if(typeof e=="object"&&e instanceof window.HTMLElement)return e}return document.body}const E=r.defineComponent((e,S)=>{const n=r.shallowRef(),m=r.shallowRef(),C=r.shallowRef(),y=r.shallowRef(),g=()=>{n.value?.parentNode?.removeChild(n.value)},d=t=>{const{visible:o,getContainer:u}=t||{},{visible:a,getContainer:i}=e;a!==o&&s&&c(i)===document.body&&(a&&!o?l+=1:t&&(l-=1)),(typeof i=="function"&&typeof u=="function"?i.toString()!==u.toString():i!==u)&&g()},v=(t=!1)=>{if(t||n.value&&!n.value.parentNode){const o=c(e.getContainer);return o?(o.appendChild(n.value),!0):!1}return!0},h=()=>{const{wrapperClassName:t}=e;n.value&&t&&t!==n.value.className&&(n.value.className=t)},w=()=>s?(n.value||(n.value=document.createElement("div"),v(!0)),h(),n.value):null;r.onMounted(()=>{y.value=new R.default({container:c(e.getContainer)}),d(),v()||(C.value=b.default(()=>{}))}),r.onUpdated(()=>{d(e),d(e),h(),v()}),r.onBeforeUnmount(()=>{const{visible:t,getContainer:o}=e;s&&c(o)===document.body&&(l=t&&l?l-1:l),g(),b.default.cancel(C.value)});const p=()=>{l===1&&!Object.keys(f).length?(p(),f=q.default({overflow:"hidden",overflowX:"hidden",overflowY:"hidden"})):l||(q.default(f),f={},p())};return()=>{const{forceRender:t,visible:o}=e;let u=null;const a={getOpenCount:N,getContainer:w,switchScrollingEffect:p,scrollLocker:y.value};return(t||o||m.value)&&(u=r.createVNode(k.default,{getContainer:w,ref:m},{default:()=>[S?.slots?.default(a)]})),u}},{props:{visible:{type:Boolean,required:!1,default:void 0},getContainer:{type:[String,Function],required:!1,skipCheck:!0,default:void 0},wrapperClassName:{type:String,required:!1,default:void 0},forceRender:{type:Boolean,required:!1,default:void 0}}});exports.default=E;exports.getOpenCount=N;
@@ -19,9 +19,10 @@ export interface PortalWrapperProps {
19
19
  wrapperClassName?: string;
20
20
  forceRender?: boolean;
21
21
  }
22
- declare const PortalWrapper: import('vue').DefineSetupFnComponent<PortalWrapperProps, any, DefaultSlotInfo, PortalWrapperProps & ({} | {
23
- [x: `on${Capitalize<any>}`]: (...args: any[]) => any;
24
- } | {
22
+ interface PortalWrapperEmits {
23
+ [key: string]: any;
24
+ }
25
+ declare const PortalWrapper: import('vue').DefineSetupFnComponent<PortalWrapperProps, PortalWrapperEmits, DefaultSlotInfo, PortalWrapperProps & {
25
26
  [x: `on${Capitalize<string>}`]: (...args: any[] | unknown[]) => any;
26
- }), import('vue').PublicProps>;
27
+ }, import('vue').PublicProps>;
27
28
  export default PortalWrapper;
@@ -9,8 +9,8 @@ const s = L();
9
9
  function D() {
10
10
  return process.env.NODE_ENV === "test" ? r : 0;
11
11
  }
12
- let c = {};
13
- function f(e) {
12
+ let f = {};
13
+ function c(e) {
14
14
  if (!s) return null;
15
15
  if (e) {
16
16
  if (typeof e == "string") return document.querySelectorAll(e)[0];
@@ -31,10 +31,10 @@ const W = /* @__PURE__ */ k((e, S) => {
31
31
  visible: a,
32
32
  getContainer: i
33
33
  } = e;
34
- a !== o && s && f(i) === document.body && (a && !o ? r += 1 : t && (r -= 1)), (typeof i == "function" && typeof l == "function" ? i.toString() !== l.toString() : i !== l) && g();
34
+ a !== o && s && c(i) === document.body && (a && !o ? r += 1 : t && (r -= 1)), (typeof i == "function" && typeof l == "function" ? i.toString() !== l.toString() : i !== l) && g();
35
35
  }, p = (t = !1) => {
36
36
  if (t || n.value && !n.value.parentNode) {
37
- const o = f(e.getContainer);
37
+ const o = c(e.getContainer);
38
38
  return o ? (o.appendChild(n.value), !0) : !1;
39
39
  }
40
40
  return !0;
@@ -46,7 +46,7 @@ const W = /* @__PURE__ */ k((e, S) => {
46
46
  }, w = () => s ? (n.value || (n.value = document.createElement("div"), p(!0)), h(), n.value) : null;
47
47
  q(() => {
48
48
  y.value = new P({
49
- container: f(e.getContainer)
49
+ container: c(e.getContainer)
50
50
  }), d(), p() || (C.value = b(() => {
51
51
  }));
52
52
  }), E(() => {
@@ -56,14 +56,14 @@ const W = /* @__PURE__ */ k((e, S) => {
56
56
  visible: t,
57
57
  getContainer: o
58
58
  } = e;
59
- s && f(o) === document.body && (r = t && r ? r - 1 : r), g(), b.cancel(C.value);
59
+ s && c(o) === document.body && (r = t && r ? r - 1 : r), g(), b.cancel(C.value);
60
60
  });
61
61
  const m = () => {
62
- r === 1 && !Object.keys(c).length ? (m(), c = N({
62
+ r === 1 && !Object.keys(f).length ? (m(), f = N({
63
63
  overflow: "hidden",
64
64
  overflowX: "hidden",
65
65
  overflowY: "hidden"
66
- })) : r || (N(c), c = {}, m());
66
+ })) : r || (N(f), f = {}, m());
67
67
  };
68
68
  return () => {
69
69
  const {
@@ -88,20 +88,24 @@ const W = /* @__PURE__ */ k((e, S) => {
88
88
  props: {
89
89
  visible: {
90
90
  type: Boolean,
91
- required: !1
91
+ required: !1,
92
+ default: void 0
92
93
  },
93
94
  getContainer: {
94
95
  type: [String, Function],
95
96
  required: !1,
96
- skipCheck: !0
97
+ skipCheck: !0,
98
+ default: void 0
97
99
  },
98
100
  wrapperClassName: {
99
101
  type: String,
100
- required: !1
102
+ required: !1,
103
+ default: void 0
101
104
  },
102
105
  forceRender: {
103
106
  type: Boolean,
104
- required: !1
107
+ required: !1,
108
+ default: void 0
105
109
  }
106
110
  }
107
111
  });
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});function f(t){let e="";if(typeof t=="string"||typeof t=="number")e+=t;else if(typeof t=="object")if(Array.isArray(t)){for(let o=0;o<t.length;o++)if(t[o]){const r=f(t[o]);r&&(e&&(e+=" "),e+=r)}}else for(const o in t)t[o]&&(e&&(e+=" "),e+=o);return e}function l(...t){let e="";for(let o=0;o<t.length;o++){const r=t[o];if(r){const s=f(r);s&&(e&&(e+=" "),e+=s)}}return e}const n=l;exports.clsx=n;exports.default=l;
@@ -0,0 +1,9 @@
1
+ type ClassValue = string | number | boolean | undefined | null | ClassDictionary | ClassArray;
2
+ interface ClassDictionary {
3
+ [id: string]: any;
4
+ }
5
+ interface ClassArray extends Array<ClassValue> {
6
+ }
7
+ export default function classNames(...args: ClassValue[]): string;
8
+ export declare const clsx: typeof classNames;
9
+ export {};
@@ -0,0 +1,32 @@
1
+ function r(t) {
2
+ let e = "";
3
+ if (typeof t == "string" || typeof t == "number")
4
+ e += t;
5
+ else if (typeof t == "object")
6
+ if (Array.isArray(t)) {
7
+ for (let f = 0; f < t.length; f++)
8
+ if (t[f]) {
9
+ const n = r(t[f]);
10
+ n && (e && (e += " "), e += n);
11
+ }
12
+ } else
13
+ for (const f in t)
14
+ t[f] && (e && (e += " "), e += f);
15
+ return e;
16
+ }
17
+ function s(...t) {
18
+ let e = "";
19
+ for (let f = 0; f < t.length; f++) {
20
+ const n = t[f];
21
+ if (n) {
22
+ const o = r(n);
23
+ o && (e && (e += " "), e += o);
24
+ }
25
+ }
26
+ return e;
27
+ }
28
+ const l = s;
29
+ export {
30
+ l as clsx,
31
+ s as default
32
+ };
package/dist/index.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./utils/get.cjs"),t=require("./utils/set.cjs"),r=require("./warning.cjs");exports.get=e.default;exports.set=t.default;exports.warning=r.warningOnce;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./classnames.cjs"),t=require("./utils/get.cjs"),s=require("./utils/set.cjs"),r=require("./warning.cjs");exports.classNames=e.default;exports.clsx=e.clsx;exports.get=t.default;exports.set=s.default;exports.warning=r.warningOnce;
package/dist/index.d.ts CHANGED
@@ -1,3 +1,4 @@
1
+ export { default as classNames, clsx } from './classnames';
1
2
  export { default as get } from './utils/get';
2
3
  export { default as set } from './utils/set';
3
4
  export { default as warning } from './warning';
package/dist/index.js CHANGED
@@ -1,8 +1,11 @@
1
- import { default as a } from "./utils/get.js";
2
- import { default as o } from "./utils/set.js";
1
+ import { default as r, clsx as s } from "./classnames.js";
2
+ import { default as o } from "./utils/get.js";
3
+ import { default as l } from "./utils/set.js";
3
4
  import { warningOnce as n } from "./warning.js";
4
5
  export {
5
- a as get,
6
- o as set,
6
+ r as classNames,
7
+ s as clsx,
8
+ o as get,
9
+ l as set,
7
10
  n as warning
8
11
  };
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const u=require("vue"),y=require("../isValid.cjs");function a(t){return t&&(t.type===u.Comment||t.type===u.Fragment&&t.children.length===0||t.type===u.Text&&t.children.trim()==="")}function o(t=[]){const r=[];return t.forEach(n=>{Array.isArray(n)?r.push(...n):n?.type===u.Fragment?r.push(...o(n.children)):r.push(n)}),r.filter(n=>!a(n))}const p=Symbol("skipFlatten");function f(t,r=!0){const n=Array.isArray(t)?t:[t],s=[];return n.forEach(e=>{Array.isArray(e)?s.push(...f(e,r)):y.default(e)?s.push(e):e&&typeof e=="object"&&e.type===u.Fragment?e.key===p?s.push(e):s.push(...f(e.children,r)):e&&u.isVNode(e)&&(r&&!a(e)?s.push(e):r||s.push(e))}),r?o(s):s}exports.filterEmpty=o;exports.flattenChildren=f;exports.isEmptyElement=a;exports.skipFlattenKey=p;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("vue"),i=require("../isValid.cjs");function u(e){return e&&(e.type===o.Comment||e.type===o.Fragment&&e.children.length===0||e.type===o.Text&&e.children.trim()==="")}function a(e=[]){const t=[];return e.forEach(r=>{Array.isArray(r)?t.push(...r):r?.type===o.Fragment?t.push(...a(r.children)):t.push(r)}),t.filter(r=>!u(r))}const p=Symbol("skipFlatten");function f(e,t=!0){const r=Array.isArray(e)?e:[e],s=[];return r.forEach(n=>{Array.isArray(n)?s.push(...f(n,t)):i.default(n)?s.push(n):n&&typeof n=="object"&&n.type===o.Fragment?n.key===p?s.push(n):s.push(...f(n.children,t)):n&&o.isVNode(n)&&(t&&!u(n)?s.push(n):t||s.push(n))}),t?a(s):s}function y(e,...t){const r={};return t.forEach(s=>{r[s]=o.toRef(e,s)}),r}function m(e){const t={};return Object.keys(e).forEach(r=>{const s=e[r];s!==void 0&&(t[r]=s)}),t}exports.filterEmpty=a;exports.flattenChildren=f;exports.isEmptyElement=u;exports.removeUndefined=m;exports.skipFlattenKey=p;exports.toPropsRefs=y;
@@ -1,6 +1,8 @@
1
- import { VNode, VNodeNormalizedChildren } from 'vue';
1
+ import { Ref, VNode, VNodeNormalizedChildren } from 'vue';
2
2
  export declare function isEmptyElement(c: any): boolean;
3
3
  export declare function filterEmpty(children?: any[]): any[];
4
4
  export declare const skipFlattenKey: unique symbol;
5
5
  declare function flattenChildren(children?: VNode | VNodeNormalizedChildren, isFilterEmpty?: boolean): any[];
6
6
  export { flattenChildren };
7
+ export declare function toPropsRefs<T extends Record<string, any>, K extends keyof T>(obj: T, ...args: K[]): { [key in K]-?: Ref<T[key]>; };
8
+ export declare function removeUndefined<T>(obj: T): Partial<T>;
@@ -1,24 +1,39 @@
1
- import { Comment as a, Fragment as f, Text as y, isVNode as m } from "vue";
1
+ import { Comment as a, Fragment as o, Text as y, isVNode as m, toRef as i } from "vue";
2
2
  import A from "../isValid.js";
3
- function p(r) {
4
- return r && (r.type === a || r.type === f && r.children.length === 0 || r.type === y && r.children.trim() === "");
3
+ function u(e) {
4
+ return e && (e.type === a || e.type === o && e.children.length === 0 || e.type === y && e.children.trim() === "");
5
5
  }
6
- function u(r = []) {
7
- const t = [];
6
+ function p(e = []) {
7
+ const r = [];
8
+ return e.forEach((t) => {
9
+ Array.isArray(t) ? r.push(...t) : t?.type === o ? r.push(...p(t.children)) : r.push(t);
10
+ }), r.filter((t) => !u(t));
11
+ }
12
+ const v = Symbol("skipFlatten");
13
+ function f(e, r = !0) {
14
+ const t = Array.isArray(e) ? e : [e], s = [];
15
+ return t.forEach((n) => {
16
+ Array.isArray(n) ? s.push(...f(n, r)) : A(n) ? s.push(n) : n && typeof n == "object" && n.type === o ? n.key === v ? s.push(n) : s.push(...f(n.children, r)) : n && m(n) && (r && !u(n) ? s.push(n) : r || s.push(n));
17
+ }), r ? p(s) : s;
18
+ }
19
+ function g(e, ...r) {
20
+ const t = {};
8
21
  return r.forEach((s) => {
9
- Array.isArray(s) ? t.push(...s) : s?.type === f ? t.push(...u(s.children)) : t.push(s);
10
- }), t.filter((s) => !p(s));
22
+ t[s] = i(e, s);
23
+ }), t;
11
24
  }
12
- const i = Symbol("skipFlatten");
13
- function o(r, t = !0) {
14
- const s = Array.isArray(r) ? r : [r], n = [];
15
- return s.forEach((e) => {
16
- Array.isArray(e) ? n.push(...o(e, t)) : A(e) ? n.push(e) : e && typeof e == "object" && e.type === f ? e.key === i ? n.push(e) : n.push(...o(e.children, t)) : e && m(e) && (t && !p(e) ? n.push(e) : t || n.push(e));
17
- }), t ? u(n) : n;
25
+ function k(e) {
26
+ const r = {};
27
+ return Object.keys(e).forEach((t) => {
28
+ const s = e[t];
29
+ s !== void 0 && (r[t] = s);
30
+ }), r;
18
31
  }
19
32
  export {
20
- u as filterEmpty,
21
- o as flattenChildren,
22
- p as isEmptyElement,
23
- i as skipFlattenKey
33
+ p as filterEmpty,
34
+ f as flattenChildren,
35
+ u as isEmptyElement,
36
+ k as removeUndefined,
37
+ v as skipFlattenKey,
38
+ g as toPropsRefs
24
39
  };
package/dist/raf.cjs CHANGED
@@ -1 +1 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});let u=e=>+setTimeout(e,16),l=e=>clearTimeout(e);typeof window<"u"&&"requestAnimationFrame"in window&&(u=e=>window.requestAnimationFrame(e),l=e=>window.cancelAnimationFrame(e));let c=0;const n=new Map;function d(e){n.delete(e)}function o(e,t=1){c+=1;const i=c;function a(r){if(r===0)d(i),e();else{const s=u(()=>{a(r-1)});n.set(i,s)}}return a(t),i}o.cancel=e=>{const t=n.get(e);return d(e),l(t)};process.env.NODE_ENV!=="production"&&(o.ids=()=>n);exports.default=o;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});let c=e=>+setTimeout(e,16),l=e=>clearTimeout(e);typeof window<"u"&&"requestAnimationFrame"in window&&(c=e=>window.requestAnimationFrame(e),l=e=>window.cancelAnimationFrame(e));let u=0;const i=new Map;function f(e){i.delete(e)}function t(e,n=1){u+=1;const o=u;function r(a){if(a===0)f(o),e();else{const d=c(()=>{r(a-1)});i.set(o,d)}}return r(n),o}t.cancel=e=>{const n=i.get(e);return f(e),l(n)};process.env.NODE_ENV!=="production"&&(t.ids=()=>i);function s(e){let n=null;return()=>{n!==null&&t.cancel(n),n=t(e)}}exports.default=t;exports.rafDebounce=s;
package/dist/raf.d.ts CHANGED
@@ -4,3 +4,4 @@ declare namespace wrapperRaf {
4
4
  var ids: () => Map<number, number>;
5
5
  }
6
6
  export default wrapperRaf;
7
+ export declare function rafDebounce(fn: () => void): () => void;
package/dist/raf.js CHANGED
@@ -1,30 +1,37 @@
1
- let c = (e) => +setTimeout(e, 16), f = (e) => clearTimeout(e);
2
- typeof window < "u" && "requestAnimationFrame" in window && (c = (e) => window.requestAnimationFrame(e), f = (e) => window.cancelAnimationFrame(e));
3
- let r = 0;
4
- const n = /* @__PURE__ */ new Map();
5
- function d(e) {
6
- n.delete(e);
1
+ let l = (e) => +setTimeout(e, 16), u = (e) => clearTimeout(e);
2
+ typeof window < "u" && "requestAnimationFrame" in window && (l = (e) => window.requestAnimationFrame(e), u = (e) => window.cancelAnimationFrame(e));
3
+ let c = 0;
4
+ const a = /* @__PURE__ */ new Map();
5
+ function f(e) {
6
+ a.delete(e);
7
7
  }
8
- function l(e, t = 1) {
9
- r += 1;
10
- const a = r;
11
- function i(o) {
12
- if (o === 0)
13
- d(a), e();
8
+ function t(e, n = 1) {
9
+ c += 1;
10
+ const i = c;
11
+ function o(r) {
12
+ if (r === 0)
13
+ f(i), e();
14
14
  else {
15
- const s = c(() => {
16
- i(o - 1);
15
+ const d = l(() => {
16
+ o(r - 1);
17
17
  });
18
- n.set(a, s);
18
+ a.set(i, d);
19
19
  }
20
20
  }
21
- return i(t), a;
21
+ return o(n), i;
22
22
  }
23
- l.cancel = (e) => {
24
- const t = n.get(e);
25
- return d(e), f(t);
23
+ t.cancel = (e) => {
24
+ const n = a.get(e);
25
+ return f(e), u(n);
26
26
  };
27
- process.env.NODE_ENV !== "production" && (l.ids = () => n);
27
+ process.env.NODE_ENV !== "production" && (t.ids = () => a);
28
+ function s(e) {
29
+ let n = null;
30
+ return () => {
31
+ n !== null && t.cancel(n), n = t(e);
32
+ };
33
+ }
28
34
  export {
29
- l as default
35
+ t as default,
36
+ s as rafDebounce
30
37
  };
@@ -1 +1 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const l=require("vue");function v(e){return e!==void 0&&(e==="topLeft"||e==="topRight")?"slide-down":"slide-up"}function u(e,r={}){return e?e?{name:e,appear:!0,enterFromClass:`${e}-enter ${e}-enter-prepare ${e}-enter-start`,enterActiveClass:`${e}-enter ${e}-enter-prepare`,enterToClass:`${e}-enter ${e}-enter-active`,leaveFromClass:` ${e}-leave`,leaveActiveClass:`${e}-leave ${e}-leave-active`,leaveToClass:`${e}-leave ${e}-leave-active`,...r}:{css:!1,...r}:{}}function c(e,r={}){return e?{name:e,appear:!0,appearActiveClass:`${e}`,appearToClass:`${e}-appear ${e}-appear-active`,enterFromClass:`${e}-appear ${e}-enter ${e}-appear-prepare ${e}-enter-prepare`,enterActiveClass:`${e}`,enterToClass:`${e}-enter ${e}-appear ${e}-appear-active ${e}-enter-active`,leaveActiveClass:`${e} ${e}-leave`,leaveToClass:`${e}-leave-active`,...r}:{css:!1,...r}}const o=()=>({height:0,opacity:0}),$=e=>({height:`${e.scrollHeight}px`,opacity:1}),s=e=>({height:`${e.offsetHeight}px`});function a(e="ant-motion-collapse",r,p){return{name:e,appear:!0,css:!0,onBeforeEnter:t=>{p.value=e,r.value=o()},onEnter:t=>{l.nextTick(()=>{r.value=$(t)})},onAfterEnter:()=>{p.value="",r.value={}},onBeforeLeave:t=>{p.value=e,r.value=s(t)},onLeave:t=>{setTimeout(()=>{r.value=o()})},onAfterLeave:()=>{p.value="",r.value={}}}}function n(e,r,p){return p!==void 0?p:`${e}-${r}`}exports.collapseMotion=a;exports.getTransitionDirection=v;exports.getTransitionGroupProps=c;exports.getTransitionName=n;exports.getTransitionProps=u;
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const o=require("vue");function u(e){return e!==void 0&&(e==="topLeft"||e==="topRight")?"slide-down":"slide-up"}function $(e,r={}){return e?e?{name:e,appear:!0,enterFromClass:`${e} ${e}-enter ${e}-enter-prepare ${e}-enter-start`,enterActiveClass:`${e} ${e}-enter ${e}-enter-prepare`,enterToClass:`${e} ${e}-enter ${e}-enter-active`,leaveFromClass:`${e} ${e}-leave`,leaveActiveClass:`${e} ${e}-leave ${e}-leave-active`,leaveToClass:`${e} ${e}-leave ${e}-leave-active`,...r}:{css:!1,...r}:{}}function t(e,r={}){return e?{name:e,appear:!0,appearActiveClass:`${e}`,appearToClass:`${e}-appear ${e}-appear-active`,enterFromClass:`${e}-appear ${e}-enter ${e}-appear-prepare ${e}-enter-prepare`,enterActiveClass:`${e}`,enterToClass:`${e}-enter ${e}-appear ${e}-appear-active ${e}-enter-active`,leaveActiveClass:`${e} ${e}-leave`,leaveToClass:`${e}-leave-active`,...r}:{css:!1,...r}}const v=()=>({height:0,opacity:0}),c=e=>({height:`${e.scrollHeight}px`,opacity:1}),s=e=>({height:`${e.offsetHeight}px`});function g(e="ant-motion-collapse",r,p){return{name:e,appear:!0,css:!0,onBeforeEnter:l=>{p.value=e,r.value=v()},onEnter:l=>{o.nextTick(()=>{r.value=c(l)})},onAfterEnter:()=>{p.value="",r.value={}},onBeforeLeave:l=>{p.value=e,r.value=s(l)},onLeave:l=>{setTimeout(()=>{r.value=v()})},onAfterLeave:()=>{p.value="",r.value={}}}}function f(e,r,p){return p!==void 0?p:`${e}-${r}`}exports.collapseMotion=g;exports.getTransitionDirection=u;exports.getTransitionGroupProps=t;exports.getTransitionName=f;exports.getTransitionProps=$;
@@ -1,8 +1,8 @@
1
- import { nextTick as o } from "vue";
2
- function c(e) {
1
+ import { nextTick as $ } from "vue";
2
+ function t(e) {
3
3
  return e !== void 0 && (e === "topLeft" || e === "topRight") ? "slide-down" : "slide-up";
4
4
  }
5
- function a(e, r = {}) {
5
+ function f(e, r = {}) {
6
6
  return e ? e ? {
7
7
  name: e,
8
8
  appear: !0,
@@ -10,16 +10,16 @@ function a(e, r = {}) {
10
10
  // appearFromClass: `${transitionName}-appear ${transitionName}-appear-prepare`,
11
11
  // appearActiveClass: `antdv-base-transtion`,
12
12
  // appearToClass: `${transitionName}-appear ${transitionName}-appear-active`,
13
- enterFromClass: `${e}-enter ${e}-enter-prepare ${e}-enter-start`,
14
- enterActiveClass: `${e}-enter ${e}-enter-prepare`,
15
- enterToClass: `${e}-enter ${e}-enter-active`,
16
- leaveFromClass: ` ${e}-leave`,
17
- leaveActiveClass: `${e}-leave ${e}-leave-active`,
18
- leaveToClass: `${e}-leave ${e}-leave-active`,
13
+ enterFromClass: `${e} ${e}-enter ${e}-enter-prepare ${e}-enter-start`,
14
+ enterActiveClass: `${e} ${e}-enter ${e}-enter-prepare`,
15
+ enterToClass: `${e} ${e}-enter ${e}-enter-active`,
16
+ leaveFromClass: `${e} ${e}-leave`,
17
+ leaveActiveClass: `${e} ${e}-leave ${e}-leave-active`,
18
+ leaveToClass: `${e} ${e}-leave ${e}-leave-active`,
19
19
  ...r
20
20
  } : { css: !1, ...r } : {};
21
21
  }
22
- function s(e, r = {}) {
22
+ function g(e, r = {}) {
23
23
  return e ? {
24
24
  name: e,
25
25
  appear: !0,
@@ -34,11 +34,11 @@ function s(e, r = {}) {
34
34
  ...r
35
35
  } : { css: !1, ...r };
36
36
  }
37
- const l = () => ({ height: 0, opacity: 0 }), t = (e) => ({
37
+ const l = () => ({ height: 0, opacity: 0 }), u = (e) => ({
38
38
  height: `${e.scrollHeight}px`,
39
39
  opacity: 1
40
- }), u = (e) => ({ height: `${e.offsetHeight}px` });
41
- function f(e = "ant-motion-collapse", r, p) {
40
+ }), c = (e) => ({ height: `${e.offsetHeight}px` });
41
+ function C(e = "ant-motion-collapse", r, p) {
42
42
  return {
43
43
  name: e,
44
44
  appear: !0,
@@ -47,15 +47,15 @@ function f(e = "ant-motion-collapse", r, p) {
47
47
  p.value = e, r.value = l();
48
48
  },
49
49
  onEnter: (v) => {
50
- o(() => {
51
- r.value = t(v);
50
+ $(() => {
51
+ r.value = u(v);
52
52
  });
53
53
  },
54
54
  onAfterEnter: () => {
55
55
  p.value = "", r.value = {};
56
56
  },
57
57
  onBeforeLeave: (v) => {
58
- p.value = e, r.value = u(v);
58
+ p.value = e, r.value = c(v);
59
59
  },
60
60
  onLeave: (v) => {
61
61
  setTimeout(() => {
@@ -67,13 +67,13 @@ function f(e = "ant-motion-collapse", r, p) {
67
67
  }
68
68
  };
69
69
  }
70
- function g(e, r, p) {
70
+ function s(e, r, p) {
71
71
  return p !== void 0 ? p : `${e}-${r}`;
72
72
  }
73
73
  export {
74
- f as collapseMotion,
75
- c as getTransitionDirection,
76
- s as getTransitionGroupProps,
77
- g as getTransitionName,
78
- a as getTransitionProps
74
+ C as collapseMotion,
75
+ t as getTransitionDirection,
76
+ g as getTransitionGroupProps,
77
+ s as getTransitionName,
78
+ f as getTransitionProps
79
79
  };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});function i(){let t=[];return(r,e)=>(t=JSON.stringify(e),r(e,t))}function n(){let t=!1;return(r,e)=>{if(!t)return t=!0,r(e)}}exports.renderFirstTrigger=n;exports.watchState=i;
@@ -0,0 +1,2 @@
1
+ export declare function watchState(): (fn: any, args: any[]) => any;
2
+ export declare function renderFirstTrigger(): (fn: any, args: any[]) => any;
@@ -0,0 +1,15 @@
1
+ function n() {
2
+ let t = [];
3
+ return (e, r) => (t = JSON.stringify(r), e(r, t));
4
+ }
5
+ function i() {
6
+ let t = !1;
7
+ return (e, r) => {
8
+ if (!t)
9
+ return t = !0, e(r);
10
+ };
11
+ }
12
+ export {
13
+ i as renderFirstTrigger,
14
+ n as watchState
15
+ };
package/package.json CHANGED
@@ -1,15 +1,11 @@
1
1
  {
2
2
  "name": "@v-c/util",
3
3
  "type": "module",
4
- "version": "0.0.6",
4
+ "version": "0.0.9",
5
5
  "description": "Vue3 components utils",
6
6
  "publishConfig": {
7
7
  "access": "public"
8
8
  },
9
- "files": [
10
- "dist",
11
- "package.json"
12
- ],
13
9
  "author": {
14
10
  "name": "aibayanyu20",
15
11
  "email": "aibayanyu@qq.com",
@@ -17,6 +13,10 @@
17
13
  },
18
14
  "main": "dist/index.js",
19
15
  "types": "dist/index.d.ts",
16
+ "files": [
17
+ "dist",
18
+ "package.json"
19
+ ],
20
20
  "peerDependencies": {
21
21
  "vue": "^3.0.0"
22
22
  },