@chaibuilder/sdk 2.0.0-beta.10 → 2.0.0-beta.102

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 (53) hide show
  1. package/README.md +1 -3
  2. package/dist/ChaiThemeFn-Cort9tch.js +201 -0
  3. package/dist/ChaiThemeFn-DQu-2Eh9.cjs +13 -0
  4. package/dist/CodeEditor-BQTYQosF.cjs +1 -0
  5. package/dist/CodeEditor-DyWk02_x.js +65 -0
  6. package/dist/Topbar-BhwvnJJc.cjs +1 -0
  7. package/dist/Topbar-BuWEmzZG.js +16 -0
  8. package/dist/chaibuilder-logo.png +0 -0
  9. package/dist/context-menu-CeqJxblw.cjs +1 -0
  10. package/dist/context-menu-iqXuo9Yt.js +907 -0
  11. package/dist/core.cjs +7 -18
  12. package/dist/core.d.ts +79 -46
  13. package/dist/core.js +5564 -5309
  14. package/dist/getSplitClasses-DodqA_KW.cjs +1 -0
  15. package/dist/getSplitClasses-DphwgQiE.js +48 -0
  16. package/dist/{iconBase-Ief2hJUZ.js → iconBase-DHfFLkem.js} +6 -12
  17. package/dist/mockServiceWorker.js +39 -24
  18. package/dist/plugin-2xcljWGM.cjs +1 -0
  19. package/dist/plugin-kUMxtQR5.js +24 -0
  20. package/dist/render.cjs +2 -2
  21. package/dist/render.d.ts +41 -16
  22. package/dist/render.js +166 -139
  23. package/dist/runtime.cjs +1 -1
  24. package/dist/runtime.d.ts +6 -1
  25. package/dist/runtime.js +0 -20
  26. package/dist/{style.css → sdk.css} +1 -1
  27. package/dist/tailwind.cjs +1 -1
  28. package/dist/tailwind.d.ts +37 -26
  29. package/dist/tailwind.js +8 -10
  30. package/dist/ui.cjs +1 -1
  31. package/dist/ui.d.ts +12 -51
  32. package/dist/ui.js +194 -433
  33. package/dist/web-blocks.cjs +2 -2
  34. package/dist/web-blocks.d.ts +6 -0
  35. package/dist/web-blocks.js +1230 -813
  36. package/package.json +136 -132
  37. package/dist/CodeEditor-9qjIOTD0.js +0 -126
  38. package/dist/CodeEditor-pceepCns.cjs +0 -1
  39. package/dist/STRINGS-Xxstm-7I.js +0 -7
  40. package/dist/STRINGS-Yl7cSWDc.cjs +0 -1
  41. package/dist/Topbar-7bGqLcSJ.js +0 -73
  42. package/dist/Topbar-EXPx1Yg2.cjs +0 -1
  43. package/dist/context-menu-4nQs6OxC.cjs +0 -1
  44. package/dist/context-menu-oLipAPzI.js +0 -817
  45. package/dist/controls-lEwMTdPQ.js +0 -234
  46. package/dist/controls-p9IwFnPx.cjs +0 -1
  47. package/dist/jsx-runtime-JYMCiFoE.cjs +0 -27
  48. package/dist/jsx-runtime-Sp0orL4X.js +0 -631
  49. package/dist/plugin-Dm5EFGnP.cjs +0 -1
  50. package/dist/plugin-KIpT3NWi.cjs +0 -1
  51. package/dist/plugin-PFjzFeON.js +0 -97
  52. package/dist/plugin-ooqqxWRQ.js +0 -55
  53. /package/dist/{iconBase-aZzpqff_.cjs → iconBase-Cn2BsTrq.cjs} +0 -0
package/package.json CHANGED
@@ -5,7 +5,7 @@
5
5
  "author": "Suraj Air",
6
6
  "license": "BSD-3-Clause",
7
7
  "homepage": "https://chaibuilder.com",
8
- "version": "2.0.0-beta.10",
8
+ "version": "2.0.0-beta.102",
9
9
  "type": "module",
10
10
  "repository": {
11
11
  "type": "git",
@@ -16,178 +16,182 @@
16
16
  ],
17
17
  "main": "dist/core.js",
18
18
  "sideEffects": false,
19
- "scripts": {
20
- "dev": "vite",
21
- "build": "tsc && vite build",
22
- "lint": "eslint . --ext ts,tsx --report-unused-disable-directives --max-warnings 0",
23
- "preview": "vite preview",
24
- "test": "jest --colors --verbose",
25
- "test:watch": "jest --watch --colors",
26
- "test:coverage": "jest --coverage --colors",
27
- "e2e": "playwright test",
28
- "e2e:report": "playwright show-report",
29
- "e2e:ui": "playwright test --ui",
30
- "docs": "typedoc --plugin typedoc-plugin-clarity",
31
- "prepare": "husky"
32
- },
33
19
  "exports": {
34
20
  ".": {
21
+ "types": "./dist/core.d.ts",
35
22
  "import": "./dist/core.js",
36
- "require": "./dist/core.cjs",
37
- "types": "./dist/core.d.ts"
23
+ "require": "./dist/core.cjs"
38
24
  },
39
25
  "./render": {
26
+ "types": "./dist/render.d.ts",
40
27
  "import": "./dist/render.js",
41
- "require": "./dist/render.cjs",
42
- "types": "./dist/render.d.ts"
28
+ "require": "./dist/render.cjs"
43
29
  },
44
30
  "./ui": {
31
+ "types": "./dist/ui.d.ts",
45
32
  "import": "./dist/ui.js",
46
- "require": "./dist/ui.cjs",
47
- "types": "./dist/ui.d.ts"
33
+ "require": "./dist/ui.cjs"
48
34
  },
49
35
  "./tailwind": {
36
+ "types": "./dist/tailwind.d.ts",
50
37
  "import": "./dist/tailwind.js",
51
- "require": "./dist/tailwind.cjs",
52
- "types": "./dist/tailwind.d.ts"
53
- },
54
- "./styles": {
55
- "import": "./dist/style.css",
56
- "require": "./dist/style.css"
38
+ "require": "./dist/tailwind.cjs"
57
39
  },
58
40
  "./web-blocks": {
41
+ "types": "./dist/web-blocks.d.ts",
59
42
  "import": "./dist/web-blocks.js",
60
- "require": "./dist/web-blocks.cjs",
61
- "types": "./dist/web-blocks.d.ts"
43
+ "require": "./dist/web-blocks.cjs"
62
44
  },
63
45
  "./runtime": {
46
+ "types": "./dist/runtime.d.ts",
64
47
  "import": "./dist/runtime.js",
65
- "require": "./dist/runtime.cjs",
66
- "types": "./dist/runtime.d.ts"
48
+ "require": "./dist/runtime.cjs"
49
+ },
50
+ "./styles": {
51
+ "import": "./dist/sdk.css",
52
+ "require": "./dist/sdk.css"
53
+ }
54
+ },
55
+ "peerDependencies": {
56
+ "@chaibuilder/runtime": "2.0.0-beta.24",
57
+ "@types/react": "*",
58
+ "@types/react-dom": "*",
59
+ "jotai": "2.12.1",
60
+ "react": "^18.0 || ^19.0",
61
+ "react-dom": "^18.0 || ^19.0"
62
+ },
63
+ "peerDependenciesMeta": {
64
+ "@types/react": {
65
+ "optional": true
66
+ },
67
+ "@types/react-dom": {
68
+ "optional": true
67
69
  }
68
70
  },
69
71
  "dependencies": {
70
- "@bobthered/tailwindcss-palette-generator": "^4.0.0",
71
- "@chaibuilder/runtime": "0.2.12",
72
- "@floating-ui/dom": "1.4.5",
73
- "@floating-ui/react-dom": "2.0.1",
74
- "@mhsdesign/jit-browser-tailwindcss": "0.4.1",
75
- "@monaco-editor/react": "^4.6.0",
76
- "@radix-ui/react-accordion": "^1.1.2",
77
- "@radix-ui/react-alert-dialog": "^1.0.5",
78
- "@radix-ui/react-context-menu": "^2.1.5",
79
- "@radix-ui/react-dialog": "^1.0.5",
80
- "@radix-ui/react-dropdown-menu": "^2.0.6",
81
- "@radix-ui/react-hover-card": "^1.0.7",
82
- "@radix-ui/react-icons": "^1.3.0",
83
- "@radix-ui/react-label": "^2.0.2",
84
- "@radix-ui/react-menubar": "^1.0.4",
85
- "@radix-ui/react-navigation-menu": "^1.1.4",
86
- "@radix-ui/react-popover": "^1.0.7",
87
- "@radix-ui/react-scroll-area": "^1.0.5",
88
- "@radix-ui/react-select": "^1.2.2",
89
- "@radix-ui/react-separator": "^1.0.3",
90
- "@radix-ui/react-slot": "^1.0.2",
91
- "@radix-ui/react-switch": "^1.0.3",
92
- "@radix-ui/react-tabs": "^1.0.4",
93
- "@radix-ui/react-toast": "^1.1.5",
94
- "@radix-ui/react-toggle": "^1.0.3",
95
- "@radix-ui/react-tooltip": "^1.0.7",
96
- "@react-email/components": "^0.0.18",
97
- "@react-email/render": "^0.0.14",
98
- "@react-hookz/web": "23.1.0",
99
- "@rjsf/core": "5.11.2",
100
- "@rjsf/utils": "5.11.2",
101
- "@rjsf/validator-ajv8": "5.11.2",
102
- "@tailwindcss/aspect-ratio": "0.4.2",
103
- "@tailwindcss/forms": "^0.5.6",
72
+ "@chaibuilder/runtime": "2.0.0-beta.24",
73
+ "@floating-ui/dom": "1.6.13",
74
+ "@floating-ui/react-dom": "2.1.2",
75
+ "@mhsdesign/jit-browser-tailwindcss": "0.4.2",
76
+ "@radix-ui/react-accordion": "^1.2.2",
77
+ "@radix-ui/react-alert-dialog": "^1.1.5",
78
+ "@radix-ui/react-context-menu": "^2.2.5",
79
+ "@radix-ui/react-dialog": "^1.1.5",
80
+ "@radix-ui/react-dropdown-menu": "^2.1.5",
81
+ "@radix-ui/react-hover-card": "^1.1.5",
82
+ "@radix-ui/react-icons": "^1.3.2",
83
+ "@radix-ui/react-label": "^2.1.1",
84
+ "@radix-ui/react-menubar": "^1.1.5",
85
+ "@radix-ui/react-navigation-menu": "^1.2.4",
86
+ "@radix-ui/react-popover": "^1.1.5",
87
+ "@radix-ui/react-scroll-area": "^1.2.2",
88
+ "@radix-ui/react-select": "^2.1.5",
89
+ "@radix-ui/react-separator": "^1.1.1",
90
+ "@radix-ui/react-slot": "^1.1.1",
91
+ "@radix-ui/react-switch": "^1.1.2",
92
+ "@radix-ui/react-tabs": "^1.1.2",
93
+ "@radix-ui/react-toast": "^1.2.5",
94
+ "@radix-ui/react-toggle": "^1.1.1",
95
+ "@radix-ui/react-tooltip": "^1.1.7",
96
+ "@react-hookz/web": "25.0.1",
97
+ "@rjsf/core": "5.24.2",
98
+ "@rjsf/utils": "5.24.2",
99
+ "@rjsf/validator-ajv8": "5.24.2",
100
+ "@tailwindcss/aspect-ratio": "^0.4.2",
101
+ "@tailwindcss/container-queries": "^0.1.1",
102
+ "@tailwindcss/forms": "^0.5.10",
104
103
  "@tailwindcss/line-clamp": "^0.4.4",
105
- "@tailwindcss/typography": "^0.5.10",
104
+ "@tailwindcss/typography": "^0.5.16",
106
105
  "class-variance-authority": "0.6.1",
107
- "clsx": "1.2.1",
106
+ "clsx": "2.1.1",
108
107
  "cmdk": "0.2.0",
109
- "flagged": "2.0.9",
110
- "framer-motion": "^11.4.0",
111
- "fuse.js": "6.6.2",
108
+ "flagged": "3.0.0",
109
+ "framer-motion": "^12.0.3",
110
+ "fuse.js": "7.0.0",
112
111
  "himalaya": "^1.1.0",
113
- "i18next": "^23.6.0",
114
- "jotai": "2.2.2",
112
+ "i18next": "^24.2.1",
113
+ "jotai": "2.12.1",
115
114
  "lodash": "^4.17.21",
116
115
  "lodash-es": "4.17.21",
117
- "lucide-react": "^0.244.0",
118
- "re-resizable": "^6.9.17",
119
- "react": "^18.2.0",
116
+ "lucide-react": "^0.474.0",
117
+ "re-resizable": "^6.10.3",
120
118
  "react-arborist": "^3.4.0",
121
- "react-autosuggest": "10.1.0",
119
+ "react-autosuggest": "^10.1.0",
122
120
  "react-colorful": "5.6.1",
123
- "react-dom": "^18.2.0",
124
- "react-email": "^2.1.3",
125
- "react-error-boundary": "^4.0.13",
126
- "react-hotkeys-hook": "4.4.1",
127
- "react-i18next": "13.0.1",
128
- "react-icons": "5.3.0",
121
+ "react-error-boundary": "^5.0.0",
122
+ "react-hotkeys-hook": "4.6.1",
123
+ "react-i18next": "15.4.0",
124
+ "react-icons": "5.4.0",
129
125
  "react-icons-picker": "^1.0.9",
130
- "react-json-view-lite": "^1.4.0",
126
+ "react-json-view-lite": "^2.3.0",
131
127
  "react-quill": "^2.0.0",
132
- "react-wrap-balancer": "^1.1.0",
133
- "tailwind-merge": "2.3.0",
128
+ "react-wrap-balancer": "^1.1.1",
129
+ "tailwind-merge": "^2.6.0",
134
130
  "tree-model": "^1.0.7",
135
131
  "undo-manager": "^1.1.1"
136
132
  },
137
133
  "devDependencies": {
138
- "@ai-sdk/openai": "^0.0.37",
139
- "@commitlint/cli": "17.7.1",
140
- "@commitlint/config-conventional": "17.7.0",
141
- "@emotion/react": "^11.11.1",
142
- "@faker-js/faker": "^8.3.1",
143
- "@nozbe/watermelondb": "^0.27.1",
144
- "@playwright/test": "^1.39.0",
145
- "@tanstack/eslint-plugin-query": "^5.8.4",
146
- "@testing-library/react": "^16.0.0",
147
- "@testing-library/react-hooks": "^8.0.1",
148
- "@types/jest": "^29.5.7",
149
- "@types/lodash": "^4.14.200",
134
+ "@commitlint/cli": "19.6.1",
135
+ "@commitlint/config-conventional": "19.6.0",
136
+ "@emotion/react": "^11.14.0",
137
+ "@faker-js/faker": "^9.4.0",
138
+ "@microsoft/clarity": "^1.0.0",
139
+ "@playwright/test": "^1.50.0",
140
+ "@tanstack/eslint-plugin-query": "^5.64.2",
141
+ "@testing-library/react": "^16.2.0",
142
+ "@types/lodash": "^4.17.14",
150
143
  "@types/node": "^20.8.10",
151
- "@types/react": "^18.2.34",
152
- "@types/react-dom": "^18.2.14",
153
- "@typescript-eslint/eslint-plugin": "^6.9.1",
154
- "@typescript-eslint/parser": "^6.9.1",
155
- "@vitejs/plugin-react-swc": "^3.4.1",
156
- "ai": "^3.2.32",
157
- "autoprefixer": "^10.4.16",
158
- "axios": "^1.7.7",
159
- "better-docs": "^2.7.2",
144
+ "@types/react": "^18.3.1",
145
+ "@types/react-dom": "^18.3.1",
146
+ "@typescript-eslint/eslint-plugin": "^8.21.0",
147
+ "@typescript-eslint/parser": "^8.21.0",
148
+ "@vitejs/plugin-react-swc": "^3.7.2",
149
+ "autoprefixer": "^10.4.20",
150
+ "axios": "^1.7.9",
160
151
  "cheerio": "1.0.0-rc.12",
161
- "dotenv": "^16.4.5",
162
- "drizzle-kit": "^0.20.4",
163
- "drizzle-orm": "^0.29.0",
164
- "eslint": "^8.53.0",
165
- "eslint-plugin-react-hooks": "^4.6.0",
166
- "eslint-plugin-react-refresh": "^0.4.4",
167
- "husky": "^9.0.10",
168
- "jest": "^29.7.0",
152
+ "dotenv": "^16.4.7",
153
+ "eslint": "^9.18.0",
154
+ "eslint-plugin-react-hooks": "^5.1.0",
155
+ "eslint-plugin-react-refresh": "^0.4.18",
156
+ "husky": "^9.1.7",
169
157
  "jest-environment-jsdom": "^29.7.0",
170
- "jotai-devtools": "^0.7.1",
171
- "jsdoc": "^4.0.2",
172
- "msw": "^2.0.8",
173
- "postcss": "^8.4.31",
174
- "prettier": "^3.3.0",
175
- "prettier-plugin-tailwindcss": "^0.6.1",
158
+ "jotai-devtools": "^0.11.0",
159
+ "jsdoc": "^4.0.4",
160
+ "msw": "^2.7.0",
161
+ "postcss": "^8.5.1",
162
+ "prettier": "^3.4.2",
163
+ "prettier-plugin-tailwindcss": "^0.6.11",
176
164
  "prop-types": "^15.8.1",
177
- "react-router-dom": "^6.19.0",
178
- "tailwindcss": "^3.3.5",
179
- "tailwindcss-animate": "1.0.6",
180
- "ts-jest": "^29.1.1",
165
+ "react": "^18.3.1",
166
+ "react-dom": "^18.3.1",
167
+ "react-router-dom": "^7.1.3",
168
+ "tailwindcss": "^3.4.11",
169
+ "tailwindcss-animate": "^1.0.7",
170
+ "ts-jest": "^29.2.5",
181
171
  "ts-node": "^10.9.2",
182
- "typedoc": "^0.26.7",
183
- "typedoc-github-theme": "^0.1.2",
184
- "typedoc-plugin-clarity": "^1.6.0",
185
- "typescript": "^5.2.2",
186
- "vite": "^5.0.12",
187
- "vite-plugin-dts": "^3.6.3",
188
- "zod": "^3.23.8"
172
+ "typescript": "^5.7.3",
173
+ "vite": "^6.0.11",
174
+ "vite-plugin-dts": "^4.5.0",
175
+ "vitest": "^3.0.4",
176
+ "zod": "^3.24.1"
189
177
  },
190
178
  "msw": {
191
179
  "workerDirectory": "public"
180
+ },
181
+ "engines": {
182
+ "node": "^20.18.0"
183
+ },
184
+ "scripts": {
185
+ "dev": "vite",
186
+ "build": "tsc && vite build",
187
+ "live": "tsc && vite build --config vite.config.live.ts",
188
+ "lint": "eslint . --ext ts,tsx --report-unused-disable-directives --max-warnings 0",
189
+ "preview": "vite preview",
190
+ "test": "vitest --run",
191
+ "test:watch": "vitest --watch",
192
+ "test:coverage": "vitest --coverage",
193
+ "e2e": "playwright test",
194
+ "e2e:report": "playwright show-report",
195
+ "e2e:ui": "playwright test --ui"
192
196
  }
193
- }
197
+ }
@@ -1,126 +0,0 @@
1
- import { j as t } from "./jsx-runtime-Sp0orL4X.js";
2
- import k from "@monaco-editor/react";
3
- import { B as C } from "./context-menu-oLipAPzI.js";
4
- import { useTranslation as j } from "react-i18next";
5
- import { useState as l, useCallback as v, useEffect as g } from "react";
6
- import { useCodeEditor as y, useSelectedBlockIds as N, useUpdateBlocksProps as T, useUpdateBlocksPropsRealtime as E } from "./core.js";
7
- import { Cross2Icon as w } from "@radix-ui/react-icons";
8
- import { useThrottledCallback as B } from "@react-hookz/web";
9
- import "@radix-ui/react-switch";
10
- import "@radix-ui/react-accordion";
11
- import "@radix-ui/react-alert-dialog";
12
- import "@radix-ui/react-slot";
13
- import "class-variance-authority";
14
- import "@radix-ui/react-dialog";
15
- import "@radix-ui/react-label";
16
- import "@radix-ui/react-scroll-area";
17
- import "@radix-ui/react-tabs";
18
- import "@radix-ui/react-tooltip";
19
- import "@radix-ui/react-popover";
20
- import "@radix-ui/react-hover-card";
21
- import "@radix-ui/react-dropdown-menu";
22
- import "@radix-ui/react-separator";
23
- import "@radix-ui/react-toast";
24
- import "@radix-ui/react-context-menu";
25
- import "clsx";
26
- import "tailwind-merge";
27
- import "lodash-es";
28
- import "jotai";
29
- import "./iconBase-Ief2hJUZ.js";
30
- import "@chaibuilder/runtime";
31
- import "./plugin-ooqqxWRQ.js";
32
- import "lodash";
33
- import "tree-model";
34
- import "react-quill";
35
- import "./STRINGS-Xxstm-7I.js";
36
- import "flagged";
37
- import "react-hotkeys-hook";
38
- import "@floating-ui/dom";
39
- import "@floating-ui/react-dom";
40
- import "@tailwindcss/typography";
41
- import "@tailwindcss/forms";
42
- import "@tailwindcss/aspect-ratio";
43
- import "react-wrap-balancer";
44
- import "react-dom";
45
- import "prop-types";
46
- import "react-error-boundary";
47
- import "re-resizable";
48
- import "lucide-react";
49
- import "react-arborist";
50
- import "himalaya";
51
- import "@rjsf/core";
52
- import "@rjsf/validator-ajv8";
53
- import "react-icons-picker";
54
- import "react-autosuggest";
55
- import "fuse.js";
56
- import "i18next";
57
- import "framer-motion";
58
- const n = (r) => {
59
- const i = document.createElement("div");
60
- return i.innerHTML = r, i.innerHTML;
61
- };
62
- function Pt() {
63
- const { t: r } = j(), [i, a] = l(!1), [m, c] = l(""), [o, s] = y(), [p] = N(), d = T(), u = E(), f = B(
64
- (e) => {
65
- const b = n(e);
66
- u([o.blockId], { [o.blockProp]: b });
67
- },
68
- [],
69
- 300
70
- ), x = v(() => {
71
- if (i) {
72
- const e = n(m);
73
- d([o.blockId], { [o.blockProp]: e });
74
- }
75
- }, [i, m]);
76
- g(() => {
77
- p.includes(o == null ? void 0 : o.blockId) || (x(), s(null));
78
- }, [p]);
79
- const h = () => {
80
- s(null);
81
- };
82
- return /* @__PURE__ */ t.jsxs("div", { className: "h-full rounded-t-lg border-t-4 border-black bg-black text-white", children: [
83
- /* @__PURE__ */ t.jsx("button", { onClick: h, className: "fixed inset-0 z-[100000] cursor-default bg-gray-400/20" }),
84
- /* @__PURE__ */ t.jsxs("div", { className: "relative z-[100001] h-full w-full flex-col gap-y-1", children: [
85
- /* @__PURE__ */ t.jsxs("div", { className: "-mt-1 flex items-center justify-between px-2 py-2", children: [
86
- /* @__PURE__ */ t.jsxs("h3", { className: "space-x-3 text-sm font-semibold", children: [
87
- /* @__PURE__ */ t.jsx("span", { children: r("HTML Code Editor |") }),
88
- /* @__PURE__ */ t.jsx("span", { className: "text-xs text-gray-400", children: r("Scripts will be only executed in preview and live mode.") })
89
- ] }),
90
- /* @__PURE__ */ t.jsx("div", { className: "flex gap-x-2", children: /* @__PURE__ */ t.jsx(
91
- C,
92
- {
93
- onClick: () => s(null),
94
- size: "sm",
95
- variant: "destructive",
96
- className: "h-6 w-fit",
97
- children: /* @__PURE__ */ t.jsx(w, {})
98
- }
99
- ) })
100
- ] }),
101
- /* @__PURE__ */ t.jsx(
102
- k,
103
- {
104
- onMount: (e) => {
105
- e.setValue(o.initialCode);
106
- },
107
- onChange: (e) => {
108
- a(!0), c(e), f(e);
109
- },
110
- height: "100%",
111
- defaultLanguage: "html",
112
- theme: "vs-dark",
113
- defaultValue: "",
114
- options: {
115
- minimap: {
116
- enabled: !1
117
- }
118
- }
119
- }
120
- )
121
- ] })
122
- ] });
123
- }
124
- export {
125
- Pt as default
126
- };
@@ -1 +0,0 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./jsx-runtime-JYMCiFoE.cjs"),b=require("@monaco-editor/react"),k=require("./context-menu-4nQs6OxC.cjs"),C=require("react-i18next"),u=require("react"),n=require("./core.cjs"),E=require("@radix-ui/react-icons"),R=require("@react-hookz/web");require("@radix-ui/react-switch");require("@radix-ui/react-accordion");require("@radix-ui/react-alert-dialog");require("@radix-ui/react-slot");require("class-variance-authority");require("@radix-ui/react-dialog");require("@radix-ui/react-label");require("@radix-ui/react-scroll-area");require("@radix-ui/react-tabs");require("@radix-ui/react-tooltip");require("@radix-ui/react-popover");require("@radix-ui/react-hover-card");require("@radix-ui/react-dropdown-menu");require("@radix-ui/react-separator");require("@radix-ui/react-toast");require("@radix-ui/react-context-menu");require("clsx");require("tailwind-merge");require("lodash-es");require("jotai");require("./iconBase-aZzpqff_.cjs");require("@chaibuilder/runtime");require("./plugin-KIpT3NWi.cjs");require("lodash");require("tree-model");require("react-quill");require("./STRINGS-Yl7cSWDc.cjs");require("flagged");require("react-hotkeys-hook");require("@floating-ui/dom");require("@floating-ui/react-dom");require("@tailwindcss/typography");require("@tailwindcss/forms");require("@tailwindcss/aspect-ratio");require("react-wrap-balancer");require("react-dom");require("prop-types");require("react-error-boundary");require("re-resizable");require("lucide-react");require("react-arborist");require("himalaya");require("@rjsf/core");require("@rjsf/validator-ajv8");require("react-icons-picker");require("react-autosuggest");require("fuse.js");require("i18next");require("framer-motion");const a=s=>{const i=document.createElement("div");return i.innerHTML=s,i.innerHTML};function g(){const{t:s}=C.useTranslation(),[i,d]=u.useState(!1),[l,q]=u.useState(""),[r,o]=n.useCodeEditor(),[c]=n.useSelectedBlockIds(),x=n.useUpdateBlocksProps(),m=n.useUpdateBlocksPropsRealtime(),p=R.useThrottledCallback(t=>{const h=a(t);m([r.blockId],{[r.blockProp]:h})},[],300),j=u.useCallback(()=>{if(i){const t=a(l);x([r.blockId],{[r.blockProp]:t})}},[i,l]);u.useEffect(()=>{c.includes(r==null?void 0:r.blockId)||(j(),o(null))},[c]);const f=()=>{o(null)};return e.jsxRuntimeExports.jsxs("div",{className:"h-full rounded-t-lg border-t-4 border-black bg-black text-white",children:[e.jsxRuntimeExports.jsx("button",{onClick:f,className:"fixed inset-0 z-[100000] cursor-default bg-gray-400/20"}),e.jsxRuntimeExports.jsxs("div",{className:"relative z-[100001] h-full w-full flex-col gap-y-1",children:[e.jsxRuntimeExports.jsxs("div",{className:"-mt-1 flex items-center justify-between px-2 py-2",children:[e.jsxRuntimeExports.jsxs("h3",{className:"space-x-3 text-sm font-semibold",children:[e.jsxRuntimeExports.jsx("span",{children:s("HTML Code Editor |")}),e.jsxRuntimeExports.jsx("span",{className:"text-xs text-gray-400",children:s("Scripts will be only executed in preview and live mode.")})]}),e.jsxRuntimeExports.jsx("div",{className:"flex gap-x-2",children:e.jsxRuntimeExports.jsx(k.Button,{onClick:()=>o(null),size:"sm",variant:"destructive",className:"h-6 w-fit",children:e.jsxRuntimeExports.jsx(E.Cross2Icon,{})})})]}),e.jsxRuntimeExports.jsx(b,{onMount:t=>{t.setValue(r.initialCode)},onChange:t=>{d(!0),q(t),p(t)},height:"100%",defaultLanguage:"html",theme:"vs-dark",defaultValue:"",options:{minimap:{enabled:!1}}})]})]})}exports.default=g;
@@ -1,7 +0,0 @@
1
- const s = "#styles:", _ = "#slots:", t = "#i18n", E = "__ADD_BLOCK_INTERNAL_ROOT";
2
- export {
3
- t as I,
4
- E as R,
5
- s as S,
6
- _ as a
7
- };
@@ -1 +0,0 @@
1
- "use strict";const _="#styles:",E="#slots:",s="#i18n",T="__ADD_BLOCK_INTERNAL_ROOT";exports.I18N_KEY=s;exports.ROOT_TEMP_KEY=T;exports.SLOT_KEY=E;exports.STYLES_KEY=_;
@@ -1,73 +0,0 @@
1
- import { j as t } from "./jsx-runtime-Sp0orL4X.js";
2
- import o, { Suspense as m } from "react";
3
- import { S as i } from "./context-menu-oLipAPzI.js";
4
- import "react-i18next";
5
- import { useBuilderProp as p } from "./core.js";
6
- import "@radix-ui/react-switch";
7
- import "@radix-ui/react-accordion";
8
- import "@radix-ui/react-icons";
9
- import "@radix-ui/react-alert-dialog";
10
- import "@radix-ui/react-slot";
11
- import "class-variance-authority";
12
- import "@radix-ui/react-dialog";
13
- import "@radix-ui/react-label";
14
- import "@radix-ui/react-scroll-area";
15
- import "@radix-ui/react-tabs";
16
- import "@radix-ui/react-tooltip";
17
- import "@radix-ui/react-popover";
18
- import "@radix-ui/react-hover-card";
19
- import "@radix-ui/react-dropdown-menu";
20
- import "@radix-ui/react-separator";
21
- import "@radix-ui/react-toast";
22
- import "@radix-ui/react-context-menu";
23
- import "clsx";
24
- import "tailwind-merge";
25
- import "lodash-es";
26
- import "jotai";
27
- import "./iconBase-Ief2hJUZ.js";
28
- import "@chaibuilder/runtime";
29
- import "./plugin-ooqqxWRQ.js";
30
- import "@react-hookz/web";
31
- import "lodash";
32
- import "tree-model";
33
- import "react-quill";
34
- import "./STRINGS-Xxstm-7I.js";
35
- import "flagged";
36
- import "react-hotkeys-hook";
37
- import "@floating-ui/dom";
38
- import "@floating-ui/react-dom";
39
- import "@tailwindcss/typography";
40
- import "@tailwindcss/forms";
41
- import "@tailwindcss/aspect-ratio";
42
- import "react-wrap-balancer";
43
- import "react-dom";
44
- import "prop-types";
45
- import "react-error-boundary";
46
- import "re-resizable";
47
- import "lucide-react";
48
- import "react-arborist";
49
- import "himalaya";
50
- import "@rjsf/core";
51
- import "@rjsf/validator-ajv8";
52
- import "react-icons-picker";
53
- import "react-autosuggest";
54
- import "fuse.js";
55
- import "i18next";
56
- import "framer-motion";
57
- const ct = () => {
58
- const e = p("topBarComponents.left", []), s = p("topBarComponents.center", []), a = p("topBarComponents.right", []);
59
- return /* @__PURE__ */ t.jsxs("div", { className: "flex h-14 items-center justify-between px-2", children: [
60
- /* @__PURE__ */ t.jsx("div", { className: "flex items-center space-x-2", children: /* @__PURE__ */ t.jsx("div", { className: "flex items-center space-x-2 font-bold", children: o.Children.toArray(
61
- e.map((r) => /* @__PURE__ */ t.jsx(m, { fallback: /* @__PURE__ */ t.jsx(i, { className: "h-10" }), children: /* @__PURE__ */ t.jsx(r, {}) }))
62
- ) }) }),
63
- /* @__PURE__ */ t.jsx("div", { className: "flex items-center space-x-2", children: o.Children.toArray(
64
- s.map((r) => /* @__PURE__ */ t.jsx(m, { fallback: /* @__PURE__ */ t.jsx(i, { className: "h-10" }), children: /* @__PURE__ */ t.jsx(r, {}) }))
65
- ) }),
66
- /* @__PURE__ */ t.jsx("div", { className: "flex items-center space-x-1", children: o.Children.toArray(
67
- a.map((r) => /* @__PURE__ */ t.jsx(m, { fallback: /* @__PURE__ */ t.jsx(i, { className: "h-10" }), children: /* @__PURE__ */ t.jsx(r, {}) }))
68
- ) })
69
- ] });
70
- };
71
- export {
72
- ct as default
73
- };
@@ -1 +0,0 @@
1
- "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("./jsx-runtime-JYMCiFoE.cjs"),r=require("react"),s=require("./context-menu-4nQs6OxC.cjs");require("react-i18next");const u=require("./core.cjs");require("@radix-ui/react-switch");require("@radix-ui/react-accordion");require("@radix-ui/react-icons");require("@radix-ui/react-alert-dialog");require("@radix-ui/react-slot");require("class-variance-authority");require("@radix-ui/react-dialog");require("@radix-ui/react-label");require("@radix-ui/react-scroll-area");require("@radix-ui/react-tabs");require("@radix-ui/react-tooltip");require("@radix-ui/react-popover");require("@radix-ui/react-hover-card");require("@radix-ui/react-dropdown-menu");require("@radix-ui/react-separator");require("@radix-ui/react-toast");require("@radix-ui/react-context-menu");require("clsx");require("tailwind-merge");require("lodash-es");require("jotai");require("./iconBase-aZzpqff_.cjs");require("@chaibuilder/runtime");require("./plugin-KIpT3NWi.cjs");require("@react-hookz/web");require("lodash");require("tree-model");require("react-quill");require("./STRINGS-Yl7cSWDc.cjs");require("flagged");require("react-hotkeys-hook");require("@floating-ui/dom");require("@floating-ui/react-dom");require("@tailwindcss/typography");require("@tailwindcss/forms");require("@tailwindcss/aspect-ratio");require("react-wrap-balancer");require("react-dom");require("prop-types");require("react-error-boundary");require("re-resizable");require("lucide-react");require("react-arborist");require("himalaya");require("@rjsf/core");require("@rjsf/validator-ajv8");require("react-icons-picker");require("react-autosuggest");require("fuse.js");require("i18next");require("framer-motion");const o=()=>{const t=u.useBuilderProp("topBarComponents.left",[]),n=u.useBuilderProp("topBarComponents.center",[]),q=u.useBuilderProp("topBarComponents.right",[]);return e.jsxRuntimeExports.jsxs("div",{className:"flex h-14 items-center justify-between px-2",children:[e.jsxRuntimeExports.jsx("div",{className:"flex items-center space-x-2",children:e.jsxRuntimeExports.jsx("div",{className:"flex items-center space-x-2 font-bold",children:r.Children.toArray(t.map(i=>e.jsxRuntimeExports.jsx(r.Suspense,{fallback:e.jsxRuntimeExports.jsx(s.Skeleton,{className:"h-10"}),children:e.jsxRuntimeExports.jsx(i,{})})))})}),e.jsxRuntimeExports.jsx("div",{className:"flex items-center space-x-2",children:r.Children.toArray(n.map(i=>e.jsxRuntimeExports.jsx(r.Suspense,{fallback:e.jsxRuntimeExports.jsx(s.Skeleton,{className:"h-10"}),children:e.jsxRuntimeExports.jsx(i,{})})))}),e.jsxRuntimeExports.jsx("div",{className:"flex items-center space-x-1",children:r.Children.toArray(q.map(i=>e.jsxRuntimeExports.jsx(r.Suspense,{fallback:e.jsxRuntimeExports.jsx(s.Skeleton,{className:"h-10"}),children:e.jsxRuntimeExports.jsx(i,{})})))})]})};exports.default=o;
@@ -1 +0,0 @@
1
- "use strict";const s=require("./jsx-runtime-JYMCiFoE.cjs"),Ue=require("@radix-ui/react-switch"),Qe=require("react"),Xe=require("@radix-ui/react-accordion"),x=require("@radix-ui/react-icons"),Ye=require("@radix-ui/react-alert-dialog"),Je=require("@radix-ui/react-slot"),S=require("class-variance-authority"),Ke=require("@radix-ui/react-dialog"),We=require("@radix-ui/react-label"),Ze=require("@radix-ui/react-scroll-area"),$e=require("@radix-ui/react-tabs"),et=require("@radix-ui/react-tooltip"),tt=require("@radix-ui/react-popover"),ot=require("@radix-ui/react-hover-card"),st=require("@radix-ui/react-dropdown-menu"),at=require("@radix-ui/react-separator"),rt=require("@radix-ui/react-toast"),nt=require("@radix-ui/react-context-menu"),it=require("clsx"),dt=require("tailwind-merge");function m(e){const t=Object.create(null,{[Symbol.toStringTag]:{value:"Module"}});if(e){for(const o in e)if(o!=="default"){const r=Object.getOwnPropertyDescriptor(e,o);Object.defineProperty(t,o,r.get?r:{enumerable:!0,get:()=>e[o]})}}return t.default=e,Object.freeze(t)}const D=m(Ue),n=m(Qe),g=m(Xe),c=m(Ye),u=m(Ke),P=m(We),f=m(Ze),b=m($e),j=m(et),R=m(tt),h=m(ot),i=m(st),I=m(at),p=m(rt),d=m(nt),a=(...e)=>dt.twMerge(it.clsx(e)),k=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(D.Root,{className:a("peer inline-flex h-[24px] w-[44px] shrink-0 cursor-pointer items-center rounded-full border-2 border-transparent transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-slate-400 focus-visible:ring-offset-2 focus-visible:ring-offset-white disabled:cursor-not-allowed disabled:opacity-50 data-[state=checked]:bg-slate-900 data-[state=unchecked]:bg-slate-200 dark:focus-visible:ring-slate-800 dark:focus-visible:ring-offset-slate-950 dark:data-[state=checked]:bg-slate-50 dark:data-[state=unchecked]:bg-slate-800",e),...t,ref:o,children:s.jsxRuntimeExports.jsx(D.Thumb,{className:a("pointer-events-none block h-5 w-5 rounded-full bg-white shadow-lg ring-0 transition-transform data-[state=checked]:translate-x-5 data-[state=unchecked]:translate-x-0 dark:bg-slate-950")})}));k.displayName=D.Root.displayName;const w=S.cva("inline-flex items-center justify-center rounded-md text-sm font-medium transition-colors focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:pointer-events-none disabled:opacity-50",{variants:{variant:{default:"bg-primary text-primary-foreground shadow hover:bg-primary/90",destructive:"bg-destructive text-destructive-foreground shadow-sm hover:bg-destructive/90",outline:"border border-input bg-background shadow-sm hover:bg-accent hover:text-accent-foreground",secondary:"bg-secondary text-secondary-foreground shadow-sm hover:bg-secondary/80",ghost:"hover:bg-accent hover:text-accent-foreground",link:"text-primary underline-offset-4 hover:underline"},size:{default:"h-9 px-4 py-2",sm:"h-8 rounded-md px-3 text-xs",lg:"h-10 rounded-md px-8",icon:"h-9 w-9"}},defaultVariants:{variant:"default",size:"default"}}),_=n.forwardRef(({className:e,variant:t,size:o,asChild:r=!1,...l},C)=>{const Be=r?Je.Slot:"button";return s.jsxRuntimeExports.jsx(Be,{className:a(w({variant:t,size:o,className:e})),ref:C,...l})});_.displayName="Button";const lt=g.Root,z=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(g.Item,{ref:o,className:a("border-b",e),...t}));z.displayName="AccordionItem";const O=n.forwardRef(({className:e,children:t,...o},r)=>s.jsxRuntimeExports.jsx(g.Header,{className:"flex",children:s.jsxRuntimeExports.jsxs(g.Trigger,{ref:r,className:a("flex flex-1 items-center justify-between py-4 text-sm font-medium transition-all hover:underline [&[data-state=open]>svg]:rotate-180",e),...o,children:[t,o.hideArrow?null:s.jsxRuntimeExports.jsx(x.ChevronDownIcon,{className:"h-4 w-4 shrink-0 text-muted-foreground transition-transform duration-200"})]})}));O.displayName=g.Trigger.displayName;const q=n.forwardRef(({className:e,children:t,...o},r)=>s.jsxRuntimeExports.jsx(g.Content,{ref:r,className:a("text-sm data-[state=closed]:animate-accordion-up data-[state=open]:animate-accordion-down",e),...o,children:s.jsxRuntimeExports.jsx("div",{className:"pb-4 pt-0",children:t})}));q.displayName=g.Content.displayName;const ct=c.Root,mt=c.Trigger,L=({className:e,...t})=>s.jsxRuntimeExports.jsx(c.Portal,{className:a(e),...t});L.displayName=c.Portal.displayName;const H=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(c.Overlay,{className:a("fixed inset-0 z-50 bg-background/80 backdrop-blur-sm data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...t,ref:o}));H.displayName=c.Overlay.displayName;const V=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsxs(L,{children:[s.jsxRuntimeExports.jsx(H,{}),s.jsxRuntimeExports.jsx(c.Content,{ref:o,className:a("fixed left-[50%] top-[50%] z-50 grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg md:w-full",e),...t})]}));V.displayName=c.Content.displayName;const G=({className:e,...t})=>s.jsxRuntimeExports.jsx("div",{className:a("flex flex-col space-y-2 text-center sm:text-left",e),...t});G.displayName="AlertDialogHeader";const F=({className:e,...t})=>s.jsxRuntimeExports.jsx("div",{className:a("flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2",e),...t});F.displayName="AlertDialogFooter";const B=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(c.Title,{ref:o,className:a("text-lg font-semibold",e),...t}));B.displayName=c.Title.displayName;const U=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(c.Description,{ref:o,className:a("text-sm text-muted-foreground",e),...t}));U.displayName=c.Description.displayName;const Q=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(c.Action,{ref:o,className:a(w(),e),...t}));Q.displayName=c.Action.displayName;const X=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(c.Cancel,{ref:o,className:a(w({variant:"outline"}),"mt-2 sm:mt-0",e),...t}));X.displayName=c.Cancel.displayName;const ut=u.Root,pt=u.Trigger,Y=({className:e,...t})=>s.jsxRuntimeExports.jsx(u.Portal,{className:a(e),...t});Y.displayName=u.Portal.displayName;const J=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(u.Overlay,{ref:o,className:a("fixed inset-0 z-50 bg-background/80 backdrop-blur-sm data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0",e),...t}));J.displayName=u.Overlay.displayName;const K=n.forwardRef(({className:e,children:t,...o},r)=>s.jsxRuntimeExports.jsxs(Y,{children:[s.jsxRuntimeExports.jsx(J,{}),s.jsxRuntimeExports.jsxs(u.Content,{ref:r,className:a("fixed left-[50%] top-[50%] z-[999] grid w-full max-w-lg translate-x-[-50%] translate-y-[-50%] gap-4 border bg-background p-6 shadow-lg duration-200 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[state=closed]:slide-out-to-left-1/2 data-[state=closed]:slide-out-to-top-[48%] data-[state=open]:slide-in-from-left-1/2 data-[state=open]:slide-in-from-top-[48%] sm:rounded-lg md:w-full",e),...o,children:[t,s.jsxRuntimeExports.jsxs(u.Close,{className:"absolute right-4 top-4 rounded-sm opacity-70 ring-offset-background transition-opacity hover:opacity-100 focus:outline-none focus:ring-2 focus:ring-ring focus:ring-offset-2 disabled:pointer-events-none data-[state=open]:bg-accent data-[state=open]:text-muted-foreground",children:[s.jsxRuntimeExports.jsx(x.Cross2Icon,{className:"h-4 w-4"}),s.jsxRuntimeExports.jsx("span",{className:"sr-only",children:"Close"})]})]})]}));K.displayName=u.Content.displayName;const W=({className:e,...t})=>s.jsxRuntimeExports.jsx("div",{className:a("flex flex-col space-y-1.5 text-center sm:text-left",e),...t});W.displayName="DialogHeader";const Z=({className:e,...t})=>s.jsxRuntimeExports.jsx("div",{className:a("flex flex-col-reverse sm:flex-row sm:justify-end sm:space-x-2",e),...t});Z.displayName="DialogFooter";const $=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(u.Title,{ref:o,className:a("text-lg font-semibold leading-none tracking-tight",e),...t}));$.displayName=u.Title.displayName;const ee=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(u.Description,{ref:o,className:a("text-sm text-muted-foreground",e),...t}));ee.displayName=u.Description.displayName;const te=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx("div",{ref:o,className:a("rounded-xl border bg-card text-card-foreground shadow",e),...t}));te.displayName="Card";const oe=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx("div",{ref:o,className:a("flex flex-col space-y-1.5 p-6",e),...t}));oe.displayName="CardHeader";const se=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx("h3",{ref:o,className:a("font-semibold leading-none tracking-tight",e),...t}));se.displayName="CardTitle";const ae=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx("p",{ref:o,className:a("text-sm text-muted-foreground",e),...t}));ae.displayName="CardDescription";const re=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx("div",{ref:o,className:a("p-6 pt-0",e),...t}));re.displayName="CardContent";const ne=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx("div",{ref:o,className:a(" flex items-center p-6 pt-0",e),...t}));ne.displayName="CardFooter";const ie=n.forwardRef(({className:e,type:t,...o},r)=>s.jsxRuntimeExports.jsx("input",{type:t,className:a("flex h-9 w-full rounded-md border border-border bg-background px-3 py-1 text-sm shadow-sm transition-colors file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50",e),ref:r,...o,autoCapitalize:"off",autoCorrect:"off",spellCheck:"false"}));ie.displayName="Input";const xt=S.cva("text-sm font-medium leading-none peer-disabled:cursor-not-allowed peer-disabled:opacity-70"),de=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(P.Root,{ref:o,className:a(xt(),e),...t}));de.displayName=P.Root.displayName;const le=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx("textarea",{className:a("flex min-h-[60px] w-full rounded-md border border-input bg-transparent px-3 py-2 text-sm shadow-sm placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50",e),ref:o,...t,autoCapitalize:"off",autoCorrect:"off",spellCheck:"false"}));le.displayName="Textarea";const ce=n.forwardRef(({className:e,children:t,...o},r)=>s.jsxRuntimeExports.jsxs(f.Root,{ref:r,className:a("relative overflow-hidden",e),...o,children:[s.jsxRuntimeExports.jsx(f.Viewport,{className:"h-full w-full rounded-[inherit]",children:t}),s.jsxRuntimeExports.jsx(M,{}),s.jsxRuntimeExports.jsx(f.Corner,{})]}));ce.displayName=f.Root.displayName;const M=n.forwardRef(({className:e,orientation:t="vertical",...o},r)=>s.jsxRuntimeExports.jsx(f.ScrollAreaScrollbar,{ref:r,orientation:t,className:a("flex touch-none select-none transition-colors",t==="vertical"&&"h-full w-2.5 border-l border-l-transparent p-[1px]",t==="horizontal"&&"h-2.5 border-t border-t-transparent p-[1px]",e),...o,children:s.jsxRuntimeExports.jsx(f.ScrollAreaThumb,{className:"relative flex-1 rounded-full bg-border"})}));M.displayName=f.ScrollAreaScrollbar.displayName;const ft=b.Root,me=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(b.List,{ref:o,className:a("inline-flex h-9 items-center justify-center rounded-lg bg-muted p-1 text-muted-foreground",e),...t}));me.displayName=b.List.displayName;const ue=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(b.Trigger,{ref:o,className:a("inline-flex items-center justify-center whitespace-nowrap rounded-md px-3 py-1 text-sm font-medium ring-offset-background transition-all focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 data-[state=active]:bg-background data-[state=active]:text-foreground data-[state=active]:shadow",e),...t}));ue.displayName=b.Trigger.displayName;const pe=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(b.Content,{ref:o,className:a("mt-2 ring-offset-background focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2",e),...t}));pe.displayName=b.Content.displayName;const gt=j.Portal,bt=j.Provider,jt=j.Root,vt=j.Trigger,xe=n.forwardRef(({className:e,sideOffset:t=4,...o},r)=>s.jsxRuntimeExports.jsx(j.Content,{ref:r,sideOffset:t,className:a("z-50 overflow-hidden rounded-md bg-primary px-3 py-1.5 text-xs text-primary-foreground animate-in fade-in-0 zoom-in-95 data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=closed]:zoom-out-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",e),...o}));xe.displayName=j.Content.displayName;const Rt=R.Root,yt=R.Trigger,fe=n.forwardRef(({className:e,align:t="center",sideOffset:o=4,...r},l)=>s.jsxRuntimeExports.jsx(R.Portal,{children:s.jsxRuntimeExports.jsx(R.Content,{ref:l,align:t,sideOffset:o,className:a("z-50 w-72 rounded-md border bg-popover p-4 text-popover-foreground shadow-md outline-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",e),...r})}));fe.displayName=R.Content.displayName;const Nt=h.Root,ht=h.Trigger,ge=n.forwardRef(({className:e,align:t="center",sideOffset:o=4,...r},l)=>s.jsxRuntimeExports.jsx(h.Content,{ref:l,align:t,sideOffset:o,className:a("z-50 w-64 rounded-md border bg-popover p-4 text-popover-foreground shadow-md outline-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",e),...r}));ge.displayName=h.Content.displayName;const wt=i.Root,Ct=i.Trigger,Tt=i.Group,Et=i.Portal,Dt=i.Sub,St=i.RadioGroup,be=n.forwardRef(({className:e,inset:t,children:o,...r},l)=>s.jsxRuntimeExports.jsxs(i.SubTrigger,{ref:l,className:a("flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent data-[state=open]:bg-accent",t&&"pl-8",e),...r,children:[o,s.jsxRuntimeExports.jsx(x.ChevronRightIcon,{className:"ml-auto h-4 w-4"})]}));be.displayName=i.SubTrigger.displayName;const je=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(i.SubContent,{ref:o,className:a("z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-lg data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",e),...t}));je.displayName=i.SubContent.displayName;const ve=n.forwardRef(({className:e,sideOffset:t=4,...o},r)=>s.jsxRuntimeExports.jsx(i.Portal,{children:s.jsxRuntimeExports.jsx(i.Content,{ref:r,sideOffset:t,className:a("z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-md","data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",e),...o})}));ve.displayName=i.Content.displayName;const Re=n.forwardRef(({className:e,inset:t,...o},r)=>s.jsxRuntimeExports.jsx(i.Item,{ref:r,className:a("relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",t&&"pl-8",e),...o}));Re.displayName=i.Item.displayName;const ye=n.forwardRef(({className:e,children:t,checked:o,...r},l)=>s.jsxRuntimeExports.jsxs(i.CheckboxItem,{ref:l,className:a("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),checked:o,...r,children:[s.jsxRuntimeExports.jsx("span",{className:"absolute left-2 flex h-3.5 w-3.5 items-center justify-center",children:s.jsxRuntimeExports.jsx(i.ItemIndicator,{children:s.jsxRuntimeExports.jsx(x.CheckIcon,{className:"h-4 w-4"})})}),t]}));ye.displayName=i.CheckboxItem.displayName;const Ne=n.forwardRef(({className:e,children:t,...o},r)=>s.jsxRuntimeExports.jsxs(i.RadioItem,{ref:r,className:a("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none transition-colors focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),...o,children:[s.jsxRuntimeExports.jsx("span",{className:"absolute left-2 flex h-3.5 w-3.5 items-center justify-center",children:s.jsxRuntimeExports.jsx(i.ItemIndicator,{children:s.jsxRuntimeExports.jsx(x.DotFilledIcon,{className:"h-4 w-4 fill-current"})})}),t]}));Ne.displayName=i.RadioItem.displayName;const he=n.forwardRef(({className:e,inset:t,...o},r)=>s.jsxRuntimeExports.jsx(i.Label,{ref:r,className:a("px-2 py-1.5 text-sm font-semibold",t&&"pl-8",e),...o}));he.displayName=i.Label.displayName;const we=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(i.Separator,{ref:o,className:a("-mx-1 my-1 h-px bg-muted",e),...t}));we.displayName=i.Separator.displayName;const Ce=({className:e,...t})=>s.jsxRuntimeExports.jsx("span",{className:a("ml-auto text-xs tracking-widest opacity-60",e),...t});Ce.displayName="DropdownMenuShortcut";const Te=n.forwardRef(({className:e,orientation:t="horizontal",decorative:o=!0,...r},l)=>s.jsxRuntimeExports.jsx(I.Root,{ref:l,decorative:o,orientation:t,className:a("shrink-0 bg-border",t==="horizontal"?"h-[1px] w-full":"h-full w-[1px]",e),...r}));Te.displayName=I.Root.displayName;const Mt=1,At=1e6;let T=0;function Pt(){return T=(T+1)%Number.MAX_VALUE,T.toString()}const E=new Map,A=e=>{if(E.has(e))return;const t=setTimeout(()=>{E.delete(e),v({type:"REMOVE_TOAST",toastId:e})},At);E.set(e,t)},Ee=(e,t)=>{switch(t.type){case"ADD_TOAST":return{...e,toasts:[t.toast,...e.toasts].slice(0,Mt)};case"UPDATE_TOAST":return{...e,toasts:e.toasts.map(o=>o.id===t.toast.id?{...o,...t.toast}:o)};case"DISMISS_TOAST":{const{toastId:o}=t;return o?A(o):e.toasts.forEach(r=>{A(r.id)}),{...e,toasts:e.toasts.map(r=>r.id===o||o===void 0?{...r,open:!1}:r)}}case"REMOVE_TOAST":return t.toastId===void 0?{...e,toasts:[]}:{...e,toasts:e.toasts.filter(o=>o.id!==t.toastId)}}},y=[];let N={toasts:[]};function v(e){N=Ee(N,e),y.forEach(t=>{t(N)})}function De({...e}){const t=Pt(),o=l=>v({type:"UPDATE_TOAST",toast:{...l,id:t}}),r=()=>v({type:"DISMISS_TOAST",toastId:t});return v({type:"ADD_TOAST",toast:{...e,id:t,open:!0,onOpenChange:l=>{l||r()}}}),{id:t,dismiss:r,update:o}}function Se(){const[e,t]=n.useState(N);return n.useEffect(()=>(y.push(t),()=>{const o=y.indexOf(t);o>-1&&y.splice(o,1)}),[e]),{...e,toast:De,dismiss:o=>v({type:"DISMISS_TOAST",toastId:o})}}const It=p.Provider,Me=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(p.Viewport,{ref:o,className:a("fixed top-0 z-[100] flex max-h-screen w-full flex-col-reverse p-4 sm:bottom-0 sm:right-0 sm:top-auto sm:flex-col md:max-w-[420px]",e),...t}));Me.displayName=p.Viewport.displayName;const kt=S.cva("group pointer-events-auto relative flex w-full items-center justify-between space-x-2 overflow-hidden rounded-md border p-4 pr-6 shadow-lg transition-all data-[swipe=cancel]:translate-x-0 data-[swipe=end]:translate-x-[var(--radix-toast-swipe-end-x)] data-[swipe=move]:translate-x-[var(--radix-toast-swipe-move-x)] data-[swipe=move]:transition-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[swipe=end]:animate-out data-[state=closed]:fade-out-80 data-[state=closed]:slide-out-to-right-full data-[state=open]:slide-in-from-top-full data-[state=open]:sm:slide-in-from-bottom-full",{variants:{variant:{default:"border bg-background",destructive:"destructive group border-destructive bg-destructive text-destructive-foreground"}},defaultVariants:{variant:"default"}}),Ae=n.forwardRef(({className:e,variant:t,...o},r)=>s.jsxRuntimeExports.jsx(p.Root,{ref:r,className:a(kt({variant:t}),e),...o}));Ae.displayName=p.Root.displayName;const _t=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(p.Action,{ref:o,className:a("inline-flex h-8 shrink-0 items-center justify-center rounded-md border bg-transparent px-3 text-sm font-medium transition-colors hover:bg-secondary focus:outline-none focus:ring-1 focus:ring-ring disabled:pointer-events-none disabled:opacity-50 group-[.destructive]:border-muted/40 group-[.destructive]:hover:border-destructive/30 group-[.destructive]:hover:bg-destructive group-[.destructive]:hover:text-destructive-foreground group-[.destructive]:focus:ring-destructive",e),...t}));_t.displayName=p.Action.displayName;const Pe=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(p.Close,{ref:o,className:a("absolute right-1 top-1 rounded-md p-1 text-foreground/50 opacity-0 transition-opacity hover:text-foreground focus:opacity-100 focus:outline-none focus:ring-1 group-hover:opacity-100 group-[.destructive]:text-red-300 group-[.destructive]:hover:text-red-50 group-[.destructive]:focus:ring-red-400 group-[.destructive]:focus:ring-offset-red-600",e),"toast-close":"",...t,children:s.jsxRuntimeExports.jsx(x.Cross2Icon,{className:"h-4 w-4"})}));Pe.displayName=p.Close.displayName;const Ie=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(p.Title,{ref:o,className:a("text-sm font-semibold [&+div]:text-xs",e),...t}));Ie.displayName=p.Title.displayName;const ke=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(p.Description,{ref:o,className:a("text-sm opacity-90",e),...t}));ke.displayName=p.Description.displayName;function zt(){const{toasts:e}=Se();return s.jsxRuntimeExports.jsxs(It,{children:[e.map(({id:t,title:o,description:r,action:l,...C})=>s.jsxRuntimeExports.jsxs(Ae,{...C,children:[s.jsxRuntimeExports.jsxs("div",{className:"grid gap-1",children:[o&&s.jsxRuntimeExports.jsx(Ie,{children:o}),r&&s.jsxRuntimeExports.jsx(ke,{children:r})]}),l,s.jsxRuntimeExports.jsx(Pe,{})]},t)),s.jsxRuntimeExports.jsx(Me,{})]})}const Ot=({className:e,...t})=>s.jsxRuntimeExports.jsx("div",{className:a("animate-pulse rounded-md bg-primary/10",e),...t}),qt=d.Root,Lt=d.Trigger,Ht=d.Group,Vt=d.Portal,Gt=d.Sub,Ft=d.RadioGroup,_e=n.forwardRef(({className:e,inset:t,children:o,...r},l)=>s.jsxRuntimeExports.jsxs(d.SubTrigger,{ref:l,className:a("flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[state=open]:bg-accent data-[state=open]:text-accent-foreground",t&&"pl-8",e),...r,children:[o,s.jsxRuntimeExports.jsx(x.ChevronRightIcon,{className:"ml-auto h-4 w-4"})]}));_e.displayName=d.SubTrigger.displayName;const ze=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(d.SubContent,{ref:o,className:a("z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-lg data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",e),...t}));ze.displayName=d.SubContent.displayName;const Oe=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(d.Portal,{children:s.jsxRuntimeExports.jsx(d.Content,{ref:o,className:a("z-50 min-w-[8rem] overflow-hidden rounded-md border bg-popover p-1 text-popover-foreground shadow-md data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2",e),...t})}));Oe.displayName=d.Content.displayName;const qe=n.forwardRef(({className:e,inset:t,...o},r)=>s.jsxRuntimeExports.jsx(d.Item,{ref:r,className:a("relative flex cursor-default select-none items-center rounded-sm px-2 py-1.5 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",t&&"pl-8",e),...o}));qe.displayName=d.Item.displayName;const Le=n.forwardRef(({className:e,children:t,checked:o,...r},l)=>s.jsxRuntimeExports.jsxs(d.CheckboxItem,{ref:l,className:a("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),checked:o,...r,children:[s.jsxRuntimeExports.jsx("span",{className:"absolute left-2 flex h-3.5 w-3.5 items-center justify-center",children:s.jsxRuntimeExports.jsx(d.ItemIndicator,{children:s.jsxRuntimeExports.jsx(x.CheckIcon,{className:"h-4 w-4"})})}),t]}));Le.displayName=d.CheckboxItem.displayName;const He=n.forwardRef(({className:e,children:t,...o},r)=>s.jsxRuntimeExports.jsxs(d.RadioItem,{ref:r,className:a("relative flex cursor-default select-none items-center rounded-sm py-1.5 pl-8 pr-2 text-sm outline-none focus:bg-accent focus:text-accent-foreground data-[disabled]:pointer-events-none data-[disabled]:opacity-50",e),...o,children:[s.jsxRuntimeExports.jsx("span",{className:"absolute left-2 flex h-3.5 w-3.5 items-center justify-center",children:s.jsxRuntimeExports.jsx(d.ItemIndicator,{children:s.jsxRuntimeExports.jsx(x.DotFilledIcon,{className:"h-4 w-4 fill-current"})})}),t]}));He.displayName=d.RadioItem.displayName;const Ve=n.forwardRef(({className:e,inset:t,...o},r)=>s.jsxRuntimeExports.jsx(d.Label,{ref:r,className:a("px-2 py-1.5 text-sm font-semibold text-foreground",t&&"pl-8",e),...o}));Ve.displayName=d.Label.displayName;const Ge=n.forwardRef(({className:e,...t},o)=>s.jsxRuntimeExports.jsx(d.Separator,{ref:o,className:a("-mx-1 my-1 h-px bg-border",e),...t}));Ge.displayName=d.Separator.displayName;const Fe=({className:e,...t})=>s.jsxRuntimeExports.jsx("span",{className:a("ml-auto text-xs tracking-widest text-muted-foreground",e),...t});Fe.displayName="ContextMenuShortcut";exports.Accordion=lt;exports.AccordionContent=q;exports.AccordionItem=z;exports.AccordionTrigger=O;exports.AlertDialog=ct;exports.AlertDialogAction=Q;exports.AlertDialogCancel=X;exports.AlertDialogContent=V;exports.AlertDialogDescription=U;exports.AlertDialogFooter=F;exports.AlertDialogHeader=G;exports.AlertDialogTitle=B;exports.AlertDialogTrigger=mt;exports.Button=_;exports.Card=te;exports.CardContent=re;exports.CardDescription=ae;exports.CardFooter=ne;exports.CardHeader=oe;exports.CardTitle=se;exports.ContextMenu=qt;exports.ContextMenuCheckboxItem=Le;exports.ContextMenuContent=Oe;exports.ContextMenuGroup=Ht;exports.ContextMenuItem=qe;exports.ContextMenuLabel=Ve;exports.ContextMenuPortal=Vt;exports.ContextMenuRadioGroup=Ft;exports.ContextMenuRadioItem=He;exports.ContextMenuSeparator=Ge;exports.ContextMenuShortcut=Fe;exports.ContextMenuSub=Gt;exports.ContextMenuSubContent=ze;exports.ContextMenuSubTrigger=_e;exports.ContextMenuTrigger=Lt;exports.Dialog=ut;exports.DialogContent=K;exports.DialogDescription=ee;exports.DialogFooter=Z;exports.DialogHeader=W;exports.DialogTitle=$;exports.DialogTrigger=pt;exports.DropdownMenu=wt;exports.DropdownMenuCheckboxItem=ye;exports.DropdownMenuContent=ve;exports.DropdownMenuGroup=Tt;exports.DropdownMenuItem=Re;exports.DropdownMenuLabel=he;exports.DropdownMenuPortal=Et;exports.DropdownMenuRadioGroup=St;exports.DropdownMenuRadioItem=Ne;exports.DropdownMenuSeparator=we;exports.DropdownMenuShortcut=Ce;exports.DropdownMenuSub=Dt;exports.DropdownMenuSubContent=je;exports.DropdownMenuSubTrigger=be;exports.DropdownMenuTrigger=Ct;exports.HoverCard=Nt;exports.HoverCardContent=ge;exports.HoverCardTrigger=ht;exports.Input=ie;exports.Label=de;exports.Popover=Rt;exports.PopoverContent=fe;exports.PopoverTrigger=yt;exports.ScrollArea=ce;exports.ScrollBar=M;exports.Separator=Te;exports.Skeleton=Ot;exports.Switch=k;exports.Tabs=ft;exports.TabsContent=pe;exports.TabsList=me;exports.TabsTrigger=ue;exports.Textarea=le;exports.Toaster=zt;exports.Tooltip=jt;exports.TooltipContent=xe;exports.TooltipPortal=gt;exports.TooltipProvider=bt;exports.TooltipTrigger=vt;exports.buttonVariants=w;exports.cn=a;exports.reducer=Ee;exports.toast=De;exports.useToast=Se;