@wix/patterns 1.385.0 → 1.388.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 (620) hide show
  1. package/dist/cjs/components/CardContainer/CardContainer.st.css.js +2 -2
  2. package/dist/cjs/components/CardContainer/CardContainer.st.css.js.map +1 -1
  3. package/dist/cjs/components/CmsFieldManagement/CmsFieldForm.js +119 -0
  4. package/dist/cjs/components/CmsFieldManagement/CmsFieldForm.js.map +1 -0
  5. package/dist/cjs/components/CmsFieldManagement/CmsFieldModal.js +41 -0
  6. package/dist/cjs/components/CmsFieldManagement/CmsFieldModal.js.map +1 -0
  7. package/dist/cjs/components/CmsFieldManagement/CmsFieldModalState.js +95 -0
  8. package/dist/cjs/components/CmsFieldManagement/CmsFieldModalState.js.map +1 -0
  9. package/dist/cjs/components/CmsFieldManagement/CmsFormState.js +194 -0
  10. package/dist/cjs/components/CmsFieldManagement/CmsFormState.js.map +1 -0
  11. package/dist/cjs/components/CmsFieldManagement/Sections/BasicsSection.js +68 -0
  12. package/dist/cjs/components/CmsFieldManagement/Sections/BasicsSection.js.map +1 -0
  13. package/dist/cjs/components/CmsFieldManagement/Sections/ValidationAndDefaultsSection.js +152 -0
  14. package/dist/cjs/components/CmsFieldManagement/Sections/ValidationAndDefaultsSection.js.map +1 -0
  15. package/dist/cjs/components/CmsFieldManagement/Sections/ValidationSubSection.js +62 -0
  16. package/dist/cjs/components/CmsFieldManagement/Sections/ValidationSubSection.js.map +1 -0
  17. package/dist/cjs/components/CmsFieldManagement/fieldTypeUtils.js +10 -0
  18. package/dist/cjs/components/CmsFieldManagement/fieldTypeUtils.js.map +1 -0
  19. package/dist/cjs/components/CmsFieldManagement/fieldValidationRulesMap.js +18 -0
  20. package/dist/cjs/components/CmsFieldManagement/fieldValidationRulesMap.js.map +1 -0
  21. package/dist/cjs/components/CmsFieldManagement/formFields/CharactersLimitInput.js +66 -0
  22. package/dist/cjs/components/CmsFieldManagement/formFields/CharactersLimitInput.js.map +1 -0
  23. package/dist/cjs/components/CmsFieldManagement/formFields/FieldNameInput.js +38 -0
  24. package/dist/cjs/components/CmsFieldManagement/formFields/FieldNameInput.js.map +1 -0
  25. package/dist/cjs/components/CmsFieldManagement/formFields/FieldPiiToggle.js +34 -0
  26. package/dist/cjs/components/CmsFieldManagement/formFields/FieldPiiToggle.js.map +1 -0
  27. package/dist/cjs/components/CmsFieldManagement/formFields/FieldTypeSelect.js +57 -0
  28. package/dist/cjs/components/CmsFieldManagement/formFields/FieldTypeSelect.js.map +1 -0
  29. package/dist/cjs/components/CmsFieldManagement/formFields/RequiredToggle.js +24 -0
  30. package/dist/cjs/components/CmsFieldManagement/formFields/RequiredToggle.js.map +1 -0
  31. package/dist/cjs/components/CmsFieldManagement/index.js +7 -0
  32. package/dist/cjs/components/CmsFieldManagement/index.js.map +1 -0
  33. package/dist/cjs/components/CmsFieldManagement/toFieldSpec.js +38 -0
  34. package/dist/cjs/components/CmsFieldManagement/toFieldSpec.js.map +1 -0
  35. package/dist/cjs/components/CmsFieldManagement/types.js +4 -0
  36. package/dist/cjs/components/CmsFieldManagement/types.js.map +1 -0
  37. package/dist/cjs/components/Collapse/Collapse.st.css.js +3 -3
  38. package/dist/cjs/components/Collapse/Collapse.st.css.js.map +1 -1
  39. package/dist/cjs/components/CollectionPageNew/CollectionPage.st.css.js +2 -2
  40. package/dist/cjs/components/CollectionPageNew/CollectionPage.st.css.js.map +1 -1
  41. package/dist/cjs/components/CollectionSectionHeader/CollectionSectionHeader.st.css.js +3 -3
  42. package/dist/cjs/components/CollectionSectionHeader/CollectionSectionHeader.st.css.js.map +1 -1
  43. package/dist/cjs/components/CollectionTable/CollectionTable.st.css.js +2 -2
  44. package/dist/cjs/components/CollectionTable/CollectionTable.st.css.js.map +1 -1
  45. package/dist/cjs/components/CollectionTable/CollectionTableWSRTable.st.css.js +2 -2
  46. package/dist/cjs/components/CollectionTable/CollectionTableWSRTable.st.css.js.map +1 -1
  47. package/dist/cjs/components/CollectionToolbar/CollectionToolbar.st.css.js +5 -5
  48. package/dist/cjs/components/CollectionToolbar/CollectionToolbar.st.css.js.map +1 -1
  49. package/dist/cjs/components/CollectionToolbar/SearchOrCustomFilter.st.css.js +4 -4
  50. package/dist/cjs/components/CollectionToolbar/SearchOrCustomFilter.st.css.js.map +1 -1
  51. package/dist/cjs/components/CollectionViewsDropdown/AutoCompleteReadonly.st.css.js +2 -2
  52. package/dist/cjs/components/CollectionViewsDropdown/AutoCompleteReadonly.st.css.js.map +1 -1
  53. package/dist/cjs/components/CollectionViewsDropdown/ViewsDropdown.st.css.js +2 -2
  54. package/dist/cjs/components/CollectionViewsDropdown/ViewsDropdown.st.css.js.map +1 -1
  55. package/dist/cjs/components/CustomColumnsPanel/ColumnListTableListItem.js +15 -14
  56. package/dist/cjs/components/CustomColumnsPanel/ColumnListTableListItem.js.map +1 -1
  57. package/dist/cjs/components/CustomColumnsPanel/ColumnsList.js +8 -6
  58. package/dist/cjs/components/CustomColumnsPanel/ColumnsList.js.map +1 -1
  59. package/dist/cjs/components/CustomColumnsPanel/CustomColumnsPanel.js +51 -11
  60. package/dist/cjs/components/CustomColumnsPanel/CustomColumnsPanel.js.map +1 -1
  61. package/dist/cjs/components/CustomColumnsPanel/useSidePanelFieldActions.js +52 -0
  62. package/dist/cjs/components/CustomColumnsPanel/useSidePanelFieldActions.js.map +1 -0
  63. package/dist/cjs/components/DragHandle/DragHandle.st.css.js +2 -2
  64. package/dist/cjs/components/DragHandle/DragHandle.st.css.js.map +1 -1
  65. package/dist/cjs/components/EditableTable/EditableCell.js +6 -6
  66. package/dist/cjs/components/EditableTable/EditableCell.js.map +1 -1
  67. package/dist/cjs/components/EditableTable/EditableCell.st.css.js +3 -3
  68. package/dist/cjs/components/EditableTable/EditableCell.st.css.js.map +1 -1
  69. package/dist/cjs/components/EditableTable/EditableColumnHeader.uni.driver.js +8 -1
  70. package/dist/cjs/components/EditableTable/EditableColumnHeader.uni.driver.js.map +1 -1
  71. package/dist/cjs/components/EditableTable/EditableTable.js +12 -10
  72. package/dist/cjs/components/EditableTable/EditableTable.js.map +1 -1
  73. package/dist/cjs/components/EditableTable/HeaderActionsPopover.js +14 -99
  74. package/dist/cjs/components/EditableTable/HeaderActionsPopover.js.map +1 -1
  75. package/dist/cjs/components/EditableTable/HeaderActionsPopover.st.css +8 -10
  76. package/dist/cjs/components/EditableTable/HeaderActionsPopover.st.css.js +2 -2
  77. package/dist/cjs/components/EditableTable/HeaderActionsPopover.st.css.js.map +1 -1
  78. package/dist/cjs/components/EditableTable/cellTypes/CellViewLayout.st.css.js +2 -2
  79. package/dist/cjs/components/EditableTable/cellTypes/CellViewLayout.st.css.js.map +1 -1
  80. package/dist/cjs/components/EditableTable/cellTypes/boolean/Edit.st.css.js +3 -3
  81. package/dist/cjs/components/EditableTable/cellTypes/boolean/Edit.st.css.js.map +1 -1
  82. package/dist/cjs/components/EditableTable/cellTypes/boolean/View.st.css.js +3 -3
  83. package/dist/cjs/components/EditableTable/cellTypes/boolean/View.st.css.js.map +1 -1
  84. package/dist/cjs/components/EditableTable/cellTypes/date/Edit.js +4 -4
  85. package/dist/cjs/components/EditableTable/cellTypes/date/Edit.js.map +1 -1
  86. package/dist/cjs/components/EditableTable/cellTypes/date/Edit.st.css.js +3 -3
  87. package/dist/cjs/components/EditableTable/cellTypes/date/Edit.st.css.js.map +1 -1
  88. package/dist/cjs/components/EditableTable/cellTypes/date/View.st.css.js +2 -2
  89. package/dist/cjs/components/EditableTable/cellTypes/date/View.st.css.js.map +1 -1
  90. package/dist/cjs/components/EditableTable/cellTypes/email/Edit.st.css.js +3 -3
  91. package/dist/cjs/components/EditableTable/cellTypes/email/Edit.st.css.js.map +1 -1
  92. package/dist/cjs/components/EditableTable/cellTypes/email/View.st.css.js +2 -2
  93. package/dist/cjs/components/EditableTable/cellTypes/email/View.st.css.js.map +1 -1
  94. package/dist/cjs/components/EditableTable/cellTypes/image/View.js +2 -2
  95. package/dist/cjs/components/EditableTable/cellTypes/image/View.js.map +1 -1
  96. package/dist/cjs/components/EditableTable/cellTypes/mediaGallery/View.uni.driver.js.map +1 -1
  97. package/dist/cjs/components/EditableTable/cellTypes/number/Edit.st.css.js +3 -3
  98. package/dist/cjs/components/EditableTable/cellTypes/number/Edit.st.css.js.map +1 -1
  99. package/dist/cjs/components/EditableTable/cellTypes/number/View.st.css.js +3 -3
  100. package/dist/cjs/components/EditableTable/cellTypes/number/View.st.css.js.map +1 -1
  101. package/dist/cjs/components/EditableTable/cellTypes/object/Edit.st.css.js +3 -3
  102. package/dist/cjs/components/EditableTable/cellTypes/object/Edit.st.css.js.map +1 -1
  103. package/dist/cjs/components/EditableTable/cellTypes/object/View.st.css.js +2 -2
  104. package/dist/cjs/components/EditableTable/cellTypes/object/View.st.css.js.map +1 -1
  105. package/dist/cjs/components/EditableTable/cellTypes/select/Edit.st.css.js +3 -3
  106. package/dist/cjs/components/EditableTable/cellTypes/select/Edit.st.css.js.map +1 -1
  107. package/dist/cjs/components/EditableTable/cellTypes/text/Edit.js +7 -7
  108. package/dist/cjs/components/EditableTable/cellTypes/text/Edit.js.map +1 -1
  109. package/dist/cjs/components/EditableTable/cellTypes/text/Edit.st.css.js +4 -4
  110. package/dist/cjs/components/EditableTable/cellTypes/text/Edit.st.css.js.map +1 -1
  111. package/dist/cjs/components/EditableTable/cellTypes/text/View.st.css.js +2 -2
  112. package/dist/cjs/components/EditableTable/cellTypes/text/View.st.css.js.map +1 -1
  113. package/dist/cjs/components/EditableTable/cellTypes/url/Edit.js.map +1 -1
  114. package/dist/cjs/components/EditableTable/cellTypes/url/Edit.st.css.js +3 -3
  115. package/dist/cjs/components/EditableTable/cellTypes/url/Edit.st.css.js.map +1 -1
  116. package/dist/cjs/components/EditableTable/cellTypes/url/View.st.css.js +5 -5
  117. package/dist/cjs/components/EditableTable/cellTypes/url/View.st.css.js.map +1 -1
  118. package/dist/cjs/components/EditableTable/cellTypes/url/View.uni.driver.js.map +1 -1
  119. package/dist/cjs/components/EditableTable/useCellFocusAndEditing.js.map +1 -1
  120. package/dist/cjs/components/EditableTable/useHeaderActions.js +91 -0
  121. package/dist/cjs/components/EditableTable/useHeaderActions.js.map +1 -0
  122. package/dist/cjs/components/EntityPage/EntityPagePlain.st.css.js +2 -2
  123. package/dist/cjs/components/EntityPage/EntityPagePlain.st.css.js.map +1 -1
  124. package/dist/cjs/components/Fade/Fade.st.css.js +2 -2
  125. package/dist/cjs/components/Fade/Fade.st.css.js.map +1 -1
  126. package/dist/cjs/components/FieldActions/FieldActions.js +225 -0
  127. package/dist/cjs/components/FieldActions/FieldActions.js.map +1 -0
  128. package/dist/cjs/components/FieldActions/HeaderActionsPopover.js +121 -0
  129. package/dist/cjs/components/FieldActions/HeaderActionsPopover.js.map +1 -0
  130. package/dist/cjs/components/FieldActions/headerActionTypes.js.map +1 -0
  131. package/dist/cjs/components/FieldActions/index.js +13 -0
  132. package/dist/cjs/components/FieldActions/index.js.map +1 -0
  133. package/dist/cjs/components/Heading/Heading.st.css.js +2 -2
  134. package/dist/cjs/components/Heading/Heading.st.css.js.map +1 -1
  135. package/dist/cjs/components/ImportButton/ImportStepUpload.st.css.js +3 -3
  136. package/dist/cjs/components/ImportButton/ImportStepUpload.st.css.js.map +1 -1
  137. package/dist/cjs/components/InputOverflow/InputOverflow.st.css.js +2 -2
  138. package/dist/cjs/components/InputOverflow/InputOverflow.st.css.js.map +1 -1
  139. package/dist/cjs/components/LoadingRow/LoadingRow.st.css.js +3 -3
  140. package/dist/cjs/components/LoadingRow/LoadingRow.st.css.js.map +1 -1
  141. package/dist/cjs/components/MaxHeightText/MaxHeightText.st.css.js +2 -2
  142. package/dist/cjs/components/MaxHeightText/MaxHeightText.st.css.js.map +1 -1
  143. package/dist/cjs/components/MaxLines/MaxLines.st.css.js +2 -2
  144. package/dist/cjs/components/MaxLines/MaxLines.st.css.js.map +1 -1
  145. package/dist/cjs/components/MultiBulkActionToolbar/MultiBulkActionToolbar.st.css.js +5 -5
  146. package/dist/cjs/components/MultiBulkActionToolbar/MultiBulkActionToolbar.st.css.js.map +1 -1
  147. package/dist/cjs/components/NestedTable/NestedTablePlaceholderStatesRow.st.css.js +2 -2
  148. package/dist/cjs/components/NestedTable/NestedTablePlaceholderStatesRow.st.css.js.map +1 -1
  149. package/dist/cjs/components/NestedTable/NestedTableRow.st.css.js +5 -5
  150. package/dist/cjs/components/NestedTable/NestedTableRow.st.css.js.map +1 -1
  151. package/dist/cjs/components/NestedTableDragAndDrop/MultipleDragOverlayEffect.st.css.js +2 -2
  152. package/dist/cjs/components/NestedTableDragAndDrop/MultipleDragOverlayEffect.st.css.js.map +1 -1
  153. package/dist/cjs/components/NestedTableDragAndDrop/NestedTableDragAndDropRow.st.css.js +2 -2
  154. package/dist/cjs/components/NestedTableDragAndDrop/NestedTableDragAndDropRow.st.css.js.map +1 -1
  155. package/dist/cjs/components/PickerContent/PickerContent.st.css.js +2 -2
  156. package/dist/cjs/components/PickerContent/PickerContent.st.css.js.map +1 -1
  157. package/dist/cjs/components/PickerContent/PickerContentAdditionalStep.st.css.js +4 -4
  158. package/dist/cjs/components/PickerContent/PickerContentAdditionalStep.st.css.js.map +1 -1
  159. package/dist/cjs/components/PickerTableListItem/PickerTableListItem.st.css.js +2 -2
  160. package/dist/cjs/components/PickerTableListItem/PickerTableListItem.st.css.js.map +1 -1
  161. package/dist/cjs/components/SchemaCard/SchemaCard.js +9 -2
  162. package/dist/cjs/components/SchemaCard/SchemaCard.js.map +1 -1
  163. package/dist/cjs/components/ScrollableContent/ScrollableContent.st.css.js +2 -2
  164. package/dist/cjs/components/ScrollableContent/ScrollableContent.st.css.js.map +1 -1
  165. package/dist/cjs/components/SkeletonCard/SkeletonCard.st.css.js +3 -3
  166. package/dist/cjs/components/SkeletonCard/SkeletonCard.st.css.js.map +1 -1
  167. package/dist/cjs/components/SlidingModal/SlidingModal.st.css.js +2 -2
  168. package/dist/cjs/components/SlidingModal/SlidingModal.st.css.js.map +1 -1
  169. package/dist/cjs/components/TabsFilter/TabsFilter.st.css.js +3 -3
  170. package/dist/cjs/components/TabsFilter/TabsFilter.st.css.js.map +1 -1
  171. package/dist/cjs/components/Tags/ManageTags/ManageTagsModal/ManageTagsModal.st.css.js +2 -2
  172. package/dist/cjs/components/Tags/ManageTags/ManageTagsModal/ManageTagsModal.st.css.js.map +1 -1
  173. package/dist/cjs/components/TagsFilter/TagsFilter.js +1 -1
  174. package/dist/cjs/components/TagsFilter/TagsFilter.js.map +1 -1
  175. package/dist/cjs/components/ToolbarItem/ToolbarItem.st.css.js +2 -2
  176. package/dist/cjs/components/ToolbarItem/ToolbarItem.st.css.js.map +1 -1
  177. package/dist/cjs/components/ToolbarItemBox/ToolbarItemBox.st.css.js +2 -2
  178. package/dist/cjs/components/ToolbarItemBox/ToolbarItemBox.st.css.js.map +1 -1
  179. package/dist/cjs/components/common.st.css.js +4 -4
  180. package/dist/cjs/components/common.st.css.js.map +1 -1
  181. package/dist/cjs/hooks/useCloseOnAncestorScroll.js.map +1 -0
  182. package/dist/cjs/index.js.map +1 -1
  183. package/dist/cjs/providers/SchemaContext.js.map +1 -1
  184. package/dist/cjs/providers/SchemaProvider.js +56 -0
  185. package/dist/cjs/providers/SchemaProvider.js.map +1 -0
  186. package/dist/cjs/providers/index.js +6 -0
  187. package/dist/cjs/providers/index.js.map +1 -1
  188. package/dist/cjs/state/CollectionPage/CollectionPageHeader.st.css.js +2 -2
  189. package/dist/cjs/state/CollectionPage/CollectionPageHeader.st.css.js.map +1 -1
  190. package/dist/cjs/state/EditableTable/EditableTableState.js +1 -1
  191. package/dist/cjs/state/EditableTable/EditableTableState.js.map +1 -1
  192. package/dist/cjs/state/EditableTable/FieldActionsState.js +113 -2
  193. package/dist/cjs/state/EditableTable/FieldActionsState.js.map +1 -1
  194. package/dist/cjs/state/EditableTable/types.js.map +1 -1
  195. package/dist/cjs/state/FormPage/FormPageHeader.st.css.js +2 -2
  196. package/dist/cjs/state/FormPage/FormPageHeader.st.css.js.map +1 -1
  197. package/dist/cjs/state/ViewTypeState.js.map +1 -1
  198. package/dist/cjs/styles.global.css +1 -1
  199. package/dist/cjs/types/SchemaConfig.js.map +1 -1
  200. package/dist/cjs/version.js +1 -1
  201. package/dist/cjs/version.js.map +1 -1
  202. package/dist/docs/index.json +20 -20
  203. package/dist/esm/components/CardContainer/CardContainer.st.css.js +2 -2
  204. package/dist/esm/components/CardContainer/CardContainer.st.css.js.map +1 -1
  205. package/dist/esm/components/CmsFieldManagement/CmsFieldForm.js +21 -0
  206. package/dist/esm/components/CmsFieldManagement/CmsFieldForm.js.map +1 -0
  207. package/dist/esm/components/CmsFieldManagement/CmsFieldModal.js +9 -0
  208. package/dist/esm/components/CmsFieldManagement/CmsFieldModal.js.map +1 -0
  209. package/dist/esm/components/CmsFieldManagement/CmsFieldModalState.js +76 -0
  210. package/dist/esm/components/CmsFieldManagement/CmsFieldModalState.js.map +1 -0
  211. package/dist/esm/components/CmsFieldManagement/CmsFormState.js +172 -0
  212. package/dist/esm/components/CmsFieldManagement/CmsFormState.js.map +1 -0
  213. package/dist/esm/components/CmsFieldManagement/Sections/BasicsSection.js +16 -0
  214. package/dist/esm/components/CmsFieldManagement/Sections/BasicsSection.js.map +1 -0
  215. package/dist/esm/components/CmsFieldManagement/Sections/ValidationAndDefaultsSection.js +35 -0
  216. package/dist/esm/components/CmsFieldManagement/Sections/ValidationAndDefaultsSection.js.map +1 -0
  217. package/dist/esm/components/CmsFieldManagement/Sections/ValidationSubSection.js +19 -0
  218. package/dist/esm/components/CmsFieldManagement/Sections/ValidationSubSection.js.map +1 -0
  219. package/dist/esm/components/CmsFieldManagement/fieldTypeUtils.js +9 -0
  220. package/dist/esm/components/CmsFieldManagement/fieldTypeUtils.js.map +1 -0
  221. package/dist/esm/components/CmsFieldManagement/fieldValidationRulesMap.js +13 -0
  222. package/dist/esm/components/CmsFieldManagement/fieldValidationRulesMap.js.map +1 -0
  223. package/dist/esm/components/CmsFieldManagement/formFields/CharactersLimitInput.js +8 -0
  224. package/dist/esm/components/CmsFieldManagement/formFields/CharactersLimitInput.js.map +1 -0
  225. package/dist/esm/components/CmsFieldManagement/formFields/FieldNameInput.js +5 -0
  226. package/dist/esm/components/CmsFieldManagement/formFields/FieldNameInput.js.map +1 -0
  227. package/dist/esm/components/CmsFieldManagement/formFields/FieldPiiToggle.js +5 -0
  228. package/dist/esm/components/CmsFieldManagement/formFields/FieldPiiToggle.js.map +1 -0
  229. package/dist/esm/components/CmsFieldManagement/formFields/FieldTypeSelect.js +23 -0
  230. package/dist/esm/components/CmsFieldManagement/formFields/FieldTypeSelect.js.map +1 -0
  231. package/dist/esm/components/CmsFieldManagement/formFields/RequiredToggle.js +4 -0
  232. package/dist/esm/components/CmsFieldManagement/formFields/RequiredToggle.js.map +1 -0
  233. package/dist/esm/components/CmsFieldManagement/index.js +2 -0
  234. package/dist/esm/components/CmsFieldManagement/index.js.map +1 -0
  235. package/dist/esm/components/CmsFieldManagement/toFieldSpec.js +23 -0
  236. package/dist/esm/components/CmsFieldManagement/toFieldSpec.js.map +1 -0
  237. package/dist/esm/components/CmsFieldManagement/types.js +2 -0
  238. package/dist/esm/components/CmsFieldManagement/types.js.map +1 -0
  239. package/dist/esm/components/Collapse/Collapse.st.css.js +2 -2
  240. package/dist/esm/components/CollectionPageNew/CollectionPage.st.css.js +2 -2
  241. package/dist/esm/components/CollectionSectionHeader/CollectionSectionHeader.st.css.js +2 -2
  242. package/dist/esm/components/CollectionTable/CollectionTable.st.css.js +2 -2
  243. package/dist/esm/components/CollectionTable/CollectionTableWSRTable.st.css.js +2 -2
  244. package/dist/esm/components/CollectionToolbar/CollectionToolbar.st.css.js +2 -2
  245. package/dist/esm/components/CollectionToolbar/CollectionToolbar.st.css.js.map +1 -1
  246. package/dist/esm/components/CollectionToolbar/SearchOrCustomFilter.st.css.js +2 -2
  247. package/dist/esm/components/CollectionViewsDropdown/AutoCompleteReadonly.st.css.js +2 -2
  248. package/dist/esm/components/CollectionViewsDropdown/ViewsDropdown.st.css.js +2 -2
  249. package/dist/esm/components/CustomColumnsPanel/ColumnListTableListItem.js +4 -3
  250. package/dist/esm/components/CustomColumnsPanel/ColumnListTableListItem.js.map +1 -1
  251. package/dist/esm/components/CustomColumnsPanel/ColumnsList.js +2 -2
  252. package/dist/esm/components/CustomColumnsPanel/ColumnsList.js.map +1 -1
  253. package/dist/esm/components/CustomColumnsPanel/CustomColumnsPanel.js +9 -3
  254. package/dist/esm/components/CustomColumnsPanel/CustomColumnsPanel.js.map +1 -1
  255. package/dist/esm/components/CustomColumnsPanel/useSidePanelFieldActions.js +43 -0
  256. package/dist/esm/components/CustomColumnsPanel/useSidePanelFieldActions.js.map +1 -0
  257. package/dist/esm/components/DragHandle/DragHandle.st.css.js +2 -2
  258. package/dist/esm/components/EditableTable/EditableCell.js.map +1 -1
  259. package/dist/esm/components/EditableTable/EditableCell.st.css.js +2 -2
  260. package/dist/esm/components/EditableTable/EditableColumnHeader.uni.driver.js +9 -0
  261. package/dist/esm/components/EditableTable/EditableColumnHeader.uni.driver.js.map +1 -1
  262. package/dist/esm/components/EditableTable/EditableTable.js +3 -3
  263. package/dist/esm/components/EditableTable/EditableTable.js.map +1 -1
  264. package/dist/esm/components/EditableTable/HeaderActionsPopover.js +5 -31
  265. package/dist/esm/components/EditableTable/HeaderActionsPopover.js.map +1 -1
  266. package/dist/esm/components/EditableTable/HeaderActionsPopover.st.css +8 -10
  267. package/dist/esm/components/EditableTable/HeaderActionsPopover.st.css.js +2 -2
  268. package/dist/esm/components/EditableTable/HeaderActionsPopover.st.css.js.map +1 -1
  269. package/dist/esm/components/EditableTable/cellTypes/CellViewLayout.st.css.js +2 -2
  270. package/dist/esm/components/EditableTable/cellTypes/boolean/Edit.st.css.js +2 -2
  271. package/dist/esm/components/EditableTable/cellTypes/boolean/Edit.st.css.js.map +1 -1
  272. package/dist/esm/components/EditableTable/cellTypes/boolean/View.st.css.js +2 -2
  273. package/dist/esm/components/EditableTable/cellTypes/date/Edit.js +4 -2
  274. package/dist/esm/components/EditableTable/cellTypes/date/Edit.js.map +1 -1
  275. package/dist/esm/components/EditableTable/cellTypes/date/Edit.st.css.js +2 -2
  276. package/dist/esm/components/EditableTable/cellTypes/date/View.st.css.js +2 -2
  277. package/dist/esm/components/EditableTable/cellTypes/email/Edit.st.css.js +2 -2
  278. package/dist/esm/components/EditableTable/cellTypes/email/View.st.css.js +2 -2
  279. package/dist/esm/components/EditableTable/cellTypes/email/View.st.css.js.map +1 -1
  280. package/dist/esm/components/EditableTable/cellTypes/image/View.js +1 -1
  281. package/dist/esm/components/EditableTable/cellTypes/image/View.js.map +1 -1
  282. package/dist/esm/components/EditableTable/cellTypes/mediaGallery/View.uni.driver.js +3 -1
  283. package/dist/esm/components/EditableTable/cellTypes/mediaGallery/View.uni.driver.js.map +1 -1
  284. package/dist/esm/components/EditableTable/cellTypes/number/Edit.st.css.js +2 -2
  285. package/dist/esm/components/EditableTable/cellTypes/number/View.st.css.js +2 -2
  286. package/dist/esm/components/EditableTable/cellTypes/object/Edit.st.css.js +2 -2
  287. package/dist/esm/components/EditableTable/cellTypes/object/Edit.st.css.js.map +1 -1
  288. package/dist/esm/components/EditableTable/cellTypes/object/View.st.css.js +2 -2
  289. package/dist/esm/components/EditableTable/cellTypes/select/Edit.st.css.js +2 -2
  290. package/dist/esm/components/EditableTable/cellTypes/text/Edit.js +7 -5
  291. package/dist/esm/components/EditableTable/cellTypes/text/Edit.js.map +1 -1
  292. package/dist/esm/components/EditableTable/cellTypes/text/Edit.st.css.js +2 -2
  293. package/dist/esm/components/EditableTable/cellTypes/text/View.st.css.js +2 -2
  294. package/dist/esm/components/EditableTable/cellTypes/url/Edit.js.map +1 -1
  295. package/dist/esm/components/EditableTable/cellTypes/url/Edit.st.css.js +2 -2
  296. package/dist/esm/components/EditableTable/cellTypes/url/View.st.css.js +2 -2
  297. package/dist/esm/components/EditableTable/cellTypes/url/View.st.css.js.map +1 -1
  298. package/dist/esm/components/EditableTable/cellTypes/url/View.uni.driver.js +1 -3
  299. package/dist/esm/components/EditableTable/cellTypes/url/View.uni.driver.js.map +1 -1
  300. package/dist/esm/components/EditableTable/useCellFocusAndEditing.js +4 -1
  301. package/dist/esm/components/EditableTable/useCellFocusAndEditing.js.map +1 -1
  302. package/dist/esm/components/EditableTable/useHeaderActions.js +82 -0
  303. package/dist/esm/components/EditableTable/useHeaderActions.js.map +1 -0
  304. package/dist/esm/components/EntityPage/EntityPagePlain.st.css.js +2 -2
  305. package/dist/esm/components/EntityPage/EntityPagePlain.st.css.js.map +1 -1
  306. package/dist/esm/components/Fade/Fade.st.css.js +2 -2
  307. package/dist/esm/components/FieldActions/FieldActions.js +152 -0
  308. package/dist/esm/components/FieldActions/FieldActions.js.map +1 -0
  309. package/dist/esm/components/FieldActions/HeaderActionsPopover.js +33 -0
  310. package/dist/esm/components/FieldActions/HeaderActionsPopover.js.map +1 -0
  311. package/dist/esm/components/FieldActions/headerActionTypes.js.map +1 -0
  312. package/dist/esm/components/FieldActions/index.js +3 -0
  313. package/dist/esm/components/FieldActions/index.js.map +1 -0
  314. package/dist/esm/components/Heading/Heading.st.css.js +2 -2
  315. package/dist/esm/components/ImportButton/ImportStepUpload.st.css.js +2 -2
  316. package/dist/esm/components/InputOverflow/InputOverflow.st.css.js +2 -2
  317. package/dist/esm/components/InputOverflow/InputOverflow.st.css.js.map +1 -1
  318. package/dist/esm/components/LoadingRow/LoadingRow.st.css.js +3 -3
  319. package/dist/esm/components/MaxHeightText/MaxHeightText.st.css.js +2 -2
  320. package/dist/esm/components/MaxLines/MaxLines.st.css.js +2 -2
  321. package/dist/esm/components/MultiBulkActionToolbar/MultiBulkActionToolbar.st.css.js +2 -2
  322. package/dist/esm/components/NestedTable/NestedTablePlaceholderStatesRow.st.css.js +2 -2
  323. package/dist/esm/components/NestedTable/NestedTableRow.st.css.js +2 -2
  324. package/dist/esm/components/NestedTable/NestedTableRow.st.css.js.map +1 -1
  325. package/dist/esm/components/NestedTableDragAndDrop/MultipleDragOverlayEffect.st.css.js +2 -2
  326. package/dist/esm/components/NestedTableDragAndDrop/NestedTableDragAndDropRow.st.css.js +2 -2
  327. package/dist/esm/components/PickerContent/PickerContent.st.css.js +2 -2
  328. package/dist/esm/components/PickerContent/PickerContent.st.css.js.map +1 -1
  329. package/dist/esm/components/PickerContent/PickerContentAdditionalStep.st.css.js +2 -2
  330. package/dist/esm/components/PickerTableListItem/PickerTableListItem.st.css.js +2 -2
  331. package/dist/esm/components/SchemaCard/SchemaCard.js +6 -5
  332. package/dist/esm/components/SchemaCard/SchemaCard.js.map +1 -1
  333. package/dist/esm/components/ScrollableContent/ScrollableContent.st.css.js +2 -2
  334. package/dist/esm/components/SkeletonCard/SkeletonCard.st.css.js +2 -2
  335. package/dist/esm/components/SlidingModal/SlidingModal.st.css.js +2 -2
  336. package/dist/esm/components/TabsFilter/TabsFilter.st.css.js +2 -2
  337. package/dist/esm/components/TabsFilter/TabsFilter.st.css.js.map +1 -1
  338. package/dist/esm/components/Tags/ManageTags/ManageTagsModal/ManageTagsModal.st.css.js +2 -2
  339. package/dist/esm/components/TagsFilter/TagsFilter.js +5 -1
  340. package/dist/esm/components/TagsFilter/TagsFilter.js.map +1 -1
  341. package/dist/esm/components/ToolbarItem/ToolbarItem.st.css.js +2 -2
  342. package/dist/esm/components/ToolbarItemBox/ToolbarItemBox.st.css.js +2 -2
  343. package/dist/esm/components/ToolbarItemBox/ToolbarItemBox.st.css.js.map +1 -1
  344. package/dist/esm/components/common.st.css.js +2 -2
  345. package/dist/esm/hooks/useCloseOnAncestorScroll.js.map +1 -0
  346. package/dist/esm/index.js.map +1 -1
  347. package/dist/esm/providers/SchemaContext.js.map +1 -1
  348. package/dist/esm/providers/SchemaProvider.js +26 -0
  349. package/dist/esm/providers/SchemaProvider.js.map +1 -0
  350. package/dist/esm/providers/index.js +1 -0
  351. package/dist/esm/providers/index.js.map +1 -1
  352. package/dist/esm/state/CollectionPage/CollectionPageHeader.st.css.js +2 -2
  353. package/dist/esm/state/EditableTable/EditableTableState.js +1 -1
  354. package/dist/esm/state/EditableTable/EditableTableState.js.map +1 -1
  355. package/dist/esm/state/EditableTable/FieldActionsState.js +114 -1
  356. package/dist/esm/state/EditableTable/FieldActionsState.js.map +1 -1
  357. package/dist/esm/state/FormPage/FormPageHeader.st.css.js +2 -2
  358. package/dist/esm/state/ViewTypeState.js +3 -1
  359. package/dist/esm/state/ViewTypeState.js.map +1 -1
  360. package/dist/esm/styles.global.css +1 -1
  361. package/dist/esm/version.js +1 -1
  362. package/dist/types/components/ActionCell/useActionCellColumn.d.ts +2 -2
  363. package/dist/types/components/ActionCell/useActionCellColumnBase.d.ts +2 -2
  364. package/dist/types/components/CardContainer/CardContainer.st.css.d.ts.map +1 -1
  365. package/dist/types/components/CmsFieldManagement/CmsFieldForm.d.ts +10 -0
  366. package/dist/types/components/CmsFieldManagement/CmsFieldForm.d.ts.map +1 -0
  367. package/dist/types/components/CmsFieldManagement/CmsFieldModal.d.ts +8 -0
  368. package/dist/types/components/CmsFieldManagement/CmsFieldModal.d.ts.map +1 -0
  369. package/dist/types/components/CmsFieldManagement/CmsFieldModalState.d.ts +14 -0
  370. package/dist/types/components/CmsFieldManagement/CmsFieldModalState.d.ts.map +1 -0
  371. package/dist/types/components/CmsFieldManagement/CmsFormState.d.ts +45 -0
  372. package/dist/types/components/CmsFieldManagement/CmsFormState.d.ts.map +1 -0
  373. package/dist/types/components/CmsFieldManagement/Sections/BasicsSection.d.ts +10 -0
  374. package/dist/types/components/CmsFieldManagement/Sections/BasicsSection.d.ts.map +1 -0
  375. package/dist/types/components/CmsFieldManagement/Sections/ValidationAndDefaultsSection.d.ts +10 -0
  376. package/dist/types/components/CmsFieldManagement/Sections/ValidationAndDefaultsSection.d.ts.map +1 -0
  377. package/dist/types/components/CmsFieldManagement/Sections/ValidationSubSection.d.ts +10 -0
  378. package/dist/types/components/CmsFieldManagement/Sections/ValidationSubSection.d.ts.map +1 -0
  379. package/dist/types/components/CmsFieldManagement/fieldTypeUtils.d.ts +5 -0
  380. package/dist/types/components/CmsFieldManagement/fieldTypeUtils.d.ts.map +1 -0
  381. package/dist/types/components/CmsFieldManagement/fieldValidationRulesMap.d.ts +3 -0
  382. package/dist/types/components/CmsFieldManagement/fieldValidationRulesMap.d.ts.map +1 -0
  383. package/dist/types/components/CmsFieldManagement/formFields/CharactersLimitInput.d.ts +10 -0
  384. package/dist/types/components/CmsFieldManagement/formFields/CharactersLimitInput.d.ts.map +1 -0
  385. package/dist/types/components/CmsFieldManagement/formFields/FieldNameInput.d.ts +10 -0
  386. package/dist/types/components/CmsFieldManagement/formFields/FieldNameInput.d.ts.map +1 -0
  387. package/dist/types/components/CmsFieldManagement/formFields/FieldPiiToggle.d.ts +9 -0
  388. package/dist/types/components/CmsFieldManagement/formFields/FieldPiiToggle.d.ts.map +1 -0
  389. package/dist/types/components/CmsFieldManagement/formFields/FieldTypeSelect.d.ts +11 -0
  390. package/dist/types/components/CmsFieldManagement/formFields/FieldTypeSelect.d.ts.map +1 -0
  391. package/dist/types/components/CmsFieldManagement/formFields/RequiredToggle.d.ts +8 -0
  392. package/dist/types/components/CmsFieldManagement/formFields/RequiredToggle.d.ts.map +1 -0
  393. package/dist/types/components/CmsFieldManagement/index.d.ts +2 -0
  394. package/dist/types/components/CmsFieldManagement/index.d.ts.map +1 -0
  395. package/dist/types/components/CmsFieldManagement/toFieldSpec.d.ts +4 -0
  396. package/dist/types/components/CmsFieldManagement/toFieldSpec.d.ts.map +1 -0
  397. package/dist/types/components/CmsFieldManagement/types.d.ts +15 -0
  398. package/dist/types/components/CmsFieldManagement/types.d.ts.map +1 -0
  399. package/dist/types/components/CollectionFilter/CollectionFilterState.d.ts +1 -1
  400. package/dist/types/components/CollectionTable/CollectionTable.uni.driver.d.ts +24 -24
  401. package/dist/types/components/CollectionToolbar/CollectionToolbar.st.css.d.ts.map +1 -1
  402. package/dist/types/components/CollectionToolbar/CollectionToolbar.uni.driver.d.ts +11 -11
  403. package/dist/types/components/CustomColumnsPanel/ColumnListTableListItem.d.ts +1 -0
  404. package/dist/types/components/CustomColumnsPanel/ColumnListTableListItem.d.ts.map +1 -1
  405. package/dist/types/components/CustomColumnsPanel/ColumnsList.d.ts +2 -1
  406. package/dist/types/components/CustomColumnsPanel/ColumnsList.d.ts.map +1 -1
  407. package/dist/types/components/CustomColumnsPanel/CustomColumnsPanel.d.ts.map +1 -1
  408. package/dist/types/components/CustomColumnsPanel/useSidePanelFieldActions.d.ts +6 -0
  409. package/dist/types/components/CustomColumnsPanel/useSidePanelFieldActions.d.ts.map +1 -0
  410. package/dist/types/components/CustomFieldModal/CustomFieldModal.uni.driver.d.ts +2 -2
  411. package/dist/types/components/CustomFieldsWidget/CustomFieldsWidget.uni.driver.d.ts +3 -3
  412. package/dist/types/components/DropdownFilter/CollectionDropdownFilter.uni.driver.d.ts +1 -1
  413. package/dist/types/components/EditableTable/EditableCell.d.ts.map +1 -1
  414. package/dist/types/components/EditableTable/EditableColumnHeader.uni.driver.d.ts +2 -0
  415. package/dist/types/components/EditableTable/EditableColumnHeader.uni.driver.d.ts.map +1 -1
  416. package/dist/types/components/EditableTable/EditableTable.d.ts +1 -1
  417. package/dist/types/components/EditableTable/EditableTable.d.ts.map +1 -1
  418. package/dist/types/components/EditableTable/EditableTable.uni.driver.d.ts +1 -0
  419. package/dist/types/components/EditableTable/EditableTable.uni.driver.d.ts.map +1 -1
  420. package/dist/types/components/EditableTable/HeaderActionsPopover.d.ts +2 -6
  421. package/dist/types/components/EditableTable/HeaderActionsPopover.d.ts.map +1 -1
  422. package/dist/types/components/EditableTable/HeaderActionsPopover.st.css.d.ts.map +1 -1
  423. package/dist/types/components/EditableTable/cellTypes/boolean/Edit.st.css.d.ts.map +1 -1
  424. package/dist/types/components/EditableTable/cellTypes/date/Edit.d.ts.map +1 -1
  425. package/dist/types/components/EditableTable/cellTypes/email/View.st.css.d.ts.map +1 -1
  426. package/dist/types/components/EditableTable/cellTypes/image/View.d.ts.map +1 -1
  427. package/dist/types/components/EditableTable/cellTypes/mediaGallery/View.uni.driver.d.ts.map +1 -1
  428. package/dist/types/components/EditableTable/cellTypes/object/Edit.st.css.d.ts.map +1 -1
  429. package/dist/types/components/EditableTable/cellTypes/text/Edit.d.ts.map +1 -1
  430. package/dist/types/components/EditableTable/cellTypes/url/Edit.d.ts.map +1 -1
  431. package/dist/types/components/EditableTable/cellTypes/url/View.st.css.d.ts.map +1 -1
  432. package/dist/types/components/EditableTable/cellTypes/url/View.uni.driver.d.ts.map +1 -1
  433. package/dist/types/components/EditableTable/useCellFocusAndEditing.d.ts.map +1 -1
  434. package/dist/types/components/EditableTable/useHeaderActions.d.ts +6 -0
  435. package/dist/types/components/EditableTable/useHeaderActions.d.ts.map +1 -0
  436. package/dist/types/components/EntityPage/EntityPagePlain.st.css.d.ts.map +1 -1
  437. package/dist/types/components/FieldActions/FieldActions.d.ts +40 -0
  438. package/dist/types/components/FieldActions/FieldActions.d.ts.map +1 -0
  439. package/dist/types/components/FieldActions/HeaderActionsPopover.d.ts +9 -0
  440. package/dist/types/components/FieldActions/HeaderActionsPopover.d.ts.map +1 -0
  441. package/dist/types/components/{EditableTable → FieldActions}/headerActionTypes.d.ts +2 -0
  442. package/dist/types/components/FieldActions/headerActionTypes.d.ts.map +1 -0
  443. package/dist/types/components/FieldActions/index.d.ts +6 -0
  444. package/dist/types/components/FieldActions/index.d.ts.map +1 -0
  445. package/dist/types/components/FiltersPanel/FiltersPanel.uni.driver.d.ts +4 -4
  446. package/dist/types/components/Grid/Grid.uni.driver.d.ts +13 -13
  447. package/dist/types/components/Grid/GridFolders.uni.driver.d.ts +38 -38
  448. package/dist/types/components/Grid/GridFoldersSection.uni.driver.d.ts +13 -13
  449. package/dist/types/components/InputOverflow/InputOverflow.st.css.d.ts.map +1 -1
  450. package/dist/types/components/Kanban/Kanban.uni.driver.d.ts +11 -11
  451. package/dist/types/components/Kanban/KanbanCardActionsHelper.d.ts +44 -44
  452. package/dist/types/components/Kanban/useCardActions.d.ts +44 -44
  453. package/dist/types/components/LayoutSwitch/LayoutSwitch.uni.driver.d.ts +40 -39
  454. package/dist/types/components/LayoutSwitch/LayoutSwitch.uni.driver.d.ts.map +1 -1
  455. package/dist/types/components/NestedTable/NestedTable.uni.driver.d.ts +37 -37
  456. package/dist/types/components/NestedTable/NestedTableRow.st.css.d.ts.map +1 -1
  457. package/dist/types/components/PickerContent/PickerContent.st.css.d.ts.map +1 -1
  458. package/dist/types/components/ResponsiveButton/ResponsiveButton.d.ts +1 -1
  459. package/dist/types/components/SchemaCard/SchemaCard.d.ts.map +1 -1
  460. package/dist/types/components/SummaryBar/SummaryBar.uni.driver.d.ts +1 -1
  461. package/dist/types/components/Table/Table.uni.driver.d.ts +26 -26
  462. package/dist/types/components/TableFolders/TableFolders.uni.driver.d.ts +37 -37
  463. package/dist/types/components/TableGridSwitch/TableGridSwitch.uni.driver.d.ts +40 -40
  464. package/dist/types/components/TabsFilter/TabsFilter.st.css.d.ts.map +1 -1
  465. package/dist/types/components/TabsFilter/TabsFilter.uni.driver.d.ts +1 -1
  466. package/dist/types/components/TagsFilter/TagsFilter.d.ts.map +1 -1
  467. package/dist/types/components/ToolbarItemBox/ToolbarItemBox.st.css.d.ts.map +1 -1
  468. package/dist/types/hooks/useCloseOnAncestorScroll.d.ts.map +1 -0
  469. package/dist/types/hooks/useCollectionOptions.d.ts +10 -10
  470. package/dist/types/index.d.ts +1 -0
  471. package/dist/types/index.d.ts.map +1 -1
  472. package/dist/types/providers/SchemaContext.d.ts +2 -0
  473. package/dist/types/providers/SchemaContext.d.ts.map +1 -1
  474. package/dist/types/providers/SchemaProvider.d.ts +9 -0
  475. package/dist/types/providers/SchemaProvider.d.ts.map +1 -0
  476. package/dist/types/providers/index.d.ts +1 -0
  477. package/dist/types/providers/index.d.ts.map +1 -1
  478. package/dist/types/state/EditableTable/EditableTableState.d.ts +2 -5
  479. package/dist/types/state/EditableTable/EditableTableState.d.ts.map +1 -1
  480. package/dist/types/state/EditableTable/FieldActionsState.d.ts +11 -2
  481. package/dist/types/state/EditableTable/FieldActionsState.d.ts.map +1 -1
  482. package/dist/types/state/EditableTable/types.d.ts +4 -0
  483. package/dist/types/state/EditableTable/types.d.ts.map +1 -1
  484. package/dist/types/state/ViewTypeState.d.ts.map +1 -1
  485. package/dist/types/testkit/enzyme.d.ts +194 -194
  486. package/dist/types/testkit/jsdom.d.ts +248 -246
  487. package/dist/types/testkit/jsdom.d.ts.map +1 -1
  488. package/dist/types/testkit/playwright.d.ts +195 -194
  489. package/dist/types/testkit/playwright.d.ts.map +1 -1
  490. package/dist/types/testkit/puppeteer.d.ts +206 -205
  491. package/dist/types/testkit/puppeteer.d.ts.map +1 -1
  492. package/dist/types/types/SchemaConfig.d.ts +9 -0
  493. package/dist/types/types/SchemaConfig.d.ts.map +1 -1
  494. package/dist/types/version.d.ts +1 -1
  495. package/package.json +6 -6
  496. package/src/components/CardContainer/CardContainer.st.css.ts +2 -2
  497. package/src/components/CmsFieldManagement/CmsFieldForm.tsx +63 -0
  498. package/src/components/CmsFieldManagement/CmsFieldModal.tsx +23 -0
  499. package/src/components/CmsFieldManagement/CmsFieldModalState.ts +100 -0
  500. package/src/components/CmsFieldManagement/CmsFormState.ts +238 -0
  501. package/src/components/CmsFieldManagement/Sections/BasicsSection.tsx +46 -0
  502. package/src/components/CmsFieldManagement/Sections/ValidationAndDefaultsSection.tsx +67 -0
  503. package/src/components/CmsFieldManagement/Sections/ValidationSubSection.tsx +51 -0
  504. package/src/components/CmsFieldManagement/fieldTypeUtils.ts +17 -0
  505. package/src/components/CmsFieldManagement/fieldValidationRulesMap.ts +18 -0
  506. package/src/components/CmsFieldManagement/formFields/CharactersLimitInput.tsx +34 -0
  507. package/src/components/CmsFieldManagement/formFields/FieldNameInput.tsx +31 -0
  508. package/src/components/CmsFieldManagement/formFields/FieldPiiToggle.tsx +24 -0
  509. package/src/components/CmsFieldManagement/formFields/FieldTypeSelect.tsx +55 -0
  510. package/src/components/CmsFieldManagement/formFields/RequiredToggle.tsx +18 -0
  511. package/src/components/CmsFieldManagement/index.ts +1 -0
  512. package/src/components/CmsFieldManagement/toFieldSpec.ts +37 -0
  513. package/src/components/CmsFieldManagement/types.ts +21 -0
  514. package/src/components/Collapse/Collapse.st.css.ts +2 -2
  515. package/src/components/CollectionPageNew/CollectionPage.st.css.ts +2 -2
  516. package/src/components/CollectionSectionHeader/CollectionSectionHeader.st.css.ts +2 -2
  517. package/src/components/CollectionTable/CollectionTable.st.css.ts +2 -2
  518. package/src/components/CollectionTable/CollectionTableWSRTable.st.css.ts +2 -2
  519. package/src/components/CollectionToolbar/CollectionToolbar.st.css.ts +2 -2
  520. package/src/components/CollectionToolbar/SearchOrCustomFilter.st.css.ts +2 -2
  521. package/src/components/CollectionViewsDropdown/AutoCompleteReadonly.st.css.ts +2 -2
  522. package/src/components/CollectionViewsDropdown/ViewsDropdown.st.css.ts +2 -2
  523. package/src/components/CustomColumnsPanel/ColumnListTableListItem.tsx +5 -1
  524. package/src/components/CustomColumnsPanel/ColumnsList.tsx +4 -2
  525. package/src/components/CustomColumnsPanel/CustomColumnsPanel.tsx +25 -2
  526. package/src/components/CustomColumnsPanel/useSidePanelFieldActions.tsx +69 -0
  527. package/src/components/DragHandle/DragHandle.st.css.ts +2 -2
  528. package/src/components/EditableTable/EditableCell.st.css.ts +2 -2
  529. package/src/components/EditableTable/EditableCell.tsx +5 -8
  530. package/src/components/EditableTable/EditableColumnHeader.uni.driver.ts +10 -0
  531. package/src/components/EditableTable/EditableTable.tsx +11 -3
  532. package/src/components/EditableTable/HeaderActionsPopover.st.css +8 -10
  533. package/src/components/EditableTable/HeaderActionsPopover.st.css.ts +2 -2
  534. package/src/components/EditableTable/HeaderActionsPopover.tsx +9 -84
  535. package/src/components/EditableTable/cellTypes/CellViewLayout.st.css.ts +2 -2
  536. package/src/components/EditableTable/cellTypes/boolean/Edit.st.css.ts +2 -2
  537. package/src/components/EditableTable/cellTypes/boolean/View.st.css.ts +2 -2
  538. package/src/components/EditableTable/cellTypes/date/Edit.st.css.ts +2 -2
  539. package/src/components/EditableTable/cellTypes/date/Edit.tsx +6 -2
  540. package/src/components/EditableTable/cellTypes/date/View.st.css.ts +2 -2
  541. package/src/components/EditableTable/cellTypes/email/Edit.st.css.ts +2 -2
  542. package/src/components/EditableTable/cellTypes/email/View.st.css.ts +2 -2
  543. package/src/components/EditableTable/cellTypes/image/View.tsx +3 -3
  544. package/src/components/EditableTable/cellTypes/mediaGallery/View.uni.driver.ts +3 -1
  545. package/src/components/EditableTable/cellTypes/number/Edit.st.css.ts +2 -2
  546. package/src/components/EditableTable/cellTypes/number/View.st.css.ts +2 -2
  547. package/src/components/EditableTable/cellTypes/object/Edit.st.css.ts +2 -2
  548. package/src/components/EditableTable/cellTypes/object/View.st.css.ts +2 -2
  549. package/src/components/EditableTable/cellTypes/select/Edit.st.css.ts +2 -2
  550. package/src/components/EditableTable/cellTypes/text/Edit.st.css.ts +2 -2
  551. package/src/components/EditableTable/cellTypes/text/Edit.tsx +24 -13
  552. package/src/components/EditableTable/cellTypes/text/View.st.css.ts +2 -2
  553. package/src/components/EditableTable/cellTypes/url/Edit.st.css.ts +2 -2
  554. package/src/components/EditableTable/cellTypes/url/Edit.tsx +8 -2
  555. package/src/components/EditableTable/cellTypes/url/View.st.css.ts +2 -2
  556. package/src/components/EditableTable/cellTypes/url/View.uni.driver.ts +1 -3
  557. package/src/components/EditableTable/useCellFocusAndEditing.ts +4 -1
  558. package/src/components/EditableTable/useHeaderActions.tsx +120 -0
  559. package/src/components/EntityPage/EntityPagePlain.st.css.ts +2 -2
  560. package/src/components/Fade/Fade.st.css.ts +2 -2
  561. package/src/components/FieldActions/FieldActions.tsx +248 -0
  562. package/src/components/FieldActions/HeaderActionsPopover.tsx +99 -0
  563. package/src/components/{EditableTable → FieldActions}/headerActionTypes.ts +2 -0
  564. package/src/components/FieldActions/index.ts +17 -0
  565. package/src/components/Heading/Heading.st.css.ts +2 -2
  566. package/src/components/ImportButton/ImportStepUpload.st.css.ts +2 -2
  567. package/src/components/InputOverflow/InputOverflow.st.css.ts +2 -2
  568. package/src/components/LoadingRow/LoadingRow.st.css.ts +3 -3
  569. package/src/components/MaxHeightText/MaxHeightText.st.css.ts +2 -2
  570. package/src/components/MaxLines/MaxLines.st.css.ts +2 -2
  571. package/src/components/MultiBulkActionToolbar/MultiBulkActionToolbar.st.css.ts +2 -2
  572. package/src/components/NestedTable/NestedTablePlaceholderStatesRow.st.css.ts +2 -2
  573. package/src/components/NestedTable/NestedTableRow.st.css.ts +2 -2
  574. package/src/components/NestedTableDragAndDrop/MultipleDragOverlayEffect.st.css.ts +2 -2
  575. package/src/components/NestedTableDragAndDrop/NestedTableDragAndDropRow.st.css.ts +2 -2
  576. package/src/components/PickerContent/PickerContent.st.css.ts +2 -2
  577. package/src/components/PickerContent/PickerContentAdditionalStep.st.css.ts +2 -2
  578. package/src/components/PickerTableListItem/PickerTableListItem.st.css.ts +2 -2
  579. package/src/components/SchemaCard/SchemaCard.tsx +7 -5
  580. package/src/components/ScrollableContent/ScrollableContent.st.css.ts +2 -2
  581. package/src/components/SkeletonCard/SkeletonCard.st.css.ts +2 -2
  582. package/src/components/SlidingModal/SlidingModal.st.css.ts +2 -2
  583. package/src/components/TabsFilter/TabsFilter.st.css.ts +2 -2
  584. package/src/components/Tags/ManageTags/ManageTagsModal/ManageTagsModal.st.css.ts +2 -2
  585. package/src/components/TagsFilter/TagsFilter.tsx +6 -4
  586. package/src/components/ToolbarItem/ToolbarItem.st.css.ts +2 -2
  587. package/src/components/ToolbarItemBox/ToolbarItemBox.st.css.ts +2 -2
  588. package/src/components/common.st.css.ts +2 -2
  589. package/src/index.ts +7 -0
  590. package/src/providers/{SchemaContext.tsx → SchemaContext.ts} +2 -0
  591. package/src/providers/SchemaProvider.tsx +50 -0
  592. package/src/providers/index.ts +1 -0
  593. package/src/state/CollectionPage/CollectionPageHeader.st.css.ts +2 -2
  594. package/src/state/EditableTable/EditableTableState.ts +3 -5
  595. package/src/state/EditableTable/FieldActionsState.ts +137 -1
  596. package/src/state/EditableTable/types.ts +6 -0
  597. package/src/state/FormPage/FormPageHeader.st.css.ts +2 -2
  598. package/src/state/ViewTypeState.ts +3 -1
  599. package/src/styles.global.css +1 -1
  600. package/src/types/SchemaConfig.ts +10 -0
  601. package/src/version.ts +1 -1
  602. package/dist/cjs/components/EditableTable/headerActionTypes.js.map +0 -1
  603. package/dist/cjs/components/EditableTable/useBuiltInHeaderActions.js +0 -130
  604. package/dist/cjs/components/EditableTable/useBuiltInHeaderActions.js.map +0 -1
  605. package/dist/cjs/components/EditableTable/useCloseOnAncestorScroll.js.map +0 -1
  606. package/dist/esm/components/EditableTable/headerActionTypes.js.map +0 -1
  607. package/dist/esm/components/EditableTable/useBuiltInHeaderActions.js +0 -84
  608. package/dist/esm/components/EditableTable/useBuiltInHeaderActions.js.map +0 -1
  609. package/dist/esm/components/EditableTable/useCloseOnAncestorScroll.js.map +0 -1
  610. package/dist/types/components/EditableTable/headerActionTypes.d.ts.map +0 -1
  611. package/dist/types/components/EditableTable/useBuiltInHeaderActions.d.ts +0 -6
  612. package/dist/types/components/EditableTable/useBuiltInHeaderActions.d.ts.map +0 -1
  613. package/dist/types/components/EditableTable/useCloseOnAncestorScroll.d.ts.map +0 -1
  614. package/src/components/EditableTable/useBuiltInHeaderActions.tsx +0 -116
  615. /package/dist/cjs/components/{EditableTable → FieldActions}/headerActionTypes.js +0 -0
  616. /package/dist/cjs/{components/EditableTable → hooks}/useCloseOnAncestorScroll.js +0 -0
  617. /package/dist/esm/components/{EditableTable → FieldActions}/headerActionTypes.js +0 -0
  618. /package/dist/esm/{components/EditableTable → hooks}/useCloseOnAncestorScroll.js +0 -0
  619. /package/dist/types/{components/EditableTable → hooks}/useCloseOnAncestorScroll.d.ts +0 -0
  620. /package/src/{components/EditableTable → hooks}/useCloseOnAncestorScroll.ts +0 -0
@@ -0,0 +1,23 @@
1
+ import React from 'react';
2
+ import { observer } from 'mobx-react-lite';
3
+ import { CustomActionModal } from '../ActionModal';
4
+ import { CmsFieldForm } from './CmsFieldForm';
5
+ import { CmsFieldModalState } from './CmsFieldModalState';
6
+
7
+ export const CmsFieldModal = observer(
8
+ ({ state }: { state: CmsFieldModalState }) => {
9
+ const { formState } = state;
10
+
11
+ return (
12
+ <CustomActionModal
13
+ dataHook="cms-field-modal"
14
+ state={state.modal}
15
+ onAfterClose={() => state.reset()}
16
+ title={formState?.mode === 'edit' ? 'Edit field' : 'Add a field'}
17
+ content={formState ? <CmsFieldForm state={formState} /> : null}
18
+ primaryButtonText="Save"
19
+ secondaryButtonText="Cancel"
20
+ />
21
+ );
22
+ },
23
+ );
@@ -0,0 +1,100 @@
1
+ import { action, makeObservable, observable } from 'mobx';
2
+ import { ConditionalModalState, type ToastConfig } from '@wix/bex-core';
3
+ import { Field, SchemaConfig } from '../../types/SchemaConfig';
4
+ import { CmsFormState } from './CmsFormState';
5
+ import { toFieldSpec } from './toFieldSpec';
6
+ import { getFieldTypeValidationRulesList } from './fieldValidationRulesMap';
7
+
8
+ export class CmsFieldModalState {
9
+ private readonly getSchema: () => SchemaConfig;
10
+ private readonly resolveError: (e: unknown) => ToastConfig;
11
+ readonly modal: ConditionalModalState<null>;
12
+ formState: CmsFormState | null = null;
13
+
14
+ constructor(
15
+ getSchema: () => SchemaConfig,
16
+ resolveError: (e: unknown) => ToastConfig,
17
+ ) {
18
+ this.getSchema = getSchema;
19
+ this.resolveError = resolveError;
20
+ this.modal = new ConditionalModalState({
21
+ onConfirm: () => this.submit(),
22
+ });
23
+
24
+ makeObservable(this, {
25
+ formState: observable.ref,
26
+ open: action,
27
+ reset: action,
28
+ });
29
+ }
30
+
31
+ open(fieldId?: string) {
32
+ const schemaConfig = this.getSchema();
33
+
34
+ this.formState = new CmsFormState({
35
+ schemaConfig,
36
+ getValidationRules: getFieldTypeValidationRulesList,
37
+ });
38
+
39
+ if (fieldId) {
40
+ const field = schemaConfig.fields[fieldId];
41
+ if (!field) {
42
+ console.warn(`[CmsFieldModalState] Missing field "${fieldId}"`);
43
+ return;
44
+ }
45
+
46
+ this.formState.setMode('edit');
47
+ this.formState.loadField(field);
48
+ }
49
+
50
+ this.modal.open(null);
51
+ }
52
+
53
+ reset() {
54
+ this.formState = null;
55
+ }
56
+
57
+ private async submit(): Promise<void> {
58
+ const { formState } = this;
59
+ if (!formState) {
60
+ return;
61
+ }
62
+ const schemaConfig = this.getSchema();
63
+
64
+ if (formState.hasInvalidFields || !formState.properties.type) {
65
+ formState.enableShowValidationError();
66
+ throw new Error('validation');
67
+ }
68
+
69
+ try {
70
+ const { type, ...rest } = formState.properties;
71
+ const fieldSpec = toFieldSpec({ ...rest, type }, formState.fieldRules);
72
+
73
+ if (formState.mode === 'edit') {
74
+ if (!formState.editingFieldId) {
75
+ throw new Error('Missing editing field id for CMS field update');
76
+ }
77
+ if (!schemaConfig.fieldActions?.editField) {
78
+ throw new Error(
79
+ 'SchemaConfig.fieldActions.editField is not configured',
80
+ );
81
+ }
82
+ await schemaConfig.fieldActions.editField(
83
+ formState.editingFieldId,
84
+ fieldSpec,
85
+ );
86
+ schemaConfig.refresh?.();
87
+ return;
88
+ }
89
+
90
+ if (!schemaConfig.fieldActions?.addField) {
91
+ throw new Error('SchemaConfig.fieldActions.addField is not configured');
92
+ }
93
+ await schemaConfig.fieldActions.addField(fieldSpec as Field);
94
+ schemaConfig.refresh?.();
95
+ } catch (e) {
96
+ formState.setErrorToastConfig(this.resolveError(e));
97
+ throw e;
98
+ }
99
+ }
100
+ }
@@ -0,0 +1,238 @@
1
+ import { action, computed, makeObservable, observable } from 'mobx';
2
+ import type { ToastConfig } from '@wix/bex-core';
3
+ import type { Field, SchemaConfig } from '../../types/SchemaConfig';
4
+ import {
5
+ isPIISupportedByFieldType,
6
+ isSelectableFieldType,
7
+ } from './fieldTypeUtils';
8
+ import type {
9
+ FieldProperties,
10
+ FieldPropertiesState,
11
+ FieldRules,
12
+ SelectableFieldTypes,
13
+ ValidationRule,
14
+ } from './types';
15
+
16
+ export interface CmsFormStateParams {
17
+ schemaConfig: SchemaConfig;
18
+ getValidationRules: (t: SelectableFieldTypes) => ValidationRule[];
19
+ mode?: 'new' | 'edit';
20
+ editingFieldId?: string;
21
+ }
22
+
23
+ function defaultProperties(): FieldPropertiesState {
24
+ return {
25
+ type: undefined,
26
+ name: '',
27
+ isPii: false,
28
+ helpText: '',
29
+ };
30
+ }
31
+
32
+ // TODO: confirm vs cms-web
33
+ const NAME_MAX_LENGTH = 50;
34
+
35
+ export class CmsFormState {
36
+ readonly schemaConfig: SchemaConfig;
37
+ readonly getValidationRules: (t: SelectableFieldTypes) => ValidationRule[];
38
+
39
+ properties: FieldPropertiesState = defaultProperties();
40
+ fieldRules: FieldRules = { validationRules: {} };
41
+ mode: 'new' | 'edit';
42
+ editingFieldId: string | undefined;
43
+ touchedFields: Set<keyof FieldProperties> = new Set();
44
+ showValidationError: boolean = false;
45
+ errorToastConfig: ToastConfig | undefined = undefined;
46
+
47
+ constructor(params: CmsFormStateParams) {
48
+ this.schemaConfig = params.schemaConfig;
49
+ this.getValidationRules = params.getValidationRules;
50
+ this.mode = params.mode ?? 'new';
51
+ this.editingFieldId = params.editingFieldId;
52
+
53
+ makeObservable(this, {
54
+ properties: observable.ref,
55
+ fieldRules: observable.ref,
56
+ mode: observable.ref,
57
+ editingFieldId: observable.ref,
58
+ touchedFields: observable,
59
+ showValidationError: observable.ref,
60
+ errorToastConfig: observable.ref,
61
+
62
+ fieldTypeError: computed,
63
+ nameError: computed,
64
+ hasInvalidFields: computed,
65
+ visibleErrors: computed,
66
+ supportedValidationRules: computed,
67
+ validationErrorMessage: computed,
68
+
69
+ setProperty: action,
70
+ setValidationRule: action.bound,
71
+ blurField: action,
72
+ enableShowValidationError: action,
73
+ setMode: action,
74
+ setErrorToastConfig: action,
75
+ loadField: action,
76
+ reset: action,
77
+
78
+ hideValidationError: action.bound,
79
+ changeType: action.bound,
80
+ changeName: action.bound,
81
+ setIsPii: action.bound,
82
+ setHelpText: action.bound,
83
+ });
84
+ }
85
+
86
+ get fieldTypeError(): string | undefined {
87
+ if (!this.properties.type) {
88
+ return 'Field type is required';
89
+ }
90
+ return undefined;
91
+ }
92
+
93
+ get nameError(): string | undefined {
94
+ const name = this.properties.name.trim();
95
+ if (!name) {
96
+ return 'Field name is required';
97
+ }
98
+ if (name.length > NAME_MAX_LENGTH) {
99
+ return `Field name must be ${NAME_MAX_LENGTH} characters or fewer`;
100
+ }
101
+ return undefined;
102
+ }
103
+
104
+ get hasInvalidFields(): boolean {
105
+ return !!(this.fieldTypeError || this.nameError);
106
+ }
107
+
108
+ // Spec §3 specifies booleans; returning the error string directly is more useful for rendering
109
+ // (one property read instead of two). Deviation is intentional — update spec if accepted.
110
+ get visibleErrors(): {
111
+ type: string | undefined;
112
+ name: string | undefined;
113
+ } {
114
+ const { showValidationError, touchedFields } = this;
115
+ return {
116
+ type: showValidationError ? this.fieldTypeError : undefined,
117
+ name:
118
+ showValidationError || touchedFields.has('name')
119
+ ? this.nameError
120
+ : undefined,
121
+ };
122
+ }
123
+
124
+ get supportedValidationRules(): ValidationRule[] {
125
+ return this.properties.type
126
+ ? this.getValidationRules(this.properties.type)
127
+ : [];
128
+ }
129
+
130
+ get validationErrorMessage(): string {
131
+ return (
132
+ this.fieldTypeError ||
133
+ this.nameError ||
134
+ 'Please fix the errors before saving'
135
+ );
136
+ }
137
+
138
+ setProperty<K extends keyof FieldPropertiesState>(
139
+ key: K,
140
+ value: FieldPropertiesState[K],
141
+ ) {
142
+ this.properties = { ...this.properties, [key]: value };
143
+ }
144
+
145
+ setValidationRule(rule: ValidationRule, value: unknown) {
146
+ this.fieldRules = {
147
+ ...this.fieldRules,
148
+ validationRules: { ...this.fieldRules.validationRules, [rule]: value },
149
+ };
150
+ }
151
+
152
+ blurField(field: keyof FieldProperties) {
153
+ this.touchedFields.add(field);
154
+ }
155
+
156
+ enableShowValidationError() {
157
+ this.showValidationError = true;
158
+ }
159
+
160
+ setMode(mode: 'new' | 'edit') {
161
+ this.mode = mode;
162
+ }
163
+
164
+ setErrorToastConfig(cfg: ToastConfig | undefined) {
165
+ this.errorToastConfig = cfg;
166
+ }
167
+
168
+ reset() {
169
+ this.properties = defaultProperties();
170
+ this.fieldRules = { validationRules: {} };
171
+ this.editingFieldId = undefined;
172
+ this.touchedFields.clear();
173
+ this.showValidationError = false;
174
+ this.errorToastConfig = undefined;
175
+ }
176
+
177
+ hideValidationError() {
178
+ this.showValidationError = false;
179
+ }
180
+
181
+ changeType(v: SelectableFieldTypes) {
182
+ this.setProperty('type', v);
183
+ this._onTypeChange(v);
184
+ }
185
+
186
+ changeName(v: string) {
187
+ this.setProperty('name', v);
188
+ }
189
+
190
+ setIsPii(v: boolean) {
191
+ this.setProperty('isPii', v);
192
+ }
193
+
194
+ setHelpText(v: string) {
195
+ this.setProperty('helpText', v);
196
+ }
197
+
198
+ loadField(field: Field) {
199
+ const mappedType: SelectableFieldTypes | undefined = isSelectableFieldType(
200
+ field.type,
201
+ )
202
+ ? field.type
203
+ : undefined;
204
+ this.properties = {
205
+ type: mappedType,
206
+ name: field.displayName,
207
+ isPii: field.isPii ?? false,
208
+ helpText: field.helpText ?? '',
209
+ };
210
+ this.fieldRules = {
211
+ validationRules: {
212
+ ...(field.validation?.required !== undefined && {
213
+ required: field.validation.required,
214
+ }),
215
+ ...(field.validation?.stringLengthRange !== undefined && {
216
+ charactersLimit: field.validation.stringLengthRange,
217
+ }),
218
+ },
219
+ };
220
+ this.editingFieldId = field.id;
221
+ this.errorToastConfig = undefined;
222
+ }
223
+
224
+ private _onTypeChange(newType: SelectableFieldTypes) {
225
+ const supported = new Set(this.getValidationRules(newType));
226
+ this.fieldRules = {
227
+ validationRules: Object.fromEntries(
228
+ Object.entries(this.fieldRules.validationRules).filter(([k]) =>
229
+ supported.has(k as ValidationRule),
230
+ ),
231
+ ),
232
+ };
233
+ if (!isPIISupportedByFieldType(newType)) {
234
+ this.properties = { ...this.properties, isPii: false };
235
+ }
236
+ this.touchedFields.clear();
237
+ }
238
+ }
@@ -0,0 +1,46 @@
1
+ import React from 'react';
2
+ import { observer } from 'mobx-react-lite';
3
+ import { Box } from '@wix/design-system';
4
+ import type { CmsFormState } from '../CmsFormState';
5
+ import { isPIISupportedByFieldType } from '../fieldTypeUtils';
6
+ import { FieldTypeSelect } from '../formFields/FieldTypeSelect';
7
+ import { FieldNameInput } from '../formFields/FieldNameInput';
8
+ import { FieldPiiToggle } from '../formFields/FieldPiiToggle';
9
+
10
+ interface Props {
11
+ state: CmsFormState;
12
+ }
13
+
14
+ const _BasicsSection = ({ state }: Props) => {
15
+ const { properties, visibleErrors, mode } = state;
16
+
17
+ return (
18
+ <Box direction="vertical" gap="SP4">
19
+ <FieldTypeSelect
20
+ label="Field Type"
21
+ value={properties.type}
22
+ onChange={state.changeType}
23
+ disabled={mode === 'edit'}
24
+ error={visibleErrors.type}
25
+ />
26
+
27
+ <FieldNameInput
28
+ label="Field Name"
29
+ value={properties.name}
30
+ onChange={state.changeName}
31
+ onBlur={() => state.blurField('name')}
32
+ error={visibleErrors.name}
33
+ />
34
+
35
+ {isPIISupportedByFieldType(properties.type) && (
36
+ <FieldPiiToggle
37
+ label="Personally Identifiable Information (PII)"
38
+ checked={properties.isPii}
39
+ onChange={state.setIsPii}
40
+ />
41
+ )}
42
+ </Box>
43
+ );
44
+ };
45
+
46
+ export const BasicsSection = observer(_BasicsSection);
@@ -0,0 +1,67 @@
1
+ import React, { useState } from 'react';
2
+ import { observer } from 'mobx-react-lite';
3
+ import { Box, Divider, Input, Text } from '@wix/design-system';
4
+ import { ChevronDown, ChevronRight } from '@wix/wix-ui-icons-common';
5
+ import type { CmsFormState } from '../CmsFormState';
6
+ import { ValidationSubSection } from './ValidationSubSection';
7
+
8
+ interface Props {
9
+ state: CmsFormState;
10
+ }
11
+
12
+ const _ValidationAndDefaultsSection = ({ state }: Props) => {
13
+ const [isOpen, setIsOpen] = useState(false);
14
+ const hasValidation = state.supportedValidationRules.length > 0;
15
+
16
+ return (
17
+ <Box direction="vertical">
18
+ <div
19
+ role="button"
20
+ tabIndex={0}
21
+ style={{
22
+ cursor: 'pointer',
23
+ padding: '16px 0 16px 0',
24
+ display: 'flex',
25
+ alignItems: 'center',
26
+ gap: 8,
27
+ }}
28
+ onClick={() => setIsOpen((v) => !v)}
29
+ onKeyDown={(e) => {
30
+ if (e.key === 'Enter' || e.key === ' ') {
31
+ e.preventDefault();
32
+ setIsOpen((v) => !v);
33
+ }
34
+ }}
35
+ >
36
+ {isOpen ? <ChevronDown size="18px" /> : <ChevronRight size="18px" />}
37
+ <Text weight="bold">Validation and defaults</Text>
38
+ </div>
39
+
40
+ {isOpen && (
41
+ <Box direction="vertical" gap="SP0">
42
+ {hasValidation && (
43
+ <Box direction="vertical" gap="SP4" paddingBottom="SP4">
44
+ <Text weight="bold">Validation</Text>
45
+ <ValidationSubSection state={state} />
46
+ <Divider />
47
+ </Box>
48
+ )}
49
+
50
+ <Box direction="vertical" gap="SP4" paddingBottom="SP4">
51
+ <Text weight="bold">Help text</Text>
52
+ <Input
53
+ ariaLabel="Help text"
54
+ value={state.properties.helpText}
55
+ onChange={(e) => state.setHelpText(e.target.value)}
56
+ />
57
+ <Divider />
58
+ </Box>
59
+ </Box>
60
+ )}
61
+ </Box>
62
+ );
63
+ };
64
+
65
+ export const ValidationAndDefaultsSection = observer(
66
+ _ValidationAndDefaultsSection,
67
+ );
@@ -0,0 +1,51 @@
1
+ import React from 'react';
2
+ import { observer } from 'mobx-react-lite';
3
+ import { Box } from '@wix/design-system';
4
+ import type { StringLengthRange } from '../../../types/SchemaConfig';
5
+ import type { CmsFormState } from '../CmsFormState';
6
+ import type { ValidationRule } from '../types';
7
+ import { RequiredToggle } from '../formFields/RequiredToggle';
8
+ import { CharactersLimitInput } from '../formFields/CharactersLimitInput';
9
+
10
+ interface Props {
11
+ state: CmsFormState;
12
+ }
13
+
14
+ const _ValidationSubSection = ({ state }: Props) => {
15
+ const { supportedValidationRules, fieldRules } = state;
16
+
17
+ return (
18
+ <Box direction="vertical" gap="SP4">
19
+ {supportedValidationRules.map((rule: ValidationRule) => {
20
+ if (rule === 'required') {
21
+ return (
22
+ <RequiredToggle
23
+ key="required"
24
+ label="Required"
25
+ checked={Boolean(fieldRules.validationRules.required)}
26
+ onChange={(v) => state.setValidationRule('required', v)}
27
+ />
28
+ );
29
+ }
30
+ if (rule === 'charactersLimit') {
31
+ return (
32
+ <CharactersLimitInput
33
+ key="charactersLimit"
34
+ minLabel="Min characters"
35
+ maxLabel="Max characters"
36
+ value={
37
+ (fieldRules.validationRules.charactersLimit as
38
+ | StringLengthRange
39
+ | undefined) ?? {}
40
+ }
41
+ onChange={(v) => state.setValidationRule('charactersLimit', v)}
42
+ />
43
+ );
44
+ }
45
+ return null;
46
+ })}
47
+ </Box>
48
+ );
49
+ };
50
+
51
+ export const ValidationSubSection = observer(_ValidationSubSection);
@@ -0,0 +1,17 @@
1
+ import type { PatternsFieldType } from '../../types/SchemaConfig';
2
+ import type { SelectableFieldTypes } from './types';
3
+
4
+ const SELECTABLE_FIELD_TYPES = new Set<PatternsFieldType>([
5
+ 'SHORT_TEXT',
6
+ 'NUMBER',
7
+ 'BOOLEAN',
8
+ 'DATE',
9
+ ]);
10
+
11
+ export const isSelectableFieldType = (
12
+ t: PatternsFieldType,
13
+ ): t is SelectableFieldTypes => SELECTABLE_FIELD_TYPES.has(t);
14
+
15
+ export const isPIISupportedByFieldType = (
16
+ t: SelectableFieldTypes | undefined,
17
+ ): boolean => t === 'SHORT_TEXT';
@@ -0,0 +1,18 @@
1
+ import type { SelectableFieldTypes, ValidationRule } from './types';
2
+
3
+ // Sourced from cms-web packages/auto-cms-field-types/src/field-types-metadata.json validations[] per type.
4
+ //
5
+ // TODO: cross-check this map against cms-web before GA. The ValidationSection UI in Phase 3 renders
6
+ // rule inputs based on this map — a wrong entry surfaces as the wrong set of inputs for a field type.
7
+ // Updating this file is the single place to fix any mismatch; no downstream changes required.
8
+ const fieldValidationRulesMap: Record<SelectableFieldTypes, ValidationRule[]> =
9
+ {
10
+ SHORT_TEXT: ['required', 'charactersLimit'],
11
+ NUMBER: ['required'],
12
+ BOOLEAN: ['required'],
13
+ DATE: ['required'],
14
+ };
15
+
16
+ export const getFieldTypeValidationRulesList = (
17
+ t: SelectableFieldTypes,
18
+ ): ValidationRule[] => fieldValidationRulesMap[t] ?? [];
@@ -0,0 +1,34 @@
1
+ import React from 'react';
2
+ import { Box, FormField, NumberInput } from '@wix/design-system';
3
+ import type { StringLengthRange } from '../../../types/SchemaConfig';
4
+
5
+ export interface CharactersLimitInputProps {
6
+ minLabel: string;
7
+ maxLabel: string;
8
+ value: StringLengthRange;
9
+ onChange: (v: StringLengthRange) => void;
10
+ }
11
+
12
+ export const CharactersLimitInput = ({
13
+ minLabel,
14
+ maxLabel,
15
+ value,
16
+ onChange,
17
+ }: CharactersLimitInputProps) => (
18
+ <Box gap="SP3">
19
+ <FormField label={minLabel}>
20
+ <NumberInput
21
+ value={value.minLength}
22
+ onChange={(v) => onChange({ ...value, minLength: v ?? undefined })}
23
+ min={0}
24
+ />
25
+ </FormField>
26
+ <FormField label={maxLabel}>
27
+ <NumberInput
28
+ value={value.maxLength}
29
+ onChange={(v) => onChange({ ...value, maxLength: v ?? undefined })}
30
+ min={0}
31
+ />
32
+ </FormField>
33
+ </Box>
34
+ );
@@ -0,0 +1,31 @@
1
+ import React from 'react';
2
+ import { FormField, Input } from '@wix/design-system';
3
+
4
+ export interface FieldNameInputProps {
5
+ label: string;
6
+ value: string;
7
+ onChange: (v: string) => void;
8
+ onBlur?: () => void;
9
+ error?: string;
10
+ }
11
+
12
+ export const FieldNameInput = ({
13
+ label,
14
+ value,
15
+ onChange,
16
+ onBlur,
17
+ error,
18
+ }: FieldNameInputProps) => (
19
+ <FormField
20
+ required
21
+ label={label}
22
+ status={error ? 'error' : undefined}
23
+ statusMessage={error}
24
+ >
25
+ <Input
26
+ value={value}
27
+ onChange={(e) => onChange(e.target.value)}
28
+ onBlur={onBlur}
29
+ />
30
+ </FormField>
31
+ );
@@ -0,0 +1,24 @@
1
+ import React from 'react';
2
+ import { FormField, ToggleSwitch } from '@wix/design-system';
3
+
4
+ export interface FieldPiiToggleProps {
5
+ label: string;
6
+ checked: boolean;
7
+ onChange: (v: boolean) => void;
8
+ disabled?: boolean;
9
+ }
10
+
11
+ export const FieldPiiToggle = ({
12
+ label,
13
+ checked,
14
+ onChange,
15
+ disabled,
16
+ }: FieldPiiToggleProps) => (
17
+ <FormField label={label}>
18
+ <ToggleSwitch
19
+ checked={checked}
20
+ onChange={(e) => onChange(e.target.checked)}
21
+ disabled={disabled}
22
+ />
23
+ </FormField>
24
+ );