@declarion/react 0.1.44 → 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/dist-lib/JsonEditor-CWueGEgA.js +65 -0
- package/dist-lib/JsonEditor-CWueGEgA.js.map +1 -0
- package/dist-lib/api/data.d.ts +28 -0
- package/dist-lib/components/list/PeekFieldCell.d.ts +16 -0
- package/dist-lib/components/list/QuickPeek.d.ts +11 -4
- package/dist-lib/components/list/peekDraftStore.d.ts +6 -0
- package/dist-lib/declarion-react.css +2 -1
- package/dist-lib/index.js +17948 -15054
- package/dist-lib/index.js.map +1 -1
- package/dist-lib/types/api.d.ts +3 -1
- package/package.json +14 -14
- package/dist-lib/JsonEditor-ByVfvrpB.js +0 -71
- package/dist-lib/JsonEditor-ByVfvrpB.js.map +0 -1
package/dist-lib/types/api.d.ts
CHANGED
|
@@ -27,7 +27,9 @@ export declare class ApiError extends Error {
|
|
|
27
27
|
code: string;
|
|
28
28
|
/** Bulk operation item index (present on validation errors for array requests). */
|
|
29
29
|
index?: number;
|
|
30
|
-
|
|
30
|
+
/** Raw JSON body for endpoints that return a non-standard error envelope (e.g. invoke:each batch). */
|
|
31
|
+
raw?: unknown;
|
|
32
|
+
constructor(status: number, message: string, code: string, index?: number, raw?: unknown);
|
|
31
33
|
}
|
|
32
34
|
export type TenantEnv = "production" | "staging" | "dev" | string;
|
|
33
35
|
export interface Tenant {
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@declarion/react",
|
|
3
|
-
"version": "0.1.
|
|
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.
|
|
43
|
+
"@tanstack/react-query": "^5.99.2",
|
|
44
44
|
"@tanstack/react-table": "^8.20.0",
|
|
45
|
-
"@tanstack/react-virtual": "^3.
|
|
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": "^
|
|
50
|
-
"recharts": "^
|
|
49
|
+
"react-router-dom": "^7.14.2",
|
|
50
|
+
"recharts": "^3.8.1",
|
|
51
51
|
"remark-breaks": "^4.0.0",
|
|
52
|
-
"sonner": "^
|
|
53
|
-
"tailwind-merge": "^
|
|
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.
|
|
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": "^
|
|
66
|
+
"@vitejs/plugin-react": "^6.0.1",
|
|
67
67
|
"jsdom": "^29.0.1",
|
|
68
|
-
"msw": "^2.
|
|
68
|
+
"msw": "^2.13.4",
|
|
69
69
|
"react": "^19.0.0",
|
|
70
70
|
"react-dom": "^19.0.0",
|
|
71
|
-
"tailwindcss": "^4.
|
|
71
|
+
"tailwindcss": "^4.2.4",
|
|
72
72
|
"tsc-alias": "^1.8.16",
|
|
73
|
-
"typescript": "^
|
|
74
|
-
"vite": "^
|
|
75
|
-
"vitest": "^4.1.
|
|
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;"}
|