eco-vue-js 0.9.21 → 0.9.23

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.
Files changed (66) hide show
  1. package/dist/components/FieldWrapper/WFieldWrapper.vue.d.ts.map +1 -1
  2. package/dist/components/FieldWrapper/WFieldWrapper.vue.js +5 -4
  3. package/dist/components/FieldWrapper/components/FilterButton.vue.d.ts +4 -2
  4. package/dist/components/FieldWrapper/components/FilterButton.vue.d.ts.map +1 -1
  5. package/dist/components/FieldWrapper/components/FilterButton.vue.js +9 -3
  6. package/dist/components/Form/WForm.vue.d.ts +13 -8
  7. package/dist/components/Form/WForm.vue.d.ts.map +1 -1
  8. package/dist/components/Form/WForm.vue.js +86 -32
  9. package/dist/components/Form/WFormValidator.vue.d.ts +3 -2
  10. package/dist/components/Form/WFormValidator.vue.d.ts.map +1 -1
  11. package/dist/components/Form/WFormValidator.vue.js +4 -0
  12. package/dist/components/Form/models/injection.d.ts +2 -1
  13. package/dist/components/Form/models/injection.d.ts.map +1 -1
  14. package/dist/components/Form/models/utils.d.ts +3 -0
  15. package/dist/components/Form/models/utils.d.ts.map +1 -1
  16. package/dist/components/Form/models/utils.js +1 -6
  17. package/dist/components/Form/use/useFormValueMap.d.ts +7 -0
  18. package/dist/components/Form/use/useFormValueMap.d.ts.map +1 -0
  19. package/dist/components/Form/use/useFormValueMap.js +36 -0
  20. package/dist/components/InfiniteList/components/InfiniteListPage.vue.d.ts.map +1 -1
  21. package/dist/components/InfiniteList/components/InfiniteListPage.vue.js +9 -11
  22. package/dist/components/InfiniteList/components/InfiniteListPages.vue.d.ts.map +1 -1
  23. package/dist/components/InfiniteList/components/InfiniteListPages.vue.js +11 -3
  24. package/dist/components/InfiniteList/components/InfiniteListScroll.vue.d.ts +6 -2
  25. package/dist/components/InfiniteList/components/InfiniteListScroll.vue.d.ts.map +1 -1
  26. package/dist/components/InfiniteList/components/InfiniteListScroll.vue.js +7 -5
  27. package/dist/components/InfiniteList/models/utils.d.ts +1 -1
  28. package/dist/components/InfiniteList/models/utils.d.ts.map +1 -1
  29. package/dist/components/InfiniteList/models/utils.js +2 -2
  30. package/dist/components/List/WListCard.vue.d.ts +1 -1
  31. package/dist/components/Modal/WModalStepper.vue.d.ts +761 -471
  32. package/dist/components/Modal/WModalStepper.vue.d.ts.map +1 -1
  33. package/dist/components/Tabs/WTabs.vue.d.ts +567 -45
  34. package/dist/components/Tabs/WTabs.vue.d.ts.map +1 -1
  35. package/dist/components/Tabs/WTabs.vue.js +147 -129
  36. package/dist/components/Tabs/WTabsColumns.vue.d.ts +4 -2
  37. package/dist/components/Tabs/WTabsColumns.vue.d.ts.map +1 -1
  38. package/dist/components/Tabs/WTabsItem.vue.d.ts +2 -18
  39. package/dist/components/Tabs/WTabsItem.vue.d.ts.map +1 -1
  40. package/dist/components/Tabs/components/TabItem.vue.d.ts +51 -43
  41. package/dist/components/Tabs/components/TabItem.vue.d.ts.map +1 -1
  42. package/dist/components/Tabs/components/TabItem.vue.js +2 -15
  43. package/dist/components/Tabs/types.d.ts +10 -0
  44. package/dist/components/Tabs/types.d.ts.map +1 -1
  45. package/package.json +1 -1
  46. package/dist/components/Form/use/useFormErrorMessageMap.d.ts +0 -8
  47. package/dist/components/Form/use/useFormErrorMessageMap.d.ts.map +0 -1
  48. package/dist/components/Form/use/useFormErrorMessageMap.js +0 -32
  49. package/dist/components/Form/use/useFormHasChangesMap.d.ts +0 -6
  50. package/dist/components/Form/use/useFormHasChangesMap.d.ts.map +0 -1
  51. package/dist/components/Form/use/useFormHasChangesMap.js +0 -27
  52. package/dist/components/Form/use/useFormHasValueMap.d.ts +0 -6
  53. package/dist/components/Form/use/useFormHasValueMap.d.ts.map +0 -1
  54. package/dist/components/Form/use/useFormHasValueMap.js +0 -31
  55. package/dist/components/Form/use/useFormInitModelMap.d.ts +0 -6
  56. package/dist/components/Form/use/useFormInitModelMap.d.ts.map +0 -1
  57. package/dist/components/Form/use/useFormInitModelMap.js +0 -31
  58. package/dist/components/Form/use/useFormInvalidateMap.d.ts +0 -8
  59. package/dist/components/Form/use/useFormInvalidateMap.d.ts.map +0 -1
  60. package/dist/components/Form/use/useFormInvalidateMap.js +0 -32
  61. package/dist/components/Form/use/useFormTitleMap.d.ts +0 -6
  62. package/dist/components/Form/use/useFormTitleMap.d.ts.map +0 -1
  63. package/dist/components/Form/use/useFormTitleMap.js +0 -29
  64. package/dist/components/Form/use/useFormValidateMap.d.ts +0 -9
  65. package/dist/components/Form/use/useFormValidateMap.d.ts.map +0 -1
  66. package/dist/components/Form/use/useFormValidateMap.js +0 -39
@@ -1 +1 @@
1
- {"version":3,"file":"WFieldWrapper.vue.d.ts","sourceRoot":"","sources":["../../../src/components/FieldWrapper/WFieldWrapper.vue"],"names":[],"mappings":"AAoNA,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,SAAS,CAAA;AA6C9C,iBAAS,cAAc;;uBA6PI,GAAG;0BACC,GAAG;;;gCAzQP,OAAO,KAAG,IAAI;;YA0Qb,GAAG;;;gCA1QJ,OAAO,KAAG,IAAI;;YA2QX,GAAG;uBACL,GAAG;;;;;WAUjB,OAAO,IAA6B;EAEjD;AAoBD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;;;;kFASnB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAWpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
1
+ {"version":3,"file":"WFieldWrapper.vue.d.ts","sourceRoot":"","sources":["../../../src/components/FieldWrapper/WFieldWrapper.vue"],"names":[],"mappings":"AAsNA,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,SAAS,CAAA;AA6C9C,iBAAS,cAAc;;uBA6PI,GAAG;0BACC,GAAG;;;gCAzQP,OAAO,KAAG,IAAI;;YA0Qb,GAAG;;;gCA1QJ,OAAO,KAAG,IAAI;;YA2QX,GAAG;uBACL,GAAG;;;;;WAUjB,OAAO,IAA6B;EAEjD;AAoBD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;;;;kFASnB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAWpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
@@ -64,7 +64,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
64
64
  const id = useId();
65
65
  const focused = ref(false);
66
66
  const encodedQueryParam = computed(() => {
67
- if (!props.filterField) return void 0;
67
+ if (props.filterField === void 0) return void 0;
68
68
  return encodeQueryParam(props.filterValue === void 0 ? props.modelValue : props.filterValue);
69
69
  });
70
70
  const setFocused = (value) => {
@@ -119,7 +119,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
119
119
  renderSlot(_ctx.$slots, "subtitle"),
120
120
  createElementVNode("div", {
121
121
  class: normalizeClass(["grid grid-cols-[1fr,auto]", {
122
- "pr-9": !_ctx.title && !_ctx.$slots.title && _ctx.filterField && encodedQueryParam.value
122
+ "pr-9": !_ctx.title && !_ctx.$slots.title && _ctx.filterField
123
123
  }])
124
124
  }, [
125
125
  !_ctx.skeleton ? (openBlock(), createElementBlock("div", {
@@ -180,12 +180,13 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
180
180
  _ctx.$slots.right ? (openBlock(), createElementBlock("div", _hoisted_5, [
181
181
  renderSlot(_ctx.$slots, "right")
182
182
  ], 512)) : createCommentVNode("", true),
183
- !_ctx.title && !_ctx.$slots.title && _ctx.filterField && encodedQueryParam.value ? (openBlock(), createBlock(_sfc_main$1, {
183
+ !_ctx.title && !_ctx.$slots.title && _ctx.filterField ? (openBlock(), createBlock(_sfc_main$1, {
184
184
  key: 3,
185
185
  "filter-field": _ctx.filterField,
186
186
  "encoded-query-param": encodedQueryParam.value,
187
+ skeleton: _ctx.skeleton,
187
188
  class: "absolute right-0 self-center"
188
- }, null, 8, ["filter-field", "encoded-query-param"])) : createCommentVNode("", true)
189
+ }, null, 8, ["filter-field", "encoded-query-param", "skeleton"])) : createCommentVNode("", true)
189
190
  ], 2)
190
191
  ], 10, _hoisted_1),
191
192
  _ctx.description ? (openBlock(), createElementBlock("div", {
@@ -1,9 +1,11 @@
1
1
  declare const _default: import('vue').DefineComponent<{
2
2
  filterField: string;
3
- encodedQueryParam: EncodeQueryParam<unknown>;
3
+ encodedQueryParam: EncodeQueryParam<unknown> | undefined;
4
+ skeleton?: boolean;
4
5
  }, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{
5
6
  filterField: string;
6
- encodedQueryParam: EncodeQueryParam<unknown>;
7
+ encodedQueryParam: EncodeQueryParam<unknown> | undefined;
8
+ skeleton?: boolean;
7
9
  }> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
8
10
  export default _default;
9
11
  //# sourceMappingURL=FilterButton.vue.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"FilterButton.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/FieldWrapper/components/FilterButton.vue"],"names":[],"mappings":";iBA2Be,MAAM;uBACA,gBAAgB,CAAC,OAAO,CAAC;;iBAD/B,MAAM;uBACA,gBAAgB,CAAC,OAAO,CAAC;;AAyE9C,wBAMG"}
1
+ {"version":3,"file":"FilterButton.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/FieldWrapper/components/FilterButton.vue"],"names":[],"mappings":";iBAkCe,MAAM;uBACA,gBAAgB,CAAC,OAAO,CAAC,GAAG,SAAS;eAC7C,OAAO;;iBAFL,MAAM;uBACA,gBAAgB,CAAC,OAAO,CAAC,GAAG,SAAS;eAC7C,OAAO;;AAgFpB,wBAMG"}
@@ -1,15 +1,21 @@
1
1
  import { defineComponent, openBlock, createElementBlock, normalizeClass, createVNode, unref } from 'vue';
2
2
  import IconFilter from '../../../assets/icons/sax/IconFilter.svg.js';
3
3
 
4
+ const _hoisted_1 = {
5
+ key: 0,
6
+ class: "square-5"
7
+ };
4
8
  const _sfc_main = /* @__PURE__ */ defineComponent({
5
9
  __name: "FilterButton",
6
10
  props: {
7
11
  filterField: {},
8
- encodedQueryParam: {}
12
+ encodedQueryParam: {},
13
+ skeleton: { type: Boolean }
9
14
  },
10
15
  setup(__props) {
11
16
  return (_ctx, _cache) => {
12
- return openBlock(), createElementBlock("button", {
17
+ return _ctx.skeleton || !_ctx.encodedQueryParam ? (openBlock(), createElementBlock("div", _hoisted_1)) : (openBlock(), createElementBlock("button", {
18
+ key: 1,
13
19
  class: normalizeClass(["w-ripple w-ripple-hover rounded p-0.5", {
14
20
  "text-description": _ctx.$route.query[_ctx.filterField] !== _ctx.encodedQueryParam,
15
21
  "bg-primary-default dark:bg-primary-dark text-default dark:text-default-dark": _ctx.$route.query[_ctx.filterField] === _ctx.encodedQueryParam
@@ -17,7 +23,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
17
23
  onClick: _cache[0] || (_cache[0] = ($event) => _ctx.$router.replace({ query: { ..._ctx.$route.query, [_ctx.filterField]: _ctx.$route.query[_ctx.filterField] === _ctx.encodedQueryParam ? void 0 : _ctx.encodedQueryParam } }))
18
24
  }, [
19
25
  createVNode(unref(IconFilter), { class: "square-4" })
20
- ], 2);
26
+ ], 2));
21
27
  };
22
28
  }
23
29
  });
@@ -1,3 +1,4 @@
1
+ import { ValidatePath } from './models/utils';
1
2
  declare function __VLS_template(): {
2
3
  slots: {
3
4
  default?(_: {}): any;
@@ -12,14 +13,18 @@ declare const __VLS_component: import('vue').DefineComponent<{
12
13
  noTag?: boolean;
13
14
  }, {
14
15
  isValid: import('vue').ComputedRef<boolean>;
15
- hasChanges: import('vue').ComputedRef<boolean>;
16
- hasValue: import('vue').ComputedRef<boolean | null>;
17
- validate: (silent?: boolean, path?: import('./use/useFormValidateMap').ValidatePath) => string | undefined;
18
- invalidate: (payload: {
19
- [x: string]: string | string[] | undefined;
20
- }) => void;
21
- initModel: () => void;
22
- errorMessage: import('vue').ComputedRef<string>;
16
+ hasChanges: import('vue').Ref<boolean, boolean>;
17
+ hasChangesMap: import('vue').Ref<Record<string, boolean>, Record<string, boolean>>;
18
+ hasValue: import('vue').Ref<boolean | null, boolean | null>;
19
+ hasValueMap: import('vue').Ref<Record<string, boolean | null>, Record<string, boolean | null>>;
20
+ validate: import('vue').Ref<(silent?: boolean, path?: ValidatePath) => string | undefined, (silent?: boolean, path?: ValidatePath) => string | undefined>;
21
+ validateMap: import('vue').Ref<Record<string, (silent?: boolean, path?: ValidatePath) => string | undefined>, Record<string, (silent?: boolean, path?: ValidatePath) => string | undefined>>;
22
+ invalidate: import('vue').Ref<(messages: Record<string, string | string[] | undefined>) => void, (messages: Record<string, string | string[] | undefined>) => void>;
23
+ invalidateMap: import('vue').Ref<Record<string, (messages: Record<string, string | string[] | undefined>) => void>, Record<string, (messages: Record<string, string | string[] | undefined>) => void>>;
24
+ initModel: import('vue').Ref<() => void, () => void>;
25
+ initModelMap: import('vue').Ref<Record<string, () => void>, Record<string, () => void>>;
26
+ errorMessage: import('vue').Ref<string | undefined, string | undefined>;
27
+ errorMessageMap: import('vue').Ref<Record<string, string | undefined>, Record<string, string | undefined>>;
23
28
  }, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {} & {
24
29
  "update:has-changes": (value: boolean) => any;
25
30
  "update:is-valid": (value: boolean | undefined) => any;
@@ -1 +1 @@
1
- {"version":3,"file":"WForm.vue.d.ts","sourceRoot":"","sources":["../../../src/components/Form/WForm.vue"],"names":[],"mappings":"AAgLA,iBAAS,cAAc;;yBA+BM,GAAG;;;WASlB,OAAO,IAA6B;EAEjD;AAcD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;WAvIZ,MAAM;YACL,MAAM;YACN,OAAO;;;;;;;;;;;;;;;;WAFR,MAAM;YACL,MAAM;YACN,OAAO;;;;;kFAiJf,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAWpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
1
+ {"version":3,"file":"WForm.vue.d.ts","sourceRoot":"","sources":["../../../src/components/Form/WForm.vue"],"names":[],"mappings":"AAkKA,OAAO,EAAC,KAAK,YAAY,EAAiB,MAAM,gBAAgB,CAAA;AA0KhE,iBAAS,cAAc;;yBA+BM,GAAG;;;WASlB,OAAO,IAA6B;EAEjD;AAcD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;WA7NZ,MAAM;YACL,MAAM;YACN,OAAO;;;;;;;;;;;;;;;;;;;;WAFR,MAAM;YACL,MAAM;YACN,OAAO;;;;;kFAuOf,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAWpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
@@ -1,13 +1,8 @@
1
- import { defineComponent, toRef, provide, inject, watch, onBeforeUnmount, openBlock, createBlock, resolveDynamicComponent, withCtx, renderSlot } from 'vue';
1
+ import { defineComponent, toRef, computed, provide, inject, watch, onBeforeUnmount, openBlock, createBlock, resolveDynamicComponent, withCtx, renderSlot } from 'vue';
2
2
  import _sfc_main$1 from '../EmptyComponent/WEmptyComponent.vue.js';
3
- import { wFormUnlistener } from './models/injection.js';
4
- import { useFormErrorMessageMap } from './use/useFormErrorMessageMap.js';
5
- import { useFormHasChangesMap } from './use/useFormHasChangesMap.js';
6
- import { useFormHasValueMap } from './use/useFormHasValueMap.js';
7
- import { useFormInitModelMap } from './use/useFormInitModelMap.js';
8
- import { useFormInvalidateMap } from './use/useFormInvalidateMap.js';
9
- import { useFormTitleMap } from './use/useFormTitleMap.js';
10
- import { useFormValidateMap } from './use/useFormValidateMap.js';
3
+ import { wFormTitleUpdater, wFormUnlistener, wFormErrorMessageUpdater, wFormHasChangesUpdater, wFormHasValueUpdater, wFormValidateUpdater, wFormInvalidateUpdater, wFormInitModelUpdater } from './models/injection.js';
4
+ import { compileMessage } from './models/utils.js';
5
+ import { useFormValueMap } from './use/useFormValueMap.js';
11
6
 
12
7
  const _sfc_main = /* @__PURE__ */ defineComponent({
13
8
  __name: "WForm",
@@ -21,27 +16,80 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
21
16
  const props = __props;
22
17
  const emit = __emit;
23
18
  const name = toRef(props, "name");
24
- const { titleGetter, titleMapUnlistener } = useFormTitleMap(name, toRef(props, "title"));
25
- const { errorMessageMapUnlistener, isValid, errorMessage, errorMessageMap } = useFormErrorMessageMap(name, titleGetter);
26
- const { hasChangesMapUnlistener, hasChanges } = useFormHasChangesMap(name);
27
- const { hasValueMapUnlistener, hasValue } = useFormHasValueMap(name);
28
- const { validateMapUnlistener, validate } = useFormValidateMap(name, titleGetter, (value) => emit("update:is-valid", value));
29
- const { invalidateMapUnlistener, invalidate } = useFormInvalidateMap(name);
30
- const { initModelMapUnlistener, initModel } = useFormInitModelMap(name);
19
+ const titleMap = useFormValueMap(wFormTitleUpdater, name, toRef(props, "title"));
20
+ const titleGetter = (key) => {
21
+ return titleMap.map.value[key] ?? "";
22
+ };
23
+ const errorMessageMap = useFormValueMap(
24
+ wFormErrorMessageUpdater,
25
+ name,
26
+ (map) => computed(() => Object.keys(map.value).map((key) => compileMessage(titleGetter(key), map.value[key])).filter((item) => item).join("\n") || void 0)
27
+ );
28
+ const isValid = computed(() => !Object.values(errorMessageMap.map.value).some((item) => item));
29
+ const hasChangesMap = useFormValueMap(
30
+ wFormHasChangesUpdater,
31
+ name,
32
+ (map) => computed(() => Object.values(map.value).some((value) => value))
33
+ );
34
+ const hasValueMap = useFormValueMap(
35
+ wFormHasValueUpdater,
36
+ name,
37
+ (map) => computed(() => {
38
+ const items = Object.values(map.value);
39
+ if (items.length === 0) return null;
40
+ return items.length !== 0 && items.every((value) => value);
41
+ })
42
+ );
43
+ const validateMap = useFormValueMap(
44
+ wFormValidateUpdater,
45
+ name,
46
+ (map) => (silent, path) => {
47
+ const messages = Object.keys(map.value).map((key) => {
48
+ return compileMessage(
49
+ titleGetter(key),
50
+ map.value[key](
51
+ silent,
52
+ path?.[key] instanceof Object ? path[key] : path?.[key] === true ? void 0 : path
53
+ )
54
+ );
55
+ }).filter((item) => item);
56
+ if (!silent) emit("update:is-valid", messages.length === 0);
57
+ return messages.length === 0 ? void 0 : messages.join("\n");
58
+ }
59
+ );
60
+ const invalidateMap = useFormValueMap(
61
+ wFormInvalidateUpdater,
62
+ name,
63
+ (map) => (payload) => {
64
+ const value = name.value ? payload[name.value] ?? payload : payload;
65
+ Object.keys(map.value).forEach((key) => {
66
+ map.value[key]?.(value);
67
+ });
68
+ }
69
+ );
70
+ const initModelMap = useFormValueMap(
71
+ wFormInitModelUpdater,
72
+ name,
73
+ (map) => () => {
74
+ Object.keys(map.value).forEach((key) => {
75
+ map.value[key]?.();
76
+ });
77
+ }
78
+ );
31
79
  const unlistener = (key) => {
32
- titleMapUnlistener(key);
33
- errorMessageMapUnlistener(key);
34
- hasChangesMapUnlistener(key);
35
- hasValueMapUnlistener(key);
36
- validateMapUnlistener(key);
37
- invalidateMapUnlistener(key);
38
- initModelMapUnlistener(key);
80
+ titleMap.unlistener(key);
81
+ errorMessageMap.unlistener(key);
82
+ hasChangesMap.unlistener(key);
83
+ hasValueMap.unlistener(key);
84
+ validateMap.unlistener(key);
85
+ invalidateMap.unlistener(key);
86
+ initModelMap.unlistener(key);
39
87
  };
40
88
  provide(wFormUnlistener, unlistener);
41
89
  const unlistenerInjected = inject(wFormUnlistener, void 0);
42
- watch(errorMessageMap, () => emit("update:is-valid", isValid.value));
43
- watch(hasChanges, (value) => emit("update:has-changes", value));
44
- watch(hasValue, (value) => emit("update:has-value", value));
90
+ watch(errorMessageMap.map, () => emit("update:is-valid", isValid.value));
91
+ watch(hasChangesMap.value, (value) => emit("update:has-changes", value));
92
+ watch(hasValueMap.value, (value) => emit("update:has-value", value));
45
93
  onBeforeUnmount(() => {
46
94
  if (props.name) {
47
95
  unlistenerInjected?.(props.name);
@@ -50,12 +98,18 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
50
98
  });
51
99
  __expose({
52
100
  isValid,
53
- hasChanges,
54
- hasValue,
55
- validate,
56
- invalidate,
57
- initModel,
58
- errorMessage
101
+ hasChanges: hasChangesMap.value,
102
+ hasChangesMap: hasChangesMap.map,
103
+ hasValue: hasValueMap.value,
104
+ hasValueMap: hasValueMap.map,
105
+ validate: validateMap.value,
106
+ validateMap: validateMap.map,
107
+ invalidate: invalidateMap.value,
108
+ invalidateMap: invalidateMap.map,
109
+ initModel: initModelMap.value,
110
+ initModelMap: initModelMap.map,
111
+ errorMessage: errorMessageMap.value,
112
+ errorMessageMap: errorMessageMap.map
59
113
  });
60
114
  return (_ctx, _cache) => {
61
115
  return openBlock(), createBlock(resolveDynamicComponent(_ctx.noTag ? _sfc_main$1 : "div"), null, {
@@ -1,8 +1,9 @@
1
+ import { VNode } from 'vue';
1
2
  declare function __VLS_template(): {
2
3
  slots: Readonly<{
3
- default: () => void;
4
+ default: () => VNode[];
4
5
  }> & {
5
- default: () => void;
6
+ default: () => VNode[];
6
7
  };
7
8
  refs: {
8
9
  component: unknown;
@@ -1 +1 @@
1
- {"version":3,"file":"WFormValidator.vue.d.ts","sourceRoot":"","sources":["../../../src/components/Form/WFormValidator.vue"],"names":[],"mappings":"AA4mBA,iBAAS,cAAc;;iBAbZ,MAAM,IAAI;;iBAAV,MAAM,IAAI;;;;;WA4GP,OAAO,IAA6B;EAEjD;AAqBD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;WAjaZ,MAAM;YACL,MAAM;eACH,UAAU,GAAG,UAAU,EAAE;sBAClB,MAAM;sBACN,MAAM;gBACZ,OAAO;eACR,OAAO;;;wBAuQE,MAAM;qBAxEN,IAAI;;;;;;;WArMjB,MAAM;YACL,MAAM;eACH,UAAU,GAAG,UAAU,EAAE;sBAClB,MAAM;sBACN,MAAM;gBACZ,OAAO;eACR,OAAO;;;;;;kFAwalB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAWpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
1
+ {"version":3,"file":"WFormValidator.vue.d.ts","sourceRoot":"","sources":["../../../src/components/Form/WFormValidator.vue"],"names":[],"mappings":"AAsTA,OAAO,EAAC,KAAK,KAAK,EAAyF,MAAM,KAAK,CAAA;AA4TtH,iBAAS,cAAc;;iBAbZ,MAAM,KAAK,EAAE;;iBAAb,MAAM,KAAK,EAAE;;;;;WA4GV,OAAO,IAA6B;EAEjD;AAqBD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;WAtaZ,MAAM;YACL,MAAM;eACH,UAAU,GAAG,UAAU,EAAE;sBAClB,MAAM;sBACN,MAAM;gBACZ,OAAO;eACR,OAAO;;;wBA4QE,MAAM;qBA5EN,IAAI;;;;;;;WAtMjB,MAAM;YACL,MAAM;eACH,UAAU,GAAG,UAAU,EAAE;sBAClB,MAAM;sBACN,MAAM;gBACZ,OAAO;eACR,OAAO;;;;;;kFA6alB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAWpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
@@ -58,6 +58,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
58
58
  const initModelValue = ref();
59
59
  const required = computed(() => componentSlot.value?.props?.required !== void 0 ? componentSlot.value?.props?.required !== false : void 0);
60
60
  const mandatory = computed(() => componentSlot.value?.props?.mandatory !== void 0 ? componentSlot.value?.props?.mandatory !== false : void 0);
61
+ const skeleton = computed(() => componentSlot.value?.props?.skeleton !== void 0 ? componentSlot.value?.props?.skeleton !== false : void 0);
61
62
  const title = computed(() => props.title ?? componentSlot.value?.props?.title);
62
63
  const errorMessage = ref(null);
63
64
  const hasChanges = computed(() => {
@@ -199,6 +200,9 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
199
200
  watch(required, () => {
200
201
  if (hasBeenValidated.value) doValidate();
201
202
  });
203
+ watch(skeleton, (value) => {
204
+ if (!value) initModel();
205
+ });
202
206
  onBeforeMount(() => {
203
207
  if (props.name) {
204
208
  initModel();
@@ -1,9 +1,10 @@
1
+ import { ValidatePath } from './utils';
1
2
  import { InjectionKey } from 'vue';
2
3
  export declare const wFormTitleUpdater: InjectionKey<(key: string, value: string | undefined) => void>;
3
4
  export declare const wFormErrorMessageUpdater: InjectionKey<(key: string, value: string | undefined) => void>;
4
5
  export declare const wFormHasChangesUpdater: InjectionKey<(key: string, value: boolean) => void>;
5
6
  export declare const wFormHasValueUpdater: InjectionKey<(key: string, value: boolean | null) => void>;
6
- export declare const wFormValidateUpdater: InjectionKey<(key: string, value: () => string | undefined) => void>;
7
+ export declare const wFormValidateUpdater: InjectionKey<(key: string, value: (silent?: boolean, path?: ValidatePath) => string | undefined) => void>;
7
8
  export declare const wFormInvalidateUpdater: InjectionKey<(key: string, value: (messages: Record<string, string | string[] | undefined>) => void) => void>;
8
9
  export declare const wFormInitModelUpdater: InjectionKey<(key: string, value: () => void) => void>;
9
10
  export declare const wFormUnlistener: InjectionKey<(key: string) => void>;
@@ -1 +1 @@
1
- {"version":3,"file":"injection.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/models/injection.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,YAAY,EAAC,MAAM,KAAK,CAAA;AAErC,eAAO,MAAM,iBAAiB,EAAkC,YAAY,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,SAAS,KAAK,IAAI,CAAC,CAAA;AAE9H,eAAO,MAAM,wBAAwB,EAAyC,YAAY,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,SAAS,KAAK,IAAI,CAAC,CAAA;AAE5I,eAAO,MAAM,sBAAsB,EAAuC,YAAY,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,KAAK,IAAI,CAAC,CAAA;AAE7H,eAAO,MAAM,oBAAoB,EAAqC,YAAY,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,GAAG,IAAI,KAAK,IAAI,CAAC,CAAA;AAEhI,eAAO,MAAM,oBAAoB,EAAqC,YAAY,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,MAAM,GAAG,SAAS,KAAK,IAAI,CAAC,CAAA;AAE1I,eAAO,MAAM,sBAAsB,EAAqC,YAAY,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAC,KAAK,IAAI,KAAK,IAAI,CAAC,CAAA;AAErL,eAAO,MAAM,qBAAqB,EAAsC,YAAY,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,IAAI,KAAK,IAAI,CAAC,CAAA;AAE9H,eAAO,MAAM,eAAe,EAAgC,YAAY,CAAC,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI,CAAC,CAAA"}
1
+ {"version":3,"file":"injection.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/models/injection.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,YAAY,EAAC,MAAM,SAAS,CAAA;AACzC,OAAO,KAAK,EAAC,YAAY,EAAC,MAAM,KAAK,CAAA;AAErC,eAAO,MAAM,iBAAiB,EAAkC,YAAY,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,SAAS,KAAK,IAAI,CAAC,CAAA;AAE9H,eAAO,MAAM,wBAAwB,EAAyC,YAAY,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,SAAS,KAAK,IAAI,CAAC,CAAA;AAE5I,eAAO,MAAM,sBAAsB,EAAuC,YAAY,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,KAAK,IAAI,CAAC,CAAA;AAE7H,eAAO,MAAM,oBAAoB,EAAqC,YAAY,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,OAAO,GAAG,IAAI,KAAK,IAAI,CAAC,CAAA;AAEhI,eAAO,MAAM,oBAAoB,EAAqC,YAAY,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,MAAM,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,EAAE,YAAY,KAAK,MAAM,GAAG,SAAS,KAAK,IAAI,CAAC,CAAA;AAE/K,eAAO,MAAM,sBAAsB,EAAqC,YAAY,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAC,KAAK,IAAI,KAAK,IAAI,CAAC,CAAA;AAErL,eAAO,MAAM,qBAAqB,EAAsC,YAAY,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,IAAI,KAAK,IAAI,CAAC,CAAA;AAE9H,eAAO,MAAM,eAAe,EAAgC,YAAY,CAAC,CAAC,GAAG,EAAE,MAAM,KAAK,IAAI,CAAC,CAAA"}
@@ -1,4 +1,7 @@
1
1
  export declare const removeKey: <T extends Record<string, unknown>>(entity: T, key: string) => T;
2
2
  export declare const compileMessage: (title: string | undefined, message: string | undefined) => string | undefined;
3
3
  export declare const scrollToValidator: (element: HTMLElement) => void;
4
+ export type ValidatePath = {
5
+ [Key in string]: boolean | ValidatePath;
6
+ };
4
7
  //# sourceMappingURL=utils.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/models/utils.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,SAAS,GAAI,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,UAAU,CAAC,OAAO,MAAM,KAAG,CAMrF,CAAA;AAKD,eAAO,MAAM,cAAc,UAAW,MAAM,GAAG,SAAS,WAAW,MAAM,GAAG,SAAS,KAAG,MAAM,GAAG,SAShG,CAAA;AAED,eAAO,MAAM,iBAAiB,YAAsB,WAAW,KAAG,IAM3D,CAAA"}
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/models/utils.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,SAAS,GAAI,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,UAAU,CAAC,OAAO,MAAM,KAAG,CAMrF,CAAA;AAKD,eAAO,MAAM,cAAc,UAAW,MAAM,GAAG,SAAS,WAAW,MAAM,GAAG,SAAS,KAAG,MAAM,GAAG,SAShG,CAAA;AAED,eAAO,MAAM,iBAAiB,YAAsB,WAAW,KAAG,IAM3D,CAAA;AAEP,MAAM,MAAM,YAAY,GAAG;KACxB,GAAG,IAAI,MAAM,GAAG,OAAO,GAAG,YAAY;CACxC,CAAA"}
@@ -12,11 +12,6 @@ import '../../Input/WInputDate.vue.js';
12
12
  import '../../Link/WLink.vue.js';
13
13
  import '@tanstack/vue-query';
14
14
 
15
- const removeKey = (entity, key) => {
16
- const result = { ...entity };
17
- delete result[key];
18
- return result;
19
- };
20
15
  const fieldMessageStart = " - ";
21
16
  const subformMessageStart = " ";
22
17
  const compileMessage = (title, message) => {
@@ -37,4 +32,4 @@ const scrollToValidator = throttle((element) => {
37
32
  });
38
33
  }, 300);
39
34
 
40
- export { compileMessage, removeKey, scrollToValidator };
35
+ export { compileMessage, scrollToValidator };
@@ -0,0 +1,7 @@
1
+ import { InjectionKey, Ref } from 'vue';
2
+ export declare const useFormValueMap: <Value, ValueGetter extends Ref<Value> | ((map: Ref<Record<string, Value>>) => Value) | ((map: Ref<Record<string, Value>>) => Ref<Value>)>(injectionKey: InjectionKey<(key: string, value: Value) => void>, name: Ref<string | undefined>, valueGetter: ValueGetter) => {
3
+ unlistener(key: string): void;
4
+ map: Ref<Record<string, Value>>;
5
+ value: ValueGetter extends () => unknown ? ReturnType<ValueGetter> : Ref<Value>;
6
+ };
7
+ //# sourceMappingURL=useFormValueMap.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useFormValueMap.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/use/useFormValueMap.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,KAAK,YAAY,EAAE,KAAK,GAAG,EAAoD,MAAM,KAAK,CAAA;AAElG,eAAO,MAAM,eAAe,GAAI,KAAK,EAAE,WAAW,SAAS,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,KAAK,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,KAAK,GAAG,CAAC,KAAK,CAAC,CAAC,gBACxJ,YAAY,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC,QACzD,GAAG,CAAC,MAAM,GAAG,SAAS,CAAC,eAChB,WAAW,KACvB;IACD,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAAA;IAC7B,GAAG,EAAE,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAA;IAC/B,KAAK,EAAE,WAAW,SAAS,MAAM,OAAO,GAAG,UAAU,CAAC,WAAW,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,CAAA;CAwChF,CAAA"}
@@ -0,0 +1,36 @@
1
+ import { ref, provide, inject, isRef, watch, onBeforeMount } from 'vue';
2
+
3
+ const useFormValueMap = (injectionKey, name, valueGetter) => {
4
+ const map = ref({});
5
+ const updater = (key, value2) => {
6
+ if (value2 === null || value2 === void 0) unlistener(key);
7
+ else map.value[key] = value2;
8
+ if (!name.value) updaterInjected?.(key, value2);
9
+ };
10
+ const unlistener = (key) => {
11
+ if (key in map.value) delete map.value[key];
12
+ };
13
+ provide(injectionKey, updater);
14
+ const updaterInjected = inject(injectionKey, void 0);
15
+ const value = isRef(valueGetter) ? valueGetter : valueGetter(map);
16
+ if (isRef(value)) {
17
+ watch(value, (value2) => {
18
+ if (name.value) {
19
+ updaterInjected?.(name.value, value2);
20
+ }
21
+ }, { immediate: true });
22
+ } else {
23
+ onBeforeMount(() => {
24
+ if (name.value) {
25
+ updaterInjected?.(name.value, value);
26
+ }
27
+ });
28
+ }
29
+ return {
30
+ unlistener,
31
+ map,
32
+ value
33
+ };
34
+ };
35
+
36
+ export { useFormValueMap };
@@ -1 +1 @@
1
- {"version":3,"file":"InfiniteListPage.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/InfiniteList/components/InfiniteListPage.vue"],"names":[],"mappings":"yBAgXiB,KAAK,SAAS,MAAM,GAAG,MAAM,EAAE,IAAI,SAAS,WAAW,EAAE,WAAW,eACvE,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,cAClD,mBAAmB,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC,CAAC,iBAC5F,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,CAAC,QAAQ,CAAC;WA4cxD,mBAAmB,CAAC;qBAxcb,WAAW;oBACZ,iBAAiB,CAAC,IAAI,EAAE,WAAW,CAAC;wBAChC,MAAM;mBACX,OAAO;kBACR,OAAO;wBACD,OAAO;eAChB,OAAO;gBACN,OAAO;qBACF,OAAO;oBACR,OAAO;oBACP,MAAM;oBACN,OAAO;oBACP,OAAO;oBACP,MAAM;0BACA,MAAM,GAAG,KAAK;2BACb,OAAO,GAAG,IAAI;uBAClB,OAAO,CAAC,YAAY,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC;mBAElD,KAAK,EAAE;qBACL,CAAC,IAAI,EAAE,IAAI,KAAK,KAAK;qBACrB,OAAO;uBACL,OAAO;2BACH,OAAO;6BACL,OAAO;KAibuD,CAAC,4BAA2B;oBAChG,OAAO,KAAK,EAAE,gBAAgB;;;;2BAjWvB,MAAM;MAiWuC,GAAG,IAAI;WACpE,GAAG;;kBAhPD,CAAC,KAAK,EAAE;YAChB,IAAI,EAAE,IAAI,CAAA;YACV,MAAM,EAAE,CAAC,OAAO,CAAC,EAAE,IAAI,GAAG,SAAS,KAAK,IAAI,CAAA;YAC5C,QAAQ,EAAE,OAAO,CAAA;YACjB,OAAO,EAAE,MAAM,IAAI,CAAA;YACnB,QAAQ,CAAC,EAAE,IAAI,CAAA;YACf,IAAI,CAAC,EAAE,IAAI,CAAA;YACX,KAAK,EAAE,OAAO,CAAA;YACd,IAAI,EAAE,OAAO,CAAA;YACb,IAAI,EAAE,MAAM,CAAA;YACZ,KAAK,EAAE,MAAM,CAAA;SACd,KAAK,IAAI;;kBAXA,CAAC,KAAK,EAAE;YAChB,IAAI,EAAE,IAAI,CAAA;YACV,MAAM,EAAE,CAAC,OAAO,CAAC,EAAE,IAAI,GAAG,SAAS,KAAK,IAAI,CAAA;YAC5C,QAAQ,EAAE,OAAO,CAAA;YACjB,OAAO,EAAE,MAAM,IAAI,CAAA;YACnB,QAAQ,CAAC,EAAE,IAAI,CAAA;YACf,IAAI,CAAC,EAAE,IAAI,CAAA;YACX,KAAK,EAAE,OAAO,CAAA;YACd,IAAI,EAAE,OAAO,CAAA;YACb,IAAI,EAAE,MAAM,CAAA;YACZ,KAAK,EAAE,MAAM,CAAA;SACd,KAAK,IAAI;;;YA7LN,cAAc,SAAS,MAAM,GAAG,IAAI;YACpC,oBAAoB,SAAS,MAAM,GAAG,IAAI;YAC1C,kBAAkB,SAAS,MAAM,GAAG,IAAI,GAAG,IAAI;YAC/C,sBAAsB,SAAS,MAAM,GAAG,IAAI,GAAG,IAAI;YACnD,eAAe,SAAS,MAAM,GAAG,IAAI;YACrC,aAAa,SAAS,MAAM,GAAG,IAAI;YACnC,SAAS,GAAG,IAAI;YAChB,2BAA2B,GAAG,IAAI;YAClC,iBAAiB,UAAU,KAAK,EAAE,GAAG,IAAI;YACzC,SAAS,GAAG,IAAI;;;;;YA8ZsB,OAAO,CAAC,OAAO,WAAW,CAAC;;AAtdvE,wBAsd4E;AAC5E,KAAK,mBAAmB,CAAC,CAAC,IAAI;KAAG,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAG,GAAG,EAAE,CAAC"}
1
+ {"version":3,"file":"InfiniteListPage.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/InfiniteList/components/InfiniteListPage.vue"],"names":[],"mappings":"yBA4WiB,KAAK,SAAS,MAAM,GAAG,MAAM,EAAE,IAAI,SAAS,WAAW,EAAE,WAAW,eACvE,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,cAClD,mBAAmB,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC,CAAC,iBAC5F,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,CAAC,QAAQ,CAAC;WAscxD,mBAAmB,CAAC;qBAlcb,WAAW;oBACZ,iBAAiB,CAAC,IAAI,EAAE,WAAW,CAAC;wBAChC,MAAM;mBACX,OAAO;kBACR,OAAO;wBACD,OAAO;eAChB,OAAO;gBACN,OAAO;qBACF,OAAO;oBACR,OAAO;oBACP,MAAM;oBACN,OAAO;oBACP,OAAO;oBACP,MAAM;0BACA,MAAM,GAAG,KAAK;2BACb,OAAO,GAAG,IAAI;uBAClB,OAAO,CAAC,YAAY,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC;mBAElD,KAAK,EAAE;qBACL,CAAC,IAAI,EAAE,IAAI,KAAK,KAAK;qBACrB,OAAO;uBACL,OAAO;2BACH,OAAO;6BACL,OAAO;KA2auD,CAAC,4BAA2B;oBAChG,OAAO,KAAK,EAAE,gBAAgB;;;;2BA3VvB,MAAM;MA2VuC,GAAG,IAAI;WACpE,GAAG;;kBA1OD,CAAC,KAAK,EAAE;YAChB,IAAI,EAAE,IAAI,CAAA;YACV,MAAM,EAAE,CAAC,OAAO,CAAC,EAAE,IAAI,GAAG,SAAS,KAAK,IAAI,CAAA;YAC5C,QAAQ,EAAE,OAAO,CAAA;YACjB,OAAO,EAAE,MAAM,IAAI,CAAA;YACnB,QAAQ,CAAC,EAAE,IAAI,CAAA;YACf,IAAI,CAAC,EAAE,IAAI,CAAA;YACX,KAAK,EAAE,OAAO,CAAA;YACd,IAAI,EAAE,OAAO,CAAA;YACb,IAAI,EAAE,MAAM,CAAA;YACZ,KAAK,EAAE,MAAM,CAAA;SACd,KAAK,IAAI;;kBAXA,CAAC,KAAK,EAAE;YAChB,IAAI,EAAE,IAAI,CAAA;YACV,MAAM,EAAE,CAAC,OAAO,CAAC,EAAE,IAAI,GAAG,SAAS,KAAK,IAAI,CAAA;YAC5C,QAAQ,EAAE,OAAO,CAAA;YACjB,OAAO,EAAE,MAAM,IAAI,CAAA;YACnB,QAAQ,CAAC,EAAE,IAAI,CAAA;YACf,IAAI,CAAC,EAAE,IAAI,CAAA;YACX,KAAK,EAAE,OAAO,CAAA;YACd,IAAI,EAAE,OAAO,CAAA;YACb,IAAI,EAAE,MAAM,CAAA;YACZ,KAAK,EAAE,MAAM,CAAA;SACd,KAAK,IAAI;;;YA7LN,cAAc,SAAS,MAAM,GAAG,IAAI;YACpC,oBAAoB,SAAS,MAAM,GAAG,IAAI;YAC1C,kBAAkB,SAAS,MAAM,GAAG,IAAI,GAAG,IAAI;YAC/C,sBAAsB,SAAS,MAAM,GAAG,IAAI,GAAG,IAAI;YACnD,eAAe,SAAS,MAAM,GAAG,IAAI;YACrC,aAAa,SAAS,MAAM,GAAG,IAAI;YACnC,SAAS,GAAG,IAAI;YAChB,2BAA2B,GAAG,IAAI;YAClC,iBAAiB,UAAU,KAAK,EAAE,GAAG,IAAI;YACzC,SAAS,GAAG,IAAI;;;;;YAwZsB,OAAO,CAAC,OAAO,WAAW,CAAC;;AAhdvE,wBAgd4E;AAC5E,KAAK,mBAAmB,CAAC,CAAC,IAAI;KAAG,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAG,GAAG,EAAE,CAAC"}
@@ -1,4 +1,4 @@
1
- import { defineComponent, useTemplateRef, ref, toRef, computed, watch, onMounted, nextTick, onBeforeUnmount, openBlock, createElementBlock, normalizeClass, unref, Fragment, createElementVNode, createBlock, createCommentVNode, resolveDynamicComponent, TransitionGroup, normalizeProps, mergeProps, withCtx, renderList, renderSlot, toDisplayString } from 'vue';
1
+ import { defineComponent, useTemplateRef, ref, toRef, computed, watch, onMounted, nextTick, onBeforeUnmount, openBlock, createElementBlock, unref, Fragment, createElementVNode, normalizeClass, createBlock, createCommentVNode, resolveDynamicComponent, TransitionGroup, normalizeProps, mergeProps, withCtx, renderList, renderSlot, toDisplayString } from 'vue';
2
2
  import _sfc_main$3 from '../../EmptyComponent/WEmptyComponent.vue.js';
3
3
  import '../../Button/WButtonAction.vue.js';
4
4
  import '../../Button/WButton.vue.js';
@@ -15,7 +15,11 @@ import '../../Input/WInputDate.vue.js';
15
15
  import '../../Link/WLink.vue.js';
16
16
  import '@tanstack/vue-query';
17
17
 
18
- const _hoisted_1 = { class: "py-1.25 sm-not:px-3 cursor-default select-none" };
18
+ const _hoisted_1 = {
19
+ ref: "element",
20
+ class: "relative"
21
+ };
22
+ const _hoisted_2 = { class: "py-1.25 sm-not:px-3 cursor-default select-none" };
19
23
  const _sfc_main = /* @__PURE__ */ defineComponent({
20
24
  __name: "InfiniteListPage",
21
25
  props: {
@@ -170,13 +174,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
170
174
  scrollTo
171
175
  });
172
176
  return (_ctx, _cache) => {
173
- return openBlock(), createElementBlock("div", {
174
- ref: "element",
175
- class: normalizeClass(["relative", {
176
- "last:min-h-[calc(100vh-var(--header-height)-var(--infinite-list-header-height))] last:pb-16": !_ctx.minHeight,
177
- "last:min-h-full": _ctx.minHeight && !unref(data)
178
- }])
179
- }, [
177
+ return openBlock(), createElementBlock("div", _hoisted_1, [
180
178
  page.value && unref(data)?.results.length !== 0 ? (openBlock(), createElementBlock(Fragment, { key: 0 }, [
181
179
  createElementVNode("div", {
182
180
  class: normalizeClass(["flex", {
@@ -269,9 +267,9 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
269
267
  "pb-2": _ctx.minHeight && !_ctx.lastChild
270
268
  }])
271
269
  }, [
272
- createElementVNode("div", _hoisted_1, toDisplayString(_ctx.emptyStub), 1)
270
+ createElementVNode("div", _hoisted_2, toDisplayString(_ctx.emptyStub), 1)
273
271
  ], 2))
274
- ], 2);
272
+ ], 512);
275
273
  };
276
274
  }
277
275
  });
@@ -1 +1 @@
1
- {"version":3,"file":"InfiniteListPages.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/InfiniteList/components/InfiniteListPages.vue"],"names":[],"mappings":"yBAgUiB,KAAK,SAAS,MAAM,GAAG,MAAM,EAAE,IAAI,SAAS,WAAW,EAAE,WAAW,eACvE,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,cAClD,mBAAmB,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC,CAAC,iBAC5F,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,CAAC,QAAQ,CAAC;WAglBxD,mBAAmB,CAAC;;;;;oBA5kBd,iBAAiB,CAAC,IAAI,EAAE,WAAW,CAAC;qBACnC,WAAW;yBACP,MAAM;wBACP,OAAO;eAChB,OAAO;gBACN,OAAO;qBACF,OAAO;qBACP,MAAM;2BACA,OAAO,GAAG,IAAI;oBACrB,MAAM;uBACH,MAAM;oBACT,OAAO;oBACP,OAAO;wBACH,CAAC,MAAM,WAAW,CAAC,EAAE;oBACzB,MAAM;oBACN,MAAM;mBACP,MAAM;0BACC,MAAM,GAAG,KAAK;uBACjB,OAAO,CAAC,YAAY,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC;mBAElD,KAAK,EAAE;qBACL,CAAC,IAAI,EAAE,IAAI,KAAK,KAAK;qBACrB,OAAO;uBACL,OAAO;2BACH,OAAO;6BACL,OAAO;KAmjBuD,CAAC,4BAA2B;oBAChG,OAAO,KAAK,EAAE,gBAAgB;;0CArbP,MAAM;MAqbuB,GAAG,IAAI;WACpE,GAAG;;kBApYD,CAAC,KAAK,EAAE;YAChB,IAAI,EAAE,IAAI,CAAA;YACV,MAAM,EAAE,CAAC,OAAO,CAAC,EAAE,IAAI,GAAG,SAAS,KAAK,IAAI,CAAA;YAC5C,QAAQ,EAAE,OAAO,CAAA;YACjB,OAAO,EAAE,MAAM,IAAI,CAAA;YACnB,QAAQ,CAAC,EAAE,IAAI,CAAA;YACf,IAAI,CAAC,EAAE,IAAI,CAAA;YACX,KAAK,EAAE,OAAO,CAAA;YACd,IAAI,EAAE,OAAO,CAAA;YACb,SAAS,EAAE,OAAO,CAAA;YAClB,IAAI,EAAE,MAAM,CAAA;YACZ,KAAK,EAAE,MAAM,CAAA;YACb,KAAK,EAAE,KAAK,CAAA;SACb,KAAK,IAAI;;kBAbA,CAAC,KAAK,EAAE;YAChB,IAAI,EAAE,IAAI,CAAA;YACV,MAAM,EAAE,CAAC,OAAO,CAAC,EAAE,IAAI,GAAG,SAAS,KAAK,IAAI,CAAA;YAC5C,QAAQ,EAAE,OAAO,CAAA;YACjB,OAAO,EAAE,MAAM,IAAI,CAAA;YACnB,QAAQ,CAAC,EAAE,IAAI,CAAA;YACf,IAAI,CAAC,EAAE,IAAI,CAAA;YACX,KAAK,EAAE,OAAO,CAAA;YACd,IAAI,EAAE,OAAO,CAAA;YACb,SAAS,EAAE,OAAO,CAAA;YAClB,IAAI,EAAE,MAAM,CAAA;YACZ,KAAK,EAAE,MAAM,CAAA;YACb,KAAK,EAAE,KAAK,CAAA;SACb,KAAK,IAAI;;;YAzKN,aAAa,SAAS,MAAM,GAAG,SAAS,GAAG,IAAI;YAC/C,cAAc,SAAS,MAAM,GAAG,IAAI;YACpC,iBAAiB,UAAU,KAAK,EAAE,GAAG,IAAI;;;;;YAmiBH,OAAO,CAAC,OAAO,WAAW,CAAC;;AA1lBvE,wBA0lB4E;AAC5E,KAAK,mBAAmB,CAAC,CAAC,IAAI;KAAG,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAG,GAAG,EAAE,CAAC"}
1
+ {"version":3,"file":"InfiniteListPages.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/InfiniteList/components/InfiniteListPages.vue"],"names":[],"mappings":"yBA2UiB,KAAK,SAAS,MAAM,GAAG,MAAM,EAAE,IAAI,SAAS,WAAW,EAAE,WAAW,eACvE,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,cAClD,mBAAmB,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC,CAAC,iBAC5F,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,CAAC,QAAQ,CAAC;WAgmBxD,mBAAmB,CAAC;;;;;oBA5lBd,iBAAiB,CAAC,IAAI,EAAE,WAAW,CAAC;qBACnC,WAAW;yBACP,MAAM;wBACP,OAAO;eAChB,OAAO;gBACN,OAAO;qBACF,OAAO;qBACP,MAAM;2BACA,OAAO,GAAG,IAAI;oBACrB,MAAM;uBACH,MAAM;oBACT,OAAO;oBACP,OAAO;wBACH,CAAC,MAAM,WAAW,CAAC,EAAE;oBACzB,MAAM;oBACN,MAAM;mBACP,MAAM;0BACC,MAAM,GAAG,KAAK;uBACjB,OAAO,CAAC,YAAY,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC,CAAC;mBAElD,KAAK,EAAE;qBACL,CAAC,IAAI,EAAE,IAAI,KAAK,KAAK;qBACrB,OAAO;uBACL,OAAO;2BACH,OAAO;6BACL,OAAO;KAmkBuD,CAAC,4BAA2B;oBAChG,OAAO,KAAK,EAAE,gBAAgB;;0CAlcP,MAAM;MAkcuB,GAAG,IAAI;WACpE,GAAG;;kBA7YD,CAAC,KAAK,EAAE;YAChB,IAAI,EAAE,IAAI,CAAA;YACV,MAAM,EAAE,CAAC,OAAO,CAAC,EAAE,IAAI,GAAG,SAAS,KAAK,IAAI,CAAA;YAC5C,QAAQ,EAAE,OAAO,CAAA;YACjB,OAAO,EAAE,MAAM,IAAI,CAAA;YACnB,QAAQ,CAAC,EAAE,IAAI,CAAA;YACf,IAAI,CAAC,EAAE,IAAI,CAAA;YACX,KAAK,EAAE,OAAO,CAAA;YACd,IAAI,EAAE,OAAO,CAAA;YACb,SAAS,EAAE,OAAO,CAAA;YAClB,IAAI,EAAE,MAAM,CAAA;YACZ,KAAK,EAAE,MAAM,CAAA;YACb,KAAK,EAAE,KAAK,CAAA;SACb,KAAK,IAAI;;kBAbA,CAAC,KAAK,EAAE;YAChB,IAAI,EAAE,IAAI,CAAA;YACV,MAAM,EAAE,CAAC,OAAO,CAAC,EAAE,IAAI,GAAG,SAAS,KAAK,IAAI,CAAA;YAC5C,QAAQ,EAAE,OAAO,CAAA;YACjB,OAAO,EAAE,MAAM,IAAI,CAAA;YACnB,QAAQ,CAAC,EAAE,IAAI,CAAA;YACf,IAAI,CAAC,EAAE,IAAI,CAAA;YACX,KAAK,EAAE,OAAO,CAAA;YACd,IAAI,EAAE,OAAO,CAAA;YACb,SAAS,EAAE,OAAO,CAAA;YAClB,IAAI,EAAE,MAAM,CAAA;YACZ,KAAK,EAAE,MAAM,CAAA;YACb,KAAK,EAAE,KAAK,CAAA;SACb,KAAK,IAAI;;;YAhLN,aAAa,SAAS,MAAM,GAAG,SAAS,GAAG,IAAI;YAC/C,cAAc,SAAS,MAAM,GAAG,IAAI;YACpC,iBAAiB,UAAU,KAAK,EAAE,GAAG,IAAI;;;;;YAmjBH,OAAO,CAAC,OAAO,WAAW,CAAC;;AA1mBvE,wBA0mB4E;AAC5E,KAAK,mBAAmB,CAAC,CAAC,IAAI;KAAG,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAG,GAAG,EAAE,CAAC"}
@@ -1,4 +1,4 @@
1
- import { defineComponent, useTemplateRef, ref, computed, watch, toRef, openBlock, createBlock, normalizeStyle, withCtx, unref, createCommentVNode, createElementBlock, Fragment, renderList, nextTick, renderSlot } from 'vue';
1
+ import { defineComponent, useTemplateRef, ref, computed, watch, toRef, openBlock, createBlock, normalizeStyle, normalizeClass, withCtx, unref, createCommentVNode, createElementBlock, Fragment, renderList, nextTick, renderSlot } from 'vue';
2
2
  import { isEqualObj } from '../../../utils/utils.js';
3
3
  import _sfc_main$2 from './InfiniteListButton.vue.js';
4
4
  import _sfc_main$3 from './InfiniteListPage.vue.js';
@@ -102,6 +102,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
102
102
  if (index === -1) return;
103
103
  const newPages = pages.value.slice(0, pages.value.length - index);
104
104
  pages.value = newPages.length === 0 ? [1] : newPages;
105
+ if (pagesCount.value >= page) pagesCount.value = page - 1;
106
+ if (nextPage.value === page) nextPage.value = null;
105
107
  emit("update:page", pages.value[pages.value.length - 1]);
106
108
  };
107
109
  const goto = async (page = 1, itemIndex) => {
@@ -116,6 +118,9 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
116
118
  isResettingPage.value = true;
117
119
  emit("update:page", page === 1 ? void 0 : page);
118
120
  pages.value = [];
121
+ const element = props.scrollingElement ?? document.scrollingElement;
122
+ const value = (infiniteScrollRef.value?.$el.offsetTop ?? 0) - props.headerHeight - 60;
123
+ if (element && element.scrollTop > value) element.scrollTop = value;
119
124
  await nextTick();
120
125
  pages.value = [page];
121
126
  nextPage.value = null;
@@ -123,7 +128,6 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
123
128
  };
124
129
  watch(toRef(props, "queryParams"), (newValue, oldValue) => {
125
130
  if (isEqualObj(newValue, oldValue, ["page", ...props.excludeParams ?? []])) return;
126
- if (pages.value.length === 1 && pages.value[0] === 1) return;
127
131
  resetPage();
128
132
  });
129
133
  watch(pagesCount, (value) => {
@@ -141,6 +145,10 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
141
145
  ref: "infiniteScroll",
142
146
  "scrolling-element": _ctx.scrollingElement,
143
147
  style: normalizeStyle({ "--infinite-list-header-height": _ctx.headerHeight + "px" }),
148
+ class: normalizeClass({
149
+ "min-h-[calc(100vh-var(--header-height)-var(--infinite-list-header-height))] pb-16": !_ctx.minHeight,
150
+ "min-h-full": _ctx.minHeight
151
+ }),
144
152
  "onScroll:down": addNextPage,
145
153
  "onScroll:up": addPreviousPage
146
154
  }, {
@@ -219,7 +227,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
219
227
  })) : createCommentVNode("", true)
220
228
  ]),
221
229
  _: 3
222
- }, 8, ["scrolling-element", "style"]);
230
+ }, 8, ["scrolling-element", "style", "class"]);
223
231
  };
224
232
  }
225
233
  });
@@ -2,7 +2,9 @@ declare function __VLS_template(): {
2
2
  slots: {
3
3
  default?(_: {}): any;
4
4
  };
5
- refs: {};
5
+ refs: {
6
+ container: HTMLDivElement;
7
+ };
6
8
  attrs: Partial<{}>;
7
9
  };
8
10
  type __VLS_TemplateResult = ReturnType<typeof __VLS_template>;
@@ -19,7 +21,9 @@ declare const __VLS_component: import('vue').DefineComponent<{
19
21
  }> & Readonly<{
20
22
  "onScroll:up"?: (() => any) | undefined;
21
23
  "onScroll:down"?: (() => any) | undefined;
22
- }>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
24
+ }>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {
25
+ container: HTMLDivElement;
26
+ }, any>;
23
27
  declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, __VLS_TemplateResult["slots"]>;
24
28
  export default _default;
25
29
  type __VLS_WithTemplateSlots<T, S> = T & {
@@ -1 +1 @@
1
- {"version":3,"file":"InfiniteListScroll.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/InfiniteList/components/InfiniteListScroll.vue"],"names":[],"mappings":"AA4IA,iBAAS,cAAc;;yBA0BM,GAAG;;;WASlB,OAAO,IAA6B;EAEjD;AAYD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;sBApHD,OAAO,GAAG,IAAI;;;;;;;;sBAAd,OAAO,GAAG,IAAI;;;;kFA+HhC,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAWpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
1
+ {"version":3,"file":"InfiniteListScroll.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/InfiniteList/components/InfiniteListScroll.vue"],"names":[],"mappings":"AAgJA,iBAAS,cAAc;;yBA4BM,GAAG;;;;;WAUlB,OAAO,IAA6B;EAEjD;AAYD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;sBAzHD,OAAO,GAAG,IAAI;;;;;;;;sBAAd,OAAO,GAAG,IAAI;;;;;;OAqIhC,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAWpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
@@ -1,6 +1,7 @@
1
- import { defineComponent, computed, watch, onMounted, onUnmounted, openBlock, createElementBlock, renderSlot } from 'vue';
1
+ import { defineComponent, useTemplateRef, computed, watch, onMounted, onUnmounted, openBlock, createElementBlock, renderSlot } from 'vue';
2
2
  import { getIsScrollUp, getIsScrollDown } from '../models/utils.js';
3
3
 
4
+ const _hoisted_1 = { ref: "container" };
4
5
  const _sfc_main = /* @__PURE__ */ defineComponent({
5
6
  __name: "InfiniteListScroll",
6
7
  props: {
@@ -10,10 +11,11 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
10
11
  setup(__props, { expose: __expose, emit: __emit }) {
11
12
  const props = __props;
12
13
  const emit = __emit;
14
+ const containerRef = useTemplateRef("container");
13
15
  const element = computed(() => props.scrollingElement ?? document);
14
16
  const listener = (event) => {
15
- if (event.target !== element.value) return;
16
- if (getIsScrollUp(props.scrollingElement ?? document.scrollingElement)) {
17
+ if (event.target !== element.value || !containerRef.value) return;
18
+ if (getIsScrollUp(props.scrollingElement ?? document.scrollingElement, containerRef.value.offsetTop)) {
17
19
  emit("scroll:up");
18
20
  return;
19
21
  }
@@ -46,9 +48,9 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
46
48
  checkIsScrollDown
47
49
  });
48
50
  return (_ctx, _cache) => {
49
- return openBlock(), createElementBlock("div", null, [
51
+ return openBlock(), createElementBlock("div", _hoisted_1, [
50
52
  renderSlot(_ctx.$slots, "default")
51
- ]);
53
+ ], 512);
52
54
  };
53
55
  }
54
56
  });
@@ -1,3 +1,3 @@
1
- export declare const getIsScrollUp: (element: Element | null) => boolean;
1
+ export declare const getIsScrollUp: (element: Element | null, offsetTop: number) => boolean;
2
2
  export declare const getIsScrollDown: (element: Element | null) => boolean;
3
3
  //# sourceMappingURL=utils.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../src/components/InfiniteList/models/utils.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,aAAa,YAAa,OAAO,GAAG,IAAI,KAAG,OAIvD,CAAA;AAED,eAAO,MAAM,eAAe,YAAa,OAAO,GAAG,IAAI,KAAG,OAIzD,CAAA"}
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../src/components/InfiniteList/models/utils.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,aAAa,YAAa,OAAO,GAAG,IAAI,aAAa,MAAM,KAAG,OAI1E,CAAA;AAED,eAAO,MAAM,eAAe,YAAa,OAAO,GAAG,IAAI,KAAG,OAIzD,CAAA"}