@gravity-ui/page-constructor 8.5.0-alpha.1 → 8.5.0-alpha.4

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 (258) hide show
  1. package/build/cjs/containers/PageConstructor/PageConstructor.d.ts +0 -1
  2. package/build/cjs/containers/PageConstructor/PageConstructor.js +0 -1
  3. package/build/cjs/containers/PageConstructor/PageConstructor.js.map +1 -1
  4. package/build/cjs/form-builder-v2/CanvasContentContext.d.ts +18 -0
  5. package/build/cjs/form-builder-v2/CanvasContentContext.js +21 -0
  6. package/build/cjs/form-builder-v2/CanvasContentContext.js.map +1 -0
  7. package/build/cjs/form-builder-v2/FormBuilderV2.css +93 -0
  8. package/build/cjs/form-builder-v2/FormBuilderV2.d.ts +10 -0
  9. package/build/cjs/form-builder-v2/FormBuilderV2.js +123 -0
  10. package/build/cjs/form-builder-v2/FormBuilderV2.js.map +1 -0
  11. package/build/cjs/form-builder-v2/components/Canvas/Canvas.css +15 -0
  12. package/build/cjs/form-builder-v2/components/Canvas/Canvas.d.ts +8 -0
  13. package/build/cjs/form-builder-v2/components/Canvas/Canvas.js +17 -0
  14. package/build/cjs/form-builder-v2/components/Canvas/Canvas.js.map +1 -0
  15. package/build/cjs/form-builder-v2/components/CanvasCard/CanvasCard.css +133 -0
  16. package/build/cjs/form-builder-v2/components/CanvasCard/CanvasCard.d.ts +9 -0
  17. package/build/cjs/form-builder-v2/components/CanvasCard/CanvasCard.js +72 -0
  18. package/build/cjs/form-builder-v2/components/CanvasCard/CanvasCard.js.map +1 -0
  19. package/build/cjs/form-builder-v2/components/CanvasCard/components/FieldPreview.d.ts +6 -0
  20. package/build/cjs/form-builder-v2/components/CanvasCard/components/FieldPreview.js +44 -0
  21. package/build/cjs/form-builder-v2/components/CanvasCard/components/FieldPreview.js.map +1 -0
  22. package/build/cjs/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.d.ts +9 -0
  23. package/build/cjs/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.js +20 -0
  24. package/build/cjs/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.js.map +1 -0
  25. package/build/cjs/form-builder-v2/components/ContentTab/ContentTab.css +22 -0
  26. package/build/cjs/form-builder-v2/components/ContentTab/ContentTab.d.ts +1 -0
  27. package/build/cjs/form-builder-v2/components/ContentTab/ContentTab.js +21 -0
  28. package/build/cjs/form-builder-v2/components/ContentTab/ContentTab.js.map +1 -0
  29. package/build/cjs/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.css +13 -0
  30. package/build/cjs/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.d.ts +7 -0
  31. package/build/cjs/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.js +24 -0
  32. package/build/cjs/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.js.map +1 -0
  33. package/build/cjs/form-builder-v2/components/FieldSettings/FieldSettings.css +30 -0
  34. package/build/cjs/form-builder-v2/components/FieldSettings/FieldSettings.d.ts +6 -0
  35. package/build/cjs/form-builder-v2/components/FieldSettings/FieldSettings.js +49 -0
  36. package/build/cjs/form-builder-v2/components/FieldSettings/FieldSettings.js.map +1 -0
  37. package/build/cjs/form-builder-v2/components/FieldSettings/fields/ColorInputSettings.d.ts +12 -0
  38. package/build/cjs/form-builder-v2/components/FieldSettings/fields/ColorInputSettings.js +11 -0
  39. package/build/cjs/form-builder-v2/components/FieldSettings/fields/ColorInputSettings.js.map +1 -0
  40. package/build/cjs/form-builder-v2/components/FieldSettings/fields/OptionsSettings.d.ts +12 -0
  41. package/build/cjs/form-builder-v2/components/FieldSettings/fields/OptionsSettings.js +38 -0
  42. package/build/cjs/form-builder-v2/components/FieldSettings/fields/OptionsSettings.js.map +1 -0
  43. package/build/cjs/form-builder-v2/components/FieldSettings/fields/Row.d.ts +7 -0
  44. package/build/cjs/form-builder-v2/components/FieldSettings/fields/Row.js +9 -0
  45. package/build/cjs/form-builder-v2/components/FieldSettings/fields/Row.js.map +1 -0
  46. package/build/cjs/form-builder-v2/components/FieldSettings/fields/SectionSettings.d.ts +9 -0
  47. package/build/cjs/form-builder-v2/components/FieldSettings/fields/SectionSettings.js +40 -0
  48. package/build/cjs/form-builder-v2/components/FieldSettings/fields/SectionSettings.js.map +1 -0
  49. package/build/cjs/form-builder-v2/components/FieldSettings/fields/SwitchSettings.d.ts +12 -0
  50. package/build/cjs/form-builder-v2/components/FieldSettings/fields/SwitchSettings.js +11 -0
  51. package/build/cjs/form-builder-v2/components/FieldSettings/fields/SwitchSettings.js.map +1 -0
  52. package/build/cjs/form-builder-v2/components/FieldSettings/fields/TextFieldSettings.d.ts +12 -0
  53. package/build/cjs/form-builder-v2/components/FieldSettings/fields/TextFieldSettings.js +11 -0
  54. package/build/cjs/form-builder-v2/components/FieldSettings/fields/TextFieldSettings.js.map +1 -0
  55. package/build/cjs/form-builder-v2/components/FieldSettings/fields/TextSettings.d.ts +11 -0
  56. package/build/cjs/form-builder-v2/components/FieldSettings/fields/TextSettings.js +53 -0
  57. package/build/cjs/form-builder-v2/components/FieldSettings/fields/TextSettings.js.map +1 -0
  58. package/build/cjs/form-builder-v2/components/Inspector/Inspector.css +20 -0
  59. package/build/cjs/form-builder-v2/components/Inspector/Inspector.d.ts +1 -0
  60. package/build/cjs/form-builder-v2/components/Inspector/Inspector.js +20 -0
  61. package/build/cjs/form-builder-v2/components/Inspector/Inspector.js.map +1 -0
  62. package/build/cjs/form-builder-v2/components/Palette/Palette.css +56 -0
  63. package/build/cjs/form-builder-v2/components/Palette/Palette.d.ts +4 -0
  64. package/build/cjs/form-builder-v2/components/Palette/Palette.js +62 -0
  65. package/build/cjs/form-builder-v2/components/Palette/Palette.js.map +1 -0
  66. package/build/cjs/form-builder-v2/components/ResizeHandle/ResizeHandle.css +29 -0
  67. package/build/cjs/form-builder-v2/components/ResizeHandle/ResizeHandle.d.ts +9 -0
  68. package/build/cjs/form-builder-v2/components/ResizeHandle/ResizeHandle.js +98 -0
  69. package/build/cjs/form-builder-v2/components/ResizeHandle/ResizeHandle.js.map +1 -0
  70. package/build/cjs/form-builder-v2/components/SchemaPopup/SchemaPopup.css +49 -0
  71. package/build/cjs/form-builder-v2/components/SchemaPopup/SchemaPopup.d.ts +11 -0
  72. package/build/cjs/form-builder-v2/components/SchemaPopup/SchemaPopup.js +82 -0
  73. package/build/cjs/form-builder-v2/components/SchemaPopup/SchemaPopup.js.map +1 -0
  74. package/build/cjs/form-builder-v2/components/WhenEditor/WhenEditor.css +24 -0
  75. package/build/cjs/form-builder-v2/components/WhenEditor/WhenEditor.d.ts +8 -0
  76. package/build/cjs/form-builder-v2/components/WhenEditor/WhenEditor.js +50 -0
  77. package/build/cjs/form-builder-v2/components/WhenEditor/WhenEditor.js.map +1 -0
  78. package/build/cjs/form-builder-v2/components/WhenEditor/utils.d.ts +24 -0
  79. package/build/cjs/form-builder-v2/components/WhenEditor/utils.js +83 -0
  80. package/build/cjs/form-builder-v2/components/WhenEditor/utils.js.map +1 -0
  81. package/build/cjs/form-builder-v2/hooks/FormContext.d.ts +11 -0
  82. package/build/cjs/form-builder-v2/hooks/FormContext.js +22 -0
  83. package/build/cjs/form-builder-v2/hooks/FormContext.js.map +1 -0
  84. package/build/cjs/form-builder-v2/hooks/useFormFields.d.ts +23 -0
  85. package/build/cjs/form-builder-v2/hooks/useFormFields.js +144 -0
  86. package/build/cjs/form-builder-v2/hooks/useFormFields.js.map +1 -0
  87. package/build/cjs/form-builder-v2/index.d.ts +2 -0
  88. package/build/cjs/form-builder-v2/index.js +6 -0
  89. package/build/cjs/form-builder-v2/index.js.map +1 -0
  90. package/build/cjs/form-builder-v2/styles/variables.css +0 -0
  91. package/build/cjs/form-builder-v2/types.d.ts +32 -0
  92. package/build/cjs/form-builder-v2/types.js +3 -0
  93. package/build/cjs/form-builder-v2/types.js.map +1 -0
  94. package/build/cjs/form-builder-v2/utils/cn.d.ts +2 -0
  95. package/build/cjs/form-builder-v2/utils/cn.js +7 -0
  96. package/build/cjs/form-builder-v2/utils/cn.js.map +1 -0
  97. package/build/cjs/form-builder-v2/utils/dragData.d.ts +18 -0
  98. package/build/cjs/form-builder-v2/utils/dragData.js +18 -0
  99. package/build/cjs/form-builder-v2/utils/dragData.js.map +1 -0
  100. package/build/cjs/form-builder-v2/utils/fieldDefaults.d.ts +2 -0
  101. package/build/cjs/form-builder-v2/utils/fieldDefaults.js +51 -0
  102. package/build/cjs/form-builder-v2/utils/fieldDefaults.js.map +1 -0
  103. package/build/cjs/form-builder-v2/utils/fieldGroups.d.ts +3 -0
  104. package/build/cjs/form-builder-v2/utils/fieldGroups.js +26 -0
  105. package/build/cjs/form-builder-v2/utils/fieldGroups.js.map +1 -0
  106. package/build/cjs/form-builder-v2/utils/fieldMeta.d.ts +6 -0
  107. package/build/cjs/form-builder-v2/utils/fieldMeta.js +45 -0
  108. package/build/cjs/form-builder-v2/utils/fieldMeta.js.map +1 -0
  109. package/build/cjs/form-builder-v2/utils/fieldNames.d.ts +8 -0
  110. package/build/cjs/form-builder-v2/utils/fieldNames.js +75 -0
  111. package/build/cjs/form-builder-v2/utils/fieldNames.js.map +1 -0
  112. package/build/cjs/form-builder-v2/utils/fieldTree.d.ts +2 -0
  113. package/build/cjs/form-builder-v2/utils/fieldTree.js +7 -0
  114. package/build/cjs/form-builder-v2/utils/fieldTree.js.map +1 -0
  115. package/build/cjs/form-builder-v2/utils/fieldTreeOps.d.ts +13 -0
  116. package/build/cjs/form-builder-v2/utils/fieldTreeOps.js +80 -0
  117. package/build/cjs/form-builder-v2/utils/fieldTreeOps.js.map +1 -0
  118. package/build/cjs/form-builder-v2/utils/parseSchema.d.ts +9 -0
  119. package/build/cjs/form-builder-v2/utils/parseSchema.js +102 -0
  120. package/build/cjs/form-builder-v2/utils/parseSchema.js.map +1 -0
  121. package/build/cjs/form-builder-v2/utils/stripIds.d.ts +3 -0
  122. package/build/cjs/form-builder-v2/utils/stripIds.js +12 -0
  123. package/build/cjs/form-builder-v2/utils/stripIds.js.map +1 -0
  124. package/build/cjs/form-builder-v2/utils/treeWalk.d.ts +4 -0
  125. package/build/cjs/form-builder-v2/utils/treeWalk.js +45 -0
  126. package/build/cjs/form-builder-v2/utils/treeWalk.js.map +1 -0
  127. package/build/cjs/hooks/usePCEditorInitializeEvents.js +2 -2
  128. package/build/cjs/hooks/usePCEditorInitializeEvents.js.map +1 -1
  129. package/build/esm/containers/PageConstructor/PageConstructor.d.ts +0 -1
  130. package/build/esm/containers/PageConstructor/PageConstructor.js +0 -1
  131. package/build/esm/containers/PageConstructor/PageConstructor.js.map +1 -1
  132. package/build/esm/form-builder-v2/CanvasContentContext.d.ts +18 -0
  133. package/build/esm/form-builder-v2/CanvasContentContext.js +15 -0
  134. package/build/esm/form-builder-v2/CanvasContentContext.js.map +1 -0
  135. package/build/esm/form-builder-v2/FormBuilderV2.css +93 -0
  136. package/build/esm/form-builder-v2/FormBuilderV2.d.ts +11 -0
  137. package/build/esm/form-builder-v2/FormBuilderV2.js +119 -0
  138. package/build/esm/form-builder-v2/FormBuilderV2.js.map +1 -0
  139. package/build/esm/form-builder-v2/components/Canvas/Canvas.css +15 -0
  140. package/build/esm/form-builder-v2/components/Canvas/Canvas.d.ts +9 -0
  141. package/build/esm/form-builder-v2/components/Canvas/Canvas.js +14 -0
  142. package/build/esm/form-builder-v2/components/Canvas/Canvas.js.map +1 -0
  143. package/build/esm/form-builder-v2/components/CanvasCard/CanvasCard.css +133 -0
  144. package/build/esm/form-builder-v2/components/CanvasCard/CanvasCard.d.ts +10 -0
  145. package/build/esm/form-builder-v2/components/CanvasCard/CanvasCard.js +68 -0
  146. package/build/esm/form-builder-v2/components/CanvasCard/CanvasCard.js.map +1 -0
  147. package/build/esm/form-builder-v2/components/CanvasCard/components/FieldPreview.d.ts +6 -0
  148. package/build/esm/form-builder-v2/components/CanvasCard/components/FieldPreview.js +39 -0
  149. package/build/esm/form-builder-v2/components/CanvasCard/components/FieldPreview.js.map +1 -0
  150. package/build/esm/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.d.ts +9 -0
  151. package/build/esm/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.js +16 -0
  152. package/build/esm/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.js.map +1 -0
  153. package/build/esm/form-builder-v2/components/ContentTab/ContentTab.css +22 -0
  154. package/build/esm/form-builder-v2/components/ContentTab/ContentTab.d.ts +2 -0
  155. package/build/esm/form-builder-v2/components/ContentTab/ContentTab.js +17 -0
  156. package/build/esm/form-builder-v2/components/ContentTab/ContentTab.js.map +1 -0
  157. package/build/esm/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.css +13 -0
  158. package/build/esm/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.d.ts +8 -0
  159. package/build/esm/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.js +21 -0
  160. package/build/esm/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.js.map +1 -0
  161. package/build/esm/form-builder-v2/components/FieldSettings/FieldSettings.css +30 -0
  162. package/build/esm/form-builder-v2/components/FieldSettings/FieldSettings.d.ts +7 -0
  163. package/build/esm/form-builder-v2/components/FieldSettings/FieldSettings.js +45 -0
  164. package/build/esm/form-builder-v2/components/FieldSettings/FieldSettings.js.map +1 -0
  165. package/build/esm/form-builder-v2/components/FieldSettings/fields/ColorInputSettings.d.ts +12 -0
  166. package/build/esm/form-builder-v2/components/FieldSettings/fields/ColorInputSettings.js +6 -0
  167. package/build/esm/form-builder-v2/components/FieldSettings/fields/ColorInputSettings.js.map +1 -0
  168. package/build/esm/form-builder-v2/components/FieldSettings/fields/OptionsSettings.d.ts +12 -0
  169. package/build/esm/form-builder-v2/components/FieldSettings/fields/OptionsSettings.js +33 -0
  170. package/build/esm/form-builder-v2/components/FieldSettings/fields/OptionsSettings.js.map +1 -0
  171. package/build/esm/form-builder-v2/components/FieldSettings/fields/Row.d.ts +7 -0
  172. package/build/esm/form-builder-v2/components/FieldSettings/fields/Row.js +5 -0
  173. package/build/esm/form-builder-v2/components/FieldSettings/fields/Row.js.map +1 -0
  174. package/build/esm/form-builder-v2/components/FieldSettings/fields/SectionSettings.d.ts +9 -0
  175. package/build/esm/form-builder-v2/components/FieldSettings/fields/SectionSettings.js +35 -0
  176. package/build/esm/form-builder-v2/components/FieldSettings/fields/SectionSettings.js.map +1 -0
  177. package/build/esm/form-builder-v2/components/FieldSettings/fields/SwitchSettings.d.ts +12 -0
  178. package/build/esm/form-builder-v2/components/FieldSettings/fields/SwitchSettings.js +6 -0
  179. package/build/esm/form-builder-v2/components/FieldSettings/fields/SwitchSettings.js.map +1 -0
  180. package/build/esm/form-builder-v2/components/FieldSettings/fields/TextFieldSettings.d.ts +12 -0
  181. package/build/esm/form-builder-v2/components/FieldSettings/fields/TextFieldSettings.js +6 -0
  182. package/build/esm/form-builder-v2/components/FieldSettings/fields/TextFieldSettings.js.map +1 -0
  183. package/build/esm/form-builder-v2/components/FieldSettings/fields/TextSettings.d.ts +11 -0
  184. package/build/esm/form-builder-v2/components/FieldSettings/fields/TextSettings.js +48 -0
  185. package/build/esm/form-builder-v2/components/FieldSettings/fields/TextSettings.js.map +1 -0
  186. package/build/esm/form-builder-v2/components/Inspector/Inspector.css +20 -0
  187. package/build/esm/form-builder-v2/components/Inspector/Inspector.d.ts +2 -0
  188. package/build/esm/form-builder-v2/components/Inspector/Inspector.js +16 -0
  189. package/build/esm/form-builder-v2/components/Inspector/Inspector.js.map +1 -0
  190. package/build/esm/form-builder-v2/components/Palette/Palette.css +56 -0
  191. package/build/esm/form-builder-v2/components/Palette/Palette.d.ts +5 -0
  192. package/build/esm/form-builder-v2/components/Palette/Palette.js +58 -0
  193. package/build/esm/form-builder-v2/components/Palette/Palette.js.map +1 -0
  194. package/build/esm/form-builder-v2/components/ResizeHandle/ResizeHandle.css +29 -0
  195. package/build/esm/form-builder-v2/components/ResizeHandle/ResizeHandle.d.ts +10 -0
  196. package/build/esm/form-builder-v2/components/ResizeHandle/ResizeHandle.js +94 -0
  197. package/build/esm/form-builder-v2/components/ResizeHandle/ResizeHandle.js.map +1 -0
  198. package/build/esm/form-builder-v2/components/SchemaPopup/SchemaPopup.css +49 -0
  199. package/build/esm/form-builder-v2/components/SchemaPopup/SchemaPopup.d.ts +12 -0
  200. package/build/esm/form-builder-v2/components/SchemaPopup/SchemaPopup.js +78 -0
  201. package/build/esm/form-builder-v2/components/SchemaPopup/SchemaPopup.js.map +1 -0
  202. package/build/esm/form-builder-v2/components/WhenEditor/WhenEditor.css +24 -0
  203. package/build/esm/form-builder-v2/components/WhenEditor/WhenEditor.d.ts +9 -0
  204. package/build/esm/form-builder-v2/components/WhenEditor/WhenEditor.js +46 -0
  205. package/build/esm/form-builder-v2/components/WhenEditor/WhenEditor.js.map +1 -0
  206. package/build/esm/form-builder-v2/components/WhenEditor/utils.d.ts +24 -0
  207. package/build/esm/form-builder-v2/components/WhenEditor/utils.js +76 -0
  208. package/build/esm/form-builder-v2/components/WhenEditor/utils.js.map +1 -0
  209. package/build/esm/form-builder-v2/hooks/FormContext.d.ts +11 -0
  210. package/build/esm/form-builder-v2/hooks/FormContext.js +16 -0
  211. package/build/esm/form-builder-v2/hooks/FormContext.js.map +1 -0
  212. package/build/esm/form-builder-v2/hooks/useFormFields.d.ts +23 -0
  213. package/build/esm/form-builder-v2/hooks/useFormFields.js +139 -0
  214. package/build/esm/form-builder-v2/hooks/useFormFields.js.map +1 -0
  215. package/build/esm/form-builder-v2/index.d.ts +2 -0
  216. package/build/esm/form-builder-v2/index.js +3 -0
  217. package/build/esm/form-builder-v2/index.js.map +1 -0
  218. package/build/esm/form-builder-v2/styles/variables.css +0 -0
  219. package/build/esm/form-builder-v2/types.d.ts +32 -0
  220. package/build/esm/form-builder-v2/types.js +2 -0
  221. package/build/esm/form-builder-v2/types.js.map +1 -0
  222. package/build/esm/form-builder-v2/utils/cn.d.ts +2 -0
  223. package/build/esm/form-builder-v2/utils/cn.js +4 -0
  224. package/build/esm/form-builder-v2/utils/cn.js.map +1 -0
  225. package/build/esm/form-builder-v2/utils/dragData.d.ts +18 -0
  226. package/build/esm/form-builder-v2/utils/dragData.js +11 -0
  227. package/build/esm/form-builder-v2/utils/dragData.js.map +1 -0
  228. package/build/esm/form-builder-v2/utils/fieldDefaults.d.ts +2 -0
  229. package/build/esm/form-builder-v2/utils/fieldDefaults.js +47 -0
  230. package/build/esm/form-builder-v2/utils/fieldDefaults.js.map +1 -0
  231. package/build/esm/form-builder-v2/utils/fieldGroups.d.ts +3 -0
  232. package/build/esm/form-builder-v2/utils/fieldGroups.js +21 -0
  233. package/build/esm/form-builder-v2/utils/fieldGroups.js.map +1 -0
  234. package/build/esm/form-builder-v2/utils/fieldMeta.d.ts +6 -0
  235. package/build/esm/form-builder-v2/utils/fieldMeta.js +42 -0
  236. package/build/esm/form-builder-v2/utils/fieldMeta.js.map +1 -0
  237. package/build/esm/form-builder-v2/utils/fieldNames.d.ts +8 -0
  238. package/build/esm/form-builder-v2/utils/fieldNames.js +66 -0
  239. package/build/esm/form-builder-v2/utils/fieldNames.js.map +1 -0
  240. package/build/esm/form-builder-v2/utils/fieldTree.d.ts +2 -0
  241. package/build/esm/form-builder-v2/utils/fieldTree.js +3 -0
  242. package/build/esm/form-builder-v2/utils/fieldTree.js.map +1 -0
  243. package/build/esm/form-builder-v2/utils/fieldTreeOps.d.ts +13 -0
  244. package/build/esm/form-builder-v2/utils/fieldTreeOps.js +69 -0
  245. package/build/esm/form-builder-v2/utils/fieldTreeOps.js.map +1 -0
  246. package/build/esm/form-builder-v2/utils/parseSchema.d.ts +9 -0
  247. package/build/esm/form-builder-v2/utils/parseSchema.js +98 -0
  248. package/build/esm/form-builder-v2/utils/parseSchema.js.map +1 -0
  249. package/build/esm/form-builder-v2/utils/stripIds.d.ts +3 -0
  250. package/build/esm/form-builder-v2/utils/stripIds.js +8 -0
  251. package/build/esm/form-builder-v2/utils/stripIds.js.map +1 -0
  252. package/build/esm/form-builder-v2/utils/treeWalk.d.ts +4 -0
  253. package/build/esm/form-builder-v2/utils/treeWalk.js +39 -0
  254. package/build/esm/form-builder-v2/utils/treeWalk.js.map +1 -0
  255. package/build/esm/hooks/usePCEditorInitializeEvents.js +2 -2
  256. package/build/esm/hooks/usePCEditorInitializeEvents.js.map +1 -1
  257. package/package.json +13 -1
  258. package/widget/index.js +1 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parseSchema.js","sourceRoot":"../../../../src","sources":["form-builder-v2/utils/parseSchema.ts"],"names":[],"mappings":"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","sourcesContent":["import type {FormField} from '../types';\n\nconst VALID_TYPES = new Set([\n 'textInput',\n 'textArea',\n 'select',\n 'segmentedRadioGroup',\n 'switch',\n 'colorInput',\n 'text',\n 'section',\n]);\n\nexport type ParseSchemaResult = {ok: true; fields: FormField[]} | {ok: false; error: string};\n\nconst TYPES_REQUIRING_NAME = new Set([\n 'textInput',\n 'textArea',\n 'select',\n 'segmentedRadioGroup',\n 'switch',\n 'colorInput',\n]);\n\nconst TYPES_WITH_OPTIONS = new Set(['select', 'segmentedRadioGroup']);\n\nconst validateField = (obj: Record<string, unknown>, here: string): void => {\n const type = obj.type as string;\n\n if (TYPES_REQUIRING_NAME.has(type) && typeof obj.name !== 'string') {\n throw new Error(`${here}: field of type \"${type}\" requires \"name\"`);\n }\n\n if (TYPES_WITH_OPTIONS.has(type)) {\n if (!Array.isArray(obj.options) || obj.options.length === 0) {\n throw new Error(`${here}: field of type \"${type}\" requires non-empty \"options\" array`);\n }\n obj.options.forEach((opt: unknown, i) => {\n if (!opt || typeof opt !== 'object') {\n throw new Error(`${here}.options[${i}]: expected object`);\n }\n const o = opt as Record<string, unknown>;\n if (typeof o.value !== 'string' || typeof o.content !== 'string') {\n throw new Error(`${here}.options[${i}]: \"value\" and \"content\" must be strings`);\n }\n });\n }\n\n if (type === 'text' && typeof obj.text !== 'string') {\n throw new Error(`${here}: field of type \"text\" requires \"text\" string`);\n }\n};\n\nconst validateAndAssignIds = (raw: unknown[], path: string, nextId: () => string): FormField[] => {\n const seenNames = new Set<string>();\n return raw.map((item, i) => {\n const here = `${path}[${i}]`;\n if (!item || typeof item !== 'object') {\n throw new Error(`${here}: expected object, got ${typeof item}`);\n }\n const obj = item as Record<string, unknown>;\n if (typeof obj.type !== 'string' || !VALID_TYPES.has(obj.type)) {\n throw new Error(`${here}: unknown field type \"${String(obj.type)}\"`);\n }\n validateField(obj, here);\n if (typeof obj.name === 'string') {\n if (seenNames.has(obj.name)) {\n throw new Error(`${here}: duplicate name \"${obj.name}\"`);\n }\n seenNames.add(obj.name);\n }\n if (obj.type === 'section') {\n const nested = Array.isArray(obj.fields)\n ? validateAndAssignIds(obj.fields, `${here}.fields`, nextId)\n : [];\n return {...obj, id: nextId(), fields: nested} as FormField;\n }\n return {...obj, id: nextId()} as FormField;\n });\n};\n\nexport const parseSchema = (input: string): ParseSchemaResult => {\n const trimmed = input.trim();\n if (!trimmed) {\n return {ok: false, error: 'Schema is empty'};\n }\n let parsed: unknown;\n try {\n parsed = JSON.parse(trimmed);\n } catch (e) {\n return {ok: false, error: `JSON parse error: ${(e as Error).message}`};\n }\n if (!Array.isArray(parsed)) {\n return {ok: false, error: 'Schema must be a JSON array of fields'};\n }\n let counter = 0;\n const nextId = () => {\n counter += 1;\n return `imp_${counter}`;\n };\n try {\n const fields = validateAndAssignIds(parsed, '', nextId);\n return {ok: true, fields};\n } catch (e) {\n return {ok: false, error: (e as Error).message};\n }\n};\n"]}
@@ -0,0 +1,3 @@
1
+ import type { Fields } from "../../form-generator-v2/types.js";
2
+ import type { FormField } from "../types.js";
3
+ export declare const stripIds: (fields: FormField[]) => Fields;
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.stripIds = void 0;
4
+ const stripIds = (fields) => fields.map((field) => {
5
+ const { id: _id, ...rest } = field;
6
+ if (rest.type === 'section') {
7
+ return { ...rest, fields: (0, exports.stripIds)(rest.fields) };
8
+ }
9
+ return rest;
10
+ });
11
+ exports.stripIds = stripIds;
12
+ //# sourceMappingURL=stripIds.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stripIds.js","sourceRoot":"../../../../src","sources":["form-builder-v2/utils/stripIds.ts"],"names":[],"mappings":";;;AAGO,MAAM,QAAQ,GAAG,CAAC,MAAmB,EAAU,EAAE,CACpD,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;IACjB,MAAM,EAAC,EAAE,EAAE,GAAG,EAAE,GAAG,IAAI,EAAC,GAAG,KAAK,CAAC;IACjC,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;QAC1B,OAAO,EAAC,GAAG,IAAI,EAAE,MAAM,EAAE,IAAA,gBAAQ,EAAC,IAAI,CAAC,MAAM,CAAC,EAAC,CAAC;IACpD,CAAC;IACD,OAAO,IAAI,CAAC;AAChB,CAAC,CAAW,CAAC;AAPJ,QAAA,QAAQ,YAOJ","sourcesContent":["import type {Fields} from '../../form-generator-v2/types';\nimport type {FormField} from '../types';\n\nexport const stripIds = (fields: FormField[]): Fields =>\n fields.map((field) => {\n const {id: _id, ...rest} = field;\n if (rest.type === 'section') {\n return {...rest, fields: stripIds(rest.fields)};\n }\n return rest;\n }) as Fields;\n"]}
@@ -0,0 +1,4 @@
1
+ import { BuilderSectionField, FormField } from "../types.js";
2
+ export declare const walkFields: (fields: FormField[], visit: (field: FormField) => void) => void;
3
+ export declare const findField: (fields: FormField[], predicate: (field: FormField) => boolean) => FormField | null;
4
+ export declare const transformAtId: (fields: FormField[], id: string, handler: (siblings: FormField[], index: number, parent: BuilderSectionField | null) => FormField[], parent?: BuilderSectionField | null) => FormField[] | null;
@@ -0,0 +1,45 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.transformAtId = exports.findField = exports.walkFields = void 0;
4
+ const walkFields = (fields, visit) => {
5
+ for (const field of fields) {
6
+ visit(field);
7
+ if (field.type === 'section') {
8
+ (0, exports.walkFields)(field.fields, visit);
9
+ }
10
+ }
11
+ };
12
+ exports.walkFields = walkFields;
13
+ const findField = (fields, predicate) => {
14
+ for (const field of fields) {
15
+ if (predicate(field))
16
+ return field;
17
+ if (field.type === 'section') {
18
+ const nested = (0, exports.findField)(field.fields, predicate);
19
+ if (nested)
20
+ return nested;
21
+ }
22
+ }
23
+ return null;
24
+ };
25
+ exports.findField = findField;
26
+ const transformAtId = (fields, id, handler, parent = null) => {
27
+ const index = fields.findIndex((field) => field.id === id);
28
+ if (index !== -1) {
29
+ return handler(fields, index, parent);
30
+ }
31
+ for (let i = 0; i < fields.length; i += 1) {
32
+ const field = fields[i];
33
+ if (field.type === 'section') {
34
+ const result = (0, exports.transformAtId)(field.fields, id, handler, field);
35
+ if (result !== null) {
36
+ const next = [...fields];
37
+ next[i] = { ...field, fields: result };
38
+ return next;
39
+ }
40
+ }
41
+ }
42
+ return null;
43
+ };
44
+ exports.transformAtId = transformAtId;
45
+ //# sourceMappingURL=treeWalk.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"treeWalk.js","sourceRoot":"../../../../src","sources":["form-builder-v2/utils/treeWalk.ts"],"names":[],"mappings":";;;AAEO,MAAM,UAAU,GAAG,CAAC,MAAmB,EAAE,KAAiC,EAAQ,EAAE;IACvF,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;QACzB,KAAK,CAAC,KAAK,CAAC,CAAC;QACb,IAAI,KAAK,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YAC3B,IAAA,kBAAU,EAAC,KAAK,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;QACpC,CAAC;IACL,CAAC;AACL,CAAC,CAAC;AAPW,QAAA,UAAU,cAOrB;AAEK,MAAM,SAAS,GAAG,CACrB,MAAmB,EACnB,SAAwC,EACxB,EAAE;IAClB,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;QACzB,IAAI,SAAS,CAAC,KAAK,CAAC;YAAE,OAAO,KAAK,CAAC;QACnC,IAAI,KAAK,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YAC3B,MAAM,MAAM,GAAG,IAAA,iBAAS,EAAC,KAAK,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;YAClD,IAAI,MAAM;gBAAE,OAAO,MAAM,CAAC;QAC9B,CAAC;IACL,CAAC;IACD,OAAO,IAAI,CAAC;AAChB,CAAC,CAAC;AAZW,QAAA,SAAS,aAYpB;AAEK,MAAM,aAAa,GAAG,CACzB,MAAmB,EACnB,EAAU,EACV,OAIgB,EAChB,SAAqC,IAAI,EACvB,EAAE;IACpB,MAAM,KAAK,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;IAC3D,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE,CAAC;QACf,OAAO,OAAO,CAAC,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;IAC1C,CAAC;IACD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;QACxC,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QACxB,IAAI,KAAK,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;YAC3B,MAAM,MAAM,GAAG,IAAA,qBAAa,EAAC,KAAK,CAAC,MAAM,EAAE,EAAE,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;YAC/D,IAAI,MAAM,KAAK,IAAI,EAAE,CAAC;gBAClB,MAAM,IAAI,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC;gBACzB,IAAI,CAAC,CAAC,CAAC,GAAG,EAAC,GAAG,KAAK,EAAE,MAAM,EAAE,MAAM,EAAC,CAAC;gBACrC,OAAO,IAAI,CAAC;YAChB,CAAC;QACL,CAAC;IACL,CAAC;IACD,OAAO,IAAI,CAAC;AAChB,CAAC,CAAC;AA1BW,QAAA,aAAa,iBA0BxB","sourcesContent":["import {BuilderSectionField, FormField} from '../types';\n\nexport const walkFields = (fields: FormField[], visit: (field: FormField) => void): void => {\n for (const field of fields) {\n visit(field);\n if (field.type === 'section') {\n walkFields(field.fields, visit);\n }\n }\n};\n\nexport const findField = (\n fields: FormField[],\n predicate: (field: FormField) => boolean,\n): FormField | null => {\n for (const field of fields) {\n if (predicate(field)) return field;\n if (field.type === 'section') {\n const nested = findField(field.fields, predicate);\n if (nested) return nested;\n }\n }\n return null;\n};\n\nexport const transformAtId = (\n fields: FormField[],\n id: string,\n handler: (\n siblings: FormField[],\n index: number,\n parent: BuilderSectionField | null,\n ) => FormField[],\n parent: BuilderSectionField | null = null,\n): FormField[] | null => {\n const index = fields.findIndex((field) => field.id === id);\n if (index !== -1) {\n return handler(fields, index, parent);\n }\n for (let i = 0; i < fields.length; i += 1) {\n const field = fields[i];\n if (field.type === 'section') {\n const result = transformAtId(field.fields, id, handler, field);\n if (result !== null) {\n const next = [...fields];\n next[i] = {...field, fields: result};\n return next;\n }\n }\n }\n return null;\n};\n"]}
@@ -39,7 +39,7 @@ const usePCEditorInitializeEvents = ({ initialContent, setContent, blocks, globa
39
39
  });
40
40
  });
41
41
  const onResize = React.useCallback(() => {
42
- const height = document.documentElement.getBoundingClientRect().height;
42
+ const height = document.body.scrollHeight;
43
43
  (0, usePostMessageAPI_1.sendEventPostMessage)('ON_RESIZE', { height });
44
44
  }, []);
45
45
  React.useEffect(() => {
@@ -83,7 +83,7 @@ const usePCEditorInitializeEvents = ({ initialContent, setContent, blocks, globa
83
83
  };
84
84
  }, [onResize]);
85
85
  React.useEffect(() => {
86
- const height = document.documentElement.getBoundingClientRect().height;
86
+ const height = document.body.scrollHeight;
87
87
  (0, usePostMessageAPI_1.sendEventPostMessage)('ON_INIT', { height });
88
88
  }, []);
89
89
  };
@@ -1 +1 @@
1
- {"version":3,"file":"usePCEditorInitializeEvents.js","sourceRoot":"../../../src","sources":["hooks/usePCEditorInitializeEvents.ts"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport _ from 'lodash';\n\nimport {toSerializableRect} from '../common/types/rect';\nimport {BlockData} from '../constructor-items';\nimport {BlockRegistry} from '../context/blockRegistryContext';\nimport {Fields} from '../form-generator-v2/types';\nimport {PageContent} from '../models';\n\nimport {usePCEditorStore} from './usePCEditorStore';\nimport {sendEventPostMessage, useInternalPostMessageAPIListener} from './usePostMessageAPI';\n\ninterface UseEditorInitializeProps {\n initialContent: PageContent;\n setContent: (content: PageContent) => void;\n blocks: Array<BlockData>;\n global?: Fields;\n blockInputs?: Fields;\n registry: BlockRegistry | null;\n}\n\nfunction collectRectMap(registry: BlockRegistry) {\n return registry.getEntries().map(({path, element, dropZone}) => {\n const rect = element.getClientRects().item(0) ?? element.getBoundingClientRect();\n return {path, rect: toSerializableRect(rect), dropZone};\n });\n}\n\nexport const usePCEditorInitializeEvents = ({\n initialContent,\n setContent,\n blocks,\n global,\n blockInputs,\n registry,\n}: UseEditorInitializeProps) => {\n const {initialized, content} = usePCEditorStore();\n\n React.useEffect(() => {\n if (initialized) {\n setContent(content);\n }\n }, [content, initialized, setContent]);\n\n useInternalPostMessageAPIListener('GET_INITIAL_CONTENT', () => {\n sendEventPostMessage('ON_INITIAL_CONTENT', initialContent);\n });\n\n useInternalPostMessageAPIListener('GET_SUPPORTED_BLOCKS', () => {\n sendEventPostMessage('ON_SUPPORTED_BLOCKS', {\n blocks: blocks.map((block) => ({\n type: block.type,\n schema: blockInputs?.length\n ? {\n ...block.schema,\n inputs: [...blockInputs, ...(block.schema?.inputs || [])],\n }\n : block.schema,\n })),\n subBlocks: [],\n global: global || [],\n });\n });\n\n const onResize = React.useCallback(() => {\n const height = document.documentElement.getBoundingClientRect().height;\n sendEventPostMessage('ON_RESIZE', {height});\n }, []);\n\n React.useEffect(() => {\n if (!registry) {\n return undefined;\n }\n\n let frame: number | null = null;\n\n const sendRectMap = () => {\n frame = null;\n sendEventPostMessage('ON_UPDATE_RECT_MAP', {rects: collectRectMap(registry)});\n };\n\n const scheduleSend = () => {\n if (frame !== null) {\n return;\n }\n frame = requestAnimationFrame(sendRectMap);\n };\n\n const throttledSchedule = _.throttle(scheduleSend, 100, {leading: true, trailing: true});\n\n const unsubscribe = registry.subscribe(throttledSchedule);\n const observer = new ResizeObserver(throttledSchedule);\n observer.observe(document.body);\n\n // Initial push once registry is ready.\n throttledSchedule();\n\n return () => {\n throttledSchedule.cancel();\n unsubscribe();\n observer.disconnect();\n if (frame !== null) {\n cancelAnimationFrame(frame);\n }\n };\n }, [registry]);\n\n React.useEffect(() => {\n window.addEventListener('resize', onResize);\n const observer = new ResizeObserver(onResize);\n observer.observe(document.documentElement);\n observer.observe(document.body);\n\n return () => {\n window.removeEventListener('resize', onResize);\n observer.disconnect();\n };\n }, [onResize]);\n\n React.useEffect(() => {\n const height = document.documentElement.getBoundingClientRect().height;\n sendEventPostMessage('ON_INIT', {height});\n }, []);\n};\n"]}
1
+ {"version":3,"file":"usePCEditorInitializeEvents.js","sourceRoot":"../../../src","sources":["hooks/usePCEditorInitializeEvents.ts"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport _ from 'lodash';\n\nimport {toSerializableRect} from '../common/types/rect';\nimport {BlockData} from '../constructor-items';\nimport {BlockRegistry} from '../context/blockRegistryContext';\nimport {Fields} from '../form-generator-v2/types';\nimport {PageContent} from '../models';\n\nimport {usePCEditorStore} from './usePCEditorStore';\nimport {sendEventPostMessage, useInternalPostMessageAPIListener} from './usePostMessageAPI';\n\ninterface UseEditorInitializeProps {\n initialContent: PageContent;\n setContent: (content: PageContent) => void;\n blocks: Array<BlockData>;\n global?: Fields;\n blockInputs?: Fields;\n registry: BlockRegistry | null;\n}\n\nfunction collectRectMap(registry: BlockRegistry) {\n return registry.getEntries().map(({path, element, dropZone}) => {\n const rect = element.getClientRects().item(0) ?? element.getBoundingClientRect();\n return {path, rect: toSerializableRect(rect), dropZone};\n });\n}\n\nexport const usePCEditorInitializeEvents = ({\n initialContent,\n setContent,\n blocks,\n global,\n blockInputs,\n registry,\n}: UseEditorInitializeProps) => {\n const {initialized, content} = usePCEditorStore();\n\n React.useEffect(() => {\n if (initialized) {\n setContent(content);\n }\n }, [content, initialized, setContent]);\n\n useInternalPostMessageAPIListener('GET_INITIAL_CONTENT', () => {\n sendEventPostMessage('ON_INITIAL_CONTENT', initialContent);\n });\n\n useInternalPostMessageAPIListener('GET_SUPPORTED_BLOCKS', () => {\n sendEventPostMessage('ON_SUPPORTED_BLOCKS', {\n blocks: blocks.map((block) => ({\n type: block.type,\n schema: blockInputs?.length\n ? {\n ...block.schema,\n inputs: [...blockInputs, ...(block.schema?.inputs || [])],\n }\n : block.schema,\n })),\n subBlocks: [],\n global: global || [],\n });\n });\n\n const onResize = React.useCallback(() => {\n const height = document.body.scrollHeight;\n sendEventPostMessage('ON_RESIZE', {height});\n }, []);\n\n React.useEffect(() => {\n if (!registry) {\n return undefined;\n }\n\n let frame: number | null = null;\n\n const sendRectMap = () => {\n frame = null;\n sendEventPostMessage('ON_UPDATE_RECT_MAP', {rects: collectRectMap(registry)});\n };\n\n const scheduleSend = () => {\n if (frame !== null) {\n return;\n }\n frame = requestAnimationFrame(sendRectMap);\n };\n\n const throttledSchedule = _.throttle(scheduleSend, 100, {leading: true, trailing: true});\n\n const unsubscribe = registry.subscribe(throttledSchedule);\n const observer = new ResizeObserver(throttledSchedule);\n observer.observe(document.body);\n\n // Initial push once registry is ready.\n throttledSchedule();\n\n return () => {\n throttledSchedule.cancel();\n unsubscribe();\n observer.disconnect();\n if (frame !== null) {\n cancelAnimationFrame(frame);\n }\n };\n }, [registry]);\n\n React.useEffect(() => {\n window.addEventListener('resize', onResize);\n const observer = new ResizeObserver(onResize);\n observer.observe(document.documentElement);\n observer.observe(document.body);\n\n return () => {\n window.removeEventListener('resize', onResize);\n observer.disconnect();\n };\n }, [onResize]);\n\n React.useEffect(() => {\n const height = document.body.scrollHeight;\n sendEventPostMessage('ON_INIT', {height});\n }, []);\n};\n"]}
@@ -1,5 +1,4 @@
1
1
  import * as React from 'react';
2
- import '@diplodoc/transform/dist/js/yfm';
3
2
  import type { PageConstructorWrapper } from "../../common/types/index.js";
4
3
  import { BlockData, blockMap, navItemMap, subBlockMap } from "../../constructor-items.js";
5
4
  import { Fields } from "../../form-generator-v2/types.js";
@@ -1,6 +1,5 @@
1
1
  import { jsx as _jsx } from "react/jsx-runtime";
2
2
  import * as React from 'react';
3
- import '@diplodoc/transform/dist/js/yfm';
4
3
  import RootCn from "../../components/RootCn/index.js";
5
4
  import { navItemMap } from "../../constructor-items.js";
6
5
  import { BlockRegistryContext, useBlockRegistryProvider } from "../../context/blockRegistryContext/index.js";
@@ -1 +1 @@
1
- {"version":3,"file":"PageConstructor.js","sourceRoot":"../../../../src","sources":["containers/PageConstructor/PageConstructor.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport '@diplodoc/transform/dist/js/yfm';\n\nimport type {PageConstructorWrapper} from '../../common/types';\nimport RootCn from '../../components/RootCn';\nimport {BlockData, blockMap, navItemMap, subBlockMap} from '../../constructor-items';\nimport {BlockRegistryContext, useBlockRegistryProvider} from '../../context/blockRegistryContext';\nimport {BlocksContext} from '../../context/blocksContext';\nimport {InnerContext} from '../../context/innerContext';\nimport {Fields} from '../../form-generator-v2/types';\nimport {usePCEditorInitializeEvents} from '../../hooks/usePCEditorInitializeEvents';\nimport {usePCEditorStore} from '../../hooks/usePCEditorStore';\nimport {\n BlockWrapperDataProps,\n CustomConfig,\n CustomItems,\n PageContent,\n ShouldRenderBlock,\n} from '../../models';\nimport {block as cnBlock, getCustomItems} from '../../utils';\n\nimport {ConstructorBlocks} from './components';\nimport {ConstructorRow} from './components/ConstructorRow';\n\nimport './PageConstructor.scss';\n\nexport interface PageConstructorExtension<\n GlobalConfig extends Object = {},\n WrapperProps extends Object = {},\n BlockWrapperProps extends Object = {},\n> {\n name: string;\n id: string;\n settings: {\n ContentWrapper?: PageConstructorWrapper<WrapperProps>;\n contentWrapperProps?: WrapperProps;\n globalInputs?: Fields;\n globalDefaults?: GlobalConfig;\n blockWrapper?: React.ComponentType<\n BlockWrapperDataProps<BlockWrapperProps> & React.PropsWithChildren\n >;\n blockWrapperProps?: BlockWrapperProps;\n blockInputs?: Fields;\n };\n}\n\nconst b = cnBlock('page-constructor');\n\nexport type ItemMap = typeof blockMap & typeof subBlockMap & CustomItems;\n\nexport type NavItemMap = typeof navItemMap & CustomItems;\n\nexport interface PageConstructorProps {\n content?: PageContent;\n shouldRenderBlock?: ShouldRenderBlock;\n custom?: CustomConfig;\n blocks?: Array<BlockData>;\n extensions?: Array<PageConstructorExtension>;\n}\n\nexport const PageConstructor = (props: PageConstructorProps) => {\n const {\n content: initialContent = {blocks: []},\n shouldRenderBlock,\n custom,\n blocks: availableLocalBlocks = [],\n extensions: extensionsProp,\n } = props;\n\n const extensions = React.useMemo(() => extensionsProp ?? [], [extensionsProp]);\n\n const {blocks: availableGlobalBlocks} = React.useContext(BlocksContext);\n\n const availableBlocks = React.useMemo(\n () => [...availableGlobalBlocks, ...availableLocalBlocks],\n [availableGlobalBlocks, availableLocalBlocks],\n );\n\n const globalDefaults = extensions.reduce(\n (acc, extension) => ({\n ...acc,\n ...(extension.settings.globalDefaults || {}),\n }),\n {},\n );\n\n const [content, setContent] = React.useState<PageContent>({\n ...globalDefaults,\n ...initialContent,\n });\n\n const store = usePCEditorStore();\n const {initialized} = store;\n\n const blockRegistry = useBlockRegistryProvider();\n\n const blockWrappers = React.useMemo(\n () =>\n extensions.flatMap((ext) =>\n ext.settings.blockWrapper\n ? [\n {\n wrapper: ext.settings.blockWrapper,\n props: ext.settings.blockWrapperProps ?? {},\n },\n ]\n : [],\n ),\n [extensions],\n );\n\n const blockInputs = React.useMemo(\n () =>\n extensions.reduce<Fields>(\n (acc, ext) => [...acc, ...((ext.settings.blockInputs || []) as Fields)],\n [],\n ),\n [extensions],\n );\n\n usePCEditorInitializeEvents({\n initialContent: content,\n setContent,\n blocks: availableBlocks,\n global: extensions.reduce<Fields>(\n (acc, extension) => [...acc, ...((extension.settings.globalInputs || []) as Fields)],\n [],\n ),\n blockInputs,\n registry: blockRegistry,\n });\n\n const context = React.useMemo(\n () => ({\n blocks: availableBlocks,\n navItemMap: {\n ...navItemMap,\n ...getCustomItems(['navigation'], custom),\n },\n loadables: custom?.loadable,\n shouldRenderBlock,\n blockWrappers,\n content,\n setContent,\n }),\n [custom, shouldRenderBlock, availableBlocks, content, setContent, blockWrappers],\n );\n\n const restBlocks = content.blocks;\n\n const blocksContent = restBlocks && (\n <ConstructorRow>\n <ConstructorBlocks items={restBlocks} />\n </ConstructorRow>\n );\n\n // Apply extensions (wrappers) from outermost to innermost\n const wrappedContent = extensions.reduceRight<React.ReactNode>(\n (children, extension) =>\n extension.settings.ContentWrapper ? (\n <extension.settings.ContentWrapper\n {...(extension.settings.contentWrapperProps || {})}\n >\n {children}\n </extension.settings.ContentWrapper>\n ) : (\n children\n ),\n blocksContent || null,\n );\n\n return (\n <BlockRegistryContext.Provider value={blockRegistry}>\n <InnerContext.Provider value={context}>\n <RootCn className={b('', {['with-editor']: initialized})}>{wrappedContent}</RootCn>\n </InnerContext.Provider>\n </BlockRegistryContext.Provider>\n );\n};\n"]}
1
+ {"version":3,"file":"PageConstructor.js","sourceRoot":"../../../../src","sources":["containers/PageConstructor/PageConstructor.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport type {PageConstructorWrapper} from '../../common/types';\nimport RootCn from '../../components/RootCn';\nimport {BlockData, blockMap, navItemMap, subBlockMap} from '../../constructor-items';\nimport {BlockRegistryContext, useBlockRegistryProvider} from '../../context/blockRegistryContext';\nimport {BlocksContext} from '../../context/blocksContext';\nimport {InnerContext} from '../../context/innerContext';\nimport {Fields} from '../../form-generator-v2/types';\nimport {usePCEditorInitializeEvents} from '../../hooks/usePCEditorInitializeEvents';\nimport {usePCEditorStore} from '../../hooks/usePCEditorStore';\nimport {\n BlockWrapperDataProps,\n CustomConfig,\n CustomItems,\n PageContent,\n ShouldRenderBlock,\n} from '../../models';\nimport {block as cnBlock, getCustomItems} from '../../utils';\n\nimport {ConstructorBlocks} from './components';\nimport {ConstructorRow} from './components/ConstructorRow';\n\nimport './PageConstructor.scss';\n\nexport interface PageConstructorExtension<\n GlobalConfig extends Object = {},\n WrapperProps extends Object = {},\n BlockWrapperProps extends Object = {},\n> {\n name: string;\n id: string;\n settings: {\n ContentWrapper?: PageConstructorWrapper<WrapperProps>;\n contentWrapperProps?: WrapperProps;\n globalInputs?: Fields;\n globalDefaults?: GlobalConfig;\n blockWrapper?: React.ComponentType<\n BlockWrapperDataProps<BlockWrapperProps> & React.PropsWithChildren\n >;\n blockWrapperProps?: BlockWrapperProps;\n blockInputs?: Fields;\n };\n}\n\nconst b = cnBlock('page-constructor');\n\nexport type ItemMap = typeof blockMap & typeof subBlockMap & CustomItems;\n\nexport type NavItemMap = typeof navItemMap & CustomItems;\n\nexport interface PageConstructorProps {\n content?: PageContent;\n shouldRenderBlock?: ShouldRenderBlock;\n custom?: CustomConfig;\n blocks?: Array<BlockData>;\n extensions?: Array<PageConstructorExtension>;\n}\n\nexport const PageConstructor = (props: PageConstructorProps) => {\n const {\n content: initialContent = {blocks: []},\n shouldRenderBlock,\n custom,\n blocks: availableLocalBlocks = [],\n extensions: extensionsProp,\n } = props;\n\n const extensions = React.useMemo(() => extensionsProp ?? [], [extensionsProp]);\n\n const {blocks: availableGlobalBlocks} = React.useContext(BlocksContext);\n\n const availableBlocks = React.useMemo(\n () => [...availableGlobalBlocks, ...availableLocalBlocks],\n [availableGlobalBlocks, availableLocalBlocks],\n );\n\n const globalDefaults = extensions.reduce(\n (acc, extension) => ({\n ...acc,\n ...(extension.settings.globalDefaults || {}),\n }),\n {},\n );\n\n const [content, setContent] = React.useState<PageContent>({\n ...globalDefaults,\n ...initialContent,\n });\n\n const store = usePCEditorStore();\n const {initialized} = store;\n\n const blockRegistry = useBlockRegistryProvider();\n\n const blockWrappers = React.useMemo(\n () =>\n extensions.flatMap((ext) =>\n ext.settings.blockWrapper\n ? [\n {\n wrapper: ext.settings.blockWrapper,\n props: ext.settings.blockWrapperProps ?? {},\n },\n ]\n : [],\n ),\n [extensions],\n );\n\n const blockInputs = React.useMemo(\n () =>\n extensions.reduce<Fields>(\n (acc, ext) => [...acc, ...((ext.settings.blockInputs || []) as Fields)],\n [],\n ),\n [extensions],\n );\n\n usePCEditorInitializeEvents({\n initialContent: content,\n setContent,\n blocks: availableBlocks,\n global: extensions.reduce<Fields>(\n (acc, extension) => [...acc, ...((extension.settings.globalInputs || []) as Fields)],\n [],\n ),\n blockInputs,\n registry: blockRegistry,\n });\n\n const context = React.useMemo(\n () => ({\n blocks: availableBlocks,\n navItemMap: {\n ...navItemMap,\n ...getCustomItems(['navigation'], custom),\n },\n loadables: custom?.loadable,\n shouldRenderBlock,\n blockWrappers,\n content,\n setContent,\n }),\n [custom, shouldRenderBlock, availableBlocks, content, setContent, blockWrappers],\n );\n\n const restBlocks = content.blocks;\n\n const blocksContent = restBlocks && (\n <ConstructorRow>\n <ConstructorBlocks items={restBlocks} />\n </ConstructorRow>\n );\n\n // Apply extensions (wrappers) from outermost to innermost\n const wrappedContent = extensions.reduceRight<React.ReactNode>(\n (children, extension) =>\n extension.settings.ContentWrapper ? (\n <extension.settings.ContentWrapper\n {...(extension.settings.contentWrapperProps || {})}\n >\n {children}\n </extension.settings.ContentWrapper>\n ) : (\n children\n ),\n blocksContent || null,\n );\n\n return (\n <BlockRegistryContext.Provider value={blockRegistry}>\n <InnerContext.Provider value={context}>\n <RootCn className={b('', {['with-editor']: initialized})}>{wrappedContent}</RootCn>\n </InnerContext.Provider>\n </BlockRegistryContext.Provider>\n );\n};\n"]}
@@ -0,0 +1,18 @@
1
+ import * as React from 'react';
2
+ import type { Content } from "../form-generator-v2/types.js";
3
+ interface CanvasContentContextType {
4
+ content: Content;
5
+ setContent: React.Dispatch<React.SetStateAction<Content>>;
6
+ templateContent: Content;
7
+ setTemplateContent: React.Dispatch<React.SetStateAction<Content>>;
8
+ }
9
+ interface CanvasContentProviderProps {
10
+ content: Content;
11
+ setContent: React.Dispatch<React.SetStateAction<Content>>;
12
+ templateContent: Content;
13
+ setTemplateContent: React.Dispatch<React.SetStateAction<Content>>;
14
+ children: React.ReactNode;
15
+ }
16
+ export declare const CanvasContentProvider: ({ content, setContent, templateContent, setTemplateContent, children, }: CanvasContentProviderProps) => import("react/jsx-runtime").JSX.Element;
17
+ export declare const useCanvasContent: () => CanvasContentContextType;
18
+ export {};
@@ -0,0 +1,15 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import * as React from 'react';
3
+ const CanvasContentContext = React.createContext(null);
4
+ export const CanvasContentProvider = ({ content, setContent, templateContent, setTemplateContent, children, }) => {
5
+ const value = React.useMemo(() => ({ content, setContent, templateContent, setTemplateContent }), [content, setContent, templateContent, setTemplateContent]);
6
+ return _jsx(CanvasContentContext.Provider, { value: value, children: children });
7
+ };
8
+ export const useCanvasContent = () => {
9
+ const context = React.useContext(CanvasContentContext);
10
+ if (!context) {
11
+ throw new Error('useCanvasContent must be used within a CanvasContentProvider');
12
+ }
13
+ return context;
14
+ };
15
+ //# sourceMappingURL=CanvasContentContext.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CanvasContentContext.js","sourceRoot":"../../../src","sources":["form-builder-v2/CanvasContentContext.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAW/B,MAAM,oBAAoB,GAAG,KAAK,CAAC,aAAa,CAAkC,IAAI,CAAC,CAAC;AAUxF,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,EAClC,OAAO,EACP,UAAU,EACV,eAAe,EACf,kBAAkB,EAClB,QAAQ,GACiB,EAAE,EAAE;IAC7B,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CACvB,GAAG,EAAE,CAAC,CAAC,EAAC,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,kBAAkB,EAAC,CAAC,EAClE,CAAC,OAAO,EAAE,UAAU,EAAE,eAAe,EAAE,kBAAkB,CAAC,CAC7D,CAAC;IACF,OAAO,KAAC,oBAAoB,CAAC,QAAQ,IAAC,KAAK,EAAE,KAAK,YAAG,QAAQ,GAAiC,CAAC;AACnG,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,gBAAgB,GAAG,GAA6B,EAAE;IAC3D,MAAM,OAAO,GAAG,KAAK,CAAC,UAAU,CAAC,oBAAoB,CAAC,CAAC;IACvD,IAAI,CAAC,OAAO,EAAE,CAAC;QACX,MAAM,IAAI,KAAK,CAAC,8DAA8D,CAAC,CAAC;IACpF,CAAC;IACD,OAAO,OAAO,CAAC;AACnB,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport type {Content} from '../form-generator-v2/types';\n\ninterface CanvasContentContextType {\n content: Content;\n setContent: React.Dispatch<React.SetStateAction<Content>>;\n templateContent: Content;\n setTemplateContent: React.Dispatch<React.SetStateAction<Content>>;\n}\n\nconst CanvasContentContext = React.createContext<CanvasContentContextType | null>(null);\n\ninterface CanvasContentProviderProps {\n content: Content;\n setContent: React.Dispatch<React.SetStateAction<Content>>;\n templateContent: Content;\n setTemplateContent: React.Dispatch<React.SetStateAction<Content>>;\n children: React.ReactNode;\n}\n\nexport const CanvasContentProvider = ({\n content,\n setContent,\n templateContent,\n setTemplateContent,\n children,\n}: CanvasContentProviderProps) => {\n const value = React.useMemo<CanvasContentContextType>(\n () => ({content, setContent, templateContent, setTemplateContent}),\n [content, setContent, templateContent, setTemplateContent],\n );\n return <CanvasContentContext.Provider value={value}>{children}</CanvasContentContext.Provider>;\n};\n\nexport const useCanvasContent = (): CanvasContentContextType => {\n const context = React.useContext(CanvasContentContext);\n if (!context) {\n throw new Error('useCanvasContent must be used within a CanvasContentProvider');\n }\n return context;\n};\n"]}
@@ -0,0 +1,93 @@
1
+ .pcformbuilderv2-main {
2
+ width: 100%;
3
+ min-width: 640px;
4
+ display: flex;
5
+ flex-direction: column;
6
+ min-height: 0;
7
+ }
8
+ .pcformbuilderv2-main__toolbar {
9
+ display: flex;
10
+ justify-content: space-between;
11
+ align-items: center;
12
+ padding: var(--g-spacing-2) 0;
13
+ gap: var(--g-spacing-3);
14
+ }
15
+ .pcformbuilderv2-main__toolbar-option {
16
+ display: inline-flex;
17
+ align-items: center;
18
+ gap: 6px;
19
+ }
20
+ .pcformbuilderv2-main__schema-popup {
21
+ width: min(560px, 90vw);
22
+ padding: var(--g-spacing-4);
23
+ display: flex;
24
+ flex-direction: column;
25
+ gap: 10px;
26
+ }
27
+ .pcformbuilderv2-main__schema-popup-header {
28
+ display: flex;
29
+ flex-direction: column;
30
+ gap: var(--g-spacing-half);
31
+ }
32
+ .pcformbuilderv2-main__schema-popup-json {
33
+ margin: 0;
34
+ padding: var(--g-spacing-3);
35
+ background: var(--g-color-base-generic);
36
+ border-radius: var(--g-border-radius-m);
37
+ font-size: 12px;
38
+ line-height: 1.4;
39
+ max-height: min(480px, 60vh);
40
+ overflow: auto;
41
+ white-space: pre;
42
+ }
43
+ .pcformbuilderv2-main__schema-popup-actions {
44
+ display: flex;
45
+ gap: var(--g-spacing-2);
46
+ justify-content: flex-end;
47
+ }
48
+ .pcformbuilderv2-main__visual {
49
+ display: grid;
50
+ grid-template-columns: var(--fb2-palette-w, 220px) var(--g-spacing-2) minmax(240px, 1fr) var(--g-spacing-2) var(--fb2-inspector-w, 320px);
51
+ padding: var(--g-spacing-4) 0;
52
+ align-items: stretch;
53
+ }
54
+ .pcformbuilderv2-main__palette, .pcformbuilderv2-main__canvas, .pcformbuilderv2-main__inspector {
55
+ min-width: 0;
56
+ }
57
+ .pcformbuilderv2-main__palette, .pcformbuilderv2-main__inspector {
58
+ position: sticky;
59
+ top: var(--g-spacing-4);
60
+ align-self: start;
61
+ max-height: calc(100vh - 80px);
62
+ overflow-y: auto;
63
+ }
64
+ .pcformbuilderv2-main_compact .pcformbuilderv2-main__visual {
65
+ grid-template-columns: 56px minmax(240px, 1fr) var(--g-spacing-2) var(--fb2-inspector-w, 320px);
66
+ }
67
+ .pcformbuilderv2-main_compact .pcformbuilderv2-main__canvas {
68
+ padding-left: var(--g-spacing-2);
69
+ }
70
+ .pcformbuilderv2-main_compact .pcformbuilderv2-palette {
71
+ padding: 6px;
72
+ }
73
+ .pcformbuilderv2-main_compact .pcformbuilderv2-palette__header {
74
+ display: none;
75
+ }
76
+ .pcformbuilderv2-main_compact .pcformbuilderv2-palette__items {
77
+ grid-template-columns: 1fr;
78
+ }
79
+ .pcformbuilderv2-main_compact .pcformbuilderv2-palette__tile {
80
+ padding: var(--g-spacing-1);
81
+ gap: 0;
82
+ }
83
+ .pcformbuilderv2-main_compact .pcformbuilderv2-palette__tile-label {
84
+ position: absolute;
85
+ width: 1px;
86
+ height: 1px;
87
+ padding: 0;
88
+ margin: -1px;
89
+ overflow: hidden;
90
+ clip: rect(0, 0, 0, 0);
91
+ white-space: nowrap;
92
+ border: 0;
93
+ }
@@ -0,0 +1,11 @@
1
+ import { FormField } from "./types.js";
2
+ import './FormBuilderV2.css';
3
+ export type FormBuilderDensity = 'full' | 'compact';
4
+ interface FormBuilderV2Props {
5
+ className?: string;
6
+ formFields: FormField[];
7
+ onChange?: (fields: FormField[]) => void;
8
+ density?: FormBuilderDensity;
9
+ }
10
+ export declare const FormBuilderV2: ({ className, formFields, onChange, density, }: FormBuilderV2Props) => import("react/jsx-runtime").JSX.Element;
11
+ export {};
@@ -0,0 +1,119 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import * as React from 'react';
4
+ import { move } from '@dnd-kit/helpers';
5
+ import { DragDropProvider, DragOverlay } from '@dnd-kit/react';
6
+ import { Code, Eye, Pencil } from '@gravity-ui/icons';
7
+ import { Button, Icon, SegmentedRadioGroup } from '@gravity-ui/uikit';
8
+ import { CanvasContentProvider } from "./CanvasContentContext.js";
9
+ import { Canvas } from "./components/Canvas/Canvas.js";
10
+ import { ContentTab } from "./components/ContentTab/ContentTab.js";
11
+ import { DragOverlayPreview } from "./components/DragOverlayPreview/DragOverlayPreview.js";
12
+ import { Inspector } from "./components/Inspector/Inspector.js";
13
+ import { PALETTE_DRAGGABLE_PREFIX, Palette } from "./components/Palette/Palette.js";
14
+ import { ResizeHandle } from "./components/ResizeHandle/ResizeHandle.js";
15
+ import { SchemaPopup } from "./components/SchemaPopup/SchemaPopup.js";
16
+ import { FormProvider, useFormContext } from "./hooks/FormContext.js";
17
+ import { formBuilderV2Cn } from "./utils/cn.js";
18
+ import { isDropAfter, isPaletteData, isSectionDropData } from "./utils/dragData.js";
19
+ import { applyGroupsMap, buildGroupsMap } from "./utils/fieldGroups.js";
20
+ import { findFieldById } from "./utils/fieldTree.js";
21
+ import { stripIds } from "./utils/stripIds.js";
22
+ import './FormBuilderV2.css';
23
+ const b = formBuilderV2Cn('main');
24
+ const PALETTE_MIN = 160;
25
+ const PALETTE_MAX = 400;
26
+ const PALETTE_DEFAULT = 220;
27
+ const INSPECTOR_MIN = 240;
28
+ const INSPECTOR_MAX = 560;
29
+ const INSPECTOR_DEFAULT = 320;
30
+ const FormBuilderShell = ({ className, density }) => {
31
+ const [mode, setMode] = React.useState('edit');
32
+ const [canvasContent, setCanvasContent] = React.useState({});
33
+ const [templateContent, setTemplateContent] = React.useState({});
34
+ const [paletteWidth, setPaletteWidth] = React.useState(PALETTE_DEFAULT);
35
+ const [inspectorWidth, setInspectorWidth] = React.useState(INSPECTOR_DEFAULT);
36
+ const [schemaPopupOpen, setSchemaPopupOpen] = React.useState(false);
37
+ const schemaButtonRef = React.useRef(null);
38
+ const isCompact = density === 'compact';
39
+ const { formFields, setAllFields, addField, addFieldToSection, insertFieldBefore, insertFieldAfter, moveFieldToSection, } = useFormContext();
40
+ const schema = React.useMemo(() => stripIds(formFields), [formFields]);
41
+ const handleDragEnd = React.useCallback((event) => {
42
+ if (event.canceled)
43
+ return;
44
+ const { source, target } = event.operation;
45
+ if (!source)
46
+ return;
47
+ const paletteData = isPaletteData(source.data) ? source.data : null;
48
+ const isPaletteDrag = paletteData !== null || String(source.id).startsWith(PALETTE_DRAGGABLE_PREFIX);
49
+ if (isPaletteDrag) {
50
+ const type = paletteData?.type;
51
+ if (!type)
52
+ return;
53
+ if (!target) {
54
+ addField(type);
55
+ return;
56
+ }
57
+ if (isSectionDropData(target.data)) {
58
+ addFieldToSection(target.data.sectionId, type);
59
+ return;
60
+ }
61
+ if (String(target.id) === String(source.id)) {
62
+ addField(type);
63
+ return;
64
+ }
65
+ const dropAfter = isDropAfter(event.operation.position?.current?.y, target.shape?.center?.y);
66
+ if (dropAfter) {
67
+ insertFieldAfter(String(target.id), type);
68
+ }
69
+ else {
70
+ insertFieldBefore(String(target.id), type);
71
+ }
72
+ return;
73
+ }
74
+ if (target && isSectionDropData(target.data)) {
75
+ moveFieldToSection(String(source.id), target.data.sectionId);
76
+ return;
77
+ }
78
+ const groups = buildGroupsMap(formFields);
79
+ const nextGroups = move(groups, event);
80
+ const nextFields = applyGroupsMap(nextGroups);
81
+ setAllFields(nextFields);
82
+ }, [
83
+ addField,
84
+ addFieldToSection,
85
+ formFields,
86
+ insertFieldBefore,
87
+ insertFieldAfter,
88
+ moveFieldToSection,
89
+ setAllFields,
90
+ ]);
91
+ const gridStyle = {
92
+ '--fb2-palette-w': `${paletteWidth}px`,
93
+ '--fb2-inspector-w': `${inspectorWidth}px`,
94
+ };
95
+ return (_jsx("div", { className: b({ compact: density === 'compact' }, className), children: _jsxs(CanvasContentProvider, { content: canvasContent, setContent: setCanvasContent, templateContent: templateContent, setTemplateContent: setTemplateContent, children: [_jsxs("div", { className: b('toolbar'), children: [_jsx(SegmentedRadioGroup, { size: "m", value: mode, onUpdate: setMode, options: [
96
+ {
97
+ value: 'edit',
98
+ content: (_jsxs("span", { className: b('toolbar-option'), children: [_jsx(Icon, { data: Pencil, size: 14 }), "Edit"] })),
99
+ },
100
+ {
101
+ value: 'preview',
102
+ content: (_jsxs("span", { className: b('toolbar-option'), children: [_jsx(Icon, { data: Eye, size: 14 }), "Preview"] })),
103
+ },
104
+ ] }), _jsxs(Button, { ref: schemaButtonRef, view: "outlined", size: "m", onClick: () => setSchemaPopupOpen((prev) => !prev), children: [_jsx(Icon, { data: Code, size: 14 }), "Schema"] }), _jsx(SchemaPopup, { schema: schema, onApply: setAllFields, open: schemaPopupOpen, onOpenChange: setSchemaPopupOpen, anchorElement: schemaButtonRef.current })] }), mode === 'edit' ? (_jsxs(DragDropProvider, { onDragEnd: handleDragEnd, children: [_jsxs("div", { className: b('visual'), style: gridStyle, children: [_jsx("aside", { className: b('palette'), children: _jsx(Palette, {}) }), !isCompact && (_jsx(ResizeHandle, { value: paletteWidth, min: PALETTE_MIN, max: PALETTE_MAX, direction: "left", onChange: setPaletteWidth })), _jsx("main", { className: b('canvas'), children: _jsx(Canvas, {}) }), _jsx(ResizeHandle, { value: inspectorWidth, min: INSPECTOR_MIN, max: INSPECTOR_MAX, direction: "right", onChange: setInspectorWidth }), _jsx("aside", { className: b('inspector'), children: _jsx(Inspector, {}) })] }), _jsx(DragOverlay, { dropAnimation: null, children: (source) => {
105
+ if (!source)
106
+ return null;
107
+ if (isPaletteData(source.data)) {
108
+ return _jsx(DragOverlayPreview, { type: source.data.type });
109
+ }
110
+ const field = findFieldById(formFields, String(source.id));
111
+ if (!field)
112
+ return null;
113
+ return _jsx(DragOverlayPreview, { type: field.type, field: field });
114
+ } })] })) : (_jsx(ContentTab, {}))] }) }));
115
+ };
116
+ export const FormBuilderV2 = ({ className, formFields, onChange, density = 'full', }) => {
117
+ return (_jsx(FormProvider, { formFields: formFields, onChange: onChange, children: _jsx(FormBuilderShell, { className: className, density: density }) }));
118
+ };
119
+ //# sourceMappingURL=FormBuilderV2.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FormBuilderV2.js","sourceRoot":"../../../src","sources":["form-builder-v2/FormBuilderV2.tsx"],"names":[],"mappings":"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","sourcesContent":["'use client';\n\nimport * as React from 'react';\n\nimport type {DragDropEvents} from '@dnd-kit/abstract';\nimport type {DragDropManager, Draggable, Droppable} from '@dnd-kit/dom';\nimport {move} from '@dnd-kit/helpers';\nimport {DragDropProvider, DragOverlay} from '@dnd-kit/react';\nimport {Code, Eye, Pencil} from '@gravity-ui/icons';\nimport {Button, Icon, SegmentedRadioGroup} from '@gravity-ui/uikit';\n\nimport type {Content} from '../form-generator-v2/types';\n\nimport {CanvasContentProvider} from './CanvasContentContext';\nimport {Canvas} from './components/Canvas/Canvas';\nimport {ContentTab} from './components/ContentTab/ContentTab';\nimport {DragOverlayPreview} from './components/DragOverlayPreview/DragOverlayPreview';\nimport {Inspector} from './components/Inspector/Inspector';\nimport {PALETTE_DRAGGABLE_PREFIX, Palette} from './components/Palette/Palette';\nimport {ResizeHandle} from './components/ResizeHandle/ResizeHandle';\nimport {SchemaPopup} from './components/SchemaPopup/SchemaPopup';\nimport {FormProvider, useFormContext} from './hooks/FormContext';\nimport {FormField} from './types';\nimport {formBuilderV2Cn} from './utils/cn';\nimport {isDropAfter, isPaletteData, isSectionDropData} from './utils/dragData';\nimport {applyGroupsMap, buildGroupsMap} from './utils/fieldGroups';\nimport {findFieldById} from './utils/fieldTree';\nimport {stripIds} from './utils/stripIds';\n\nimport './FormBuilderV2.scss';\n\nconst b = formBuilderV2Cn('main');\n\ntype DndEvents = DragDropEvents<Draggable, Droppable, DragDropManager>;\ntype DragEndEvent = Parameters<DndEvents['dragend']>[0];\n\ntype Mode = 'edit' | 'preview';\n\nexport type FormBuilderDensity = 'full' | 'compact';\n\nconst PALETTE_MIN = 160;\nconst PALETTE_MAX = 400;\nconst PALETTE_DEFAULT = 220;\nconst INSPECTOR_MIN = 240;\nconst INSPECTOR_MAX = 560;\nconst INSPECTOR_DEFAULT = 320;\n\ninterface FormBuilderV2Props {\n className?: string;\n formFields: FormField[];\n onChange?: (fields: FormField[]) => void;\n\n density?: FormBuilderDensity;\n}\n\ninterface FormBuilderShellProps {\n className?: string;\n density: FormBuilderDensity;\n}\n\nconst FormBuilderShell = ({className, density}: FormBuilderShellProps) => {\n const [mode, setMode] = React.useState<Mode>('edit');\n const [canvasContent, setCanvasContent] = React.useState<Content>({});\n const [templateContent, setTemplateContent] = React.useState<Content>({});\n const [paletteWidth, setPaletteWidth] = React.useState(PALETTE_DEFAULT);\n const [inspectorWidth, setInspectorWidth] = React.useState(INSPECTOR_DEFAULT);\n const [schemaPopupOpen, setSchemaPopupOpen] = React.useState(false);\n const schemaButtonRef = React.useRef<HTMLButtonElement | null>(null);\n\n const isCompact = density === 'compact';\n\n const {\n formFields,\n setAllFields,\n addField,\n addFieldToSection,\n insertFieldBefore,\n insertFieldAfter,\n moveFieldToSection,\n } = useFormContext();\n\n const schema = React.useMemo(() => stripIds(formFields), [formFields]);\n\n const handleDragEnd = React.useCallback(\n (event: DragEndEvent) => {\n if (event.canceled) return;\n const {source, target} = event.operation;\n if (!source) return;\n\n const paletteData = isPaletteData(source.data) ? source.data : null;\n const isPaletteDrag =\n paletteData !== null || String(source.id).startsWith(PALETTE_DRAGGABLE_PREFIX);\n\n if (isPaletteDrag) {\n const type = paletteData?.type;\n if (!type) return;\n if (!target) {\n addField(type);\n return;\n }\n\n if (isSectionDropData(target.data)) {\n addFieldToSection(target.data.sectionId, type);\n return;\n }\n\n if (String(target.id) === String(source.id)) {\n addField(type);\n return;\n }\n\n const dropAfter = isDropAfter(\n event.operation.position?.current?.y,\n target.shape?.center?.y,\n );\n if (dropAfter) {\n insertFieldAfter(String(target.id), type);\n } else {\n insertFieldBefore(String(target.id), type);\n }\n return;\n }\n\n if (target && isSectionDropData(target.data)) {\n moveFieldToSection(String(source.id), target.data.sectionId);\n return;\n }\n\n const groups = buildGroupsMap(formFields);\n const nextGroups = move(groups, event);\n const nextFields = applyGroupsMap(nextGroups);\n setAllFields(nextFields);\n },\n [\n addField,\n addFieldToSection,\n formFields,\n insertFieldBefore,\n insertFieldAfter,\n moveFieldToSection,\n setAllFields,\n ],\n );\n\n const gridStyle = {\n '--fb2-palette-w': `${paletteWidth}px`,\n '--fb2-inspector-w': `${inspectorWidth}px`,\n } as React.CSSProperties;\n\n return (\n <div className={b({compact: density === 'compact'}, className)}>\n <CanvasContentProvider\n content={canvasContent}\n setContent={setCanvasContent}\n templateContent={templateContent}\n setTemplateContent={setTemplateContent}\n >\n <div className={b('toolbar')}>\n <SegmentedRadioGroup<Mode>\n size=\"m\"\n value={mode}\n onUpdate={setMode}\n options={[\n {\n value: 'edit',\n content: (\n <span className={b('toolbar-option')}>\n <Icon data={Pencil} size={14} />\n Edit\n </span>\n ),\n },\n {\n value: 'preview',\n content: (\n <span className={b('toolbar-option')}>\n <Icon data={Eye} size={14} />\n Preview\n </span>\n ),\n },\n ]}\n />\n <Button\n ref={schemaButtonRef}\n view=\"outlined\"\n size=\"m\"\n onClick={() => setSchemaPopupOpen((prev) => !prev)}\n >\n <Icon data={Code} size={14} />\n Schema\n </Button>\n <SchemaPopup\n schema={schema}\n onApply={setAllFields}\n open={schemaPopupOpen}\n onOpenChange={setSchemaPopupOpen}\n anchorElement={schemaButtonRef.current}\n />\n </div>\n\n {mode === 'edit' ? (\n <DragDropProvider onDragEnd={handleDragEnd}>\n <div className={b('visual')} style={gridStyle}>\n <aside className={b('palette')}>\n <Palette />\n </aside>\n {!isCompact && (\n <ResizeHandle\n value={paletteWidth}\n min={PALETTE_MIN}\n max={PALETTE_MAX}\n direction=\"left\"\n onChange={setPaletteWidth}\n />\n )}\n <main className={b('canvas')}>\n <Canvas />\n </main>\n <ResizeHandle\n value={inspectorWidth}\n min={INSPECTOR_MIN}\n max={INSPECTOR_MAX}\n direction=\"right\"\n onChange={setInspectorWidth}\n />\n <aside className={b('inspector')}>\n <Inspector />\n </aside>\n </div>\n <DragOverlay dropAnimation={null}>\n {(source) => {\n if (!source) return null;\n if (isPaletteData(source.data)) {\n return <DragOverlayPreview type={source.data.type} />;\n }\n const field = findFieldById(formFields, String(source.id));\n if (!field) return null;\n return <DragOverlayPreview type={field.type} field={field} />;\n }}\n </DragOverlay>\n </DragDropProvider>\n ) : (\n <ContentTab />\n )}\n </CanvasContentProvider>\n </div>\n );\n};\n\nexport const FormBuilderV2 = ({\n className,\n formFields,\n onChange,\n density = 'full',\n}: FormBuilderV2Props) => {\n return (\n <FormProvider formFields={formFields} onChange={onChange}>\n <FormBuilderShell className={className} density={density} />\n </FormProvider>\n );\n};\n"]}
@@ -0,0 +1,15 @@
1
+ .pcformbuilderv2-canvas {
2
+ padding: var(--g-spacing-5);
3
+ min-height: 400px;
4
+ }
5
+ .pcformbuilderv2-canvas__list {
6
+ display: flex;
7
+ flex-direction: column;
8
+ gap: var(--g-spacing-3);
9
+ }
10
+ .pcformbuilderv2-canvas__empty {
11
+ padding: var(--g-spacing-10) var(--g-spacing-5);
12
+ text-align: center;
13
+ border: 1px dashed var(--g-color-line-generic);
14
+ border-radius: var(--g-border-radius-l);
15
+ }
@@ -0,0 +1,9 @@
1
+ import { FormField } from "../../types.js";
2
+ import './Canvas.css';
3
+ interface CanvasListProps {
4
+ fields: FormField[];
5
+ parentGroup: string;
6
+ }
7
+ declare const CanvasList: ({ fields, parentGroup }: CanvasListProps) => import("react/jsx-runtime").JSX.Element;
8
+ export declare const Canvas: () => import("react/jsx-runtime").JSX.Element;
9
+ export { CanvasList };
@@ -0,0 +1,14 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { Card, Text } from '@gravity-ui/uikit';
3
+ import { useFormContext } from "../../hooks/FormContext.js";
4
+ import { formBuilderV2Cn } from "../../utils/cn.js";
5
+ import { CanvasCard } from "../CanvasCard/CanvasCard.js";
6
+ import './Canvas.css';
7
+ const b = formBuilderV2Cn('canvas');
8
+ const CanvasList = ({ fields, parentGroup }) => (_jsx("div", { className: b('list'), children: fields.map((field, index) => (_jsx(CanvasCard, { field: field, index: index, group: parentGroup }, field.id))) }));
9
+ export const Canvas = () => {
10
+ const { formFields, selectField } = useFormContext();
11
+ return (_jsx(Card, { className: b(), view: "outlined", onClick: () => selectField(null), children: formFields.length === 0 ? (_jsx("div", { className: b('empty'), children: _jsx(Text, { variant: "body-2", color: "hint", children: "Canvas is empty. Click a field type on the left to add it." }) })) : (_jsx(CanvasList, { fields: formFields, parentGroup: "root" })) }));
12
+ };
13
+ export { CanvasList };
14
+ //# sourceMappingURL=Canvas.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Canvas.js","sourceRoot":"../../../../../src","sources":["form-builder-v2/components/Canvas/Canvas.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAC,IAAI,EAAE,IAAI,EAAC,MAAM,mBAAmB,CAAC;AAE7C,OAAO,EAAC,cAAc,EAAC,mCAAgC;AAEvD,OAAO,EAAC,eAAe,EAAC,0BAAuB;AAC/C,OAAO,EAAC,UAAU,EAAC,oCAAiC;AAEpD,OAAO,cAAc,CAAC;AAEtB,MAAM,CAAC,GAAG,eAAe,CAAC,QAAQ,CAAC,CAAC;AAOpC,MAAM,UAAU,GAAG,CAAC,EAAC,MAAM,EAAE,WAAW,EAAkB,EAAE,EAAE,CAAC,CAC3D,cAAK,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,YACpB,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,CAC1B,KAAC,UAAU,IAAgB,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,WAAW,IAAxD,KAAK,CAAC,EAAE,CAAoD,CAChF,CAAC,GACA,CACT,CAAC;AAEF,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,EAAE;IACvB,MAAM,EAAC,UAAU,EAAE,WAAW,EAAC,GAAG,cAAc,EAAE,CAAC;IAEnD,OAAO,CACH,KAAC,IAAI,IAAC,SAAS,EAAE,CAAC,EAAE,EAAE,IAAI,EAAC,UAAU,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,IAAI,CAAC,YACjE,UAAU,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,CACvB,cAAK,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,YACtB,KAAC,IAAI,IAAC,OAAO,EAAC,QAAQ,EAAC,KAAK,EAAC,MAAM,2EAE5B,GACL,CACT,CAAC,CAAC,CAAC,CACA,KAAC,UAAU,IAAC,MAAM,EAAE,UAAU,EAAE,WAAW,EAAC,MAAM,GAAG,CACxD,GACE,CACV,CAAC;AACN,CAAC,CAAC;AAEF,OAAO,EAAC,UAAU,EAAC,CAAC","sourcesContent":["import {Card, Text} from '@gravity-ui/uikit';\n\nimport {useFormContext} from '../../hooks/FormContext';\nimport {FormField} from '../../types';\nimport {formBuilderV2Cn} from '../../utils/cn';\nimport {CanvasCard} from '../CanvasCard/CanvasCard';\n\nimport './Canvas.scss';\n\nconst b = formBuilderV2Cn('canvas');\n\ninterface CanvasListProps {\n fields: FormField[];\n parentGroup: string;\n}\n\nconst CanvasList = ({fields, parentGroup}: CanvasListProps) => (\n <div className={b('list')}>\n {fields.map((field, index) => (\n <CanvasCard key={field.id} field={field} index={index} group={parentGroup} />\n ))}\n </div>\n);\n\nexport const Canvas = () => {\n const {formFields, selectField} = useFormContext();\n\n return (\n <Card className={b()} view=\"outlined\" onClick={() => selectField(null)}>\n {formFields.length === 0 ? (\n <div className={b('empty')}>\n <Text variant=\"body-2\" color=\"hint\">\n Canvas is empty. Click a field type on the left to add it.\n </Text>\n </div>\n ) : (\n <CanvasList fields={formFields} parentGroup=\"root\" />\n )}\n </Card>\n );\n};\n\nexport {CanvasList};\n"]}