@effect-app/vue-components 0.22.15 → 0.22.17

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.
@@ -1,8 +1,8 @@
1
- (function(){"use strict";try{if(typeof document<"u"){var n=document.createElement("style");if(n.appendChild(document.createTextNode("fieldset[data-v-72cd2c5e]{display:contents}fieldset[disabled][data-v-72cd2c5e]>*{pointer-events:none}")),document.head.appendChild(n),window.customElements){const e=window.customElements.define;window.customElements.define=function(c,t){const d=t.prototype.connectedCallback;return t.prototype.connectedCallback=function(){if(d&&d.call(this),this.shadowRoot){const o=document.createElement("style");o.appendChild(document.createTextNode("fieldset[data-v-72cd2c5e]{display:contents}fieldset[disabled][data-v-72cd2c5e]>*{pointer-events:none}")),this.shadowRoot.appendChild(o)}},e.call(window.customElements,c,t)}}}}catch(e){console.error("vite-plugin-css-injected-by-js",e)}})();
1
+ (function(){"use strict";try{if(typeof document<"u"){var n=document.createElement("style");if(n.appendChild(document.createTextNode("fieldset[data-v-0628edeb]{display:contents}fieldset[disabled][data-v-0628edeb]>*{pointer-events:none}")),document.head.appendChild(n),window.customElements){const e=window.customElements.define;window.customElements.define=function(i,t){const d=t.prototype.connectedCallback;return t.prototype.connectedCallback=function(){if(d&&d.call(this),this.shadowRoot){const o=document.createElement("style");o.appendChild(document.createTextNode("fieldset[data-v-0628edeb]{display:contents}fieldset[disabled][data-v-0628edeb]>*{pointer-events:none}")),this.shadowRoot.appendChild(o)}},e.call(window.customElements,i,t)}}}}catch(e){console.error("vite-plugin-css-injected-by-js",e)}})();
2
2
  import o from "./vue-components.es20.js";
3
3
 
4
4
  import r from "./vue-components.es17.js";
5
- const e = /* @__PURE__ */ r(o, [["__scopeId", "data-v-72cd2c5e"]]);
5
+ const a = /* @__PURE__ */ r(o, [["__scopeId", "data-v-0628edeb"]]);
6
6
  export {
7
- e as default
7
+ a as default
8
8
  };
@@ -1,9 +1,9 @@
1
- import { defineComponent as M, getCurrentInstance as B, computed as v, onBeforeMount as F, watch as g, createElementBlock as S, openBlock as O, withModifiers as L, createElementVNode as C, unref as m, renderSlot as p, createCommentVNode as V, Fragment as k } from "vue";
2
- import { useStore as h } from "@tanstack/vue-form";
3
- import { getOmegaStore as $ } from "./vue-components.es26.js";
1
+ import { defineComponent as B, getCurrentInstance as F, computed as l, onBeforeMount as L, watch as S, createElementBlock as O, openBlock as h, withModifiers as C, createElementVNode as V, unref as m, renderSlot as b, createCommentVNode as k, Fragment as _ } from "vue";
2
+ import { useStore as y } from "@tanstack/vue-form";
3
+ import { getOmegaStore as $ } from "./vue-components.es27.js";
4
4
  import { provideOmegaErrors as A } from "./vue-components.es8.js";
5
5
  import { useOmegaForm as K } from "./vue-components.es9.js";
6
- const _ = ["disabled"], D = /* @__PURE__ */ M({
6
+ const P = ["disabled"], U = /* @__PURE__ */ B({
7
7
  __name: "OmegaWrapper",
8
8
  props: {
9
9
  omegaConfig: {},
@@ -26,21 +26,21 @@ const _ = ["disabled"], D = /* @__PURE__ */ M({
26
26
  isLoading: { type: Boolean, default: void 0 },
27
27
  onSubmit: {}
28
28
  },
29
- setup(y) {
30
- const o = y, w = B(), E = ({ formApi: e, meta: r, value: i }) => new Promise((t) => {
31
- w.emit("submit", { formApi: e, meta: r, value: i });
32
- const n = g(() => o.isLoading, (u) => {
29
+ setup(w) {
30
+ const o = w, E = F(), j = ({ formApi: e, meta: r, value: i }) => new Promise((t) => {
31
+ E.emit("submit", { formApi: e, meta: r, value: i });
32
+ const n = S(() => o.isLoading, (u) => {
33
33
  u || (t(), n.stop());
34
34
  });
35
- }), l = typeof o.isLoading < "u" ? E : typeof o.onSubmit < "u" ? o.onSubmit : void 0, f = o.form || !o.schema ? void 0 : K(
35
+ }), v = typeof o.isLoading < "u" ? l(() => j) : typeof o.onSubmit < "u" ? l(() => o.onSubmit) : void 0, f = v?.value ? (...e) => v.value(...e) : void 0, c = o.form || !o.schema ? void 0 : K(
36
36
  o.schema,
37
37
  {
38
38
  ...o,
39
- onSubmit: l
39
+ onSubmit: f
40
40
  },
41
41
  o.omegaConfig
42
- ), s = v(() => o.form ?? f);
43
- F(() => {
42
+ ), s = l(() => o.form ?? c);
43
+ L(() => {
44
44
  if (!o.form) return;
45
45
  const e = Object.keys(o.form.options || {}), r = /* @__PURE__ */ new Set([
46
46
  "omegaConfig",
@@ -51,7 +51,7 @@ const _ = ["disabled"], D = /* @__PURE__ */ M({
51
51
  "schema"
52
52
  ]), i = Object.fromEntries(
53
53
  Object.entries(o).filter(
54
- ([a, d]) => a === "isLoading" ? !1 : !r.has(a) && d !== void 0
54
+ ([a, p]) => a === "isLoading" ? !1 : !r.has(a) && p !== void 0
55
55
  )
56
56
  ), t = Object.keys(i), n = e.filter(
57
57
  (a) => t.includes(a) && i[a] !== void 0
@@ -68,27 +68,27 @@ Props will overwrite existing form options. This might indicate a configuration
68
68
  ...s.value.options,
69
69
  ...i
70
70
  };
71
- l && (u.onSubmit = l), s.value.options = Object.fromEntries(
71
+ f && (u.onSubmit = f), s.value.options = Object.fromEntries(
72
72
  // TODO
73
73
  Object.entries(u).filter(
74
- ([a, d]) => d !== void 0
74
+ ([a, p]) => p !== void 0
75
75
  )
76
76
  );
77
77
  });
78
- const j = h(
78
+ const I = y(
79
79
  s.value.store,
80
80
  (e) => e.isSubmitting
81
- ), b = $(
81
+ ), g = $(
82
82
  s.value,
83
83
  o.subscribe
84
- ), I = h(
84
+ ), M = y(
85
85
  s.value.store,
86
86
  (e) => e.submissionAttempts
87
- ), c = v(() => s.value.useStore((e) => e.errors));
88
- return g(
89
- () => [s.value.filterItems, c.value.value],
87
+ ), d = l(() => s.value.useStore((e) => e.errors));
88
+ return S(
89
+ () => [s.value.filterItems, d.value.value],
90
90
  () => {
91
- const e = s.value.filterItems, r = c.value.value;
91
+ const e = s.value.filterItems, r = d.value.value;
92
92
  return e ? r ? (Object.values(r).filter(
93
93
  (t) => !!t
94
94
  ).flatMap(
@@ -105,23 +105,23 @@ Props will overwrite existing form options. This might indicate a configuration
105
105
  });
106
106
  }), {}) : {} : {};
107
107
  }
108
- ), A(I, c.value, o.showErrorsOn), (e, r) => (O(), S("form", {
108
+ ), A(M, d.value, o.showErrorsOn), (e, r) => (h(), O("form", {
109
109
  novalidate: "",
110
- onSubmit: r[0] || (r[0] = L((i) => s.value.handleSubmit(), ["prevent", "stop"]))
110
+ onSubmit: r[0] || (r[0] = C((i) => s.value.handleSubmit(), ["prevent", "stop"]))
111
111
  }, [
112
- C("fieldset", { disabled: m(j) }, [
113
- o.form ? (O(), S(k, { key: 0 }, [
114
- p(e.$slots, "externalForm", { subscribedValues: m(b) }, void 0, !0),
115
- p(e.$slots, "default", {}, void 0, !0)
116
- ], 64)) : m(f) ? p(e.$slots, "internalForm", {
112
+ V("fieldset", { disabled: m(I) }, [
113
+ o.form ? (h(), O(_, { key: 0 }, [
114
+ b(e.$slots, "externalForm", { subscribedValues: m(g) }, void 0, !0),
115
+ b(e.$slots, "default", {}, void 0, !0)
116
+ ], 64)) : m(c) ? b(e.$slots, "internalForm", {
117
117
  key: 1,
118
- form: m(f),
119
- subscribedValues: m(b)
120
- }, void 0, !0) : V("", !0)
121
- ], 8, _)
118
+ form: m(c),
119
+ subscribedValues: m(g)
120
+ }, void 0, !0) : k("", !0)
121
+ ], 8, P)
122
122
  ], 32));
123
123
  }
124
124
  });
125
125
  export {
126
- D as default
126
+ U as default
127
127
  };
@@ -1,5 +1,5 @@
1
1
  import { Exit as c, Runtime as s } from "effect";
2
- import { dual as n, isFunction as m } from "./vue-components.es28.js";
2
+ import { dual as n, isFunction as m } from "./vue-components.es26.js";
3
3
  const i = Symbol.for("clone-trait"), u = n(2, (e, t) => i in e ? e[i](t) : Object.setPrototypeOf(t, Object.getPrototypeOf(e)));
4
4
  n(2, (e, t) => u(e, { ...e, ...m(t) ? t(e) : t }));
5
5
  const b = (e) => new Promise((t, r) => e.addObserver((o) => {
@@ -1,4 +1,4 @@
1
- import { isFunction as c } from "./vue-components.es28.js";
1
+ import { isFunction as c } from "./vue-components.es26.js";
2
2
  const s = c, t = (o) => typeof o == "object" && o !== null, i = (o) => t(o) || s(o);
3
3
  export {
4
4
  s as isFunction,
@@ -1,13 +1,44 @@
1
- import { useStore as u } from "@tanstack/vue-form";
2
- import { computed as f } from "vue";
3
- function c(o, t) {
4
- return f(() => t ? u(o.store, (n) => {
5
- const r = {};
6
- for (const e of t)
7
- r[e] = n[e];
8
- return r;
9
- }).value : {});
10
- }
1
+ const f = (c) => typeof c == "function", a = function(c, r) {
2
+ switch (c) {
3
+ case 0:
4
+ case 1:
5
+ throw new RangeError(`Invalid arity ${c}`);
6
+ case 2:
7
+ return function(n, t) {
8
+ return arguments.length >= 2 ? r(n, t) : function(e) {
9
+ return r(e, n);
10
+ };
11
+ };
12
+ case 3:
13
+ return function(n, t, e) {
14
+ return arguments.length >= 3 ? r(n, t, e) : function(u) {
15
+ return r(u, n, t);
16
+ };
17
+ };
18
+ case 4:
19
+ return function(n, t, e, u) {
20
+ return arguments.length >= 4 ? r(n, t, e, u) : function(i) {
21
+ return r(i, n, t, e);
22
+ };
23
+ };
24
+ case 5:
25
+ return function(n, t, e, u, i) {
26
+ return arguments.length >= 5 ? r(n, t, e, u, i) : function(s) {
27
+ return r(s, n, t, e, u);
28
+ };
29
+ };
30
+ default:
31
+ return function() {
32
+ if (arguments.length >= c)
33
+ return r.apply(this, arguments);
34
+ const n = arguments;
35
+ return function(t) {
36
+ return r(t, ...n);
37
+ };
38
+ };
39
+ }
40
+ };
11
41
  export {
12
- c as getOmegaStore
42
+ a as dual,
43
+ f as isFunction
13
44
  };
@@ -1,92 +1,13 @@
1
- (function(){"use strict";try{if(typeof document<"u"){var i=document.createElement("style");if(i.appendChild(document.createTextNode(".omega-input .v-input__details:has(.v-messages:empty){grid-template-rows:0fr;transition:all .2s}.omega-input .v-messages:empty{min-height:0}.omega-input .v-input__details:has(.v-messages){transition:all .2s;overflow:hidden;min-height:0;display:grid;grid-template-rows:1fr}.omega-input .v-messages{transition:all .2s}.omega-input .v-messages>*{transition-duration:0s!important}.omega-input [role=alert]:has(.v-messages:empty){padding:0}.omega-input .v-btn{cursor:pointer;width:auto;appearance:none;box-shadow:none;display:block;min-width:auto;height:auto;padding:.5em .5em .5em 1em}")),document.head.appendChild(i),window.customElements){const e=window.customElements.define;window.customElements.define=function(s,t){const n=t.prototype.connectedCallback;return t.prototype.connectedCallback=function(){if(n&&n.call(this),this.shadowRoot){const a=document.createElement("style");a.appendChild(document.createTextNode(".omega-input .v-input__details:has(.v-messages:empty){grid-template-rows:0fr;transition:all .2s}.omega-input .v-messages:empty{min-height:0}.omega-input .v-input__details:has(.v-messages){transition:all .2s;overflow:hidden;min-height:0;display:grid;grid-template-rows:1fr}.omega-input .v-messages{transition:all .2s}.omega-input .v-messages>*{transition-duration:0s!important}.omega-input [role=alert]:has(.v-messages:empty){padding:0}.omega-input .v-btn{cursor:pointer;width:auto;appearance:none;box-shadow:none;display:block;min-width:auto;height:auto;padding:.5em .5em .5em 1em}")),this.shadowRoot.appendChild(a)}},e.call(window.customElements,s,t)}}}}catch(e){console.error("vite-plugin-css-injected-by-js",e)}})();
2
- import { defineComponent as w, getCurrentInstance as x, useId as C, computed as a, watch as f, nextTick as N, onMounted as d, ref as $, watchEffect as k, renderSlot as B, normalizeProps as I, guardReactiveProps as O, createElementVNode as _, normalizeClass as q, createBlock as L, createCommentVNode as P, unref as F, openBlock as S, mergeProps as T } from "vue";
3
- import { useStore as z } from "@tanstack/vue-form";
4
- import { useOmegaErrors as A } from "./vue-components.es8.js";
5
- import D from "./vue-components.es51.js";
6
-
7
- const J = /* @__PURE__ */ w({
8
- inheritAttrs: !1,
9
- __name: "OmegaInternalInput",
10
- props: {
11
- field: {},
12
- meta: {},
13
- label: {},
14
- options: {},
15
- type: {},
16
- validators: {}
17
- },
18
- setup(c) {
19
- const e = c, v = x()?.appContext.components.VTextField, l = C(), o = e.field, r = z(o.store, (t) => t), m = a(() => e.type ? e.type : e.meta?.type === "string" ? e.meta.format === "email" ? "email" : "string" : e.meta?.type || "unknown"), n = a(() => r.value.value), g = a(
20
- () => (
21
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
22
- r.value.meta.errors.map((t) => t?.message).filter(Boolean)
23
- )
24
- ), y = (t) => t == null || t === !1 || t === "" || Number.isNaN(t);
25
- f(
26
- () => !!n.value,
27
- () => {
28
- y(n.value) && e.meta?.type !== "boolean" && N(() => {
29
- o.setValue(
30
- e.meta?.nullableOrUndefined === "undefined" ? void 0 : null
31
- );
32
- });
33
- }
34
- ), d(() => {
35
- !n.value && !e.meta?.required && e.meta?.nullableOrUndefined === "null" && o.setValue(null);
36
- });
37
- const { addError: h, removeError: b, showErrors: E, showErrorsOn: V } = A(), s = $(!1);
38
- k(() => {
39
- (E.value || V === "onChange") && (s.value = !0);
40
- });
41
- const u = () => {
42
- s.value = !0;
43
- };
44
- d(() => {
45
- n.value && u();
46
- });
47
- const p = a(() => !s.value && m.value !== "select" ? [] : g.value);
48
- f(
49
- () => r.value.meta.errors,
50
- () => {
51
- r.value.meta.errors.length ? h({
52
- inputId: l,
53
- errors: r.value.meta.errors.map((t) => t.message).filter(Boolean),
54
- label: e.label
55
- }) : b(l);
56
- }
57
- );
58
- const i = a(() => ({
59
- id: l,
60
- required: e.meta?.required,
61
- minLength: e.meta?.type === "string" && e.meta?.minLength,
62
- maxLength: e.meta?.type === "string" && e.meta?.maxLength,
63
- max: e.meta?.type === "number" && e.meta?.maximum,
64
- min: e.meta?.type === "number" && e.meta?.minimum,
65
- name: e.field.name,
66
- modelValue: e.field.state.value,
67
- errorMessages: p.value,
68
- error: !!p.value.length,
69
- field: e.field,
70
- setRealDirty: u,
71
- type: m.value,
72
- label: `${e.label}${e.meta?.required ? " *" : ""}`,
73
- options: e.options
74
- }));
75
- return (t, R) => B(t.$slots, "default", I(O(i.value)), () => [
76
- _("div", {
77
- class: q(t.$attrs.class),
78
- onFocusout: u
79
- }, [
80
- F(v) ? (S(), L(D, T({
81
- key: 0,
82
- "input-props": i.value
83
- }, t.$attrs, {
84
- "vuetify-value": i.value.field.state.value
85
- }), null, 16, ["input-props", "vuetify-value"])) : P("", !0)
86
- ], 34)
87
- ]);
88
- }
89
- });
1
+ import { useStore as u } from "@tanstack/vue-form";
2
+ import { computed as f } from "vue";
3
+ function c(o, t) {
4
+ return f(() => t ? u(o.store, (n) => {
5
+ const r = {};
6
+ for (const e of t)
7
+ r[e] = n[e];
8
+ return r;
9
+ }).value : {});
10
+ }
90
11
  export {
91
- J as default
12
+ c as getOmegaStore
92
13
  };
@@ -1,44 +1,92 @@
1
- const f = (c) => typeof c == "function", a = function(c, r) {
2
- switch (c) {
3
- case 0:
4
- case 1:
5
- throw new RangeError(`Invalid arity ${c}`);
6
- case 2:
7
- return function(n, t) {
8
- return arguments.length >= 2 ? r(n, t) : function(e) {
9
- return r(e, n);
10
- };
11
- };
12
- case 3:
13
- return function(n, t, e) {
14
- return arguments.length >= 3 ? r(n, t, e) : function(u) {
15
- return r(u, n, t);
16
- };
17
- };
18
- case 4:
19
- return function(n, t, e, u) {
20
- return arguments.length >= 4 ? r(n, t, e, u) : function(i) {
21
- return r(i, n, t, e);
22
- };
23
- };
24
- case 5:
25
- return function(n, t, e, u, i) {
26
- return arguments.length >= 5 ? r(n, t, e, u, i) : function(s) {
27
- return r(s, n, t, e, u);
28
- };
29
- };
30
- default:
31
- return function() {
32
- if (arguments.length >= c)
33
- return r.apply(this, arguments);
34
- const n = arguments;
35
- return function(t) {
36
- return r(t, ...n);
37
- };
38
- };
1
+ (function(){"use strict";try{if(typeof document<"u"){var i=document.createElement("style");if(i.appendChild(document.createTextNode(".omega-input .v-input__details:has(.v-messages:empty){grid-template-rows:0fr;transition:all .2s}.omega-input .v-messages:empty{min-height:0}.omega-input .v-input__details:has(.v-messages){transition:all .2s;overflow:hidden;min-height:0;display:grid;grid-template-rows:1fr}.omega-input .v-messages{transition:all .2s}.omega-input .v-messages>*{transition-duration:0s!important}.omega-input [role=alert]:has(.v-messages:empty){padding:0}.omega-input .v-btn{cursor:pointer;width:auto;appearance:none;box-shadow:none;display:block;min-width:auto;height:auto;padding:.5em .5em .5em 1em}")),document.head.appendChild(i),window.customElements){const e=window.customElements.define;window.customElements.define=function(s,t){const n=t.prototype.connectedCallback;return t.prototype.connectedCallback=function(){if(n&&n.call(this),this.shadowRoot){const a=document.createElement("style");a.appendChild(document.createTextNode(".omega-input .v-input__details:has(.v-messages:empty){grid-template-rows:0fr;transition:all .2s}.omega-input .v-messages:empty{min-height:0}.omega-input .v-input__details:has(.v-messages){transition:all .2s;overflow:hidden;min-height:0;display:grid;grid-template-rows:1fr}.omega-input .v-messages{transition:all .2s}.omega-input .v-messages>*{transition-duration:0s!important}.omega-input [role=alert]:has(.v-messages:empty){padding:0}.omega-input .v-btn{cursor:pointer;width:auto;appearance:none;box-shadow:none;display:block;min-width:auto;height:auto;padding:.5em .5em .5em 1em}")),this.shadowRoot.appendChild(a)}},e.call(window.customElements,s,t)}}}}catch(e){console.error("vite-plugin-css-injected-by-js",e)}})();
2
+ import { defineComponent as w, getCurrentInstance as x, useId as C, computed as a, watch as f, nextTick as N, onMounted as d, ref as $, watchEffect as k, renderSlot as B, normalizeProps as I, guardReactiveProps as O, createElementVNode as _, normalizeClass as q, createBlock as L, createCommentVNode as P, unref as F, openBlock as S, mergeProps as T } from "vue";
3
+ import { useStore as z } from "@tanstack/vue-form";
4
+ import { useOmegaErrors as A } from "./vue-components.es8.js";
5
+ import D from "./vue-components.es51.js";
6
+
7
+ const J = /* @__PURE__ */ w({
8
+ inheritAttrs: !1,
9
+ __name: "OmegaInternalInput",
10
+ props: {
11
+ field: {},
12
+ meta: {},
13
+ label: {},
14
+ options: {},
15
+ type: {},
16
+ validators: {}
17
+ },
18
+ setup(c) {
19
+ const e = c, v = x()?.appContext.components.VTextField, l = C(), o = e.field, r = z(o.store, (t) => t), m = a(() => e.type ? e.type : e.meta?.type === "string" ? e.meta.format === "email" ? "email" : "string" : e.meta?.type || "unknown"), n = a(() => r.value.value), g = a(
20
+ () => (
21
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
22
+ r.value.meta.errors.map((t) => t?.message).filter(Boolean)
23
+ )
24
+ ), y = (t) => t == null || t === !1 || t === "" || Number.isNaN(t);
25
+ f(
26
+ () => !!n.value,
27
+ () => {
28
+ y(n.value) && e.meta?.type !== "boolean" && N(() => {
29
+ o.setValue(
30
+ e.meta?.nullableOrUndefined === "undefined" ? void 0 : null
31
+ );
32
+ });
33
+ }
34
+ ), d(() => {
35
+ !n.value && !e.meta?.required && e.meta?.nullableOrUndefined === "null" && o.setValue(null);
36
+ });
37
+ const { addError: h, removeError: b, showErrors: E, showErrorsOn: V } = A(), s = $(!1);
38
+ k(() => {
39
+ (E.value || V === "onChange") && (s.value = !0);
40
+ });
41
+ const u = () => {
42
+ s.value = !0;
43
+ };
44
+ d(() => {
45
+ n.value && u();
46
+ });
47
+ const p = a(() => !s.value && m.value !== "select" ? [] : g.value);
48
+ f(
49
+ () => r.value.meta.errors,
50
+ () => {
51
+ r.value.meta.errors.length ? h({
52
+ inputId: l,
53
+ errors: r.value.meta.errors.map((t) => t.message).filter(Boolean),
54
+ label: e.label
55
+ }) : b(l);
56
+ }
57
+ );
58
+ const i = a(() => ({
59
+ id: l,
60
+ required: e.meta?.required,
61
+ minLength: e.meta?.type === "string" && e.meta?.minLength,
62
+ maxLength: e.meta?.type === "string" && e.meta?.maxLength,
63
+ max: e.meta?.type === "number" && e.meta?.maximum,
64
+ min: e.meta?.type === "number" && e.meta?.minimum,
65
+ name: e.field.name,
66
+ modelValue: e.field.state.value,
67
+ errorMessages: p.value,
68
+ error: !!p.value.length,
69
+ field: e.field,
70
+ setRealDirty: u,
71
+ type: m.value,
72
+ label: `${e.label}${e.meta?.required ? " *" : ""}`,
73
+ options: e.options
74
+ }));
75
+ return (t, R) => B(t.$slots, "default", I(O(i.value)), () => [
76
+ _("div", {
77
+ class: q(t.$attrs.class),
78
+ onFocusout: u
79
+ }, [
80
+ F(v) ? (S(), L(D, T({
81
+ key: 0,
82
+ "input-props": i.value
83
+ }, t.$attrs, {
84
+ "vuetify-value": i.value.field.state.value
85
+ }), null, 16, ["input-props", "vuetify-value"])) : P("", !0)
86
+ ], 34)
87
+ ]);
39
88
  }
40
- };
89
+ });
41
90
  export {
42
- a as dual,
43
- f as isFunction
91
+ J as default
44
92
  };
@@ -1,4 +1,4 @@
1
- import f from "./vue-components.es27.js";
1
+ import f from "./vue-components.es28.js";
2
2
  export {
3
3
  f as default
4
4
  };
@@ -1,6 +1,6 @@
1
1
  import { defineComponent as y, inject as h, computed as l, createBlock as s, openBlock as i, resolveDynamicComponent as M, withCtx as p, createCommentVNode as $, mergeProps as b, renderSlot as C, normalizeProps as k, guardReactiveProps as F } from "vue";
2
2
  import { generateInputStandardSchemaFromFieldMeta as A } from "./vue-components.es10.js";
3
- import w from "./vue-components.es27.js";
3
+ import w from "./vue-components.es28.js";
4
4
  import { useIntl as I } from "./vue-components.es3.js";
5
5
  const z = /* @__PURE__ */ y({
6
6
  inheritAttrs: !1,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@effect-app/vue-components",
3
- "version": "0.22.15",
3
+ "version": "0.22.17",
4
4
  "peerDependencies": {
5
5
  "@mdi/js": "^7.4.47",
6
6
  "effect": "^3.17.13",
@@ -48,7 +48,7 @@
48
48
  "@tanstack/vue-form": "^1.19.5",
49
49
  "highlight.js": "^11.11.1",
50
50
  "vue3-highlightjs": "^1.0.5",
51
- "@effect-app/vue": "2.64.1",
51
+ "@effect-app/vue": "2.64.2",
52
52
  "effect-app": "3.3.7"
53
53
  },
54
54
  "scripts": {
@@ -126,12 +126,16 @@ const eventOnSubmit: FormProps<From, To>["onSubmit"] = (
126
126
  })
127
127
  })
128
128
 
129
- const onSubmit = typeof props.isLoading !== "undefined"
130
- ? eventOnSubmit
129
+ // we need to keep onSubmit reactive or it can't pick up local state changes, inside forms
130
+ // which is the whole point of having props
131
+ const onSubmit_ = typeof props.isLoading !== "undefined"
132
+ ? computed(() => eventOnSubmit)
131
133
  : typeof props.onSubmit !== "undefined"
132
- ? props.onSubmit
134
+ ? computed(() => props.onSubmit)
133
135
  : undefined
134
136
 
137
+ const onSubmit = onSubmit_?.value ? (...args: [any]) => onSubmit_!.value!(...args) : undefined
138
+
135
139
  const localForm = props.form || !props.schema
136
140
  ? undefined
137
141
  : useOmegaForm<From, To>(