@byline/ui 0.9.3

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 (368) hide show
  1. package/LICENSE +373 -0
  2. package/README.md +17 -0
  3. package/dist/admin/components/admin-account/change-password.d.ts +9 -0
  4. package/dist/admin/components/admin-account/change-password.d.ts.map +1 -0
  5. package/dist/admin/components/admin-account/change-password.js +192 -0
  6. package/dist/admin/components/admin-account/change-password.module.js +8 -0
  7. package/dist/admin/components/admin-account/change-password_module.css +27 -0
  8. package/dist/admin/components/admin-account/container.d.ts +30 -0
  9. package/dist/admin/components/admin-account/container.d.ts.map +1 -0
  10. package/dist/admin/components/admin-account/container.js +299 -0
  11. package/dist/admin/components/admin-account/container.module.js +28 -0
  12. package/dist/admin/components/admin-account/container_module.css +106 -0
  13. package/dist/admin/components/admin-account/update.d.ts +9 -0
  14. package/dist/admin/components/admin-account/update.d.ts.map +1 -0
  15. package/dist/admin/components/admin-account/update.js +207 -0
  16. package/dist/admin/components/admin-account/update.module.js +8 -0
  17. package/dist/admin/components/admin-account/update_module.css +27 -0
  18. package/dist/admin/components/admin-permissions/inspector.d.ts +5 -0
  19. package/dist/admin/components/admin-permissions/inspector.d.ts.map +1 -0
  20. package/dist/admin/components/admin-permissions/inspector.js +284 -0
  21. package/dist/admin/components/admin-permissions/inspector.module.js +56 -0
  22. package/dist/admin/components/admin-permissions/inspector_module.css +238 -0
  23. package/dist/admin/components/admin-roles/create.d.ts +8 -0
  24. package/dist/admin/components/admin-roles/create.d.ts.map +1 -0
  25. package/dist/admin/components/admin-roles/create.js +177 -0
  26. package/dist/admin/components/admin-roles/create.module.js +8 -0
  27. package/dist/admin/components/admin-roles/create_module.css +27 -0
  28. package/dist/admin/components/admin-roles/permissions.d.ts +11 -0
  29. package/dist/admin/components/admin-roles/permissions.d.ts.map +1 -0
  30. package/dist/admin/components/admin-roles/permissions.js +303 -0
  31. package/dist/admin/components/admin-roles/permissions.module.js +44 -0
  32. package/dist/admin/components/admin-roles/permissions_module.css +192 -0
  33. package/dist/admin/components/admin-roles/update.d.ts +9 -0
  34. package/dist/admin/components/admin-roles/update.d.ts.map +1 -0
  35. package/dist/admin/components/admin-roles/update.js +166 -0
  36. package/dist/admin/components/admin-roles/update.module.js +8 -0
  37. package/dist/admin/components/admin-roles/update_module.css +27 -0
  38. package/dist/admin/components/admin-users/create.d.ts +9 -0
  39. package/dist/admin/components/admin-users/create.d.ts.map +1 -0
  40. package/dist/admin/components/admin-users/create.js +268 -0
  41. package/dist/admin/components/admin-users/create.module.js +10 -0
  42. package/dist/admin/components/admin-users/create_module.css +45 -0
  43. package/dist/admin/components/admin-users/roles.d.ts +12 -0
  44. package/dist/admin/components/admin-users/roles.d.ts.map +1 -0
  45. package/dist/admin/components/admin-users/roles.js +148 -0
  46. package/dist/admin/components/admin-users/roles.module.js +18 -0
  47. package/dist/admin/components/admin-users/roles_module.css +75 -0
  48. package/dist/admin/components/admin-users/set-password.d.ts +9 -0
  49. package/dist/admin/components/admin-users/set-password.d.ts.map +1 -0
  50. package/dist/admin/components/admin-users/set-password.js +170 -0
  51. package/dist/admin/components/admin-users/set-password.module.js +9 -0
  52. package/dist/admin/components/admin-users/set-password_module.css +31 -0
  53. package/dist/admin/components/admin-users/update.d.ts +9 -0
  54. package/dist/admin/components/admin-users/update.d.ts.map +1 -0
  55. package/dist/admin/components/admin-users/update.js +254 -0
  56. package/dist/admin/components/admin-users/update.module.js +9 -0
  57. package/dist/admin/components/admin-users/update_module.css +34 -0
  58. package/dist/admin/components/auth/sign-in-form.d.ts +14 -0
  59. package/dist/admin/components/auth/sign-in-form.d.ts.map +1 -0
  60. package/dist/admin/components/auth/sign-in-form.js +107 -0
  61. package/dist/admin/components/auth/sign-in-form.module.js +10 -0
  62. package/dist/admin/components/auth/sign-in-form_module.css +35 -0
  63. package/dist/admin/components/collections/diff-modal.d.ts +23 -0
  64. package/dist/admin/components/collections/diff-modal.d.ts.map +1 -0
  65. package/dist/admin/components/collections/diff-modal.js +147 -0
  66. package/dist/admin/components/collections/diff-modal.module.js +14 -0
  67. package/dist/admin/components/collections/diff-modal_module.css +56 -0
  68. package/dist/admin/components/collections/status-badge.d.ts +26 -0
  69. package/dist/admin/components/collections/status-badge.d.ts.map +1 -0
  70. package/dist/admin/components/collections/status-badge.js +35 -0
  71. package/dist/admin/components/collections/status-badge.module.js +7 -0
  72. package/dist/admin/components/collections/status-badge_module.css +20 -0
  73. package/dist/admin/group.d.ts +28 -0
  74. package/dist/admin/group.d.ts.map +1 -0
  75. package/dist/admin/group.js +14 -0
  76. package/dist/admin/group.module.js +6 -0
  77. package/dist/admin/group_module.css +19 -0
  78. package/dist/admin/row.d.ts +26 -0
  79. package/dist/admin/row.d.ts.map +1 -0
  80. package/dist/admin/row.js +8 -0
  81. package/dist/admin/row.module.js +5 -0
  82. package/dist/admin/row_module.css +18 -0
  83. package/dist/admin/tabs.d.ts +33 -0
  84. package/dist/admin/tabs.d.ts.map +1 -0
  85. package/dist/admin/tabs.js +34 -0
  86. package/dist/admin/tabs.module.js +10 -0
  87. package/dist/admin/tabs_module.css +68 -0
  88. package/dist/dnd/draggable-sortable/demo/draggable-list-demo.js +105 -0
  89. package/dist/dnd/draggable-sortable/demo/draggable-list-demo.module.js +12 -0
  90. package/dist/dnd/draggable-sortable/demo/draggable-list-demo_module.css +39 -0
  91. package/dist/dnd/draggable-sortable/draggable-sortable-item/index.d.ts +19 -0
  92. package/dist/dnd/draggable-sortable/draggable-sortable-item/index.d.ts.map +1 -0
  93. package/dist/dnd/draggable-sortable/draggable-sortable-item/index.js +27 -0
  94. package/dist/dnd/draggable-sortable/draggable-sortable-item/types.d.ts +25 -0
  95. package/dist/dnd/draggable-sortable/draggable-sortable-item/types.d.ts.map +1 -0
  96. package/dist/dnd/draggable-sortable/draggable-sortable-item/types.js +1 -0
  97. package/dist/dnd/draggable-sortable/draggable-sortable.d.ts +17 -0
  98. package/dist/dnd/draggable-sortable/draggable-sortable.d.ts.map +1 -0
  99. package/dist/dnd/draggable-sortable/draggable-sortable.js +46 -0
  100. package/dist/dnd/draggable-sortable/index.d.ts +5 -0
  101. package/dist/dnd/draggable-sortable/index.d.ts.map +1 -0
  102. package/dist/dnd/draggable-sortable/index.js +4 -0
  103. package/dist/dnd/draggable-sortable/types.d.ts +26 -0
  104. package/dist/dnd/draggable-sortable/types.d.ts.map +1 -0
  105. package/dist/dnd/draggable-sortable/types.js +1 -0
  106. package/dist/dnd/draggable-sortable/use-draggable-sortable/index.d.ts +16 -0
  107. package/dist/dnd/draggable-sortable/use-draggable-sortable/index.d.ts.map +1 -0
  108. package/dist/dnd/draggable-sortable/use-draggable-sortable/index.js +28 -0
  109. package/dist/dnd/draggable-sortable/use-draggable-sortable/types.d.ts +23 -0
  110. package/dist/dnd/draggable-sortable/use-draggable-sortable/types.d.ts.map +1 -0
  111. package/dist/dnd/draggable-sortable/use-draggable-sortable/types.js +1 -0
  112. package/dist/dnd/draggable-sortable/utils.d.ts +14 -0
  113. package/dist/dnd/draggable-sortable/utils.d.ts.map +1 -0
  114. package/dist/dnd/draggable-sortable/utils.js +10 -0
  115. package/dist/fields/array/array-field.d.ts +15 -0
  116. package/dist/fields/array/array-field.d.ts.map +1 -0
  117. package/dist/fields/array/array-field.js +176 -0
  118. package/dist/fields/array/array-field.module.js +11 -0
  119. package/dist/fields/array/array-field_module.css +32 -0
  120. package/dist/fields/blocks/blocks-field.d.ts +14 -0
  121. package/dist/fields/blocks/blocks-field.d.ts.map +1 -0
  122. package/dist/fields/blocks/blocks-field.js +244 -0
  123. package/dist/fields/blocks/blocks-field.module.js +26 -0
  124. package/dist/fields/blocks/blocks-field_module.css +107 -0
  125. package/dist/fields/checkbox/checkbox-field.d.ts +17 -0
  126. package/dist/fields/checkbox/checkbox-field.d.ts.map +1 -0
  127. package/dist/fields/checkbox/checkbox-field.js +27 -0
  128. package/dist/fields/column-formatter.d.ts +21 -0
  129. package/dist/fields/column-formatter.d.ts.map +1 -0
  130. package/dist/fields/column-formatter.js +15 -0
  131. package/dist/fields/date-time-formatter.d.ts +17 -0
  132. package/dist/fields/date-time-formatter.d.ts.map +1 -0
  133. package/dist/fields/date-time-formatter.js +8 -0
  134. package/dist/fields/datetime/datetime-field.d.ts +17 -0
  135. package/dist/fields/datetime/datetime-field.d.ts.map +1 -0
  136. package/dist/fields/datetime/datetime-field.js +37 -0
  137. package/dist/fields/datetime/datetime-field.module.js +5 -0
  138. package/dist/fields/datetime/datetime-field_module.css +4 -0
  139. package/dist/fields/draggable-context-menu.d.ts +7 -0
  140. package/dist/fields/draggable-context-menu.d.ts.map +1 -0
  141. package/dist/fields/draggable-context-menu.js +83 -0
  142. package/dist/fields/draggable-context-menu.module.js +15 -0
  143. package/dist/fields/draggable-context-menu_module.css +91 -0
  144. package/dist/fields/field-helpers.d.ts +27 -0
  145. package/dist/fields/field-helpers.d.ts.map +1 -0
  146. package/dist/fields/field-helpers.js +48 -0
  147. package/dist/fields/field-renderer.d.ts +31 -0
  148. package/dist/fields/field-renderer.d.ts.map +1 -0
  149. package/dist/fields/field-renderer.js +189 -0
  150. package/dist/fields/field-renderer.module.js +8 -0
  151. package/dist/fields/field-renderer_module.css +11 -0
  152. package/dist/fields/file/file-field.d.ts +18 -0
  153. package/dist/fields/file/file-field.d.ts.map +1 -0
  154. package/dist/fields/file/file-field.js +125 -0
  155. package/dist/fields/file/file-field.module.js +13 -0
  156. package/dist/fields/file/file-field_module.css +64 -0
  157. package/dist/fields/group/group-field.d.ts +16 -0
  158. package/dist/fields/group/group-field.d.ts.map +1 -0
  159. package/dist/fields/group/group-field.js +59 -0
  160. package/dist/fields/group/group-field.module.js +9 -0
  161. package/dist/fields/group/group-field_module.css +27 -0
  162. package/dist/fields/image/image-field.d.ts +20 -0
  163. package/dist/fields/image/image-field.d.ts.map +1 -0
  164. package/dist/fields/image/image-field.js +198 -0
  165. package/dist/fields/image/image-field.module.js +21 -0
  166. package/dist/fields/image/image-field_module.css +96 -0
  167. package/dist/fields/image/image-upload-field.d.ts +22 -0
  168. package/dist/fields/image/image-upload-field.d.ts.map +1 -0
  169. package/dist/fields/image/image-upload-field.js +187 -0
  170. package/dist/fields/image/image-upload-field.module.js +19 -0
  171. package/dist/fields/image/image-upload-field_module.css +92 -0
  172. package/dist/fields/local-date-time.d.ts +28 -0
  173. package/dist/fields/local-date-time.d.ts.map +1 -0
  174. package/dist/fields/local-date-time.js +49 -0
  175. package/dist/fields/locale-badge.d.ts +19 -0
  176. package/dist/fields/locale-badge.d.ts.map +1 -0
  177. package/dist/fields/locale-badge.js +10 -0
  178. package/dist/fields/locale-badge.module.js +5 -0
  179. package/dist/fields/locale-badge_module.css +27 -0
  180. package/dist/fields/numerical/numerical-field.d.ts +19 -0
  181. package/dist/fields/numerical/numerical-field.d.ts.map +1 -0
  182. package/dist/fields/numerical/numerical-field.js +73 -0
  183. package/dist/fields/relation/relation-display.d.ts +41 -0
  184. package/dist/fields/relation/relation-display.d.ts.map +1 -0
  185. package/dist/fields/relation/relation-display.js +58 -0
  186. package/dist/fields/relation/relation-display.module.js +9 -0
  187. package/dist/fields/relation/relation-display_module.css +21 -0
  188. package/dist/fields/relation/relation-field.d.ts +19 -0
  189. package/dist/fields/relation/relation-field.d.ts.map +1 -0
  190. package/dist/fields/relation/relation-field.js +133 -0
  191. package/dist/fields/relation/relation-field.module.js +13 -0
  192. package/dist/fields/relation/relation-field_module.css +62 -0
  193. package/dist/fields/relation/relation-picker.d.ts +50 -0
  194. package/dist/fields/relation/relation-picker.d.ts.map +1 -0
  195. package/dist/fields/relation/relation-picker.js +233 -0
  196. package/dist/fields/relation/relation-picker.module.js +26 -0
  197. package/dist/fields/relation/relation-picker_module.css +124 -0
  198. package/dist/fields/relation/relation-summary.d.ts +32 -0
  199. package/dist/fields/relation/relation-summary.d.ts.map +1 -0
  200. package/dist/fields/relation/relation-summary.js +50 -0
  201. package/dist/fields/relation/relation-summary.module.js +11 -0
  202. package/dist/fields/relation/relation-summary_module.css +37 -0
  203. package/dist/fields/select/select-field.d.ts +17 -0
  204. package/dist/fields/select/select-field.d.ts.map +1 -0
  205. package/dist/fields/select/select-field.js +42 -0
  206. package/dist/fields/select/select-field.module.js +5 -0
  207. package/dist/fields/select/select-field_module.css +4 -0
  208. package/dist/fields/sortable-item.d.ts +16 -0
  209. package/dist/fields/sortable-item.d.ts.map +1 -0
  210. package/dist/fields/sortable-item.js +80 -0
  211. package/dist/fields/sortable-item.module.js +22 -0
  212. package/dist/fields/sortable-item_module.css +124 -0
  213. package/dist/fields/text/text-field.d.ts +21 -0
  214. package/dist/fields/text/text-field.d.ts.map +1 -0
  215. package/dist/fields/text/text-field.js +104 -0
  216. package/dist/fields/text/text-field.module.js +6 -0
  217. package/dist/fields/text/text-field_module.css +5 -0
  218. package/dist/fields/text-area/text-area-field.d.ts +21 -0
  219. package/dist/fields/text-area/text-area-field.d.ts.map +1 -0
  220. package/dist/fields/text-area/text-area-field.js +105 -0
  221. package/dist/fields/text-area/text-area-field.module.js +6 -0
  222. package/dist/fields/text-area/text-area-field_module.css +5 -0
  223. package/dist/fields/use-field-change-handler.d.ts +24 -0
  224. package/dist/fields/use-field-change-handler.d.ts.map +1 -0
  225. package/dist/fields/use-field-change-handler.js +52 -0
  226. package/dist/forms/document-actions.d.ts +14 -0
  227. package/dist/forms/document-actions.d.ts.map +1 -0
  228. package/dist/forms/document-actions.js +153 -0
  229. package/dist/forms/document-actions.module.js +18 -0
  230. package/dist/forms/document-actions_module.css +66 -0
  231. package/dist/forms/form-context.d.ts +78 -0
  232. package/dist/forms/form-context.d.ts.map +1 -0
  233. package/dist/forms/form-context.js +420 -0
  234. package/dist/forms/form-renderer.d.ts +66 -0
  235. package/dist/forms/form-renderer.d.ts.map +1 -0
  236. package/dist/forms/form-renderer.js +555 -0
  237. package/dist/forms/form-renderer.module.js +46 -0
  238. package/dist/forms/form-renderer_module.css +242 -0
  239. package/dist/forms/navigation-guard.d.ts +55 -0
  240. package/dist/forms/navigation-guard.d.ts.map +1 -0
  241. package/dist/forms/navigation-guard.js +22 -0
  242. package/dist/forms/path-widget.d.ts +33 -0
  243. package/dist/forms/path-widget.d.ts.map +1 -0
  244. package/dist/forms/path-widget.js +101 -0
  245. package/dist/forms/path-widget.module.js +8 -0
  246. package/dist/forms/path-widget_module.css +29 -0
  247. package/dist/forms/upload-executor.d.ts +58 -0
  248. package/dist/forms/upload-executor.d.ts.map +1 -0
  249. package/dist/forms/upload-executor.js +92 -0
  250. package/dist/react.d.ts +55 -0
  251. package/dist/react.d.ts.map +1 -0
  252. package/dist/react.js +48 -0
  253. package/dist/services/admin-services-context.d.ts +17 -0
  254. package/dist/services/admin-services-context.d.ts.map +1 -0
  255. package/dist/services/admin-services-context.js +13 -0
  256. package/dist/services/admin-services-types.d.ts +130 -0
  257. package/dist/services/admin-services-types.d.ts.map +1 -0
  258. package/dist/services/admin-services-types.js +1 -0
  259. package/dist/services/field-services-context.d.ts +17 -0
  260. package/dist/services/field-services-context.d.ts.map +1 -0
  261. package/dist/services/field-services-context.js +13 -0
  262. package/dist/services/field-services-types.d.ts +64 -0
  263. package/dist/services/field-services-types.d.ts.map +1 -0
  264. package/dist/services/field-services-types.js +1 -0
  265. package/package.json +133 -0
  266. package/src/admin/components/admin-account/change-password.module.css +40 -0
  267. package/src/admin/components/admin-account/change-password.tsx +232 -0
  268. package/src/admin/components/admin-account/container.module.css +158 -0
  269. package/src/admin/components/admin-account/container.tsx +230 -0
  270. package/src/admin/components/admin-account/update.module.css +40 -0
  271. package/src/admin/components/admin-account/update.tsx +263 -0
  272. package/src/admin/components/admin-permissions/inspector.module.css +326 -0
  273. package/src/admin/components/admin-permissions/inspector.tsx +298 -0
  274. package/src/admin/components/admin-roles/create.module.css +40 -0
  275. package/src/admin/components/admin-roles/create.tsx +218 -0
  276. package/src/admin/components/admin-roles/permissions.module.css +279 -0
  277. package/src/admin/components/admin-roles/permissions.tsx +396 -0
  278. package/src/admin/components/admin-roles/update.module.css +40 -0
  279. package/src/admin/components/admin-roles/update.tsx +218 -0
  280. package/src/admin/components/admin-users/create.module.css +63 -0
  281. package/src/admin/components/admin-users/create.tsx +323 -0
  282. package/src/admin/components/admin-users/roles.module.css +119 -0
  283. package/src/admin/components/admin-users/roles.tsx +172 -0
  284. package/src/admin/components/admin-users/set-password.module.css +46 -0
  285. package/src/admin/components/admin-users/set-password.tsx +199 -0
  286. package/src/admin/components/admin-users/update.module.css +49 -0
  287. package/src/admin/components/admin-users/update.tsx +328 -0
  288. package/src/admin/components/auth/sign-in-form.module.css +53 -0
  289. package/src/admin/components/auth/sign-in-form.tsx +118 -0
  290. package/src/admin/components/collections/diff-modal.module.css +79 -0
  291. package/src/admin/components/collections/diff-modal.tsx +171 -0
  292. package/src/admin/components/collections/status-badge.module.css +31 -0
  293. package/src/admin/components/collections/status-badge.tsx +69 -0
  294. package/src/admin/group.module.css +41 -0
  295. package/src/admin/group.tsx +40 -0
  296. package/src/admin/row.module.css +32 -0
  297. package/src/admin/row.tsx +33 -0
  298. package/src/admin/tabs.module.css +107 -0
  299. package/src/admin/tabs.tsx +74 -0
  300. package/src/declarations.d.ts +4 -0
  301. package/src/dnd/draggable-sortable/demo/draggable-list-demo.module.css +65 -0
  302. package/src/dnd/draggable-sortable/demo/draggable-list-demo.tsx +117 -0
  303. package/src/dnd/draggable-sortable/draggable-sortable-item/index.tsx +54 -0
  304. package/src/dnd/draggable-sortable/draggable-sortable-item/types.ts +30 -0
  305. package/src/dnd/draggable-sortable/draggable-sortable.tsx +86 -0
  306. package/src/dnd/draggable-sortable/index.ts +5 -0
  307. package/src/dnd/draggable-sortable/types.ts +24 -0
  308. package/src/dnd/draggable-sortable/use-draggable-sortable/index.tsx +50 -0
  309. package/src/dnd/draggable-sortable/use-draggable-sortable/types.ts +25 -0
  310. package/src/dnd/draggable-sortable/utils.ts +29 -0
  311. package/src/fields/array/array-field.module.css +48 -0
  312. package/src/fields/array/array-field.tsx +266 -0
  313. package/src/fields/blocks/blocks-field.module.css +148 -0
  314. package/src/fields/blocks/blocks-field.tsx +312 -0
  315. package/src/fields/checkbox/checkbox-field.tsx +53 -0
  316. package/src/fields/column-formatter.tsx +31 -0
  317. package/src/fields/date-time-formatter.tsx +22 -0
  318. package/src/fields/datetime/datetime-field.module.css +13 -0
  319. package/src/fields/datetime/datetime-field.tsx +54 -0
  320. package/src/fields/draggable-context-menu.module.css +127 -0
  321. package/src/fields/draggable-context-menu.tsx +85 -0
  322. package/src/fields/field-helpers.ts +66 -0
  323. package/src/fields/field-renderer.module.css +22 -0
  324. package/src/fields/field-renderer.tsx +255 -0
  325. package/src/fields/file/file-field.module.css +88 -0
  326. package/src/fields/file/file-field.tsx +107 -0
  327. package/src/fields/group/group-field.module.css +43 -0
  328. package/src/fields/group/group-field.tsx +84 -0
  329. package/src/fields/image/image-field.module.css +129 -0
  330. package/src/fields/image/image-field.tsx +212 -0
  331. package/src/fields/image/image-upload-field.module.css +123 -0
  332. package/src/fields/image/image-upload-field.tsx +270 -0
  333. package/src/fields/local-date-time.tsx +88 -0
  334. package/src/fields/locale-badge.module.css +37 -0
  335. package/src/fields/locale-badge.tsx +32 -0
  336. package/src/fields/numerical/numerical-field.tsx +112 -0
  337. package/src/fields/relation/relation-display.module.css +36 -0
  338. package/src/fields/relation/relation-display.tsx +130 -0
  339. package/src/fields/relation/relation-field.module.css +83 -0
  340. package/src/fields/relation/relation-field.tsx +202 -0
  341. package/src/fields/relation/relation-picker.module.css +168 -0
  342. package/src/fields/relation/relation-picker.tsx +325 -0
  343. package/src/fields/relation/relation-summary.module.css +55 -0
  344. package/src/fields/relation/relation-summary.tsx +123 -0
  345. package/src/fields/select/select-field.module.css +13 -0
  346. package/src/fields/select/select-field.tsx +56 -0
  347. package/src/fields/sortable-item.module.css +167 -0
  348. package/src/fields/sortable-item.tsx +101 -0
  349. package/src/fields/text/text-field.module.css +13 -0
  350. package/src/fields/text/text-field.tsx +146 -0
  351. package/src/fields/text-area/text-area-field.module.css +13 -0
  352. package/src/fields/text-area/text-area-field.tsx +147 -0
  353. package/src/fields/use-field-change-handler.ts +112 -0
  354. package/src/forms/document-actions.module.css +94 -0
  355. package/src/forms/document-actions.tsx +149 -0
  356. package/src/forms/form-context.tsx +620 -0
  357. package/src/forms/form-renderer.module.css +318 -0
  358. package/src/forms/form-renderer.tsx +786 -0
  359. package/src/forms/navigation-guard.tsx +98 -0
  360. package/src/forms/path-widget.module.css +41 -0
  361. package/src/forms/path-widget.test.tsx +217 -0
  362. package/src/forms/path-widget.tsx +141 -0
  363. package/src/forms/upload-executor.ts +190 -0
  364. package/src/react.ts +79 -0
  365. package/src/services/admin-services-context.tsx +35 -0
  366. package/src/services/admin-services-types.ts +177 -0
  367. package/src/services/field-services-context.tsx +35 -0
  368. package/src/services/field-services-types.ts +68 -0
@@ -0,0 +1,555 @@
1
+ import { Fragment, jsx, jsxs } from "react/jsx-runtime";
2
+ import { useCallback, useEffect, useMemo, useRef, useState } from "react";
3
+ import { Button, ComboButton, Modal } from "@infonomic/uikit/react";
4
+ import classnames from "classnames";
5
+ import { Group } from "../admin/group.js";
6
+ import { Row } from "../admin/row.js";
7
+ import { Tabs } from "../admin/tabs.js";
8
+ import { FieldRenderer } from "../fields/field-renderer.js";
9
+ import { LocalDateTime } from "../fields/local-date-time.js";
10
+ import { useBylineFieldServices } from "../services/field-services-context.js";
11
+ import { DocumentActions } from "./document-actions.js";
12
+ import { FormProvider, useFieldValue, useFormContext } from "./form-context.js";
13
+ import form_renderer_module from "./form-renderer.module.js";
14
+ import { useNavigationGuardAdapter } from "./navigation-guard.js";
15
+ import { PathWidget } from "./path-widget.js";
16
+ import { executeUploads } from "./upload-executor.js";
17
+ const FormStatusDisplay = ({ initialData, workflowStatuses, publishedVersion, onUnpublish })=>{
18
+ const statusCode = initialData?.status;
19
+ const statusLabel = workflowStatuses?.find((s)=>s.name === statusCode)?.label ?? statusCode;
20
+ const showStatusCell = (workflowStatuses?.length ?? 0) > 1;
21
+ return /*#__PURE__*/ jsxs("div", {
22
+ className: classnames('byline-form-status', form_renderer_module.status),
23
+ children: [
24
+ /*#__PURE__*/ jsxs("div", {
25
+ className: classnames('byline-form-status-meta', form_renderer_module["status-meta"]),
26
+ children: [
27
+ showStatusCell && /*#__PURE__*/ jsxs("div", {
28
+ className: classnames('byline-form-status-cell', form_renderer_module["status-cell"]),
29
+ children: [
30
+ /*#__PURE__*/ jsx("span", {
31
+ className: classnames('byline-form-status-muted', form_renderer_module["status-muted"]),
32
+ children: "Status:"
33
+ }),
34
+ /*#__PURE__*/ jsx("span", {
35
+ className: classnames('byline-form-status-trunc', form_renderer_module["status-trunc"]),
36
+ children: statusLabel
37
+ })
38
+ ]
39
+ }),
40
+ initialData?.updatedAt != null && /*#__PURE__*/ jsxs("div", {
41
+ className: classnames('byline-form-status-cell', form_renderer_module["status-cell"]),
42
+ children: [
43
+ /*#__PURE__*/ jsx("span", {
44
+ className: classnames('byline-form-status-muted', form_renderer_module["status-muted"]),
45
+ children: "Last modified:"
46
+ }),
47
+ /*#__PURE__*/ jsx("span", {
48
+ className: classnames('byline-form-status-trunc', form_renderer_module["status-trunc"]),
49
+ children: /*#__PURE__*/ jsx(LocalDateTime, {
50
+ value: initialData.updatedAt
51
+ })
52
+ })
53
+ ]
54
+ }),
55
+ initialData?.createdAt != null && /*#__PURE__*/ jsxs("div", {
56
+ className: classnames('byline-form-status-cell', form_renderer_module["status-cell"]),
57
+ children: [
58
+ /*#__PURE__*/ jsx("span", {
59
+ className: classnames('byline-form-status-muted', form_renderer_module["status-muted"]),
60
+ children: "Created:"
61
+ }),
62
+ /*#__PURE__*/ jsx("span", {
63
+ className: classnames('byline-form-status-trunc', form_renderer_module["status-trunc"]),
64
+ children: /*#__PURE__*/ jsx(LocalDateTime, {
65
+ value: initialData.createdAt
66
+ })
67
+ })
68
+ ]
69
+ })
70
+ ]
71
+ }),
72
+ null != publishedVersion && /*#__PURE__*/ jsxs("div", {
73
+ className: classnames('byline-form-status-published', form_renderer_module["status-published"]),
74
+ children: [
75
+ /*#__PURE__*/ jsxs("span", {
76
+ className: classnames('byline-form-status-muted', form_renderer_module["status-muted"]),
77
+ children: [
78
+ "A published version is currently live.",
79
+ ' ',
80
+ publishedVersion.updatedAt ? /*#__PURE__*/ jsxs("span", {
81
+ children: [
82
+ "Published on ",
83
+ /*#__PURE__*/ jsx(LocalDateTime, {
84
+ value: publishedVersion.updatedAt
85
+ })
86
+ ]
87
+ }) : ''
88
+ ]
89
+ }),
90
+ onUnpublish && /*#__PURE__*/ jsxs(Fragment, {
91
+ children: [
92
+ ' ',
93
+ /*#__PURE__*/ jsx("button", {
94
+ type: "button",
95
+ onClick: onUnpublish,
96
+ className: classnames('byline-form-status-unpublish', form_renderer_module["status-unpublish"]),
97
+ children: "Unpublish"
98
+ })
99
+ ]
100
+ })
101
+ ]
102
+ })
103
+ ]
104
+ });
105
+ };
106
+ function computeStatusTransitions(currentStatus, workflowStatuses, nextStatus) {
107
+ if (!workflowStatuses || 0 === workflowStatuses.length || !currentStatus) return {
108
+ primaryStatus: nextStatus,
109
+ secondaryStatuses: []
110
+ };
111
+ if (workflowStatuses.length <= 1) return {
112
+ primaryStatus: void 0,
113
+ secondaryStatuses: []
114
+ };
115
+ const currentIndex = workflowStatuses.findIndex((s)=>s.name === currentStatus);
116
+ if (-1 === currentIndex) return {
117
+ primaryStatus: nextStatus,
118
+ secondaryStatuses: []
119
+ };
120
+ const isAtEnd = currentIndex === workflowStatuses.length - 1;
121
+ const isAtStart = 0 === currentIndex;
122
+ const availableTargets = [];
123
+ if (!isAtStart && workflowStatuses[0]) availableTargets.push(workflowStatuses[0]);
124
+ if (currentIndex > 1 && workflowStatuses[currentIndex - 1]) availableTargets.push(workflowStatuses[currentIndex - 1]);
125
+ if (!isAtEnd && workflowStatuses[currentIndex + 1]) availableTargets.push(workflowStatuses[currentIndex + 1]);
126
+ let primaryStatus;
127
+ let secondaryStatuses;
128
+ if (isAtEnd) {
129
+ const prevStatus = workflowStatuses[currentIndex - 1];
130
+ primaryStatus = prevStatus;
131
+ secondaryStatuses = availableTargets.filter((s)=>s.name !== prevStatus?.name);
132
+ } else {
133
+ primaryStatus = nextStatus;
134
+ secondaryStatuses = availableTargets.filter((s)=>s.name !== nextStatus?.name);
135
+ }
136
+ return {
137
+ primaryStatus,
138
+ secondaryStatuses
139
+ };
140
+ }
141
+ const FormContent = ({ mode, fields, onSubmit, onCancel, onStatusChange, onUnpublish, onDelete, nextStatus, workflowStatuses, publishedVersion, initialData, adminConfig, useAsTitle, useAsPath, headingLabel, headerSlot, collectionPath, initialLocale, onLocaleChange, defaultLocale = 'en', useNavigationGuard: useNavigationGuardProp, _activeTabBySet, _onTabChange })=>{
142
+ const { getFieldValues, runFieldHooks, validateForm, errors: initialErrors, hasChanges: hasChangesFn, resetHasChanges, getPatches, getSystemPath, subscribeErrors, subscribeMeta, setFieldValue, setFieldError, getPendingUploads, clearPendingUploads } = useFormContext();
143
+ const [errors, setErrors] = useState(initialErrors);
144
+ const [hasChanges, setHasChanges] = useState(hasChangesFn());
145
+ const [statusBusy, setStatusBusy] = useState(false);
146
+ const [isUploading, setIsUploading] = useState(false);
147
+ const [contentLocale, setContentLocale] = useState(initialLocale ?? defaultLocale);
148
+ const { uploadField } = useBylineFieldServices();
149
+ useEffect(()=>{
150
+ if (initialLocale) setContentLocale(initialLocale);
151
+ }, [
152
+ initialLocale
153
+ ]);
154
+ const fieldByName = useMemo(()=>{
155
+ const map = new Map();
156
+ for (const field of fields)if ('name' in field) map.set(field.name, field);
157
+ return map;
158
+ }, [
159
+ fields
160
+ ]);
161
+ const tabSetByName = useMemo(()=>{
162
+ const map = new Map();
163
+ for (const set of adminConfig?.tabSets ?? [])map.set(set.name, set);
164
+ return map;
165
+ }, [
166
+ adminConfig
167
+ ]);
168
+ const rowByName = useMemo(()=>{
169
+ const map = new Map();
170
+ for (const row of adminConfig?.rows ?? [])map.set(row.name, row);
171
+ return map;
172
+ }, [
173
+ adminConfig
174
+ ]);
175
+ const groupByName = useMemo(()=>{
176
+ const map = new Map();
177
+ for (const group of adminConfig?.groups ?? [])map.set(group.name, group);
178
+ return map;
179
+ }, [
180
+ adminConfig
181
+ ]);
182
+ const layout = useMemo(()=>{
183
+ if (adminConfig?.layout) return adminConfig.layout;
184
+ return {
185
+ main: fields.filter((f)=>'name' in f).map((f)=>f.name)
186
+ };
187
+ }, [
188
+ adminConfig,
189
+ fields
190
+ ]);
191
+ const fieldToTabPath = useMemo(()=>{
192
+ const map = new Map();
193
+ const visit = (names, tabSetName, tabName, seen)=>{
194
+ for (const name of names)if (fieldByName.has(name)) map.set(name, {
195
+ tabSetName,
196
+ tabName
197
+ });
198
+ else if (seen.has(name)) ;
199
+ else if (rowByName.has(name)) {
200
+ const row = rowByName.get(name);
201
+ const next = new Set(seen).add(name);
202
+ visit(row.fields, tabSetName, tabName, next);
203
+ } else if (groupByName.has(name)) {
204
+ const group = groupByName.get(name);
205
+ const next = new Set(seen).add(name);
206
+ visit(group.fields, tabSetName, tabName, next);
207
+ }
208
+ };
209
+ for (const set of adminConfig?.tabSets ?? [])for (const tab of set.tabs)visit(tab.fields, set.name, tab.name, new Set());
210
+ return map;
211
+ }, [
212
+ adminConfig,
213
+ fieldByName,
214
+ rowByName,
215
+ groupByName
216
+ ]);
217
+ const tabSets = adminConfig?.tabSets ?? [];
218
+ const initialActiveTabBySet = useMemo(()=>{
219
+ const result = {};
220
+ for (const set of tabSets){
221
+ const saved = _activeTabBySet?.[set.name];
222
+ if (saved && set.tabs.some((t)=>t.name === saved)) result[set.name] = saved;
223
+ else result[set.name] = set.tabs[0]?.name ?? '';
224
+ }
225
+ return result;
226
+ }, [
227
+ tabSets,
228
+ _activeTabBySet
229
+ ]);
230
+ const [activeTabBySet, setActiveTabBySet] = useState(initialActiveTabBySet);
231
+ const handleTabChange = useCallback((tabSetName, tabName)=>{
232
+ setActiveTabBySet((prev)=>({
233
+ ...prev,
234
+ [tabSetName]: tabName
235
+ }));
236
+ _onTabChange?.(tabSetName, tabName);
237
+ }, [
238
+ _onTabChange
239
+ ]);
240
+ const [formData, setFormData] = useState(()=>getFieldValues());
241
+ const liveTitle = useFieldValue(useAsTitle ?? '');
242
+ const heading = liveTitle || (headingLabel ? `${'create' === mode ? 'Create' : 'Edit'} ${headingLabel}` : 'create' === mode ? 'Create' : 'Edit');
243
+ const guardFromContext = useNavigationGuardAdapter();
244
+ const useGuard = useNavigationGuardProp ?? guardFromContext;
245
+ const guard = useGuard(hasChanges);
246
+ const currentStatus = initialData?.status;
247
+ const { primaryStatus, secondaryStatuses } = computeStatusTransitions(currentStatus, workflowStatuses, nextStatus);
248
+ useEffect(()=>subscribeErrors((newErrors)=>setErrors(newErrors)), [
249
+ subscribeErrors
250
+ ]);
251
+ useEffect(()=>subscribeMeta(()=>setHasChanges(hasChangesFn())), [
252
+ subscribeMeta,
253
+ hasChangesFn
254
+ ]);
255
+ useEffect(()=>subscribeMeta(()=>setFormData(getFieldValues())), [
256
+ subscribeMeta,
257
+ getFieldValues
258
+ ]);
259
+ const handleCancel = ()=>{
260
+ if (onCancel && 'function' == typeof onCancel) onCancel();
261
+ };
262
+ const handleSubmit = (e)=>{
263
+ e.preventDefault();
264
+ (async ()=>{
265
+ const hookErrors = await runFieldHooks(fields);
266
+ const formErrors = validateForm(fields);
267
+ const allErrors = [
268
+ ...hookErrors,
269
+ ...formErrors
270
+ ];
271
+ if (allErrors.length > 0) return void console.error('Form validation failed:', allErrors);
272
+ const pendingUploads = getPendingUploads();
273
+ if (pendingUploads.size > 0) {
274
+ setIsUploading(true);
275
+ try {
276
+ const uploadResult = await executeUploads(pendingUploads, uploadField);
277
+ if (!uploadResult.allSucceeded) {
278
+ for (const [fieldPath, errorMessage] of uploadResult.errors.entries())setFieldError(fieldPath, `Upload failed: ${errorMessage}`);
279
+ console.error('One or more uploads failed:', uploadResult.errors);
280
+ setIsUploading(false);
281
+ return;
282
+ }
283
+ for (const [fieldPath, storedFile] of uploadResult.successful.entries())setFieldValue(fieldPath, storedFile);
284
+ clearPendingUploads();
285
+ } catch (err) {
286
+ console.error('Upload execution error:', err);
287
+ setIsUploading(false);
288
+ return;
289
+ }
290
+ setIsUploading(false);
291
+ }
292
+ const data = getFieldValues();
293
+ const patches = getPatches();
294
+ const systemPath = getSystemPath();
295
+ if (onSubmit && 'function' == typeof onSubmit) {
296
+ onSubmit({
297
+ data,
298
+ patches,
299
+ systemPath
300
+ });
301
+ resetHasChanges();
302
+ }
303
+ })();
304
+ };
305
+ const tabErrorCountsBySet = useMemo(()=>{
306
+ const result = {};
307
+ for (const err of errors){
308
+ const path = fieldToTabPath.get(err.field);
309
+ if (path) {
310
+ result[path.tabSetName] ??= {};
311
+ result[path.tabSetName][path.tabName] = (result[path.tabSetName]?.[path.tabName] ?? 0) + 1;
312
+ }
313
+ }
314
+ return result;
315
+ }, [
316
+ errors,
317
+ fieldToTabPath
318
+ ]);
319
+ const renderField = (fieldName)=>{
320
+ const field = fieldByName.get(fieldName);
321
+ if (!field) return null;
322
+ return /*#__PURE__*/ jsx(FieldRenderer, {
323
+ field: field,
324
+ defaultValue: initialData?.fields?.[field.name],
325
+ collectionPath: collectionPath,
326
+ contentLocale: contentLocale,
327
+ components: adminConfig?.fields?.[field.name]?.components
328
+ }, field.name);
329
+ };
330
+ const renderItem = (name)=>{
331
+ const tabSet = tabSetByName.get(name);
332
+ if (tabSet) return renderTabSet(tabSet);
333
+ const group = groupByName.get(name);
334
+ if (group) return renderGroup(group);
335
+ const row = rowByName.get(name);
336
+ if (row) return renderRow(row);
337
+ return renderField(name);
338
+ };
339
+ const renderRow = (row)=>/*#__PURE__*/ jsx(Row, {
340
+ children: row.fields.map((name)=>renderField(name))
341
+ }, `row:${row.name}`);
342
+ const renderGroup = (group)=>/*#__PURE__*/ jsx(Group, {
343
+ label: group.label,
344
+ children: group.fields.map((name)=>renderItem(name))
345
+ }, `group:${group.name}`);
346
+ const renderTabSet = (set)=>{
347
+ const visibleTabs = set.tabs.filter((tab)=>!tab.condition || tab.condition(formData));
348
+ const requested = activeTabBySet[set.name] ?? '';
349
+ const resolvedActive = visibleTabs.length > 0 && !visibleTabs.some((t)=>t.name === requested) ? visibleTabs[0]?.name ?? requested : requested;
350
+ const activeTab = visibleTabs.find((t)=>t.name === resolvedActive);
351
+ return /*#__PURE__*/ jsxs("div", {
352
+ className: classnames('byline-form-tabset', form_renderer_module.tabset),
353
+ children: [
354
+ visibleTabs.length > 0 && /*#__PURE__*/ jsx(Tabs, {
355
+ tabs: visibleTabs,
356
+ activeTab: resolvedActive,
357
+ onChange: (tabName)=>handleTabChange(set.name, tabName),
358
+ errorCounts: tabErrorCountsBySet[set.name],
359
+ className: classnames('byline-form-tabset-tabs', form_renderer_module["tabset-tabs"])
360
+ }),
361
+ activeTab && /*#__PURE__*/ jsx("div", {
362
+ className: classnames('byline-form-tabset-fields', form_renderer_module["tabset-fields"]),
363
+ children: activeTab.fields.map((name)=>renderItem(name))
364
+ })
365
+ ]
366
+ }, `tabset:${set.name}`);
367
+ };
368
+ return /*#__PURE__*/ jsxs("form", {
369
+ noValidate: true,
370
+ onSubmit: handleSubmit,
371
+ className: classnames('byline-form', form_renderer_module.form),
372
+ children: [
373
+ /*#__PURE__*/ jsxs("div", {
374
+ className: classnames('byline-form-heading-row', form_renderer_module["heading-row"]),
375
+ children: [
376
+ /*#__PURE__*/ jsx("h1", {
377
+ className: classnames('byline-form-heading', form_renderer_module.heading),
378
+ children: heading
379
+ }),
380
+ headerSlot
381
+ ]
382
+ }),
383
+ /*#__PURE__*/ jsxs("div", {
384
+ className: classnames('byline-form-status-bar', form_renderer_module["status-bar"]),
385
+ children: [
386
+ /*#__PURE__*/ jsx(FormStatusDisplay, {
387
+ initialData: initialData,
388
+ workflowStatuses: workflowStatuses,
389
+ publishedVersion: publishedVersion,
390
+ onUnpublish: onUnpublish
391
+ }),
392
+ /*#__PURE__*/ jsxs("div", {
393
+ className: classnames('byline-form-actions', form_renderer_module.actions),
394
+ children: [
395
+ /*#__PURE__*/ jsx(Button, {
396
+ className: classnames('byline-form-actions-button', form_renderer_module["actions-button"]),
397
+ size: "sm",
398
+ intent: "noeffect",
399
+ type: "button",
400
+ onClick: handleCancel,
401
+ children: false === hasChanges ? 'Close' : 'Cancel'
402
+ }),
403
+ /*#__PURE__*/ jsx(Button, {
404
+ className: classnames('byline-form-actions-button', form_renderer_module["actions-button"]),
405
+ size: "sm",
406
+ type: "submit",
407
+ disabled: false === hasChanges || isUploading,
408
+ children: isUploading ? 'Uploading…' : 'Save'
409
+ }),
410
+ primaryStatus && onStatusChange && /*#__PURE__*/ jsx("div", {
411
+ className: classnames('byline-form-actions-status-wrap', form_renderer_module["actions-status-wrap"]),
412
+ children: /*#__PURE__*/ jsx(ComboButton, {
413
+ buttonClassName: classnames('byline-form-actions-combo-button', form_renderer_module["actions-combo-button"]),
414
+ triggerClassName: classnames('byline-form-actions-combo-trigger', form_renderer_module["actions-combo-trigger"]),
415
+ options: secondaryStatuses.map((s)=>({
416
+ label: s.verb ?? s.label ?? s.name,
417
+ value: s.name
418
+ })),
419
+ sideOffset: 5,
420
+ size: "sm",
421
+ type: "button",
422
+ intent: "success",
423
+ disabled: statusBusy,
424
+ onOptionSelect: async (value)=>{
425
+ setStatusBusy(true);
426
+ try {
427
+ await onStatusChange(value);
428
+ } finally{
429
+ setStatusBusy(false);
430
+ }
431
+ },
432
+ onButtonClick: async ()=>{
433
+ setStatusBusy(true);
434
+ try {
435
+ await onStatusChange(primaryStatus.name);
436
+ } finally{
437
+ setStatusBusy(false);
438
+ }
439
+ },
440
+ children: statusBusy ? '...' : primaryStatus.verb ?? primaryStatus.label ?? primaryStatus.name
441
+ })
442
+ }),
443
+ /*#__PURE__*/ jsx(DocumentActions, {
444
+ publishedVersion: publishedVersion,
445
+ onUnpublish: onUnpublish,
446
+ onDelete: onDelete
447
+ })
448
+ ]
449
+ })
450
+ ]
451
+ }),
452
+ /*#__PURE__*/ jsxs("div", {
453
+ className: classnames('byline-form-layout', form_renderer_module.layout),
454
+ children: [
455
+ /*#__PURE__*/ jsx("div", {
456
+ className: classnames('byline-form-content', form_renderer_module.content),
457
+ children: layout.main.map((name)=>renderItem(name))
458
+ }),
459
+ /*#__PURE__*/ jsxs("div", {
460
+ className: classnames('byline-form-sidebar', form_renderer_module.sidebar),
461
+ children: [
462
+ (useAsPath || 'string' == typeof initialData?.path && initialData.path.length > 0) && /*#__PURE__*/ jsx(PathWidget, {
463
+ useAsPath: useAsPath,
464
+ collectionPath: collectionPath ?? '',
465
+ defaultLocale: defaultLocale,
466
+ mode: mode
467
+ }),
468
+ (layout.sidebar ?? []).map((name)=>renderItem(name))
469
+ ]
470
+ })
471
+ ]
472
+ }),
473
+ guard.isBlocked && /*#__PURE__*/ jsx(Modal, {
474
+ isOpen: true,
475
+ closeOnOverlayClick: false,
476
+ onDismiss: guard.stay,
477
+ children: /*#__PURE__*/ jsxs(Modal.Container, {
478
+ style: {
479
+ maxWidth: '460px'
480
+ },
481
+ children: [
482
+ /*#__PURE__*/ jsx(Modal.Header, {
483
+ className: classnames('byline-form-guard-modal-head', form_renderer_module["guard-modal-head"]),
484
+ children: /*#__PURE__*/ jsx("h3", {
485
+ className: classnames('byline-form-guard-modal-title', form_renderer_module["guard-modal-title"]),
486
+ children: "Leave without saving?"
487
+ })
488
+ }),
489
+ /*#__PURE__*/ jsx(Modal.Content, {
490
+ children: /*#__PURE__*/ jsx("p", {
491
+ className: classnames('byline-form-guard-modal-text', form_renderer_module["guard-modal-text"]),
492
+ children: "Your changes have not been saved. If you leave now, you will lose your changes."
493
+ })
494
+ }),
495
+ /*#__PURE__*/ jsxs(Modal.Actions, {
496
+ children: [
497
+ /*#__PURE__*/ jsx(Button, {
498
+ size: "sm",
499
+ intent: "noeffect",
500
+ type: "button",
501
+ onClick: guard.stay,
502
+ children: "Stay on this page"
503
+ }),
504
+ /*#__PURE__*/ jsx(Button, {
505
+ size: "sm",
506
+ intent: "danger",
507
+ type: "button",
508
+ onClick: guard.proceed,
509
+ children: "Leave anyway"
510
+ })
511
+ ]
512
+ })
513
+ ]
514
+ })
515
+ })
516
+ ]
517
+ });
518
+ };
519
+ const FormRenderer = ({ mode, fields, onSubmit, onCancel, onStatusChange, onUnpublish, onDelete, nextStatus, workflowStatuses, publishedVersion, initialData, adminConfig, useAsTitle, useAsPath, headingLabel, headerSlot, collectionPath, initialLocale, onLocaleChange, defaultLocale, useNavigationGuard })=>{
520
+ const savedTabsRef = useRef({});
521
+ return /*#__PURE__*/ jsx(FormProvider, {
522
+ initialData: initialData,
523
+ children: /*#__PURE__*/ jsx(FormContent, {
524
+ mode: mode,
525
+ fields: fields,
526
+ onSubmit: onSubmit,
527
+ onCancel: onCancel,
528
+ onStatusChange: onStatusChange,
529
+ onUnpublish: onUnpublish,
530
+ onDelete: onDelete,
531
+ nextStatus: nextStatus,
532
+ workflowStatuses: workflowStatuses,
533
+ publishedVersion: publishedVersion,
534
+ initialData: initialData,
535
+ adminConfig: adminConfig,
536
+ useAsTitle: useAsTitle,
537
+ useAsPath: useAsPath,
538
+ headingLabel: headingLabel,
539
+ headerSlot: headerSlot,
540
+ collectionPath: collectionPath,
541
+ initialLocale: initialLocale,
542
+ onLocaleChange: onLocaleChange,
543
+ defaultLocale: defaultLocale,
544
+ useNavigationGuard: useNavigationGuard,
545
+ _activeTabBySet: savedTabsRef.current,
546
+ _onTabChange: (tabSetName, tabName)=>{
547
+ savedTabsRef.current = {
548
+ ...savedTabsRef.current,
549
+ [tabSetName]: tabName
550
+ };
551
+ }
552
+ })
553
+ }, `${initialLocale ?? 'default'}-${initialData?.versionId ?? ''}`);
554
+ };
555
+ export { FormRenderer };
@@ -0,0 +1,46 @@
1
+ import "./form-renderer_module.css";
2
+ const form_renderer_module = {
3
+ form: "form-MVxxVb",
4
+ "heading-row": "heading-row-qw_UYh",
5
+ headingRow: "heading-row-qw_UYh",
6
+ heading: "heading-wnLlb_",
7
+ "status-bar": "status-bar-kQCXLT",
8
+ statusBar: "status-bar-kQCXLT",
9
+ status: "status-XbhkJR",
10
+ "status-meta": "status-meta-gppNXX",
11
+ statusMeta: "status-meta-gppNXX",
12
+ "status-cell": "status-cell-Tr3QHl",
13
+ statusCell: "status-cell-Tr3QHl",
14
+ "status-muted": "status-muted-vHn34O",
15
+ statusMuted: "status-muted-vHn34O",
16
+ "status-trunc": "status-trunc-jGiHWf",
17
+ statusTrunc: "status-trunc-jGiHWf",
18
+ "status-published": "status-published-hqosWb",
19
+ statusPublished: "status-published-hqosWb",
20
+ "status-unpublish": "status-unpublish-DiCNI0",
21
+ statusUnpublish: "status-unpublish-DiCNI0",
22
+ actions: "actions-AZBIdR",
23
+ "actions-button": "actions-button-VIwbST",
24
+ actionsButton: "actions-button-VIwbST",
25
+ "actions-status-wrap": "actions-status-wrap-hSvlps",
26
+ actionsStatusWrap: "actions-status-wrap-hSvlps",
27
+ "actions-combo-button": "actions-combo-button-XvqHCC",
28
+ actionsComboButton: "actions-combo-button-XvqHCC",
29
+ "actions-combo-trigger": "actions-combo-trigger-bmXUzc",
30
+ actionsComboTrigger: "actions-combo-trigger-bmXUzc",
31
+ layout: "layout-WTbLYr",
32
+ content: "content-_P5cdJ",
33
+ sidebar: "sidebar-WsxX88",
34
+ tabset: "tabset-xfaMkP",
35
+ "tabset-tabs": "tabset-tabs-jZpqd_",
36
+ tabsetTabs: "tabset-tabs-jZpqd_",
37
+ "tabset-fields": "tabset-fields-JJefdw",
38
+ tabsetFields: "tabset-fields-JJefdw",
39
+ "guard-modal-head": "guard-modal-head-r2TApi",
40
+ guardModalHead: "guard-modal-head-r2TApi",
41
+ "guard-modal-title": "guard-modal-title-p9dFJ9",
42
+ guardModalTitle: "guard-modal-title-p9dFJ9",
43
+ "guard-modal-text": "guard-modal-text-uW56HS",
44
+ guardModalText: "guard-modal-text-uW56HS"
45
+ };
46
+ export default form_renderer_module;