@declarion/react 0.1.45 → 0.1.46

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@declarion/react",
3
- "version": "0.1.45",
3
+ "version": "0.1.46",
4
4
  "private": false,
5
5
  "license": "MIT",
6
6
  "description": "React SDK for Declarion, the schema-driven business apps platform.",
@@ -40,39 +40,39 @@
40
40
  "@radix-ui/react-select": "^2.1.0",
41
41
  "@radix-ui/react-separator": "^1.1.0",
42
42
  "@radix-ui/react-slot": "^1.1.0",
43
- "@tanstack/react-query": "^5.62.0",
43
+ "@tanstack/react-query": "^5.99.2",
44
44
  "@tanstack/react-table": "^8.20.0",
45
- "@tanstack/react-virtual": "^3.11.0",
45
+ "@tanstack/react-virtual": "^3.13.24",
46
46
  "class-variance-authority": "^0.7.0",
47
47
  "clsx": "^2.1.0",
48
48
  "react-markdown": "^10.1.0",
49
- "react-router-dom": "^6.28.0",
50
- "recharts": "^2.15.0",
49
+ "react-router-dom": "^7.14.2",
50
+ "recharts": "^3.8.1",
51
51
  "remark-breaks": "^4.0.0",
52
- "sonner": "^1.7.0",
53
- "tailwind-merge": "^2.6.0",
52
+ "sonner": "^2.0.7",
53
+ "tailwind-merge": "^3.5.0",
54
54
  "vanilla-jsoneditor": "^3.11.0",
55
55
  "zustand": "^5.0.0"
56
56
  },
57
57
  "devDependencies": {
58
58
  "@tailwindcss/typography": "^0.5.19",
59
- "@tailwindcss/vite": "^4.0.0",
59
+ "@tailwindcss/vite": "^4.2.4",
60
60
  "@testing-library/dom": "^10.4.1",
61
61
  "@testing-library/jest-dom": "^6.9.1",
62
62
  "@testing-library/react": "^16.3.2",
63
63
  "@testing-library/user-event": "^14.6.1",
64
64
  "@types/react": "^19.0.0",
65
65
  "@types/react-dom": "^19.0.0",
66
- "@vitejs/plugin-react": "^4.3.0",
66
+ "@vitejs/plugin-react": "^6.0.1",
67
67
  "jsdom": "^29.0.1",
68
- "msw": "^2.12.14",
68
+ "msw": "^2.13.4",
69
69
  "react": "^19.0.0",
70
70
  "react-dom": "^19.0.0",
71
- "tailwindcss": "^4.0.0",
71
+ "tailwindcss": "^4.2.4",
72
72
  "tsc-alias": "^1.8.16",
73
- "typescript": "^5.7.0",
74
- "vite": "^6.0.0",
75
- "vitest": "^4.1.0"
73
+ "typescript": "^6.0.3",
74
+ "vite": "^8.0.9",
75
+ "vitest": "^4.1.5"
76
76
  },
77
77
  "scripts": {
78
78
  "dev": "vite",
@@ -1,71 +0,0 @@
1
- import { jsx as b } from "react/jsx-runtime";
2
- import { useRef as i, useEffect as a } from "react";
3
- import { Mode as l, createJSONEditor as E } from "vanilla-jsoneditor";
4
- import "vanilla-jsoneditor/themes/jse-theme-dark.css";
5
- function p(t) {
6
- if (t == null) return { text: "" };
7
- if (typeof t == "string")
8
- try {
9
- return { json: JSON.parse(t) };
10
- } catch {
11
- return { text: t };
12
- }
13
- return { json: t };
14
- }
15
- function N({ value: t, onChange: u, readOnly: e }) {
16
- const o = i(null), s = i(null), n = i(u);
17
- return a(() => {
18
- n.current = u;
19
- }, [u]), a(() => {
20
- if (!o.current) return;
21
- const j = {
22
- content: p(t),
23
- readOnly: e ?? !1,
24
- mode: e ? l.tree : l.text,
25
- mainMenuBar: !e,
26
- navigationBar: !1,
27
- statusBar: !1,
28
- onChange: (r, c, x) => {
29
- if (!(e || !n.current) && !x.contentErrors) {
30
- if ("json" in r)
31
- n.current(r.json);
32
- else if ("text" in r)
33
- try {
34
- n.current(JSON.parse(r.text));
35
- } catch {
36
- n.current(r.text);
37
- }
38
- }
39
- }
40
- }, f = () => {
41
- var c;
42
- const r = document.documentElement.dataset.theme === "dark";
43
- (c = o.current) == null || c.classList.toggle("jse-theme-dark", r);
44
- };
45
- f();
46
- const m = new MutationObserver(f);
47
- m.observe(document.documentElement, {
48
- attributes: !0,
49
- attributeFilter: ["data-theme"]
50
- });
51
- const d = E({
52
- target: o.current,
53
- props: j
54
- });
55
- return s.current = d, () => {
56
- m.disconnect(), d.destroy(), s.current = null;
57
- };
58
- }, [e]), a(() => {
59
- !s.current || !e || s.current.updateProps({ content: p(t) });
60
- }, [t, e]), /* @__PURE__ */ b(
61
- "div",
62
- {
63
- ref: o,
64
- className: e ? "json-editor-readonly" : "json-editor-editable"
65
- }
66
- );
67
- }
68
- export {
69
- N as JsonEditor
70
- };
71
- //# sourceMappingURL=JsonEditor-ByVfvrpB.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"JsonEditor-ByVfvrpB.js","sources":["../src/components/fields/JsonEditor.tsx"],"sourcesContent":["import { useRef, useEffect } from \"react\";\nimport {\n createJSONEditor,\n Mode,\n type Content,\n type OnChangeStatus,\n type JSONEditorPropsOptional,\n} from \"vanilla-jsoneditor\";\n// Dark theme CSS vars for vanilla-jsoneditor (sets --jse-* custom properties)\nimport \"vanilla-jsoneditor/themes/jse-theme-dark.css\";\n\ninterface JsonEditorProps {\n value: unknown;\n onChange?: (value: unknown) => void;\n readOnly?: boolean;\n // Future: JSON Schema for in-editor validation (Ajv). Accept now, wire later.\n schema?: Record<string, unknown>;\n}\n\nfunction toContent(v: unknown): Content {\n if (v == null) return { text: \"\" };\n if (typeof v === \"string\") {\n try {\n return { json: JSON.parse(v) };\n } catch {\n return { text: v };\n }\n }\n return { json: v };\n}\n\nexport function JsonEditor({ value, onChange, readOnly }: JsonEditorProps) {\n const containerRef = useRef<HTMLDivElement>(null);\n const editorRef = useRef<ReturnType<typeof createJSONEditor> | null>(null);\n const onChangeRef = useRef(onChange);\n useEffect(() => { onChangeRef.current = onChange; }, [onChange]);\n\n // Create / recreate editor when readOnly changes\n useEffect(() => {\n if (!containerRef.current) return;\n\n const props: JSONEditorPropsOptional = {\n content: toContent(value),\n readOnly: readOnly ?? false,\n mode: readOnly ? Mode.tree : Mode.text,\n mainMenuBar: !readOnly,\n navigationBar: false,\n statusBar: false,\n onChange: (content: Content, _prev: Content, status: OnChangeStatus) => {\n if (readOnly || !onChangeRef.current) return;\n if (status.contentErrors) return;\n if (\"json\" in content) {\n onChangeRef.current(content.json);\n } else if (\"text\" in content) {\n try {\n onChangeRef.current(JSON.parse(content.text));\n } catch {\n onChangeRef.current(content.text);\n }\n }\n },\n };\n\n const syncDarkClass = () => {\n const isDark = document.documentElement.dataset.theme === \"dark\";\n containerRef.current?.classList.toggle(\"jse-theme-dark\", isDark);\n };\n syncDarkClass();\n\n // Watch for theme attribute changes on <html>.\n const observer = new MutationObserver(syncDarkClass);\n observer.observe(document.documentElement, {\n attributes: true,\n attributeFilter: [\"data-theme\"],\n });\n\n const editor = createJSONEditor({\n target: containerRef.current,\n props,\n });\n editorRef.current = editor;\n\n return () => {\n observer.disconnect();\n editor.destroy();\n editorRef.current = null;\n };\n }, [readOnly]); // eslint-disable-line react-hooks/exhaustive-deps\n\n // Update content when value changes externally (read-only mode only)\n useEffect(() => {\n if (!editorRef.current || !readOnly) return;\n editorRef.current.updateProps({ content: toContent(value) });\n }, [value, readOnly]);\n\n return (\n <div\n ref={containerRef}\n className={readOnly ? \"json-editor-readonly\" : \"json-editor-editable\"}\n />\n );\n}\n"],"names":["toContent","v","JsonEditor","value","onChange","readOnly","containerRef","useRef","editorRef","onChangeRef","useEffect","props","Mode","content","_prev","status","syncDarkClass","isDark","_a","observer","editor","createJSONEditor","jsx"],"mappings":";;;;AAmBA,SAASA,EAAUC,GAAqB;AACtC,MAAIA,KAAK,KAAM,QAAO,EAAE,MAAM,GAAA;AAC9B,MAAI,OAAOA,KAAM;AACf,QAAI;AACF,aAAO,EAAE,MAAM,KAAK,MAAMA,CAAC,EAAA;AAAA,IAC7B,QAAQ;AACN,aAAO,EAAE,MAAMA,EAAA;AAAA,IACjB;AAEF,SAAO,EAAE,MAAMA,EAAA;AACjB;AAEO,SAASC,EAAW,EAAE,OAAAC,GAAO,UAAAC,GAAU,UAAAC,KAA6B;AACzE,QAAMC,IAAeC,EAAuB,IAAI,GAC1CC,IAAYD,EAAmD,IAAI,GACnEE,IAAcF,EAAOH,CAAQ;AACnC,SAAAM,EAAU,MAAM;AAAE,IAAAD,EAAY,UAAUL;AAAA,EAAU,GAAG,CAACA,CAAQ,CAAC,GAG/DM,EAAU,MAAM;AACd,QAAI,CAACJ,EAAa,QAAS;AAE3B,UAAMK,IAAiC;AAAA,MACrC,SAASX,EAAUG,CAAK;AAAA,MACxB,UAAUE,KAAY;AAAA,MACtB,MAAMA,IAAWO,EAAK,OAAOA,EAAK;AAAA,MAClC,aAAa,CAACP;AAAA,MACd,eAAe;AAAA,MACf,WAAW;AAAA,MACX,UAAU,CAACQ,GAAkBC,GAAgBC,MAA2B;AACtE,YAAI,EAAAV,KAAY,CAACI,EAAY,YACzB,CAAAM,EAAO;AACX,cAAI,UAAUF;AACZ,YAAAJ,EAAY,QAAQI,EAAQ,IAAI;AAAA,mBACvB,UAAUA;AACnB,gBAAI;AACF,cAAAJ,EAAY,QAAQ,KAAK,MAAMI,EAAQ,IAAI,CAAC;AAAA,YAC9C,QAAQ;AACN,cAAAJ,EAAY,QAAQI,EAAQ,IAAI;AAAA,YAClC;AAAA;AAAA,MAEJ;AAAA,IAAA,GAGIG,IAAgB,MAAM;;AAC1B,YAAMC,IAAS,SAAS,gBAAgB,QAAQ,UAAU;AAC1D,OAAAC,IAAAZ,EAAa,YAAb,QAAAY,EAAsB,UAAU,OAAO,kBAAkBD;AAAA,IAC3D;AACA,IAAAD,EAAA;AAGA,UAAMG,IAAW,IAAI,iBAAiBH,CAAa;AACnD,IAAAG,EAAS,QAAQ,SAAS,iBAAiB;AAAA,MACzC,YAAY;AAAA,MACZ,iBAAiB,CAAC,YAAY;AAAA,IAAA,CAC/B;AAED,UAAMC,IAASC,EAAiB;AAAA,MAC9B,QAAQf,EAAa;AAAA,MACrB,OAAAK;AAAA,IAAA,CACD;AACD,WAAAH,EAAU,UAAUY,GAEb,MAAM;AACX,MAAAD,EAAS,WAAA,GACTC,EAAO,QAAA,GACPZ,EAAU,UAAU;AAAA,IACtB;AAAA,EACF,GAAG,CAACH,CAAQ,CAAC,GAGbK,EAAU,MAAM;AACd,IAAI,CAACF,EAAU,WAAW,CAACH,KAC3BG,EAAU,QAAQ,YAAY,EAAE,SAASR,EAAUG,CAAK,GAAG;AAAA,EAC7D,GAAG,CAACA,GAAOE,CAAQ,CAAC,GAGlB,gBAAAiB;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,KAAKhB;AAAA,MACL,WAAWD,IAAW,yBAAyB;AAAA,IAAA;AAAA,EAAA;AAGrD;"}