@flowgram.ai/form-materials 0.1.0-alpha.14 → 0.1.0-alpha.16

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 (511) hide show
  1. package/bin/run.sh +7 -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 +54 -0
  10. package/dist/cjs/components/code-editor/editor-all.js +52 -0
  11. package/dist/cjs/components/code-editor/editor-json.js +71 -0
  12. package/dist/cjs/components/code-editor/editor-python.js +63 -0
  13. package/dist/cjs/components/code-editor/editor-shell.js +63 -0
  14. package/dist/cjs/components/code-editor/editor-sql.js +71 -0
  15. package/dist/cjs/components/code-editor/editor-ts.js +80 -0
  16. package/dist/cjs/components/code-editor/editor.js +105 -0
  17. package/dist/cjs/components/code-editor/factory.js +96 -0
  18. package/dist/cjs/components/code-editor/index.js +60 -0
  19. package/dist/cjs/components/code-editor/theme/dark.js +258 -0
  20. package/dist/cjs/components/code-editor/theme/index.js +11 -0
  21. package/dist/cjs/components/code-editor/theme/light.js +244 -0
  22. package/dist/cjs/components/code-editor/utils.js +43 -0
  23. package/dist/cjs/components/code-editor-mini/index.js +66 -0
  24. package/dist/cjs/components/condition-context/context.js +59 -0
  25. package/dist/cjs/components/condition-context/hooks/use-condition.js +97 -0
  26. package/dist/cjs/components/condition-context/index.js +47 -0
  27. package/dist/cjs/components/condition-context/op.js +117 -0
  28. package/dist/cjs/components/condition-context/types.js +18 -0
  29. package/dist/cjs/components/condition-row/index.js +140 -0
  30. package/dist/cjs/components/condition-row/styles.js +77 -0
  31. package/dist/cjs/components/condition-row/types.js +18 -0
  32. package/dist/cjs/components/constant-input/index.js +80 -0
  33. package/dist/cjs/components/constant-input/types.js +18 -0
  34. package/dist/cjs/components/coze-editor-extensions/extensions/inputs-tree.js +172 -0
  35. package/dist/cjs/components/coze-editor-extensions/extensions/variable-tag.js +152 -0
  36. package/dist/cjs/components/coze-editor-extensions/extensions/variable-tree.js +109 -0
  37. package/dist/cjs/components/coze-editor-extensions/index.js +86 -0
  38. package/dist/cjs/components/coze-editor-extensions/styles.js +89 -0
  39. package/dist/cjs/components/db-condition-row/index.js +140 -0
  40. package/dist/cjs/components/db-condition-row/styles.js +94 -0
  41. package/dist/cjs/components/db-condition-row/types.js +18 -0
  42. package/dist/cjs/components/display-flow-value/index.js +64 -0
  43. package/dist/cjs/components/display-inputs-values/index.js +76 -0
  44. package/dist/cjs/components/display-inputs-values/styles.js +51 -0
  45. package/dist/cjs/components/display-outputs/index.js +72 -0
  46. package/dist/cjs/components/display-outputs/styles.js +51 -0
  47. package/dist/cjs/components/display-schema-tag/index.js +77 -0
  48. package/dist/cjs/components/display-schema-tag/styles.js +71 -0
  49. package/dist/cjs/components/display-schema-tree/index.js +93 -0
  50. package/dist/cjs/components/display-schema-tree/styles.js +135 -0
  51. package/dist/cjs/components/dynamic-value-input/hooks.js +99 -0
  52. package/dist/cjs/components/dynamic-value-input/index.js +174 -0
  53. package/dist/cjs/components/dynamic-value-input/styles.js +107 -0
  54. package/dist/cjs/components/index.js +201 -0
  55. package/dist/cjs/components/inputs-values/index.js +112 -0
  56. package/dist/cjs/components/inputs-values/styles.js +60 -0
  57. package/dist/cjs/components/inputs-values/types.js +18 -0
  58. package/dist/cjs/components/inputs-values-tree/hooks/use-child-list.js +77 -0
  59. package/dist/cjs/components/inputs-values-tree/index.js +87 -0
  60. package/dist/cjs/components/inputs-values-tree/row.js +183 -0
  61. package/dist/cjs/components/inputs-values-tree/styles.js +177 -0
  62. package/dist/cjs/components/inputs-values-tree/types.js +18 -0
  63. package/dist/cjs/components/json-editor-with-variables/editor.js +84 -0
  64. package/dist/cjs/components/json-editor-with-variables/index.js +57 -0
  65. package/dist/cjs/components/json-schema-editor/default-value.js +54 -0
  66. package/dist/cjs/components/json-schema-editor/hooks.js +130 -0
  67. package/dist/cjs/components/json-schema-editor/index.js +246 -0
  68. package/dist/cjs/components/json-schema-editor/styles.js +231 -0
  69. package/dist/cjs/components/json-schema-editor/types.js +18 -0
  70. package/dist/cjs/components/prompt-editor/editor.js +99 -0
  71. package/dist/cjs/components/prompt-editor/extensions/jinja.js +73 -0
  72. package/dist/cjs/components/prompt-editor/extensions/language-support.js +48 -0
  73. package/dist/cjs/components/prompt-editor/extensions/markdown.js +81 -0
  74. package/dist/cjs/components/prompt-editor/index.js +57 -0
  75. package/dist/cjs/components/prompt-editor/styles.js +55 -0
  76. package/dist/cjs/components/prompt-editor/types.js +7 -0
  77. package/dist/cjs/components/prompt-editor-with-inputs/editor.js +47 -0
  78. package/dist/cjs/components/prompt-editor-with-inputs/index.js +57 -0
  79. package/dist/cjs/components/prompt-editor-with-variables/editor.js +48 -0
  80. package/dist/cjs/components/prompt-editor-with-variables/index.js +57 -0
  81. package/dist/cjs/components/sql-editor-with-variables/editor.js +53 -0
  82. package/dist/cjs/components/sql-editor-with-variables/index.js +57 -0
  83. package/dist/cjs/components/type-selector/index.js +139 -0
  84. package/dist/cjs/components/variable-selector/context.js +56 -0
  85. package/dist/cjs/components/variable-selector/index.js +143 -0
  86. package/dist/cjs/components/variable-selector/styles.js +114 -0
  87. package/dist/cjs/components/variable-selector/use-variable-tree.js +99 -0
  88. package/dist/cjs/effects/auto-rename-ref/index.js +98 -0
  89. package/dist/cjs/effects/index.js +60 -0
  90. package/dist/cjs/effects/listen-ref-schema-change/index.js +57 -0
  91. package/dist/cjs/effects/listen-ref-value-change/index.js +54 -0
  92. package/dist/cjs/effects/provide-batch-input/index.js +64 -0
  93. package/dist/cjs/effects/provide-json-schema-outputs/index.js +49 -0
  94. package/dist/cjs/effects/sync-variable-title/index.js +52 -0
  95. package/dist/cjs/effects/validate-when-variable-sync/index.js +49 -0
  96. package/dist/cjs/form-plugins/batch-outputs-plugin/index.js +104 -0
  97. package/dist/cjs/form-plugins/index.js +47 -0
  98. package/dist/cjs/form-plugins/infer-assign-plugin/index.js +72 -0
  99. package/dist/cjs/form-plugins/infer-inputs-plugin/index.js +74 -0
  100. package/dist/cjs/hooks/index.js +36 -0
  101. package/dist/cjs/hooks/use-object-list/index.js +136 -0
  102. package/dist/cjs/index.js +270 -0
  103. package/dist/cjs/plugins/disable-declaration-plugin/create-disable-declaration-plugin.js +51 -0
  104. package/dist/cjs/plugins/disable-declaration-plugin/index.js +36 -0
  105. package/dist/cjs/plugins/index.js +49 -0
  106. package/dist/cjs/plugins/json-schema-preset/create-type-preset-plugin.js +50 -0
  107. package/dist/cjs/plugins/json-schema-preset/index.js +47 -0
  108. package/dist/cjs/plugins/json-schema-preset/react.js +51 -0
  109. package/dist/cjs/plugins/json-schema-preset/type-definition/array.js +78 -0
  110. package/dist/cjs/plugins/json-schema-preset/type-definition/boolean.js +86 -0
  111. package/dist/cjs/plugins/json-schema-preset/type-definition/date-time.js +81 -0
  112. package/dist/cjs/plugins/json-schema-preset/type-definition/index.js +61 -0
  113. package/dist/cjs/plugins/json-schema-preset/type-definition/integer.js +82 -0
  114. package/dist/cjs/plugins/json-schema-preset/type-definition/map.js +54 -0
  115. package/dist/cjs/plugins/json-schema-preset/type-definition/number.js +82 -0
  116. package/dist/cjs/plugins/json-schema-preset/type-definition/object.js +54 -0
  117. package/dist/cjs/plugins/json-schema-preset/type-definition/string.js +83 -0
  118. package/dist/cjs/plugins/json-schema-preset/types.js +18 -0
  119. package/dist/cjs/shared/flow-value/index.js +36 -0
  120. package/dist/cjs/shared/flow-value/schema.js +82 -0
  121. package/dist/cjs/shared/flow-value/types.js +18 -0
  122. package/dist/cjs/shared/flow-value/utils.js +156 -0
  123. package/dist/cjs/shared/format-legacy-refs/index.js +99 -0
  124. package/dist/cjs/shared/index.js +73 -0
  125. package/dist/cjs/shared/inject-material/index.js +66 -0
  126. package/dist/cjs/shared/lazy-suspense/index.js +58 -0
  127. package/dist/cjs/shared/polyfill-create-root/index.js +53 -0
  128. package/dist/cjs/validate/index.js +36 -0
  129. package/dist/cjs/validate/validate-flow-value/index.js +63 -0
  130. package/dist/esm/components/assign-row/index.mjs +78 -0
  131. package/dist/esm/components/assign-row/types.mjs +0 -0
  132. package/dist/esm/components/assign-rows/index.mjs +51 -0
  133. package/dist/esm/components/batch-outputs/index.mjs +57 -0
  134. package/dist/esm/components/batch-outputs/styles.mjs +13 -0
  135. package/dist/esm/components/batch-outputs/types.mjs +0 -0
  136. package/dist/esm/components/batch-variable-selector/index.mjs +19 -0
  137. package/dist/esm/components/blur-input/index.mjs +20 -0
  138. package/dist/esm/components/code-editor/editor-all.mjs +18 -0
  139. package/dist/esm/components/code-editor/editor-json.mjs +16 -0
  140. package/dist/esm/components/code-editor/editor-python.mjs +8 -0
  141. package/dist/esm/components/code-editor/editor-shell.mjs +8 -0
  142. package/dist/esm/components/code-editor/editor-sql.mjs +16 -0
  143. package/dist/esm/components/code-editor/editor-ts.mjs +22 -0
  144. package/dist/esm/components/code-editor/editor.mjs +60 -0
  145. package/dist/esm/components/code-editor/factory.mjs +36 -0
  146. package/dist/esm/components/code-editor/index.mjs +8 -0
  147. package/dist/esm/components/code-editor/theme/dark.mjs +221 -0
  148. package/dist/esm/components/code-editor/theme/index.mjs +5 -0
  149. package/dist/esm/components/code-editor/theme/light.mjs +207 -0
  150. package/dist/esm/components/code-editor/utils.mjs +9 -0
  151. package/dist/esm/components/code-editor-mini/index.mjs +22 -0
  152. package/dist/esm/components/condition-context/context.mjs +19 -0
  153. package/dist/esm/components/condition-context/hooks/use-condition.mjs +63 -0
  154. package/dist/esm/components/condition-context/index.mjs +4 -0
  155. package/dist/esm/components/condition-context/op.mjs +80 -0
  156. package/dist/esm/components/condition-context/types.mjs +0 -0
  157. package/dist/esm/components/condition-row/index.mjs +106 -0
  158. package/dist/esm/components/condition-row/styles.mjs +21 -0
  159. package/dist/esm/components/condition-row/types.mjs +0 -0
  160. package/dist/esm/components/constant-input/index.mjs +36 -0
  161. package/dist/esm/components/constant-input/types.mjs +0 -0
  162. package/dist/esm/components/coze-editor-extensions/extensions/inputs-tree.mjs +135 -0
  163. package/dist/esm/components/coze-editor-extensions/extensions/variable-tag.mjs +118 -0
  164. package/dist/esm/components/coze-editor-extensions/extensions/variable-tree.mjs +75 -0
  165. package/dist/esm/components/coze-editor-extensions/index.mjs +18 -0
  166. package/{src/components/prompt-editor-with-variables/styles.tsx → dist/esm/components/coze-editor-extensions/styles.mjs} +7 -15
  167. package/dist/esm/components/db-condition-row/index.mjs +106 -0
  168. package/dist/esm/components/db-condition-row/styles.mjs +32 -0
  169. package/dist/esm/components/db-condition-row/types.mjs +0 -0
  170. package/dist/esm/components/display-flow-value/index.mjs +30 -0
  171. package/dist/esm/components/display-inputs-values/index.mjs +39 -0
  172. package/dist/esm/components/display-inputs-values/styles.mjs +7 -0
  173. package/dist/esm/components/display-outputs/index.mjs +38 -0
  174. package/dist/esm/components/display-outputs/styles.mjs +7 -0
  175. package/dist/esm/components/display-schema-tag/index.mjs +33 -0
  176. package/dist/esm/components/display-schema-tag/styles.mjs +21 -0
  177. package/dist/esm/components/display-schema-tree/index.mjs +49 -0
  178. package/dist/esm/components/display-schema-tree/styles.mjs +79 -0
  179. package/dist/esm/components/dynamic-value-input/hooks.mjs +59 -0
  180. package/dist/esm/components/dynamic-value-input/index.mjs +137 -0
  181. package/dist/esm/components/dynamic-value-input/styles.mjs +54 -0
  182. package/dist/esm/components/index.mjs +29 -0
  183. package/dist/esm/components/inputs-values/index.mjs +78 -0
  184. package/dist/esm/components/inputs-values/styles.mjs +13 -0
  185. package/dist/esm/components/inputs-values/types.mjs +0 -0
  186. package/dist/esm/components/inputs-values-tree/hooks/use-child-list.mjs +43 -0
  187. package/dist/esm/components/inputs-values-tree/index.mjs +53 -0
  188. package/dist/esm/components/inputs-values-tree/row.mjs +149 -0
  189. package/dist/esm/components/inputs-values-tree/styles.mjs +105 -0
  190. package/dist/esm/components/inputs-values-tree/types.mjs +0 -0
  191. package/dist/esm/components/json-editor-with-variables/editor.mjs +50 -0
  192. package/dist/esm/components/json-editor-with-variables/index.mjs +5 -0
  193. package/dist/esm/components/json-schema-editor/default-value.mjs +20 -0
  194. package/dist/esm/components/json-schema-editor/hooks.mjs +96 -0
  195. package/dist/esm/components/json-schema-editor/index.mjs +212 -0
  196. package/dist/esm/components/json-schema-editor/styles.mjs +138 -0
  197. package/dist/esm/components/json-schema-editor/types.mjs +0 -0
  198. package/dist/esm/components/prompt-editor/editor.mjs +52 -0
  199. package/dist/esm/components/prompt-editor/extensions/jinja.mjs +39 -0
  200. package/dist/esm/components/prompt-editor/extensions/language-support.mjs +14 -0
  201. package/dist/esm/components/prompt-editor/extensions/markdown.mjs +47 -0
  202. package/dist/esm/components/prompt-editor/index.mjs +5 -0
  203. package/dist/esm/components/prompt-editor/styles.mjs +11 -0
  204. package/dist/esm/components/prompt-editor/types.mjs +1 -0
  205. package/dist/esm/components/prompt-editor-with-inputs/editor.mjs +13 -0
  206. package/dist/esm/components/prompt-editor-with-inputs/index.mjs +5 -0
  207. package/dist/esm/components/prompt-editor-with-variables/editor.mjs +14 -0
  208. package/dist/esm/components/prompt-editor-with-variables/index.mjs +5 -0
  209. package/dist/esm/components/sql-editor-with-variables/editor.mjs +19 -0
  210. package/dist/esm/components/sql-editor-with-variables/index.mjs +5 -0
  211. package/dist/esm/components/type-selector/index.mjs +96 -0
  212. package/dist/esm/components/variable-selector/context.mjs +16 -0
  213. package/dist/esm/components/variable-selector/index.mjs +100 -0
  214. package/dist/esm/components/variable-selector/styles.mjs +58 -0
  215. package/dist/esm/components/variable-selector/use-variable-tree.mjs +65 -0
  216. package/dist/esm/effects/auto-rename-ref/index.mjs +64 -0
  217. package/dist/esm/effects/index.mjs +8 -0
  218. package/dist/esm/effects/listen-ref-schema-change/index.mjs +23 -0
  219. package/dist/esm/effects/listen-ref-value-change/index.mjs +20 -0
  220. package/dist/esm/effects/provide-batch-input/index.mjs +30 -0
  221. package/dist/esm/effects/provide-json-schema-outputs/index.mjs +15 -0
  222. package/dist/esm/effects/sync-variable-title/index.mjs +18 -0
  223. package/dist/esm/effects/validate-when-variable-sync/index.mjs +15 -0
  224. package/dist/esm/form-plugins/batch-outputs-plugin/index.mjs +67 -0
  225. package/dist/esm/form-plugins/index.mjs +4 -0
  226. package/dist/esm/form-plugins/infer-assign-plugin/index.mjs +38 -0
  227. package/dist/esm/form-plugins/infer-inputs-plugin/index.mjs +40 -0
  228. package/dist/esm/hooks/index.mjs +2 -0
  229. package/dist/esm/hooks/use-object-list/index.mjs +102 -0
  230. package/dist/esm/index.mjs +8 -0
  231. package/dist/esm/plugins/disable-declaration-plugin/create-disable-declaration-plugin.mjs +17 -0
  232. package/dist/esm/plugins/disable-declaration-plugin/index.mjs +2 -0
  233. package/dist/esm/plugins/index.mjs +3 -0
  234. package/dist/esm/plugins/json-schema-preset/create-type-preset-plugin.mjs +16 -0
  235. package/dist/esm/plugins/json-schema-preset/index.mjs +4 -0
  236. package/dist/esm/plugins/json-schema-preset/react.mjs +14 -0
  237. package/dist/esm/plugins/json-schema-preset/type-definition/array.mjs +44 -0
  238. package/dist/esm/plugins/json-schema-preset/type-definition/boolean.mjs +52 -0
  239. package/dist/esm/plugins/json-schema-preset/type-definition/date-time.mjs +47 -0
  240. package/dist/esm/plugins/json-schema-preset/type-definition/index.mjs +24 -0
  241. package/dist/esm/plugins/json-schema-preset/type-definition/integer.mjs +48 -0
  242. package/dist/esm/plugins/json-schema-preset/type-definition/map.mjs +20 -0
  243. package/dist/esm/plugins/json-schema-preset/type-definition/number.mjs +48 -0
  244. package/dist/esm/plugins/json-schema-preset/type-definition/object.mjs +20 -0
  245. package/dist/esm/plugins/json-schema-preset/type-definition/string.mjs +49 -0
  246. package/dist/esm/plugins/json-schema-preset/types.mjs +0 -0
  247. package/dist/esm/shared/flow-value/index.mjs +2 -0
  248. package/dist/esm/shared/flow-value/schema.mjs +26 -0
  249. package/dist/esm/shared/flow-value/types.mjs +0 -0
  250. package/dist/esm/shared/flow-value/utils.mjs +122 -0
  251. package/dist/esm/shared/format-legacy-refs/index.mjs +50 -0
  252. package/dist/esm/shared/index.mjs +6 -0
  253. package/dist/esm/shared/inject-material/index.mjs +22 -0
  254. package/dist/esm/shared/lazy-suspense/index.mjs +21 -0
  255. package/dist/esm/shared/polyfill-create-root/index.mjs +16 -0
  256. package/dist/esm/validate/index.mjs +2 -0
  257. package/dist/esm/validate/validate-flow-value/index.mjs +29 -0
  258. package/dist/tsconfig.tsbuildinfo +1 -0
  259. package/dist/types/components/assign-row/index.d.ts +8 -0
  260. package/dist/types/components/assign-row/types.d.ts +20 -0
  261. package/dist/types/components/assign-rows/index.d.ts +11 -0
  262. package/dist/types/components/batch-outputs/index.d.ts +7 -0
  263. package/dist/types/components/batch-outputs/styles.d.ts +6 -0
  264. package/dist/types/components/batch-outputs/types.d.ts +18 -0
  265. package/dist/types/components/batch-variable-selector/index.d.ts +7 -0
  266. package/dist/types/components/blur-input/index.d.ts +13 -0
  267. package/dist/types/components/code-editor/editor-all.d.ts +8 -0
  268. package/dist/types/components/code-editor/editor-json.d.ts +6 -0
  269. package/dist/types/components/code-editor/editor-python.d.ts +6 -0
  270. package/dist/types/components/code-editor/editor-shell.d.ts +6 -0
  271. package/dist/types/components/code-editor/editor-sql.d.ts +6 -0
  272. package/dist/types/components/code-editor/editor-ts.d.ts +6 -0
  273. package/dist/types/components/code-editor/editor.d.ts +22 -0
  274. package/dist/types/components/code-editor/factory.d.ts +13 -0
  275. package/dist/types/components/code-editor/index.d.ts +11 -0
  276. package/dist/types/components/code-editor/theme/dark.d.ts +35 -0
  277. package/{src/typings/index.ts → dist/types/components/code-editor/theme/index.d.ts} +1 -2
  278. package/dist/types/components/code-editor/theme/light.d.ts +30 -0
  279. package/dist/types/components/code-editor/utils.d.ts +5 -0
  280. package/dist/types/components/code-editor-mini/index.d.ts +10 -0
  281. package/dist/types/components/condition-context/context.d.ts +14 -0
  282. package/dist/types/components/condition-context/hooks/use-condition.d.ts +29 -0
  283. package/dist/types/components/condition-context/index.d.ts +8 -0
  284. package/dist/types/components/condition-context/op.d.ts +22 -0
  285. package/dist/types/components/condition-context/types.d.ts +14 -0
  286. package/dist/types/components/condition-row/index.d.ts +19 -0
  287. package/dist/types/components/condition-row/styles.d.ts +9 -0
  288. package/dist/types/components/condition-row/types.d.ts +10 -0
  289. package/dist/types/components/constant-input/index.d.ts +8 -0
  290. package/dist/types/components/constant-input/types.d.ts +16 -0
  291. package/dist/types/components/coze-editor-extensions/extensions/inputs-tree.d.ts +14 -0
  292. package/{src/validate/index.tsx → dist/types/components/coze-editor-extensions/extensions/variable-tag.d.ts} +1 -2
  293. package/dist/types/components/coze-editor-extensions/extensions/variable-tree.d.ts +8 -0
  294. package/dist/types/components/coze-editor-extensions/index.d.ts +18 -0
  295. package/dist/types/components/coze-editor-extensions/styles.d.ts +9 -0
  296. package/dist/types/components/db-condition-row/index.d.ts +20 -0
  297. package/dist/types/components/db-condition-row/styles.d.ts +12 -0
  298. package/dist/types/components/db-condition-row/types.d.ts +17 -0
  299. package/dist/types/components/display-flow-value/index.d.ts +15 -0
  300. package/dist/types/components/display-inputs-values/index.d.ts +14 -0
  301. package/dist/types/components/display-inputs-values/styles.d.ts +5 -0
  302. package/dist/types/components/display-outputs/index.d.ts +14 -0
  303. package/dist/types/components/display-outputs/styles.d.ts +5 -0
  304. package/dist/types/components/display-schema-tag/index.d.ts +14 -0
  305. package/dist/types/components/display-schema-tag/styles.d.ts +8 -0
  306. package/dist/types/components/display-schema-tree/index.d.ts +16 -0
  307. package/dist/types/components/display-schema-tree/styles.d.ts +11 -0
  308. package/dist/types/components/dynamic-value-input/hooks.d.ts +28 -0
  309. package/dist/types/components/dynamic-value-input/index.d.ts +29 -0
  310. package/dist/types/components/dynamic-value-input/styles.d.ts +8 -0
  311. package/dist/types/components/index.d.ts +32 -0
  312. package/dist/types/components/inputs-values/index.d.ts +7 -0
  313. package/dist/types/components/inputs-values/styles.d.ts +6 -0
  314. package/dist/types/components/inputs-values/types.d.ts +19 -0
  315. package/dist/types/components/inputs-values-tree/hooks/use-child-list.d.ts +19 -0
  316. package/dist/types/components/inputs-values-tree/index.d.ts +7 -0
  317. package/dist/types/components/inputs-values-tree/row.d.ts +15 -0
  318. package/dist/types/components/inputs-values-tree/styles.d.ts +23 -0
  319. package/dist/types/components/inputs-values-tree/types.d.ts +18 -0
  320. package/dist/types/components/json-editor-with-variables/editor.d.ts +9 -0
  321. package/dist/types/components/json-editor-with-variables/index.d.ts +6 -0
  322. package/dist/types/components/json-schema-editor/default-value.d.ts +17 -0
  323. package/dist/types/components/json-schema-editor/hooks.d.ts +12 -0
  324. package/dist/types/components/json-schema-editor/index.d.ts +14 -0
  325. package/dist/types/components/json-schema-editor/styles.d.ts +30 -0
  326. package/dist/types/components/json-schema-editor/types.d.ts +20 -0
  327. package/dist/types/components/prompt-editor/editor.d.ts +15 -0
  328. package/dist/types/components/prompt-editor/extensions/jinja.d.ts +6 -0
  329. package/dist/types/components/prompt-editor/extensions/language-support.d.ts +6 -0
  330. package/dist/types/components/prompt-editor/extensions/markdown.d.ts +6 -0
  331. package/dist/types/components/prompt-editor/index.d.ts +6 -0
  332. package/dist/types/components/prompt-editor/styles.d.ts +7 -0
  333. package/dist/types/components/prompt-editor/types.d.ts +16 -0
  334. package/dist/types/components/prompt-editor-with-inputs/editor.d.ts +10 -0
  335. package/dist/types/components/prompt-editor-with-inputs/index.d.ts +6 -0
  336. package/dist/types/components/prompt-editor-with-variables/editor.d.ts +9 -0
  337. package/dist/types/components/prompt-editor-with-variables/index.d.ts +6 -0
  338. package/dist/types/components/sql-editor-with-variables/editor.d.ts +9 -0
  339. package/dist/types/components/sql-editor-with-variables/index.d.ts +6 -0
  340. package/dist/types/components/type-selector/index.d.ts +25 -0
  341. package/dist/types/components/variable-selector/context.d.ts +16 -0
  342. package/dist/types/components/variable-selector/index.d.ts +31 -0
  343. package/dist/types/components/variable-selector/styles.d.ts +14 -0
  344. package/dist/types/components/variable-selector/use-variable-tree.d.ts +18 -0
  345. package/dist/types/effects/auto-rename-ref/index.d.ts +17 -0
  346. package/dist/types/effects/index.d.ts +11 -0
  347. package/dist/types/effects/listen-ref-schema-change/index.d.ts +22 -0
  348. package/dist/types/effects/listen-ref-value-change/index.d.ts +22 -0
  349. package/dist/types/effects/provide-batch-input/index.d.ts +6 -0
  350. package/dist/types/effects/provide-json-schema-outputs/index.d.ts +6 -0
  351. package/dist/types/effects/sync-variable-title/index.d.ts +6 -0
  352. package/dist/types/effects/validate-when-variable-sync/index.d.ts +8 -0
  353. package/dist/types/form-plugins/batch-outputs-plugin/index.d.ts +16 -0
  354. package/dist/types/form-plugins/index.d.ts +7 -0
  355. package/dist/types/form-plugins/infer-assign-plugin/index.d.ts +10 -0
  356. package/dist/types/form-plugins/infer-inputs-plugin/index.d.ts +15 -0
  357. package/dist/types/hooks/index.d.ts +5 -0
  358. package/dist/types/hooks/use-object-list/index.d.ts +22 -0
  359. package/dist/types/index.d.ts +11 -0
  360. package/dist/types/plugins/disable-declaration-plugin/create-disable-declaration-plugin.d.ts +5 -0
  361. package/dist/types/plugins/disable-declaration-plugin/index.d.ts +5 -0
  362. package/dist/types/plugins/index.d.ts +6 -0
  363. package/dist/types/plugins/json-schema-preset/create-type-preset-plugin.d.ts +9 -0
  364. package/dist/types/plugins/json-schema-preset/index.d.ts +9 -0
  365. package/dist/types/plugins/json-schema-preset/react.d.ts +11 -0
  366. package/dist/types/plugins/json-schema-preset/type-definition/array.d.ts +6 -0
  367. package/dist/types/plugins/json-schema-preset/type-definition/boolean.d.ts +6 -0
  368. package/dist/types/plugins/json-schema-preset/type-definition/date-time.d.ts +6 -0
  369. package/dist/types/plugins/json-schema-preset/type-definition/index.d.ts +7 -0
  370. package/dist/types/plugins/json-schema-preset/type-definition/integer.d.ts +6 -0
  371. package/dist/types/plugins/json-schema-preset/type-definition/map.d.ts +6 -0
  372. package/dist/types/plugins/json-schema-preset/type-definition/number.d.ts +6 -0
  373. package/dist/types/plugins/json-schema-preset/type-definition/object.d.ts +6 -0
  374. package/dist/types/plugins/json-schema-preset/type-definition/string.d.ts +6 -0
  375. package/dist/types/plugins/json-schema-preset/types.d.ts +22 -0
  376. package/dist/types/shared/flow-value/index.d.ts +6 -0
  377. package/dist/types/shared/flow-value/schema.d.ts +107 -0
  378. package/dist/types/shared/flow-value/types.d.ts +32 -0
  379. package/dist/types/shared/flow-value/utils.d.ts +67 -0
  380. package/dist/types/shared/format-legacy-refs/index.d.ts +84 -0
  381. package/dist/types/shared/index.d.ts +9 -0
  382. package/dist/types/shared/inject-material/index.d.ts +48 -0
  383. package/dist/types/shared/lazy-suspense/index.d.ts +7 -0
  384. package/dist/types/shared/polyfill-create-root/index.d.ts +10 -0
  385. package/dist/types/validate/index.d.ts +5 -0
  386. package/dist/types/validate/validate-flow-value/index.d.ts +19 -0
  387. package/package.json +63 -26
  388. package/src/components/assign-row/index.tsx +3 -3
  389. package/src/components/assign-row/types.ts +1 -1
  390. package/src/components/batch-outputs/types.ts +1 -1
  391. package/src/components/blur-input/index.tsx +9 -1
  392. package/src/components/code-editor/editor-all.tsx +30 -0
  393. package/src/components/code-editor/editor-json.tsx +25 -0
  394. package/src/components/code-editor/editor-python.tsx +18 -0
  395. package/src/components/code-editor/editor-shell.tsx +18 -0
  396. package/src/components/code-editor/editor-sql.tsx +24 -0
  397. package/src/components/code-editor/editor-ts.tsx +31 -0
  398. package/src/components/code-editor/editor.tsx +47 -30
  399. package/src/components/code-editor/factory.tsx +61 -0
  400. package/src/components/code-editor/index.tsx +7 -7
  401. package/src/components/code-editor/theme/dark.ts +63 -78
  402. package/src/components/code-editor/theme/index.ts +1 -1
  403. package/src/components/code-editor/theme/light.ts +61 -92
  404. package/src/components/code-editor/utils.ts +4 -0
  405. package/src/components/code-editor-mini/index.tsx +3 -0
  406. package/src/components/condition-context/context.tsx +28 -0
  407. package/src/components/condition-context/hooks/use-condition.tsx +99 -0
  408. package/src/components/condition-context/index.tsx +14 -0
  409. package/src/components/condition-context/op.ts +86 -0
  410. package/src/components/condition-context/types.ts +22 -0
  411. package/src/components/condition-row/index.tsx +44 -22
  412. package/src/components/condition-row/types.ts +1 -31
  413. package/src/components/constant-input/index.tsx +1 -1
  414. package/src/components/{prompt-editor-with-inputs/inputs-picker.tsx → coze-editor-extensions/extensions/inputs-tree.tsx} +95 -5
  415. package/src/components/{prompt-editor-with-variables → coze-editor-extensions}/extensions/variable-tag.tsx +7 -4
  416. package/src/components/{prompt-editor-with-variables → coze-editor-extensions}/extensions/variable-tree.tsx +15 -6
  417. package/src/components/coze-editor-extensions/index.tsx +33 -0
  418. package/src/components/db-condition-row/index.tsx +76 -24
  419. package/src/components/db-condition-row/types.ts +1 -14
  420. package/src/components/display-flow-value/index.tsx +1 -1
  421. package/src/components/display-schema-tree/index.tsx +6 -4
  422. package/src/components/dynamic-value-input/hooks.ts +1 -1
  423. package/src/components/dynamic-value-input/index.tsx +1 -1
  424. package/src/components/index.ts +78 -25
  425. package/src/components/inputs-values/index.tsx +1 -1
  426. package/src/components/inputs-values/types.ts +1 -1
  427. package/src/components/inputs-values-tree/row.tsx +1 -1
  428. package/src/components/json-editor-with-variables/editor.tsx +9 -10
  429. package/src/components/prompt-editor/editor.tsx +2 -2
  430. package/src/components/prompt-editor/extensions/jinja.tsx +2 -2
  431. package/src/components/prompt-editor/extensions/language-support.tsx +2 -2
  432. package/src/components/prompt-editor/extensions/markdown.tsx +2 -2
  433. package/src/components/prompt-editor/types.tsx +1 -1
  434. package/src/components/prompt-editor-with-inputs/editor.tsx +2 -3
  435. package/src/components/prompt-editor-with-variables/editor.tsx +3 -5
  436. package/src/components/sql-editor-with-variables/editor.tsx +28 -0
  437. package/src/components/sql-editor-with-variables/index.tsx +12 -0
  438. package/src/components/type-selector/index.tsx +2 -3
  439. package/src/components/variable-selector/index.tsx +2 -2
  440. package/src/components/variable-selector/use-variable-tree.tsx +7 -4
  441. package/src/effects/auto-rename-ref/index.ts +1 -1
  442. package/src/effects/index.ts +7 -7
  443. package/src/effects/listen-ref-schema-change/index.ts +1 -1
  444. package/src/effects/listen-ref-value-change/index.ts +1 -1
  445. package/src/effects/provide-batch-input/index.ts +2 -3
  446. package/src/effects/provide-json-schema-outputs/index.ts +1 -2
  447. package/src/form-plugins/batch-outputs-plugin/index.ts +65 -47
  448. package/src/form-plugins/index.ts +3 -3
  449. package/src/form-plugins/infer-assign-plugin/index.ts +2 -3
  450. package/src/form-plugins/infer-inputs-plugin/index.ts +62 -14
  451. package/src/hooks/{index.tsx → index.ts} +1 -1
  452. package/src/index.ts +117 -8
  453. package/src/plugins/index.ts +11 -2
  454. package/src/plugins/json-schema-preset/create-type-preset-plugin.tsx +4 -2
  455. package/src/plugins/json-schema-preset/index.tsx +8 -24
  456. package/src/plugins/json-schema-preset/react.tsx +31 -0
  457. package/src/plugins/json-schema-preset/type-definition/array.tsx +13 -4
  458. package/src/plugins/json-schema-preset/type-definition/boolean.tsx +17 -1
  459. package/src/plugins/json-schema-preset/type-definition/date-time.tsx +21 -2
  460. package/src/plugins/json-schema-preset/type-definition/index.tsx +10 -1
  461. package/src/plugins/json-schema-preset/type-definition/integer.tsx +19 -1
  462. package/src/plugins/json-schema-preset/type-definition/map.tsx +31 -0
  463. package/src/plugins/json-schema-preset/type-definition/number.tsx +19 -1
  464. package/src/plugins/json-schema-preset/type-definition/object.tsx +9 -4
  465. package/src/plugins/json-schema-preset/type-definition/string.tsx +19 -1
  466. package/src/plugins/json-schema-preset/{manager.ts → types.ts} +7 -0
  467. package/src/shared/flow-value/index.ts +11 -1
  468. package/src/shared/flow-value/utils.ts +23 -11
  469. package/src/shared/index.ts +26 -5
  470. package/src/shared/inject-material/index.tsx +10 -6
  471. package/src/validate/index.ts +6 -0
  472. package/src/validate/validate-flow-value/index.tsx +1 -2
  473. package/bin/index.ts +0 -80
  474. package/bin/materials.ts +0 -134
  475. package/bin/project.ts +0 -95
  476. package/bin/utils/import.ts +0 -127
  477. package/bin/utils/traverse-file.ts +0 -60
  478. package/dist/esm/chunk-727SU246.js +0 -13
  479. package/dist/esm/chunk-727SU246.js.map +0 -1
  480. package/dist/esm/chunk-DEZUEMUM.js +0 -284
  481. package/dist/esm/chunk-DEZUEMUM.js.map +0 -1
  482. package/dist/esm/chunk-DUOXDOUE.js +0 -477
  483. package/dist/esm/chunk-DUOXDOUE.js.map +0 -1
  484. package/dist/esm/editor-6UMULJYB.js +0 -180
  485. package/dist/esm/editor-6UMULJYB.js.map +0 -1
  486. package/dist/esm/editor-EYOQTGMT.js +0 -282
  487. package/dist/esm/editor-EYOQTGMT.js.map +0 -1
  488. package/dist/esm/editor-OXPGKPF5.js +0 -167
  489. package/dist/esm/editor-OXPGKPF5.js.map +0 -1
  490. package/dist/esm/editor-VO6YAXRC.js +0 -249
  491. package/dist/esm/editor-VO6YAXRC.js.map +0 -1
  492. package/dist/esm/editor-XYLKTB6L.js +0 -365
  493. package/dist/esm/editor-XYLKTB6L.js.map +0 -1
  494. package/dist/esm/index.js +0 -2668
  495. package/dist/esm/index.js.map +0 -1
  496. package/dist/index.d.mts +0 -1002
  497. package/dist/index.d.ts +0 -1002
  498. package/dist/index.js +0 -5100
  499. package/dist/index.js.map +0 -1
  500. package/src/components/assign-row/components/blur-input.tsx +0 -27
  501. package/src/components/code-editor/language-features.ts +0 -44
  502. package/src/components/condition-row/constants.ts +0 -134
  503. package/src/components/condition-row/hooks/useOp.tsx +0 -56
  504. package/src/components/condition-row/hooks/useRule.ts +0 -35
  505. package/src/components/db-condition-row/hooks/use-left.tsx +0 -66
  506. package/src/components/db-condition-row/hooks/use-op.tsx +0 -59
  507. package/src/components/json-editor-with-variables/extensions/variable-tag.tsx +0 -174
  508. package/src/components/json-editor-with-variables/extensions/variable-tree.tsx +0 -83
  509. package/src/components/prompt-editor-with-inputs/extensions/inputs-tree.tsx +0 -94
  510. /package/src/components/{json-editor-with-variables → coze-editor-extensions}/styles.tsx +0 -0
  511. /package/src/{typings/flow-value/index.ts → shared/flow-value/types.ts} +0 -0
@@ -0,0 +1,30 @@
1
+ /**
2
+ * Copyright (c) 2025 Bytedance Ltd. and/or its affiliates
3
+ * SPDX-License-Identifier: MIT
4
+ */
5
+
6
+ import { CodeEditorFactory } from './factory';
7
+ import { loadTypescriptLanguage } from './editor-ts';
8
+ import { loadSqlLanguage } from './editor-sql';
9
+ import { loadShellLanguage } from './editor-shell';
10
+ import { loadPythonLanguage } from './editor-python';
11
+ import { loadJsonLanguage } from './editor-json';
12
+
13
+ const languageLoaders: Record<string, (languageId: string) => Promise<any>> = {
14
+ json: loadJsonLanguage,
15
+ python: loadPythonLanguage,
16
+ sql: loadSqlLanguage,
17
+ typescript: loadTypescriptLanguage,
18
+ shell: loadShellLanguage,
19
+ };
20
+
21
+ /**
22
+ * @deprecated CodeEditor will bundle all languages features, use XXXCodeEditor instead for better bundle experience
23
+ */
24
+ export const CodeEditor = CodeEditorFactory<false>(
25
+ (languageId) => languageLoaders[languageId]?.(languageId),
26
+ {
27
+ displayName: 'CodeEditor',
28
+ fixLanguageId: undefined,
29
+ }
30
+ );
@@ -0,0 +1,25 @@
1
+ /**
2
+ * Copyright (c) 2025 Bytedance Ltd. and/or its affiliates
3
+ * SPDX-License-Identifier: MIT
4
+ */
5
+
6
+ import { languages } from '@flowgram.ai/coze-editor/preset-code';
7
+ import { mixLanguages } from '@flowgram.ai/coze-editor';
8
+
9
+ import { CodeEditorFactory } from './factory';
10
+
11
+ export const loadJsonLanguage = () =>
12
+ import('@flowgram.ai/coze-editor/language-json').then((module) => {
13
+ languages.register('json', {
14
+ // mixLanguages is used to solve the problem that interpolation also uses parentheses, which causes incorrect highlighting
15
+ language: mixLanguages({
16
+ outerLanguage: module.json.language,
17
+ }),
18
+ languageService: module.json.languageService,
19
+ });
20
+ });
21
+
22
+ export const JsonCodeEditor = CodeEditorFactory<true>(loadJsonLanguage, {
23
+ displayName: 'JsonCodeEditor',
24
+ fixLanguageId: 'json',
25
+ });
@@ -0,0 +1,18 @@
1
+ /**
2
+ * Copyright (c) 2025 Bytedance Ltd. and/or its affiliates
3
+ * SPDX-License-Identifier: MIT
4
+ */
5
+
6
+ import { languages } from '@flowgram.ai/coze-editor/preset-code';
7
+
8
+ import { CodeEditorFactory } from './factory';
9
+
10
+ export const loadPythonLanguage = () =>
11
+ import('@flowgram.ai/coze-editor/language-python').then((module) =>
12
+ languages.register('python', module.python)
13
+ );
14
+
15
+ export const PythonCodeEditor = CodeEditorFactory<true>(loadPythonLanguage, {
16
+ displayName: 'PythonCodeEditor',
17
+ fixLanguageId: 'python',
18
+ });
@@ -0,0 +1,18 @@
1
+ /**
2
+ * Copyright (c) 2025 Bytedance Ltd. and/or its affiliates
3
+ * SPDX-License-Identifier: MIT
4
+ */
5
+
6
+ import { languages } from '@flowgram.ai/coze-editor/preset-code';
7
+
8
+ import { CodeEditorFactory } from './factory';
9
+
10
+ export const loadShellLanguage = () =>
11
+ import('@flowgram.ai/coze-editor/language-shell').then((module) =>
12
+ languages.register('shell', module.shell)
13
+ );
14
+
15
+ export const ShellCodeEditor = CodeEditorFactory<true>(loadShellLanguage, {
16
+ displayName: 'ShellCodeEditor',
17
+ fixLanguageId: 'shell',
18
+ });
@@ -0,0 +1,24 @@
1
+ /**
2
+ * Copyright (c) 2025 Bytedance Ltd. and/or its affiliates
3
+ * SPDX-License-Identifier: MIT
4
+ */
5
+
6
+ import { languages } from '@flowgram.ai/coze-editor/preset-code';
7
+ import { mixLanguages } from '@flowgram.ai/coze-editor';
8
+
9
+ import { CodeEditorFactory } from './factory';
10
+
11
+ export const loadSqlLanguage = () =>
12
+ import('@flowgram.ai/coze-editor/language-sql').then((module) => {
13
+ languages.register('sql', {
14
+ ...module.sql,
15
+ language: mixLanguages({
16
+ outerLanguage: module.sql.language,
17
+ }),
18
+ });
19
+ });
20
+
21
+ export const SQLCodeEditor = CodeEditorFactory<true>(loadSqlLanguage, {
22
+ displayName: 'SQLCodeEditor',
23
+ fixLanguageId: 'sql',
24
+ });
@@ -0,0 +1,31 @@
1
+ /**
2
+ * Copyright (c) 2025 Bytedance Ltd. and/or its affiliates
3
+ * SPDX-License-Identifier: MIT
4
+ */
5
+
6
+ import { languages } from '@flowgram.ai/coze-editor/preset-code';
7
+
8
+ import { CodeEditorFactory } from './factory';
9
+
10
+ export const loadTypescriptLanguage = () =>
11
+ import('@flowgram.ai/coze-editor/language-typescript').then((module) => {
12
+ languages.register('typescript', module.typescript);
13
+
14
+ // Init TypeScript language service
15
+ const tsWorker = new Worker(
16
+ new URL(`@flowgram.ai/coze-editor/language-typescript/worker`, import.meta.url),
17
+ { type: 'module' }
18
+ );
19
+ module.typescript.languageService.initialize(tsWorker, {
20
+ compilerOptions: {
21
+ // eliminate Promise error
22
+ lib: ['es2015', 'dom'],
23
+ noImplicitAny: false,
24
+ },
25
+ });
26
+ });
27
+
28
+ export const TypeScriptCodeEditor = CodeEditorFactory<true>(loadTypescriptLanguage, {
29
+ displayName: 'TypeScriptCodeEditor',
30
+ fixLanguageId: 'typescript',
31
+ });
@@ -5,20 +5,18 @@
5
5
 
6
6
  import React, { useEffect, useRef } from 'react';
7
7
 
8
+ import styled, { css } from 'styled-components';
8
9
  import {
9
10
  ActiveLinePlaceholder,
10
11
  createRenderer,
11
12
  EditorProvider,
12
13
  InferValues,
13
- } from '@coze-editor/editor/react';
14
- import preset, { type EditorAPI } from '@coze-editor/editor/preset-code';
14
+ } from '@flowgram.ai/coze-editor/react';
15
+ import preset, { type EditorAPI } from '@flowgram.ai/coze-editor/preset-code';
15
16
  import { EditorView } from '@codemirror/view';
16
17
 
17
18
  import { getSuffixByLanguageId } from './utils';
18
19
 
19
- import './theme';
20
- import './language-features';
21
-
22
20
  const OriginCodeEditor = createRenderer(preset, [
23
21
  EditorView.theme({
24
22
  '&.cm-focused': {
@@ -27,21 +25,30 @@ const OriginCodeEditor = createRenderer(preset, [
27
25
  }),
28
26
  ]);
29
27
 
28
+ const UIContainer = styled.div<{ $mini?: boolean }>`
29
+ ${({ $mini }) =>
30
+ $mini &&
31
+ css`
32
+ height: 24px;
33
+ `}
34
+ `;
35
+
30
36
  type Preset = typeof preset;
31
37
  type Options = Partial<InferValues<Preset[number]>>;
32
38
 
33
39
  export interface CodeEditorPropsType extends React.PropsWithChildren<{}> {
34
40
  value?: string;
35
41
  onChange?: (value: string) => void;
36
- languageId: 'python' | 'typescript' | 'shell' | 'json';
42
+ languageId: 'python' | 'typescript' | 'shell' | 'json' | 'sql';
37
43
  theme?: 'dark' | 'light';
38
44
  placeholder?: string;
39
45
  activeLinePlaceholder?: string;
40
46
  readonly?: boolean;
41
47
  options?: Options;
48
+ mini?: boolean;
42
49
  }
43
50
 
44
- export function CodeEditor({
51
+ export function BaseCodeEditor({
45
52
  value,
46
53
  onChange,
47
54
  languageId = 'python',
@@ -51,6 +58,7 @@ export function CodeEditor({
51
58
  activeLinePlaceholder,
52
59
  options,
53
60
  readonly,
61
+ mini,
54
62
  }: CodeEditorPropsType) {
55
63
  const editorRef = useRef<EditorAPI | null>(null);
56
64
 
@@ -62,28 +70,37 @@ export function CodeEditor({
62
70
  }, [value]);
63
71
 
64
72
  return (
65
- <EditorProvider>
66
- <OriginCodeEditor
67
- defaultValue={String(value || '')}
68
- options={{
69
- uri: `file:///untitled${getSuffixByLanguageId(languageId)}`,
70
- languageId,
71
- theme,
72
- placeholder,
73
- readOnly: readonly,
74
- editable: !readonly,
75
- ...(options || {}),
76
- }}
77
- didMount={(editor: EditorAPI) => {
78
- editorRef.current = editor;
79
- }}
80
- onChange={(e) => onChange?.(e.value)}
81
- >
82
- {activeLinePlaceholder && (
83
- <ActiveLinePlaceholder>{activeLinePlaceholder}</ActiveLinePlaceholder>
84
- )}
85
- {children}
86
- </OriginCodeEditor>
87
- </EditorProvider>
73
+ <UIContainer $mini={mini}>
74
+ <EditorProvider>
75
+ <OriginCodeEditor
76
+ defaultValue={String(value || '')}
77
+ options={{
78
+ uri: `file:///untitled${getSuffixByLanguageId(languageId)}`,
79
+ languageId,
80
+ theme,
81
+ placeholder,
82
+ readOnly: readonly,
83
+ editable: !readonly,
84
+ ...(mini
85
+ ? {
86
+ lineNumbersGutter: false,
87
+ foldGutter: false,
88
+ minHeight: 24,
89
+ }
90
+ : {}),
91
+ ...(options || {}),
92
+ }}
93
+ didMount={(editor: EditorAPI) => {
94
+ editorRef.current = editor;
95
+ }}
96
+ onChange={(e) => onChange?.(e.value)}
97
+ >
98
+ {activeLinePlaceholder && (
99
+ <ActiveLinePlaceholder>{activeLinePlaceholder}</ActiveLinePlaceholder>
100
+ )}
101
+ {children}
102
+ </OriginCodeEditor>
103
+ </EditorProvider>
104
+ </UIContainer>
88
105
  );
89
106
  }
@@ -0,0 +1,61 @@
1
+ /**
2
+ * Copyright (c) 2025 Bytedance Ltd. and/or its affiliates
3
+ * SPDX-License-Identifier: MIT
4
+ */
5
+
6
+ import { useEffect, useMemo, useState } from 'react';
7
+ import React from 'react';
8
+
9
+ import { languages } from '@flowgram.ai/coze-editor/preset-code';
10
+ import { Skeleton } from '@douyinfe/semi-ui';
11
+
12
+ import { lazySuspense } from '@/shared';
13
+
14
+ import type { CodeEditorPropsType } from './editor';
15
+
16
+ export const BaseCodeEditor = lazySuspense(() =>
17
+ Promise.all([import('./editor'), import('./theme')]).then(([editorModule]) => ({
18
+ default: editorModule.BaseCodeEditor,
19
+ }))
20
+ );
21
+
22
+ interface FactoryParams<FixLanguageId extends boolean> {
23
+ displayName: string;
24
+ fixLanguageId: FixLanguageId extends true ? CodeEditorPropsType['languageId'] : undefined;
25
+ }
26
+
27
+ export const CodeEditorFactory = <FixLanguageId extends boolean>(
28
+ loadLanguage: (languageId: string) => Promise<any>,
29
+ { displayName, fixLanguageId }: FactoryParams<FixLanguageId>
30
+ ): FixLanguageId extends true
31
+ ? React.FC<Omit<CodeEditorPropsType, 'languageId'>>
32
+ : React.FC<CodeEditorPropsType> => {
33
+ const EditorWithLoad = (props: CodeEditorPropsType) => {
34
+ const { languageId = fixLanguageId } = props;
35
+
36
+ if (!languageId) {
37
+ throw new Error('CodeEditorFactory: languageId is required');
38
+ }
39
+
40
+ const [loaded, setLoaded] = useState(useMemo(() => !!languages.get(languageId), [languageId]));
41
+
42
+ useEffect(() => {
43
+ if (!loaded && loadLanguage) {
44
+ loadLanguage(languageId).then(() => {
45
+ setLoaded(true);
46
+ });
47
+ }
48
+ }, [languageId, loaded]);
49
+
50
+ if (!loaded) {
51
+ return <Skeleton />;
52
+ }
53
+
54
+ return <BaseCodeEditor {...props} languageId={fixLanguageId || languageId} />;
55
+ };
56
+ EditorWithLoad.displayName = displayName;
57
+
58
+ return EditorWithLoad as FixLanguageId extends true
59
+ ? React.FC<Omit<CodeEditorPropsType, 'languageId'>>
60
+ : React.FC<CodeEditorPropsType>;
61
+ };
@@ -3,10 +3,10 @@
3
3
  * SPDX-License-Identifier: MIT
4
4
  */
5
5
 
6
- import { lazySuspense } from '@/shared';
7
-
8
- export const CodeEditor = lazySuspense(() =>
9
- import('./editor').then((module) => ({ default: module.CodeEditor }))
10
- );
11
-
12
- export type { CodeEditorPropsType } from './editor';
6
+ export { CodeEditor } from './editor-all';
7
+ export { TypeScriptCodeEditor } from './editor-ts';
8
+ export { ShellCodeEditor } from './editor-shell';
9
+ export { JsonCodeEditor } from './editor-json';
10
+ export { SQLCodeEditor } from './editor-sql';
11
+ export { PythonCodeEditor } from './editor-python';
12
+ export { BaseCodeEditor, type CodeEditorPropsType } from './editor';
@@ -3,31 +3,48 @@
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
- const colors = {
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',
9
+ export const colors = {
10
+ background: '#24292e',
11
+ foreground: '#d1d5da',
12
+ selection: '#3392FF44',
13
+ cursor: '#c8e1ff',
14
+ dropdownBackground: '#24292e',
15
+ dropdownBorder: '#1b1f23',
16
+ activeLine: '#4d566022',
17
+ matchingBracket: '#888892',
18
+ keyword: '#9197F1',
19
+ storage: '#f97583',
20
+ variable: '#ffab70',
21
+ variableName: '#D9DCFA',
22
+ parameter: '#e1e4e8',
23
+ function: '#FFCA66',
24
+ string: '#FF9878',
25
+ constant: '#79b8ff',
26
+ type: '#79b8ff',
27
+ class: '#b392f0',
28
+ number: '#2EC7D9',
29
+ comment: '#568B2A',
30
+ heading: '#79b8ff',
31
+ invalid: '#f97583',
32
+ regexp: '#9ecbff',
33
+ propertyName: '#9197F1',
34
+ separator: '#888892',
35
+ gutters: '#888892',
36
+ moduleKeyword: '#CC4FD4',
20
37
  };
21
38
 
22
39
  export const darkTheme: Extension = createTheme({
23
40
  variant: 'dark',
24
41
  settings: {
25
42
  background: colors.background,
26
- foreground: '#E6EDF3',
27
- caret: '#7DD3FC',
28
- selection: '#264F7833',
43
+ foreground: colors.foreground,
44
+ caret: colors.cursor,
45
+ selection: colors.selection,
29
46
  gutterBackground: colors.background,
30
- gutterForeground: '#6E7681',
47
+ gutterForeground: colors.foreground,
31
48
  gutterBorderColor: 'transparent',
32
49
  gutterBorderWidth: 0,
33
50
  lineHighlight: '#21262D',
@@ -44,7 +61,8 @@ export const darkTheme: Extension = createTheme({
44
61
  backgroundColor: '#21262D',
45
62
  },
46
63
  completionItemSelected: {
47
- backgroundColor: '#1F6EEB',
64
+ backgroundColor: colors.selection,
65
+ color: colors.foreground,
48
66
  },
49
67
  completionItemIcon: {
50
68
  color: '#8B949E',
@@ -60,79 +78,46 @@ export const darkTheme: Extension = createTheme({
60
78
  },
61
79
  },
62
80
  styles: [
63
- // json
81
+ { tag: t.keyword, color: colors.keyword },
82
+ { tag: t.variableName, color: colors.variableName },
64
83
  {
65
- tag: t.comment,
66
- color: colors.comment,
84
+ tag: [t.name, t.deleted, t.character, t.macroName],
85
+ color: colors.variable,
67
86
  },
87
+ { tag: [t.propertyName], color: colors.propertyName },
68
88
  {
69
- tag: [t.propertyName],
70
- color: colors.key,
71
- },
72
- {
73
- tag: [t.string],
89
+ tag: [t.processingInstruction, t.string, t.inserted, t.special(t.string)],
74
90
  color: colors.string,
75
91
  },
76
92
  {
77
- tag: [t.number],
78
- color: colors.number,
93
+ tag: [t.function(t.variableName), t.function(t.propertyName), t.labelName],
94
+ color: colors.function,
79
95
  },
80
96
  {
81
- tag: [t.bool],
82
- color: colors.boolean,
97
+ tag: [t.moduleKeyword, t.controlKeyword],
98
+ color: colors.moduleKeyword,
83
99
  },
84
100
  {
85
- tag: [t.null],
86
- color: colors.null,
101
+ tag: [t.color, t.constant(t.name), t.standard(t.name)],
102
+ color: colors.constant,
87
103
  },
104
+ { tag: t.definition(t.name), color: colors.variable },
105
+ { tag: [t.className], color: colors.class },
88
106
  {
89
- tag: [t.separator],
90
- color: colors.separator,
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
-
111
- // markdown
112
- {
113
- tag: [t.heading],
114
- color: '#7DD3FC',
115
- },
116
- {
117
- tag: [t.processingInstruction],
118
- color: '#7DD3FC',
119
- },
120
-
121
- // shell
122
- // curl
123
- {
124
- tag: [t.standard(t.variableName)],
125
- color: '#34D399',
126
- },
127
- // -X
128
- {
129
- tag: [t.attributeName],
130
- color: '#FBBF24',
131
- },
132
- // url in string (includes quotes), e.g. "https://..."
133
- {
134
- tag: [t.special(t.string)],
135
- color: '#7DD3FC',
107
+ tag: [t.number, t.changed, t.annotation, t.modifier, t.self, t.namespace],
108
+ color: colors.number,
136
109
  },
110
+ { tag: [t.typeName], color: colors.type, fontStyle: colors.type },
111
+ { tag: [t.operatorKeyword], color: colors.keyword },
112
+ { tag: [t.url, t.escape, t.regexp, t.link], color: colors.regexp },
113
+ { tag: [t.meta, t.comment], color: colors.comment },
114
+ { tag: t.strong, fontWeight: 'bold' },
115
+ { tag: t.emphasis, fontStyle: 'italic' },
116
+ { tag: t.link, textDecoration: 'underline' },
117
+ { tag: t.heading, fontWeight: 'bold', color: colors.heading },
118
+ { tag: [t.atom, t.bool, t.special(t.variableName)], color: colors.variable },
119
+ { tag: t.invalid, color: colors.invalid },
120
+ { tag: t.strikethrough, textDecoration: 'line-through' },
121
+ { tag: t.separator, color: colors.separator },
137
122
  ],
138
123
  });
@@ -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';