@effect-app/vue-components 4.0.0-beta.9 → 4.0.0-beta.91

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 (172) hide show
  1. package/README.md +24 -0
  2. package/dist/reset.css +52 -0
  3. package/dist/types/components/OmegaForm/OmegaAutoGen.vue.d.ts +1 -1
  4. package/dist/types/components/OmegaForm/OmegaFormStuff.d.ts +22 -15
  5. package/dist/types/components/OmegaForm/useOmegaForm.d.ts +3 -5
  6. package/dist/types/utils/index.d.ts +3 -4
  7. package/dist/vue-components.es.js +21 -44
  8. package/dist/vue-components10.es.js +5 -0
  9. package/dist/vue-components11.es.js +13 -0
  10. package/dist/vue-components12.es.js +444 -0
  11. package/dist/vue-components13.es.js +4 -0
  12. package/dist/vue-components14.es.js +38 -0
  13. package/dist/vue-components15.es.js +27 -0
  14. package/dist/vue-components16.es.js +28 -0
  15. package/dist/vue-components17.es.js +7 -0
  16. package/dist/vue-components18.es.js +18 -0
  17. package/dist/vue-components19.es.js +36 -0
  18. package/dist/vue-components2.es.js +11 -0
  19. package/dist/vue-components20.es.js +18 -0
  20. package/dist/vue-components21.es.js +21 -0
  21. package/dist/vue-components22.es.js +30 -0
  22. package/dist/vue-components23.es.js +7 -0
  23. package/dist/vue-components24.es.js +9 -0
  24. package/dist/vue-components25.es.js +38 -0
  25. package/dist/vue-components26.es.js +25 -0
  26. package/dist/vue-components27.es.js +128 -0
  27. package/dist/vue-components28.es.js +24 -0
  28. package/dist/vue-components29.es.js +21 -0
  29. package/dist/vue-components3.es.js +54 -0
  30. package/dist/vue-components30.es.js +9 -0
  31. package/dist/vue-components31.es.js +19 -0
  32. package/dist/vue-components32.es.js +5 -0
  33. package/dist/vue-components33.es.js +29 -0
  34. package/dist/vue-components34.es.js +5 -0
  35. package/dist/vue-components35.es.js +29 -0
  36. package/dist/vue-components36.es.js +6 -0
  37. package/dist/vue-components37.es.js +18 -0
  38. package/dist/vue-components38.es.js +56 -0
  39. package/dist/vue-components39.es.js +5 -0
  40. package/dist/vue-components4.es.js +5 -0
  41. package/dist/vue-components40.es.js +44 -0
  42. package/dist/vue-components41.es.js +5 -0
  43. package/dist/vue-components42.es.js +84 -0
  44. package/dist/vue-components44.es.js +8 -0
  45. package/dist/vue-components45.es.js +7 -0
  46. package/dist/vue-components46.es.js +267 -0
  47. package/dist/vue-components48.es.js +6 -0
  48. package/dist/vue-components49.es.js +79 -0
  49. package/dist/vue-components5.es.js +24 -0
  50. package/dist/vue-components50.es.js +5 -0
  51. package/dist/vue-components51.es.js +66 -0
  52. package/dist/vue-components52.es.js +5 -0
  53. package/dist/vue-components53.es.js +24 -0
  54. package/dist/vue-components54.es.js +5 -0
  55. package/dist/vue-components55.es.js +59 -0
  56. package/dist/vue-components56.es.js +5 -0
  57. package/dist/vue-components57.es.js +12 -0
  58. package/dist/vue-components58.es.js +22 -0
  59. package/dist/vue-components6.es.js +13 -0
  60. package/dist/vue-components60.es.js +7 -0
  61. package/dist/vue-components61.es.js +235 -0
  62. package/dist/vue-components62.es.js +33 -0
  63. package/dist/vue-components63.es.js +8 -0
  64. package/dist/vue-components64.es.js +36 -0
  65. package/dist/vue-components7.es.js +28 -0
  66. package/dist/vue-components8.es.js +47 -0
  67. package/dist/vue-components9.es.js +5 -0
  68. package/package.json +30 -25
  69. package/src/components/CommandButton.vue +1 -1
  70. package/src/components/OmegaForm/OmegaAutoGen.vue +25 -30
  71. package/src/components/OmegaForm/OmegaErrorsInternal.vue +2 -3
  72. package/src/components/OmegaForm/OmegaFormStuff.ts +504 -355
  73. package/src/components/OmegaForm/OmegaInternalInput.vue +9 -5
  74. package/src/components/OmegaForm/useOmegaForm.ts +57 -36
  75. package/src/reset.css +52 -0
  76. package/src/utils/index.ts +4 -8
  77. package/dist/vue-components.es10.js +0 -237
  78. package/dist/vue-components.es100.js +0 -4
  79. package/dist/vue-components.es11.js +0 -32
  80. package/dist/vue-components.es12.js +0 -439
  81. package/dist/vue-components.es13.js +0 -49
  82. package/dist/vue-components.es14.js +0 -4
  83. package/dist/vue-components.es15.js +0 -4
  84. package/dist/vue-components.es16.js +0 -725
  85. package/dist/vue-components.es17.js +0 -143
  86. package/dist/vue-components.es18.js +0 -6
  87. package/dist/vue-components.es19.js +0 -13
  88. package/dist/vue-components.es2.js +0 -30
  89. package/dist/vue-components.es20.js +0 -5
  90. package/dist/vue-components.es21.js +0 -26
  91. package/dist/vue-components.es22.js +0 -6
  92. package/dist/vue-components.es23.js +0 -10
  93. package/dist/vue-components.es24.js +0 -57
  94. package/dist/vue-components.es25.js +0 -71
  95. package/dist/vue-components.es26.js +0 -8
  96. package/dist/vue-components.es27.js +0 -8
  97. package/dist/vue-components.es28.js +0 -5
  98. package/dist/vue-components.es29.js +0 -5
  99. package/dist/vue-components.es3.js +0 -16
  100. package/dist/vue-components.es30.js +0 -4
  101. package/dist/vue-components.es31.js +0 -4
  102. package/dist/vue-components.es32.js +0 -4
  103. package/dist/vue-components.es33.js +0 -4
  104. package/dist/vue-components.es34.js +0 -19
  105. package/dist/vue-components.es35.js +0 -13
  106. package/dist/vue-components.es36.js +0 -40
  107. package/dist/vue-components.es37.js +0 -6
  108. package/dist/vue-components.es38.js +0 -85
  109. package/dist/vue-components.es39.js +0 -54
  110. package/dist/vue-components.es4.js +0 -52
  111. package/dist/vue-components.es40.js +0 -563
  112. package/dist/vue-components.es41.js +0 -43
  113. package/dist/vue-components.es42.js +0 -29
  114. package/dist/vue-components.es43.js +0 -7
  115. package/dist/vue-components.es44.js +0 -42
  116. package/dist/vue-components.es45.js +0 -316
  117. package/dist/vue-components.es46.js +0 -33
  118. package/dist/vue-components.es47.js +0 -6
  119. package/dist/vue-components.es48.js +0 -26
  120. package/dist/vue-components.es49.js +0 -77
  121. package/dist/vue-components.es5.js +0 -52
  122. package/dist/vue-components.es50.js +0 -101
  123. package/dist/vue-components.es51.js +0 -4
  124. package/dist/vue-components.es52.js +0 -320
  125. package/dist/vue-components.es53.js +0 -66
  126. package/dist/vue-components.es54.js +0 -4
  127. package/dist/vue-components.es55.js +0 -4
  128. package/dist/vue-components.es56.js +0 -113
  129. package/dist/vue-components.es58.js +0 -9
  130. package/dist/vue-components.es59.js +0 -34
  131. package/dist/vue-components.es6.js +0 -69
  132. package/dist/vue-components.es61.js +0 -194
  133. package/dist/vue-components.es63.js +0 -6
  134. package/dist/vue-components.es64.js +0 -103
  135. package/dist/vue-components.es65.js +0 -4
  136. package/dist/vue-components.es66.js +0 -23
  137. package/dist/vue-components.es67.js +0 -84
  138. package/dist/vue-components.es68.js +0 -14
  139. package/dist/vue-components.es69.js +0 -115
  140. package/dist/vue-components.es7.js +0 -83
  141. package/dist/vue-components.es70.js +0 -5
  142. package/dist/vue-components.es71.js +0 -34
  143. package/dist/vue-components.es72.js +0 -4
  144. package/dist/vue-components.es73.js +0 -4
  145. package/dist/vue-components.es74.js +0 -17
  146. package/dist/vue-components.es75.js +0 -72
  147. package/dist/vue-components.es76.js +0 -17
  148. package/dist/vue-components.es77.js +0 -18
  149. package/dist/vue-components.es78.js +0 -10
  150. package/dist/vue-components.es79.js +0 -25
  151. package/dist/vue-components.es8.js +0 -63
  152. package/dist/vue-components.es80.js +0 -7
  153. package/dist/vue-components.es81.js +0 -23
  154. package/dist/vue-components.es82.js +0 -32
  155. package/dist/vue-components.es83.js +0 -24
  156. package/dist/vue-components.es84.js +0 -14
  157. package/dist/vue-components.es85.js +0 -7
  158. package/dist/vue-components.es86.js +0 -21
  159. package/dist/vue-components.es87.js +0 -11
  160. package/dist/vue-components.es88.js +0 -33
  161. package/dist/vue-components.es89.js +0 -50
  162. package/dist/vue-components.es9.js +0 -21
  163. package/dist/vue-components.es90.js +0 -28
  164. package/dist/vue-components.es91.js +0 -13
  165. package/dist/vue-components.es92.js +0 -67
  166. package/dist/vue-components.es93.js +0 -58
  167. package/dist/vue-components.es94.js +0 -19
  168. package/dist/vue-components.es95.js +0 -35
  169. package/dist/vue-components.es96.js +0 -31
  170. package/dist/vue-components.es97.js +0 -44
  171. package/dist/vue-components.es98.js +0 -4
  172. package/dist/vue-components.es99.js +0 -46
@@ -0,0 +1,12 @@
1
+ import { computed as e } from "vue";
2
+ import { useStore as t } from "@tanstack/vue-form";
3
+ //#region src/components/OmegaForm/getOmegaStore.ts
4
+ function n(n, r) {
5
+ return e(() => r ? t(n.store, (e) => {
6
+ let t = {};
7
+ for (let n of r) t[n] = e[n];
8
+ return t;
9
+ }).value : {});
10
+ }
11
+ //#endregion
12
+ export { n as getOmegaStore };
@@ -0,0 +1,22 @@
1
+ import { usePreventClose as e } from "./vue-components7.es.js";
2
+ import { getOmegaStore as t } from "./vue-components57.es.js";
3
+ import { createElementBlock as n, createElementVNode as r, defineComponent as i, openBlock as a, renderSlot as o, unref as s, withModifiers as c } from "vue";
4
+ import { useStore as l } from "@tanstack/vue-form";
5
+ //#region src/components/OmegaForm/OmegaWrapper.vue?vue&type=script&setup=true&lang.ts
6
+ var u = ["disabled"], d = /* @__PURE__ */ i({
7
+ __name: "OmegaWrapper",
8
+ props: {
9
+ form: {},
10
+ disabled: { type: Boolean },
11
+ subscribe: {}
12
+ },
13
+ setup(i) {
14
+ let d = i, f = l(d.form.store, (e) => e.isSubmitting), p = t(d.form, d.subscribe);
15
+ return d.form.ignorePreventCloseEvents || e(() => d.form.useStore((e) => e.isDirty)), (e, t) => (a(), n("form", {
16
+ novalidate: "",
17
+ onSubmit: t[0] ||= c((e) => i.form.handleSubmit(), ["prevent", "stop"])
18
+ }, [r("fieldset", { disabled: s(f) || i.disabled }, [o(e.$slots, "default", { subscribedValues: s(p) }, void 0, !0)], 8, u)], 32));
19
+ }
20
+ });
21
+ //#endregion
22
+ export { d as default };
@@ -0,0 +1,13 @@
1
+ import { onMounted as e, onUnmounted as t } from "vue";
2
+ //#region src/components/OmegaForm/onMountedWithCleanup.ts
3
+ function n(n) {
4
+ let r;
5
+ e(() => {
6
+ let e = n();
7
+ e && (r = e);
8
+ }), t(() => {
9
+ r && r();
10
+ });
11
+ }
12
+ //#endregion
13
+ export { n as onMountedWithCleanup };
@@ -0,0 +1,7 @@
1
+ (function(){try{if(typeof document<`u`){var e=document.createElement(`style`);if(e.appendChild(document.createTextNode(`fieldset[data-v-8c9cb27c]{display:contents}fieldset[disabled][data-v-8c9cb27c]>*{pointer-events:none}`)),document.head.appendChild(e),window.customElements){let e=window.customElements.define;window.customElements.define=function(t,n){let r=n.prototype.connectedCallback;return n.prototype.connectedCallback=function(){if(r&&r.call(this),this.shadowRoot){let e=document.createElement(`style`);e.appendChild(document.createTextNode(`fieldset[data-v-8c9cb27c]{display:contents}fieldset[disabled][data-v-8c9cb27c]>*{pointer-events:none}`)),this.shadowRoot.appendChild(e)}},e.call(window.customElements,t,n)}}}}catch(e){console.error(`vite-plugin-css-injected-by-js`,e)}})();import e from "./vue-components44.es.js";
2
+ import t from "./vue-components58.es.js";
3
+
4
+ //#region src/components/OmegaForm/OmegaWrapper.vue
5
+ var n = /* @__PURE__ */ e(t, [["__scopeId", "data-v-8c9cb27c"]]);
6
+ //#endregion
7
+ export { n as default };
@@ -0,0 +1,235 @@
1
+ import { useIntl as e } from "./vue-components11.es.js";
2
+ import { deepMerge as t, defaultsValueFromSchema as n, generateMetaFromSchema as r, toFormSchema as i } from "./vue-components12.es.js";
3
+ import { context as a } from "./vue-components32.es.js";
4
+ import { trace as o } from "./vue-components34.es.js";
5
+ import { runtimeFiberAsPromise as s } from "./vue-components37.es.js";
6
+ import c from "./vue-components39.es.js";
7
+ import l from "./vue-components41.es.js";
8
+ import u from "./vue-components45.es.js";
9
+ import d from "./vue-components52.es.js";
10
+ import f from "./vue-components56.es.js";
11
+ import p from "./vue-components60.es.js";
12
+ import { computed as m, h, onBeforeUnmount as g, onMounted as ee, onUnmounted as _, ref as v, watch as y } from "vue";
13
+ import { Array as b, Context as x, Data as S, Effect as C, Fiber as w, Option as T, S as E } from "effect-app";
14
+ import { useForm as D } from "@tanstack/vue-form";
15
+ import { makeRunPromise as O } from "@effect-app/vue/runtime";
16
+ //#region src/components/OmegaForm/useOmegaForm.ts
17
+ var te = class extends S.TaggedError("FormErrors") {}, k = (e) => function(t) {
18
+ return { render() {
19
+ return h(t, {
20
+ form: e,
21
+ ...this.$attrs
22
+ }, this.$slots);
23
+ } };
24
+ }, A = (t) => {
25
+ let { formatMessage: n } = e(), r = (e) => e.replace(/([A-Z])/g, " $1").replace(/^./, (e) => e.toUpperCase()).trim(), i = (e) => n ? n({
26
+ id: `general.fields.${e}`,
27
+ defaultMessage: r(e)
28
+ }) : r(e);
29
+ return (e) => t.i18nNamespace ? n({
30
+ id: `${t.i18nNamespace}.fields.${e}`,
31
+ defaultMessage: i(e)
32
+ }) : i(e);
33
+ }, j = (e) => function(t) {
34
+ return {
35
+ setup() {
36
+ let { fieldMap: t, form: n } = e, r = n.useStore((e) => e.errors), i = n.useStore((e) => e.fieldMeta), a = n.useStore((e) => e.errorMap), o = A(n);
37
+ return {
38
+ generalErrors: r,
39
+ errors: m(() => {
40
+ let e = Object.entries(i.value).reduce((e, [n, r]) => {
41
+ let i = r?.errors ?? [];
42
+ if (!i.length) return e;
43
+ let a = t.value.get(n);
44
+ return a && e.push({
45
+ label: a.label,
46
+ inputId: a.id,
47
+ errors: [i[0]?.message].filter(Boolean)
48
+ }), e;
49
+ }, []), n = [];
50
+ if (a.value.onSubmit) {
51
+ for (let [e, r] of Object.entries(a.value.onSubmit)) if (b.isArray(r) && r.length) for (let e of r) {
52
+ let r = e;
53
+ if (r?.path && b.isArray(r.path) && r.path.length) {
54
+ let e = r.path.join(".");
55
+ if (!t.value.has(e)) {
56
+ n.push({
57
+ label: o(e),
58
+ inputId: e,
59
+ errors: [r.message].filter(Boolean)
60
+ });
61
+ break;
62
+ }
63
+ }
64
+ }
65
+ }
66
+ return [...e, ...n];
67
+ })
68
+ };
69
+ },
70
+ render({ errors: e, generalErrors: n }) {
71
+ return h(t, {
72
+ errors: e,
73
+ generalErrors: n,
74
+ ...this.$attrs
75
+ }, this.$slots);
76
+ }
77
+ };
78
+ }, M = (e, t) => e.includes(t), N = O(x.empty()), P = (e, h, x) => {
79
+ if (!e) throw Error("Schema is required");
80
+ let S = i(e), O = E.toStandardSchemaV1(S), A = E.decodeUnknownEffect(S), { meta: P, unionMeta: ne } = r(e), F = m(() => x?.persistency?.id ? x.persistency.id : `${window.location.pathname}-${Object.keys(P).join("-")}`), I = () => {
81
+ let e = new URLSearchParams(window.location.search);
82
+ e.delete(F.value);
83
+ let t = new URL(window.location.href);
84
+ t.search = e.toString(), window.history.replaceState({}, "", t.toString());
85
+ }, L = m(() => {
86
+ let r, i = x?.persistency;
87
+ if (i?.policies && !r && (M(i.policies, "local") || M(i.policies, "session"))) {
88
+ let e = M(i.policies, "local") ? localStorage : sessionStorage;
89
+ if (e) try {
90
+ let t = JSON.parse(e.getItem(F.value) || "{}");
91
+ e.removeItem(F.value), r = t;
92
+ } catch (e) {
93
+ console.error(e);
94
+ }
95
+ }
96
+ if (i?.policies && M(i.policies, "querystring")) try {
97
+ let e = new URLSearchParams(window.location.search).get(F.value);
98
+ I(), e && (r = t(r || {}, JSON.parse(e)));
99
+ } catch (e) {
100
+ console.error(e);
101
+ }
102
+ r ??= {};
103
+ let a = {
104
+ tanstack: h?.defaultValues || {},
105
+ persistency: r,
106
+ schema: n(e)
107
+ };
108
+ return (x?.defaultValuesPriority || [
109
+ "tanstack",
110
+ "persistency",
111
+ "schema"
112
+ ]).reverse().reduce((e, n) => Object.keys(e).length ? t(e, a[n]) : a[n], {});
113
+ }), R = (e, t) => e ? a.with(o.setSpan(a.active(), e), t) : t(), z = D({
114
+ ...h,
115
+ validators: {
116
+ onSubmit: O,
117
+ ...h?.validators || {}
118
+ },
119
+ onSubmit: h?.onSubmit ? ({ formApi: e, meta: t, value: n }) => R(t?.currentSpan, async () => {
120
+ let r = await N(A(n)), i = h.onSubmit({
121
+ formApi: e,
122
+ meta: t,
123
+ value: r
124
+ });
125
+ if (w.isFiber(i)) return await s(i);
126
+ if (C.isEffect(i)) {
127
+ let e = await N(i);
128
+ return w.isFiber(e) ? await s(e) : e;
129
+ }
130
+ return i;
131
+ }) : void 0,
132
+ defaultValues: L.value
133
+ }), B = () => {
134
+ Object.keys(P).forEach((e) => {
135
+ z.setFieldValue(e, void 0);
136
+ });
137
+ }, V = (e) => e.reduce((e, t) => {
138
+ let n = t.split(".");
139
+ return n.reduce((e, r, i) => (i === n.length - 1 ? e[r] = z.getFieldValue(t) : e[r] = e[r] ?? {}, e[r]), e), e;
140
+ }, {}), H = (e) => {
141
+ if (!e) return;
142
+ let { banKeys: t, keys: n } = e;
143
+ return b.isArray(n) ? V(n) : b.isArray(t) ? V(Object.keys(P).filter((e) => t.includes(e))) : z.store.state.values;
144
+ }, U = () => {
145
+ let e = x?.persistency;
146
+ if (!(!e?.policies || e.policies.length === 0) && (M(e.policies, "local") || M(e.policies, "session"))) {
147
+ let t = M(e.policies, "local") ? localStorage : sessionStorage;
148
+ if (!t) return;
149
+ let n = H(e);
150
+ return t.setItem(F.value, JSON.stringify(n));
151
+ }
152
+ }, W = () => {
153
+ let e = x?.persistency;
154
+ if (!(!e?.policies || e.policies.length === 0) && M(e.policies, "querystring")) {
155
+ let t = H(e), n = new URLSearchParams(window.location.search);
156
+ n.set(F.value, JSON.stringify(t));
157
+ let r = new URL(window.location.href);
158
+ r.search = n.toString(), window.history.replaceState({}, "", r.toString());
159
+ }
160
+ }, G = (e) => {
161
+ z.store.state.isDirty && e.preventDefault();
162
+ };
163
+ if (_(U), ee(() => {
164
+ window.addEventListener("beforeunload", U), window.addEventListener("blur", W), x?.preventWindowExit && x.preventWindowExit !== "nope" && window.addEventListener("beforeunload", G);
165
+ }), g(() => {
166
+ window.removeEventListener("beforeunload", U), window.removeEventListener("blur", W), x?.preventWindowExit && x.preventWindowExit !== "nope" && window.removeEventListener("beforeunload", G);
167
+ }), x?.preventWindowExit === "prevent-and-reset") {
168
+ let e = z.useStore((e) => e.isSubmitting), t = z.useStore((e) => e.submissionAttempts), n = z.useStore((e) => e.canSubmit), r = z.useStore((e) => e.values);
169
+ y([e, t], ([e, t], [i]) => {
170
+ i && !e && t > 0 && n.value && z.reset(r.value);
171
+ });
172
+ }
173
+ let K = (e) => C.currentSpan.pipe(C.option, C.flatMap((t) => C.promise(() => z.handleSubmit(T.isSome(t) ? {
174
+ currentSpan: t.value,
175
+ ...e
176
+ } : e)))), q = (e) => e?.checkErrors ? K(e?.meta).pipe(C.flatMap(C.fnUntraced(function* () {
177
+ let e = z.getAllErrors();
178
+ if (Object.keys(e.fields).length || e.form.errors.length) return yield* C.fail(new te({
179
+ form: e.form,
180
+ fields: e.fields
181
+ }));
182
+ }))) : K(e?.meta), J = z.handleSubmit, Y = v(/* @__PURE__ */ new Map()), X = Object.assign(z, {
183
+ i18nNamespace: x?.i18nNamespace,
184
+ ignorePreventCloseEvents: x?.ignorePreventCloseEvents,
185
+ meta: P,
186
+ unionMeta: ne,
187
+ clear: B,
188
+ handleSubmit: (e) => J({
189
+ currentSpan: o.getSpan(a.active()),
190
+ ...e
191
+ }),
192
+ handleSubmitEffect: q,
193
+ registerField: (e) => {
194
+ y(e, (e) => {
195
+ Y.value.set(e.name, {
196
+ label: e.label,
197
+ id: e.id
198
+ });
199
+ }, { immediate: !0 }), _(() => {
200
+ Y.value.get(e.value.name)?.id === e.value.id && Y.value.delete(e.value.name);
201
+ });
202
+ }
203
+ }), Z = v(0), Q = z.useStore((e) => e.submissionAttempts);
204
+ y(z.useStore((e) => e.values), () => {
205
+ if (Z.value !== Q.value) {
206
+ Z.value = Q.value;
207
+ for (let e of Object.values(z.fieldInfo)) e?.instance?.state.meta.errorMap?.onSubmit && e.instance.setMeta((e) => ({
208
+ ...e,
209
+ errorMap: {
210
+ ...e.errorMap,
211
+ onSubmit: void 0
212
+ }
213
+ }));
214
+ }
215
+ }, { deep: !0 });
216
+ let $ = {
217
+ form: X,
218
+ fieldMap: Y
219
+ };
220
+ return Object.assign(X, {
221
+ _paths: void 0,
222
+ _keys: void 0,
223
+ _schema: e,
224
+ errorContext: $,
225
+ Form: k(X)(p),
226
+ Input: k(X)(x?.input ?? d),
227
+ TaggedUnion: k(X)(f),
228
+ Field: z.Field,
229
+ Errors: j($)(u),
230
+ Array: k(X)(c),
231
+ AutoGen: k(X)(l)
232
+ });
233
+ };
234
+ //#endregion
235
+ export { A as useErrorLabel, P as useOmegaForm };
@@ -0,0 +1,33 @@
1
+ import e from "./vue-components52.es.js";
2
+ import { useOmegaForm as t } from "./vue-components61.es.js";
3
+ import { h as n } from "vue";
4
+ //#region src/components/OmegaForm/createUseFormWithCustomInput.ts
5
+ var r = (r) => (...i) => {
6
+ let [a, o, s] = i, c = {
7
+ name: "WrappedInput",
8
+ inheritAttrs: !1,
9
+ setup(t, { attrs: i, slots: a }) {
10
+ return () => n(e, {
11
+ ...t,
12
+ ...i
13
+ }, {
14
+ default: ({ field: e, state: t, ...o }) => n(r, {
15
+ ...Object.fromEntries(Object.entries(i).filter(([e]) => !Object.prototype.hasOwnProperty.call(o, e) && e !== "form")),
16
+ field: e,
17
+ state: t,
18
+ inputProps: o
19
+ }, {
20
+ ...a.label && { label: (e) => a.label(e) },
21
+ ...a.default && { default: (e) => a.default(e) }
22
+ }),
23
+ ...a.label && { label: (e) => a.label(e) }
24
+ });
25
+ }
26
+ };
27
+ return t(a, o, {
28
+ ...s,
29
+ input: c
30
+ });
31
+ };
32
+ //#endregion
33
+ export { r as createUseFormWithCustomInput };
@@ -0,0 +1,8 @@
1
+ import "./vue-components7.es.js";
2
+ import "./vue-components12.es.js";
3
+ import "./vue-components50.es.js";
4
+ import "./vue-components52.es.js";
5
+ import "./vue-components54.es.js";
6
+ import "./vue-components56.es.js";
7
+ import "./vue-components61.es.js";
8
+ import "./vue-components62.es.js";
@@ -0,0 +1,36 @@
1
+ import { __exportAll as e } from "./vue-components2.es.js";
2
+ import t from "./vue-components4.es.js";
3
+ import { useOnClose as n, usePreventClose as r } from "./vue-components7.es.js";
4
+ import i from "./vue-components9.es.js";
5
+ import { createMeta as a, deepMerge as o, defaultsValueFromSchema as s, duplicateSchema as c, generateInputStandardSchemaFromFieldMeta as l, generateMetaFromSchema as u, getInputType as d, isNullableOrUndefined as f, toFormSchema as p } from "./vue-components12.es.js";
6
+ import m from "./vue-components50.es.js";
7
+ import h from "./vue-components52.es.js";
8
+ import g from "./vue-components54.es.js";
9
+ import _ from "./vue-components56.es.js";
10
+ import { useOmegaForm as v } from "./vue-components61.es.js";
11
+ import { createUseFormWithCustomInput as y } from "./vue-components62.es.js";
12
+ import "./vue-components63.es.js";
13
+ //#region src/components/index.ts
14
+ var b = /* @__PURE__ */ e({
15
+ CommandButton: () => t,
16
+ Dialog: () => i,
17
+ OmegaInput: () => h,
18
+ OmegaTaggedUnion: () => _,
19
+ OmegaTaggedUnionInternal: () => g,
20
+ OmegaVuetifyInput: () => m,
21
+ createMeta: () => a,
22
+ createUseFormWithCustomInput: () => y,
23
+ deepMerge: () => o,
24
+ defaultsValueFromSchema: () => s,
25
+ duplicateSchema: () => c,
26
+ generateInputStandardSchemaFromFieldMeta: () => l,
27
+ generateMetaFromSchema: () => u,
28
+ getInputType: () => d,
29
+ isNullableOrUndefined: () => f,
30
+ toFormSchema: () => p,
31
+ useOmegaForm: () => v,
32
+ useOnClose: () => n,
33
+ usePreventClose: () => r
34
+ });
35
+ //#endregion
36
+ export { b as components_exports };
@@ -0,0 +1,28 @@
1
+ import e from "./vue-components5.es.js";
2
+ import { onMountedWithCleanup as t } from "./vue-components6.es.js";
3
+ import { inject as n, provide as r } from "vue";
4
+ //#region src/components/OmegaForm/blockDialog.ts
5
+ var i = () => e(), a = Symbol("DialogBus"), o = () => n(a, null), s = () => {
6
+ let e = i();
7
+ return r(a, e), e;
8
+ }, c = (e) => {
9
+ let n = o();
10
+ if (!n) return;
11
+ let r = e();
12
+ t(() => {
13
+ let e = (e) => {
14
+ r.value && (confirm("Es sind ungespeicherte Änderungen vorhanden. Wirklich schließen?") || (e.prevent = !0));
15
+ };
16
+ return n.on("dialog-closing", e), () => n.off("dialog-closing", e);
17
+ });
18
+ }, l = (e) => {
19
+ let t = o();
20
+ return t ||= s(), () => {
21
+ let n = {};
22
+ t.emit("dialog-closing", n), n.prevent ? typeof n.prevent == "object" && "then" in n.prevent && n.prevent.then((t) => {
23
+ t !== !1 && e();
24
+ }) : e();
25
+ };
26
+ };
27
+ //#endregion
28
+ export { l as useOnClose, c as usePreventClose };
@@ -0,0 +1,47 @@
1
+ import { onMountedWithCleanup as e } from "./vue-components6.es.js";
2
+ import { useOnClose as t } from "./vue-components7.es.js";
3
+ import { computed as n, createBlock as r, createSlots as i, defineComponent as a, guardReactiveProps as o, mergeModels as s, normalizeProps as c, openBlock as l, renderList as u, renderSlot as d, resolveComponent as f, unref as p, useModel as m, useSlots as h, withCtx as g } from "vue";
4
+ //#region src/components/Dialog.vue?vue&type=script&setup=true&lang.ts
5
+ var _ = /* @__PURE__ */ a({
6
+ __name: "Dialog",
7
+ props: /* @__PURE__ */ s({ persistent: { type: Boolean } }, {
8
+ modelValue: {
9
+ type: Boolean,
10
+ default: !1
11
+ },
12
+ modelModifiers: {}
13
+ }),
14
+ emits: ["update:modelValue"],
15
+ setup(a) {
16
+ let s = a, _ = m(a, "modelValue"), v = h(), y = n(() => {
17
+ let { default: e, ...t } = v;
18
+ return t;
19
+ }), b = t(() => _.value = !1);
20
+ return e(() => {
21
+ let e = (e) => {
22
+ _.value && !s.persistent && e.code === "Escape" && b();
23
+ };
24
+ return document.addEventListener("keydown", e), () => document.removeEventListener("keydown", e);
25
+ }), (e, t) => {
26
+ let n = f("v-dialog");
27
+ return l(), r(n, {
28
+ modelValue: _.value,
29
+ "onUpdate:modelValue": t[0] ||= (e) => _.value = e,
30
+ persistent: "",
31
+ "onClick:outside": p(b)
32
+ }, i({
33
+ default: g(({ isActive: t }) => [d(e.$slots, "default", {
34
+ open: _.value,
35
+ cancel: p(b),
36
+ isActive: t
37
+ })]),
38
+ _: 2
39
+ }, [u(y.value, (t, n) => ({
40
+ name: n,
41
+ fn: g((t) => [d(e.$slots, n, c(o(t)))])
42
+ }))]), 1032, ["modelValue", "onClick:outside"]);
43
+ };
44
+ }
45
+ });
46
+ //#endregion
47
+ export { _ as default };
@@ -0,0 +1,5 @@
1
+ import e from "./vue-components8.es.js";
2
+ //#region src/components/Dialog.vue
3
+ var t = e;
4
+ //#endregion
5
+ export { t as default };
package/package.json CHANGED
@@ -1,39 +1,40 @@
1
1
  {
2
2
  "name": "@effect-app/vue-components",
3
- "version": "4.0.0-beta.9",
3
+ "version": "4.0.0-beta.91",
4
4
  "peerDependencies": {
5
5
  "@mdi/js": "^7.4.47",
6
- "effect": "^4.0.0-beta.25",
7
- "intl-messageformat": "^11.1.2",
6
+ "effect": "^4.0.0-beta.47",
7
+ "intl-messageformat": "^11.2.0",
8
8
  "mdi-js": "^1.0.1",
9
9
  "primeflex": "^4.0.0",
10
10
  "primeicons": "^7.0.0",
11
11
  "primevue": "^4.5.4",
12
- "vue": "^3.5.29",
13
- "vuetify": "^4.0.0"
12
+ "vue": "^3.5.32",
13
+ "vuetify": "^4.0.5"
14
14
  },
15
15
  "devDependencies": {
16
- "@storybook/vue3": "^10.2.13",
17
- "@storybook/vue3-vite": "^10.2.13",
18
- "@types/node": "^25.3.3",
19
- "@vitejs/plugin-vue": "^6.0.4",
16
+ "@storybook/vue3": "^10.3.4",
17
+ "@storybook/vue3-vite": "^10.3.4",
18
+ "@types/node": "^25.5.2",
19
+ "@vitejs/plugin-vue": "^6.0.5",
20
20
  "@vue/test-utils": "^2.4.6",
21
21
  "@vueuse/core": "^14.2.1",
22
- "dprint": "^0.52.0",
23
- "jsdom": "^28.1.0",
22
+ "dprint": "^0.53.2",
23
+ "jsdom": "^29.0.2",
24
24
  "rimraf": "^6.1.3",
25
- "sass": "^1.97.3",
26
- "storybook": "^10.2.13",
27
- "typescript": "~5.9.3",
28
- "vite": "^7.3.1",
25
+ "sass": "^1.99.0",
26
+ "storybook": "^10.3.4",
27
+ "storybook-vue3-router": "^7.0.0",
28
+ "typescript": "~6.0.2",
29
+ "vite": "^8.0.6",
29
30
  "vite-plugin-css-injected-by-js": "^4.0.1",
30
31
  "vitepress": "^1.6.4",
31
- "vitest": "^4.0.18",
32
- "vue-router": "^5.0.3",
32
+ "vitest": "^4.1.3",
33
+ "vue-router": "^5.0.4",
33
34
  "vue-toastification": "^2.0.0-rc.5",
34
- "vue-tsc": "^3.2.5",
35
- "vuetify": "^4.0.0",
36
- "@effect-app/eslint-shared-config": "0.5.7-beta.1"
35
+ "vue-tsc": "^3.2.6",
36
+ "vuetify": "^4.0.5",
37
+ "@effect-app/eslint-shared-config": "0.5.7-beta.9"
37
38
  },
38
39
  "files": [
39
40
  "src",
@@ -45,21 +46,25 @@
45
46
  "types": "./dist/types/index.d.ts",
46
47
  "import": "./dist/vue-components.es.js"
47
48
  },
48
- "./dist/vue-components.css": "./dist/vue-components.css"
49
+ "./dist/vue-components.css": "./dist/vue-components.css",
50
+ "./reset.css": {
51
+ "development": "./src/reset.css",
52
+ "default": "./dist/reset.css"
53
+ }
49
54
  },
50
55
  "dependencies": {
51
- "@opentelemetry/api": "^1.9.0",
56
+ "@opentelemetry/api": "^1.9.1",
52
57
  "@tanstack/vue-form": "^1.23.5",
53
58
  "highlight.js": "^11.11.1",
54
59
  "mitt": "^3.0.1",
55
60
  "vue3-highlightjs": "^1.0.5",
56
- "@effect-app/vue": "4.0.0-beta.9",
57
- "effect-app": "4.0.0-beta.9"
61
+ "@effect-app/vue": "4.0.0-beta.91",
62
+ "effect-app": "4.0.0-beta.91"
58
63
  },
59
64
  "scripts": {
60
65
  "check": "vue-tsc",
61
66
  "build": "pnpm build:run",
62
- "build:run": "rimraf dist && vue-tsc && vite build",
67
+ "build:run": "rimraf dist && vue-tsc && vite build && cp src/reset.css dist/reset.css",
63
68
  "docs:dev": "vitepress dev docs",
64
69
  "docs:build": "vitepress build docs",
65
70
  "docs:serve": "vitepress serve docs",
@@ -66,7 +66,7 @@ export default {
66
66
  :label="command.label"
67
67
  :title="title ?? command.action"
68
68
  >
69
- <span>{{ command.label }}</span>
69
+ {{ command.label }}
70
70
  </slot>
71
71
  </v-btn>
72
72
  <v-btn
@@ -20,8 +20,7 @@
20
20
  Name extends DeepKeys<From>"
21
21
  >
22
22
  import { type DeepKeys } from "@tanstack/vue-form"
23
- import { pipe } from "effect/Function"
24
- import * as Order from "effect/Order"
23
+ import { Order } from "effect-app"
25
24
  import { computed } from "vue"
26
25
  import { type FieldMeta, type FieldPath, type OmegaAutoGenMeta, type OmegaInputProps } from "./OmegaFormStuff"
27
26
 
@@ -71,37 +70,33 @@ const orderBy: Order.Order<NewMeta> = Order.mapInput(
71
70
  (x: NewMeta) => namePosition(x.name, props.order || [])
72
71
  )
73
72
 
74
- const children = computed<NewMeta[]>(() =>
75
- pipe(
76
- props.form.meta as Record<DeepKeys<From>, FieldMeta | undefined>,
77
- // include / exclude
78
- filterRecord((_, metaKey) =>
73
+ const children = computed<NewMeta[]>(() => {
74
+ const included = filterRecord((value, metaKey) =>
75
+ Boolean(value)
76
+ && (
79
77
  props.pick
80
78
  ? props.pick.includes(metaKey) && !props.omit?.includes(metaKey)
81
79
  : !props.omit?.includes(metaKey)
82
- ),
83
- (x: Record<DeepKeys<From>, FieldMeta | undefined>) => x,
84
- // labelMap and adding name
85
- mapObject((metaValue, metaKey) => ({
86
- name: metaKey as Name,
87
- label: props.labelMap?.(metaKey) || metaKey,
88
- ...(metaValue ?? {})
89
- })),
90
- // filterMap
91
- props.filterMap
92
- ? filterMapRecord((m: NewMeta) => {
93
- const result = props.filterMap?.(m.name!, m as NewMeta)
94
- return result === undefined || result === true ? m : result
95
- })
96
- : (x: Record<DeepKeys<From>, NewMeta>) => x,
97
- // transform to array
98
- (obj: Record<DeepKeys<From>, NewMeta>) => Object.values(obj) as NewMeta[],
99
- // order
100
- (items: NewMeta[]) => [...items].sort((a, b) => orderBy(a, b)),
101
- // sort
102
- props.sort ? (items: NewMeta[]) => [...items].sort((a, b) => props.sort!(a, b)) : (x: NewMeta[]) => x
103
- )
104
- )
80
+ )
81
+ )(props.form.meta as Record<DeepKeys<From>, FieldMeta | undefined>) as Record<DeepKeys<From>, FieldMeta>
82
+
83
+ const withLabels = mapObject((metaValue: FieldMeta, metaKey) => ({
84
+ name: metaKey,
85
+ label: props.labelMap?.(metaKey) || metaKey,
86
+ ...metaValue
87
+ }))(included) as unknown as Record<DeepKeys<From>, NewMeta>
88
+
89
+ const filtered = props.filterMap
90
+ ? filterMapRecord((m: NewMeta) => {
91
+ const result = props.filterMap?.(m.name, m)
92
+ return result === undefined || result === true ? m : result
93
+ })(withLabels) as Record<DeepKeys<From>, NewMeta>
94
+ : withLabels
95
+
96
+ const sorted = [...Object.values(filtered) as NewMeta[]].sort(orderBy)
97
+
98
+ return props.sort ? sorted.sort(props.sort) : sorted
99
+ })
105
100
 
106
101
  defineSlots<{
107
102
  default(props: { child: NewMeta }): void
@@ -130,10 +130,9 @@ const showedGeneralErrors = computed(() => {
130
130
  .flatMap((issues) =>
131
131
  issues
132
132
  .filter(
133
- (issue): issue is StandardSchemaV1Issue & { message: string } =>
134
- typeof (issue as { message?: unknown })?.message === "string"
133
+ (issue): issue is StandardSchemaV1Issue & { message: string } => Boolean(issue?.message)
135
134
  )
136
- .map((issue) => (issue as StandardSchemaV1Issue & { message: string }).message)
135
+ .map((issue) => issue.message)
137
136
  )
138
137
  )
139
138
  })