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.
- package/dist/components/FieldWrapper/WFieldWrapper.vue.d.ts.map +1 -1
- package/dist/components/FieldWrapper/WFieldWrapper.vue.js +5 -4
- package/dist/components/FieldWrapper/components/FilterButton.vue.d.ts +4 -2
- package/dist/components/FieldWrapper/components/FilterButton.vue.d.ts.map +1 -1
- package/dist/components/FieldWrapper/components/FilterButton.vue.js +9 -3
- package/dist/components/Form/WForm.vue.d.ts +13 -8
- package/dist/components/Form/WForm.vue.d.ts.map +1 -1
- package/dist/components/Form/WForm.vue.js +86 -32
- package/dist/components/Form/WFormValidator.vue.d.ts +3 -2
- package/dist/components/Form/WFormValidator.vue.d.ts.map +1 -1
- package/dist/components/Form/WFormValidator.vue.js +4 -0
- package/dist/components/Form/models/injection.d.ts +2 -1
- package/dist/components/Form/models/injection.d.ts.map +1 -1
- package/dist/components/Form/models/utils.d.ts +3 -0
- package/dist/components/Form/models/utils.d.ts.map +1 -1
- package/dist/components/Form/models/utils.js +1 -6
- package/dist/components/Form/use/useFormValueMap.d.ts +7 -0
- package/dist/components/Form/use/useFormValueMap.d.ts.map +1 -0
- package/dist/components/Form/use/useFormValueMap.js +36 -0
- package/dist/components/InfiniteList/components/InfiniteListPage.vue.d.ts.map +1 -1
- package/dist/components/InfiniteList/components/InfiniteListPage.vue.js +9 -11
- package/dist/components/InfiniteList/components/InfiniteListPages.vue.d.ts.map +1 -1
- package/dist/components/InfiniteList/components/InfiniteListPages.vue.js +11 -3
- package/dist/components/InfiniteList/components/InfiniteListScroll.vue.d.ts +6 -2
- package/dist/components/InfiniteList/components/InfiniteListScroll.vue.d.ts.map +1 -1
- package/dist/components/InfiniteList/components/InfiniteListScroll.vue.js +7 -5
- package/dist/components/InfiniteList/models/utils.d.ts +1 -1
- package/dist/components/InfiniteList/models/utils.d.ts.map +1 -1
- package/dist/components/InfiniteList/models/utils.js +2 -2
- package/dist/components/List/WListCard.vue.d.ts +1 -1
- package/dist/components/Modal/WModalStepper.vue.d.ts +761 -471
- package/dist/components/Modal/WModalStepper.vue.d.ts.map +1 -1
- package/dist/components/Tabs/WTabs.vue.d.ts +567 -45
- package/dist/components/Tabs/WTabs.vue.d.ts.map +1 -1
- package/dist/components/Tabs/WTabs.vue.js +147 -129
- package/dist/components/Tabs/WTabsColumns.vue.d.ts +4 -2
- package/dist/components/Tabs/WTabsColumns.vue.d.ts.map +1 -1
- package/dist/components/Tabs/WTabsItem.vue.d.ts +2 -18
- package/dist/components/Tabs/WTabsItem.vue.d.ts.map +1 -1
- package/dist/components/Tabs/components/TabItem.vue.d.ts +51 -43
- package/dist/components/Tabs/components/TabItem.vue.d.ts.map +1 -1
- package/dist/components/Tabs/components/TabItem.vue.js +2 -15
- package/dist/components/Tabs/types.d.ts +10 -0
- package/dist/components/Tabs/types.d.ts.map +1 -1
- package/package.json +1 -1
- package/dist/components/Form/use/useFormErrorMessageMap.d.ts +0 -8
- package/dist/components/Form/use/useFormErrorMessageMap.d.ts.map +0 -1
- package/dist/components/Form/use/useFormErrorMessageMap.js +0 -32
- package/dist/components/Form/use/useFormHasChangesMap.d.ts +0 -6
- package/dist/components/Form/use/useFormHasChangesMap.d.ts.map +0 -1
- package/dist/components/Form/use/useFormHasChangesMap.js +0 -27
- package/dist/components/Form/use/useFormHasValueMap.d.ts +0 -6
- package/dist/components/Form/use/useFormHasValueMap.d.ts.map +0 -1
- package/dist/components/Form/use/useFormHasValueMap.js +0 -31
- package/dist/components/Form/use/useFormInitModelMap.d.ts +0 -6
- package/dist/components/Form/use/useFormInitModelMap.d.ts.map +0 -1
- package/dist/components/Form/use/useFormInitModelMap.js +0 -31
- package/dist/components/Form/use/useFormInvalidateMap.d.ts +0 -8
- package/dist/components/Form/use/useFormInvalidateMap.d.ts.map +0 -1
- package/dist/components/Form/use/useFormInvalidateMap.js +0 -32
- package/dist/components/Form/use/useFormTitleMap.d.ts +0 -6
- package/dist/components/Form/use/useFormTitleMap.d.ts.map +0 -1
- package/dist/components/Form/use/useFormTitleMap.js +0 -29
- package/dist/components/Form/use/useFormValidateMap.d.ts +0 -9
- package/dist/components/Form/use/useFormValidateMap.d.ts.map +0 -1
- 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":"
|
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 (
|
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
|
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
|
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":";
|
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').
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
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":"
|
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 {
|
5
|
-
import {
|
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
|
25
|
-
const
|
26
|
-
|
27
|
-
|
28
|
-
const
|
29
|
-
|
30
|
-
|
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
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
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(
|
44
|
-
watch(
|
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
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
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 +1 @@
|
|
1
|
-
{"version":3,"file":"WFormValidator.vue.d.ts","sourceRoot":"","sources":["../../../src/components/Form/WFormValidator.vue"],"names":[],"mappings":"
|
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;
|
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,
|
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":"
|
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,
|
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 = {
|
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",
|
270
|
+
createElementVNode("div", _hoisted_2, toDisplayString(_ctx.emptyStub), 1)
|
273
271
|
], 2))
|
274
|
-
],
|
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":"
|
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, {
|
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":"
|
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",
|
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,
|
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"}
|