@wix/auto-patterns 1.7.0 → 1.9.0

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 (507) hide show
  1. package/dist/cjs/components/AutoPatternsApp/AutoPatternsApp.js +10 -25
  2. package/dist/cjs/components/AutoPatternsApp/AutoPatternsApp.js.map +1 -1
  3. package/dist/cjs/components/AutoPatternsCollectionPage/AutoPatternsCollectionPage.js +11 -25
  4. package/dist/cjs/components/AutoPatternsCollectionPage/AutoPatternsCollectionPage.js.map +1 -1
  5. package/dist/cjs/components/AutoPatternsCollectionPageContent/AutoPatternsCollectionPageContent.js +3 -2
  6. package/dist/cjs/components/AutoPatternsCollectionPageContent/AutoPatternsCollectionPageContent.js.map +1 -1
  7. package/dist/cjs/components/AutoPatternsEntityPage/AutoPatternsEntityPage.js +255 -77
  8. package/dist/cjs/components/AutoPatternsEntityPage/AutoPatternsEntityPage.js.map +1 -1
  9. package/dist/cjs/components/AutoPatternsEntityPage/Fields/DateInput.js +66 -21
  10. package/dist/cjs/components/AutoPatternsEntityPage/Fields/DateInput.js.map +1 -1
  11. package/dist/cjs/components/AutoPatternsEntityPage/Fields/DateTime.js +100 -29
  12. package/dist/cjs/components/AutoPatternsEntityPage/Fields/DateTime.js.map +1 -1
  13. package/dist/cjs/components/AutoPatternsEntityPage/Fields/FormFieldInput.js +9 -4
  14. package/dist/cjs/components/AutoPatternsEntityPage/Fields/FormFieldInput.js.map +1 -1
  15. package/dist/cjs/components/AutoPatternsEntityPage/Fields/ImageInput.js +83 -0
  16. package/dist/cjs/components/AutoPatternsEntityPage/Fields/ImageInput.js.map +1 -0
  17. package/dist/cjs/components/AutoPatternsEntityPage/Fields/LongText.js +34 -6
  18. package/dist/cjs/components/AutoPatternsEntityPage/Fields/LongText.js.map +1 -1
  19. package/dist/cjs/components/AutoPatternsEntityPage/Fields/Number.js +49 -6
  20. package/dist/cjs/components/AutoPatternsEntityPage/Fields/Number.js.map +1 -1
  21. package/dist/cjs/components/AutoPatternsEntityPage/Fields/ShortText.js +48 -6
  22. package/dist/cjs/components/AutoPatternsEntityPage/Fields/ShortText.js.map +1 -1
  23. package/dist/cjs/components/AutoPatternsEntityPage/Fields/Url.js +47 -34
  24. package/dist/cjs/components/AutoPatternsEntityPage/Fields/Url.js.map +1 -1
  25. package/dist/cjs/components/AutoPatternsEntityPage/Fields/types.js.map +1 -1
  26. package/dist/cjs/components/AutoPatternsGrid/AutoPatternsGrid.js +8 -10
  27. package/dist/cjs/components/AutoPatternsGrid/AutoPatternsGrid.js.map +1 -1
  28. package/dist/cjs/components/AutoPatternsRoute/AutoPatternsRoutes.js +84 -0
  29. package/dist/cjs/components/AutoPatternsRoute/AutoPatternsRoutes.js.map +1 -0
  30. package/dist/cjs/components/AutoPatternsTable/AutoPatternsTable.js +8 -10
  31. package/dist/cjs/components/AutoPatternsTable/AutoPatternsTable.js.map +1 -1
  32. package/dist/cjs/components/AutoPatternsTable/AutoPatternsTableContent.js +7 -8
  33. package/dist/cjs/components/AutoPatternsTable/AutoPatternsTableContent.js.map +1 -1
  34. package/dist/cjs/components/DynamicIcon.js +71 -0
  35. package/dist/cjs/components/DynamicIcon.js.map +1 -0
  36. package/dist/cjs/components/ModalRenderer.js +40 -0
  37. package/dist/cjs/components/ModalRenderer.js.map +1 -0
  38. package/dist/cjs/components/filters/DynamicCollectionFilter.js +63 -0
  39. package/dist/cjs/components/filters/DynamicCollectionFilter.js.map +1 -0
  40. package/dist/cjs/components/filters/StaticCollectionFilter.js +31 -0
  41. package/dist/cjs/components/filters/StaticCollectionFilter.js.map +1 -0
  42. package/dist/cjs/components/filters/index.js +9 -0
  43. package/dist/cjs/components/filters/index.js.map +1 -0
  44. package/dist/cjs/components/modals/actions/BulkDeleteModal.js +97 -0
  45. package/dist/cjs/components/modals/actions/BulkDeleteModal.js.map +1 -0
  46. package/dist/cjs/components/modals/actions/CreateModal.js +138 -0
  47. package/dist/cjs/components/modals/actions/CreateModal.js.map +1 -0
  48. package/dist/cjs/components/modals/actions/EditModal.js +140 -0
  49. package/dist/cjs/components/modals/actions/EditModal.js.map +1 -0
  50. package/dist/cjs/components/modals/actions/index.js +22 -0
  51. package/dist/cjs/components/modals/actions/index.js.map +1 -0
  52. package/dist/cjs/{collectionData/CollectionData.js → components/modals/actions/types.js} +1 -1
  53. package/dist/cjs/components/modals/actions/types.js.map +1 -0
  54. package/dist/cjs/components/modals/index.js +10 -0
  55. package/dist/cjs/components/modals/index.js.map +1 -0
  56. package/dist/cjs/{collectionData/cms/CmsCollectionData.js → dataSourceAdapters/cms/cmsAdapter.js} +58 -18
  57. package/dist/cjs/dataSourceAdapters/cms/cmsAdapter.js.map +1 -0
  58. package/dist/cjs/{collectionData → dataSourceAdapters}/cms/filterUtils.js +18 -11
  59. package/dist/cjs/dataSourceAdapters/cms/filterUtils.js.map +1 -0
  60. package/dist/cjs/dataSourceAdapters/cms/sortUtils.js.map +1 -0
  61. package/dist/cjs/dataSourceAdapters/constants.js.map +1 -0
  62. package/dist/cjs/dataSourceAdapters/factory.js +34 -0
  63. package/dist/cjs/dataSourceAdapters/factory.js.map +1 -0
  64. package/dist/cjs/exports/form.js +10 -0
  65. package/dist/cjs/exports/form.js.map +1 -0
  66. package/dist/cjs/hooks/index.js +18 -0
  67. package/dist/cjs/hooks/index.js.map +1 -1
  68. package/dist/cjs/hooks/useActionCell.js +107 -0
  69. package/dist/cjs/hooks/useActionCell.js.map +1 -0
  70. package/dist/cjs/hooks/useActionsSDK.js +34 -0
  71. package/dist/cjs/hooks/useActionsSDK.js.map +1 -0
  72. package/dist/cjs/hooks/useAutoPatternsOptimisticActions.js +25 -0
  73. package/dist/cjs/hooks/useAutoPatternsOptimisticActions.js.map +1 -0
  74. package/dist/cjs/hooks/useBaseSDK.js +35 -0
  75. package/dist/cjs/hooks/useBaseSDK.js.map +1 -0
  76. package/dist/cjs/hooks/useBulkActionToolbar.js +86 -0
  77. package/dist/cjs/hooks/useBulkActionToolbar.js.map +1 -0
  78. package/dist/cjs/hooks/useCollectionPageActions.js +124 -0
  79. package/dist/cjs/hooks/useCollectionPageActions.js.map +1 -0
  80. package/dist/cjs/hooks/useColumns.js +90 -37
  81. package/dist/cjs/hooks/useColumns.js.map +1 -1
  82. package/dist/cjs/hooks/useCommonCollectionFeatures.js +24 -35
  83. package/dist/cjs/hooks/useCommonCollectionFeatures.js.map +1 -1
  84. package/dist/cjs/hooks/useEntityPageHeaderTexts.js +27 -0
  85. package/dist/cjs/hooks/useEntityPageHeaderTexts.js.map +1 -0
  86. package/dist/cjs/hooks/useFetchData.js +33 -9
  87. package/dist/cjs/hooks/useFetchData.js.map +1 -1
  88. package/dist/cjs/hooks/useFilters.js +83 -92
  89. package/dist/cjs/hooks/useFilters.js.map +1 -1
  90. package/dist/cjs/hooks/useGridFeatures.js +32 -21
  91. package/dist/cjs/hooks/useGridFeatures.js.map +1 -1
  92. package/dist/cjs/hooks/useNavigationUtils.js +55 -0
  93. package/dist/cjs/hooks/useNavigationUtils.js.map +1 -0
  94. package/dist/cjs/hooks/usePagePath.js +35 -0
  95. package/dist/cjs/hooks/usePagePath.js.map +1 -0
  96. package/dist/cjs/hooks/useTableFeatures.js +23 -15
  97. package/dist/cjs/hooks/useTableFeatures.js.map +1 -1
  98. package/dist/cjs/providers/AppConfigContext.js +33 -0
  99. package/dist/cjs/providers/AppConfigContext.js.map +1 -0
  100. package/dist/cjs/providers/ModalContext.js +58 -0
  101. package/dist/cjs/providers/ModalContext.js.map +1 -0
  102. package/dist/cjs/providers/OptimisticActionsContext.js +43 -0
  103. package/dist/cjs/providers/OptimisticActionsContext.js.map +1 -0
  104. package/dist/cjs/providers/PatternsWizardOverridesContext.js +1 -1
  105. package/dist/cjs/providers/PatternsWizardOverridesContext.js.map +1 -1
  106. package/dist/cjs/providers/RootAppProvider.js +48 -0
  107. package/dist/cjs/providers/RootAppProvider.js.map +1 -0
  108. package/dist/cjs/providers/SchemaContext.js +49 -5
  109. package/dist/cjs/providers/SchemaContext.js.map +1 -1
  110. package/dist/cjs/providers/SchemaRegistryContext.js +49 -0
  111. package/dist/cjs/providers/SchemaRegistryContext.js.map +1 -0
  112. package/dist/cjs/providers/index.js +22 -4
  113. package/dist/cjs/providers/index.js.map +1 -1
  114. package/dist/cjs/types/BaseSDK.js +4 -0
  115. package/dist/cjs/types/BaseSDK.js.map +1 -0
  116. package/dist/cjs/types/CollectionPageConfig.js.map +1 -1
  117. package/dist/cjs/types/EntityPageConfig.js.map +1 -1
  118. package/dist/cjs/types/actions/actionCell.js +4 -0
  119. package/dist/cjs/types/actions/actionCell.js.map +1 -0
  120. package/dist/cjs/types/actions/base.js +4 -0
  121. package/dist/cjs/types/actions/base.js.map +1 -0
  122. package/dist/cjs/types/actions/bulkActions.js +4 -0
  123. package/dist/cjs/types/actions/bulkActions.js.map +1 -0
  124. package/dist/cjs/types/actions/collectionPageActions.js +4 -0
  125. package/dist/cjs/types/actions/collectionPageActions.js.map +1 -0
  126. package/dist/cjs/types/actions/index.js +28 -0
  127. package/dist/cjs/types/actions/index.js.map +1 -0
  128. package/dist/cjs/types/index.js +18 -0
  129. package/dist/cjs/types/index.js.map +1 -1
  130. package/dist/cjs/types/types.js.map +1 -1
  131. package/dist/cjs/utils/actions/bulkDeleteAction.js +26 -0
  132. package/dist/cjs/utils/actions/bulkDeleteAction.js.map +1 -0
  133. package/dist/cjs/utils/actions/createAction.js +38 -0
  134. package/dist/cjs/utils/actions/createAction.js.map +1 -0
  135. package/dist/cjs/utils/actions/customAction.js +23 -0
  136. package/dist/cjs/utils/actions/customAction.js.map +1 -0
  137. package/dist/cjs/utils/actions/customModalAction.js +22 -0
  138. package/dist/cjs/utils/actions/customModalAction.js.map +1 -0
  139. package/dist/cjs/utils/actions/deleteAction.js +63 -0
  140. package/dist/cjs/utils/actions/deleteAction.js.map +1 -0
  141. package/dist/cjs/utils/actions/index.js +46 -0
  142. package/dist/cjs/utils/actions/index.js.map +1 -0
  143. package/dist/cjs/utils/actions/resolveAction.js +27 -0
  144. package/dist/cjs/utils/actions/resolveAction.js.map +1 -0
  145. package/dist/cjs/utils/actions/types.js +4 -0
  146. package/dist/cjs/utils/actions/types.js.map +1 -0
  147. package/dist/cjs/utils/actions/updateAction.js +40 -0
  148. package/dist/cjs/utils/actions/updateAction.js.map +1 -0
  149. package/dist/cjs/utils/filterCreators.js +137 -0
  150. package/dist/cjs/utils/filterCreators.js.map +1 -0
  151. package/dist/cjs/utils/media/getImageUrl.js +22 -0
  152. package/dist/cjs/utils/media/getImageUrl.js.map +1 -0
  153. package/dist/esm/components/AutoPatternsApp/AutoPatternsApp.js +6 -14
  154. package/dist/esm/components/AutoPatternsApp/AutoPatternsApp.js.map +1 -1
  155. package/dist/esm/components/AutoPatternsCollectionPage/AutoPatternsCollectionPage.js +6 -5
  156. package/dist/esm/components/AutoPatternsCollectionPage/AutoPatternsCollectionPage.js.map +1 -1
  157. package/dist/esm/components/AutoPatternsCollectionPageContent/AutoPatternsCollectionPageContent.js +1 -0
  158. package/dist/esm/components/AutoPatternsCollectionPageContent/AutoPatternsCollectionPageContent.js.map +1 -1
  159. package/dist/esm/components/AutoPatternsEntityPage/AutoPatternsEntityPage.js +168 -40
  160. package/dist/esm/components/AutoPatternsEntityPage/AutoPatternsEntityPage.js.map +1 -1
  161. package/dist/esm/components/AutoPatternsEntityPage/Fields/DateInput.js +66 -21
  162. package/dist/esm/components/AutoPatternsEntityPage/Fields/DateInput.js.map +1 -1
  163. package/dist/esm/components/AutoPatternsEntityPage/Fields/DateTime.js +96 -25
  164. package/dist/esm/components/AutoPatternsEntityPage/Fields/DateTime.js.map +1 -1
  165. package/dist/esm/components/AutoPatternsEntityPage/Fields/FormFieldInput.js +9 -4
  166. package/dist/esm/components/AutoPatternsEntityPage/Fields/FormFieldInput.js.map +1 -1
  167. package/dist/esm/components/AutoPatternsEntityPage/Fields/ImageInput.js +64 -0
  168. package/dist/esm/components/AutoPatternsEntityPage/Fields/ImageInput.js.map +1 -0
  169. package/dist/esm/components/AutoPatternsEntityPage/Fields/LongText.js +33 -5
  170. package/dist/esm/components/AutoPatternsEntityPage/Fields/LongText.js.map +1 -1
  171. package/dist/esm/components/AutoPatternsEntityPage/Fields/Number.js +48 -5
  172. package/dist/esm/components/AutoPatternsEntityPage/Fields/Number.js.map +1 -1
  173. package/dist/esm/components/AutoPatternsEntityPage/Fields/ShortText.js +48 -6
  174. package/dist/esm/components/AutoPatternsEntityPage/Fields/ShortText.js.map +1 -1
  175. package/dist/esm/components/AutoPatternsEntityPage/Fields/Url.js +43 -27
  176. package/dist/esm/components/AutoPatternsEntityPage/Fields/Url.js.map +1 -1
  177. package/dist/esm/components/AutoPatternsEntityPage/Fields/types.js.map +1 -1
  178. package/dist/esm/components/AutoPatternsGrid/AutoPatternsGrid.js +5 -6
  179. package/dist/esm/components/AutoPatternsGrid/AutoPatternsGrid.js.map +1 -1
  180. package/dist/esm/components/AutoPatternsRoute/AutoPatternsRoutes.js +47 -0
  181. package/dist/esm/components/AutoPatternsRoute/AutoPatternsRoutes.js.map +1 -0
  182. package/dist/esm/components/AutoPatternsTable/AutoPatternsTable.js +5 -6
  183. package/dist/esm/components/AutoPatternsTable/AutoPatternsTable.js.map +1 -1
  184. package/dist/esm/components/AutoPatternsTable/AutoPatternsTableContent.js +9 -10
  185. package/dist/esm/components/AutoPatternsTable/AutoPatternsTableContent.js.map +1 -1
  186. package/dist/esm/components/DynamicIcon.js +33 -0
  187. package/dist/esm/components/DynamicIcon.js.map +1 -0
  188. package/dist/esm/components/ModalRenderer.js +25 -0
  189. package/dist/esm/components/ModalRenderer.js.map +1 -0
  190. package/dist/esm/components/filters/DynamicCollectionFilter.js +50 -0
  191. package/dist/esm/components/filters/DynamicCollectionFilter.js.map +1 -0
  192. package/dist/esm/components/filters/StaticCollectionFilter.js +18 -0
  193. package/dist/esm/components/filters/StaticCollectionFilter.js.map +1 -0
  194. package/dist/esm/components/filters/index.js +3 -0
  195. package/dist/esm/components/filters/index.js.map +1 -0
  196. package/dist/esm/components/modals/actions/BulkDeleteModal.js +59 -0
  197. package/dist/esm/components/modals/actions/BulkDeleteModal.js.map +1 -0
  198. package/dist/esm/components/modals/actions/CreateModal.js +80 -0
  199. package/dist/esm/components/modals/actions/CreateModal.js.map +1 -0
  200. package/dist/esm/components/modals/actions/EditModal.js +82 -0
  201. package/dist/esm/components/modals/actions/EditModal.js.map +1 -0
  202. package/dist/esm/components/modals/actions/index.js +4 -0
  203. package/dist/esm/components/modals/actions/index.js.map +1 -0
  204. package/dist/esm/components/modals/actions/types.js +2 -0
  205. package/dist/esm/components/modals/actions/types.js.map +1 -0
  206. package/dist/esm/components/modals/index.js +2 -0
  207. package/dist/esm/components/modals/index.js.map +1 -0
  208. package/dist/esm/dataSourceAdapters/cms/cmsAdapter.js +132 -0
  209. package/dist/esm/dataSourceAdapters/cms/cmsAdapter.js.map +1 -0
  210. package/dist/esm/{collectionData → dataSourceAdapters}/cms/filterUtils.js +18 -11
  211. package/dist/esm/dataSourceAdapters/cms/filterUtils.js.map +1 -0
  212. package/dist/esm/dataSourceAdapters/cms/sortUtils.js.map +1 -0
  213. package/dist/esm/dataSourceAdapters/constants.js.map +1 -0
  214. package/dist/esm/dataSourceAdapters/factory.js +30 -0
  215. package/dist/esm/dataSourceAdapters/factory.js.map +1 -0
  216. package/dist/esm/exports/form.js +2 -0
  217. package/dist/esm/exports/form.js.map +1 -0
  218. package/dist/esm/hooks/index.js +3 -0
  219. package/dist/esm/hooks/index.js.map +1 -1
  220. package/dist/esm/hooks/useActionCell.js +103 -0
  221. package/dist/esm/hooks/useActionCell.js.map +1 -0
  222. package/dist/esm/hooks/useActionsSDK.js +30 -0
  223. package/dist/esm/hooks/useActionsSDK.js.map +1 -0
  224. package/dist/esm/hooks/useAutoPatternsOptimisticActions.js +23 -0
  225. package/dist/esm/hooks/useAutoPatternsOptimisticActions.js.map +1 -0
  226. package/dist/esm/hooks/useBaseSDK.js +30 -0
  227. package/dist/esm/hooks/useBaseSDK.js.map +1 -0
  228. package/dist/esm/hooks/useBulkActionToolbar.js +73 -0
  229. package/dist/esm/hooks/useBulkActionToolbar.js.map +1 -0
  230. package/dist/esm/hooks/useCollectionPageActions.js +101 -0
  231. package/dist/esm/hooks/useCollectionPageActions.js.map +1 -0
  232. package/dist/esm/hooks/useColumns.js +70 -38
  233. package/dist/esm/hooks/useColumns.js.map +1 -1
  234. package/dist/esm/hooks/useCommonCollectionFeatures.js +20 -24
  235. package/dist/esm/hooks/useCommonCollectionFeatures.js.map +1 -1
  236. package/dist/esm/hooks/useEntityPageHeaderTexts.js +23 -0
  237. package/dist/esm/hooks/useEntityPageHeaderTexts.js.map +1 -0
  238. package/dist/esm/hooks/useFetchData.js +34 -10
  239. package/dist/esm/hooks/useFetchData.js.map +1 -1
  240. package/dist/esm/hooks/useFilters.js +75 -85
  241. package/dist/esm/hooks/useFilters.js.map +1 -1
  242. package/dist/esm/hooks/useGridFeatures.js +32 -21
  243. package/dist/esm/hooks/useGridFeatures.js.map +1 -1
  244. package/dist/esm/hooks/useNavigationUtils.js +51 -0
  245. package/dist/esm/hooks/useNavigationUtils.js.map +1 -0
  246. package/dist/esm/hooks/usePagePath.js +30 -0
  247. package/dist/esm/hooks/usePagePath.js.map +1 -0
  248. package/dist/esm/hooks/useTableFeatures.js +20 -13
  249. package/dist/esm/hooks/useTableFeatures.js.map +1 -1
  250. package/dist/esm/providers/AppConfigContext.js +19 -0
  251. package/dist/esm/providers/AppConfigContext.js.map +1 -0
  252. package/dist/esm/providers/ModalContext.js +37 -0
  253. package/dist/esm/providers/ModalContext.js.map +1 -0
  254. package/dist/esm/providers/OptimisticActionsContext.js +29 -0
  255. package/dist/esm/providers/OptimisticActionsContext.js.map +1 -0
  256. package/dist/esm/providers/PatternsWizardOverridesContext.js.map +1 -1
  257. package/dist/esm/providers/RootAppProvider.js +15 -0
  258. package/dist/esm/providers/RootAppProvider.js.map +1 -0
  259. package/dist/esm/providers/SchemaContext.js +48 -4
  260. package/dist/esm/providers/SchemaContext.js.map +1 -1
  261. package/dist/esm/providers/SchemaRegistryContext.js +35 -0
  262. package/dist/esm/providers/SchemaRegistryContext.js.map +1 -0
  263. package/dist/esm/providers/index.js +4 -1
  264. package/dist/esm/providers/index.js.map +1 -1
  265. package/dist/esm/types/BaseSDK.js +2 -0
  266. package/dist/esm/types/BaseSDK.js.map +1 -0
  267. package/dist/esm/types/CollectionPageConfig.js.map +1 -1
  268. package/dist/esm/types/EntityPageConfig.js.map +1 -1
  269. package/dist/esm/types/actions/actionCell.js +2 -0
  270. package/dist/esm/types/actions/actionCell.js.map +1 -0
  271. package/dist/esm/types/actions/base.js +2 -0
  272. package/dist/esm/types/actions/base.js.map +1 -0
  273. package/dist/esm/types/actions/bulkActions.js +2 -0
  274. package/dist/esm/types/actions/bulkActions.js.map +1 -0
  275. package/dist/esm/types/actions/collectionPageActions.js +2 -0
  276. package/dist/esm/types/actions/collectionPageActions.js.map +1 -0
  277. package/dist/esm/types/actions/index.js +5 -0
  278. package/dist/esm/types/actions/index.js.map +1 -0
  279. package/dist/esm/types/index.js +3 -0
  280. package/dist/esm/types/index.js.map +1 -1
  281. package/dist/esm/types/types.js.map +1 -1
  282. package/dist/esm/utils/actions/bulkDeleteAction.js +21 -0
  283. package/dist/esm/utils/actions/bulkDeleteAction.js.map +1 -0
  284. package/dist/esm/utils/actions/createAction.js +33 -0
  285. package/dist/esm/utils/actions/createAction.js.map +1 -0
  286. package/dist/esm/utils/actions/customAction.js +18 -0
  287. package/dist/esm/utils/actions/customAction.js.map +1 -0
  288. package/dist/esm/utils/actions/customModalAction.js +17 -0
  289. package/dist/esm/utils/actions/customModalAction.js.map +1 -0
  290. package/dist/esm/utils/actions/deleteAction.js +58 -0
  291. package/dist/esm/utils/actions/deleteAction.js.map +1 -0
  292. package/dist/esm/utils/actions/index.js +9 -0
  293. package/dist/esm/utils/actions/index.js.map +1 -0
  294. package/dist/esm/utils/actions/resolveAction.js +13 -0
  295. package/dist/esm/utils/actions/resolveAction.js.map +1 -0
  296. package/dist/esm/utils/actions/types.js +2 -0
  297. package/dist/esm/utils/actions/types.js.map +1 -0
  298. package/dist/esm/utils/actions/updateAction.js +35 -0
  299. package/dist/esm/utils/actions/updateAction.js.map +1 -0
  300. package/dist/esm/utils/filterCreators.js +139 -0
  301. package/dist/esm/utils/filterCreators.js.map +1 -0
  302. package/dist/esm/utils/media/getImageUrl.js +16 -0
  303. package/dist/esm/utils/media/getImageUrl.js.map +1 -0
  304. package/dist/types/components/AutoPatternsApp/AutoPatternsApp.d.ts +2 -2
  305. package/dist/types/components/AutoPatternsApp/AutoPatternsApp.d.ts.map +1 -1
  306. package/dist/types/components/AutoPatternsCollectionPage/AutoPatternsCollectionPage.d.ts.map +1 -1
  307. package/dist/types/components/AutoPatternsCollectionPageContent/AutoPatternsCollectionPageContent.d.ts.map +1 -1
  308. package/dist/types/components/AutoPatternsEntityPage/AutoPatternsEntityPage.d.ts.map +1 -1
  309. package/dist/types/components/AutoPatternsEntityPage/Fields/Checkbox.d.ts.map +1 -1
  310. package/dist/types/components/AutoPatternsEntityPage/Fields/DateInput.d.ts.map +1 -1
  311. package/dist/types/components/AutoPatternsEntityPage/Fields/DateTime.d.ts.map +1 -1
  312. package/dist/types/components/AutoPatternsEntityPage/Fields/FormFieldInput.d.ts +3 -1
  313. package/dist/types/components/AutoPatternsEntityPage/Fields/FormFieldInput.d.ts.map +1 -1
  314. package/dist/types/components/AutoPatternsEntityPage/Fields/ImageInput.d.ts +6 -0
  315. package/dist/types/components/AutoPatternsEntityPage/Fields/ImageInput.d.ts.map +1 -0
  316. package/dist/types/components/AutoPatternsEntityPage/Fields/LongText.d.ts.map +1 -1
  317. package/dist/types/components/AutoPatternsEntityPage/Fields/Number.d.ts.map +1 -1
  318. package/dist/types/components/AutoPatternsEntityPage/Fields/ShortText.d.ts.map +1 -1
  319. package/dist/types/components/AutoPatternsEntityPage/Fields/Url.d.ts.map +1 -1
  320. package/dist/types/components/AutoPatternsEntityPage/Fields/types.d.ts +2 -0
  321. package/dist/types/components/AutoPatternsEntityPage/Fields/types.d.ts.map +1 -1
  322. package/dist/types/components/AutoPatternsEntityPage/Fields/utils/dates.d.ts.map +1 -1
  323. package/dist/types/components/AutoPatternsGrid/AutoPatternsGrid.d.ts.map +1 -1
  324. package/dist/types/components/AutoPatternsGrid/AutoPatternsGridContent.d.ts.map +1 -1
  325. package/dist/types/components/AutoPatternsRoute/AutoPatternsPage.d.ts.map +1 -1
  326. package/dist/types/components/AutoPatternsRoute/AutoPatternsRoutes.d.ts +6 -0
  327. package/dist/types/components/AutoPatternsRoute/AutoPatternsRoutes.d.ts.map +1 -0
  328. package/dist/types/components/AutoPatternsTable/AutoPatternsTable.d.ts.map +1 -1
  329. package/dist/types/components/AutoPatternsTable/AutoPatternsTableContent.d.ts.map +1 -1
  330. package/dist/types/components/DynamicIcon.d.ts +6 -0
  331. package/dist/types/components/DynamicIcon.d.ts.map +1 -0
  332. package/dist/types/components/ModalRenderer.d.ts +3 -0
  333. package/dist/types/components/ModalRenderer.d.ts.map +1 -0
  334. package/dist/types/components/filters/DynamicCollectionFilter.d.ts +12 -0
  335. package/dist/types/components/filters/DynamicCollectionFilter.d.ts.map +1 -0
  336. package/dist/types/components/filters/StaticCollectionFilter.d.ts +14 -0
  337. package/dist/types/components/filters/StaticCollectionFilter.d.ts.map +1 -0
  338. package/dist/types/components/filters/index.d.ts +3 -0
  339. package/dist/types/components/filters/index.d.ts.map +1 -0
  340. package/dist/types/components/modals/actions/BulkDeleteModal.d.ts +9 -0
  341. package/dist/types/components/modals/actions/BulkDeleteModal.d.ts.map +1 -0
  342. package/dist/types/components/modals/actions/CreateModal.d.ts +8 -0
  343. package/dist/types/components/modals/actions/CreateModal.d.ts.map +1 -0
  344. package/dist/types/components/modals/actions/EditModal.d.ts +11 -0
  345. package/dist/types/components/modals/actions/EditModal.d.ts.map +1 -0
  346. package/dist/types/components/modals/actions/index.d.ts +4 -0
  347. package/dist/types/components/modals/actions/index.d.ts.map +1 -0
  348. package/dist/types/components/modals/actions/types.d.ts +7 -0
  349. package/dist/types/components/modals/actions/types.d.ts.map +1 -0
  350. package/dist/types/components/modals/index.d.ts +2 -0
  351. package/dist/types/components/modals/index.d.ts.map +1 -0
  352. package/dist/types/dataSourceAdapters/cms/cmsAdapter.d.ts +14 -0
  353. package/dist/types/dataSourceAdapters/cms/cmsAdapter.d.ts.map +1 -0
  354. package/dist/types/{collectionData → dataSourceAdapters}/cms/filterUtils.d.ts +3 -2
  355. package/dist/types/dataSourceAdapters/cms/filterUtils.d.ts.map +1 -0
  356. package/dist/types/dataSourceAdapters/cms/sortUtils.d.ts.map +1 -0
  357. package/dist/types/dataSourceAdapters/constants.d.ts.map +1 -0
  358. package/dist/types/dataSourceAdapters/factory.d.ts +13 -0
  359. package/dist/types/dataSourceAdapters/factory.d.ts.map +1 -0
  360. package/dist/types/exports/form.d.ts +2 -0
  361. package/dist/types/exports/form.d.ts.map +1 -0
  362. package/dist/types/hooks/index.d.ts +3 -0
  363. package/dist/types/hooks/index.d.ts.map +1 -1
  364. package/dist/types/hooks/useActionCell.d.ts +9 -0
  365. package/dist/types/hooks/useActionCell.d.ts.map +1 -0
  366. package/dist/types/hooks/useActionsSDK.d.ts +6 -0
  367. package/dist/types/hooks/useActionsSDK.d.ts.map +1 -0
  368. package/dist/types/hooks/useAutoPatternsOptimisticActions.d.ts +3 -0
  369. package/dist/types/hooks/useAutoPatternsOptimisticActions.d.ts.map +1 -0
  370. package/dist/types/hooks/useBaseSDK.d.ts +3 -0
  371. package/dist/types/hooks/useBaseSDK.d.ts.map +1 -0
  372. package/dist/types/hooks/useBulkActionToolbar.d.ts +10 -0
  373. package/dist/types/hooks/useBulkActionToolbar.d.ts.map +1 -0
  374. package/dist/types/hooks/useCollectionPageActions.d.ts +10 -0
  375. package/dist/types/hooks/useCollectionPageActions.d.ts.map +1 -0
  376. package/dist/types/hooks/useColumns.d.ts.map +1 -1
  377. package/dist/types/hooks/useCommonCollectionFeatures.d.ts +9 -9
  378. package/dist/types/hooks/useCommonCollectionFeatures.d.ts.map +1 -1
  379. package/dist/types/hooks/useEmptyStates.d.ts.map +1 -1
  380. package/dist/types/hooks/useEntityPageHeaderTexts.d.ts +18 -0
  381. package/dist/types/hooks/useEntityPageHeaderTexts.d.ts.map +1 -0
  382. package/dist/types/hooks/useFetchData.d.ts +6 -2
  383. package/dist/types/hooks/useFetchData.d.ts.map +1 -1
  384. package/dist/types/hooks/useFilters.d.ts +5 -1
  385. package/dist/types/hooks/useFilters.d.ts.map +1 -1
  386. package/dist/types/hooks/useGridFeatures.d.ts +3 -8
  387. package/dist/types/hooks/useGridFeatures.d.ts.map +1 -1
  388. package/dist/types/hooks/useNavigationUtils.d.ts +10 -0
  389. package/dist/types/hooks/useNavigationUtils.d.ts.map +1 -0
  390. package/dist/types/hooks/usePagePath.d.ts +5 -0
  391. package/dist/types/hooks/usePagePath.d.ts.map +1 -0
  392. package/dist/types/hooks/useTableFeatures.d.ts +3 -7
  393. package/dist/types/hooks/useTableFeatures.d.ts.map +1 -1
  394. package/dist/types/providers/AppConfigContext.d.ts +8 -0
  395. package/dist/types/providers/AppConfigContext.d.ts.map +1 -0
  396. package/dist/types/providers/ModalContext.d.ts +20 -0
  397. package/dist/types/providers/ModalContext.d.ts.map +1 -0
  398. package/dist/types/providers/OptimisticActionsContext.d.ts +12 -0
  399. package/dist/types/providers/OptimisticActionsContext.d.ts.map +1 -0
  400. package/dist/types/providers/PatternsWizardOverridesContext.d.ts +5 -4
  401. package/dist/types/providers/PatternsWizardOverridesContext.d.ts.map +1 -1
  402. package/dist/types/providers/RootAppProvider.d.ts +7 -0
  403. package/dist/types/providers/RootAppProvider.d.ts.map +1 -0
  404. package/dist/types/providers/SchemaContext.d.ts.map +1 -1
  405. package/dist/types/providers/SchemaRegistryContext.d.ts +13 -0
  406. package/dist/types/providers/SchemaRegistryContext.d.ts.map +1 -0
  407. package/dist/types/providers/index.d.ts +4 -1
  408. package/dist/types/providers/index.d.ts.map +1 -1
  409. package/dist/types/types/BaseSDK.d.ts +12 -0
  410. package/dist/types/types/BaseSDK.d.ts.map +1 -0
  411. package/dist/types/types/CollectionPageConfig.d.ts +37 -32
  412. package/dist/types/types/CollectionPageConfig.d.ts.map +1 -1
  413. package/dist/types/types/EntityPageConfig.d.ts +51 -2
  414. package/dist/types/types/EntityPageConfig.d.ts.map +1 -1
  415. package/dist/types/types/actions/actionCell.d.ts +24 -0
  416. package/dist/types/types/actions/actionCell.d.ts.map +1 -0
  417. package/dist/types/types/actions/base.d.ts +102 -0
  418. package/dist/types/types/actions/base.d.ts.map +1 -0
  419. package/dist/types/types/actions/bulkActions.d.ts +28 -0
  420. package/dist/types/types/actions/bulkActions.d.ts.map +1 -0
  421. package/dist/types/types/actions/collectionPageActions.d.ts +27 -0
  422. package/dist/types/types/actions/collectionPageActions.d.ts.map +1 -0
  423. package/dist/types/types/actions/index.d.ts +5 -0
  424. package/dist/types/types/actions/index.d.ts.map +1 -0
  425. package/dist/types/types/index.d.ts +3 -0
  426. package/dist/types/types/index.d.ts.map +1 -1
  427. package/dist/types/types/types.d.ts +47 -12
  428. package/dist/types/types/types.d.ts.map +1 -1
  429. package/dist/types/utils/actions/bulkDeleteAction.d.ts +7 -0
  430. package/dist/types/utils/actions/bulkDeleteAction.d.ts.map +1 -0
  431. package/dist/types/utils/actions/createAction.d.ts +7 -0
  432. package/dist/types/utils/actions/createAction.d.ts.map +1 -0
  433. package/dist/types/utils/actions/customAction.d.ts +3 -0
  434. package/dist/types/utils/actions/customAction.d.ts.map +1 -0
  435. package/dist/types/utils/actions/customModalAction.d.ts +5 -0
  436. package/dist/types/utils/actions/customModalAction.d.ts.map +1 -0
  437. package/dist/types/utils/actions/deleteAction.d.ts +7 -0
  438. package/dist/types/utils/actions/deleteAction.d.ts.map +1 -0
  439. package/dist/types/utils/actions/index.d.ts +9 -0
  440. package/dist/types/utils/actions/index.d.ts.map +1 -0
  441. package/dist/types/utils/actions/resolveAction.d.ts +11 -0
  442. package/dist/types/utils/actions/resolveAction.d.ts.map +1 -0
  443. package/dist/types/utils/actions/types.d.ts +61 -0
  444. package/dist/types/utils/actions/types.d.ts.map +1 -0
  445. package/dist/types/utils/actions/updateAction.d.ts +7 -0
  446. package/dist/types/utils/actions/updateAction.d.ts.map +1 -0
  447. package/dist/types/utils/filterCreators.d.ts +48 -0
  448. package/dist/types/utils/filterCreators.d.ts.map +1 -0
  449. package/dist/types/utils/media/getImageUrl.d.ts +3 -0
  450. package/dist/types/utils/media/getImageUrl.d.ts.map +1 -0
  451. package/form/package.json +6 -0
  452. package/package.json +11 -8
  453. package/dist/cjs/collectionData/CollectionData.js.map +0 -1
  454. package/dist/cjs/collectionData/CollectionDataFactory.js +0 -12
  455. package/dist/cjs/collectionData/CollectionDataFactory.js.map +0 -1
  456. package/dist/cjs/collectionData/SchemaFactory.js +0 -12
  457. package/dist/cjs/collectionData/SchemaFactory.js.map +0 -1
  458. package/dist/cjs/collectionData/cms/CmsCollectionData.js.map +0 -1
  459. package/dist/cjs/collectionData/cms/filterUtils.js.map +0 -1
  460. package/dist/cjs/collectionData/cms/sortUtils.js.map +0 -1
  461. package/dist/cjs/collectionData/constants.js.map +0 -1
  462. package/dist/cjs/collectionData/index.js +0 -10
  463. package/dist/cjs/collectionData/index.js.map +0 -1
  464. package/dist/cjs/providers/CollectionDataContext.js +0 -44
  465. package/dist/cjs/providers/CollectionDataContext.js.map +0 -1
  466. package/dist/cjs/utils/filters.js +0 -53
  467. package/dist/cjs/utils/filters.js.map +0 -1
  468. package/dist/esm/collectionData/CollectionData.js +0 -2
  469. package/dist/esm/collectionData/CollectionData.js.map +0 -1
  470. package/dist/esm/collectionData/CollectionDataFactory.js +0 -8
  471. package/dist/esm/collectionData/CollectionDataFactory.js.map +0 -1
  472. package/dist/esm/collectionData/SchemaFactory.js +0 -8
  473. package/dist/esm/collectionData/SchemaFactory.js.map +0 -1
  474. package/dist/esm/collectionData/cms/CmsCollectionData.js +0 -91
  475. package/dist/esm/collectionData/cms/CmsCollectionData.js.map +0 -1
  476. package/dist/esm/collectionData/cms/filterUtils.js.map +0 -1
  477. package/dist/esm/collectionData/cms/sortUtils.js.map +0 -1
  478. package/dist/esm/collectionData/constants.js.map +0 -1
  479. package/dist/esm/collectionData/index.js +0 -2
  480. package/dist/esm/collectionData/index.js.map +0 -1
  481. package/dist/esm/providers/CollectionDataContext.js +0 -30
  482. package/dist/esm/providers/CollectionDataContext.js.map +0 -1
  483. package/dist/esm/utils/filters.js +0 -49
  484. package/dist/esm/utils/filters.js.map +0 -1
  485. package/dist/types/collectionData/CollectionData.d.ts +0 -9
  486. package/dist/types/collectionData/CollectionData.d.ts.map +0 -1
  487. package/dist/types/collectionData/CollectionDataFactory.d.ts +0 -4
  488. package/dist/types/collectionData/CollectionDataFactory.d.ts.map +0 -1
  489. package/dist/types/collectionData/SchemaFactory.d.ts +0 -3
  490. package/dist/types/collectionData/SchemaFactory.d.ts.map +0 -1
  491. package/dist/types/collectionData/cms/CmsCollectionData.d.ts +0 -8
  492. package/dist/types/collectionData/cms/CmsCollectionData.d.ts.map +0 -1
  493. package/dist/types/collectionData/cms/filterUtils.d.ts.map +0 -1
  494. package/dist/types/collectionData/cms/sortUtils.d.ts.map +0 -1
  495. package/dist/types/collectionData/constants.d.ts.map +0 -1
  496. package/dist/types/collectionData/index.d.ts +0 -2
  497. package/dist/types/collectionData/index.d.ts.map +0 -1
  498. package/dist/types/providers/CollectionDataContext.d.ts +0 -12
  499. package/dist/types/providers/CollectionDataContext.d.ts.map +0 -1
  500. package/dist/types/utils/filters.d.ts +0 -7
  501. package/dist/types/utils/filters.d.ts.map +0 -1
  502. /package/dist/cjs/{collectionData → dataSourceAdapters}/cms/sortUtils.js +0 -0
  503. /package/dist/cjs/{collectionData → dataSourceAdapters}/constants.js +0 -0
  504. /package/dist/esm/{collectionData → dataSourceAdapters}/cms/sortUtils.js +0 -0
  505. /package/dist/esm/{collectionData → dataSourceAdapters}/constants.js +0 -0
  506. /package/dist/types/{collectionData → dataSourceAdapters}/cms/sortUtils.d.ts +0 -0
  507. /package/dist/types/{collectionData → dataSourceAdapters}/constants.d.ts +0 -0
@@ -1 +1 @@
1
- {"version":3,"names":["_react","_interopRequireDefault","require","_patterns","_form","_designSystem","_FormFieldInput","_reactRouterDom","_SchemaContext","_jsxFileName","AutoPatternsEntityPage","configuration","title","subtitle","visibleFieldIds","collectionPagePath","parentPath","form","useForm","params","useParams","entityId","schema","useSchema","state","useEntityPage","onSave","formValues","getValues","updatedEntity","entity","newUpdatedEntity","actions","update","create","saveErrorToast","fetch","undefined","get","useEntity","default","createElement","EntityPage","dataHook","__self","__source","fileName","lineNumber","columnNumber","Header","text","displayField","Content","MainContent","Card","minHeight","Divider","Box","gap","direction","map","fieldId","Fragment","key","Cell","span","FormFieldInput","field","fields","exports"],"sources":["../../../../src/components/AutoPatternsEntityPage/AutoPatternsEntityPage.tsx"],"sourcesContent":["import React from 'react';\nimport { EntityPageConfig } from '../../types';\nimport {\n EntityPage,\n EntityPageState,\n useEntity,\n useEntityPage,\n} from '@wix/patterns';\nimport { useForm } from '@wix/patterns/form';\nimport { Box, Card, Cell } from '@wix/design-system';\nimport { FormFieldInput } from './Fields/FormFieldInput';\nimport { useParams } from 'react-router-dom';\nimport { useSchema } from '../../providers/SchemaContext';\n\nexport interface AutoPatternsEntityPageProps {\n configuration: EntityPageConfig;\n}\n\nexport const AutoPatternsEntityPage: React.FC<AutoPatternsEntityPageProps> = ({\n configuration,\n}) => {\n const {\n title,\n subtitle,\n visibleFieldIds = [],\n collectionPagePath: parentPath,\n } = configuration;\n const form = useForm<any>();\n const params = useParams();\n const entityId = params.entityId;\n const schema = useSchema();\n const state: EntityPageState<any> = useEntityPage<any, any>({\n parentPath,\n form,\n onSave: async () => {\n const formValues = form.getValues();\n const updatedEntity: any = {\n ...state.entity,\n ...formValues,\n };\n\n let newUpdatedEntity;\n if (entityId) {\n newUpdatedEntity = await schema.actions.update(updatedEntity);\n } else {\n newUpdatedEntity = await schema.actions.create(updatedEntity);\n }\n\n return { updatedEntity: newUpdatedEntity };\n },\n saveErrorToast: () => 'Failed to save',\n fetch: async () => {\n if (!entityId) {\n return { entity: undefined };\n }\n\n const entity = await schema.actions.get(entityId);\n return { entity };\n },\n });\n const entity = useEntity(state);\n\n return (\n <EntityPage state={state} dataHook=\"auto-patterns-entity-page\">\n <EntityPage.Header\n title={\n title ?? { text: entity?.[schema.displayField] ?? 'Edit Entity' }\n }\n subtitle={subtitle}\n />\n <EntityPage.Content>\n <EntityPage.MainContent>\n <EntityPage.Card minHeight=\"50px\">\n <Card.Header\n title=\"Item details\"\n subtitle=\"Modify the details of your selected item below\"\n />\n <Card.Divider />\n <Card.Content>\n <Box gap=\"SP2\" direction=\"vertical\">\n {visibleFieldIds.map((fieldId) => (\n <React.Fragment key={fieldId}>\n <Cell span={12}>\n <FormFieldInput\n key={fieldId}\n field={schema.fields[fieldId]}\n />\n </Cell>\n </React.Fragment>\n ))}\n </Box>\n </Card.Content>\n </EntityPage.Card>\n </EntityPage.MainContent>\n </EntityPage.Content>\n </EntityPage>\n );\n};\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["_react","_interopRequireWildcard","require","_patterns","_form","_designSystem","_reactRouterDom","_SchemaContext","_FormFieldInput","_hooks","_providers","_jsxFileName","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","RenderLayoutContent","content","level","sectionId","cardIndex","contentIndex","setInputRef","_content$container$ch","_overrides$components","schema","useSchema","overrides","usePatternsWizardOverridesContext","pageState","useEntityPageContext","type","field","fieldId","fields","createElement","Cell","span","__self","__source","fileName","lineNumber","columnNumber","FormFieldInput","key","inputRef","ref","container","children","length","Layout","map","child","index","component","componentId","Component","components","form","entity","RenderLayoutCard","layout","_layout$card$subtitle","EntityPage","Card","minHeight","Header","title","card","text","subtitle","Divider","Content","AutoPatternsEntityPage","configuration","_pageLayout$main","_pageLayout$sidebar","pageLayout","parentPageId","route","useForm","mode","params","useParams","entityId","id","isCreateMode","inputRefs","useRef","input","current","validate","invalidFieldId","keys","find","_inputRefs$current$fi","invalid","_inputRefs$current$in","focus","Error","getParentPagePath","useNavigation","parentPath","useMemo","state","useEntityPage","onSave","formValues","getValues","baseEntity","updatedEntity","newEntity","actions","update","create","fetch","undefined","useEntity","useEntityPageHeaderTexts","config","entityDisplayName","displayField","dataHook","MainContent","main","layoutIndex","sidebar","AdditionalContent","exports"],"sources":["../../../../src/components/AutoPatternsEntityPage/AutoPatternsEntityPage.tsx"],"sourcesContent":["import React, { useMemo, useRef } from 'react';\nimport { CardLayout, EntityPageConfig, LayoutContent } from '../../types';\nimport {\n EntityPage,\n EntityPageState,\n useEntity,\n useEntityPage,\n useEntityPageContext,\n} from '@wix/patterns';\nimport { useForm } from '@wix/patterns/form';\nimport { Card, Cell, Layout } from '@wix/design-system';\nimport { useParams } from 'react-router-dom';\nimport { useSchema } from '../../providers/SchemaContext';\nimport { BaseInputRef } from './Fields/types';\nimport { FormFieldInput } from './Fields/FormFieldInput';\nimport { useEntityPageHeaderTexts, useNavigation } from '../../hooks';\nimport { usePatternsWizardOverridesContext } from '../../providers';\n\nconst RenderLayoutContent: React.FC<{\n content: LayoutContent;\n level: number;\n sectionId: string;\n cardIndex: number;\n contentIndex: number;\n setInputRef: (id: string, input: BaseInputRef) => void;\n}> = ({ content, level, sectionId, cardIndex, contentIndex, setInputRef }) => {\n const schema = useSchema();\n const overrides = usePatternsWizardOverridesContext();\n const pageState = useEntityPageContext();\n\n switch (content.type) {\n case 'field':\n if (!content.field.fieldId) {\n return null;\n }\n\n const field = schema.fields[content.field.fieldId];\n\n if (!field) {\n return null;\n }\n\n return (\n <Cell span={content.field.span}>\n <FormFieldInput\n key={content.field.fieldId}\n field={field}\n inputRef={(ref) => setInputRef(content.field.fieldId, ref)}\n />\n </Cell>\n );\n\n case 'container':\n if (!content.container.children?.length) {\n return null;\n }\n\n return (\n <Cell span={content.container.span}>\n <Layout>\n {content.container.children.map((child, index) => (\n <RenderLayoutContent\n key={`${sectionId}-card-${cardIndex}-content-${contentIndex}-level-${level}-child-${index}`}\n content={child}\n level={level + 1}\n sectionId={sectionId}\n cardIndex={cardIndex}\n contentIndex={index}\n setInputRef={setInputRef}\n />\n ))}\n </Layout>\n </Cell>\n );\n\n case 'component':\n if (!content.component.componentId) {\n return null;\n }\n\n const Component = overrides?.components?.[content.component.componentId];\n\n if (!Component) {\n return null;\n }\n\n return (\n <Cell span={content.component.span}>\n <Component\n form={pageState.form as any}\n entity={pageState.entity as any as Record<string, any>}\n />\n </Cell>\n );\n\n default:\n return null;\n }\n};\n\nconst RenderLayoutCard: React.FC<{\n layout: CardLayout;\n sectionId: string;\n cardIndex: number;\n setInputRef: (id: string, input: BaseInputRef) => void;\n}> = ({ layout, sectionId, cardIndex, setInputRef }) => {\n switch (layout.type) {\n case 'card':\n return (\n <EntityPage.Card minHeight=\"50px\">\n <Card.Header\n title={layout.card.title.text}\n subtitle={layout.card.subtitle?.text}\n />\n <Card.Divider />\n <Card.Content>\n <Layout>\n {layout.card.children.map((child, index: number) => (\n <RenderLayoutContent\n key={`${sectionId}-card-${cardIndex}-content-${index}`}\n content={child}\n level={0}\n sectionId={sectionId}\n cardIndex={cardIndex}\n contentIndex={index}\n setInputRef={setInputRef}\n />\n ))}\n </Layout>\n </Card.Content>\n </EntityPage.Card>\n );\n default:\n return null;\n }\n};\n\nexport interface AutoPatternsEntityPageProps {\n configuration: EntityPageConfig;\n}\n\nexport const AutoPatternsEntityPage: React.FC<AutoPatternsEntityPageProps> = ({\n configuration,\n}) => {\n const { layout: pageLayout, parentPageId, route } = configuration;\n\n const form = useForm<any>({\n mode: 'onChange',\n });\n const params = useParams();\n const entityId = params[route.params.id];\n const schema = useSchema();\n const isCreateMode = !entityId;\n\n const inputRefs = useRef<{ [fieldId: string]: BaseInputRef }>({});\n\n const setInputRef = (id: string, input: BaseInputRef) => {\n inputRefs.current[id] = input;\n };\n\n const validate = () => {\n const invalidFieldId = Object.keys(inputRefs.current).find((fieldId) => {\n return inputRefs.current[fieldId]?.invalid;\n });\n\n if (invalidFieldId) {\n inputRefs.current[invalidFieldId]?.focus?.();\n throw new Error('Invalid form');\n }\n };\n const { getParentPagePath } = useNavigation();\n\n const parentPath = useMemo(\n () => getParentPagePath(parentPageId),\n [parentPageId, getParentPagePath],\n );\n\n const state: EntityPageState<any> = useEntityPage<any, any>({\n parentPath,\n form,\n onSave: async () => {\n validate();\n\n const formValues = form.getValues();\n const baseEntity = state.entity || {};\n const updatedEntity = {\n ...baseEntity,\n ...formValues,\n };\n\n const newEntity = entityId\n ? await schema.actions.update(updatedEntity)\n : await schema.actions.create(updatedEntity);\n\n return { updatedEntity: newEntity };\n },\n fetch: async () => {\n if (!entityId) {\n return { entity: undefined };\n }\n const entity = await schema.actions.get(entityId);\n return { entity };\n },\n });\n\n const entity = useEntity(state);\n\n const { title, subtitle } = useEntityPageHeaderTexts({\n config: configuration,\n isCreateMode,\n entityDisplayName: entity?.[schema.displayField],\n });\n\n return (\n <EntityPage state={state} dataHook=\"auto-patterns-entity-page\">\n <EntityPage.Header title={title} subtitle={subtitle} />\n <EntityPage.Content>\n <EntityPage.MainContent>\n {pageLayout?.main?.map((layout, layoutIndex) => (\n <RenderLayoutCard\n key={`main-section-card-${layoutIndex}`}\n layout={layout}\n sectionId=\"main\"\n cardIndex={layoutIndex}\n setInputRef={setInputRef}\n />\n ))}\n </EntityPage.MainContent>\n {pageLayout?.sidebar ? (\n <EntityPage.AdditionalContent>\n {pageLayout.sidebar?.map((layout, layoutIndex) => (\n <RenderLayoutCard\n key={`sidebar-section-card-${layoutIndex}`}\n layout={layout}\n sectionId=\"sidebar\"\n cardIndex={layoutIndex}\n setInputRef={setInputRef}\n />\n ))}\n </EntityPage.AdditionalContent>\n ) : null}\n </EntityPage.Content>\n </EntityPage>\n );\n};\n\n/*\n Key structure explanation:\n\n Main cards: main-section-card-{layoutIndex}\n Sidebar cards: sidebar-section-card-{layoutIndex}\n\n Layout content:\n {sectionId}-card-{cardIndex}-content-{contentIndex}\n\n Nested children:\n {sectionId}-card-{cardIndex}-content-{parentContentIndex}-level-{level}-child-{childIndex}\n\n This ensures uniqueness across all levels and sections.\n*/\n"],"mappings":"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","ignoreList":[]}
@@ -5,58 +5,103 @@ exports.DateInput = void 0;
5
5
  var _react = _interopRequireWildcard(require("react"));
6
6
  var _designSystem = require("@wix/design-system");
7
7
  var _dates = require("./utils/dates");
8
+ var _patterns = require("@wix/patterns");
9
+ var _form = require("@wix/patterns/form");
8
10
  var _jsxFileName = "/home/builduser/work/73d19ce3378ce4dd/packages/auto-patterns/dist/cjs/components/AutoPatternsEntityPage/Fields/DateInput.tsx";
9
11
  function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
10
12
  function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
13
+ function validateDateField(value, validation, t, format, validationType) {
14
+ if (validation != null && validation.required && (value === null || value === undefined || value === '')) {
15
+ return t('cairo.fieldValidation.requiredField');
16
+ } else if (validationType === 'formatError' && format) {
17
+ return t('cairo.customFields.fieldType.date.invalid.value', {
18
+ dateFormat: format
19
+ });
20
+ }
21
+ return '';
22
+ }
11
23
  const DateInput = props => {
24
+ var _pageState$entity, _field$validation;
12
25
  const {
13
26
  field,
14
- value,
15
- onChange
27
+ dataHook,
28
+ inputRef
16
29
  } = props;
17
- const [date, setDate] = (0, _react.useState)(() => value ? (0, _dates.getDateWithoutTimezone)((0, _dates.getISODateStringWithFixedTimezone)(value)) : undefined);
30
+ const {
31
+ translate: t,
32
+ ...container
33
+ } = (0, _patterns.useWixPatternsContainer)();
34
+ (0, _patterns.useSelector)(() => container.initTask.status);
35
+ const pageState = (0, _patterns.useEntityPageContext)();
36
+ const controller = (0, _form.useController)({
37
+ name: (field == null ? void 0 : field.id) ?? '',
38
+ control: pageState.form.control,
39
+ defaultValue: (_pageState$entity = pageState.entity) == null ? void 0 : _pageState$entity[(field == null ? void 0 : field.id) ?? ''],
40
+ rules: {
41
+ validate: value => {
42
+ const error = validateDateField(value, field.validation, t);
43
+ return error || true;
44
+ }
45
+ }
46
+ });
47
+ const [date, setDate] = (0, _react.useState)(() => {
48
+ if (controller.field.value) {
49
+ return (0, _dates.getDateWithoutTimezone)((0, _dates.getISODateStringWithFixedTimezone)(controller.field.value));
50
+ }
51
+ return undefined;
52
+ });
18
53
  const ref = (0, _react.useRef)({});
19
- const [statusMessage, setStatusMessage] = (0, _react.useState)('');
54
+ const [errorMessage, setErrorMessage] = (0, _react.useState)('');
20
55
  return /*#__PURE__*/_react.default.createElement(_designSystem.FormField, {
21
56
  label: field.displayName,
57
+ required: (_field$validation = field.validation) == null ? void 0 : _field$validation.required,
58
+ dataHook: dataHook,
22
59
  __self: void 0,
23
60
  __source: {
24
61
  fileName: _jsxFileName,
25
- lineNumber: 24,
62
+ lineNumber: 70,
26
63
  columnNumber: 5
27
64
  }
28
65
  }, /*#__PURE__*/_react.default.createElement(_designSystem.DatePicker, {
66
+ ref: internalRef => {
67
+ inputRef == null || inputRef(ref.current);
68
+ // @ts-expect-error: WSR internal API hack for focusing
69
+ ref.current.focus = () => {
70
+ var _internalRef$state;
71
+ return internalRef == null || (_internalRef$state = internalRef.state) == null || (_internalRef$state = _internalRef$state.inputRef) == null || _internalRef$state.focus == null ? void 0 : _internalRef$state.focus();
72
+ };
73
+ },
29
74
  dataHook: `date-${field.id}`,
30
75
  width: "100%",
31
76
  value: date,
32
77
  onChange: newValue => {
33
- const formattedDate = (0, _dates.getISODateStringWithFixedTimezone)(newValue);
34
78
  setDate(newValue);
35
- onChange(formattedDate.split('T')[0]);
79
+ if (newValue) {
80
+ const formattedDate = (0, _dates.getISODateStringWithFixedTimezone)(newValue);
81
+ controller.field.onChange(formattedDate.split('T')[0]);
82
+ } else {
83
+ controller.field.onChange(null);
84
+ }
36
85
  },
37
86
  onValidate: ({
38
87
  validationType,
39
- value: newValue
88
+ value: newValue,
89
+ format
40
90
  }) => {
41
- if (validationType === 'valid') {
42
- setStatusMessage('');
43
- ref.current.invalid = false;
44
- } else if (validationType === 'formatError' && newValue === '') {
91
+ const error = validateDateField(newValue, field.validation, t, format, validationType);
92
+ setErrorMessage(error);
93
+ ref.current.invalid = !!error;
94
+ if (validationType === 'formatError' && newValue === '') {
45
95
  setDate(undefined);
46
- onChange(null);
47
- setStatusMessage('');
48
- ref.current.invalid = false;
49
- } else {
50
- setStatusMessage('Invalid date');
51
- ref.current.invalid = true;
96
+ controller.field.onChange(null);
52
97
  }
53
98
  },
54
- status: ref.current.invalid ? 'error' : undefined,
55
- statusMessage: statusMessage,
99
+ status: errorMessage ? 'error' : undefined,
100
+ statusMessage: errorMessage,
56
101
  __self: void 0,
57
102
  __source: {
58
103
  fileName: _jsxFileName,
59
- lineNumber: 25,
104
+ lineNumber: 75,
60
105
  columnNumber: 7
61
106
  }
62
107
  }));
@@ -1 +1 @@
1
- {"version":3,"names":["_react","_interopRequireWildcard","require","_designSystem","_dates","_jsxFileName","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","DateInput","props","field","value","onChange","date","setDate","useState","getDateWithoutTimezone","getISODateStringWithFixedTimezone","undefined","ref","useRef","statusMessage","setStatusMessage","createElement","FormField","label","displayName","__self","__source","fileName","lineNumber","columnNumber","DatePicker","dataHook","id","width","newValue","formattedDate","split","onValidate","validationType","current","invalid","status","exports"],"sources":["../../../../../src/components/AutoPatternsEntityPage/Fields/DateInput.tsx"],"sourcesContent":["import React, { useRef, useState } from 'react';\nimport { FormField, DatePicker } from '@wix/design-system';\nimport {\n getDateWithoutTimezone,\n getISODateStringWithFixedTimezone,\n} from './utils/dates';\nimport { BaseInputProps, BaseInputRef } from './types';\n\nexport interface DateProps extends BaseInputProps<string | null> {}\n\nexport const DateInput = (props: DateProps) => {\n const { field, value, onChange } = props;\n\n const [date, setDate] = useState<Date | undefined>(() =>\n value\n ? getDateWithoutTimezone(getISODateStringWithFixedTimezone(value))\n : undefined,\n );\n\n const ref = useRef<BaseInputRef>({});\n const [statusMessage, setStatusMessage] = useState('');\n\n return (\n <FormField label={field.displayName}>\n <DatePicker\n dataHook={`date-${field.id}`}\n width=\"100%\"\n value={date}\n onChange={(newValue: Date) => {\n const formattedDate = getISODateStringWithFixedTimezone(newValue);\n setDate(newValue);\n onChange(formattedDate.split('T')[0]);\n }}\n onValidate={({ validationType, value: newValue }) => {\n if (validationType === 'valid') {\n setStatusMessage('');\n ref.current.invalid = false;\n } else if (validationType === 'formatError' && newValue === '') {\n setDate(undefined);\n onChange(null);\n setStatusMessage('');\n ref.current.invalid = false;\n } else {\n setStatusMessage('Invalid date');\n ref.current.invalid = true;\n }\n }}\n status={ref.current.invalid ? 'error' : undefined}\n statusMessage={statusMessage}\n />\n </FormField>\n );\n};\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["_react","_interopRequireWildcard","require","_designSystem","_dates","_patterns","_form","_jsxFileName","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","validateDateField","value","validation","format","validationType","required","undefined","dateFormat","DateInput","props","_pageState$entity","_field$validation","field","dataHook","inputRef","translate","container","useWixPatternsContainer","useSelector","initTask","status","pageState","useEntityPageContext","controller","useController","name","id","control","form","defaultValue","entity","rules","validate","error","date","setDate","useState","getDateWithoutTimezone","getISODateStringWithFixedTimezone","ref","useRef","errorMessage","setErrorMessage","createElement","FormField","label","displayName","__self","__source","fileName","lineNumber","columnNumber","DatePicker","internalRef","current","focus","_internalRef$state","state","width","onChange","newValue","formattedDate","split","onValidate","invalid","statusMessage","exports"],"sources":["../../../../../src/components/AutoPatternsEntityPage/Fields/DateInput.tsx"],"sourcesContent":["import React, { useState, useRef } from 'react';\nimport { FormField, DatePicker } from '@wix/design-system';\nimport {\n getDateWithoutTimezone,\n getISODateStringWithFixedTimezone,\n} from './utils/dates';\nimport { BaseInputProps, BaseInputRef } from './types';\nimport {\n useSelector,\n useWixPatternsContainer,\n useEntityPageContext,\n} from '@wix/patterns';\nimport { useController } from '@wix/patterns/form';\nimport { Translate } from '@wix/patterns/core';\n\nexport interface DateProps extends BaseInputProps<string | null> {}\n\nfunction validateDateField(\n value: string | null | undefined,\n validation: DateProps['field']['validation'],\n t: Translate,\n format?: string,\n validationType?: 'outOfBoundsError' | 'formatError' | 'valid',\n) {\n if (\n validation?.required &&\n (value === null || value === undefined || value === '')\n ) {\n return t('cairo.fieldValidation.requiredField');\n } else if (validationType === 'formatError' && format) {\n return t('cairo.customFields.fieldType.date.invalid.value', {\n dateFormat: format,\n });\n }\n\n return '';\n}\n\nexport const DateInput = (props: DateProps) => {\n const { field, dataHook, inputRef } = props;\n const { translate: t, ...container } = useWixPatternsContainer();\n useSelector(() => container.initTask.status);\n const pageState = useEntityPageContext();\n\n const controller = useController({\n name: field?.id ?? '',\n control: pageState.form.control,\n defaultValue: (pageState.entity as any)?.[field?.id ?? ''],\n rules: {\n validate: (value) => {\n const error = validateDateField(value, field.validation, t);\n return error || true;\n },\n },\n });\n\n const [date, setDate] = useState<Date | undefined>(() => {\n if (controller.field.value) {\n return getDateWithoutTimezone(\n getISODateStringWithFixedTimezone(controller.field.value),\n );\n }\n return undefined;\n });\n\n const ref = useRef<BaseInputRef>({});\n const [errorMessage, setErrorMessage] = useState<string>('');\n\n return (\n <FormField\n label={field.displayName}\n required={field.validation?.required}\n dataHook={dataHook}\n >\n <DatePicker\n ref={(internalRef) => {\n inputRef?.(ref.current);\n // @ts-expect-error: WSR internal API hack for focusing\n ref.current.focus = () => internalRef?.state?.inputRef?.focus?.();\n }}\n dataHook={`date-${field.id}`}\n width=\"100%\"\n value={date}\n onChange={(newValue: Date) => {\n setDate(newValue);\n if (newValue) {\n const formattedDate = getISODateStringWithFixedTimezone(newValue);\n controller.field.onChange(formattedDate.split('T')[0]);\n } else {\n controller.field.onChange(null);\n }\n }}\n onValidate={({ validationType, value: newValue, format }) => {\n const error = validateDateField(\n newValue,\n field.validation,\n t,\n format,\n validationType,\n );\n setErrorMessage(error);\n ref.current.invalid = !!error;\n\n if (validationType === 'formatError' && newValue === '') {\n setDate(undefined);\n controller.field.onChange(null);\n }\n }}\n status={errorMessage ? 'error' : undefined}\n statusMessage={errorMessage}\n />\n </FormField>\n );\n};\n"],"mappings":"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","ignoreList":[]}
@@ -4,41 +4,76 @@ exports.__esModule = true;
4
4
  exports.DateTime = void 0;
5
5
  var _react = _interopRequireWildcard(require("react"));
6
6
  var _designSystem = require("@wix/design-system");
7
+ var _patterns = require("@wix/patterns");
8
+ var _form = require("@wix/patterns/form");
7
9
  var _jsxFileName = "/home/builduser/work/73d19ce3378ce4dd/packages/auto-patterns/dist/cjs/components/AutoPatternsEntityPage/Fields/DateTime.tsx";
8
10
  function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
9
11
  function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
10
12
  const DateTime = props => {
13
+ var _pageState$entity, _field$validation2;
11
14
  const {
12
15
  field,
13
- value,
14
- onChange
16
+ dataHook,
17
+ inputRef
15
18
  } = props;
19
+ const {
20
+ translate: t,
21
+ ...container
22
+ } = (0, _patterns.useWixPatternsContainer)();
23
+ (0, _patterns.useSelector)(() => container.initTask.status);
24
+ const pageState = (0, _patterns.useEntityPageContext)();
25
+ const controller = (0, _form.useController)({
26
+ name: (field == null ? void 0 : field.id) ?? '',
27
+ control: pageState.form.control,
28
+ defaultValue: (_pageState$entity = pageState.entity) == null ? void 0 : _pageState$entity[(field == null ? void 0 : field.id) ?? ''],
29
+ rules: {
30
+ validate: v => {
31
+ var _field$validation;
32
+ if (field != null && (_field$validation = field.validation) != null && _field$validation.required && (v === null || v === undefined || v === '')) {
33
+ return t('cairo.fieldValidation.requiredField');
34
+ }
35
+ return true;
36
+ }
37
+ }
38
+ });
16
39
  const date = (0, _react.useMemo)(() => {
17
- if (!value) {
40
+ if (!controller.field.value) {
18
41
  return undefined;
19
42
  }
20
- const d = new Date(value);
43
+ const d = new Date(controller.field.value);
21
44
  return isNaN(d.getTime()) ? undefined : d;
22
- }, [value]);
23
- const [statusMessage, setStatusMessage] = (0, _react.useState)('');
45
+ }, [controller.field.value]);
46
+ const [dateStatusMessage, setDateStatusMessage] = (0, _react.useState)('');
47
+ const [timeStatusMessage, setTimeStatusMessage] = (0, _react.useState)('');
24
48
  const ref = (0, _react.useRef)({});
25
49
  const dateRef = (0, _react.useRef)({});
26
50
  const timeRef = (0, _react.useRef)({});
27
51
  const [dateValue, setDateValue] = (0, _react.useState)(date == null ? void 0 : date.getDate());
28
52
  const [timeValue, setTimeValue] = (0, _react.useState)(date == null ? void 0 : date.getTime());
53
+ (0, _react.useEffect)(() => {
54
+ ref.current.focus = () => {
55
+ if (dateRef.current.invalid) {
56
+ return dateRef.current.focus == null ? void 0 : dateRef.current.focus();
57
+ }
58
+ return timeRef.current.focus == null ? void 0 : timeRef.current.focus();
59
+ };
60
+ inputRef == null || inputRef(ref.current);
61
+ }, [inputRef]);
29
62
  return /*#__PURE__*/_react.default.createElement(_designSystem.FormField, {
30
63
  label: field.displayName,
64
+ required: (_field$validation2 = field.validation) == null ? void 0 : _field$validation2.required,
65
+ dataHook: dataHook,
31
66
  __self: void 0,
32
67
  __source: {
33
68
  fileName: _jsxFileName,
34
- lineNumber: 35,
69
+ lineNumber: 76,
35
70
  columnNumber: 5
36
71
  }
37
72
  }, /*#__PURE__*/_react.default.createElement(_designSystem.Layout, {
38
73
  __self: void 0,
39
74
  __source: {
40
75
  fileName: _jsxFileName,
41
- lineNumber: 36,
76
+ lineNumber: 81,
42
77
  columnNumber: 7
43
78
  }
44
79
  }, /*#__PURE__*/_react.default.createElement(_designSystem.Cell, {
@@ -46,18 +81,28 @@ const DateTime = props => {
46
81
  __self: void 0,
47
82
  __source: {
48
83
  fileName: _jsxFileName,
49
- lineNumber: 37,
84
+ lineNumber: 82,
50
85
  columnNumber: 9
51
86
  }
52
87
  }, /*#__PURE__*/_react.default.createElement(_designSystem.DatePicker, {
88
+ ref: internalRef => {
89
+ dateRef.current.focus = () => {
90
+ var _internalRef$state;
91
+ return (// TODO: PR to WSR needed to expose as public API
92
+ // @ts-expect-error
93
+ internalRef == null || (_internalRef$state = internalRef.state) == null || (_internalRef$state = _internalRef$state.inputRef) == null || _internalRef$state.focus == null ? void 0 : _internalRef$state.focus()
94
+ );
95
+ };
96
+ },
53
97
  width: "100%",
54
98
  value: date
55
- // onChange is triggered only when you have valid, non-empty value. and onValidate is triggered on every change to we use onValidate
99
+ // onChange is triggered only when you have valid, non-empty value. and onValidate is triggered on every change so we use onValidate
56
100
  ,
57
101
  onChange: () => {},
58
102
  onValidate: ({
59
103
  validationType,
60
- value: newValue
104
+ value: newValue,
105
+ format
61
106
  }) => {
62
107
  if (validationType === 'valid') {
63
108
  const dateWithNewDate = date ? new Date(date) : new Date(newValue);
@@ -65,30 +110,38 @@ const DateTime = props => {
65
110
  dateWithNewDate.setFullYear(_value.getFullYear());
66
111
  dateWithNewDate.setMonth(_value.getMonth());
67
112
  dateWithNewDate.setDate(_value.getDate());
68
- onChange(dateWithNewDate.toISOString());
113
+ controller.field.onChange(dateWithNewDate.toISOString());
69
114
  setDateValue(new Date(newValue).getDate());
70
- setStatusMessage('');
115
+ setDateStatusMessage('');
71
116
  dateRef.current.invalid = false;
72
- } else if (validationType === 'formatError' && value === '') {
73
- setStatusMessage('');
74
- dateRef.current.invalid = false;
75
- setDateValue(value);
117
+ } else if (validationType === 'formatError' && newValue === '') {
118
+ var _field$validation3;
119
+ if ((_field$validation3 = field.validation) != null && _field$validation3.required) {
120
+ setDateStatusMessage(t('cairo.fieldValidation.requiredField'));
121
+ dateRef.current.invalid = true;
122
+ } else {
123
+ setDateStatusMessage('');
124
+ dateRef.current.invalid = false;
125
+ }
126
+ setDateValue(newValue);
76
127
  if (!timeValue) {
77
- onChange(null);
128
+ controller.field.onChange(null);
78
129
  }
79
130
  } else {
80
- setStatusMessage('Invalid date');
131
+ setDateStatusMessage(t('cairo.customFields.fieldType.date.invalid.value', {
132
+ dateFormat: format ?? ''
133
+ }));
81
134
  dateRef.current.invalid = true;
82
135
  }
83
136
  ref.current.invalid = dateRef.current.invalid || timeRef.current.invalid;
84
137
  },
85
- status: ref.current.invalid ? 'error' : undefined,
86
- statusMessage: statusMessage,
138
+ status: controller.fieldState.error || dateStatusMessage ? 'error' : undefined,
139
+ statusMessage: controller.fieldState.error || dateStatusMessage,
87
140
  dataHook: `datetime-date-${field.id}`,
88
141
  __self: void 0,
89
142
  __source: {
90
143
  fileName: _jsxFileName,
91
- lineNumber: 38,
144
+ lineNumber: 83,
92
145
  columnNumber: 11
93
146
  }
94
147
  })), /*#__PURE__*/_react.default.createElement(_designSystem.Cell, {
@@ -96,20 +149,26 @@ const DateTime = props => {
96
149
  __self: void 0,
97
150
  __source: {
98
151
  fileName: _jsxFileName,
99
- lineNumber: 76,
152
+ lineNumber: 142,
100
153
  columnNumber: 9
101
154
  }
102
155
  }, /*#__PURE__*/_react.default.createElement(_designSystem.TimeInput, {
156
+ ref: internalRef => {
157
+ timeRef.current.focus = () => internalRef == null ? void 0 : internalRef.focus();
158
+ },
103
159
  dataHook: `datetime-time-${field.id}`,
104
160
  value: date ?? null,
105
- invalidMessage: "Invalid time",
161
+ status: controller.fieldState.error || timeStatusMessage ? 'error' : undefined,
162
+ statusMessage: controller.fieldState.error || timeStatusMessage,
106
163
  onInvalid: () => {
107
164
  timeRef.current.invalid = true;
165
+ setTimeStatusMessage(t('cairo.customFields.fieldType.dateAndTime.invalid.value'));
108
166
  ref.current.invalid = dateRef.current.invalid || timeRef.current.invalid;
109
167
  },
110
168
  onChange: ({
111
169
  date: newValue
112
170
  }) => {
171
+ debugger;
113
172
  timeRef.current.invalid = false;
114
173
  ref.current.invalid = dateRef.current.invalid || timeRef.current.invalid;
115
174
  if (newValue) {
@@ -118,12 +177,24 @@ const DateTime = props => {
118
177
  dateWithNewTime.setMinutes(newValue.getMinutes());
119
178
  dateWithNewTime.setSeconds(newValue.getSeconds());
120
179
  dateWithNewTime.setMilliseconds(newValue.getMilliseconds());
121
- onChange(dateWithNewTime.toISOString());
122
- } else if (!ref.current.invalid) {
180
+ controller.field.onChange(dateWithNewTime.toISOString());
181
+ setTimeStatusMessage('');
182
+ setDateStatusMessage('');
183
+ } else {
123
184
  if (!newValue) {
185
+ var _field$validation4;
124
186
  setTimeValue('');
125
- if (!dateValue) {
126
- onChange(null);
187
+ if ((_field$validation4 = field.validation) != null && _field$validation4.required) {
188
+ setTimeStatusMessage(t('cairo.fieldValidation.requiredField'));
189
+ timeRef.current.invalid = true;
190
+ } else {
191
+ setTimeStatusMessage('');
192
+ timeRef.current.invalid = false;
193
+ }
194
+ if (!ref.current.invalid) {
195
+ if (!dateValue) {
196
+ controller.field.onChange(null);
197
+ }
127
198
  }
128
199
  }
129
200
  }
@@ -131,7 +202,7 @@ const DateTime = props => {
131
202
  __self: void 0,
132
203
  __source: {
133
204
  fileName: _jsxFileName,
134
- lineNumber: 77,
205
+ lineNumber: 143,
135
206
  columnNumber: 11
136
207
  }
137
208
  }))));
@@ -1 +1 @@
1
- {"version":3,"names":["_react","_interopRequireWildcard","require","_designSystem","_jsxFileName","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","DateTime","props","field","value","onChange","date","useMemo","undefined","d","Date","isNaN","getTime","statusMessage","setStatusMessage","useState","ref","useRef","dateRef","timeRef","dateValue","setDateValue","getDate","timeValue","setTimeValue","createElement","FormField","label","displayName","__self","__source","fileName","lineNumber","columnNumber","Layout","Cell","span","DatePicker","width","onValidate","validationType","newValue","dateWithNewDate","_value","setFullYear","getFullYear","setMonth","getMonth","setDate","toISOString","current","invalid","status","dataHook","id","TimeInput","invalidMessage","onInvalid","dateWithNewTime","setHours","getHours","setMinutes","getMinutes","setSeconds","getSeconds","setMilliseconds","getMilliseconds","exports"],"sources":["../../../../../src/components/AutoPatternsEntityPage/Fields/DateTime.tsx"],"sourcesContent":["import React, { useRef, useMemo, useState } from 'react';\nimport {\n Cell,\n DatePicker,\n FormField,\n Layout,\n TimeInput,\n} from '@wix/design-system';\nimport { BaseInputProps, BaseInputRef } from './types';\n\nexport interface DateTimeProps extends BaseInputProps<string | null> {}\nexport const DateTime = (props: DateTimeProps) => {\n const { field, value, onChange } = props;\n\n const date = useMemo(() => {\n if (!value) {\n return undefined;\n }\n const d = new Date(value);\n return isNaN(d.getTime()) ? undefined : d;\n }, [value]);\n const [statusMessage, setStatusMessage] = useState('');\n\n const ref = useRef<BaseInputRef>({});\n const dateRef = useRef<BaseInputRef>({});\n const timeRef = useRef<BaseInputRef>({});\n const [dateValue, setDateValue] = useState<number | string | undefined>(\n date?.getDate(),\n );\n const [timeValue, setTimeValue] = useState<number | string | undefined>(\n date?.getTime(),\n );\n\n return (\n <FormField label={field.displayName}>\n <Layout>\n <Cell span={6}>\n <DatePicker\n width=\"100%\"\n value={date}\n // onChange is triggered only when you have valid, non-empty value. and onValidate is triggered on every change to we use onValidate\n onChange={() => {}}\n onValidate={({ validationType, value: newValue }) => {\n if (validationType === 'valid') {\n const dateWithNewDate = date\n ? new Date(date)\n : new Date(newValue);\n const _value = new Date(newValue);\n dateWithNewDate.setFullYear(_value.getFullYear());\n dateWithNewDate.setMonth(_value.getMonth());\n dateWithNewDate.setDate(_value.getDate());\n onChange(dateWithNewDate.toISOString());\n setDateValue(new Date(newValue).getDate());\n setStatusMessage('');\n dateRef.current.invalid = false;\n } else if (validationType === 'formatError' && value === '') {\n setStatusMessage('');\n dateRef.current.invalid = false;\n setDateValue(value);\n if (!timeValue) {\n onChange(null);\n }\n } else {\n setStatusMessage('Invalid date');\n dateRef.current.invalid = true;\n }\n\n ref.current.invalid =\n dateRef.current.invalid || timeRef.current.invalid;\n }}\n status={ref.current.invalid ? 'error' : undefined}\n statusMessage={statusMessage}\n dataHook={`datetime-date-${field.id}`}\n />\n </Cell>\n <Cell span={6}>\n <TimeInput\n dataHook={`datetime-time-${field.id}`}\n value={date ?? null}\n invalidMessage=\"Invalid time\"\n onInvalid={() => {\n timeRef.current.invalid = true;\n ref.current.invalid =\n dateRef.current.invalid || timeRef.current.invalid;\n }}\n onChange={({ date: newValue }) => {\n timeRef.current.invalid = false;\n ref.current.invalid =\n dateRef.current.invalid || timeRef.current.invalid;\n\n if (newValue) {\n const dateWithNewTime = date ? new Date(date) : newValue;\n dateWithNewTime.setHours(newValue.getHours());\n dateWithNewTime.setMinutes(newValue.getMinutes());\n dateWithNewTime.setSeconds(newValue.getSeconds());\n dateWithNewTime.setMilliseconds(newValue.getMilliseconds());\n onChange(dateWithNewTime.toISOString());\n } else if (!ref.current.invalid) {\n if (!newValue) {\n setTimeValue('');\n if (!dateValue) {\n onChange(null);\n }\n }\n }\n }}\n />\n </Cell>\n </Layout>\n </FormField>\n );\n};\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["_react","_interopRequireWildcard","require","_designSystem","_patterns","_form","_jsxFileName","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","DateTime","props","_pageState$entity","_field$validation2","field","dataHook","inputRef","translate","container","useWixPatternsContainer","useSelector","initTask","status","pageState","useEntityPageContext","controller","useController","name","id","control","form","defaultValue","entity","rules","validate","v","_field$validation","validation","required","undefined","date","useMemo","value","d","Date","isNaN","getTime","dateStatusMessage","setDateStatusMessage","useState","timeStatusMessage","setTimeStatusMessage","ref","useRef","dateRef","timeRef","dateValue","setDateValue","getDate","timeValue","setTimeValue","useEffect","current","focus","invalid","createElement","FormField","label","displayName","__self","__source","fileName","lineNumber","columnNumber","Layout","Cell","span","DatePicker","internalRef","_internalRef$state","state","width","onChange","onValidate","validationType","newValue","format","dateWithNewDate","_value","setFullYear","getFullYear","setMonth","getMonth","setDate","toISOString","_field$validation3","dateFormat","fieldState","error","statusMessage","TimeInput","onInvalid","dateWithNewTime","setHours","getHours","setMinutes","getMinutes","setSeconds","getSeconds","setMilliseconds","getMilliseconds","_field$validation4","exports"],"sources":["../../../../../src/components/AutoPatternsEntityPage/Fields/DateTime.tsx"],"sourcesContent":["import React, { useRef, useMemo, useState, useEffect } from 'react';\nimport {\n Cell,\n DatePicker,\n FormField,\n Layout,\n TimeInput,\n} from '@wix/design-system';\nimport { BaseInputProps, BaseInputRef } from './types';\nimport {\n useWixPatternsContainer,\n useSelector,\n useEntityPageContext,\n} from '@wix/patterns';\nimport { useController } from '@wix/patterns/form';\n\nexport interface DateTimeProps extends BaseInputProps<string | null> {}\n\nexport const DateTime = (props: DateTimeProps) => {\n const { field, dataHook, inputRef } = props;\n const { translate: t, ...container } = useWixPatternsContainer();\n useSelector(() => container.initTask.status);\n const pageState = useEntityPageContext();\n\n const controller = useController({\n name: field?.id ?? '',\n control: pageState.form.control,\n defaultValue: (pageState.entity as any)?.[field?.id ?? ''],\n rules: {\n validate: (v) => {\n if (\n field?.validation?.required &&\n (v === null || v === undefined || v === '')\n ) {\n return t('cairo.fieldValidation.requiredField');\n }\n return true;\n },\n },\n });\n\n const date = useMemo(() => {\n if (!controller.field.value) {\n return undefined;\n }\n const d = new Date(controller.field.value);\n return isNaN(d.getTime()) ? undefined : d;\n }, [controller.field.value]);\n\n const [dateStatusMessage, setDateStatusMessage] = useState('');\n const [timeStatusMessage, setTimeStatusMessage] = useState('');\n\n const ref = useRef<BaseInputRef>({});\n const dateRef = useRef<BaseInputRef>({});\n const timeRef = useRef<BaseInputRef>({});\n const [dateValue, setDateValue] = useState<number | string | undefined>(\n date?.getDate(),\n );\n const [timeValue, setTimeValue] = useState<number | string | undefined>(\n date?.getTime(),\n );\n\n useEffect(() => {\n ref.current.focus = () => {\n if (dateRef.current.invalid) {\n return dateRef.current.focus?.();\n }\n\n return timeRef.current.focus?.();\n };\n\n inputRef?.(ref.current);\n }, [inputRef]);\n\n return (\n <FormField\n label={field.displayName}\n required={field.validation?.required}\n dataHook={dataHook}\n >\n <Layout>\n <Cell span={6}>\n <DatePicker\n ref={(internalRef) => {\n dateRef.current.focus = () =>\n // TODO: PR to WSR needed to expose as public API\n // @ts-expect-error\n internalRef?.state?.inputRef?.focus?.();\n }}\n width=\"100%\"\n value={date}\n // onChange is triggered only when you have valid, non-empty value. and onValidate is triggered on every change so we use onValidate\n onChange={() => {}}\n onValidate={({ validationType, value: newValue, format }) => {\n if (validationType === 'valid') {\n const dateWithNewDate = date\n ? new Date(date)\n : new Date(newValue);\n const _value = new Date(newValue);\n dateWithNewDate.setFullYear(_value.getFullYear());\n dateWithNewDate.setMonth(_value.getMonth());\n dateWithNewDate.setDate(_value.getDate());\n controller.field.onChange(dateWithNewDate.toISOString());\n setDateValue(new Date(newValue).getDate());\n setDateStatusMessage('');\n dateRef.current.invalid = false;\n } else if (validationType === 'formatError' && newValue === '') {\n if (field.validation?.required) {\n setDateStatusMessage(\n t('cairo.fieldValidation.requiredField'),\n );\n dateRef.current.invalid = true;\n } else {\n setDateStatusMessage('');\n dateRef.current.invalid = false;\n }\n setDateValue(newValue);\n if (!timeValue) {\n controller.field.onChange(null);\n }\n } else {\n setDateStatusMessage(\n t('cairo.customFields.fieldType.date.invalid.value', {\n dateFormat: format ?? '',\n }),\n );\n dateRef.current.invalid = true;\n }\n\n ref.current.invalid =\n dateRef.current.invalid || timeRef.current.invalid;\n }}\n status={\n controller.fieldState.error || dateStatusMessage\n ? 'error'\n : undefined\n }\n statusMessage={controller.fieldState.error || dateStatusMessage}\n dataHook={`datetime-date-${field.id}`}\n />\n </Cell>\n <Cell span={6}>\n <TimeInput\n ref={(internalRef) => {\n timeRef.current.focus = () => internalRef?.focus();\n }}\n dataHook={`datetime-time-${field.id}`}\n value={date ?? null}\n status={\n controller.fieldState.error || timeStatusMessage\n ? 'error'\n : undefined\n }\n statusMessage={controller.fieldState.error || timeStatusMessage}\n onInvalid={() => {\n timeRef.current.invalid = true;\n setTimeStatusMessage(\n t('cairo.customFields.fieldType.dateAndTime.invalid.value'),\n );\n ref.current.invalid =\n dateRef.current.invalid || timeRef.current.invalid;\n }}\n onChange={({ date: newValue }) => {\n debugger;\n timeRef.current.invalid = false;\n ref.current.invalid =\n dateRef.current.invalid || timeRef.current.invalid;\n\n if (newValue) {\n const dateWithNewTime = date ? new Date(date) : newValue;\n dateWithNewTime.setHours(newValue.getHours());\n dateWithNewTime.setMinutes(newValue.getMinutes());\n dateWithNewTime.setSeconds(newValue.getSeconds());\n dateWithNewTime.setMilliseconds(newValue.getMilliseconds());\n controller.field.onChange(dateWithNewTime.toISOString());\n setTimeStatusMessage('');\n setDateStatusMessage('');\n } else {\n if (!newValue) {\n setTimeValue('');\n if (field.validation?.required) {\n setTimeStatusMessage(\n t('cairo.fieldValidation.requiredField'),\n );\n timeRef.current.invalid = true;\n } else {\n setTimeStatusMessage('');\n timeRef.current.invalid = false;\n }\n if (!ref.current.invalid) {\n if (!dateValue) {\n controller.field.onChange(null);\n }\n }\n }\n }\n }}\n />\n </Cell>\n </Layout>\n </FormField>\n );\n};\n"],"mappings":"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","ignoreList":[]}
@@ -13,6 +13,7 @@ var _DateTime = require("./DateTime");
13
13
  var _Number = require("./Number");
14
14
  var _LongText = require("./LongText");
15
15
  var _Url = require("./Url");
16
+ var _ImageInput = require("./ImageInput");
16
17
  var _jsxFileName = "/home/builduser/work/73d19ce3378ce4dd/packages/auto-patterns/dist/cjs/components/AutoPatternsEntityPage/Fields/FormFieldInput.tsx";
17
18
  const EDITABLE_INPUT_ELEMENTS = exports.EDITABLE_INPUT_ELEMENTS = {
18
19
  SHORT_TEXT: _ShortText.ShortText,
@@ -21,12 +22,14 @@ const EDITABLE_INPUT_ELEMENTS = exports.EDITABLE_INPUT_ELEMENTS = {
21
22
  DATE: _DateInput.DateInput,
22
23
  DATETIME: _DateTime.DateTime,
23
24
  NUMBER: _Number.Number,
24
- URL: _Url.Url
25
+ URL: _Url.Url,
26
+ IMAGE: _ImageInput.ImageInput
25
27
  };
26
28
  const FormFieldInput = props => {
27
29
  var _pageState$entity;
28
30
  const {
29
- field
31
+ field,
32
+ inputRef
30
33
  } = props;
31
34
  const pageState = (0, _patterns.useEntityPageContext)();
32
35
  const controller = (0, _form.useController)({
@@ -34,7 +37,7 @@ const FormFieldInput = props => {
34
37
  control: pageState.form.control,
35
38
  defaultValue: (_pageState$entity = pageState.entity) == null ? void 0 : _pageState$entity[(field == null ? void 0 : field.id) ?? '']
36
39
  });
37
- if (!field || !EDITABLE_INPUT_ELEMENTS.hasOwnProperty(field.type) || !pageState || !pageState.entity) {
40
+ if (!EDITABLE_INPUT_ELEMENTS.hasOwnProperty(field.type) || !pageState) {
38
41
  return null;
39
42
  }
40
43
  const FieldInput = EDITABLE_INPUT_ELEMENTS[field.type];
@@ -42,10 +45,12 @@ const FormFieldInput = props => {
42
45
  field: field,
43
46
  value: controller.field.value,
44
47
  onChange: controller.field.onChange,
48
+ dataHook: `form-field-${field.id}`,
49
+ inputRef: inputRef,
45
50
  __self: void 0,
46
51
  __source: {
47
52
  fileName: _jsxFileName,
48
- lineNumber: 50,
53
+ lineNumber: 51,
49
54
  columnNumber: 5
50
55
  }
51
56
  });
@@ -1 +1 @@
1
- {"version":3,"names":["_react","_interopRequireDefault","require","_ShortText","_patterns","_form","_Checkbox","_DateInput","_DateTime","_Number","_LongText","_Url","_jsxFileName","EDITABLE_INPUT_ELEMENTS","exports","SHORT_TEXT","ShortText","LONG_TEXT","LongText","BOOLEAN","Checkbox","DATE","DateInput","DATETIME","DateTime","NUMBER","Number","URL","Url","FormFieldInput","props","_pageState$entity","field","pageState","useEntityPageContext","controller","useController","name","id","control","form","defaultValue","entity","hasOwnProperty","type","FieldInput","default","createElement","value","onChange","__self","__source","fileName","lineNumber","columnNumber"],"sources":["../../../../../src/components/AutoPatternsEntityPage/Fields/FormFieldInput.tsx"],"sourcesContent":["import React from 'react';\nimport { ShortText } from './ShortText';\nimport { useEntityPageContext } from '@wix/patterns';\nimport { useController } from '@wix/patterns/form';\nimport { Field, PatternsFieldType } from '../../../types';\nimport { Checkbox } from './Checkbox';\nimport { DateInput } from './DateInput';\nimport { DateTime } from './DateTime';\nimport { Number } from './Number';\nimport { LongText } from './LongText';\nimport { Url } from './Url';\n\nexport const EDITABLE_INPUT_ELEMENTS: Partial<\n Record<PatternsFieldType, React.ComponentType<any>>\n> = {\n SHORT_TEXT: ShortText,\n LONG_TEXT: LongText,\n BOOLEAN: Checkbox,\n DATE: DateInput,\n DATETIME: DateTime,\n NUMBER: Number,\n URL: Url,\n};\n\nexport interface FormFieldInputProps {\n field?: Field;\n}\n\nexport const FormFieldInput = (props: FormFieldInputProps) => {\n const { field } = props;\n\n const pageState = useEntityPageContext();\n const controller = useController({\n name: field?.id ?? '',\n control: pageState.form.control,\n defaultValue: (pageState.entity as any)?.[field?.id ?? ''],\n });\n\n if (\n !field ||\n !EDITABLE_INPUT_ELEMENTS.hasOwnProperty(field.type) ||\n !pageState ||\n !pageState.entity\n ) {\n return null;\n }\n const FieldInput = EDITABLE_INPUT_ELEMENTS[field.type]!;\n\n return (\n <FieldInput\n field={field}\n value={controller.field.value}\n onChange={controller.field.onChange}\n />\n );\n};\n"],"mappings":";;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,UAAA,GAAAD,OAAA;AACA,IAAAE,SAAA,GAAAF,OAAA;AACA,IAAAG,KAAA,GAAAH,OAAA;AAEA,IAAAI,SAAA,GAAAJ,OAAA;AACA,IAAAK,UAAA,GAAAL,OAAA;AACA,IAAAM,SAAA,GAAAN,OAAA;AACA,IAAAO,OAAA,GAAAP,OAAA;AACA,IAAAQ,SAAA,GAAAR,OAAA;AACA,IAAAS,IAAA,GAAAT,OAAA;AAA4B,IAAAU,YAAA;AAErB,MAAMC,uBAEZ,GAAAC,OAAA,CAAAD,uBAAA,GAAG;EACFE,UAAU,EAAEC,oBAAS;EACrBC,SAAS,EAAEC,kBAAQ;EACnBC,OAAO,EAAEC,kBAAQ;EACjBC,IAAI,EAAEC,oBAAS;EACfC,QAAQ,EAAEC,kBAAQ;EAClBC,MAAM,EAAEC,cAAM;EACdC,GAAG,EAAEC;AACP,CAAC;AAMM,MAAMC,cAAc,GAAIC,KAA0B,IAAK;EAAA,IAAAC,iBAAA;EAC5D,MAAM;IAAEC;EAAM,CAAC,GAAGF,KAAK;EAEvB,MAAMG,SAAS,GAAG,IAAAC,8BAAoB,EAAC,CAAC;EACxC,MAAMC,UAAU,GAAG,IAAAC,mBAAa,EAAC;IAC/BC,IAAI,EAAE,CAAAL,KAAK,oBAALA,KAAK,CAAEM,EAAE,KAAI,EAAE;IACrBC,OAAO,EAAEN,SAAS,CAACO,IAAI,CAACD,OAAO;IAC/BE,YAAY,GAAAV,iBAAA,GAAGE,SAAS,CAACS,MAAM,qBAAjBX,iBAAA,CAA4B,CAAAC,KAAK,oBAALA,KAAK,CAAEM,EAAE,KAAI,EAAE;EAC3D,CAAC,CAAC;EAEF,IACE,CAACN,KAAK,IACN,CAACnB,uBAAuB,CAAC8B,cAAc,CAACX,KAAK,CAACY,IAAI,CAAC,IACnD,CAACX,SAAS,IACV,CAACA,SAAS,CAACS,MAAM,EACjB;IACA,OAAO,IAAI;EACb;EACA,MAAMG,UAAU,GAAGhC,uBAAuB,CAACmB,KAAK,CAACY,IAAI,CAAE;EAEvD,oBACE5C,MAAA,CAAA8C,OAAA,CAAAC,aAAA,CAACF,UAAU;IACTb,KAAK,EAAEA,KAAM;IACbgB,KAAK,EAAEb,UAAU,CAACH,KAAK,CAACgB,KAAM;IAC9BC,QAAQ,EAAEd,UAAU,CAACH,KAAK,CAACiB,QAAS;IAAAC,MAAA;IAAAC,QAAA;MAAAC,QAAA,EAAAxC,YAAA;MAAAyC,UAAA;MAAAC,YAAA;IAAA;EAAA,CACrC,CAAC;AAEN,CAAC;AAACxC,OAAA,CAAAe,cAAA,GAAAA,cAAA","ignoreList":[]}
1
+ {"version":3,"names":["_react","_interopRequireDefault","require","_ShortText","_patterns","_form","_Checkbox","_DateInput","_DateTime","_Number","_LongText","_Url","_ImageInput","_jsxFileName","EDITABLE_INPUT_ELEMENTS","exports","SHORT_TEXT","ShortText","LONG_TEXT","LongText","BOOLEAN","Checkbox","DATE","DateInput","DATETIME","DateTime","NUMBER","Number","URL","Url","IMAGE","ImageInput","FormFieldInput","props","_pageState$entity","field","inputRef","pageState","useEntityPageContext","controller","useController","name","id","control","form","defaultValue","entity","hasOwnProperty","type","FieldInput","default","createElement","value","onChange","dataHook","__self","__source","fileName","lineNumber","columnNumber"],"sources":["../../../../../src/components/AutoPatternsEntityPage/Fields/FormFieldInput.tsx"],"sourcesContent":["import React from 'react';\nimport { ShortText } from './ShortText';\nimport { useEntityPageContext } from '@wix/patterns';\nimport { useController } from '@wix/patterns/form';\nimport { Field, PatternsFieldType } from '../../../types';\nimport { Checkbox } from './Checkbox';\nimport { DateInput } from './DateInput';\nimport { DateTime } from './DateTime';\nimport { Number } from './Number';\nimport { LongText } from './LongText';\nimport { Url } from './Url';\nimport { BaseInputProps } from './types';\nimport { ImageInput } from './ImageInput';\n\nexport const EDITABLE_INPUT_ELEMENTS: Partial<\n Record<PatternsFieldType, React.ComponentType<any>>\n> = {\n SHORT_TEXT: ShortText,\n LONG_TEXT: LongText,\n BOOLEAN: Checkbox,\n DATE: DateInput,\n DATETIME: DateTime,\n NUMBER: Number,\n URL: Url,\n IMAGE: ImageInput,\n};\n\nexport interface FormFieldInputProps {\n field: Field;\n inputRef?: BaseInputProps<any>['inputRef'];\n}\n\nexport const FormFieldInput = (props: FormFieldInputProps) => {\n const { field, inputRef } = props;\n\n const pageState = useEntityPageContext();\n\n const controller = useController({\n name: field?.id ?? '',\n control: pageState.form.control,\n defaultValue: (pageState.entity as any)?.[field?.id ?? ''],\n });\n\n if (!EDITABLE_INPUT_ELEMENTS.hasOwnProperty(field.type) || !pageState) {\n return null;\n }\n\n const FieldInput = EDITABLE_INPUT_ELEMENTS[field.type]!;\n\n return (\n <FieldInput\n field={field}\n value={controller.field.value}\n onChange={controller.field.onChange}\n dataHook={`form-field-${field.id}`}\n inputRef={inputRef}\n />\n );\n};\n"],"mappings":";;;;;AAAA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,UAAA,GAAAD,OAAA;AACA,IAAAE,SAAA,GAAAF,OAAA;AACA,IAAAG,KAAA,GAAAH,OAAA;AAEA,IAAAI,SAAA,GAAAJ,OAAA;AACA,IAAAK,UAAA,GAAAL,OAAA;AACA,IAAAM,SAAA,GAAAN,OAAA;AACA,IAAAO,OAAA,GAAAP,OAAA;AACA,IAAAQ,SAAA,GAAAR,OAAA;AACA,IAAAS,IAAA,GAAAT,OAAA;AAEA,IAAAU,WAAA,GAAAV,OAAA;AAA0C,IAAAW,YAAA;AAEnC,MAAMC,uBAEZ,GAAAC,OAAA,CAAAD,uBAAA,GAAG;EACFE,UAAU,EAAEC,oBAAS;EACrBC,SAAS,EAAEC,kBAAQ;EACnBC,OAAO,EAAEC,kBAAQ;EACjBC,IAAI,EAAEC,oBAAS;EACfC,QAAQ,EAAEC,kBAAQ;EAClBC,MAAM,EAAEC,cAAM;EACdC,GAAG,EAAEC,QAAG;EACRC,KAAK,EAAEC;AACT,CAAC;AAOM,MAAMC,cAAc,GAAIC,KAA0B,IAAK;EAAA,IAAAC,iBAAA;EAC5D,MAAM;IAAEC,KAAK;IAAEC;EAAS,CAAC,GAAGH,KAAK;EAEjC,MAAMI,SAAS,GAAG,IAAAC,8BAAoB,EAAC,CAAC;EAExC,MAAMC,UAAU,GAAG,IAAAC,mBAAa,EAAC;IAC/BC,IAAI,EAAE,CAAAN,KAAK,oBAALA,KAAK,CAAEO,EAAE,KAAI,EAAE;IACrBC,OAAO,EAAEN,SAAS,CAACO,IAAI,CAACD,OAAO;IAC/BE,YAAY,GAAAX,iBAAA,GAAGG,SAAS,CAACS,MAAM,qBAAjBZ,iBAAA,CAA4B,CAAAC,KAAK,oBAALA,KAAK,CAAEO,EAAE,KAAI,EAAE;EAC3D,CAAC,CAAC;EAEF,IAAI,CAAC5B,uBAAuB,CAACiC,cAAc,CAACZ,KAAK,CAACa,IAAI,CAAC,IAAI,CAACX,SAAS,EAAE;IACrE,OAAO,IAAI;EACb;EAEA,MAAMY,UAAU,GAAGnC,uBAAuB,CAACqB,KAAK,CAACa,IAAI,CAAE;EAEvD,oBACEhD,MAAA,CAAAkD,OAAA,CAAAC,aAAA,CAACF,UAAU;IACTd,KAAK,EAAEA,KAAM;IACbiB,KAAK,EAAEb,UAAU,CAACJ,KAAK,CAACiB,KAAM;IAC9BC,QAAQ,EAAEd,UAAU,CAACJ,KAAK,CAACkB,QAAS;IACpCC,QAAQ,EAAE,cAAcnB,KAAK,CAACO,EAAE,EAAG;IACnCN,QAAQ,EAAEA,QAAS;IAAAmB,MAAA;IAAAC,QAAA;MAAAC,QAAA,EAAA5C,YAAA;MAAA6C,UAAA;MAAAC,YAAA;IAAA;EAAA,CACpB,CAAC;AAEN,CAAC;AAAC5C,OAAA,CAAAiB,cAAA,GAAAA,cAAA","ignoreList":[]}