@wix/auto-patterns 1.6.0 → 1.8.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 (453) 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/AutoPatternsCollectionPageContent/AutoPatternsCollectionPageContent.js +3 -2
  4. package/dist/cjs/components/AutoPatternsCollectionPageContent/AutoPatternsCollectionPageContent.js.map +1 -1
  5. package/dist/cjs/components/AutoPatternsEntityPage/AutoPatternsEntityPage.js +242 -71
  6. package/dist/cjs/components/AutoPatternsEntityPage/AutoPatternsEntityPage.js.map +1 -1
  7. package/dist/cjs/components/AutoPatternsEntityPage/Fields/DateInput.js +28 -5
  8. package/dist/cjs/components/AutoPatternsEntityPage/Fields/DateInput.js.map +1 -1
  9. package/dist/cjs/components/AutoPatternsEntityPage/Fields/DateTime.js +45 -10
  10. package/dist/cjs/components/AutoPatternsEntityPage/Fields/DateTime.js.map +1 -1
  11. package/dist/cjs/components/AutoPatternsEntityPage/Fields/FormFieldInput.js +7 -5
  12. package/dist/cjs/components/AutoPatternsEntityPage/Fields/FormFieldInput.js.map +1 -1
  13. package/dist/cjs/components/AutoPatternsEntityPage/Fields/LongText.js +16 -5
  14. package/dist/cjs/components/AutoPatternsEntityPage/Fields/LongText.js.map +1 -1
  15. package/dist/cjs/components/AutoPatternsEntityPage/Fields/Number.js +43 -5
  16. package/dist/cjs/components/AutoPatternsEntityPage/Fields/Number.js.map +1 -1
  17. package/dist/cjs/components/AutoPatternsEntityPage/Fields/ShortText.js +30 -5
  18. package/dist/cjs/components/AutoPatternsEntityPage/Fields/ShortText.js.map +1 -1
  19. package/dist/cjs/components/AutoPatternsEntityPage/Fields/Url.js +27 -9
  20. package/dist/cjs/components/AutoPatternsEntityPage/Fields/Url.js.map +1 -1
  21. package/dist/cjs/components/AutoPatternsEntityPage/Fields/types.js.map +1 -1
  22. package/dist/cjs/components/AutoPatternsEntityPage/Fields/utils/validateTextLength.js +39 -0
  23. package/dist/cjs/components/AutoPatternsEntityPage/Fields/utils/validateTextLength.js.map +1 -0
  24. package/dist/cjs/components/AutoPatternsGrid/AutoPatternsGrid.js +8 -10
  25. package/dist/cjs/components/AutoPatternsGrid/AutoPatternsGrid.js.map +1 -1
  26. package/dist/cjs/components/AutoPatternsRoute/AutoPatternsRoutes.js +84 -0
  27. package/dist/cjs/components/AutoPatternsRoute/AutoPatternsRoutes.js.map +1 -0
  28. package/dist/cjs/components/AutoPatternsTable/AutoPatternsTable.js +8 -10
  29. package/dist/cjs/components/AutoPatternsTable/AutoPatternsTable.js.map +1 -1
  30. package/dist/cjs/components/AutoPatternsTable/AutoPatternsTableContent.js +7 -8
  31. package/dist/cjs/components/AutoPatternsTable/AutoPatternsTableContent.js.map +1 -1
  32. package/dist/cjs/components/DynamicIcon.js +71 -0
  33. package/dist/cjs/components/DynamicIcon.js.map +1 -0
  34. package/dist/cjs/components/ModalRenderer.js +40 -0
  35. package/dist/cjs/components/ModalRenderer.js.map +1 -0
  36. package/dist/cjs/components/filters/DynamicCollectionFilter.js +63 -0
  37. package/dist/cjs/components/filters/DynamicCollectionFilter.js.map +1 -0
  38. package/dist/cjs/components/filters/StaticCollectionFilter.js +31 -0
  39. package/dist/cjs/components/filters/StaticCollectionFilter.js.map +1 -0
  40. package/dist/cjs/components/filters/index.js +9 -0
  41. package/dist/cjs/components/filters/index.js.map +1 -0
  42. package/dist/cjs/components/modals/actions/BulkDeleteModal.js +95 -0
  43. package/dist/cjs/components/modals/actions/BulkDeleteModal.js.map +1 -0
  44. package/dist/cjs/components/modals/actions/EditModal.js +136 -0
  45. package/dist/cjs/components/modals/actions/EditModal.js.map +1 -0
  46. package/dist/cjs/components/modals/actions/index.js +16 -0
  47. package/dist/cjs/components/modals/actions/index.js.map +1 -0
  48. package/dist/cjs/{collectionData/CollectionData.js → components/modals/actions/types.js} +1 -1
  49. package/dist/cjs/components/modals/actions/types.js.map +1 -0
  50. package/dist/cjs/components/modals/index.js +10 -0
  51. package/dist/cjs/components/modals/index.js.map +1 -0
  52. package/dist/cjs/{collectionData/cms/CmsCollectionData.js → dataSourceAdapters/cms/cmsAdapter.js} +57 -18
  53. package/dist/cjs/dataSourceAdapters/cms/cmsAdapter.js.map +1 -0
  54. package/dist/cjs/{collectionData → dataSourceAdapters}/cms/filterUtils.js +18 -11
  55. package/dist/cjs/dataSourceAdapters/cms/filterUtils.js.map +1 -0
  56. package/dist/cjs/dataSourceAdapters/cms/sortUtils.js.map +1 -0
  57. package/dist/cjs/dataSourceAdapters/constants.js.map +1 -0
  58. package/dist/cjs/dataSourceAdapters/factory.js +34 -0
  59. package/dist/cjs/dataSourceAdapters/factory.js.map +1 -0
  60. package/dist/cjs/exports/form.js +10 -0
  61. package/dist/cjs/exports/form.js.map +1 -0
  62. package/dist/cjs/hooks/index.js +12 -0
  63. package/dist/cjs/hooks/index.js.map +1 -1
  64. package/dist/cjs/hooks/useActionCell.js +109 -0
  65. package/dist/cjs/hooks/useActionCell.js.map +1 -0
  66. package/dist/cjs/hooks/useAutoPatternsOptimisticActions.js +15 -0
  67. package/dist/cjs/hooks/useAutoPatternsOptimisticActions.js.map +1 -0
  68. package/dist/cjs/hooks/useBulkActionToolbar.js +88 -0
  69. package/dist/cjs/hooks/useBulkActionToolbar.js.map +1 -0
  70. package/dist/cjs/hooks/useColumns.js +90 -37
  71. package/dist/cjs/hooks/useColumns.js.map +1 -1
  72. package/dist/cjs/hooks/useCommonCollectionFeatures.js +27 -35
  73. package/dist/cjs/hooks/useCommonCollectionFeatures.js.map +1 -1
  74. package/dist/cjs/hooks/useFetchData.js +33 -9
  75. package/dist/cjs/hooks/useFetchData.js.map +1 -1
  76. package/dist/cjs/hooks/useFilters.js +83 -92
  77. package/dist/cjs/hooks/useFilters.js.map +1 -1
  78. package/dist/cjs/hooks/useGridFeatures.js +31 -21
  79. package/dist/cjs/hooks/useGridFeatures.js.map +1 -1
  80. package/dist/cjs/hooks/useNavigationUtils.js +51 -0
  81. package/dist/cjs/hooks/useNavigationUtils.js.map +1 -0
  82. package/dist/cjs/hooks/usePagePath.js +35 -0
  83. package/dist/cjs/hooks/usePagePath.js.map +1 -0
  84. package/dist/cjs/hooks/useSharedDataForActions.js +44 -0
  85. package/dist/cjs/hooks/useSharedDataForActions.js.map +1 -0
  86. package/dist/cjs/hooks/useTableFeatures.js +23 -15
  87. package/dist/cjs/hooks/useTableFeatures.js.map +1 -1
  88. package/dist/cjs/providers/AppConfigContext.js +33 -0
  89. package/dist/cjs/providers/AppConfigContext.js.map +1 -0
  90. package/dist/cjs/providers/ModalContext.js +58 -0
  91. package/dist/cjs/providers/ModalContext.js.map +1 -0
  92. package/dist/cjs/providers/PatternsWizardOverridesContext.js +1 -1
  93. package/dist/cjs/providers/PatternsWizardOverridesContext.js.map +1 -1
  94. package/dist/cjs/providers/RootAppProvider.js +40 -0
  95. package/dist/cjs/providers/RootAppProvider.js.map +1 -0
  96. package/dist/cjs/providers/SchemaContext.js +49 -5
  97. package/dist/cjs/providers/SchemaContext.js.map +1 -1
  98. package/dist/cjs/providers/SchemaRegistryContext.js +49 -0
  99. package/dist/cjs/providers/SchemaRegistryContext.js.map +1 -0
  100. package/dist/cjs/providers/index.js +22 -4
  101. package/dist/cjs/providers/index.js.map +1 -1
  102. package/dist/cjs/types/CollectionPageConfig.js.map +1 -1
  103. package/dist/cjs/types/EntityPageConfig.js.map +1 -1
  104. package/dist/cjs/types/actions/actionCell.js +4 -0
  105. package/dist/cjs/types/actions/actionCell.js.map +1 -0
  106. package/dist/cjs/types/actions/base.js +4 -0
  107. package/dist/cjs/types/actions/base.js.map +1 -0
  108. package/dist/cjs/types/actions/bulkActions.js +4 -0
  109. package/dist/cjs/types/actions/bulkActions.js.map +1 -0
  110. package/dist/cjs/types/actions/index.js +22 -0
  111. package/dist/cjs/types/actions/index.js.map +1 -0
  112. package/dist/cjs/types/index.js +12 -0
  113. package/dist/cjs/types/index.js.map +1 -1
  114. package/dist/cjs/types/types.js.map +1 -1
  115. package/dist/cjs/utils/actions/bulkDeleteAction.js +26 -0
  116. package/dist/cjs/utils/actions/bulkDeleteAction.js.map +1 -0
  117. package/dist/cjs/utils/actions/customAction.js +23 -0
  118. package/dist/cjs/utils/actions/customAction.js.map +1 -0
  119. package/dist/cjs/utils/actions/customModalAction.js +22 -0
  120. package/dist/cjs/utils/actions/customModalAction.js.map +1 -0
  121. package/dist/cjs/utils/actions/deleteAction.js +61 -0
  122. package/dist/cjs/utils/actions/deleteAction.js.map +1 -0
  123. package/dist/cjs/utils/actions/index.js +40 -0
  124. package/dist/cjs/utils/actions/index.js.map +1 -0
  125. package/dist/cjs/utils/actions/resolveAction.js +27 -0
  126. package/dist/cjs/utils/actions/resolveAction.js.map +1 -0
  127. package/dist/cjs/utils/actions/types.js +4 -0
  128. package/dist/cjs/utils/actions/types.js.map +1 -0
  129. package/dist/cjs/utils/actions/updateAction.js +46 -0
  130. package/dist/cjs/utils/actions/updateAction.js.map +1 -0
  131. package/dist/cjs/utils/filterCreators.js +137 -0
  132. package/dist/cjs/utils/filterCreators.js.map +1 -0
  133. package/dist/cjs/utils/media/getImageUrl.js +22 -0
  134. package/dist/cjs/utils/media/getImageUrl.js.map +1 -0
  135. package/dist/esm/components/AutoPatternsApp/AutoPatternsApp.js +6 -14
  136. package/dist/esm/components/AutoPatternsApp/AutoPatternsApp.js.map +1 -1
  137. package/dist/esm/components/AutoPatternsCollectionPageContent/AutoPatternsCollectionPageContent.js +1 -0
  138. package/dist/esm/components/AutoPatternsCollectionPageContent/AutoPatternsCollectionPageContent.js.map +1 -1
  139. package/dist/esm/components/AutoPatternsEntityPage/AutoPatternsEntityPage.js +155 -34
  140. package/dist/esm/components/AutoPatternsEntityPage/AutoPatternsEntityPage.js.map +1 -1
  141. package/dist/esm/components/AutoPatternsEntityPage/Fields/DateInput.js +27 -4
  142. package/dist/esm/components/AutoPatternsEntityPage/Fields/DateInput.js.map +1 -1
  143. package/dist/esm/components/AutoPatternsEntityPage/Fields/DateTime.js +41 -6
  144. package/dist/esm/components/AutoPatternsEntityPage/Fields/DateTime.js.map +1 -1
  145. package/dist/esm/components/AutoPatternsEntityPage/Fields/FormFieldInput.js +7 -5
  146. package/dist/esm/components/AutoPatternsEntityPage/Fields/FormFieldInput.js.map +1 -1
  147. package/dist/esm/components/AutoPatternsEntityPage/Fields/LongText.js +14 -4
  148. package/dist/esm/components/AutoPatternsEntityPage/Fields/LongText.js.map +1 -1
  149. package/dist/esm/components/AutoPatternsEntityPage/Fields/Number.js +41 -4
  150. package/dist/esm/components/AutoPatternsEntityPage/Fields/Number.js.map +1 -1
  151. package/dist/esm/components/AutoPatternsEntityPage/Fields/ShortText.js +28 -4
  152. package/dist/esm/components/AutoPatternsEntityPage/Fields/ShortText.js.map +1 -1
  153. package/dist/esm/components/AutoPatternsEntityPage/Fields/Url.js +23 -5
  154. package/dist/esm/components/AutoPatternsEntityPage/Fields/Url.js.map +1 -1
  155. package/dist/esm/components/AutoPatternsEntityPage/Fields/types.js.map +1 -1
  156. package/dist/esm/components/AutoPatternsEntityPage/Fields/utils/validateTextLength.js +35 -0
  157. package/dist/esm/components/AutoPatternsEntityPage/Fields/utils/validateTextLength.js.map +1 -0
  158. package/dist/esm/components/AutoPatternsGrid/AutoPatternsGrid.js +5 -6
  159. package/dist/esm/components/AutoPatternsGrid/AutoPatternsGrid.js.map +1 -1
  160. package/dist/esm/components/AutoPatternsRoute/AutoPatternsRoutes.js +47 -0
  161. package/dist/esm/components/AutoPatternsRoute/AutoPatternsRoutes.js.map +1 -0
  162. package/dist/esm/components/AutoPatternsTable/AutoPatternsTable.js +5 -6
  163. package/dist/esm/components/AutoPatternsTable/AutoPatternsTable.js.map +1 -1
  164. package/dist/esm/components/AutoPatternsTable/AutoPatternsTableContent.js +9 -10
  165. package/dist/esm/components/AutoPatternsTable/AutoPatternsTableContent.js.map +1 -1
  166. package/dist/esm/components/DynamicIcon.js +33 -0
  167. package/dist/esm/components/DynamicIcon.js.map +1 -0
  168. package/dist/esm/components/ModalRenderer.js +25 -0
  169. package/dist/esm/components/ModalRenderer.js.map +1 -0
  170. package/dist/esm/components/filters/DynamicCollectionFilter.js +50 -0
  171. package/dist/esm/components/filters/DynamicCollectionFilter.js.map +1 -0
  172. package/dist/esm/components/filters/StaticCollectionFilter.js +18 -0
  173. package/dist/esm/components/filters/StaticCollectionFilter.js.map +1 -0
  174. package/dist/esm/components/filters/index.js +3 -0
  175. package/dist/esm/components/filters/index.js.map +1 -0
  176. package/dist/esm/components/modals/actions/BulkDeleteModal.js +57 -0
  177. package/dist/esm/components/modals/actions/BulkDeleteModal.js.map +1 -0
  178. package/dist/esm/components/modals/actions/EditModal.js +78 -0
  179. package/dist/esm/components/modals/actions/EditModal.js.map +1 -0
  180. package/dist/esm/components/modals/actions/index.js +3 -0
  181. package/dist/esm/components/modals/actions/index.js.map +1 -0
  182. package/dist/esm/components/modals/actions/types.js +2 -0
  183. package/dist/esm/components/modals/actions/types.js.map +1 -0
  184. package/dist/esm/components/modals/index.js +2 -0
  185. package/dist/esm/components/modals/index.js.map +1 -0
  186. package/dist/esm/dataSourceAdapters/cms/cmsAdapter.js +131 -0
  187. package/dist/esm/dataSourceAdapters/cms/cmsAdapter.js.map +1 -0
  188. package/dist/esm/{collectionData → dataSourceAdapters}/cms/filterUtils.js +18 -11
  189. package/dist/esm/dataSourceAdapters/cms/filterUtils.js.map +1 -0
  190. package/dist/esm/dataSourceAdapters/cms/sortUtils.js.map +1 -0
  191. package/dist/esm/dataSourceAdapters/constants.js.map +1 -0
  192. package/dist/esm/dataSourceAdapters/factory.js +30 -0
  193. package/dist/esm/dataSourceAdapters/factory.js.map +1 -0
  194. package/dist/esm/exports/form.js +2 -0
  195. package/dist/esm/exports/form.js.map +1 -0
  196. package/dist/esm/hooks/index.js +2 -0
  197. package/dist/esm/hooks/index.js.map +1 -1
  198. package/dist/esm/hooks/useActionCell.js +105 -0
  199. package/dist/esm/hooks/useActionCell.js.map +1 -0
  200. package/dist/esm/hooks/useAutoPatternsOptimisticActions.js +13 -0
  201. package/dist/esm/hooks/useAutoPatternsOptimisticActions.js.map +1 -0
  202. package/dist/esm/hooks/useBulkActionToolbar.js +75 -0
  203. package/dist/esm/hooks/useBulkActionToolbar.js.map +1 -0
  204. package/dist/esm/hooks/useColumns.js +70 -38
  205. package/dist/esm/hooks/useColumns.js.map +1 -1
  206. package/dist/esm/hooks/useCommonCollectionFeatures.js +23 -24
  207. package/dist/esm/hooks/useCommonCollectionFeatures.js.map +1 -1
  208. package/dist/esm/hooks/useFetchData.js +34 -10
  209. package/dist/esm/hooks/useFetchData.js.map +1 -1
  210. package/dist/esm/hooks/useFilters.js +75 -85
  211. package/dist/esm/hooks/useFilters.js.map +1 -1
  212. package/dist/esm/hooks/useGridFeatures.js +31 -21
  213. package/dist/esm/hooks/useGridFeatures.js.map +1 -1
  214. package/dist/esm/hooks/useNavigationUtils.js +47 -0
  215. package/dist/esm/hooks/useNavigationUtils.js.map +1 -0
  216. package/dist/esm/hooks/usePagePath.js +30 -0
  217. package/dist/esm/hooks/usePagePath.js.map +1 -0
  218. package/dist/esm/hooks/useSharedDataForActions.js +40 -0
  219. package/dist/esm/hooks/useSharedDataForActions.js.map +1 -0
  220. package/dist/esm/hooks/useTableFeatures.js +20 -13
  221. package/dist/esm/hooks/useTableFeatures.js.map +1 -1
  222. package/dist/esm/providers/AppConfigContext.js +19 -0
  223. package/dist/esm/providers/AppConfigContext.js.map +1 -0
  224. package/dist/esm/providers/ModalContext.js +37 -0
  225. package/dist/esm/providers/ModalContext.js.map +1 -0
  226. package/dist/esm/providers/PatternsWizardOverridesContext.js.map +1 -1
  227. package/dist/esm/providers/RootAppProvider.js +14 -0
  228. package/dist/esm/providers/RootAppProvider.js.map +1 -0
  229. package/dist/esm/providers/SchemaContext.js +48 -4
  230. package/dist/esm/providers/SchemaContext.js.map +1 -1
  231. package/dist/esm/providers/SchemaRegistryContext.js +35 -0
  232. package/dist/esm/providers/SchemaRegistryContext.js.map +1 -0
  233. package/dist/esm/providers/index.js +4 -1
  234. package/dist/esm/providers/index.js.map +1 -1
  235. package/dist/esm/types/CollectionPageConfig.js.map +1 -1
  236. package/dist/esm/types/EntityPageConfig.js.map +1 -1
  237. package/dist/esm/types/actions/actionCell.js +2 -0
  238. package/dist/esm/types/actions/actionCell.js.map +1 -0
  239. package/dist/esm/types/actions/base.js +2 -0
  240. package/dist/esm/types/actions/base.js.map +1 -0
  241. package/dist/esm/types/actions/bulkActions.js +2 -0
  242. package/dist/esm/types/actions/bulkActions.js.map +1 -0
  243. package/dist/esm/types/actions/index.js +4 -0
  244. package/dist/esm/types/actions/index.js.map +1 -0
  245. package/dist/esm/types/index.js +2 -0
  246. package/dist/esm/types/index.js.map +1 -1
  247. package/dist/esm/types/types.js.map +1 -1
  248. package/dist/esm/utils/actions/bulkDeleteAction.js +21 -0
  249. package/dist/esm/utils/actions/bulkDeleteAction.js.map +1 -0
  250. package/dist/esm/utils/actions/customAction.js +18 -0
  251. package/dist/esm/utils/actions/customAction.js.map +1 -0
  252. package/dist/esm/utils/actions/customModalAction.js +17 -0
  253. package/dist/esm/utils/actions/customModalAction.js.map +1 -0
  254. package/dist/esm/utils/actions/deleteAction.js +56 -0
  255. package/dist/esm/utils/actions/deleteAction.js.map +1 -0
  256. package/dist/esm/utils/actions/index.js +8 -0
  257. package/dist/esm/utils/actions/index.js.map +1 -0
  258. package/dist/esm/utils/actions/resolveAction.js +13 -0
  259. package/dist/esm/utils/actions/resolveAction.js.map +1 -0
  260. package/dist/esm/utils/actions/types.js +2 -0
  261. package/dist/esm/utils/actions/types.js.map +1 -0
  262. package/dist/esm/utils/actions/updateAction.js +41 -0
  263. package/dist/esm/utils/actions/updateAction.js.map +1 -0
  264. package/dist/esm/utils/filterCreators.js +139 -0
  265. package/dist/esm/utils/filterCreators.js.map +1 -0
  266. package/dist/esm/utils/media/getImageUrl.js +16 -0
  267. package/dist/esm/utils/media/getImageUrl.js.map +1 -0
  268. package/dist/types/components/AutoPatternsApp/AutoPatternsApp.d.ts.map +1 -1
  269. package/dist/types/components/AutoPatternsCollectionPageContent/AutoPatternsCollectionPageContent.d.ts.map +1 -1
  270. package/dist/types/components/AutoPatternsEntityPage/AutoPatternsEntityPage.d.ts.map +1 -1
  271. package/dist/types/components/AutoPatternsEntityPage/Fields/Checkbox.d.ts.map +1 -1
  272. package/dist/types/components/AutoPatternsEntityPage/Fields/DateInput.d.ts.map +1 -1
  273. package/dist/types/components/AutoPatternsEntityPage/Fields/DateTime.d.ts.map +1 -1
  274. package/dist/types/components/AutoPatternsEntityPage/Fields/FormFieldInput.d.ts +3 -1
  275. package/dist/types/components/AutoPatternsEntityPage/Fields/FormFieldInput.d.ts.map +1 -1
  276. package/dist/types/components/AutoPatternsEntityPage/Fields/LongText.d.ts.map +1 -1
  277. package/dist/types/components/AutoPatternsEntityPage/Fields/Number.d.ts.map +1 -1
  278. package/dist/types/components/AutoPatternsEntityPage/Fields/ShortText.d.ts.map +1 -1
  279. package/dist/types/components/AutoPatternsEntityPage/Fields/Url.d.ts.map +1 -1
  280. package/dist/types/components/AutoPatternsEntityPage/Fields/types.d.ts +2 -0
  281. package/dist/types/components/AutoPatternsEntityPage/Fields/types.d.ts.map +1 -1
  282. package/dist/types/components/AutoPatternsEntityPage/Fields/utils/dates.d.ts.map +1 -1
  283. package/dist/types/components/AutoPatternsEntityPage/Fields/utils/validateTextLength.d.ts +12 -0
  284. package/dist/types/components/AutoPatternsEntityPage/Fields/utils/validateTextLength.d.ts.map +1 -0
  285. package/dist/types/components/AutoPatternsGrid/AutoPatternsGrid.d.ts.map +1 -1
  286. package/dist/types/components/AutoPatternsGrid/AutoPatternsGridContent.d.ts.map +1 -1
  287. package/dist/types/components/AutoPatternsRoute/AutoPatternsPage.d.ts.map +1 -1
  288. package/dist/types/components/AutoPatternsRoute/AutoPatternsRoutes.d.ts +6 -0
  289. package/dist/types/components/AutoPatternsRoute/AutoPatternsRoutes.d.ts.map +1 -0
  290. package/dist/types/components/AutoPatternsTable/AutoPatternsTable.d.ts.map +1 -1
  291. package/dist/types/components/AutoPatternsTable/AutoPatternsTableContent.d.ts.map +1 -1
  292. package/dist/types/components/DynamicIcon.d.ts +6 -0
  293. package/dist/types/components/DynamicIcon.d.ts.map +1 -0
  294. package/dist/types/components/ModalRenderer.d.ts +3 -0
  295. package/dist/types/components/ModalRenderer.d.ts.map +1 -0
  296. package/dist/types/components/filters/DynamicCollectionFilter.d.ts +12 -0
  297. package/dist/types/components/filters/DynamicCollectionFilter.d.ts.map +1 -0
  298. package/dist/types/components/filters/StaticCollectionFilter.d.ts +14 -0
  299. package/dist/types/components/filters/StaticCollectionFilter.d.ts.map +1 -0
  300. package/dist/types/components/filters/index.d.ts +3 -0
  301. package/dist/types/components/filters/index.d.ts.map +1 -0
  302. package/dist/types/components/modals/actions/BulkDeleteModal.d.ts +9 -0
  303. package/dist/types/components/modals/actions/BulkDeleteModal.d.ts.map +1 -0
  304. package/dist/types/components/modals/actions/EditModal.d.ts +11 -0
  305. package/dist/types/components/modals/actions/EditModal.d.ts.map +1 -0
  306. package/dist/types/components/modals/actions/index.d.ts +3 -0
  307. package/dist/types/components/modals/actions/index.d.ts.map +1 -0
  308. package/dist/types/components/modals/actions/types.d.ts +7 -0
  309. package/dist/types/components/modals/actions/types.d.ts.map +1 -0
  310. package/dist/types/components/modals/index.d.ts +2 -0
  311. package/dist/types/components/modals/index.d.ts.map +1 -0
  312. package/dist/types/dataSourceAdapters/cms/cmsAdapter.d.ts +14 -0
  313. package/dist/types/dataSourceAdapters/cms/cmsAdapter.d.ts.map +1 -0
  314. package/dist/types/{collectionData → dataSourceAdapters}/cms/filterUtils.d.ts +3 -2
  315. package/dist/types/dataSourceAdapters/cms/filterUtils.d.ts.map +1 -0
  316. package/dist/types/dataSourceAdapters/cms/sortUtils.d.ts.map +1 -0
  317. package/dist/types/dataSourceAdapters/constants.d.ts.map +1 -0
  318. package/dist/types/dataSourceAdapters/factory.d.ts +13 -0
  319. package/dist/types/dataSourceAdapters/factory.d.ts.map +1 -0
  320. package/dist/types/exports/form.d.ts +2 -0
  321. package/dist/types/exports/form.d.ts.map +1 -0
  322. package/dist/types/hooks/index.d.ts +2 -0
  323. package/dist/types/hooks/index.d.ts.map +1 -1
  324. package/dist/types/hooks/useActionCell.d.ts +11 -0
  325. package/dist/types/hooks/useActionCell.d.ts.map +1 -0
  326. package/dist/types/hooks/useAutoPatternsOptimisticActions.d.ts +3 -0
  327. package/dist/types/hooks/useAutoPatternsOptimisticActions.d.ts.map +1 -0
  328. package/dist/types/hooks/useBulkActionToolbar.d.ts +11 -0
  329. package/dist/types/hooks/useBulkActionToolbar.d.ts.map +1 -0
  330. package/dist/types/hooks/useColumns.d.ts.map +1 -1
  331. package/dist/types/hooks/useCommonCollectionFeatures.d.ts +9 -9
  332. package/dist/types/hooks/useCommonCollectionFeatures.d.ts.map +1 -1
  333. package/dist/types/hooks/useEmptyStates.d.ts.map +1 -1
  334. package/dist/types/hooks/useFetchData.d.ts +6 -2
  335. package/dist/types/hooks/useFetchData.d.ts.map +1 -1
  336. package/dist/types/hooks/useFilters.d.ts +5 -1
  337. package/dist/types/hooks/useFilters.d.ts.map +1 -1
  338. package/dist/types/hooks/useGridFeatures.d.ts +2 -8
  339. package/dist/types/hooks/useGridFeatures.d.ts.map +1 -1
  340. package/dist/types/hooks/useNavigationUtils.d.ts +10 -0
  341. package/dist/types/hooks/useNavigationUtils.d.ts.map +1 -0
  342. package/dist/types/hooks/usePagePath.d.ts +5 -0
  343. package/dist/types/hooks/usePagePath.d.ts.map +1 -0
  344. package/dist/types/hooks/useSharedDataForActions.d.ts +8 -0
  345. package/dist/types/hooks/useSharedDataForActions.d.ts.map +1 -0
  346. package/dist/types/hooks/useTableFeatures.d.ts +3 -7
  347. package/dist/types/hooks/useTableFeatures.d.ts.map +1 -1
  348. package/dist/types/providers/AppConfigContext.d.ts +8 -0
  349. package/dist/types/providers/AppConfigContext.d.ts.map +1 -0
  350. package/dist/types/providers/ModalContext.d.ts +20 -0
  351. package/dist/types/providers/ModalContext.d.ts.map +1 -0
  352. package/dist/types/providers/PatternsWizardOverridesContext.d.ts +5 -2
  353. package/dist/types/providers/PatternsWizardOverridesContext.d.ts.map +1 -1
  354. package/dist/types/providers/RootAppProvider.d.ts +7 -0
  355. package/dist/types/providers/RootAppProvider.d.ts.map +1 -0
  356. package/dist/types/providers/SchemaContext.d.ts.map +1 -1
  357. package/dist/types/providers/SchemaRegistryContext.d.ts +13 -0
  358. package/dist/types/providers/SchemaRegistryContext.d.ts.map +1 -0
  359. package/dist/types/providers/index.d.ts +4 -1
  360. package/dist/types/providers/index.d.ts.map +1 -1
  361. package/dist/types/types/CollectionPageConfig.d.ts +33 -32
  362. package/dist/types/types/CollectionPageConfig.d.ts.map +1 -1
  363. package/dist/types/types/EntityPageConfig.d.ts +51 -2
  364. package/dist/types/types/EntityPageConfig.d.ts.map +1 -1
  365. package/dist/types/types/actions/actionCell.d.ts +24 -0
  366. package/dist/types/types/actions/actionCell.d.ts.map +1 -0
  367. package/dist/types/types/actions/base.d.ts +93 -0
  368. package/dist/types/types/actions/base.d.ts.map +1 -0
  369. package/dist/types/types/actions/bulkActions.d.ts +28 -0
  370. package/dist/types/types/actions/bulkActions.d.ts.map +1 -0
  371. package/dist/types/types/actions/index.d.ts +4 -0
  372. package/dist/types/types/actions/index.d.ts.map +1 -0
  373. package/dist/types/types/index.d.ts +2 -0
  374. package/dist/types/types/index.d.ts.map +1 -1
  375. package/dist/types/types/types.d.ts +48 -10
  376. package/dist/types/types/types.d.ts.map +1 -1
  377. package/dist/types/utils/actions/bulkDeleteAction.d.ts +7 -0
  378. package/dist/types/utils/actions/bulkDeleteAction.d.ts.map +1 -0
  379. package/dist/types/utils/actions/customAction.d.ts +3 -0
  380. package/dist/types/utils/actions/customAction.d.ts.map +1 -0
  381. package/dist/types/utils/actions/customModalAction.d.ts +5 -0
  382. package/dist/types/utils/actions/customModalAction.d.ts.map +1 -0
  383. package/dist/types/utils/actions/deleteAction.d.ts +7 -0
  384. package/dist/types/utils/actions/deleteAction.d.ts.map +1 -0
  385. package/dist/types/utils/actions/index.d.ts +8 -0
  386. package/dist/types/utils/actions/index.d.ts.map +1 -0
  387. package/dist/types/utils/actions/resolveAction.d.ts +11 -0
  388. package/dist/types/utils/actions/resolveAction.d.ts.map +1 -0
  389. package/dist/types/utils/actions/types.d.ts +65 -0
  390. package/dist/types/utils/actions/types.d.ts.map +1 -0
  391. package/dist/types/utils/actions/updateAction.d.ts +7 -0
  392. package/dist/types/utils/actions/updateAction.d.ts.map +1 -0
  393. package/dist/types/utils/filterCreators.d.ts +48 -0
  394. package/dist/types/utils/filterCreators.d.ts.map +1 -0
  395. package/dist/types/utils/media/getImageUrl.d.ts +3 -0
  396. package/dist/types/utils/media/getImageUrl.d.ts.map +1 -0
  397. package/form/package.json +6 -0
  398. package/package.json +10 -8
  399. package/dist/cjs/collectionData/CollectionData.js.map +0 -1
  400. package/dist/cjs/collectionData/CollectionDataFactory.js +0 -12
  401. package/dist/cjs/collectionData/CollectionDataFactory.js.map +0 -1
  402. package/dist/cjs/collectionData/SchemaFactory.js +0 -12
  403. package/dist/cjs/collectionData/SchemaFactory.js.map +0 -1
  404. package/dist/cjs/collectionData/cms/CmsCollectionData.js.map +0 -1
  405. package/dist/cjs/collectionData/cms/filterUtils.js.map +0 -1
  406. package/dist/cjs/collectionData/cms/sortUtils.js.map +0 -1
  407. package/dist/cjs/collectionData/constants.js.map +0 -1
  408. package/dist/cjs/collectionData/index.js +0 -10
  409. package/dist/cjs/collectionData/index.js.map +0 -1
  410. package/dist/cjs/providers/CollectionDataContext.js +0 -44
  411. package/dist/cjs/providers/CollectionDataContext.js.map +0 -1
  412. package/dist/cjs/utils/filters.js +0 -53
  413. package/dist/cjs/utils/filters.js.map +0 -1
  414. package/dist/esm/collectionData/CollectionData.js +0 -2
  415. package/dist/esm/collectionData/CollectionData.js.map +0 -1
  416. package/dist/esm/collectionData/CollectionDataFactory.js +0 -8
  417. package/dist/esm/collectionData/CollectionDataFactory.js.map +0 -1
  418. package/dist/esm/collectionData/SchemaFactory.js +0 -8
  419. package/dist/esm/collectionData/SchemaFactory.js.map +0 -1
  420. package/dist/esm/collectionData/cms/CmsCollectionData.js +0 -91
  421. package/dist/esm/collectionData/cms/CmsCollectionData.js.map +0 -1
  422. package/dist/esm/collectionData/cms/filterUtils.js.map +0 -1
  423. package/dist/esm/collectionData/cms/sortUtils.js.map +0 -1
  424. package/dist/esm/collectionData/constants.js.map +0 -1
  425. package/dist/esm/collectionData/index.js +0 -2
  426. package/dist/esm/collectionData/index.js.map +0 -1
  427. package/dist/esm/providers/CollectionDataContext.js +0 -30
  428. package/dist/esm/providers/CollectionDataContext.js.map +0 -1
  429. package/dist/esm/utils/filters.js +0 -49
  430. package/dist/esm/utils/filters.js.map +0 -1
  431. package/dist/types/collectionData/CollectionData.d.ts +0 -9
  432. package/dist/types/collectionData/CollectionData.d.ts.map +0 -1
  433. package/dist/types/collectionData/CollectionDataFactory.d.ts +0 -4
  434. package/dist/types/collectionData/CollectionDataFactory.d.ts.map +0 -1
  435. package/dist/types/collectionData/SchemaFactory.d.ts +0 -3
  436. package/dist/types/collectionData/SchemaFactory.d.ts.map +0 -1
  437. package/dist/types/collectionData/cms/CmsCollectionData.d.ts +0 -8
  438. package/dist/types/collectionData/cms/CmsCollectionData.d.ts.map +0 -1
  439. package/dist/types/collectionData/cms/filterUtils.d.ts.map +0 -1
  440. package/dist/types/collectionData/cms/sortUtils.d.ts.map +0 -1
  441. package/dist/types/collectionData/constants.d.ts.map +0 -1
  442. package/dist/types/collectionData/index.d.ts +0 -2
  443. package/dist/types/collectionData/index.d.ts.map +0 -1
  444. package/dist/types/providers/CollectionDataContext.d.ts +0 -12
  445. package/dist/types/providers/CollectionDataContext.d.ts.map +0 -1
  446. package/dist/types/utils/filters.d.ts +0 -7
  447. package/dist/types/utils/filters.d.ts.map +0 -1
  448. /package/dist/cjs/{collectionData → dataSourceAdapters}/cms/sortUtils.js +0 -0
  449. /package/dist/cjs/{collectionData → dataSourceAdapters}/constants.js +0 -0
  450. /package/dist/esm/{collectionData → dataSourceAdapters}/cms/sortUtils.js +0 -0
  451. /package/dist/esm/{collectionData → dataSourceAdapters}/constants.js +0 -0
  452. /package/dist/types/{collectionData → dataSourceAdapters}/cms/sortUtils.d.ts +0 -0
  453. /package/dist/types/{collectionData → dataSourceAdapters}/constants.d.ts +0 -0
@@ -0,0 +1,137 @@
1
+ "use strict";
2
+
3
+ exports.__esModule = true;
4
+ exports.createReferenceFilter = exports.createNumberFilter = exports.createEnumFilter = exports.createDateTimeFilter = exports.createBooleanFilter = void 0;
5
+ var _patterns = require("@wix/patterns");
6
+ var _constants = require("../dataSourceAdapters/constants");
7
+ const createDateTimeFilter = ({
8
+ id,
9
+ fieldId,
10
+ commonFilterProps,
11
+ config
12
+ }) => ({
13
+ key: id,
14
+ fieldId,
15
+ filter: (0, _patterns.dateRangeFilter)(),
16
+ component: _patterns.DateRangeFilter,
17
+ props: {
18
+ ...commonFilterProps,
19
+ mode: config == null ? void 0 : config.mode,
20
+ dateRangeOptions: config == null ? void 0 : config.presets,
21
+ filterByTime: config == null ? void 0 : config.includeTime
22
+ }
23
+ });
24
+ exports.createDateTimeFilter = createDateTimeFilter;
25
+ const createBooleanFilter = ({
26
+ id,
27
+ fieldId,
28
+ commonFilterProps,
29
+ config
30
+ }) => ({
31
+ key: id,
32
+ fieldId,
33
+ filter: (0, _patterns.idNameArrayFilter)({
34
+ matches: (fieldValue, filterValue) => {
35
+ if (fieldValue) {
36
+ return filterValue.some(v => v.id === _constants.BooleanFilters.checked);
37
+ }
38
+ return filterValue.some(v => v.id === _constants.BooleanFilters.unchecked);
39
+ }
40
+ }),
41
+ component: _patterns.RadioGroupFilter,
42
+ props: {
43
+ ...commonFilterProps,
44
+ data: [{
45
+ id: 'checked',
46
+ name: (config == null ? void 0 : config.trueLabel) || 'Yes'
47
+ }, {
48
+ id: 'unchecked',
49
+ name: (config == null ? void 0 : config.falseLabel) || 'No'
50
+ }]
51
+ }
52
+ });
53
+ exports.createBooleanFilter = createBooleanFilter;
54
+ const createNumberFilter = ({
55
+ id,
56
+ fieldId,
57
+ commonFilterProps,
58
+ config
59
+ }) => ({
60
+ key: id,
61
+ fieldId,
62
+ filter: (0, _patterns.numberRangeFilter)(),
63
+ component: _patterns.NumberRangeFilter,
64
+ props: {
65
+ ...commonFilterProps,
66
+ min: config == null ? void 0 : config.min,
67
+ max: config == null ? void 0 : config.max,
68
+ decimal: config == null ? void 0 : config.allowedDecimals
69
+ }
70
+ });
71
+ exports.createNumberFilter = createNumberFilter;
72
+ const createEnumFilter = ({
73
+ id,
74
+ fieldId,
75
+ commonFilterProps,
76
+ config
77
+ }) => {
78
+ const {
79
+ options,
80
+ selectionMode,
81
+ optionType
82
+ } = config;
83
+ const data = (options == null ? void 0 : options.map(option => ({
84
+ id: option.value,
85
+ name: option.label
86
+ }))) ?? [];
87
+ const inlineComponentThreshold = 5;
88
+ let component;
89
+ if (selectionMode === 'single') {
90
+ component = data.length > inlineComponentThreshold ? _patterns.AutoCompleteFilter : _patterns.RadioGroupFilter;
91
+ if (optionType === 'select') {
92
+ component = _patterns.AutoCompleteFilter;
93
+ } else if (optionType === 'radio') {
94
+ component = _patterns.RadioGroupFilter;
95
+ }
96
+ } else {
97
+ component = data.length > inlineComponentThreshold ? _patterns.MultiSelectCheckboxFilter : _patterns.MultiInlineCheckboxFilter;
98
+ if (optionType === 'select') {
99
+ component = _patterns.MultiSelectCollectionFilter;
100
+ } else if (optionType === 'inlineCheckbox') {
101
+ component = _patterns.MultiInlineCheckboxFilter;
102
+ } else if (optionType === 'checkbox') {
103
+ component = _patterns.MultiSelectCheckboxFilter;
104
+ }
105
+ }
106
+ return {
107
+ key: id,
108
+ fieldId,
109
+ filter: (0, _patterns.idNameArrayFilter)(),
110
+ component,
111
+ collectionData: data,
112
+ props: {
113
+ ...commonFilterProps,
114
+ data
115
+ }
116
+ };
117
+ };
118
+ exports.createEnumFilter = createEnumFilter;
119
+ const createReferenceFilter = ({
120
+ id,
121
+ fieldId,
122
+ commonFilterProps,
123
+ config,
124
+ additionalParams
125
+ }) => {
126
+ const component = (config == null ? void 0 : config.selectionMode) === 'single' ? _patterns.AutoCompleteFilter : _patterns.MultiSelectCollectionFilter;
127
+ return {
128
+ key: id,
129
+ fieldId,
130
+ filter: (0, _patterns.idNameArrayFilter)(),
131
+ component,
132
+ collectionId: additionalParams.referencedSchema.id,
133
+ props: commonFilterProps
134
+ };
135
+ };
136
+ exports.createReferenceFilter = createReferenceFilter;
137
+ //# sourceMappingURL=filterCreators.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["_patterns","require","_constants","createDateTimeFilter","id","fieldId","commonFilterProps","config","key","filter","dateRangeFilter","component","DateRangeFilter","props","mode","dateRangeOptions","presets","filterByTime","includeTime","exports","createBooleanFilter","idNameArrayFilter","matches","fieldValue","filterValue","some","v","BooleanFilters","checked","unchecked","RadioGroupFilter","data","name","trueLabel","falseLabel","createNumberFilter","numberRangeFilter","NumberRangeFilter","min","max","decimal","allowedDecimals","createEnumFilter","options","selectionMode","optionType","map","option","value","label","inlineComponentThreshold","length","AutoCompleteFilter","MultiSelectCheckboxFilter","MultiInlineCheckboxFilter","MultiSelectCollectionFilter","collectionData","createReferenceFilter","additionalParams","collectionId","referencedSchema"],"sources":["../../../src/utils/filterCreators.ts"],"sourcesContent":["import {\n dateRangeFilter,\n idNameArrayFilter,\n numberRangeFilter,\n DateRangeFilter,\n RadioGroupFilter,\n NumberRangeFilter,\n AutoCompleteFilter,\n MultiSelectCheckboxFilter,\n MultiInlineCheckboxFilter,\n MultiSelectCollectionFilter,\n} from '@wix/patterns';\nimport { BooleanFilters } from '../dataSourceAdapters/constants';\nimport { FilterOptions } from '../hooks/useFilters';\nimport { SchemaConfig } from '../types';\n\ninterface FilterOption {\n value: string;\n label: string;\n}\n\ninterface BaseFilterParams {\n id: string;\n fieldId: string;\n commonFilterProps: Record<string, any>;\n}\n\nexport const createDateTimeFilter = ({\n id,\n fieldId,\n commonFilterProps,\n config,\n}: BaseFilterParams & {\n config?: {\n mode?: 'ONLY_PREDEFINED' | 'ONLY_CUSTOM' | 'COMBINE';\n presets?: string[];\n includeTime?: boolean;\n };\n}): FilterOptions => ({\n key: id,\n fieldId,\n filter: dateRangeFilter(),\n component: DateRangeFilter,\n props: {\n ...commonFilterProps,\n mode: config?.mode,\n dateRangeOptions: config?.presets,\n filterByTime: config?.includeTime,\n },\n});\n\nexport const createBooleanFilter = ({\n id,\n fieldId,\n commonFilterProps,\n config,\n}: BaseFilterParams & {\n config?: {\n trueLabel?: string;\n falseLabel?: string;\n };\n}): FilterOptions => ({\n key: id,\n fieldId,\n filter: idNameArrayFilter({\n matches: (fieldValue, filterValue) => {\n if (fieldValue) {\n return filterValue.some((v) => v.id === BooleanFilters.checked);\n }\n return filterValue.some((v) => v.id === BooleanFilters.unchecked);\n },\n }),\n component: RadioGroupFilter,\n props: {\n ...commonFilterProps,\n data: [\n {\n id: 'checked',\n name: config?.trueLabel || 'Yes',\n },\n {\n id: 'unchecked',\n name: config?.falseLabel || 'No',\n },\n ],\n },\n});\n\nexport const createNumberFilter = ({\n id,\n fieldId,\n commonFilterProps,\n config,\n}: BaseFilterParams & {\n config?: {\n min?: number;\n max?: number;\n allowedDecimals?: boolean;\n };\n}): FilterOptions => ({\n key: id,\n fieldId,\n filter: numberRangeFilter(),\n component: NumberRangeFilter,\n props: {\n ...commonFilterProps,\n min: config?.min,\n max: config?.max,\n decimal: config?.allowedDecimals,\n },\n});\n\nexport const createEnumFilter = ({\n id,\n fieldId,\n commonFilterProps,\n config,\n}: BaseFilterParams & {\n config: {\n options?: FilterOption[];\n selectionMode?: 'single' | 'multiple';\n optionType?: 'select' | 'radio' | 'checkbox' | 'inlineCheckbox';\n };\n}): FilterOptions => {\n const { options, selectionMode, optionType } = config;\n const data =\n options?.map((option: FilterOption) => ({\n id: option.value,\n name: option.label,\n })) ?? [];\n\n const inlineComponentThreshold = 5;\n\n let component;\n\n if (selectionMode === 'single') {\n component =\n data.length > inlineComponentThreshold\n ? AutoCompleteFilter\n : RadioGroupFilter;\n if (optionType === 'select') {\n component = AutoCompleteFilter;\n } else if (optionType === 'radio') {\n component = RadioGroupFilter;\n }\n } else {\n component =\n data.length > inlineComponentThreshold\n ? MultiSelectCheckboxFilter\n : MultiInlineCheckboxFilter;\n if (optionType === 'select') {\n component = MultiSelectCollectionFilter;\n } else if (optionType === 'inlineCheckbox') {\n component = MultiInlineCheckboxFilter;\n } else if (optionType === 'checkbox') {\n component = MultiSelectCheckboxFilter;\n }\n }\n\n return {\n key: id,\n fieldId,\n filter: idNameArrayFilter(),\n component,\n collectionData: data,\n props: { ...commonFilterProps, data },\n };\n};\n\nexport const createReferenceFilter = ({\n id,\n fieldId,\n commonFilterProps,\n config,\n additionalParams,\n}: BaseFilterParams & {\n config?: {\n selectionMode?: 'single' | 'multiple';\n };\n additionalParams: {\n referencedSchema: SchemaConfig;\n };\n}): FilterOptions => {\n const component =\n config?.selectionMode === 'single'\n ? AutoCompleteFilter\n : MultiSelectCollectionFilter;\n\n return {\n key: id,\n fieldId,\n filter: idNameArrayFilter(),\n component,\n collectionId: additionalParams.referencedSchema.id,\n props: commonFilterProps,\n };\n};\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+
3
+ exports.__esModule = true;
4
+ exports.getImageUrl = void 0;
5
+ exports.isAbsoluteUrl = isAbsoluteUrl;
6
+ var _sdk = require("@wix/sdk");
7
+ const getImageUrl = image => {
8
+ if (isAbsoluteUrl(image)) {
9
+ return image;
10
+ }
11
+ return _sdk.media.getImageUrl(image).url;
12
+ };
13
+ exports.getImageUrl = getImageUrl;
14
+ function isAbsoluteUrl(url) {
15
+ try {
16
+ const parsed = new URL(url);
17
+ return !!parsed.protocol && !!parsed.host;
18
+ } catch {
19
+ return false;
20
+ }
21
+ }
22
+ //# sourceMappingURL=getImageUrl.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["_sdk","require","getImageUrl","image","isAbsoluteUrl","media","url","exports","parsed","URL","protocol","host"],"sources":["../../../../src/utils/media/getImageUrl.ts"],"sourcesContent":["import { media } from '@wix/sdk';\n\nexport const getImageUrl = (image: string) => {\n if (isAbsoluteUrl(image)) {\n return image;\n }\n\n return media.getImageUrl(image).url;\n};\n\nexport function isAbsoluteUrl(url: string): boolean {\n try {\n const parsed = new URL(url);\n return !!parsed.protocol && !!parsed.host;\n } catch {\n return false;\n }\n}\n"],"mappings":";;;;;AAAA,IAAAA,IAAA,GAAAC,OAAA;AAEO,MAAMC,WAAW,GAAIC,KAAa,IAAK;EAC5C,IAAIC,aAAa,CAACD,KAAK,CAAC,EAAE;IACxB,OAAOA,KAAK;EACd;EAEA,OAAOE,UAAK,CAACH,WAAW,CAACC,KAAK,CAAC,CAACG,GAAG;AACrC,CAAC;AAACC,OAAA,CAAAL,WAAA,GAAAA,WAAA;AAEK,SAASE,aAAaA,CAACE,GAAW,EAAW;EAClD,IAAI;IACF,MAAME,MAAM,GAAG,IAAIC,GAAG,CAACH,GAAG,CAAC;IAC3B,OAAO,CAAC,CAACE,MAAM,CAACE,QAAQ,IAAI,CAAC,CAACF,MAAM,CAACG,IAAI;EAC3C,CAAC,CAAC,MAAM;IACN,OAAO,KAAK;EACd;AACF","ignoreList":[]}
@@ -1,22 +1,14 @@
1
1
  import React from 'react';
2
- import { PatternsReactRouter, PatternsReactRoute } from '@wix/patterns';
3
- import { AutoPatternsPage } from '../AutoPatternsRoute/AutoPatternsPage';
4
- const pageTypeToRouteType = {
5
- collectionPage: 'collection',
6
- entityPage: 'editEntity'
7
- };
2
+ import { RootAppProvider } from '../../providers/RootAppProvider';
3
+ import { AutoPatternsRoutes } from '../AutoPatternsRoute/AutoPatternsRoutes';
8
4
  export const AutoPatternsApp = _ref => {
9
5
  let {
10
6
  configuration
11
7
  } = _ref;
12
- const routes = configuration.pages.map(page => /*#__PURE__*/React.createElement(PatternsReactRoute, {
13
- key: page.routePath,
14
- type: pageTypeToRouteType[page.type] ?? 'other',
15
- path: page.routePath,
16
- element: /*#__PURE__*/React.createElement(AutoPatternsPage, {
17
- pageConfig: page
18
- })
8
+ return /*#__PURE__*/React.createElement(RootAppProvider, {
9
+ appConfig: configuration
10
+ }, /*#__PURE__*/React.createElement(AutoPatternsRoutes, {
11
+ config: configuration
19
12
  }));
20
- return /*#__PURE__*/React.createElement(PatternsReactRouter, null, routes);
21
13
  };
22
14
  //# sourceMappingURL=AutoPatternsApp.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["React","PatternsReactRouter","PatternsReactRoute","AutoPatternsPage","pageTypeToRouteType","collectionPage","entityPage","AutoPatternsApp","_ref","configuration","routes","pages","map","page","createElement","key","routePath","type","path","element","pageConfig"],"sources":["../../../../src/components/AutoPatternsApp/AutoPatternsApp.tsx"],"sourcesContent":["import React from 'react';\nimport { AppConfig } from '../../types';\nimport { PatternsReactRouter, PatternsReactRoute } from '@wix/patterns';\nimport { AutoPatternsPage } from '../AutoPatternsRoute/AutoPatternsPage';\nimport type { RouteType } from '@wix/patterns/dist/types/components/Router/types';\n\nexport interface AutoPatternsAppPageProps {\n configuration: AppConfig;\n}\n\nconst pageTypeToRouteType: Record<string, RouteType> = {\n collectionPage: 'collection',\n entityPage: 'editEntity',\n};\n\nexport const AutoPatternsApp: React.FC<AutoPatternsAppPageProps> = ({\n configuration,\n}) => {\n const routes = configuration.pages.map((page) => (\n <PatternsReactRoute\n key={page.routePath}\n type={pageTypeToRouteType[page.type] ?? 'other'}\n path={page.routePath}\n element={<AutoPatternsPage pageConfig={page} />}\n />\n ));\n\n return <PatternsReactRouter>{routes}</PatternsReactRouter>;\n};\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AAEzB,SAASC,mBAAmB,EAAEC,kBAAkB,QAAQ,eAAe;AACvE,SAASC,gBAAgB,QAAQ,uCAAuC;AAOxE,MAAMC,mBAA8C,GAAG;EACrDC,cAAc,EAAE,YAAY;EAC5BC,UAAU,EAAE;AACd,CAAC;AAED,OAAO,MAAMC,eAAmD,GAAGC,IAAA,IAE7D;EAAA,IAF8D;IAClEC;EACF,CAAC,GAAAD,IAAA;EACC,MAAME,MAAM,GAAGD,aAAa,CAACE,KAAK,CAACC,GAAG,CAAEC,IAAI,iBAC1Cb,KAAA,CAAAc,aAAA,CAACZ,kBAAkB;IACjBa,GAAG,EAAEF,IAAI,CAACG,SAAU;IACpBC,IAAI,EAAEb,mBAAmB,CAACS,IAAI,CAACI,IAAI,CAAC,IAAI,OAAQ;IAChDC,IAAI,EAAEL,IAAI,CAACG,SAAU;IACrBG,OAAO,eAAEnB,KAAA,CAAAc,aAAA,CAACX,gBAAgB;MAACiB,UAAU,EAAEP;IAAK,CAAE;EAAE,CACjD,CACF,CAAC;EAEF,oBAAOb,KAAA,CAAAc,aAAA,CAACb,mBAAmB,QAAES,MAA4B,CAAC;AAC5D,CAAC","ignoreList":[]}
1
+ {"version":3,"names":["React","RootAppProvider","AutoPatternsRoutes","AutoPatternsApp","_ref","configuration","createElement","appConfig","config"],"sources":["../../../../src/components/AutoPatternsApp/AutoPatternsApp.tsx"],"sourcesContent":["import React from 'react';\nimport { AppConfig } from '../../types';\nimport { RootAppProvider } from '../../providers/RootAppProvider';\nimport { AutoPatternsRoutes } from '../AutoPatternsRoute/AutoPatternsRoutes';\n\nexport interface AutoPatternsAppPageProps {\n configuration: AppConfig;\n}\n\nexport const AutoPatternsApp: React.FC<AutoPatternsAppPageProps> = ({\n configuration,\n}) => {\n return (\n <RootAppProvider appConfig={configuration}>\n <AutoPatternsRoutes config={configuration} />\n </RootAppProvider>\n );\n};\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AAEzB,SAASC,eAAe,QAAQ,iCAAiC;AACjE,SAASC,kBAAkB,QAAQ,yCAAyC;AAM5E,OAAO,MAAMC,eAAmD,GAAGC,IAAA,IAE7D;EAAA,IAF8D;IAClEC;EACF,CAAC,GAAAD,IAAA;EACC,oBACEJ,KAAA,CAAAM,aAAA,CAACL,eAAe;IAACM,SAAS,EAAEF;EAAc,gBACxCL,KAAA,CAAAM,aAAA,CAACJ,kBAAkB;IAACM,MAAM,EAAEH;EAAc,CAAE,CAC7B,CAAC;AAEtB,CAAC","ignoreList":[]}
@@ -24,6 +24,7 @@ export const AutoPatternsCollectionPageContent = _ref => {
24
24
  case 'Grid':
25
25
  if (component.grid) {
26
26
  return /*#__PURE__*/React.createElement(AutoPatternsGrid, {
27
+ key: component.grid.collection.collectionId,
27
28
  configuration: component.grid
28
29
  });
29
30
  }
@@ -1 +1 @@
1
- {"version":3,"names":["React","AutoPatternsTable","AutoPatternsGrid","AutoPatternsCollectionPageContent","_ref","configuration","components","createElement","Fragment","map","component","type","table","key","collection","collectionId","grid"],"sources":["../../../../src/components/AutoPatternsCollectionPageContent/AutoPatternsCollectionPageContent.tsx"],"sourcesContent":["import React from 'react';\nimport { AutoPatternsTable } from '../AutoPatternsTable';\nimport { CollectionPageConfig } from '../../types';\nimport { AutoPatternsGrid } from '../AutoPatternsGrid';\n\nexport interface AutoPatternsCollectionPageContentProps {\n configuration: CollectionPageConfig;\n}\n\nexport const AutoPatternsCollectionPageContent = ({\n configuration,\n}: AutoPatternsCollectionPageContentProps) => {\n const { components } = configuration;\n return (\n <>\n {components.map((component) => {\n const { type } = component;\n switch (type) {\n case 'Table':\n if (component.table) {\n return (\n <AutoPatternsTable\n key={component.table.collection.collectionId}\n configuration={component.table}\n />\n );\n }\n return null;\n case 'Grid':\n if (component.grid) {\n return <AutoPatternsGrid configuration={component.grid} />;\n }\n return null;\n default:\n return null;\n }\n })}\n </>\n );\n};\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,iBAAiB,QAAQ,sBAAsB;AAExD,SAASC,gBAAgB,QAAQ,qBAAqB;AAMtD,OAAO,MAAMC,iCAAiC,GAAGC,IAAA,IAEH;EAAA,IAFI;IAChDC;EACsC,CAAC,GAAAD,IAAA;EACvC,MAAM;IAAEE;EAAW,CAAC,GAAGD,aAAa;EACpC,oBACEL,KAAA,CAAAO,aAAA,CAAAP,KAAA,CAAAQ,QAAA,QACGF,UAAU,CAACG,GAAG,CAAEC,SAAS,IAAK;IAC7B,MAAM;MAAEC;IAAK,CAAC,GAAGD,SAAS;IAC1B,QAAQC,IAAI;MACV,KAAK,OAAO;QACV,IAAID,SAAS,CAACE,KAAK,EAAE;UACnB,oBACEZ,KAAA,CAAAO,aAAA,CAACN,iBAAiB;YAChBY,GAAG,EAAEH,SAAS,CAACE,KAAK,CAACE,UAAU,CAACC,YAAa;YAC7CV,aAAa,EAAEK,SAAS,CAACE;UAAM,CAChC,CAAC;QAEN;QACA,OAAO,IAAI;MACb,KAAK,MAAM;QACT,IAAIF,SAAS,CAACM,IAAI,EAAE;UAClB,oBAAOhB,KAAA,CAAAO,aAAA,CAACL,gBAAgB;YAACG,aAAa,EAAEK,SAAS,CAACM;UAAK,CAAE,CAAC;QAC5D;QACA,OAAO,IAAI;MACb;QACE,OAAO,IAAI;IACf;EACF,CAAC,CACD,CAAC;AAEP,CAAC","ignoreList":[]}
1
+ {"version":3,"names":["React","AutoPatternsTable","AutoPatternsGrid","AutoPatternsCollectionPageContent","_ref","configuration","components","createElement","Fragment","map","component","type","table","key","collection","collectionId","grid"],"sources":["../../../../src/components/AutoPatternsCollectionPageContent/AutoPatternsCollectionPageContent.tsx"],"sourcesContent":["import React from 'react';\nimport { AutoPatternsTable } from '../AutoPatternsTable';\nimport { CollectionPageConfig } from '../../types';\nimport { AutoPatternsGrid } from '../AutoPatternsGrid';\n\nexport interface AutoPatternsCollectionPageContentProps {\n configuration: CollectionPageConfig;\n}\n\nexport const AutoPatternsCollectionPageContent = ({\n configuration,\n}: AutoPatternsCollectionPageContentProps) => {\n const { components } = configuration;\n return (\n <>\n {components.map((component) => {\n const { type } = component;\n switch (type) {\n case 'Table':\n if (component.table) {\n return (\n <AutoPatternsTable\n key={component.table.collection.collectionId}\n configuration={component.table}\n />\n );\n }\n return null;\n case 'Grid':\n if (component.grid) {\n return (\n <AutoPatternsGrid\n key={component.grid.collection.collectionId}\n configuration={component.grid}\n />\n );\n }\n return null;\n default:\n return null;\n }\n })}\n </>\n );\n};\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,iBAAiB,QAAQ,sBAAsB;AAExD,SAASC,gBAAgB,QAAQ,qBAAqB;AAMtD,OAAO,MAAMC,iCAAiC,GAAGC,IAAA,IAEH;EAAA,IAFI;IAChDC;EACsC,CAAC,GAAAD,IAAA;EACvC,MAAM;IAAEE;EAAW,CAAC,GAAGD,aAAa;EACpC,oBACEL,KAAA,CAAAO,aAAA,CAAAP,KAAA,CAAAQ,QAAA,QACGF,UAAU,CAACG,GAAG,CAAEC,SAAS,IAAK;IAC7B,MAAM;MAAEC;IAAK,CAAC,GAAGD,SAAS;IAC1B,QAAQC,IAAI;MACV,KAAK,OAAO;QACV,IAAID,SAAS,CAACE,KAAK,EAAE;UACnB,oBACEZ,KAAA,CAAAO,aAAA,CAACN,iBAAiB;YAChBY,GAAG,EAAEH,SAAS,CAACE,KAAK,CAACE,UAAU,CAACC,YAAa;YAC7CV,aAAa,EAAEK,SAAS,CAACE;UAAM,CAChC,CAAC;QAEN;QACA,OAAO,IAAI;MACb,KAAK,MAAM;QACT,IAAIF,SAAS,CAACM,IAAI,EAAE;UAClB,oBACEhB,KAAA,CAAAO,aAAA,CAACL,gBAAgB;YACfW,GAAG,EAAEH,SAAS,CAACM,IAAI,CAACF,UAAU,CAACC,YAAa;YAC5CV,aAAa,EAAEK,SAAS,CAACM;UAAK,CAC/B,CAAC;QAEN;QACA,OAAO,IAAI;MACb;QACE,OAAO,IAAI;IACf;EACF,CAAC,CACD,CAAC;AAEP,CAAC","ignoreList":[]}
@@ -1,44 +1,153 @@
1
- import React from 'react';
2
- import { EntityPage, useEntity, useEntityPage } from '@wix/patterns';
1
+ import React, { useMemo, useRef } from 'react';
2
+ import { EntityPage, useEntity, useEntityPage, useEntityPageContext } from '@wix/patterns';
3
3
  import { useForm } from '@wix/patterns/form';
4
- import { Box, Card, Cell } from '@wix/design-system';
5
- import { FormFieldInput } from './Fields/FormFieldInput';
4
+ import { Card, Cell, Layout } from '@wix/design-system';
6
5
  import { useParams } from 'react-router-dom';
7
6
  import { useSchema } from '../../providers/SchemaContext';
8
- export const AutoPatternsEntityPage = _ref => {
7
+ import { FormFieldInput } from './Fields/FormFieldInput';
8
+ import { useNavigation } from '../../hooks';
9
+ import { usePatternsWizardOverridesContext } from '../../providers';
10
+ const RenderLayoutContent = _ref => {
11
+ var _content$container$ch, _overrides$components;
9
12
  let {
10
- configuration
13
+ content,
14
+ level,
15
+ sectionId,
16
+ cardIndex,
17
+ contentIndex,
18
+ setInputRef
11
19
  } = _ref;
20
+ const schema = useSchema();
21
+ const overrides = usePatternsWizardOverridesContext();
22
+ const pageState = useEntityPageContext();
23
+ switch (content.type) {
24
+ case 'field':
25
+ if (!content.field.fieldId) {
26
+ return null;
27
+ }
28
+ const field = schema.fields[content.field.fieldId];
29
+ if (!field) {
30
+ return null;
31
+ }
32
+ return /*#__PURE__*/React.createElement(Cell, {
33
+ span: content.field.span
34
+ }, /*#__PURE__*/React.createElement(FormFieldInput, {
35
+ key: content.field.fieldId,
36
+ field: field,
37
+ inputRef: ref => setInputRef(content.field.fieldId, ref)
38
+ }));
39
+ case 'container':
40
+ if (!((_content$container$ch = content.container.children) != null && _content$container$ch.length)) {
41
+ return null;
42
+ }
43
+ return /*#__PURE__*/React.createElement(Cell, {
44
+ span: content.container.span
45
+ }, /*#__PURE__*/React.createElement(Layout, null, content.container.children.map((child, index) => /*#__PURE__*/React.createElement(RenderLayoutContent, {
46
+ key: `${sectionId}-card-${cardIndex}-content-${contentIndex}-level-${level}-child-${index}`,
47
+ content: child,
48
+ level: level + 1,
49
+ sectionId: sectionId,
50
+ cardIndex: cardIndex,
51
+ contentIndex: index,
52
+ setInputRef: setInputRef
53
+ }))));
54
+ case 'component':
55
+ if (!content.component.componentId) {
56
+ return null;
57
+ }
58
+ const Component = overrides == null || (_overrides$components = overrides.components) == null ? void 0 : _overrides$components[content.component.componentId];
59
+ if (!Component) {
60
+ return null;
61
+ }
62
+ return /*#__PURE__*/React.createElement(Cell, {
63
+ span: content.component.span
64
+ }, /*#__PURE__*/React.createElement(Component, {
65
+ form: pageState.form,
66
+ entity: pageState.entity
67
+ }));
68
+ default:
69
+ return null;
70
+ }
71
+ };
72
+ const RenderLayoutCard = _ref2 => {
73
+ var _layout$card$subtitle;
74
+ let {
75
+ layout,
76
+ sectionId,
77
+ cardIndex,
78
+ setInputRef
79
+ } = _ref2;
80
+ switch (layout.type) {
81
+ case 'card':
82
+ return /*#__PURE__*/React.createElement(EntityPage.Card, {
83
+ minHeight: "50px"
84
+ }, /*#__PURE__*/React.createElement(Card.Header, {
85
+ title: layout.card.title.text,
86
+ subtitle: (_layout$card$subtitle = layout.card.subtitle) == null ? void 0 : _layout$card$subtitle.text
87
+ }), /*#__PURE__*/React.createElement(Card.Divider, null), /*#__PURE__*/React.createElement(Card.Content, null, /*#__PURE__*/React.createElement(Layout, null, layout.card.children.map((child, index) => /*#__PURE__*/React.createElement(RenderLayoutContent, {
88
+ key: `${sectionId}-card-${cardIndex}-content-${index}`,
89
+ content: child,
90
+ level: 0,
91
+ sectionId: sectionId,
92
+ cardIndex: cardIndex,
93
+ contentIndex: index,
94
+ setInputRef: setInputRef
95
+ })))));
96
+ default:
97
+ return null;
98
+ }
99
+ };
100
+ export const AutoPatternsEntityPage = _ref3 => {
101
+ var _pageLayout$main, _pageLayout$sidebar;
102
+ let {
103
+ configuration
104
+ } = _ref3;
12
105
  const {
13
106
  title,
14
107
  subtitle,
15
- visibleFieldIds = [],
16
- collectionPagePath: parentPath
108
+ layout: pageLayout,
109
+ parentPageId,
110
+ route
17
111
  } = configuration;
18
112
  const form = useForm();
19
113
  const params = useParams();
20
- const entityId = params.entityId;
114
+ const entityId = params[route.params.id];
21
115
  const schema = useSchema();
116
+ const inputRefs = useRef({});
117
+ const setInputRef = (id, input) => {
118
+ inputRefs.current[id] = input;
119
+ };
120
+ const validate = () => {
121
+ const invalidFieldId = Object.keys(inputRefs.current).find(fieldId => {
122
+ var _inputRefs$current$fi;
123
+ return (_inputRefs$current$fi = inputRefs.current[fieldId]) == null ? void 0 : _inputRefs$current$fi.invalid;
124
+ });
125
+ if (invalidFieldId) {
126
+ var _inputRefs$current$in;
127
+ (_inputRefs$current$in = inputRefs.current[invalidFieldId]) == null || _inputRefs$current$in.focus == null || _inputRefs$current$in.focus();
128
+ throw new Error('Invalid form');
129
+ }
130
+ };
131
+ const {
132
+ getParentPagePath
133
+ } = useNavigation();
134
+ const parentPath = useMemo(() => getParentPagePath(parentPageId), [parentPageId, getParentPagePath]);
22
135
  const state = useEntityPage({
23
136
  parentPath,
24
137
  form,
25
138
  onSave: async () => {
139
+ validate();
26
140
  const formValues = form.getValues();
141
+ const baseEntity = state.entity || {};
27
142
  const updatedEntity = {
28
- ...state.entity,
143
+ ...baseEntity,
29
144
  ...formValues
30
145
  };
31
- let newUpdatedEntity;
32
- if (entityId) {
33
- newUpdatedEntity = await schema.actions.update(updatedEntity);
34
- } else {
35
- newUpdatedEntity = await schema.actions.create(updatedEntity);
36
- }
146
+ const newEntity = entityId ? await schema.actions.update(updatedEntity) : await schema.actions.create(updatedEntity);
37
147
  return {
38
- updatedEntity: newUpdatedEntity
148
+ updatedEntity: newEntity
39
149
  };
40
150
  },
41
- saveErrorToast: () => 'Failed to save',
42
151
  fetch: async () => {
43
152
  if (!entityId) {
44
153
  return {
@@ -60,21 +169,33 @@ export const AutoPatternsEntityPage = _ref => {
60
169
  text: (entity == null ? void 0 : entity[schema.displayField]) ?? 'Edit Entity'
61
170
  },
62
171
  subtitle: subtitle
63
- }), /*#__PURE__*/React.createElement(EntityPage.Content, null, /*#__PURE__*/React.createElement(EntityPage.MainContent, null, /*#__PURE__*/React.createElement(EntityPage.Card, {
64
- minHeight: "50px"
65
- }, /*#__PURE__*/React.createElement(Card.Header, {
66
- title: "Item details",
67
- subtitle: "Modify the details of your selected item below"
68
- }), /*#__PURE__*/React.createElement(Card.Divider, null), /*#__PURE__*/React.createElement(Card.Content, null, /*#__PURE__*/React.createElement(Box, {
69
- gap: "SP2",
70
- direction: "vertical"
71
- }, visibleFieldIds.map(fieldId => /*#__PURE__*/React.createElement(React.Fragment, {
72
- key: fieldId
73
- }, /*#__PURE__*/React.createElement(Cell, {
74
- span: 12
75
- }, /*#__PURE__*/React.createElement(FormFieldInput, {
76
- key: fieldId,
77
- field: schema.fields[fieldId]
78
- }))))))))));
172
+ }), /*#__PURE__*/React.createElement(EntityPage.Content, null, /*#__PURE__*/React.createElement(EntityPage.MainContent, null, pageLayout == null || (_pageLayout$main = pageLayout.main) == null ? void 0 : _pageLayout$main.map((layout, layoutIndex) => /*#__PURE__*/React.createElement(RenderLayoutCard, {
173
+ key: `main-section-card-${layoutIndex}`,
174
+ layout: layout,
175
+ sectionId: "main",
176
+ cardIndex: layoutIndex,
177
+ setInputRef: setInputRef
178
+ }))), pageLayout != null && pageLayout.sidebar ? /*#__PURE__*/React.createElement(EntityPage.AdditionalContent, null, (_pageLayout$sidebar = pageLayout.sidebar) == null ? void 0 : _pageLayout$sidebar.map((layout, layoutIndex) => /*#__PURE__*/React.createElement(RenderLayoutCard, {
179
+ key: `sidebar-section-card-${layoutIndex}`,
180
+ layout: layout,
181
+ sectionId: "sidebar",
182
+ cardIndex: layoutIndex,
183
+ setInputRef: setInputRef
184
+ }))) : null));
79
185
  };
186
+
187
+ /*
188
+ Key structure explanation:
189
+
190
+ Main cards: main-section-card-{layoutIndex}
191
+ Sidebar cards: sidebar-section-card-{layoutIndex}
192
+
193
+ Layout content:
194
+ {sectionId}-card-{cardIndex}-content-{contentIndex}
195
+
196
+ Nested children:
197
+ {sectionId}-card-{cardIndex}-content-{parentContentIndex}-level-{level}-child-{childIndex}
198
+
199
+ This ensures uniqueness across all levels and sections.
200
+ */
80
201
  //# sourceMappingURL=AutoPatternsEntityPage.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["React","EntityPage","useEntity","useEntityPage","useForm","Box","Card","Cell","FormFieldInput","useParams","useSchema","AutoPatternsEntityPage","_ref","configuration","title","subtitle","visibleFieldIds","collectionPagePath","parentPath","form","params","entityId","schema","state","onSave","formValues","getValues","updatedEntity","entity","newUpdatedEntity","actions","update","create","saveErrorToast","fetch","undefined","get","createElement","dataHook","Header","text","displayField","Content","MainContent","minHeight","Divider","gap","direction","map","fieldId","Fragment","key","span","field","fields"],"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","useMemo","useRef","EntityPage","useEntity","useEntityPage","useEntityPageContext","useForm","Card","Cell","Layout","useParams","useSchema","FormFieldInput","useNavigation","usePatternsWizardOverridesContext","RenderLayoutContent","_ref","_content$container$ch","_overrides$components","content","level","sectionId","cardIndex","contentIndex","setInputRef","schema","overrides","pageState","type","field","fieldId","fields","createElement","span","key","inputRef","ref","container","children","length","map","child","index","component","componentId","Component","components","form","entity","RenderLayoutCard","_ref2","_layout$card$subtitle","layout","minHeight","Header","title","card","text","subtitle","Divider","Content","AutoPatternsEntityPage","_ref3","_pageLayout$main","_pageLayout$sidebar","configuration","pageLayout","parentPageId","route","params","entityId","id","inputRefs","input","current","validate","invalidFieldId","Object","keys","find","_inputRefs$current$fi","invalid","_inputRefs$current$in","focus","Error","getParentPagePath","parentPath","state","onSave","formValues","getValues","baseEntity","updatedEntity","newEntity","actions","update","create","fetch","undefined","get","dataHook","displayField","MainContent","main","layoutIndex","sidebar","AdditionalContent"],"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 { 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 {\n title,\n subtitle,\n layout: pageLayout,\n parentPageId,\n route,\n } = configuration;\n\n const form = useForm<any>();\n const params = useParams();\n const entityId = params[route.params.id];\n const schema = useSchema();\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 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 {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":[]}
@@ -1,18 +1,38 @@
1
1
  import React, { useRef, useState } from 'react';
2
2
  import { FormField, DatePicker } from '@wix/design-system';
3
3
  import { getDateWithoutTimezone, getISODateStringWithFixedTimezone } from './utils/dates';
4
+ import { useSelector, useWixPatternsContainer } from '@wix/patterns';
4
5
  export const DateInput = props => {
6
+ var _field$validation;
5
7
  const {
6
8
  field,
7
9
  value,
8
- onChange
10
+ onChange,
11
+ dataHook,
12
+ inputRef
9
13
  } = props;
14
+ const {
15
+ translate: t,
16
+ ...container
17
+ } = useWixPatternsContainer();
18
+ useSelector(() => container.initTask.status);
10
19
  const [date, setDate] = useState(() => value ? getDateWithoutTimezone(getISODateStringWithFixedTimezone(value)) : undefined);
11
20
  const ref = useRef({});
12
21
  const [statusMessage, setStatusMessage] = useState('');
13
22
  return /*#__PURE__*/React.createElement(FormField, {
14
- label: field.displayName
23
+ label: field.displayName,
24
+ required: (_field$validation = field.validation) == null ? void 0 : _field$validation.required,
25
+ dataHook: dataHook
15
26
  }, /*#__PURE__*/React.createElement(DatePicker, {
27
+ ref: internalRef => {
28
+ inputRef == null || inputRef(ref.current);
29
+ // TODO: PR to WSR needed to expose as public API
30
+ // @ts-expect-error
31
+ ref.current.focus = () => {
32
+ var _internalRef$state;
33
+ return internalRef == null || (_internalRef$state = internalRef.state) == null || (_internalRef$state = _internalRef$state.inputRef) == null || _internalRef$state.focus == null ? void 0 : _internalRef$state.focus();
34
+ };
35
+ },
16
36
  dataHook: `date-${field.id}`,
17
37
  width: "100%",
18
38
  value: date,
@@ -24,7 +44,8 @@ export const DateInput = props => {
24
44
  onValidate: _ref => {
25
45
  let {
26
46
  validationType,
27
- value: newValue
47
+ value: newValue,
48
+ format
28
49
  } = _ref;
29
50
  if (validationType === 'valid') {
30
51
  setStatusMessage('');
@@ -35,7 +56,9 @@ export const DateInput = props => {
35
56
  setStatusMessage('');
36
57
  ref.current.invalid = false;
37
58
  } else {
38
- setStatusMessage('Invalid date');
59
+ setStatusMessage(t('cairo.customFields.fieldType.date.invalid.value', {
60
+ dateFormat: format ?? ''
61
+ }));
39
62
  ref.current.invalid = true;
40
63
  }
41
64
  },
@@ -1 +1 @@
1
- {"version":3,"names":["React","useRef","useState","FormField","DatePicker","getDateWithoutTimezone","getISODateStringWithFixedTimezone","DateInput","props","field","value","onChange","date","setDate","undefined","ref","statusMessage","setStatusMessage","createElement","label","displayName","dataHook","id","width","newValue","formattedDate","split","onValidate","_ref","validationType","current","invalid","status"],"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":"AAAA,OAAOA,KAAK,IAAIC,MAAM,EAAEC,QAAQ,QAAQ,OAAO;AAC/C,SAASC,SAAS,EAAEC,UAAU,QAAQ,oBAAoB;AAC1D,SACEC,sBAAsB,EACtBC,iCAAiC,QAC5B,eAAe;AAKtB,OAAO,MAAMC,SAAS,GAAIC,KAAgB,IAAK;EAC7C,MAAM;IAAEC,KAAK;IAAEC,KAAK;IAAEC;EAAS,CAAC,GAAGH,KAAK;EAExC,MAAM,CAACI,IAAI,EAAEC,OAAO,CAAC,GAAGX,QAAQ,CAAmB,MACjDQ,KAAK,GACDL,sBAAsB,CAACC,iCAAiC,CAACI,KAAK,CAAC,CAAC,GAChEI,SACN,CAAC;EAED,MAAMC,GAAG,GAAGd,MAAM,CAAe,CAAC,CAAC,CAAC;EACpC,MAAM,CAACe,aAAa,EAAEC,gBAAgB,CAAC,GAAGf,QAAQ,CAAC,EAAE,CAAC;EAEtD,oBACEF,KAAA,CAAAkB,aAAA,CAACf,SAAS;IAACgB,KAAK,EAAEV,KAAK,CAACW;EAAY,gBAClCpB,KAAA,CAAAkB,aAAA,CAACd,UAAU;IACTiB,QAAQ,EAAE,QAAQZ,KAAK,CAACa,EAAE,EAAG;IAC7BC,KAAK,EAAC,MAAM;IACZb,KAAK,EAAEE,IAAK;IACZD,QAAQ,EAAGa,QAAc,IAAK;MAC5B,MAAMC,aAAa,GAAGnB,iCAAiC,CAACkB,QAAQ,CAAC;MACjEX,OAAO,CAACW,QAAQ,CAAC;MACjBb,QAAQ,CAACc,aAAa,CAACC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACvC,CAAE;IACFC,UAAU,EAAEC,IAAA,IAAyC;MAAA,IAAxC;QAAEC,cAAc;QAAEnB,KAAK,EAAEc;MAAS,CAAC,GAAAI,IAAA;MAC9C,IAAIC,cAAc,KAAK,OAAO,EAAE;QAC9BZ,gBAAgB,CAAC,EAAE,CAAC;QACpBF,GAAG,CAACe,OAAO,CAACC,OAAO,GAAG,KAAK;MAC7B,CAAC,MAAM,IAAIF,cAAc,KAAK,aAAa,IAAIL,QAAQ,KAAK,EAAE,EAAE;QAC9DX,OAAO,CAACC,SAAS,CAAC;QAClBH,QAAQ,CAAC,IAAI,CAAC;QACdM,gBAAgB,CAAC,EAAE,CAAC;QACpBF,GAAG,CAACe,OAAO,CAACC,OAAO,GAAG,KAAK;MAC7B,CAAC,MAAM;QACLd,gBAAgB,CAAC,cAAc,CAAC;QAChCF,GAAG,CAACe,OAAO,CAACC,OAAO,GAAG,IAAI;MAC5B;IACF,CAAE;IACFC,MAAM,EAAEjB,GAAG,CAACe,OAAO,CAACC,OAAO,GAAG,OAAO,GAAGjB,SAAU;IAClDE,aAAa,EAAEA;EAAc,CAC9B,CACQ,CAAC;AAEhB,CAAC","ignoreList":[]}
1
+ {"version":3,"names":["React","useRef","useState","FormField","DatePicker","getDateWithoutTimezone","getISODateStringWithFixedTimezone","useSelector","useWixPatternsContainer","DateInput","props","_field$validation","field","value","onChange","dataHook","inputRef","translate","t","container","initTask","status","date","setDate","undefined","ref","statusMessage","setStatusMessage","createElement","label","displayName","required","validation","internalRef","current","focus","_internalRef$state","state","id","width","newValue","formattedDate","split","onValidate","_ref","validationType","format","invalid","dateFormat"],"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';\nimport { useSelector, useWixPatternsContainer } from '@wix/patterns';\n\nexport interface DateProps extends BaseInputProps<string | null> {}\n\nexport const DateInput = (props: DateProps) => {\n const { field, value, onChange, dataHook, inputRef } = props;\n const { translate: t, ...container } = useWixPatternsContainer();\n useSelector(() => container.initTask.status);\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\n label={field.displayName}\n required={field.validation?.required}\n dataHook={dataHook}\n >\n <DatePicker\n ref={(internalRef) => {\n inputRef?.(ref.current);\n // TODO: PR to WSR needed to expose as public API\n // @ts-expect-error\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 const formattedDate = getISODateStringWithFixedTimezone(newValue);\n setDate(newValue);\n onChange(formattedDate.split('T')[0]);\n }}\n onValidate={({ validationType, value: newValue, format }) => {\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(\n t('cairo.customFields.fieldType.date.invalid.value', {\n dateFormat: format ?? '',\n }),\n );\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":[]}