eco-vue-js 0.9.22 → 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/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 };
|
@@ -3,7 +3,7 @@ declare function __VLS_template(): {
|
|
3
3
|
default?(_: {
|
4
4
|
toggle: () => void;
|
5
5
|
isOpen: boolean;
|
6
|
-
validate: (silent?: boolean, path?: import('../Form/
|
6
|
+
validate: (silent?: boolean, path?: import('../Form/models/utils').ValidatePath) => string | undefined;
|
7
7
|
}): any;
|
8
8
|
more?(_: {}): any;
|
9
9
|
expansion?(_: {}): any;
|