@flowgram.ai/form-materials 0.1.0-alpha.13 → 0.1.0-alpha.15

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 (477) hide show
  1. package/bin/run.sh +6 -0
  2. package/dist/cjs/components/assign-row/index.js +112 -0
  3. package/dist/cjs/components/assign-row/types.js +18 -0
  4. package/dist/cjs/components/assign-rows/index.js +85 -0
  5. package/dist/cjs/components/batch-outputs/index.js +91 -0
  6. package/dist/cjs/components/batch-outputs/styles.js +60 -0
  7. package/dist/cjs/components/batch-outputs/types.js +18 -0
  8. package/dist/cjs/components/batch-variable-selector/index.js +53 -0
  9. package/dist/cjs/components/blur-input/index.js +64 -0
  10. package/dist/cjs/components/code-editor/editor.js +117 -0
  11. package/dist/cjs/components/code-editor/index.js +57 -0
  12. package/dist/cjs/components/code-editor/init-worker.js +56 -0
  13. package/dist/cjs/components/code-editor/language-features.js +21 -0
  14. package/dist/cjs/components/code-editor/theme/dark.js +188 -0
  15. package/dist/cjs/components/code-editor/theme/index.js +11 -0
  16. package/dist/cjs/components/code-editor/theme/light.js +195 -0
  17. package/dist/cjs/components/code-editor/utils.js +42 -0
  18. package/dist/cjs/components/code-editor-mini/index.js +66 -0
  19. package/dist/cjs/components/condition-row/constants.js +165 -0
  20. package/dist/cjs/components/condition-row/hooks/useOp.js +78 -0
  21. package/dist/cjs/components/condition-row/hooks/useRule.js +68 -0
  22. package/dist/cjs/components/condition-row/index.js +123 -0
  23. package/dist/cjs/components/condition-row/styles.js +77 -0
  24. package/dist/cjs/components/condition-row/types.js +52 -0
  25. package/dist/cjs/components/constant-input/index.js +80 -0
  26. package/dist/cjs/components/constant-input/types.js +18 -0
  27. package/dist/cjs/components/db-condition-row/hooks/use-left.js +86 -0
  28. package/dist/cjs/components/db-condition-row/hooks/use-op.js +79 -0
  29. package/dist/cjs/components/db-condition-row/index.js +115 -0
  30. package/dist/cjs/components/db-condition-row/styles.js +94 -0
  31. package/dist/cjs/components/db-condition-row/types.js +18 -0
  32. package/dist/cjs/components/display-flow-value/index.js +64 -0
  33. package/dist/cjs/components/display-inputs-values/index.js +76 -0
  34. package/dist/cjs/components/display-inputs-values/styles.js +51 -0
  35. package/dist/cjs/components/display-outputs/index.js +72 -0
  36. package/dist/cjs/components/display-outputs/styles.js +51 -0
  37. package/dist/cjs/components/display-schema-tag/index.js +77 -0
  38. package/dist/cjs/components/display-schema-tag/styles.js +71 -0
  39. package/dist/cjs/components/display-schema-tree/index.js +93 -0
  40. package/dist/cjs/components/display-schema-tree/styles.js +135 -0
  41. package/dist/cjs/components/dynamic-value-input/hooks.js +99 -0
  42. package/dist/cjs/components/dynamic-value-input/index.js +174 -0
  43. package/dist/cjs/components/dynamic-value-input/styles.js +107 -0
  44. package/dist/cjs/components/index.js +156 -0
  45. package/dist/cjs/components/inputs-values/index.js +112 -0
  46. package/dist/cjs/components/inputs-values/styles.js +60 -0
  47. package/dist/cjs/components/inputs-values/types.js +18 -0
  48. package/dist/cjs/components/inputs-values-tree/hooks/use-child-list.js +77 -0
  49. package/dist/cjs/components/inputs-values-tree/index.js +87 -0
  50. package/dist/cjs/components/inputs-values-tree/row.js +183 -0
  51. package/dist/cjs/components/inputs-values-tree/styles.js +177 -0
  52. package/dist/cjs/components/inputs-values-tree/types.js +18 -0
  53. package/dist/cjs/components/json-editor-with-variables/editor.js +81 -0
  54. package/dist/cjs/components/json-editor-with-variables/extensions/variable-tag.js +151 -0
  55. package/dist/cjs/components/json-editor-with-variables/extensions/variable-tree.js +97 -0
  56. package/dist/cjs/components/json-editor-with-variables/index.js +57 -0
  57. package/dist/cjs/components/json-editor-with-variables/styles.js +89 -0
  58. package/dist/cjs/components/json-schema-editor/default-value.js +54 -0
  59. package/dist/cjs/components/json-schema-editor/hooks.js +130 -0
  60. package/dist/cjs/components/json-schema-editor/index.js +246 -0
  61. package/dist/cjs/components/json-schema-editor/styles.js +231 -0
  62. package/dist/cjs/components/json-schema-editor/types.js +18 -0
  63. package/dist/cjs/components/prompt-editor/editor.js +99 -0
  64. package/dist/cjs/components/prompt-editor/extensions/jinja.js +73 -0
  65. package/dist/cjs/components/prompt-editor/extensions/language-support.js +48 -0
  66. package/dist/cjs/components/prompt-editor/extensions/markdown.js +81 -0
  67. package/dist/cjs/components/prompt-editor/index.js +57 -0
  68. package/dist/cjs/components/prompt-editor/styles.js +55 -0
  69. package/dist/cjs/components/prompt-editor/types.js +7 -0
  70. package/dist/cjs/components/prompt-editor-with-inputs/editor.js +47 -0
  71. package/dist/cjs/components/prompt-editor-with-inputs/extensions/inputs-tree.js +101 -0
  72. package/dist/cjs/components/prompt-editor-with-inputs/index.js +57 -0
  73. package/dist/cjs/components/prompt-editor-with-inputs/inputs-picker.js +104 -0
  74. package/dist/cjs/components/prompt-editor-with-variables/editor.js +49 -0
  75. package/dist/cjs/components/prompt-editor-with-variables/extensions/variable-tag.js +151 -0
  76. package/dist/cjs/components/prompt-editor-with-variables/extensions/variable-tree.js +103 -0
  77. package/dist/cjs/components/prompt-editor-with-variables/index.js +57 -0
  78. package/dist/cjs/components/prompt-editor-with-variables/styles.js +89 -0
  79. package/dist/cjs/components/type-selector/index.js +139 -0
  80. package/dist/cjs/components/variable-selector/context.js +56 -0
  81. package/dist/cjs/components/variable-selector/index.js +143 -0
  82. package/dist/cjs/components/variable-selector/styles.js +114 -0
  83. package/dist/cjs/components/variable-selector/use-variable-tree.js +100 -0
  84. package/dist/cjs/effects/auto-rename-ref/index.js +98 -0
  85. package/dist/cjs/effects/index.js +60 -0
  86. package/dist/cjs/effects/listen-ref-schema-change/index.js +57 -0
  87. package/dist/cjs/effects/listen-ref-value-change/index.js +54 -0
  88. package/dist/cjs/effects/provide-batch-input/index.js +64 -0
  89. package/dist/cjs/effects/provide-json-schema-outputs/index.js +49 -0
  90. package/dist/cjs/effects/sync-variable-title/index.js +52 -0
  91. package/dist/cjs/effects/validate-when-variable-sync/index.js +49 -0
  92. package/dist/cjs/form-plugins/batch-outputs-plugin/index.js +97 -0
  93. package/dist/cjs/form-plugins/index.js +47 -0
  94. package/dist/cjs/form-plugins/infer-assign-plugin/index.js +72 -0
  95. package/dist/cjs/form-plugins/infer-inputs-plugin/index.js +47 -0
  96. package/dist/cjs/hooks/index.js +36 -0
  97. package/dist/cjs/hooks/use-object-list/index.js +136 -0
  98. package/dist/cjs/index.js +228 -0
  99. package/dist/cjs/plugins/disable-declaration-plugin/create-disable-declaration-plugin.js +51 -0
  100. package/dist/cjs/plugins/disable-declaration-plugin/index.js +36 -0
  101. package/dist/cjs/plugins/index.js +49 -0
  102. package/dist/cjs/plugins/json-schema-preset/create-type-preset-plugin.js +49 -0
  103. package/dist/cjs/plugins/json-schema-preset/index.js +57 -0
  104. package/dist/cjs/plugins/json-schema-preset/manager.js +18 -0
  105. package/dist/cjs/plugins/json-schema-preset/type-definition/array.js +49 -0
  106. package/dist/cjs/plugins/json-schema-preset/type-definition/boolean.js +63 -0
  107. package/dist/cjs/plugins/json-schema-preset/type-definition/date-time.js +52 -0
  108. package/dist/cjs/plugins/json-schema-preset/type-definition/index.js +53 -0
  109. package/dist/cjs/plugins/json-schema-preset/type-definition/integer.js +49 -0
  110. package/dist/cjs/plugins/json-schema-preset/type-definition/number.js +49 -0
  111. package/dist/cjs/plugins/json-schema-preset/type-definition/object.js +49 -0
  112. package/dist/cjs/plugins/json-schema-preset/type-definition/string.js +54 -0
  113. package/dist/cjs/shared/flow-value/index.js +36 -0
  114. package/dist/cjs/shared/flow-value/schema.js +82 -0
  115. package/dist/cjs/shared/flow-value/types.js +18 -0
  116. package/dist/cjs/shared/flow-value/utils.js +142 -0
  117. package/dist/cjs/shared/format-legacy-refs/index.js +99 -0
  118. package/dist/cjs/shared/index.js +73 -0
  119. package/dist/cjs/shared/inject-material/index.js +65 -0
  120. package/dist/cjs/shared/lazy-suspense/index.js +58 -0
  121. package/dist/cjs/shared/polyfill-create-root/index.js +53 -0
  122. package/dist/cjs/validate/index.js +36 -0
  123. package/dist/cjs/validate/validate-flow-value/index.js +63 -0
  124. package/dist/esm/components/assign-row/index.mjs +78 -0
  125. package/dist/esm/components/assign-row/types.mjs +0 -0
  126. package/dist/esm/components/assign-rows/index.mjs +51 -0
  127. package/dist/esm/components/batch-outputs/index.mjs +57 -0
  128. package/dist/esm/components/batch-outputs/styles.mjs +13 -0
  129. package/dist/esm/components/batch-outputs/types.mjs +0 -0
  130. package/dist/esm/components/batch-variable-selector/index.mjs +19 -0
  131. package/dist/esm/components/blur-input/index.mjs +20 -0
  132. package/dist/esm/components/code-editor/editor.mjs +55 -0
  133. package/dist/esm/components/code-editor/index.mjs +5 -0
  134. package/dist/esm/components/code-editor/init-worker.mjs +19 -0
  135. package/dist/esm/components/code-editor/language-features.mjs +15 -0
  136. package/dist/esm/components/code-editor/theme/dark.mjs +154 -0
  137. package/dist/esm/components/code-editor/theme/index.mjs +5 -0
  138. package/dist/esm/components/code-editor/theme/light.mjs +161 -0
  139. package/dist/esm/components/code-editor/utils.mjs +8 -0
  140. package/dist/esm/components/code-editor-mini/index.mjs +22 -0
  141. package/dist/esm/components/condition-row/constants.mjs +128 -0
  142. package/dist/esm/components/condition-row/hooks/useOp.mjs +44 -0
  143. package/dist/esm/components/condition-row/hooks/useRule.mjs +34 -0
  144. package/dist/esm/components/condition-row/index.mjs +89 -0
  145. package/dist/esm/components/condition-row/styles.mjs +21 -0
  146. package/dist/esm/components/condition-row/types.mjs +18 -0
  147. package/dist/esm/components/constant-input/index.mjs +36 -0
  148. package/dist/esm/components/constant-input/types.mjs +0 -0
  149. package/dist/esm/components/db-condition-row/hooks/use-left.mjs +52 -0
  150. package/dist/esm/components/db-condition-row/hooks/use-op.mjs +45 -0
  151. package/dist/esm/components/db-condition-row/index.mjs +81 -0
  152. package/dist/esm/components/db-condition-row/styles.mjs +32 -0
  153. package/dist/esm/components/db-condition-row/types.mjs +0 -0
  154. package/dist/esm/components/display-flow-value/index.mjs +30 -0
  155. package/dist/esm/components/display-inputs-values/index.mjs +39 -0
  156. package/dist/esm/components/display-inputs-values/styles.mjs +7 -0
  157. package/dist/esm/components/display-outputs/index.mjs +38 -0
  158. package/dist/esm/components/display-outputs/styles.mjs +7 -0
  159. package/dist/esm/components/display-schema-tag/index.mjs +33 -0
  160. package/dist/esm/components/display-schema-tag/styles.mjs +21 -0
  161. package/dist/esm/components/display-schema-tree/index.mjs +49 -0
  162. package/dist/esm/components/display-schema-tree/styles.mjs +79 -0
  163. package/dist/esm/components/dynamic-value-input/hooks.mjs +59 -0
  164. package/dist/esm/components/dynamic-value-input/index.mjs +137 -0
  165. package/dist/esm/components/dynamic-value-input/styles.mjs +54 -0
  166. package/dist/esm/components/index.mjs +26 -0
  167. package/dist/esm/components/inputs-values/index.mjs +78 -0
  168. package/dist/esm/components/inputs-values/styles.mjs +13 -0
  169. package/dist/esm/components/inputs-values/types.mjs +0 -0
  170. package/dist/esm/components/inputs-values-tree/hooks/use-child-list.mjs +43 -0
  171. package/dist/esm/components/inputs-values-tree/index.mjs +53 -0
  172. package/dist/esm/components/inputs-values-tree/row.mjs +149 -0
  173. package/dist/esm/components/inputs-values-tree/styles.mjs +105 -0
  174. package/dist/esm/components/inputs-values-tree/types.mjs +0 -0
  175. package/dist/esm/components/json-editor-with-variables/editor.mjs +47 -0
  176. package/dist/esm/components/json-editor-with-variables/extensions/variable-tag.mjs +117 -0
  177. package/dist/esm/components/json-editor-with-variables/extensions/variable-tree.mjs +63 -0
  178. package/dist/esm/components/json-editor-with-variables/index.mjs +5 -0
  179. package/dist/esm/components/json-editor-with-variables/styles.mjs +36 -0
  180. package/dist/esm/components/json-schema-editor/default-value.mjs +20 -0
  181. package/dist/esm/components/json-schema-editor/hooks.mjs +96 -0
  182. package/dist/esm/components/json-schema-editor/index.mjs +212 -0
  183. package/dist/esm/components/json-schema-editor/styles.mjs +138 -0
  184. package/dist/esm/components/json-schema-editor/types.mjs +0 -0
  185. package/dist/esm/components/prompt-editor/editor.mjs +52 -0
  186. package/dist/esm/components/prompt-editor/extensions/jinja.mjs +39 -0
  187. package/dist/esm/components/prompt-editor/extensions/language-support.mjs +14 -0
  188. package/dist/esm/components/prompt-editor/extensions/markdown.mjs +47 -0
  189. package/dist/esm/components/prompt-editor/index.mjs +5 -0
  190. package/dist/esm/components/prompt-editor/styles.mjs +11 -0
  191. package/dist/esm/components/prompt-editor/types.mjs +1 -0
  192. package/dist/esm/components/prompt-editor-with-inputs/editor.mjs +13 -0
  193. package/dist/esm/components/prompt-editor-with-inputs/extensions/inputs-tree.mjs +67 -0
  194. package/dist/esm/components/prompt-editor-with-inputs/index.mjs +5 -0
  195. package/dist/esm/components/prompt-editor-with-inputs/inputs-picker.mjs +70 -0
  196. package/dist/esm/components/prompt-editor-with-variables/editor.mjs +15 -0
  197. package/dist/esm/components/prompt-editor-with-variables/extensions/variable-tag.mjs +117 -0
  198. package/dist/esm/components/prompt-editor-with-variables/extensions/variable-tree.mjs +69 -0
  199. package/dist/esm/components/prompt-editor-with-variables/index.mjs +5 -0
  200. package/dist/esm/components/prompt-editor-with-variables/styles.mjs +36 -0
  201. package/dist/esm/components/type-selector/index.mjs +96 -0
  202. package/dist/esm/components/variable-selector/context.mjs +16 -0
  203. package/dist/esm/components/variable-selector/index.mjs +100 -0
  204. package/dist/esm/components/variable-selector/styles.mjs +58 -0
  205. package/dist/esm/components/variable-selector/use-variable-tree.mjs +66 -0
  206. package/dist/esm/effects/auto-rename-ref/index.mjs +64 -0
  207. package/dist/esm/effects/index.mjs +8 -0
  208. package/dist/esm/effects/listen-ref-schema-change/index.mjs +23 -0
  209. package/dist/esm/effects/listen-ref-value-change/index.mjs +20 -0
  210. package/dist/esm/effects/provide-batch-input/index.mjs +30 -0
  211. package/dist/esm/effects/provide-json-schema-outputs/index.mjs +15 -0
  212. package/dist/esm/effects/sync-variable-title/index.mjs +18 -0
  213. package/dist/esm/effects/validate-when-variable-sync/index.mjs +15 -0
  214. package/dist/esm/form-plugins/batch-outputs-plugin/index.mjs +60 -0
  215. package/dist/esm/form-plugins/index.mjs +4 -0
  216. package/dist/esm/form-plugins/infer-assign-plugin/index.mjs +38 -0
  217. package/dist/esm/form-plugins/infer-inputs-plugin/index.mjs +13 -0
  218. package/dist/esm/hooks/index.mjs +2 -0
  219. package/dist/esm/hooks/use-object-list/index.mjs +102 -0
  220. package/dist/esm/index.mjs +8 -0
  221. package/dist/esm/plugins/disable-declaration-plugin/create-disable-declaration-plugin.mjs +17 -0
  222. package/dist/esm/plugins/disable-declaration-plugin/index.mjs +2 -0
  223. package/dist/esm/plugins/index.mjs +3 -0
  224. package/dist/esm/plugins/json-schema-preset/create-type-preset-plugin.mjs +15 -0
  225. package/dist/esm/plugins/json-schema-preset/index.mjs +14 -0
  226. package/dist/esm/plugins/json-schema-preset/manager.mjs +0 -0
  227. package/dist/esm/plugins/json-schema-preset/type-definition/array.mjs +15 -0
  228. package/dist/esm/plugins/json-schema-preset/type-definition/boolean.mjs +29 -0
  229. package/dist/esm/plugins/json-schema-preset/type-definition/date-time.mjs +18 -0
  230. package/dist/esm/plugins/json-schema-preset/type-definition/index.mjs +19 -0
  231. package/dist/esm/plugins/json-schema-preset/type-definition/integer.mjs +15 -0
  232. package/dist/esm/plugins/json-schema-preset/type-definition/number.mjs +15 -0
  233. package/dist/esm/plugins/json-schema-preset/type-definition/object.mjs +15 -0
  234. package/dist/esm/plugins/json-schema-preset/type-definition/string.mjs +20 -0
  235. package/dist/esm/shared/flow-value/index.mjs +2 -0
  236. package/dist/esm/shared/flow-value/schema.mjs +26 -0
  237. package/dist/esm/shared/flow-value/types.mjs +0 -0
  238. package/dist/esm/shared/flow-value/utils.mjs +108 -0
  239. package/dist/esm/shared/format-legacy-refs/index.mjs +50 -0
  240. package/dist/esm/shared/index.mjs +6 -0
  241. package/dist/esm/shared/inject-material/index.mjs +21 -0
  242. package/dist/esm/shared/lazy-suspense/index.mjs +21 -0
  243. package/dist/esm/shared/polyfill-create-root/index.mjs +16 -0
  244. package/dist/esm/validate/index.mjs +2 -0
  245. package/dist/esm/validate/validate-flow-value/index.mjs +29 -0
  246. package/dist/tsconfig.tsbuildinfo +1 -0
  247. package/dist/types/components/assign-row/index.d.ts +8 -0
  248. package/dist/types/components/assign-row/types.d.ts +20 -0
  249. package/dist/types/components/assign-rows/index.d.ts +11 -0
  250. package/dist/types/components/batch-outputs/index.d.ts +7 -0
  251. package/dist/types/components/batch-outputs/styles.d.ts +6 -0
  252. package/dist/types/components/batch-outputs/types.d.ts +18 -0
  253. package/dist/types/components/batch-variable-selector/index.d.ts +7 -0
  254. package/dist/types/components/blur-input/index.d.ts +7 -0
  255. package/dist/types/components/code-editor/editor.d.ts +23 -0
  256. package/dist/types/components/code-editor/index.d.ts +6 -0
  257. package/{src/validate/index.tsx → dist/types/components/code-editor/init-worker.d.ts} +1 -2
  258. package/{src/typings/index.ts → dist/types/components/code-editor/language-features.d.ts} +1 -2
  259. package/dist/types/components/code-editor/theme/dark.d.ts +6 -0
  260. package/{src/hooks/index.tsx → dist/types/components/code-editor/theme/index.d.ts} +1 -2
  261. package/dist/types/components/code-editor/theme/light.d.ts +6 -0
  262. package/dist/types/components/code-editor/utils.d.ts +5 -0
  263. package/dist/types/components/code-editor-mini/index.d.ts +7 -0
  264. package/dist/types/components/condition-row/constants.d.ts +7 -0
  265. package/dist/types/components/condition-row/hooks/useOp.d.ts +18 -0
  266. package/dist/types/components/condition-row/hooks/useRule.d.ts +9 -0
  267. package/dist/types/components/condition-row/index.d.ts +22 -0
  268. package/dist/types/components/condition-row/styles.d.ts +9 -0
  269. package/dist/types/components/condition-row/types.d.ts +34 -0
  270. package/dist/types/components/constant-input/index.d.ts +8 -0
  271. package/dist/types/components/constant-input/types.d.ts +16 -0
  272. package/dist/types/components/db-condition-row/hooks/use-left.d.ts +18 -0
  273. package/dist/types/components/db-condition-row/hooks/use-op.d.ts +18 -0
  274. package/dist/types/components/db-condition-row/index.d.ts +19 -0
  275. package/dist/types/components/db-condition-row/styles.d.ts +12 -0
  276. package/dist/types/components/db-condition-row/types.d.ts +25 -0
  277. package/dist/types/components/display-flow-value/index.d.ts +15 -0
  278. package/dist/types/components/display-inputs-values/index.d.ts +14 -0
  279. package/dist/types/components/display-inputs-values/styles.d.ts +5 -0
  280. package/dist/types/components/display-outputs/index.d.ts +14 -0
  281. package/dist/types/components/display-outputs/styles.d.ts +5 -0
  282. package/dist/types/components/display-schema-tag/index.d.ts +14 -0
  283. package/dist/types/components/display-schema-tag/styles.d.ts +8 -0
  284. package/dist/types/components/display-schema-tree/index.d.ts +16 -0
  285. package/dist/types/components/display-schema-tree/styles.d.ts +11 -0
  286. package/dist/types/components/dynamic-value-input/hooks.d.ts +28 -0
  287. package/dist/types/components/dynamic-value-input/index.d.ts +27 -0
  288. package/dist/types/components/dynamic-value-input/styles.d.ts +8 -0
  289. package/dist/types/components/index.d.ts +29 -0
  290. package/dist/types/components/inputs-values/index.d.ts +7 -0
  291. package/dist/types/components/inputs-values/styles.d.ts +6 -0
  292. package/dist/types/components/inputs-values/types.d.ts +19 -0
  293. package/dist/types/components/inputs-values-tree/hooks/use-child-list.d.ts +19 -0
  294. package/dist/types/components/inputs-values-tree/index.d.ts +7 -0
  295. package/dist/types/components/inputs-values-tree/row.d.ts +15 -0
  296. package/dist/types/components/inputs-values-tree/styles.d.ts +23 -0
  297. package/dist/types/components/inputs-values-tree/types.d.ts +18 -0
  298. package/dist/types/components/json-editor-with-variables/editor.d.ts +9 -0
  299. package/dist/types/components/json-editor-with-variables/extensions/variable-tag.d.ts +5 -0
  300. package/dist/types/components/json-editor-with-variables/extensions/variable-tree.d.ts +6 -0
  301. package/dist/types/components/json-editor-with-variables/index.d.ts +6 -0
  302. package/dist/types/components/json-editor-with-variables/styles.d.ts +9 -0
  303. package/dist/types/components/json-schema-editor/default-value.d.ts +17 -0
  304. package/dist/types/components/json-schema-editor/hooks.d.ts +12 -0
  305. package/dist/types/components/json-schema-editor/index.d.ts +14 -0
  306. package/dist/types/components/json-schema-editor/styles.d.ts +30 -0
  307. package/dist/types/components/json-schema-editor/types.d.ts +20 -0
  308. package/dist/types/components/prompt-editor/editor.d.ts +15 -0
  309. package/dist/types/components/prompt-editor/extensions/jinja.d.ts +6 -0
  310. package/dist/types/components/prompt-editor/extensions/language-support.d.ts +6 -0
  311. package/dist/types/components/prompt-editor/extensions/markdown.d.ts +6 -0
  312. package/dist/types/components/prompt-editor/index.d.ts +6 -0
  313. package/dist/types/components/prompt-editor/styles.d.ts +7 -0
  314. package/dist/types/components/prompt-editor/types.d.ts +16 -0
  315. package/dist/types/components/prompt-editor-with-inputs/editor.d.ts +10 -0
  316. package/dist/types/components/prompt-editor-with-inputs/extensions/inputs-tree.d.ts +9 -0
  317. package/dist/types/components/prompt-editor-with-inputs/index.d.ts +6 -0
  318. package/dist/types/components/prompt-editor-with-inputs/inputs-picker.d.ts +9 -0
  319. package/dist/types/components/prompt-editor-with-variables/editor.d.ts +9 -0
  320. package/dist/types/components/prompt-editor-with-variables/extensions/variable-tag.d.ts +5 -0
  321. package/dist/types/components/prompt-editor-with-variables/extensions/variable-tree.d.ts +6 -0
  322. package/dist/types/components/prompt-editor-with-variables/index.d.ts +6 -0
  323. package/dist/types/components/prompt-editor-with-variables/styles.d.ts +9 -0
  324. package/dist/types/components/type-selector/index.d.ts +23 -0
  325. package/dist/types/components/variable-selector/context.d.ts +16 -0
  326. package/dist/types/components/variable-selector/index.d.ts +29 -0
  327. package/dist/types/components/variable-selector/styles.d.ts +14 -0
  328. package/dist/types/components/variable-selector/use-variable-tree.d.ts +18 -0
  329. package/dist/types/effects/auto-rename-ref/index.d.ts +17 -0
  330. package/dist/types/effects/index.d.ts +11 -0
  331. package/dist/types/effects/listen-ref-schema-change/index.d.ts +22 -0
  332. package/dist/types/effects/listen-ref-value-change/index.d.ts +22 -0
  333. package/dist/types/effects/provide-batch-input/index.d.ts +6 -0
  334. package/dist/types/effects/provide-json-schema-outputs/index.d.ts +6 -0
  335. package/dist/types/effects/sync-variable-title/index.d.ts +6 -0
  336. package/dist/types/effects/validate-when-variable-sync/index.d.ts +8 -0
  337. package/dist/types/form-plugins/batch-outputs-plugin/index.d.ts +12 -0
  338. package/dist/types/form-plugins/index.d.ts +7 -0
  339. package/dist/types/form-plugins/infer-assign-plugin/index.d.ts +10 -0
  340. package/dist/types/form-plugins/infer-inputs-plugin/index.d.ts +11 -0
  341. package/dist/types/hooks/index.d.ts +5 -0
  342. package/dist/types/hooks/use-object-list/index.d.ts +22 -0
  343. package/dist/types/index.d.ts +11 -0
  344. package/dist/types/plugins/disable-declaration-plugin/create-disable-declaration-plugin.d.ts +5 -0
  345. package/dist/types/plugins/disable-declaration-plugin/index.d.ts +5 -0
  346. package/dist/types/plugins/index.d.ts +6 -0
  347. package/dist/types/plugins/json-schema-preset/create-type-preset-plugin.d.ts +9 -0
  348. package/dist/types/plugins/json-schema-preset/index.d.ts +13 -0
  349. package/dist/types/plugins/json-schema-preset/manager.d.ts +17 -0
  350. package/dist/types/plugins/json-schema-preset/type-definition/array.d.ts +6 -0
  351. package/dist/types/plugins/json-schema-preset/type-definition/boolean.d.ts +6 -0
  352. package/dist/types/plugins/json-schema-preset/type-definition/date-time.d.ts +6 -0
  353. package/dist/types/plugins/json-schema-preset/type-definition/index.d.ts +5 -0
  354. package/dist/types/plugins/json-schema-preset/type-definition/integer.d.ts +6 -0
  355. package/dist/types/plugins/json-schema-preset/type-definition/number.d.ts +6 -0
  356. package/dist/types/plugins/json-schema-preset/type-definition/object.d.ts +6 -0
  357. package/dist/types/plugins/json-schema-preset/type-definition/string.d.ts +6 -0
  358. package/dist/types/shared/flow-value/index.d.ts +6 -0
  359. package/dist/types/shared/flow-value/schema.d.ts +107 -0
  360. package/dist/types/shared/flow-value/types.d.ts +32 -0
  361. package/dist/types/shared/flow-value/utils.d.ts +65 -0
  362. package/dist/types/shared/format-legacy-refs/index.d.ts +84 -0
  363. package/dist/types/shared/index.d.ts +9 -0
  364. package/dist/types/shared/inject-material/index.d.ts +46 -0
  365. package/dist/types/shared/lazy-suspense/index.d.ts +7 -0
  366. package/dist/types/shared/polyfill-create-root/index.d.ts +10 -0
  367. package/dist/types/validate/index.d.ts +5 -0
  368. package/dist/types/validate/validate-flow-value/index.d.ts +19 -0
  369. package/package.json +22 -23
  370. package/src/components/assign-row/index.tsx +3 -3
  371. package/src/components/assign-row/types.ts +1 -1
  372. package/src/components/batch-outputs/index.tsx +3 -2
  373. package/src/components/batch-outputs/types.ts +1 -1
  374. package/src/components/code-editor/editor.tsx +97 -0
  375. package/src/components/code-editor/index.tsx +5 -89
  376. package/src/components/code-editor/init-worker.ts +27 -0
  377. package/src/components/code-editor/language-features.ts +6 -27
  378. package/src/components/code-editor/theme/dark.ts +50 -31
  379. package/src/components/code-editor/theme/index.ts +1 -1
  380. package/src/components/code-editor/theme/light.ts +57 -33
  381. package/src/components/code-editor-mini/index.tsx +2 -2
  382. package/src/components/condition-row/constants.ts +8 -0
  383. package/src/components/condition-row/hooks/useRule.ts +1 -1
  384. package/src/components/condition-row/index.tsx +4 -0
  385. package/src/components/condition-row/types.ts +1 -1
  386. package/src/components/constant-input/index.tsx +1 -1
  387. package/src/components/db-condition-row/hooks/use-left.tsx +66 -0
  388. package/src/components/db-condition-row/hooks/use-op.tsx +59 -0
  389. package/src/components/db-condition-row/index.tsx +93 -0
  390. package/src/components/db-condition-row/styles.tsx +43 -0
  391. package/src/components/db-condition-row/types.ts +34 -0
  392. package/src/components/display-flow-value/index.tsx +3 -13
  393. package/src/components/display-inputs-values/index.tsx +44 -6
  394. package/src/components/dynamic-value-input/hooks.ts +25 -4
  395. package/src/components/dynamic-value-input/index.tsx +21 -12
  396. package/src/components/dynamic-value-input/styles.tsx +14 -4
  397. package/src/components/index.ts +50 -22
  398. package/src/components/inputs-values/index.tsx +15 -4
  399. package/src/components/inputs-values/styles.tsx +1 -1
  400. package/src/components/inputs-values/types.ts +1 -1
  401. package/src/components/inputs-values-tree/hooks/use-child-list.tsx +76 -0
  402. package/src/components/inputs-values-tree/index.tsx +62 -0
  403. package/src/components/inputs-values-tree/row.tsx +177 -0
  404. package/src/components/inputs-values-tree/styles.tsx +128 -0
  405. package/src/components/inputs-values-tree/types.ts +21 -0
  406. package/src/components/json-editor-with-variables/editor.tsx +69 -0
  407. package/src/components/json-editor-with-variables/extensions/variable-tag.tsx +7 -6
  408. package/src/components/json-editor-with-variables/extensions/variable-tree.tsx +3 -3
  409. package/src/components/json-editor-with-variables/index.tsx +5 -59
  410. package/src/components/json-schema-editor/default-value.tsx +1 -3
  411. package/src/components/json-schema-editor/hooks.tsx +14 -3
  412. package/src/components/json-schema-editor/index.tsx +18 -58
  413. package/src/components/json-schema-editor/styles.tsx +12 -55
  414. package/src/components/json-schema-editor/types.ts +0 -1
  415. package/src/components/prompt-editor/editor.tsx +81 -0
  416. package/src/components/prompt-editor/extensions/jinja.tsx +2 -2
  417. package/src/components/prompt-editor/extensions/language-support.tsx +2 -2
  418. package/src/components/prompt-editor/extensions/markdown.tsx +2 -2
  419. package/src/components/prompt-editor/index.tsx +5 -62
  420. package/src/components/prompt-editor/types.tsx +1 -1
  421. package/src/components/prompt-editor-with-inputs/editor.tsx +25 -0
  422. package/src/components/prompt-editor-with-inputs/extensions/inputs-tree.tsx +15 -4
  423. package/src/components/prompt-editor-with-inputs/index.tsx +5 -16
  424. package/src/components/prompt-editor-with-inputs/inputs-picker.tsx +34 -17
  425. package/src/components/prompt-editor-with-variables/editor.tsx +22 -0
  426. package/src/components/prompt-editor-with-variables/extensions/variable-tag.tsx +13 -21
  427. package/src/components/prompt-editor-with-variables/extensions/variable-tree.tsx +16 -4
  428. package/src/components/prompt-editor-with-variables/index.tsx +5 -13
  429. package/src/components/type-selector/index.tsx +12 -2
  430. package/src/components/variable-selector/context.tsx +28 -0
  431. package/src/components/variable-selector/index.tsx +10 -1
  432. package/src/components/variable-selector/use-variable-tree.tsx +3 -3
  433. package/src/effects/auto-rename-ref/index.ts +8 -55
  434. package/src/effects/index.ts +7 -7
  435. package/src/effects/listen-ref-schema-change/index.ts +1 -1
  436. package/src/effects/listen-ref-value-change/index.ts +1 -1
  437. package/src/effects/provide-batch-input/index.ts +1 -1
  438. package/src/effects/validate-when-variable-sync/index.ts +1 -1
  439. package/src/form-plugins/batch-outputs-plugin/index.ts +1 -1
  440. package/src/form-plugins/index.ts +3 -3
  441. package/src/form-plugins/infer-assign-plugin/index.ts +2 -2
  442. package/src/form-plugins/infer-inputs-plugin/index.ts +4 -76
  443. package/src/hooks/index.ts +6 -0
  444. package/src/hooks/use-object-list/index.tsx +35 -7
  445. package/src/index.ts +98 -7
  446. package/src/plugins/index.ts +11 -2
  447. package/src/plugins/json-schema-preset/index.tsx +4 -4
  448. package/src/plugins/json-schema-preset/manager.ts +1 -0
  449. package/src/plugins/json-schema-preset/type-definition/date-time.tsx +25 -0
  450. package/src/plugins/json-schema-preset/type-definition/index.tsx +2 -0
  451. package/src/plugins/json-schema-preset/type-definition/string.tsx +18 -9
  452. package/src/shared/flow-value/index.ts +16 -0
  453. package/src/shared/flow-value/schema.ts +38 -0
  454. package/src/{typings/flow-value/index.ts → shared/flow-value/types.ts} +3 -1
  455. package/src/shared/flow-value/utils.ts +200 -0
  456. package/src/shared/format-legacy-refs/index.ts +1 -1
  457. package/src/shared/index.ts +26 -2
  458. package/src/shared/lazy-suspense/index.tsx +28 -0
  459. package/src/shared/polyfill-create-root/index.tsx +33 -0
  460. package/src/validate/index.ts +6 -0
  461. package/src/validate/validate-flow-value/index.tsx +4 -16
  462. package/bin/index.ts +0 -91
  463. package/bin/materials.ts +0 -107
  464. package/bin/project.ts +0 -95
  465. package/bin/utils/import.ts +0 -127
  466. package/bin/utils/traverse-file.ts +0 -60
  467. package/dist/esm/index.js +0 -3864
  468. package/dist/esm/index.js.map +0 -1
  469. package/dist/index.d.mts +0 -763
  470. package/dist/index.d.ts +0 -763
  471. package/dist/index.js +0 -3849
  472. package/dist/index.js.map +0 -1
  473. package/src/components/inputs-values/components/blur-input.tsx +0 -27
  474. package/src/components/json-schema-editor/components/blur-input.tsx +0 -27
  475. package/src/plugins/disable-declaration-plugin/config.json +0 -5
  476. package/src/plugins/json-schema-preset/config.json +0 -9
  477. /package/src/components/{assign-row/components/blur-input.tsx → blur-input/index.tsx} +0 -0
@@ -0,0 +1,46 @@
1
+ /**
2
+ * Copyright (c) 2025 Bytedance Ltd. and/or its affiliates
3
+ * SPDX-License-Identifier: MIT
4
+ */
5
+ import React from 'react';
6
+ /**
7
+ * Creates a material component wrapper with dependency injection support
8
+ *
9
+ * This Higher-Order Component (HOC) implements a dynamic component replacement mechanism
10
+ * for material components. It automatically checks if a custom renderer is registered
11
+ * in the editor context, using the injected component if available, otherwise
12
+ * falling back to the default component.
13
+ *
14
+ * @example
15
+ * ```tsx
16
+ * // 1.Create an injectable material component
17
+ * const InjectVariableSelector = createInjectMaterial(VariableSelector)
18
+ *
19
+ * // 2. Register custom components in editor
20
+ * // Configure in use-editor-props.tsx:
21
+ * const editorProps = {
22
+ * materials: {
23
+ * components: {
24
+ * [VariableSelector.renderKey]: YourCustomVariableSelector
25
+ * }
26
+ * }
27
+ * }
28
+ * ```
29
+ *
30
+ * @description
31
+ * Data flow explanation:
32
+ * - Register components to FlowRendererRegistry in use-editor-props
33
+ * - InjectMaterial reads renderers from FlowRendererRegistry
34
+ * - If registered renderer exists and type is REACT, use injected component
35
+ * - If not exists or type mismatch, fallback to default component
36
+ *
37
+ * @param Component - Default React component
38
+ * @param params - Optional parameters
39
+ * @param params.renderKey - Custom render key name, highest priority
40
+ * @returns Wrapper component with dependency injection support
41
+ */
42
+ export declare function createInjectMaterial<Props>(Component: React.FC<Props> & {
43
+ renderKey?: string;
44
+ }, params?: {
45
+ renderKey?: string;
46
+ }): React.FC<Props>;
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Copyright (c) 2025 Bytedance Ltd. and/or its affiliates
3
+ * SPDX-License-Identifier: MIT
4
+ */
5
+ import React, { ComponentType, lazy } from 'react';
6
+ export declare function withSuspense<T extends ComponentType<any>>(Component: T, fallback?: React.ReactNode): T;
7
+ export declare function lazySuspense<T extends ComponentType<any>>(params: Parameters<typeof lazy<T>>[0], fallback?: React.ReactNode): React.LazyExoticComponent<T>;
@@ -0,0 +1,10 @@
1
+ /**
2
+ * Copyright (c) 2025 Bytedance Ltd. and/or its affiliates
3
+ * SPDX-License-Identifier: MIT
4
+ */
5
+ export interface IPolyfillRoot {
6
+ render(children: React.ReactNode): void;
7
+ unmount(): void;
8
+ }
9
+ export declare function polyfillCreateRoot(dom: HTMLElement): IPolyfillRoot;
10
+ export declare function unstableSetCreateRoot(createRoot: (dom: HTMLElement) => IPolyfillRoot): void;
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Copyright (c) 2025 Bytedance Ltd. and/or its affiliates
3
+ * SPDX-License-Identifier: MIT
4
+ */
5
+ export { validateFlowValue } from './validate-flow-value';
@@ -0,0 +1,19 @@
1
+ /**
2
+ * Copyright (c) 2025 Bytedance Ltd. and/or its affiliates
3
+ * SPDX-License-Identifier: MIT
4
+ */
5
+ import { FeedbackLevel, FlowNodeEntity } from '@flowgram.ai/editor';
6
+ import { IFlowValue } from '../../shared';
7
+ interface Context {
8
+ node: FlowNodeEntity;
9
+ required?: boolean;
10
+ errorMessages?: {
11
+ required?: string;
12
+ unknownVariable?: string;
13
+ };
14
+ }
15
+ export declare function validateFlowValue(value: IFlowValue | undefined, ctx: Context): {
16
+ level: FeedbackLevel;
17
+ message: string;
18
+ } | undefined;
19
+ export {};
package/package.json CHANGED
@@ -1,19 +1,19 @@
1
1
  {
2
2
  "name": "@flowgram.ai/form-materials",
3
- "version": "0.1.0-alpha.13",
3
+ "version": "0.1.0-alpha.15",
4
4
  "homepage": "https://flowgram.ai/",
5
5
  "repository": "https://github.com/bytedance/flowgram.ai",
6
6
  "license": "MIT",
7
7
  "exports": {
8
- "types": "./dist/index.d.ts",
9
- "import": "./dist/esm/index.js",
10
- "require": "./dist/index.js"
8
+ "types": "./dist/types/index.d.ts",
9
+ "import": "./dist/esm/index.mjs",
10
+ "require": "./dist/cjs/index.js"
11
11
  },
12
- "main": "./dist/index.js",
13
- "module": "./dist/esm/index.js",
14
- "types": "./dist/index.d.ts",
12
+ "main": "./dist/cjs/index.js",
13
+ "module": "./dist/esm/index.mjs",
14
+ "types": "./dist/types/index.d.ts",
15
15
  "bin": {
16
- "flowgram-form-materials": "./bin/index.ts"
16
+ "flowgram-form-materials": "./bin/run.sh"
17
17
  },
18
18
  "files": [
19
19
  "dist",
@@ -24,21 +24,18 @@
24
24
  "@douyinfe/semi-icons": "^2.80.0",
25
25
  "@douyinfe/semi-illustrations": "^2.80.0",
26
26
  "@douyinfe/semi-ui": "^2.80.0",
27
- "lodash": "^4.17.21",
27
+ "lodash-es": "^4.17.21",
28
28
  "nanoid": "^4.0.2",
29
- "commander": "^11.0.0",
30
- "chalk": "^5.3.0",
31
- "inquirer": "^9.2.7",
32
29
  "immer": "~10.1.1",
33
- "@coze-editor/editor": "0.1.0-alpha.879fbb",
34
30
  "@codemirror/view": "~6.38.0",
35
31
  "@codemirror/state": "~6.5.2",
36
- "typescript": "^5.8.3",
37
- "@flowgram.ai/editor": "0.1.0-alpha.13",
38
- "@flowgram.ai/json-schema": "0.1.0-alpha.13"
32
+ "zod": "^3.24.4",
33
+ "@flowgram.ai/json-schema": "0.1.0-alpha.15",
34
+ "@flowgram.ai/coze-editor": "0.1.0-alpha.15",
35
+ "@flowgram.ai/editor": "0.1.0-alpha.15"
39
36
  },
40
37
  "devDependencies": {
41
- "@types/lodash": "^4.14.137",
38
+ "@types/lodash-es": "^4.17.12",
42
39
  "@types/node": "^18",
43
40
  "@types/react": "^18",
44
41
  "@types/react-dom": "^18",
@@ -48,11 +45,12 @@
48
45
  "react": "^18",
49
46
  "react-dom": "^18",
50
47
  "styled-components": "^5",
51
- "tsup": "^8.0.1",
52
48
  "typescript": "^5.8.3",
53
49
  "vitest": "^0.34.6",
54
- "@flowgram.ai/eslint-config": "0.1.0-alpha.13",
55
- "@flowgram.ai/ts-config": "0.1.0-alpha.13"
50
+ "@rslib/core": "~0.12.4",
51
+ "@rsbuild/plugin-react": "^1.1.1",
52
+ "@flowgram.ai/ts-config": "0.1.0-alpha.15",
53
+ "@flowgram.ai/eslint-config": "0.1.0-alpha.15"
56
54
  },
57
55
  "peerDependencies": {
58
56
  "react": ">=16.8",
@@ -64,9 +62,10 @@
64
62
  "registry": "https://registry.npmjs.org/"
65
63
  },
66
64
  "scripts": {
67
- "build": "npm run build:fast -- --dts-resolve",
68
- "build:fast": "tsup src/index.ts --format cjs,esm --sourcemap --legacy-output",
69
- "build:watch": "npm run build:fast -- --dts-resolve",
65
+ "build": "rslib build",
66
+ "build:fast": "rslib build",
67
+ "build:watch": "rslib build",
68
+ "name-export": "node scripts/name-export.js",
70
69
  "clean": "rimraf dist",
71
70
  "test": "exit 0",
72
71
  "test:cov": "exit 0",
@@ -8,12 +8,12 @@ import React from 'react';
8
8
  import { IconButton } from '@douyinfe/semi-ui';
9
9
  import { IconMinus } from '@douyinfe/semi-icons';
10
10
 
11
- import { IFlowConstantRefValue } from '@/typings';
11
+ import { IFlowConstantRefValue } from '@/shared';
12
12
  import { InjectVariableSelector } from '@/components/variable-selector';
13
13
  import { InjectDynamicValueInput } from '@/components/dynamic-value-input';
14
+ import { BlurInput } from '@/components/blur-input';
14
15
 
15
16
  import { AssignRowProps } from './types';
16
- import { BlurInput } from './components/blur-input';
17
17
 
18
18
  export function AssignRow(props: AssignRowProps) {
19
19
  const {
@@ -81,4 +81,4 @@ export function AssignRow(props: AssignRowProps) {
81
81
  );
82
82
  }
83
83
 
84
- export { AssignValueType } from './types';
84
+ export { type AssignValueType } from './types';
@@ -3,7 +3,7 @@
3
3
  * SPDX-License-Identifier: MIT
4
4
  */
5
5
 
6
- import { IFlowRefValue, IFlowValue } from '@/typings';
6
+ import { IFlowRefValue, IFlowValue } from '@/shared';
7
7
 
8
8
  export type AssignValueType =
9
9
  | {
@@ -5,6 +5,7 @@
5
5
 
6
6
  import React from 'react';
7
7
 
8
+ import { I18n } from '@flowgram.ai/editor';
8
9
  import { Button, Input } from '@douyinfe/semi-ui';
9
10
  import { IconDelete, IconPlus } from '@douyinfe/semi-icons';
10
11
 
@@ -46,8 +47,8 @@ export function BatchOutputs(props: PropsType) {
46
47
  </UIRow>
47
48
  ))}
48
49
  </UIRows>
49
- <Button disabled={readonly} icon={<IconPlus />} size="small" onClick={add}>
50
- Add
50
+ <Button disabled={readonly} icon={<IconPlus />} size="small" onClick={() => add()}>
51
+ {I18n.t('Add')}
51
52
  </Button>
52
53
  </div>
53
54
  );
@@ -3,7 +3,7 @@
3
3
  * SPDX-License-Identifier: MIT
4
4
  */
5
5
 
6
- import { IFlowRefValue } from '@/typings';
6
+ import { IFlowRefValue } from '@/shared';
7
7
 
8
8
  export type ValueType = Record<string, IFlowRefValue | undefined>;
9
9
 
@@ -0,0 +1,97 @@
1
+ /**
2
+ * Copyright (c) 2025 Bytedance Ltd. and/or its affiliates
3
+ * SPDX-License-Identifier: MIT
4
+ */
5
+
6
+ import React, { useEffect, useRef } from 'react';
7
+
8
+ import {
9
+ ActiveLinePlaceholder,
10
+ createRenderer,
11
+ EditorProvider,
12
+ InferValues,
13
+ } from '@flowgram.ai/coze-editor/react';
14
+ import preset, { type EditorAPI } from '@flowgram.ai/coze-editor/preset-code';
15
+ import { EditorView } from '@codemirror/view';
16
+
17
+ import { getSuffixByLanguageId } from './utils';
18
+
19
+ import './theme';
20
+ import './language-features';
21
+
22
+ const OriginCodeEditor = createRenderer(preset, [
23
+ EditorView.theme({
24
+ '&.cm-focused': {
25
+ outline: 'none',
26
+ },
27
+ }),
28
+ ]);
29
+
30
+ type Preset = typeof preset;
31
+ type Options = Partial<InferValues<Preset[number]>>;
32
+
33
+ export interface CodeEditorPropsType extends React.PropsWithChildren<{}> {
34
+ value?: string;
35
+ onChange?: (value: string) => void;
36
+ languageId: 'python' | 'typescript' | 'shell' | 'json';
37
+ theme?: 'dark' | 'light';
38
+ placeholder?: string;
39
+ activeLinePlaceholder?: string;
40
+ readonly?: boolean;
41
+ options?: Options;
42
+ }
43
+
44
+ export function CodeEditor({
45
+ value,
46
+ onChange,
47
+ languageId = 'python',
48
+ theme = 'light',
49
+ children,
50
+ placeholder,
51
+ activeLinePlaceholder,
52
+ options,
53
+ readonly,
54
+ }: CodeEditorPropsType) {
55
+ const editorRef = useRef<EditorAPI | null>(null);
56
+
57
+ useEffect(() => {
58
+ // listen to value change
59
+ if (editorRef.current?.getValue() !== value) {
60
+ editorRef.current?.setValue(String(value || ''));
61
+ }
62
+ }, [value]);
63
+
64
+ useEffect(() => {
65
+ if (languageId === 'typescript') {
66
+ import('./init-worker').then((module) => {
67
+ module.initTsWorker();
68
+ });
69
+ }
70
+ }, [languageId]);
71
+
72
+ return (
73
+ <EditorProvider>
74
+ <OriginCodeEditor
75
+ defaultValue={String(value || '')}
76
+ options={{
77
+ uri: `file:///untitled${getSuffixByLanguageId(languageId)}`,
78
+ languageId,
79
+ theme,
80
+ placeholder,
81
+ readOnly: readonly,
82
+ editable: !readonly,
83
+ ...(options || {}),
84
+ }}
85
+ didMount={(editor: EditorAPI) => {
86
+ editorRef.current = editor;
87
+ }}
88
+ onChange={(e) => onChange?.(e.value)}
89
+ >
90
+ {activeLinePlaceholder && (
91
+ <ActiveLinePlaceholder>{activeLinePlaceholder}</ActiveLinePlaceholder>
92
+ )}
93
+ {children}
94
+ </OriginCodeEditor>
95
+ </EditorProvider>
96
+ );
97
+ }
@@ -3,94 +3,10 @@
3
3
  * SPDX-License-Identifier: MIT
4
4
  */
5
5
 
6
- import React, { useEffect, useRef } from 'react';
6
+ import { lazySuspense } from '@/shared';
7
7
 
8
- import {
9
- ActiveLinePlaceholder,
10
- createRenderer,
11
- EditorProvider,
12
- InferValues,
13
- } from '@coze-editor/editor/react';
14
- import preset, { type EditorAPI } from '@coze-editor/editor/preset-code';
15
- import { EditorView } from '@codemirror/view';
8
+ export const CodeEditor = lazySuspense(() =>
9
+ import('./editor').then((module) => ({ default: module.CodeEditor }))
10
+ );
16
11
 
17
- import { getSuffixByLanguageId } from './utils';
18
- import { initTsWorker } from './language-features';
19
-
20
- import './theme';
21
- import './language-features';
22
-
23
- const OriginCodeEditor = createRenderer(preset, [
24
- EditorView.theme({
25
- '&.cm-focused': {
26
- outline: 'none',
27
- },
28
- }),
29
- ]);
30
-
31
- type Preset = typeof preset;
32
- type Options = Partial<InferValues<Preset[number]>>;
33
-
34
- export interface CodeEditorPropsType extends React.PropsWithChildren<{}> {
35
- value?: string;
36
- onChange?: (value: string) => void;
37
- languageId: 'python' | 'typescript' | 'shell' | 'json';
38
- theme?: 'dark' | 'light';
39
- placeholder?: string;
40
- activeLinePlaceholder?: string;
41
- readonly?: boolean;
42
- options?: Options;
43
- }
44
-
45
- export function CodeEditor({
46
- value,
47
- onChange,
48
- languageId = 'python',
49
- theme = 'light',
50
- children,
51
- placeholder,
52
- activeLinePlaceholder,
53
- options,
54
- readonly,
55
- }: CodeEditorPropsType) {
56
- const editorRef = useRef<EditorAPI | null>(null);
57
-
58
- useEffect(() => {
59
- if (languageId === 'typescript') {
60
- initTsWorker();
61
- }
62
- }, [languageId]);
63
-
64
- useEffect(() => {
65
- // listen to value change
66
- if (editorRef.current?.getValue() !== value) {
67
- editorRef.current?.setValue(String(value || ''));
68
- }
69
- }, [value]);
70
-
71
- return (
72
- <EditorProvider>
73
- <OriginCodeEditor
74
- defaultValue={value}
75
- options={{
76
- uri: `file:///untitled${getSuffixByLanguageId(languageId)}`,
77
- languageId,
78
- theme,
79
- placeholder,
80
- readOnly: readonly,
81
- editable: !readonly,
82
- ...(options || {}),
83
- }}
84
- didMount={(editor: EditorAPI) => {
85
- editorRef.current = editor;
86
- }}
87
- onChange={(e) => onChange?.(e.value)}
88
- >
89
- {activeLinePlaceholder && (
90
- <ActiveLinePlaceholder>{activeLinePlaceholder}</ActiveLinePlaceholder>
91
- )}
92
- {children}
93
- </OriginCodeEditor>
94
- </EditorProvider>
95
- );
96
- }
12
+ export type { CodeEditorPropsType } from './editor';
@@ -0,0 +1,27 @@
1
+ /**
2
+ * Copyright (c) 2025 Bytedance Ltd. and/or its affiliates
3
+ * SPDX-License-Identifier: MIT
4
+ */
5
+
6
+ import { typescript } from '@flowgram.ai/coze-editor/language-typescript';
7
+
8
+ let tsWorkerInit = false;
9
+
10
+ export const initTsWorker = () => {
11
+ if (tsWorkerInit) {
12
+ return;
13
+ }
14
+ tsWorkerInit = true;
15
+
16
+ const tsWorker = new Worker(
17
+ new URL(`@flowgram.ai/coze-editor/language-typescript/worker`, import.meta.url),
18
+ { type: 'module' }
19
+ );
20
+ typescript.languageService.initialize(tsWorker, {
21
+ compilerOptions: {
22
+ // eliminate Promise error
23
+ lib: ['es2015', 'dom'],
24
+ noImplicitAny: false,
25
+ },
26
+ });
27
+ };
@@ -3,12 +3,12 @@
3
3
  * SPDX-License-Identifier: MIT
4
4
  */
5
5
 
6
- import { languages } from '@coze-editor/editor/preset-code';
7
- import { typescript } from '@coze-editor/editor/language-typescript';
8
- import { shell } from '@coze-editor/editor/language-shell';
9
- import { python } from '@coze-editor/editor/language-python';
10
- import { json } from '@coze-editor/editor/language-json';
11
- import { mixLanguages } from '@coze-editor/editor';
6
+ import { languages } from '@flowgram.ai/coze-editor/preset-code';
7
+ import { typescript } from '@flowgram.ai/coze-editor/language-typescript';
8
+ import { shell } from '@flowgram.ai/coze-editor/language-shell';
9
+ import { python } from '@flowgram.ai/coze-editor/language-python';
10
+ import { json } from '@flowgram.ai/coze-editor/language-json';
11
+ import { mixLanguages } from '@flowgram.ai/coze-editor';
12
12
 
13
13
  languages.register('python', python);
14
14
  languages.register('shell', shell);
@@ -21,24 +21,3 @@ languages.register('json', {
21
21
  }),
22
22
  languageService: json.languageService,
23
23
  });
24
-
25
- let tsWorkerInit = false;
26
-
27
- export const initTsWorker = () => {
28
- if (tsWorkerInit) {
29
- return;
30
- }
31
- tsWorkerInit = true;
32
-
33
- const tsWorker = new Worker(
34
- new URL(`@coze-editor/editor/language-typescript/worker`, import.meta.url),
35
- { type: 'module' }
36
- );
37
- typescript.languageService.initialize(tsWorker, {
38
- compilerOptions: {
39
- // eliminate Promise error
40
- lib: ['es2015', 'dom'],
41
- noImplicitAny: false,
42
- },
43
- });
44
- };
@@ -3,59 +3,60 @@
3
3
  * SPDX-License-Identifier: MIT
4
4
  */
5
5
 
6
- import { createTheme, tags as t } from '@coze-editor/editor/preset-code';
6
+ import { createTheme, tags as t } from '@flowgram.ai/coze-editor/preset-code';
7
7
  import { type Extension } from '@codemirror/state';
8
8
 
9
9
  const colors = {
10
- background: '#151B27',
11
- // syntax
12
- comment: '#FFFFFF63',
13
- key: '#39E5D7',
14
- string: '#FF94D2',
15
- number: '#FF9933',
16
- boolean: '#78B0FF',
17
- null: '#78B0FF',
18
- separator: '#FFFFFFC9',
10
+ background: '#0D1117',
11
+ // syntax - 现代化暗色主题配色
12
+ comment: '#8B949E',
13
+ key: '#7DD3FC',
14
+ variable: '#F472B6',
15
+ string: '#34D399',
16
+ number: '#FBBF24',
17
+ boolean: '#A78BFA',
18
+ null: '#A78BFA',
19
+ separator: '#E6EDF3',
19
20
  };
20
21
 
21
22
  export const darkTheme: Extension = createTheme({
22
23
  variant: 'dark',
23
24
  settings: {
24
25
  background: colors.background,
25
- foreground: '#fff',
26
- caret: '#AEAFAD',
27
- selection: '#d9d9d942',
26
+ foreground: '#E6EDF3',
27
+ caret: '#7DD3FC',
28
+ selection: '#264F7833',
28
29
  gutterBackground: colors.background,
29
- gutterForeground: '#FFFFFF63',
30
+ gutterForeground: '#6E7681',
30
31
  gutterBorderColor: 'transparent',
31
32
  gutterBorderWidth: 0,
32
- lineHighlight: '#272e3d36',
33
- bracketColors: ['#FFEF61', '#DD99FF', '#78B0FF'],
33
+ lineHighlight: '#21262D',
34
+ bracketColors: ['#FBBF24', '#A78BFA', '#7DD3FC'],
34
35
  tooltip: {
35
- backgroundColor: '#363D4D',
36
- color: '#fff',
37
- border: 'none',
36
+ backgroundColor: '#21262D',
37
+ color: '#E6EDF3',
38
+ border: '1px solid #30363D',
38
39
  },
39
40
  link: {
40
- color: '#4daafc',
41
+ color: '#58A6FF',
41
42
  },
42
43
  completionItemHover: {
43
- backgroundColor: '#FFFFFF0F',
44
+ backgroundColor: '#21262D',
44
45
  },
45
46
  completionItemSelected: {
46
- backgroundColor: '#FFFFFF17',
47
+ backgroundColor: '#1F6EEB',
47
48
  },
48
49
  completionItemIcon: {
49
- color: '#FFFFFFC9',
50
+ color: '#8B949E',
50
51
  },
51
52
  completionItemLabel: {
52
- color: '#FFFFFFC9',
53
+ color: '#E6EDF3',
53
54
  },
54
55
  completionItemInfo: {
55
- color: '#FFFFFFC9',
56
+ color: '#8B949E',
56
57
  },
57
58
  completionItemDetail: {
58
- color: '#FFFFFF63',
59
+ color: '#6E7681',
59
60
  },
60
61
  },
61
62
  styles: [
@@ -89,31 +90,49 @@ export const darkTheme: Extension = createTheme({
89
90
  color: colors.separator,
90
91
  },
91
92
 
93
+ // js
94
+ {
95
+ tag: [t.definitionKeyword],
96
+ color: '#C084FC',
97
+ },
98
+ {
99
+ tag: [t.modifier],
100
+ color: '#C084FC',
101
+ },
102
+ {
103
+ tag: [t.controlKeyword],
104
+ color: '#C084FC',
105
+ },
106
+ {
107
+ tag: [t.operatorKeyword],
108
+ color: '#C084FC',
109
+ },
110
+
92
111
  // markdown
93
112
  {
94
113
  tag: [t.heading],
95
- color: '#6b6bff',
114
+ color: '#7DD3FC',
96
115
  },
97
116
  {
98
117
  tag: [t.processingInstruction],
99
- color: '#6b6bff',
118
+ color: '#7DD3FC',
100
119
  },
101
120
 
102
121
  // shell
103
122
  // curl
104
123
  {
105
124
  tag: [t.standard(t.variableName)],
106
- color: '#3BEB84',
125
+ color: '#34D399',
107
126
  },
108
127
  // -X
109
128
  {
110
129
  tag: [t.attributeName],
111
- color: '#FF9933',
130
+ color: '#FBBF24',
112
131
  },
113
132
  // url in string (includes quotes), e.g. "https://..."
114
133
  {
115
134
  tag: [t.special(t.string)],
116
- color: '#78B0FF',
135
+ color: '#7DD3FC',
117
136
  },
118
137
  ],
119
138
  });
@@ -3,7 +3,7 @@
3
3
  * SPDX-License-Identifier: MIT
4
4
  */
5
5
 
6
- import { themes } from '@coze-editor/editor/preset-code';
6
+ import { themes } from '@flowgram.ai/coze-editor/preset-code';
7
7
 
8
8
  import { lightTheme } from './light';
9
9
  import { darkTheme } from './dark';