@gravity-ui/page-constructor 8.5.0-alpha.2 → 8.5.0-alpha.5

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 (305) hide show
  1. package/build/cjs/blocks/ContentLayout/index_deprecated.d.ts +1 -1
  2. package/build/cjs/blocks/ExtendedFeatures/index_deprecated.d.ts +1 -1
  3. package/build/cjs/blocks/FilterBlock/index.d.ts +1 -1
  4. package/build/cjs/blocks/FilterBlock/index_deprecated.d.ts +1 -1
  5. package/build/cjs/blocks/Form/index.d.ts +1 -1
  6. package/build/cjs/blocks/Form/index_deprecated.d.ts +1 -1
  7. package/build/cjs/blocks/HeaderSlider/index.d.ts +1 -1
  8. package/build/cjs/blocks/HeaderSlider/index_deprecated.d.ts +1 -1
  9. package/build/cjs/blocks/Icons/index.d.ts +1 -1
  10. package/build/cjs/blocks/Icons/index_deprecated.d.ts +1 -1
  11. package/build/cjs/blocks/Info/index.d.ts +1 -1
  12. package/build/cjs/blocks/Info/index_deprecated.d.ts +1 -1
  13. package/build/cjs/blocks/Map/index.d.ts +1 -1
  14. package/build/cjs/blocks/Map/index_deprecated.d.ts +1 -1
  15. package/build/cjs/blocks/Media/index_deprecated.d.ts +1 -1
  16. package/build/cjs/blocks/PromoFeaturesBlock/index_deprecated.d.ts +1 -1
  17. package/build/cjs/blocks/Questions/index_deprecated.d.ts +1 -1
  18. package/build/cjs/blocks/Share/index.d.ts +1 -1
  19. package/build/cjs/blocks/Share/index_deprecated.d.ts +1 -1
  20. package/build/cjs/blocks/Slider/index.d.ts +1 -1
  21. package/build/cjs/blocks/Slider/index_deprecated.d.ts +1 -1
  22. package/build/cjs/blocks/Table/index.d.ts +1 -1
  23. package/build/cjs/blocks/Table/index_deprecated.d.ts +1 -1
  24. package/build/cjs/blocks/Tabs/index.d.ts +1 -1
  25. package/build/cjs/blocks/Tabs/index_deprecated.d.ts +1 -1
  26. package/build/cjs/form-builder-v2/CanvasContentContext.d.ts +18 -0
  27. package/build/cjs/form-builder-v2/CanvasContentContext.js +21 -0
  28. package/build/cjs/form-builder-v2/CanvasContentContext.js.map +1 -0
  29. package/build/cjs/form-builder-v2/FormBuilderV2.css +93 -0
  30. package/build/cjs/form-builder-v2/FormBuilderV2.d.ts +10 -0
  31. package/build/cjs/form-builder-v2/FormBuilderV2.js +123 -0
  32. package/build/cjs/form-builder-v2/FormBuilderV2.js.map +1 -0
  33. package/build/cjs/form-builder-v2/components/Canvas/Canvas.css +15 -0
  34. package/build/cjs/form-builder-v2/components/Canvas/Canvas.d.ts +8 -0
  35. package/build/cjs/form-builder-v2/components/Canvas/Canvas.js +17 -0
  36. package/build/cjs/form-builder-v2/components/Canvas/Canvas.js.map +1 -0
  37. package/build/cjs/form-builder-v2/components/CanvasCard/CanvasCard.css +133 -0
  38. package/build/cjs/form-builder-v2/components/CanvasCard/CanvasCard.d.ts +9 -0
  39. package/build/cjs/form-builder-v2/components/CanvasCard/CanvasCard.js +72 -0
  40. package/build/cjs/form-builder-v2/components/CanvasCard/CanvasCard.js.map +1 -0
  41. package/build/cjs/form-builder-v2/components/CanvasCard/components/FieldPreview.d.ts +6 -0
  42. package/build/cjs/form-builder-v2/components/CanvasCard/components/FieldPreview.js +44 -0
  43. package/build/cjs/form-builder-v2/components/CanvasCard/components/FieldPreview.js.map +1 -0
  44. package/build/cjs/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.d.ts +9 -0
  45. package/build/cjs/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.js +20 -0
  46. package/build/cjs/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.js.map +1 -0
  47. package/build/cjs/form-builder-v2/components/ContentTab/ContentTab.css +22 -0
  48. package/build/cjs/form-builder-v2/components/ContentTab/ContentTab.d.ts +1 -0
  49. package/build/cjs/form-builder-v2/components/ContentTab/ContentTab.js +21 -0
  50. package/build/cjs/form-builder-v2/components/ContentTab/ContentTab.js.map +1 -0
  51. package/build/cjs/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.css +13 -0
  52. package/build/cjs/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.d.ts +7 -0
  53. package/build/cjs/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.js +24 -0
  54. package/build/cjs/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.js.map +1 -0
  55. package/build/cjs/form-builder-v2/components/FieldSettings/FieldSettings.css +30 -0
  56. package/build/cjs/form-builder-v2/components/FieldSettings/FieldSettings.d.ts +6 -0
  57. package/build/cjs/form-builder-v2/components/FieldSettings/FieldSettings.js +49 -0
  58. package/build/cjs/form-builder-v2/components/FieldSettings/FieldSettings.js.map +1 -0
  59. package/build/cjs/form-builder-v2/components/FieldSettings/fields/ColorInputSettings.d.ts +12 -0
  60. package/build/cjs/form-builder-v2/components/FieldSettings/fields/ColorInputSettings.js +11 -0
  61. package/build/cjs/form-builder-v2/components/FieldSettings/fields/ColorInputSettings.js.map +1 -0
  62. package/build/cjs/form-builder-v2/components/FieldSettings/fields/OptionsSettings.d.ts +12 -0
  63. package/build/cjs/form-builder-v2/components/FieldSettings/fields/OptionsSettings.js +38 -0
  64. package/build/cjs/form-builder-v2/components/FieldSettings/fields/OptionsSettings.js.map +1 -0
  65. package/build/cjs/form-builder-v2/components/FieldSettings/fields/Row.d.ts +7 -0
  66. package/build/cjs/form-builder-v2/components/FieldSettings/fields/Row.js +9 -0
  67. package/build/cjs/form-builder-v2/components/FieldSettings/fields/Row.js.map +1 -0
  68. package/build/cjs/form-builder-v2/components/FieldSettings/fields/SectionSettings.d.ts +9 -0
  69. package/build/cjs/form-builder-v2/components/FieldSettings/fields/SectionSettings.js +40 -0
  70. package/build/cjs/form-builder-v2/components/FieldSettings/fields/SectionSettings.js.map +1 -0
  71. package/build/cjs/form-builder-v2/components/FieldSettings/fields/SwitchSettings.d.ts +12 -0
  72. package/build/cjs/form-builder-v2/components/FieldSettings/fields/SwitchSettings.js +11 -0
  73. package/build/cjs/form-builder-v2/components/FieldSettings/fields/SwitchSettings.js.map +1 -0
  74. package/build/cjs/form-builder-v2/components/FieldSettings/fields/TextFieldSettings.d.ts +12 -0
  75. package/build/cjs/form-builder-v2/components/FieldSettings/fields/TextFieldSettings.js +11 -0
  76. package/build/cjs/form-builder-v2/components/FieldSettings/fields/TextFieldSettings.js.map +1 -0
  77. package/build/cjs/form-builder-v2/components/FieldSettings/fields/TextSettings.d.ts +11 -0
  78. package/build/cjs/form-builder-v2/components/FieldSettings/fields/TextSettings.js +53 -0
  79. package/build/cjs/form-builder-v2/components/FieldSettings/fields/TextSettings.js.map +1 -0
  80. package/build/cjs/form-builder-v2/components/Inspector/Inspector.css +20 -0
  81. package/build/cjs/form-builder-v2/components/Inspector/Inspector.d.ts +1 -0
  82. package/build/cjs/form-builder-v2/components/Inspector/Inspector.js +20 -0
  83. package/build/cjs/form-builder-v2/components/Inspector/Inspector.js.map +1 -0
  84. package/build/cjs/form-builder-v2/components/Palette/Palette.css +56 -0
  85. package/build/cjs/form-builder-v2/components/Palette/Palette.d.ts +4 -0
  86. package/build/cjs/form-builder-v2/components/Palette/Palette.js +62 -0
  87. package/build/cjs/form-builder-v2/components/Palette/Palette.js.map +1 -0
  88. package/build/cjs/form-builder-v2/components/ResizeHandle/ResizeHandle.css +29 -0
  89. package/build/cjs/form-builder-v2/components/ResizeHandle/ResizeHandle.d.ts +9 -0
  90. package/build/cjs/form-builder-v2/components/ResizeHandle/ResizeHandle.js +98 -0
  91. package/build/cjs/form-builder-v2/components/ResizeHandle/ResizeHandle.js.map +1 -0
  92. package/build/cjs/form-builder-v2/components/SchemaPopup/SchemaPopup.css +49 -0
  93. package/build/cjs/form-builder-v2/components/SchemaPopup/SchemaPopup.d.ts +11 -0
  94. package/build/cjs/form-builder-v2/components/SchemaPopup/SchemaPopup.js +82 -0
  95. package/build/cjs/form-builder-v2/components/SchemaPopup/SchemaPopup.js.map +1 -0
  96. package/build/cjs/form-builder-v2/components/WhenEditor/WhenEditor.css +24 -0
  97. package/build/cjs/form-builder-v2/components/WhenEditor/WhenEditor.d.ts +8 -0
  98. package/build/cjs/form-builder-v2/components/WhenEditor/WhenEditor.js +50 -0
  99. package/build/cjs/form-builder-v2/components/WhenEditor/WhenEditor.js.map +1 -0
  100. package/build/cjs/form-builder-v2/components/WhenEditor/utils.d.ts +24 -0
  101. package/build/cjs/form-builder-v2/components/WhenEditor/utils.js +83 -0
  102. package/build/cjs/form-builder-v2/components/WhenEditor/utils.js.map +1 -0
  103. package/build/cjs/form-builder-v2/hooks/FormContext.d.ts +11 -0
  104. package/build/cjs/form-builder-v2/hooks/FormContext.js +22 -0
  105. package/build/cjs/form-builder-v2/hooks/FormContext.js.map +1 -0
  106. package/build/cjs/form-builder-v2/hooks/useFormFields.d.ts +23 -0
  107. package/build/cjs/form-builder-v2/hooks/useFormFields.js +144 -0
  108. package/build/cjs/form-builder-v2/hooks/useFormFields.js.map +1 -0
  109. package/build/cjs/form-builder-v2/index.d.ts +2 -0
  110. package/build/cjs/form-builder-v2/index.js +6 -0
  111. package/build/cjs/form-builder-v2/index.js.map +1 -0
  112. package/build/cjs/form-builder-v2/styles/variables.css +0 -0
  113. package/build/cjs/form-builder-v2/types.d.ts +32 -0
  114. package/build/cjs/form-builder-v2/types.js +3 -0
  115. package/build/cjs/form-builder-v2/types.js.map +1 -0
  116. package/build/cjs/form-builder-v2/utils/cn.d.ts +2 -0
  117. package/build/cjs/form-builder-v2/utils/cn.js +7 -0
  118. package/build/cjs/form-builder-v2/utils/cn.js.map +1 -0
  119. package/build/cjs/form-builder-v2/utils/dragData.d.ts +18 -0
  120. package/build/cjs/form-builder-v2/utils/dragData.js +18 -0
  121. package/build/cjs/form-builder-v2/utils/dragData.js.map +1 -0
  122. package/build/cjs/form-builder-v2/utils/fieldDefaults.d.ts +2 -0
  123. package/build/cjs/form-builder-v2/utils/fieldDefaults.js +51 -0
  124. package/build/cjs/form-builder-v2/utils/fieldDefaults.js.map +1 -0
  125. package/build/cjs/form-builder-v2/utils/fieldGroups.d.ts +3 -0
  126. package/build/cjs/form-builder-v2/utils/fieldGroups.js +26 -0
  127. package/build/cjs/form-builder-v2/utils/fieldGroups.js.map +1 -0
  128. package/build/cjs/form-builder-v2/utils/fieldMeta.d.ts +6 -0
  129. package/build/cjs/form-builder-v2/utils/fieldMeta.js +45 -0
  130. package/build/cjs/form-builder-v2/utils/fieldMeta.js.map +1 -0
  131. package/build/cjs/form-builder-v2/utils/fieldNames.d.ts +8 -0
  132. package/build/cjs/form-builder-v2/utils/fieldNames.js +75 -0
  133. package/build/cjs/form-builder-v2/utils/fieldNames.js.map +1 -0
  134. package/build/cjs/form-builder-v2/utils/fieldTree.d.ts +2 -0
  135. package/build/cjs/form-builder-v2/utils/fieldTree.js +7 -0
  136. package/build/cjs/form-builder-v2/utils/fieldTree.js.map +1 -0
  137. package/build/cjs/form-builder-v2/utils/fieldTreeOps.d.ts +13 -0
  138. package/build/cjs/form-builder-v2/utils/fieldTreeOps.js +80 -0
  139. package/build/cjs/form-builder-v2/utils/fieldTreeOps.js.map +1 -0
  140. package/build/cjs/form-builder-v2/utils/parseSchema.d.ts +9 -0
  141. package/build/cjs/form-builder-v2/utils/parseSchema.js +102 -0
  142. package/build/cjs/form-builder-v2/utils/parseSchema.js.map +1 -0
  143. package/build/cjs/form-builder-v2/utils/stripIds.d.ts +3 -0
  144. package/build/cjs/form-builder-v2/utils/stripIds.js +12 -0
  145. package/build/cjs/form-builder-v2/utils/stripIds.js.map +1 -0
  146. package/build/cjs/form-builder-v2/utils/treeWalk.d.ts +4 -0
  147. package/build/cjs/form-builder-v2/utils/treeWalk.js +45 -0
  148. package/build/cjs/form-builder-v2/utils/treeWalk.js.map +1 -0
  149. package/build/cjs/form-generator-v2/components/constants.d.ts +11 -11
  150. package/build/cjs/form-generator-v2/index.d.ts +2 -0
  151. package/build/cjs/form-generator-v2/index.js +8 -0
  152. package/build/cjs/form-generator-v2/index.js.map +1 -0
  153. package/build/esm/blocks/ContentLayout/index_deprecated.d.ts +1 -1
  154. package/build/esm/blocks/ExtendedFeatures/index_deprecated.d.ts +1 -1
  155. package/build/esm/blocks/FilterBlock/index.d.ts +1 -1
  156. package/build/esm/blocks/FilterBlock/index_deprecated.d.ts +1 -1
  157. package/build/esm/blocks/Form/index.d.ts +1 -1
  158. package/build/esm/blocks/Form/index_deprecated.d.ts +1 -1
  159. package/build/esm/blocks/HeaderSlider/index.d.ts +1 -1
  160. package/build/esm/blocks/HeaderSlider/index_deprecated.d.ts +1 -1
  161. package/build/esm/blocks/Icons/index.d.ts +1 -1
  162. package/build/esm/blocks/Icons/index_deprecated.d.ts +1 -1
  163. package/build/esm/blocks/Info/index.d.ts +1 -1
  164. package/build/esm/blocks/Info/index_deprecated.d.ts +1 -1
  165. package/build/esm/blocks/Map/index.d.ts +1 -1
  166. package/build/esm/blocks/Map/index_deprecated.d.ts +1 -1
  167. package/build/esm/blocks/Media/index_deprecated.d.ts +1 -1
  168. package/build/esm/blocks/PromoFeaturesBlock/index_deprecated.d.ts +1 -1
  169. package/build/esm/blocks/Questions/index_deprecated.d.ts +1 -1
  170. package/build/esm/blocks/Share/index.d.ts +1 -1
  171. package/build/esm/blocks/Share/index_deprecated.d.ts +1 -1
  172. package/build/esm/blocks/Slider/index.d.ts +1 -1
  173. package/build/esm/blocks/Slider/index_deprecated.d.ts +1 -1
  174. package/build/esm/blocks/Table/index.d.ts +1 -1
  175. package/build/esm/blocks/Table/index_deprecated.d.ts +1 -1
  176. package/build/esm/blocks/Tabs/index.d.ts +1 -1
  177. package/build/esm/blocks/Tabs/index_deprecated.d.ts +1 -1
  178. package/build/esm/form-builder-v2/CanvasContentContext.d.ts +18 -0
  179. package/build/esm/form-builder-v2/CanvasContentContext.js +15 -0
  180. package/build/esm/form-builder-v2/CanvasContentContext.js.map +1 -0
  181. package/build/esm/form-builder-v2/FormBuilderV2.css +93 -0
  182. package/build/esm/form-builder-v2/FormBuilderV2.d.ts +11 -0
  183. package/build/esm/form-builder-v2/FormBuilderV2.js +119 -0
  184. package/build/esm/form-builder-v2/FormBuilderV2.js.map +1 -0
  185. package/build/esm/form-builder-v2/components/Canvas/Canvas.css +15 -0
  186. package/build/esm/form-builder-v2/components/Canvas/Canvas.d.ts +9 -0
  187. package/build/esm/form-builder-v2/components/Canvas/Canvas.js +14 -0
  188. package/build/esm/form-builder-v2/components/Canvas/Canvas.js.map +1 -0
  189. package/build/esm/form-builder-v2/components/CanvasCard/CanvasCard.css +133 -0
  190. package/build/esm/form-builder-v2/components/CanvasCard/CanvasCard.d.ts +10 -0
  191. package/build/esm/form-builder-v2/components/CanvasCard/CanvasCard.js +68 -0
  192. package/build/esm/form-builder-v2/components/CanvasCard/CanvasCard.js.map +1 -0
  193. package/build/esm/form-builder-v2/components/CanvasCard/components/FieldPreview.d.ts +6 -0
  194. package/build/esm/form-builder-v2/components/CanvasCard/components/FieldPreview.js +39 -0
  195. package/build/esm/form-builder-v2/components/CanvasCard/components/FieldPreview.js.map +1 -0
  196. package/build/esm/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.d.ts +9 -0
  197. package/build/esm/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.js +16 -0
  198. package/build/esm/form-builder-v2/components/CanvasCard/components/SectionChildrenDropZone.js.map +1 -0
  199. package/build/esm/form-builder-v2/components/ContentTab/ContentTab.css +22 -0
  200. package/build/esm/form-builder-v2/components/ContentTab/ContentTab.d.ts +2 -0
  201. package/build/esm/form-builder-v2/components/ContentTab/ContentTab.js +17 -0
  202. package/build/esm/form-builder-v2/components/ContentTab/ContentTab.js.map +1 -0
  203. package/build/esm/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.css +13 -0
  204. package/build/esm/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.d.ts +8 -0
  205. package/build/esm/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.js +21 -0
  206. package/build/esm/form-builder-v2/components/DragOverlayPreview/DragOverlayPreview.js.map +1 -0
  207. package/build/esm/form-builder-v2/components/FieldSettings/FieldSettings.css +30 -0
  208. package/build/esm/form-builder-v2/components/FieldSettings/FieldSettings.d.ts +7 -0
  209. package/build/esm/form-builder-v2/components/FieldSettings/FieldSettings.js +45 -0
  210. package/build/esm/form-builder-v2/components/FieldSettings/FieldSettings.js.map +1 -0
  211. package/build/esm/form-builder-v2/components/FieldSettings/fields/ColorInputSettings.d.ts +12 -0
  212. package/build/esm/form-builder-v2/components/FieldSettings/fields/ColorInputSettings.js +6 -0
  213. package/build/esm/form-builder-v2/components/FieldSettings/fields/ColorInputSettings.js.map +1 -0
  214. package/build/esm/form-builder-v2/components/FieldSettings/fields/OptionsSettings.d.ts +12 -0
  215. package/build/esm/form-builder-v2/components/FieldSettings/fields/OptionsSettings.js +33 -0
  216. package/build/esm/form-builder-v2/components/FieldSettings/fields/OptionsSettings.js.map +1 -0
  217. package/build/esm/form-builder-v2/components/FieldSettings/fields/Row.d.ts +7 -0
  218. package/build/esm/form-builder-v2/components/FieldSettings/fields/Row.js +5 -0
  219. package/build/esm/form-builder-v2/components/FieldSettings/fields/Row.js.map +1 -0
  220. package/build/esm/form-builder-v2/components/FieldSettings/fields/SectionSettings.d.ts +9 -0
  221. package/build/esm/form-builder-v2/components/FieldSettings/fields/SectionSettings.js +35 -0
  222. package/build/esm/form-builder-v2/components/FieldSettings/fields/SectionSettings.js.map +1 -0
  223. package/build/esm/form-builder-v2/components/FieldSettings/fields/SwitchSettings.d.ts +12 -0
  224. package/build/esm/form-builder-v2/components/FieldSettings/fields/SwitchSettings.js +6 -0
  225. package/build/esm/form-builder-v2/components/FieldSettings/fields/SwitchSettings.js.map +1 -0
  226. package/build/esm/form-builder-v2/components/FieldSettings/fields/TextFieldSettings.d.ts +12 -0
  227. package/build/esm/form-builder-v2/components/FieldSettings/fields/TextFieldSettings.js +6 -0
  228. package/build/esm/form-builder-v2/components/FieldSettings/fields/TextFieldSettings.js.map +1 -0
  229. package/build/esm/form-builder-v2/components/FieldSettings/fields/TextSettings.d.ts +11 -0
  230. package/build/esm/form-builder-v2/components/FieldSettings/fields/TextSettings.js +48 -0
  231. package/build/esm/form-builder-v2/components/FieldSettings/fields/TextSettings.js.map +1 -0
  232. package/build/esm/form-builder-v2/components/Inspector/Inspector.css +20 -0
  233. package/build/esm/form-builder-v2/components/Inspector/Inspector.d.ts +2 -0
  234. package/build/esm/form-builder-v2/components/Inspector/Inspector.js +16 -0
  235. package/build/esm/form-builder-v2/components/Inspector/Inspector.js.map +1 -0
  236. package/build/esm/form-builder-v2/components/Palette/Palette.css +56 -0
  237. package/build/esm/form-builder-v2/components/Palette/Palette.d.ts +5 -0
  238. package/build/esm/form-builder-v2/components/Palette/Palette.js +58 -0
  239. package/build/esm/form-builder-v2/components/Palette/Palette.js.map +1 -0
  240. package/build/esm/form-builder-v2/components/ResizeHandle/ResizeHandle.css +29 -0
  241. package/build/esm/form-builder-v2/components/ResizeHandle/ResizeHandle.d.ts +10 -0
  242. package/build/esm/form-builder-v2/components/ResizeHandle/ResizeHandle.js +94 -0
  243. package/build/esm/form-builder-v2/components/ResizeHandle/ResizeHandle.js.map +1 -0
  244. package/build/esm/form-builder-v2/components/SchemaPopup/SchemaPopup.css +49 -0
  245. package/build/esm/form-builder-v2/components/SchemaPopup/SchemaPopup.d.ts +12 -0
  246. package/build/esm/form-builder-v2/components/SchemaPopup/SchemaPopup.js +78 -0
  247. package/build/esm/form-builder-v2/components/SchemaPopup/SchemaPopup.js.map +1 -0
  248. package/build/esm/form-builder-v2/components/WhenEditor/WhenEditor.css +24 -0
  249. package/build/esm/form-builder-v2/components/WhenEditor/WhenEditor.d.ts +9 -0
  250. package/build/esm/form-builder-v2/components/WhenEditor/WhenEditor.js +46 -0
  251. package/build/esm/form-builder-v2/components/WhenEditor/WhenEditor.js.map +1 -0
  252. package/build/esm/form-builder-v2/components/WhenEditor/utils.d.ts +24 -0
  253. package/build/esm/form-builder-v2/components/WhenEditor/utils.js +76 -0
  254. package/build/esm/form-builder-v2/components/WhenEditor/utils.js.map +1 -0
  255. package/build/esm/form-builder-v2/hooks/FormContext.d.ts +11 -0
  256. package/build/esm/form-builder-v2/hooks/FormContext.js +16 -0
  257. package/build/esm/form-builder-v2/hooks/FormContext.js.map +1 -0
  258. package/build/esm/form-builder-v2/hooks/useFormFields.d.ts +23 -0
  259. package/build/esm/form-builder-v2/hooks/useFormFields.js +139 -0
  260. package/build/esm/form-builder-v2/hooks/useFormFields.js.map +1 -0
  261. package/build/esm/form-builder-v2/index.d.ts +2 -0
  262. package/build/esm/form-builder-v2/index.js +3 -0
  263. package/build/esm/form-builder-v2/index.js.map +1 -0
  264. package/build/esm/form-builder-v2/styles/variables.css +0 -0
  265. package/build/esm/form-builder-v2/types.d.ts +32 -0
  266. package/build/esm/form-builder-v2/types.js +2 -0
  267. package/build/esm/form-builder-v2/types.js.map +1 -0
  268. package/build/esm/form-builder-v2/utils/cn.d.ts +2 -0
  269. package/build/esm/form-builder-v2/utils/cn.js +4 -0
  270. package/build/esm/form-builder-v2/utils/cn.js.map +1 -0
  271. package/build/esm/form-builder-v2/utils/dragData.d.ts +18 -0
  272. package/build/esm/form-builder-v2/utils/dragData.js +11 -0
  273. package/build/esm/form-builder-v2/utils/dragData.js.map +1 -0
  274. package/build/esm/form-builder-v2/utils/fieldDefaults.d.ts +2 -0
  275. package/build/esm/form-builder-v2/utils/fieldDefaults.js +47 -0
  276. package/build/esm/form-builder-v2/utils/fieldDefaults.js.map +1 -0
  277. package/build/esm/form-builder-v2/utils/fieldGroups.d.ts +3 -0
  278. package/build/esm/form-builder-v2/utils/fieldGroups.js +21 -0
  279. package/build/esm/form-builder-v2/utils/fieldGroups.js.map +1 -0
  280. package/build/esm/form-builder-v2/utils/fieldMeta.d.ts +6 -0
  281. package/build/esm/form-builder-v2/utils/fieldMeta.js +42 -0
  282. package/build/esm/form-builder-v2/utils/fieldMeta.js.map +1 -0
  283. package/build/esm/form-builder-v2/utils/fieldNames.d.ts +8 -0
  284. package/build/esm/form-builder-v2/utils/fieldNames.js +66 -0
  285. package/build/esm/form-builder-v2/utils/fieldNames.js.map +1 -0
  286. package/build/esm/form-builder-v2/utils/fieldTree.d.ts +2 -0
  287. package/build/esm/form-builder-v2/utils/fieldTree.js +3 -0
  288. package/build/esm/form-builder-v2/utils/fieldTree.js.map +1 -0
  289. package/build/esm/form-builder-v2/utils/fieldTreeOps.d.ts +13 -0
  290. package/build/esm/form-builder-v2/utils/fieldTreeOps.js +69 -0
  291. package/build/esm/form-builder-v2/utils/fieldTreeOps.js.map +1 -0
  292. package/build/esm/form-builder-v2/utils/parseSchema.d.ts +9 -0
  293. package/build/esm/form-builder-v2/utils/parseSchema.js +98 -0
  294. package/build/esm/form-builder-v2/utils/parseSchema.js.map +1 -0
  295. package/build/esm/form-builder-v2/utils/stripIds.d.ts +3 -0
  296. package/build/esm/form-builder-v2/utils/stripIds.js +8 -0
  297. package/build/esm/form-builder-v2/utils/stripIds.js.map +1 -0
  298. package/build/esm/form-builder-v2/utils/treeWalk.d.ts +4 -0
  299. package/build/esm/form-builder-v2/utils/treeWalk.js +39 -0
  300. package/build/esm/form-builder-v2/utils/treeWalk.js.map +1 -0
  301. package/build/esm/form-generator-v2/components/constants.d.ts +11 -11
  302. package/build/esm/form-generator-v2/index.d.ts +2 -0
  303. package/build/esm/form-generator-v2/index.js +3 -0
  304. package/build/esm/form-generator-v2/index.js.map +1 -0
  305. package/package.json +21 -1
@@ -0,0 +1,20 @@
1
+ .pcformbuilderv2-inspector {
2
+ padding: 14px;
3
+ }
4
+ .pcformbuilderv2-inspector__header {
5
+ display: flex;
6
+ flex-direction: column;
7
+ gap: var(--g-spacing-half);
8
+ margin-bottom: var(--g-spacing-3);
9
+ padding-bottom: 10px;
10
+ border-bottom: 1px solid var(--g-color-line-generic);
11
+ }
12
+ .pcformbuilderv2-inspector__body {
13
+ display: flex;
14
+ flex-direction: column;
15
+ gap: var(--g-spacing-2);
16
+ }
17
+ .pcformbuilderv2-inspector__empty {
18
+ padding: var(--g-spacing-4) var(--g-spacing-2);
19
+ text-align: center;
20
+ }
@@ -0,0 +1,2 @@
1
+ import './Inspector.css';
2
+ export declare const Inspector: () => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,16 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import * as React from 'react';
3
+ import { Card, Text } from '@gravity-ui/uikit';
4
+ import { FieldSettings } from "../FieldSettings/FieldSettings.js";
5
+ import { useFormContext } from "../../hooks/FormContext.js";
6
+ import { formBuilderV2Cn } from "../../utils/cn.js";
7
+ import { TYPE_LABELS } from "../../utils/fieldMeta.js";
8
+ import { findFieldById } from "../../utils/fieldTree.js";
9
+ import './Inspector.css';
10
+ const b = formBuilderV2Cn('inspector');
11
+ export const Inspector = () => {
12
+ const { formFields, selectedFieldId } = useFormContext();
13
+ const selected = React.useMemo(() => (selectedFieldId ? findFieldById(formFields, selectedFieldId) : null), [formFields, selectedFieldId]);
14
+ return (_jsx(Card, { className: b(), view: "outlined", children: selected ? (_jsxs(React.Fragment, { children: [_jsxs("div", { className: b('header'), children: [_jsx(Text, { variant: "subheader-2", children: TYPE_LABELS[selected.type] }), 'name' in selected && selected.name ? (_jsx(Text, { variant: "caption-1", color: "hint", children: selected.name })) : null] }), _jsx("div", { className: b('body'), children: _jsx(FieldSettings, { field: selected }) })] })) : (_jsx("div", { className: b('empty'), children: _jsx(Text, { variant: "body-2", color: "hint", children: "Select a field on the canvas to edit its settings." }) })) }));
15
+ };
16
+ //# sourceMappingURL=Inspector.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Inspector.js","sourceRoot":"../../../../../src","sources":["form-builder-v2/components/Inspector/Inspector.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAC,IAAI,EAAE,IAAI,EAAC,MAAM,mBAAmB,CAAC;AAE7C,OAAO,EAAC,aAAa,EAAC,0CAAqD;AAC3E,OAAO,EAAC,cAAc,EAAC,mCAAgC;AACvD,OAAO,EAAC,eAAe,EAAC,0BAAuB;AAC/C,OAAO,EAAC,WAAW,EAAC,iCAA8B;AAClD,OAAO,EAAC,aAAa,EAAC,iCAA8B;AAEpD,OAAO,iBAAiB,CAAC;AAEzB,MAAM,CAAC,GAAG,eAAe,CAAC,WAAW,CAAC,CAAC;AAEvC,MAAM,CAAC,MAAM,SAAS,GAAG,GAAG,EAAE;IAC1B,MAAM,EAAC,UAAU,EAAE,eAAe,EAAC,GAAG,cAAc,EAAE,CAAC;IAEvD,MAAM,QAAQ,GAAG,KAAK,CAAC,OAAO,CAC1B,GAAG,EAAE,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,aAAa,CAAC,UAAU,EAAE,eAAe,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAC3E,CAAC,UAAU,EAAE,eAAe,CAAC,CAChC,CAAC;IAEF,OAAO,CACH,KAAC,IAAI,IAAC,SAAS,EAAE,CAAC,EAAE,EAAE,IAAI,EAAC,UAAU,YAChC,QAAQ,CAAC,CAAC,CAAC,CACR,MAAC,KAAK,CAAC,QAAQ,eACX,eAAK,SAAS,EAAE,CAAC,CAAC,QAAQ,CAAC,aACvB,KAAC,IAAI,IAAC,OAAO,EAAC,aAAa,YAAE,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAQ,EAC9D,MAAM,IAAI,QAAQ,IAAI,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CACnC,KAAC,IAAI,IAAC,OAAO,EAAC,WAAW,EAAC,KAAK,EAAC,MAAM,YACjC,QAAQ,CAAC,IAAI,GACX,CACV,CAAC,CAAC,CAAC,IAAI,IACN,EACN,cAAK,SAAS,EAAE,CAAC,CAAC,MAAM,CAAC,YACrB,KAAC,aAAa,IAAC,KAAK,EAAE,QAAQ,GAAI,GAChC,IACO,CACpB,CAAC,CAAC,CAAC,CACA,cAAK,SAAS,EAAE,CAAC,CAAC,OAAO,CAAC,YACtB,KAAC,IAAI,IAAC,OAAO,EAAC,QAAQ,EAAC,KAAK,EAAC,MAAM,mEAE5B,GACL,CACT,GACE,CACV,CAAC;AACN,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {Card, Text} from '@gravity-ui/uikit';\n\nimport {FieldSettings} from '../../components/FieldSettings/FieldSettings';\nimport {useFormContext} from '../../hooks/FormContext';\nimport {formBuilderV2Cn} from '../../utils/cn';\nimport {TYPE_LABELS} from '../../utils/fieldMeta';\nimport {findFieldById} from '../../utils/fieldTree';\n\nimport './Inspector.scss';\n\nconst b = formBuilderV2Cn('inspector');\n\nexport const Inspector = () => {\n const {formFields, selectedFieldId} = useFormContext();\n\n const selected = React.useMemo(\n () => (selectedFieldId ? findFieldById(formFields, selectedFieldId) : null),\n [formFields, selectedFieldId],\n );\n\n return (\n <Card className={b()} view=\"outlined\">\n {selected ? (\n <React.Fragment>\n <div className={b('header')}>\n <Text variant=\"subheader-2\">{TYPE_LABELS[selected.type]}</Text>\n {'name' in selected && selected.name ? (\n <Text variant=\"caption-1\" color=\"hint\">\n {selected.name}\n </Text>\n ) : null}\n </div>\n <div className={b('body')}>\n <FieldSettings field={selected} />\n </div>\n </React.Fragment>\n ) : (\n <div className={b('empty')}>\n <Text variant=\"body-2\" color=\"hint\">\n Select a field on the canvas to edit its settings.\n </Text>\n </div>\n )}\n </Card>\n );\n};\n"]}
@@ -0,0 +1,56 @@
1
+ .pcformbuilderv2-palette {
2
+ padding: var(--g-spacing-3);
3
+ }
4
+ .pcformbuilderv2-palette__header {
5
+ display: flex;
6
+ flex-direction: column;
7
+ gap: var(--g-spacing-half);
8
+ margin-bottom: 10px;
9
+ }
10
+ .pcformbuilderv2-palette__items {
11
+ display: grid;
12
+ grid-template-columns: 1fr 1fr;
13
+ gap: 6px;
14
+ }
15
+ .pcformbuilderv2-palette__tile {
16
+ display: flex;
17
+ flex-direction: column;
18
+ align-items: center;
19
+ justify-content: center;
20
+ gap: 6px;
21
+ aspect-ratio: 1;
22
+ width: 100%;
23
+ height: auto;
24
+ padding: var(--g-spacing-2);
25
+ border: 1px solid var(--g-color-line-generic);
26
+ border-radius: var(--g-border-radius-m);
27
+ background: transparent;
28
+ color: var(--g-color-text-primary);
29
+ cursor: grab;
30
+ transition: background-color 0.15s ease, border-color 0.15s ease, opacity 0.15s ease;
31
+ }
32
+ .pcformbuilderv2-palette__tile .g-button__text {
33
+ display: flex;
34
+ flex-direction: column;
35
+ align-items: center;
36
+ justify-content: center;
37
+ gap: 6px;
38
+ width: 100%;
39
+ }
40
+ .pcformbuilderv2-palette__tile:hover {
41
+ background-color: var(--g-color-base-simple-hover);
42
+ border-color: var(--g-color-line-generic-hover);
43
+ }
44
+ .pcformbuilderv2-palette__tile:active {
45
+ cursor: grabbing;
46
+ background-color: var(--g-color-base-simple-hover-solid);
47
+ }
48
+ .pcformbuilderv2-palette__tile_dragging {
49
+ opacity: 0.5;
50
+ }
51
+ .pcformbuilderv2-palette__tile-label {
52
+ font-size: var(--g-text-caption-2-font-size);
53
+ line-height: 1.2;
54
+ text-align: center;
55
+ color: var(--g-color-text-secondary);
56
+ }
@@ -0,0 +1,5 @@
1
+ import type { PaletteDragData } from "../../utils/dragData.js";
2
+ import './Palette.css';
3
+ export type { PaletteDragData };
4
+ export declare const PALETTE_DRAGGABLE_PREFIX = "palette:";
5
+ export declare const Palette: () => import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,58 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import * as React from 'react';
3
+ import { PointerActivationConstraints, PointerSensor } from '@dnd-kit/dom';
4
+ import { useDraggable } from '@dnd-kit/react';
5
+ import { Button, Card, Icon, Text, Tooltip } from '@gravity-ui/uikit';
6
+ import { useFormContext } from "../../hooks/FormContext.js";
7
+ import { formBuilderV2Cn } from "../../utils/cn.js";
8
+ import { FIELD_TYPES, PALETTE_LABELS, TYPE_ICONS } from "../../utils/fieldMeta.js";
9
+ import './Palette.css';
10
+ const b = formBuilderV2Cn('palette');
11
+ export const PALETTE_DRAGGABLE_PREFIX = 'palette:';
12
+ const findContainerId = (fields, selectedId, parentSectionId = null) => {
13
+ if (!selectedId)
14
+ return null;
15
+ for (const field of fields) {
16
+ if (field.id === selectedId) {
17
+ return field.type === 'section' ? field.id : parentSectionId;
18
+ }
19
+ if (field.type === 'section') {
20
+ const nested = findContainerId(field.fields, selectedId, field.id);
21
+ if (nested !== undefined)
22
+ return nested;
23
+ }
24
+ }
25
+ return undefined;
26
+ };
27
+ const DRAG_DISTANCE = 4;
28
+ const paletteSensors = [
29
+ PointerSensor.configure({
30
+ activationConstraints: [new PointerActivationConstraints.Distance({ value: DRAG_DISTANCE })],
31
+ }),
32
+ ];
33
+ const PaletteTile = ({ type, label, icon, onClick }) => {
34
+ const { ref, handleRef, isDragging } = useDraggable({
35
+ id: `${PALETTE_DRAGGABLE_PREFIX}${type}`,
36
+ data: { kind: 'palette', type },
37
+ sensors: paletteSensors,
38
+ });
39
+ const setRefs = React.useCallback((element) => {
40
+ ref(element);
41
+ handleRef(element);
42
+ }, [ref, handleRef]);
43
+ return (_jsx(Tooltip, { content: label, placement: "right", openDelay: 500, children: _jsxs(Button, { ref: setRefs, view: "flat", size: "m", className: b('tile', { dragging: isDragging }), onClick: onClick, children: [_jsx(Icon, { data: icon, size: 18 }), _jsx("span", { className: b('tile-label'), children: label })] }) }));
44
+ };
45
+ export const Palette = () => {
46
+ const { addField, addFieldToSection, formFields, selectedFieldId } = useFormContext();
47
+ const containerId = React.useMemo(() => findContainerId(formFields, selectedFieldId), [formFields, selectedFieldId]);
48
+ const handleAdd = (type) => {
49
+ if (containerId) {
50
+ addFieldToSection(containerId, type);
51
+ }
52
+ else {
53
+ addField(type);
54
+ }
55
+ };
56
+ return (_jsxs(Card, { className: b(), view: "outlined", children: [_jsxs("div", { className: b('header'), children: [_jsx(Text, { variant: "subheader-2", children: "Add field" }), _jsx(Text, { variant: "caption-1", color: "hint", children: "Click to add, or drag onto the canvas to drop at a specific position." })] }), _jsx("div", { className: b('items'), children: FIELD_TYPES.map((type) => (_jsx(PaletteTile, { type: type, label: PALETTE_LABELS[type], icon: TYPE_ICONS[type], onClick: () => handleAdd(type) }, type))) })] }));
57
+ };
58
+ //# sourceMappingURL=Palette.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Palette.js","sourceRoot":"../../../../../src","sources":["form-builder-v2/components/Palette/Palette.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {PointerActivationConstraints, PointerSensor} from '@dnd-kit/dom';\nimport {useDraggable} from '@dnd-kit/react';\nimport {Button, Card, Icon, Text, Tooltip} from '@gravity-ui/uikit';\nimport type {IconData} from '@gravity-ui/uikit';\n\nimport {useFormContext} from '../../hooks/FormContext';\nimport {BuilderFieldType, FormField} from '../../types';\nimport {formBuilderV2Cn} from '../../utils/cn';\nimport type {PaletteDragData} from '../../utils/dragData';\nimport {FIELD_TYPES, PALETTE_LABELS, TYPE_ICONS} from '../../utils/fieldMeta';\n\nimport './Palette.scss';\n\nexport type {PaletteDragData};\n\nconst b = formBuilderV2Cn('palette');\n\nexport const PALETTE_DRAGGABLE_PREFIX = 'palette:';\n\nconst findContainerId = (\n fields: FormField[],\n selectedId: string | null,\n parentSectionId: string | null = null,\n): string | null | undefined => {\n if (!selectedId) return null;\n for (const field of fields) {\n if (field.id === selectedId) {\n return field.type === 'section' ? field.id : parentSectionId;\n }\n if (field.type === 'section') {\n const nested = findContainerId(field.fields, selectedId, field.id);\n if (nested !== undefined) return nested;\n }\n }\n return undefined;\n};\n\ninterface PaletteTileProps {\n type: BuilderFieldType;\n label: string;\n icon: IconData;\n onClick: () => void;\n}\n\nconst DRAG_DISTANCE = 4;\n\nconst paletteSensors = [\n PointerSensor.configure({\n activationConstraints: [new PointerActivationConstraints.Distance({value: DRAG_DISTANCE})],\n }),\n];\n\nconst PaletteTile = ({type, label, icon, onClick}: PaletteTileProps) => {\n const {ref, handleRef, isDragging} = useDraggable({\n id: `${PALETTE_DRAGGABLE_PREFIX}${type}`,\n data: {kind: 'palette', type},\n sensors: paletteSensors,\n });\n\n const setRefs = React.useCallback(\n (element: HTMLButtonElement | null) => {\n ref(element);\n handleRef(element);\n },\n [ref, handleRef],\n );\n\n return (\n <Tooltip content={label} placement=\"right\" openDelay={500}>\n <Button\n ref={setRefs}\n view=\"flat\"\n size=\"m\"\n className={b('tile', {dragging: isDragging})}\n onClick={onClick}\n >\n <Icon data={icon} size={18} />\n <span className={b('tile-label')}>{label}</span>\n </Button>\n </Tooltip>\n );\n};\n\nexport const Palette = () => {\n const {addField, addFieldToSection, formFields, selectedFieldId} = useFormContext();\n\n const containerId = React.useMemo(\n () => findContainerId(formFields, selectedFieldId),\n [formFields, selectedFieldId],\n );\n\n const handleAdd = (type: BuilderFieldType) => {\n if (containerId) {\n addFieldToSection(containerId, type);\n } else {\n addField(type);\n }\n };\n\n return (\n <Card className={b()} view=\"outlined\">\n <div className={b('header')}>\n <Text variant=\"subheader-2\">Add field</Text>\n <Text variant=\"caption-1\" color=\"hint\">\n Click to add, or drag onto the canvas to drop at a specific position.\n </Text>\n </div>\n <div className={b('items')}>\n {FIELD_TYPES.map((type) => (\n <PaletteTile\n key={type}\n type={type}\n label={PALETTE_LABELS[type]}\n icon={TYPE_ICONS[type]}\n onClick={() => handleAdd(type)}\n />\n ))}\n </div>\n </Card>\n );\n};\n"]}
@@ -0,0 +1,29 @@
1
+ .pcformbuilderv2-resize-handle {
2
+ width: var(--g-spacing-2);
3
+ align-self: stretch;
4
+ cursor: col-resize;
5
+ position: relative;
6
+ user-select: none;
7
+ }
8
+ .pcformbuilderv2-resize-handle::after {
9
+ content: "";
10
+ position: absolute;
11
+ top: 50%;
12
+ left: 50%;
13
+ transform: translate(-50%, -50%);
14
+ width: 2px;
15
+ height: 40%;
16
+ background: var(--g-color-line-generic);
17
+ opacity: 0;
18
+ border-radius: 2px;
19
+ transition: opacity 0.12s ease, background-color 0.12s ease, height 0.12s ease;
20
+ }
21
+ .pcformbuilderv2-resize-handle:hover::after {
22
+ opacity: 1;
23
+ height: 60%;
24
+ }
25
+ .pcformbuilderv2-resize-handle_dragging::after {
26
+ opacity: 1;
27
+ height: 100%;
28
+ background: var(--g-color-line-brand);
29
+ }
@@ -0,0 +1,10 @@
1
+ import './ResizeHandle.css';
2
+ interface ResizeHandleProps {
3
+ value: number;
4
+ min: number;
5
+ max: number;
6
+ direction: 'left' | 'right';
7
+ onChange: (next: number) => void;
8
+ }
9
+ export declare const ResizeHandle: ({ value, min, max, direction, onChange }: ResizeHandleProps) => import("react/jsx-runtime").JSX.Element;
10
+ export {};
@@ -0,0 +1,94 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import * as React from 'react';
3
+ import { formBuilderV2Cn } from "../../utils/cn.js";
4
+ import './ResizeHandle.css';
5
+ const b = formBuilderV2Cn('resize-handle');
6
+ export const ResizeHandle = ({ value, min, max, direction, onChange }) => {
7
+ const [dragging, setDragging] = React.useState(false);
8
+ const onChangeRef = React.useRef(onChange);
9
+ onChangeRef.current = onChange;
10
+ const cleanupRef = React.useRef(null);
11
+ const mountedRef = React.useRef(true);
12
+ React.useEffect(() => {
13
+ mountedRef.current = true;
14
+ return () => {
15
+ mountedRef.current = false;
16
+ cleanupRef.current?.();
17
+ };
18
+ }, []);
19
+ const onMouseDown = React.useCallback((event) => {
20
+ event.preventDefault();
21
+ const startX = event.clientX;
22
+ const startValue = value;
23
+ setDragging(true);
24
+ let rafId = null;
25
+ let pendingValue = startValue;
26
+ const controller = new AbortController();
27
+ const { signal } = controller;
28
+ const flush = () => {
29
+ rafId = null;
30
+ onChangeRef.current(pendingValue);
31
+ };
32
+ const cleanup = () => {
33
+ if (signal.aborted)
34
+ return;
35
+ controller.abort();
36
+ if (rafId !== null) {
37
+ cancelAnimationFrame(rafId);
38
+ rafId = null;
39
+ }
40
+ document.body.style.cursor = '';
41
+ document.body.style.userSelect = '';
42
+ cleanupRef.current = null;
43
+ };
44
+ const handleMove = (moveEvent) => {
45
+ const deltaRaw = moveEvent.clientX - startX;
46
+ const delta = direction === 'left' ? deltaRaw : -deltaRaw;
47
+ pendingValue = Math.max(min, Math.min(max, startValue + delta));
48
+ if (rafId === null) {
49
+ rafId = requestAnimationFrame(flush);
50
+ }
51
+ };
52
+ const handleUp = () => {
53
+ if (rafId !== null) {
54
+ cancelAnimationFrame(rafId);
55
+ rafId = null;
56
+ onChangeRef.current(pendingValue);
57
+ }
58
+ if (mountedRef.current) {
59
+ setDragging(false);
60
+ }
61
+ cleanup();
62
+ };
63
+ document.body.style.cursor = 'col-resize';
64
+ document.body.style.userSelect = 'none';
65
+ document.addEventListener('mousemove', handleMove, { signal });
66
+ document.addEventListener('mouseup', handleUp, { signal });
67
+ cleanupRef.current = cleanup;
68
+ }, [direction, max, min, value]);
69
+ const onKeyDown = React.useCallback((event) => {
70
+ const STEP = event.shiftKey ? 32 : 8;
71
+ const sign = direction === 'left' ? 1 : -1;
72
+ let next = null;
73
+ switch (event.key) {
74
+ case 'ArrowLeft':
75
+ next = value + sign * -STEP;
76
+ break;
77
+ case 'ArrowRight':
78
+ next = value + sign * STEP;
79
+ break;
80
+ case 'Home':
81
+ next = direction === 'left' ? min : max;
82
+ break;
83
+ case 'End':
84
+ next = direction === 'left' ? max : min;
85
+ break;
86
+ default:
87
+ return;
88
+ }
89
+ event.preventDefault();
90
+ onChangeRef.current(Math.max(min, Math.min(max, next)));
91
+ }, [direction, max, min, value]);
92
+ return (_jsx("div", { className: b({ dragging }), onMouseDown: onMouseDown, onKeyDown: onKeyDown, role: "slider", "aria-orientation": "vertical", "aria-valuemin": min, "aria-valuemax": max, "aria-valuenow": value, "aria-label": direction === 'left' ? 'Resize palette' : 'Resize inspector', tabIndex: 0 }));
93
+ };
94
+ //# sourceMappingURL=ResizeHandle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ResizeHandle.js","sourceRoot":"../../../../../src","sources":["form-builder-v2/components/ResizeHandle/ResizeHandle.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {formBuilderV2Cn} from '../../utils/cn';\n\nimport './ResizeHandle.scss';\n\nconst b = formBuilderV2Cn('resize-handle');\n\ninterface ResizeHandleProps {\n value: number;\n min: number;\n max: number;\n direction: 'left' | 'right';\n onChange: (next: number) => void;\n}\n\nexport const ResizeHandle = ({value, min, max, direction, onChange}: ResizeHandleProps) => {\n const [dragging, setDragging] = React.useState(false);\n const onChangeRef = React.useRef(onChange);\n onChangeRef.current = onChange;\n\n const cleanupRef = React.useRef<(() => void) | null>(null);\n const mountedRef = React.useRef(true);\n\n React.useEffect(() => {\n mountedRef.current = true;\n return () => {\n mountedRef.current = false;\n cleanupRef.current?.();\n };\n }, []);\n\n const onMouseDown = React.useCallback(\n (event: React.MouseEvent) => {\n event.preventDefault();\n const startX = event.clientX;\n const startValue = value;\n setDragging(true);\n\n let rafId: number | null = null;\n let pendingValue = startValue;\n const controller = new AbortController();\n const {signal} = controller;\n\n const flush = () => {\n rafId = null;\n onChangeRef.current(pendingValue);\n };\n\n const cleanup = () => {\n if (signal.aborted) return;\n controller.abort();\n if (rafId !== null) {\n cancelAnimationFrame(rafId);\n rafId = null;\n }\n document.body.style.cursor = '';\n document.body.style.userSelect = '';\n cleanupRef.current = null;\n };\n\n const handleMove = (moveEvent: MouseEvent) => {\n const deltaRaw = moveEvent.clientX - startX;\n const delta = direction === 'left' ? deltaRaw : -deltaRaw;\n pendingValue = Math.max(min, Math.min(max, startValue + delta));\n if (rafId === null) {\n rafId = requestAnimationFrame(flush);\n }\n };\n\n const handleUp = () => {\n if (rafId !== null) {\n cancelAnimationFrame(rafId);\n rafId = null;\n onChangeRef.current(pendingValue);\n }\n if (mountedRef.current) {\n setDragging(false);\n }\n cleanup();\n };\n\n document.body.style.cursor = 'col-resize';\n document.body.style.userSelect = 'none';\n\n document.addEventListener('mousemove', handleMove, {signal});\n document.addEventListener('mouseup', handleUp, {signal});\n\n cleanupRef.current = cleanup;\n },\n [direction, max, min, value],\n );\n\n const onKeyDown = React.useCallback(\n (event: React.KeyboardEvent<HTMLDivElement>) => {\n const STEP = event.shiftKey ? 32 : 8;\n const sign = direction === 'left' ? 1 : -1;\n let next: number | null = null;\n switch (event.key) {\n case 'ArrowLeft':\n next = value + sign * -STEP;\n break;\n case 'ArrowRight':\n next = value + sign * STEP;\n break;\n case 'Home':\n next = direction === 'left' ? min : max;\n break;\n case 'End':\n next = direction === 'left' ? max : min;\n break;\n default:\n return;\n }\n event.preventDefault();\n onChangeRef.current(Math.max(min, Math.min(max, next)));\n },\n [direction, max, min, value],\n );\n\n return (\n <div\n className={b({dragging})}\n onMouseDown={onMouseDown}\n onKeyDown={onKeyDown}\n role=\"slider\"\n aria-orientation=\"vertical\"\n aria-valuemin={min}\n aria-valuemax={max}\n aria-valuenow={value}\n aria-label={direction === 'left' ? 'Resize palette' : 'Resize inspector'}\n tabIndex={0}\n />\n );\n};\n"]}
@@ -0,0 +1,49 @@
1
+ .pcformbuilderv2-schema-popup {
2
+ width: min(560px, 90vw);
3
+ padding: var(--g-spacing-4);
4
+ display: flex;
5
+ flex-direction: column;
6
+ gap: 10px;
7
+ }
8
+ .pcformbuilderv2-schema-popup__header {
9
+ display: flex;
10
+ flex-direction: column;
11
+ gap: var(--g-spacing-half);
12
+ }
13
+ .pcformbuilderv2-schema-popup__textarea {
14
+ box-sizing: border-box;
15
+ width: 100%;
16
+ max-width: 100%;
17
+ min-height: 400px;
18
+ max-height: min(70vh, 700px);
19
+ padding: var(--g-spacing-3);
20
+ background: var(--g-color-base-generic);
21
+ border: 1px solid var(--g-color-line-generic);
22
+ border-radius: var(--g-border-radius-m);
23
+ font-family: monospace;
24
+ font-size: 12px;
25
+ line-height: 1.4;
26
+ color: var(--g-color-text-primary);
27
+ white-space: pre;
28
+ overflow: auto;
29
+ resize: vertical;
30
+ outline: none;
31
+ transition: border-color 0.15s ease;
32
+ tab-size: 2;
33
+ }
34
+ .pcformbuilderv2-schema-popup__textarea:focus {
35
+ border-color: var(--g-color-line-brand);
36
+ }
37
+ .pcformbuilderv2-schema-popup__textarea_error {
38
+ border-color: var(--g-color-line-danger);
39
+ }
40
+ .pcformbuilderv2-schema-popup__error-message {
41
+ padding: var(--g-spacing-2) var(--g-spacing-3);
42
+ background: var(--g-color-base-danger-light);
43
+ border-radius: var(--g-border-radius-m);
44
+ }
45
+ .pcformbuilderv2-schema-popup__actions {
46
+ display: flex;
47
+ gap: var(--g-spacing-2);
48
+ justify-content: flex-end;
49
+ }
@@ -0,0 +1,12 @@
1
+ import type { Fields } from "../../../form-generator-v2/types.js";
2
+ import type { FormField } from "../../types.js";
3
+ import './SchemaPopup.css';
4
+ interface SchemaPopupProps {
5
+ schema: Fields;
6
+ onApply: (fields: FormField[]) => void;
7
+ open: boolean;
8
+ onOpenChange: (open: boolean) => void;
9
+ anchorElement: HTMLElement | null;
10
+ }
11
+ export declare const SchemaPopup: ({ schema, onApply, open, onOpenChange, anchorElement, }: SchemaPopupProps) => import("react/jsx-runtime").JSX.Element;
12
+ export {};
@@ -0,0 +1,78 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import * as React from 'react';
3
+ import { Button, Card, Popup, Text } from '@gravity-ui/uikit';
4
+ import { formBuilderV2Cn } from "../../utils/cn.js";
5
+ import { parseSchema } from "../../utils/parseSchema.js";
6
+ import './SchemaPopup.css';
7
+ const b = formBuilderV2Cn('schema-popup');
8
+ const stringify = (schema) => JSON.stringify(schema, null, 2);
9
+ export const SchemaPopup = ({ schema, onApply, open, onOpenChange, anchorElement, }) => {
10
+ const textareaRef = React.useRef(null);
11
+ const copyTimeoutRef = React.useRef(null);
12
+ const [draft, setDraft] = React.useState(() => stringify(schema));
13
+ const [error, setError] = React.useState(null);
14
+ const [copied, setCopied] = React.useState(false);
15
+ const [isFocused, setIsFocused] = React.useState(false);
16
+ React.useEffect(() => {
17
+ if (!isFocused) {
18
+ setDraft(stringify(schema));
19
+ setError(null);
20
+ }
21
+ }, [schema, isFocused]);
22
+ React.useEffect(() => () => {
23
+ if (copyTimeoutRef.current)
24
+ clearTimeout(copyTimeoutRef.current);
25
+ }, []);
26
+ const applyDraft = (value) => {
27
+ setDraft(value);
28
+ const result = parseSchema(value);
29
+ if (result.ok) {
30
+ setError(null);
31
+ onApply(result.fields);
32
+ }
33
+ else {
34
+ setError(result.error);
35
+ }
36
+ };
37
+ const replaceSelection = (insert, caretOffset) => {
38
+ const t = textareaRef.current;
39
+ if (!t)
40
+ return;
41
+ const { selectionStart, selectionEnd } = t;
42
+ const next = draft.slice(0, selectionStart) + insert + draft.slice(selectionEnd);
43
+ const nextCaret = selectionStart + caretOffset;
44
+ applyDraft(next);
45
+ requestAnimationFrame(() => {
46
+ t.selectionStart = nextCaret;
47
+ t.selectionEnd = nextCaret;
48
+ });
49
+ };
50
+ const handleKeyDown = (event) => {
51
+ if (event.key === 'Tab') {
52
+ event.preventDefault();
53
+ replaceSelection(' ', 2);
54
+ return;
55
+ }
56
+ if (event.key === 'Enter') {
57
+ event.preventDefault();
58
+ const t = event.currentTarget;
59
+ const before = draft.slice(0, t.selectionStart);
60
+ const lineStart = before.lastIndexOf('\n') + 1;
61
+ const indent = before.slice(lineStart).match(/^[ \t]*/)?.[0] ?? '';
62
+ const insert = `\n${indent}`;
63
+ replaceSelection(insert, insert.length);
64
+ }
65
+ };
66
+ const handleCopy = React.useCallback(async () => {
67
+ try {
68
+ await navigator.clipboard.writeText(draft);
69
+ setCopied(true);
70
+ if (copyTimeoutRef.current)
71
+ clearTimeout(copyTimeoutRef.current);
72
+ copyTimeoutRef.current = setTimeout(() => setCopied(false), 1500);
73
+ }
74
+ catch { }
75
+ }, [draft]);
76
+ return (_jsx(Popup, { anchorElement: anchorElement, open: open, onOpenChange: onOpenChange, placement: "bottom-end", children: _jsxs(Card, { className: b(), view: "outlined", children: [_jsxs("div", { className: b('header'), children: [_jsx(Text, { variant: "subheader-2", children: "Form schema" }), _jsx(Text, { variant: "caption-1", color: "hint", children: "Edit JSON directly \u2014 the canvas updates live. Paste your own schema to load it. Selection on canvas resets after each edit." })] }), _jsx("textarea", { ref: textareaRef, className: b('textarea', { error: Boolean(error) }), value: draft, onChange: (event) => applyDraft(event.target.value), onKeyDown: handleKeyDown, onFocus: () => setIsFocused(true), onBlur: () => setIsFocused(false), spellCheck: false, wrap: "off" }), error && (_jsx("div", { className: b('error-message'), children: _jsx(Text, { variant: "caption-1", color: "danger", children: error }) })), _jsxs("div", { className: b('actions'), children: [_jsx(Button, { view: "action", size: "m", onClick: handleCopy, children: copied ? '✓ Copied' : 'Copy' }), _jsx(Button, { view: "flat", size: "m", onClick: () => onOpenChange(false), children: "Close" })] })] }) }));
77
+ };
78
+ //# sourceMappingURL=SchemaPopup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SchemaPopup.js","sourceRoot":"../../../../../src","sources":["form-builder-v2/components/SchemaPopup/SchemaPopup.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAC,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAC,MAAM,mBAAmB,CAAC;AAI5D,OAAO,EAAC,eAAe,EAAC,0BAAuB;AAC/C,OAAO,EAAC,WAAW,EAAC,mCAAgC;AAEpD,OAAO,mBAAmB,CAAC;AAE3B,MAAM,CAAC,GAAG,eAAe,CAAC,cAAc,CAAC,CAAC;AAE1C,MAAM,SAAS,GAAG,CAAC,MAAc,EAAU,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;AAU9E,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,EACxB,MAAM,EACN,OAAO,EACP,IAAI,EACJ,YAAY,EACZ,aAAa,GACE,EAAE,EAAE;IACnB,MAAM,WAAW,GAAG,KAAK,CAAC,MAAM,CAAsB,IAAI,CAAC,CAAC;IAC5D,MAAM,cAAc,GAAG,KAAK,CAAC,MAAM,CAAuC,IAAI,CAAC,CAAC;IAChF,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAS,GAAG,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC;IAC1E,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAgB,IAAI,CAAC,CAAC;IAC9D,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAClD,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAExD,KAAK,CAAC,SAAS,CAAC,GAAG,EAAE;QACjB,IAAI,CAAC,SAAS,EAAE,CAAC;YACb,QAAQ,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC;YAC5B,QAAQ,CAAC,IAAI,CAAC,CAAC;QACnB,CAAC;IACL,CAAC,EAAE,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC,CAAC;IAExB,KAAK,CAAC,SAAS,CACX,GAAG,EAAE,CAAC,GAAG,EAAE;QACP,IAAI,cAAc,CAAC,OAAO;YAAE,YAAY,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;IACrE,CAAC,EACD,EAAE,CACL,CAAC;IAEF,MAAM,UAAU,GAAG,CAAC,KAAa,EAAE,EAAE;QACjC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAChB,MAAM,MAAM,GAAG,WAAW,CAAC,KAAK,CAAC,CAAC;QAClC,IAAI,MAAM,CAAC,EAAE,EAAE,CAAC;YACZ,QAAQ,CAAC,IAAI,CAAC,CAAC;YACf,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAC3B,CAAC;aAAM,CAAC;YACJ,QAAQ,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAC3B,CAAC;IACL,CAAC,CAAC;IAEF,MAAM,gBAAgB,GAAG,CAAC,MAAc,EAAE,WAAmB,EAAE,EAAE;QAC7D,MAAM,CAAC,GAAG,WAAW,CAAC,OAAO,CAAC;QAC9B,IAAI,CAAC,CAAC;YAAE,OAAO;QACf,MAAM,EAAC,cAAc,EAAE,YAAY,EAAC,GAAG,CAAC,CAAC;QACzC,MAAM,IAAI,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,cAAc,CAAC,GAAG,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QACjF,MAAM,SAAS,GAAG,cAAc,GAAG,WAAW,CAAC;QAC/C,UAAU,CAAC,IAAI,CAAC,CAAC;QACjB,qBAAqB,CAAC,GAAG,EAAE;YACvB,CAAC,CAAC,cAAc,GAAG,SAAS,CAAC;YAC7B,CAAC,CAAC,YAAY,GAAG,SAAS,CAAC;QAC/B,CAAC,CAAC,CAAC;IACP,CAAC,CAAC;IAEF,MAAM,aAAa,GAAG,CAAC,KAA+C,EAAE,EAAE;QACtE,IAAI,KAAK,CAAC,GAAG,KAAK,KAAK,EAAE,CAAC;YACtB,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,gBAAgB,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;YAC1B,OAAO;QACX,CAAC;QACD,IAAI,KAAK,CAAC,GAAG,KAAK,OAAO,EAAE,CAAC;YACxB,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,MAAM,CAAC,GAAG,KAAK,CAAC,aAAa,CAAC;YAC9B,MAAM,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,cAAc,CAAC,CAAC;YAChD,MAAM,SAAS,GAAG,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC/C,MAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;YACnE,MAAM,MAAM,GAAG,KAAK,MAAM,EAAE,CAAC;YAC7B,gBAAgB,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;QAC5C,CAAC;IACL,CAAC,CAAC;IAEF,MAAM,UAAU,GAAG,KAAK,CAAC,WAAW,CAAC,KAAK,IAAI,EAAE;QAC5C,IAAI,CAAC;YACD,MAAM,SAAS,CAAC,SAAS,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;YAC3C,SAAS,CAAC,IAAI,CAAC,CAAC;YAChB,IAAI,cAAc,CAAC,OAAO;gBAAE,YAAY,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;YACjE,cAAc,CAAC,OAAO,GAAG,UAAU,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,CAAC;QACtE,CAAC;QAAC,MAAM,CAAC,CAAA,CAAC;IACd,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IAEZ,OAAO,CACH,KAAC,KAAK,IACF,aAAa,EAAE,aAAa,EAC5B,IAAI,EAAE,IAAI,EACV,YAAY,EAAE,YAAY,EAC1B,SAAS,EAAC,YAAY,YAEtB,MAAC,IAAI,IAAC,SAAS,EAAE,CAAC,EAAE,EAAE,IAAI,EAAC,UAAU,aACjC,eAAK,SAAS,EAAE,CAAC,CAAC,QAAQ,CAAC,aACvB,KAAC,IAAI,IAAC,OAAO,EAAC,aAAa,4BAAmB,EAC9C,KAAC,IAAI,IAAC,OAAO,EAAC,WAAW,EAAC,KAAK,EAAC,MAAM,iJAG/B,IACL,EACN,mBACI,GAAG,EAAE,WAAW,EAChB,SAAS,EAAE,CAAC,CAAC,UAAU,EAAE,EAAC,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,EAAC,CAAC,EACjD,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,EACnD,SAAS,EAAE,aAAa,EACxB,OAAO,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,EACjC,MAAM,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC,EACjC,UAAU,EAAE,KAAK,EACjB,IAAI,EAAC,KAAK,GACZ,EACD,KAAK,IAAI,CACN,cAAK,SAAS,EAAE,CAAC,CAAC,eAAe,CAAC,YAC9B,KAAC,IAAI,IAAC,OAAO,EAAC,WAAW,EAAC,KAAK,EAAC,QAAQ,YACnC,KAAK,GACH,GACL,CACT,EACD,eAAK,SAAS,EAAE,CAAC,CAAC,SAAS,CAAC,aACxB,KAAC,MAAM,IAAC,IAAI,EAAC,QAAQ,EAAC,IAAI,EAAC,GAAG,EAAC,OAAO,EAAE,UAAU,YAC7C,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,MAAM,GACxB,EACT,KAAC,MAAM,IAAC,IAAI,EAAC,MAAM,EAAC,IAAI,EAAC,GAAG,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,KAAK,CAAC,sBAEtD,IACP,IACH,GACH,CACX,CAAC;AACN,CAAC,CAAC","sourcesContent":["import * as React from 'react';\n\nimport {Button, Card, Popup, Text} from '@gravity-ui/uikit';\n\nimport type {Fields} from '../../../form-generator-v2/types';\nimport type {FormField} from '../../types';\nimport {formBuilderV2Cn} from '../../utils/cn';\nimport {parseSchema} from '../../utils/parseSchema';\n\nimport './SchemaPopup.scss';\n\nconst b = formBuilderV2Cn('schema-popup');\n\nconst stringify = (schema: Fields): string => JSON.stringify(schema, null, 2);\n\ninterface SchemaPopupProps {\n schema: Fields;\n onApply: (fields: FormField[]) => void;\n open: boolean;\n onOpenChange: (open: boolean) => void;\n anchorElement: HTMLElement | null;\n}\n\nexport const SchemaPopup = ({\n schema,\n onApply,\n open,\n onOpenChange,\n anchorElement,\n}: SchemaPopupProps) => {\n const textareaRef = React.useRef<HTMLTextAreaElement>(null);\n const copyTimeoutRef = React.useRef<ReturnType<typeof setTimeout> | null>(null);\n const [draft, setDraft] = React.useState<string>(() => stringify(schema));\n const [error, setError] = React.useState<string | null>(null);\n const [copied, setCopied] = React.useState(false);\n const [isFocused, setIsFocused] = React.useState(false);\n\n React.useEffect(() => {\n if (!isFocused) {\n setDraft(stringify(schema));\n setError(null);\n }\n }, [schema, isFocused]);\n\n React.useEffect(\n () => () => {\n if (copyTimeoutRef.current) clearTimeout(copyTimeoutRef.current);\n },\n [],\n );\n\n const applyDraft = (value: string) => {\n setDraft(value);\n const result = parseSchema(value);\n if (result.ok) {\n setError(null);\n onApply(result.fields);\n } else {\n setError(result.error);\n }\n };\n\n const replaceSelection = (insert: string, caretOffset: number) => {\n const t = textareaRef.current;\n if (!t) return;\n const {selectionStart, selectionEnd} = t;\n const next = draft.slice(0, selectionStart) + insert + draft.slice(selectionEnd);\n const nextCaret = selectionStart + caretOffset;\n applyDraft(next);\n requestAnimationFrame(() => {\n t.selectionStart = nextCaret;\n t.selectionEnd = nextCaret;\n });\n };\n\n const handleKeyDown = (event: React.KeyboardEvent<HTMLTextAreaElement>) => {\n if (event.key === 'Tab') {\n event.preventDefault();\n replaceSelection(' ', 2);\n return;\n }\n if (event.key === 'Enter') {\n event.preventDefault();\n const t = event.currentTarget;\n const before = draft.slice(0, t.selectionStart);\n const lineStart = before.lastIndexOf('\\n') + 1;\n const indent = before.slice(lineStart).match(/^[ \\t]*/)?.[0] ?? '';\n const insert = `\\n${indent}`;\n replaceSelection(insert, insert.length);\n }\n };\n\n const handleCopy = React.useCallback(async () => {\n try {\n await navigator.clipboard.writeText(draft);\n setCopied(true);\n if (copyTimeoutRef.current) clearTimeout(copyTimeoutRef.current);\n copyTimeoutRef.current = setTimeout(() => setCopied(false), 1500);\n } catch {}\n }, [draft]);\n\n return (\n <Popup\n anchorElement={anchorElement}\n open={open}\n onOpenChange={onOpenChange}\n placement=\"bottom-end\"\n >\n <Card className={b()} view=\"outlined\">\n <div className={b('header')}>\n <Text variant=\"subheader-2\">Form schema</Text>\n <Text variant=\"caption-1\" color=\"hint\">\n Edit JSON directly — the canvas updates live. Paste your own schema to load\n it. Selection on canvas resets after each edit.\n </Text>\n </div>\n <textarea\n ref={textareaRef}\n className={b('textarea', {error: Boolean(error)})}\n value={draft}\n onChange={(event) => applyDraft(event.target.value)}\n onKeyDown={handleKeyDown}\n onFocus={() => setIsFocused(true)}\n onBlur={() => setIsFocused(false)}\n spellCheck={false}\n wrap=\"off\"\n />\n {error && (\n <div className={b('error-message')}>\n <Text variant=\"caption-1\" color=\"danger\">\n {error}\n </Text>\n </div>\n )}\n <div className={b('actions')}>\n <Button view=\"action\" size=\"m\" onClick={handleCopy}>\n {copied ? '✓ Copied' : 'Copy'}\n </Button>\n <Button view=\"flat\" size=\"m\" onClick={() => onOpenChange(false)}>\n Close\n </Button>\n </div>\n </Card>\n </Popup>\n );\n};\n"]}
@@ -0,0 +1,24 @@
1
+ .pcformbuilderv2-when-editor {
2
+ display: flex;
3
+ flex-direction: column;
4
+ gap: 6px;
5
+ padding: var(--g-spacing-2);
6
+ border: 1px solid var(--g-color-line-generic);
7
+ border-radius: var(--g-border-radius-m);
8
+ }
9
+ .pcformbuilderv2-when-editor__condition {
10
+ display: grid;
11
+ grid-template-columns: minmax(0, 1fr) 80px minmax(0, 1fr) auto;
12
+ gap: 6px;
13
+ align-items: center;
14
+ }
15
+ .pcformbuilderv2-when-editor__combinator {
16
+ display: flex;
17
+ align-items: center;
18
+ }
19
+ .pcformbuilderv2-when-editor__actions {
20
+ display: flex;
21
+ gap: var(--g-spacing-2);
22
+ align-items: center;
23
+ margin-top: var(--g-spacing-1);
24
+ }
@@ -0,0 +1,9 @@
1
+ import type { When } from "../../../form-generator-v2/types.js";
2
+ import './WhenEditor.css';
3
+ interface WhenEditorProps {
4
+ when: When | undefined;
5
+ availableFields: string[];
6
+ onChange: (next: When | undefined) => void;
7
+ }
8
+ export declare const WhenEditor: ({ when, availableFields, onChange }: WhenEditorProps) => import("react/jsx-runtime").JSX.Element;
9
+ export {};
@@ -0,0 +1,46 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import * as React from 'react';
3
+ import { TrashBin } from '@gravity-ui/icons';
4
+ import { Button, Icon, Select, TextInput } from '@gravity-ui/uikit';
5
+ import { formBuilderV2Cn } from "../../utils/cn.js";
6
+ import { COMBINATOR_OPTIONS, OPERATOR_OPTIONS, coerceValue, displayValue, parse, serialize, } from "./utils.js";
7
+ import './WhenEditor.css';
8
+ const b = formBuilderV2Cn('when-editor');
9
+ export const WhenEditor = ({ when, availableFields, onChange }) => {
10
+ const { conditions, combinators } = parse(when);
11
+ const fieldOptions = React.useMemo(() => availableFields.map((name) => ({ value: name, content: name })), [availableFields]);
12
+ const commit = (nextConditions, nextCombinators) => {
13
+ onChange(serialize(nextConditions, nextCombinators));
14
+ };
15
+ const addCondition = () => {
16
+ const nextConditions = [
17
+ ...conditions,
18
+ { field: availableFields[0] ?? '', operator: '===', value: '' },
19
+ ];
20
+ const nextCombinators = conditions.length === 0 ? combinators : [...combinators, { operator: '&&' }];
21
+ commit(nextConditions, nextCombinators);
22
+ };
23
+ const removeCondition = (index) => {
24
+ const nextConditions = conditions.filter((_, i) => i !== index);
25
+ const nextCombinators = index === 0
26
+ ? combinators.slice(1)
27
+ : [...combinators.slice(0, index - 1), ...combinators.slice(index)];
28
+ commit(nextConditions, nextCombinators);
29
+ };
30
+ const updateCondition = (index, patch) => {
31
+ const nextConditions = conditions.map((c, i) => (i === index ? { ...c, ...patch } : c));
32
+ commit(nextConditions, combinators);
33
+ };
34
+ const updateCombinator = (index, op) => {
35
+ const nextCombinators = combinators.map((c, i) => (i === index ? { operator: op } : c));
36
+ commit(conditions, nextCombinators);
37
+ };
38
+ const clearAll = () => {
39
+ onChange(undefined);
40
+ };
41
+ if (conditions.length === 0) {
42
+ return (_jsx("div", { className: b(), children: _jsx(Button, { view: "normal", size: "s", onClick: addCondition, children: "+ Add condition" }) }));
43
+ }
44
+ return (_jsxs("div", { className: b(), children: [conditions.map((cond, i) => (_jsxs(React.Fragment, { children: [i > 0 && (_jsx("div", { className: b('combinator'), children: _jsx(Select, { size: "s", value: [combinators[i - 1]?.operator ?? '&&'], options: COMBINATOR_OPTIONS, onUpdate: (next) => updateCombinator(i - 1, next[0]), width: 80 }) })), _jsxs("div", { className: b('condition'), children: [_jsx(Select, { size: "s", value: [cond.field], options: fieldOptions, onUpdate: (next) => updateCondition(i, { field: next[0] ?? '' }), placeholder: "field", filterable: true, width: "max" }), _jsx(Select, { size: "s", value: [cond.operator], options: OPERATOR_OPTIONS, onUpdate: (next) => updateCondition(i, { operator: next[0] }), width: 80 }), _jsx(TextInput, { size: "s", value: displayValue(cond.value), onUpdate: (value) => updateCondition(i, { value: coerceValue(value) }), placeholder: 'value ("true"/"false" \u2192 bool)' }), _jsx(Button, { view: "flat-danger", size: "s", onClick: () => removeCondition(i), title: "Remove condition", children: _jsx(Icon, { data: TrashBin, size: 12 }) })] })] }, i))), _jsxs("div", { className: b('actions'), children: [_jsx(Button, { view: "normal", size: "s", onClick: addCondition, children: "+ Add condition" }), _jsx(Button, { view: "flat", size: "s", onClick: clearAll, children: "Clear" })] })] }));
45
+ };
46
+ //# sourceMappingURL=WhenEditor.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"WhenEditor.js","sourceRoot":"../../../../../src","sources":["form-builder-v2/components/WhenEditor/WhenEditor.tsx"],"names":[],"mappings":"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","sourcesContent":["import * as React from 'react';\n\nimport {TrashBin} from '@gravity-ui/icons';\nimport {Button, Icon, Select, TextInput} from '@gravity-ui/uikit';\n\nimport type {When} from '../../../form-generator-v2/types';\nimport {formBuilderV2Cn} from '../../utils/cn';\n\nimport {\n COMBINATOR_OPTIONS,\n Combinator,\n Condition,\n OPERATOR_OPTIONS,\n coerceValue,\n displayValue,\n parse,\n serialize,\n} from './utils';\n\nimport './WhenEditor.scss';\n\nconst b = formBuilderV2Cn('when-editor');\n\ninterface WhenEditorProps {\n when: When | undefined;\n availableFields: string[];\n onChange: (next: When | undefined) => void;\n}\n\nexport const WhenEditor = ({when, availableFields, onChange}: WhenEditorProps) => {\n const {conditions, combinators} = parse(when);\n\n const fieldOptions = React.useMemo(\n () => availableFields.map((name) => ({value: name, content: name})),\n [availableFields],\n );\n\n const commit = (nextConditions: Condition[], nextCombinators: Combinator[]) => {\n onChange(serialize(nextConditions, nextCombinators));\n };\n\n const addCondition = () => {\n const nextConditions: Condition[] = [\n ...conditions,\n {field: availableFields[0] ?? '', operator: '===', value: ''},\n ];\n const nextCombinators: Combinator[] =\n conditions.length === 0 ? combinators : [...combinators, {operator: '&&'}];\n commit(nextConditions, nextCombinators);\n };\n\n const removeCondition = (index: number) => {\n const nextConditions = conditions.filter((_, i) => i !== index);\n const nextCombinators =\n index === 0\n ? combinators.slice(1)\n : [...combinators.slice(0, index - 1), ...combinators.slice(index)];\n commit(nextConditions, nextCombinators);\n };\n\n const updateCondition = (index: number, patch: Partial<Condition>) => {\n const nextConditions = conditions.map((c, i) => (i === index ? {...c, ...patch} : c));\n commit(nextConditions, combinators);\n };\n\n const updateCombinator = (index: number, op: '&&' | '||') => {\n const nextCombinators = combinators.map((c, i) => (i === index ? {operator: op} : c));\n commit(conditions, nextCombinators);\n };\n\n const clearAll = () => {\n onChange(undefined);\n };\n\n if (conditions.length === 0) {\n return (\n <div className={b()}>\n <Button view=\"normal\" size=\"s\" onClick={addCondition}>\n + Add condition\n </Button>\n </div>\n );\n }\n\n return (\n <div className={b()}>\n {conditions.map((cond, i) => (\n <React.Fragment key={i}>\n {i > 0 && (\n <div className={b('combinator')}>\n <Select\n size=\"s\"\n value={[combinators[i - 1]?.operator ?? '&&']}\n options={COMBINATOR_OPTIONS}\n onUpdate={(next) => updateCombinator(i - 1, next[0] as '&&' | '||')}\n width={80}\n />\n </div>\n )}\n <div className={b('condition')}>\n <Select\n size=\"s\"\n value={[cond.field]}\n options={fieldOptions}\n onUpdate={(next) => updateCondition(i, {field: next[0] ?? ''})}\n placeholder=\"field\"\n filterable\n width=\"max\"\n />\n <Select\n size=\"s\"\n value={[cond.operator]}\n options={OPERATOR_OPTIONS}\n onUpdate={(next) =>\n updateCondition(i, {operator: next[0] as '===' | '!=='})\n }\n width={80}\n />\n <TextInput\n size=\"s\"\n value={displayValue(cond.value)}\n onUpdate={(value) => updateCondition(i, {value: coerceValue(value)})}\n placeholder='value (\"true\"/\"false\" → bool)'\n />\n <Button\n view=\"flat-danger\"\n size=\"s\"\n onClick={() => removeCondition(i)}\n title=\"Remove condition\"\n >\n <Icon data={TrashBin} size={12} />\n </Button>\n </div>\n </React.Fragment>\n ))}\n <div className={b('actions')}>\n <Button view=\"normal\" size=\"s\" onClick={addCondition}>\n + Add condition\n </Button>\n <Button view=\"flat\" size=\"s\" onClick={clearAll}>\n Clear\n </Button>\n </div>\n </div>\n );\n};\n"]}