@strapi/content-manager 0.0.0-next.e3eb36dde0d936dc941df54e440e2c50a0582eeb → 0.0.0-next.e50ef5e2ea57ecf3da5bcf308508b51ee3c0deca

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 (208) hide show
  1. package/dist/admin/components/ConfigurationForm/Fields.js +300 -204
  2. package/dist/admin/components/ConfigurationForm/Fields.js.map +1 -1
  3. package/dist/admin/components/ConfigurationForm/Fields.mjs +304 -209
  4. package/dist/admin/components/ConfigurationForm/Fields.mjs.map +1 -1
  5. package/dist/admin/components/LeftMenu.js +34 -30
  6. package/dist/admin/components/LeftMenu.js.map +1 -1
  7. package/dist/admin/components/LeftMenu.mjs +36 -32
  8. package/dist/admin/components/LeftMenu.mjs.map +1 -1
  9. package/dist/admin/history/components/VersionContent.js +24 -3
  10. package/dist/admin/history/components/VersionContent.js.map +1 -1
  11. package/dist/admin/history/components/VersionContent.mjs +25 -4
  12. package/dist/admin/history/components/VersionContent.mjs.map +1 -1
  13. package/dist/admin/history/components/VersionHeader.js +6 -0
  14. package/dist/admin/history/components/VersionHeader.js.map +1 -1
  15. package/dist/admin/history/components/VersionHeader.mjs +7 -1
  16. package/dist/admin/history/components/VersionHeader.mjs.map +1 -1
  17. package/dist/admin/hooks/useDocumentActions.js +7 -3
  18. package/dist/admin/hooks/useDocumentActions.js.map +1 -1
  19. package/dist/admin/hooks/useDocumentActions.mjs +7 -3
  20. package/dist/admin/hooks/useDocumentActions.mjs.map +1 -1
  21. package/dist/admin/index.js +2 -0
  22. package/dist/admin/index.js.map +1 -1
  23. package/dist/admin/index.mjs +1 -0
  24. package/dist/admin/index.mjs.map +1 -1
  25. package/dist/admin/pages/EditView/EditViewPage.js +94 -75
  26. package/dist/admin/pages/EditView/EditViewPage.js.map +1 -1
  27. package/dist/admin/pages/EditView/EditViewPage.mjs +95 -76
  28. package/dist/admin/pages/EditView/EditViewPage.mjs.map +1 -1
  29. package/dist/admin/pages/EditView/components/DocumentActions.js +83 -70
  30. package/dist/admin/pages/EditView/components/DocumentActions.js.map +1 -1
  31. package/dist/admin/pages/EditView/components/DocumentActions.mjs +85 -72
  32. package/dist/admin/pages/EditView/components/DocumentActions.mjs.map +1 -1
  33. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksContent.js +12 -15
  34. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksContent.js.map +1 -1
  35. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksContent.mjs +12 -15
  36. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksContent.mjs.map +1 -1
  37. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksEditor.js +54 -14
  38. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksEditor.js.map +1 -1
  39. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksEditor.mjs +55 -15
  40. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksEditor.mjs.map +1 -1
  41. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksToolbar.js +21 -35
  42. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksToolbar.js.map +1 -1
  43. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksToolbar.mjs +21 -35
  44. package/dist/admin/pages/EditView/components/FormInputs/BlocksInput/BlocksToolbar.mjs.map +1 -1
  45. package/dist/admin/pages/EditView/components/FormInputs/Component/NonRepeatable.js +12 -1
  46. package/dist/admin/pages/EditView/components/FormInputs/Component/NonRepeatable.js.map +1 -1
  47. package/dist/admin/pages/EditView/components/FormInputs/Component/NonRepeatable.mjs +13 -2
  48. package/dist/admin/pages/EditView/components/FormInputs/Component/NonRepeatable.mjs.map +1 -1
  49. package/dist/admin/pages/EditView/components/FormInputs/Component/Repeatable.js +13 -2
  50. package/dist/admin/pages/EditView/components/FormInputs/Component/Repeatable.js.map +1 -1
  51. package/dist/admin/pages/EditView/components/FormInputs/Component/Repeatable.mjs +14 -3
  52. package/dist/admin/pages/EditView/components/FormInputs/Component/Repeatable.mjs.map +1 -1
  53. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/DynamicComponent.js +18 -5
  54. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/DynamicComponent.js.map +1 -1
  55. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/DynamicComponent.mjs +20 -7
  56. package/dist/admin/pages/EditView/components/FormInputs/DynamicZone/DynamicComponent.mjs.map +1 -1
  57. package/dist/admin/pages/EditView/components/FormInputs/Relations/RelationModal.js +1 -0
  58. package/dist/admin/pages/EditView/components/FormInputs/Relations/RelationModal.js.map +1 -1
  59. package/dist/admin/pages/EditView/components/FormInputs/Relations/RelationModal.mjs +1 -0
  60. package/dist/admin/pages/EditView/components/FormInputs/Relations/RelationModal.mjs.map +1 -1
  61. package/dist/admin/pages/EditView/components/FormInputs/Relations/Relations.js +155 -106
  62. package/dist/admin/pages/EditView/components/FormInputs/Relations/Relations.js.map +1 -1
  63. package/dist/admin/pages/EditView/components/FormInputs/Relations/Relations.mjs +158 -109
  64. package/dist/admin/pages/EditView/components/FormInputs/Relations/Relations.mjs.map +1 -1
  65. package/dist/admin/pages/EditView/components/FormInputs/UID.js +4 -2
  66. package/dist/admin/pages/EditView/components/FormInputs/UID.js.map +1 -1
  67. package/dist/admin/pages/EditView/components/FormInputs/UID.mjs +4 -2
  68. package/dist/admin/pages/EditView/components/FormInputs/UID.mjs.map +1 -1
  69. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/Editor.js +1 -1
  70. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/Editor.js.map +1 -1
  71. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/Editor.mjs +1 -1
  72. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/Editor.mjs.map +1 -1
  73. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/WysiwygNav.js +86 -118
  74. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/WysiwygNav.js.map +1 -1
  75. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/WysiwygNav.mjs +86 -118
  76. package/dist/admin/pages/EditView/components/FormInputs/Wysiwyg/WysiwygNav.mjs.map +1 -1
  77. package/dist/admin/pages/EditView/components/FormLayout.js +46 -26
  78. package/dist/admin/pages/EditView/components/FormLayout.js.map +1 -1
  79. package/dist/admin/pages/EditView/components/FormLayout.mjs +46 -26
  80. package/dist/admin/pages/EditView/components/FormLayout.mjs.map +1 -1
  81. package/dist/admin/pages/EditView/utils/data.js +103 -0
  82. package/dist/admin/pages/EditView/utils/data.js.map +1 -1
  83. package/dist/admin/pages/EditView/utils/data.mjs +103 -1
  84. package/dist/admin/pages/EditView/utils/data.mjs.map +1 -1
  85. package/dist/admin/pages/ListView/ListViewPage.js +86 -0
  86. package/dist/admin/pages/ListView/ListViewPage.js.map +1 -1
  87. package/dist/admin/pages/ListView/ListViewPage.mjs +88 -2
  88. package/dist/admin/pages/ListView/ListViewPage.mjs.map +1 -1
  89. package/dist/admin/pages/ListView/components/BulkActions/ConfirmBulkActionDialog.js +2 -1
  90. package/dist/admin/pages/ListView/components/BulkActions/ConfirmBulkActionDialog.js.map +1 -1
  91. package/dist/admin/pages/ListView/components/BulkActions/ConfirmBulkActionDialog.mjs +2 -1
  92. package/dist/admin/pages/ListView/components/BulkActions/ConfirmBulkActionDialog.mjs.map +1 -1
  93. package/dist/admin/pages/ListView/components/Filters.js +1 -0
  94. package/dist/admin/pages/ListView/components/Filters.js.map +1 -1
  95. package/dist/admin/pages/ListView/components/Filters.mjs +1 -0
  96. package/dist/admin/pages/ListView/components/Filters.mjs.map +1 -1
  97. package/dist/admin/pages/ListView/components/TableActions.js +13 -3
  98. package/dist/admin/pages/ListView/components/TableActions.js.map +1 -1
  99. package/dist/admin/pages/ListView/components/TableActions.mjs +13 -3
  100. package/dist/admin/pages/ListView/components/TableActions.mjs.map +1 -1
  101. package/dist/admin/services/api.js +2 -1
  102. package/dist/admin/services/api.js.map +1 -1
  103. package/dist/admin/services/api.mjs +2 -1
  104. package/dist/admin/services/api.mjs.map +1 -1
  105. package/dist/admin/services/documents.js +4 -4
  106. package/dist/admin/services/documents.js.map +1 -1
  107. package/dist/admin/services/documents.mjs +4 -4
  108. package/dist/admin/services/documents.mjs.map +1 -1
  109. package/dist/admin/src/components/ConfigurationForm/Fields.d.ts +6 -4
  110. package/dist/admin/src/exports.d.ts +1 -0
  111. package/dist/admin/src/history/services/historyVersion.d.ts +1 -1
  112. package/dist/admin/src/hooks/useDocumentActions.d.ts +1 -0
  113. package/dist/admin/src/pages/EditView/components/FormInputs/UID.d.ts +1 -0
  114. package/dist/admin/src/pages/EditView/components/FormLayout.d.ts +7 -7
  115. package/dist/admin/src/pages/EditView/utils/data.d.ts +19 -1
  116. package/dist/admin/src/preview/services/preview.d.ts +1 -1
  117. package/dist/admin/src/services/api.d.ts +1 -1
  118. package/dist/admin/src/services/components.d.ts +2 -2
  119. package/dist/admin/src/services/contentTypes.d.ts +3 -3
  120. package/dist/admin/src/services/documents.d.ts +23 -17
  121. package/dist/admin/src/services/homepage.d.ts +1 -1
  122. package/dist/admin/src/services/init.d.ts +1 -1
  123. package/dist/admin/src/services/relations.d.ts +2 -2
  124. package/dist/admin/src/services/uid.d.ts +3 -3
  125. package/dist/admin/src/utils/validation.d.ts +1 -0
  126. package/dist/admin/translations/en.json.js +1 -0
  127. package/dist/admin/translations/en.json.js.map +1 -1
  128. package/dist/admin/translations/en.json.mjs +1 -0
  129. package/dist/admin/translations/en.json.mjs.map +1 -1
  130. package/dist/admin/translations/fr.json.js +6 -1
  131. package/dist/admin/translations/fr.json.js.map +1 -1
  132. package/dist/admin/translations/fr.json.mjs +6 -1
  133. package/dist/admin/translations/fr.json.mjs.map +1 -1
  134. package/dist/admin/utils/validation.js +17 -6
  135. package/dist/admin/utils/validation.js.map +1 -1
  136. package/dist/admin/utils/validation.mjs +17 -6
  137. package/dist/admin/utils/validation.mjs.map +1 -1
  138. package/dist/server/controllers/content-types.js +11 -1
  139. package/dist/server/controllers/content-types.js.map +1 -1
  140. package/dist/server/controllers/content-types.mjs +11 -1
  141. package/dist/server/controllers/content-types.mjs.map +1 -1
  142. package/dist/server/controllers/relations.js +2 -2
  143. package/dist/server/controllers/relations.js.map +1 -1
  144. package/dist/server/controllers/relations.mjs +2 -2
  145. package/dist/server/controllers/relations.mjs.map +1 -1
  146. package/dist/server/controllers/validation/index.js +14 -2
  147. package/dist/server/controllers/validation/index.js.map +1 -1
  148. package/dist/server/controllers/validation/index.mjs +14 -2
  149. package/dist/server/controllers/validation/index.mjs.map +1 -1
  150. package/dist/server/history/services/lifecycles.js +3 -0
  151. package/dist/server/history/services/lifecycles.js.map +1 -1
  152. package/dist/server/history/services/lifecycles.mjs +3 -0
  153. package/dist/server/history/services/lifecycles.mjs.map +1 -1
  154. package/dist/server/homepage/services/homepage.js +58 -49
  155. package/dist/server/homepage/services/homepage.js.map +1 -1
  156. package/dist/server/homepage/services/homepage.mjs +58 -49
  157. package/dist/server/homepage/services/homepage.mjs.map +1 -1
  158. package/dist/server/services/data-mapper.js +4 -1
  159. package/dist/server/services/data-mapper.js.map +1 -1
  160. package/dist/server/services/data-mapper.mjs +4 -1
  161. package/dist/server/services/data-mapper.mjs.map +1 -1
  162. package/dist/server/services/document-manager.js +8 -1
  163. package/dist/server/services/document-manager.js.map +1 -1
  164. package/dist/server/services/document-manager.mjs +8 -1
  165. package/dist/server/services/document-manager.mjs.map +1 -1
  166. package/dist/server/services/document-metadata.js +3 -1
  167. package/dist/server/services/document-metadata.js.map +1 -1
  168. package/dist/server/services/document-metadata.mjs +3 -1
  169. package/dist/server/services/document-metadata.mjs.map +1 -1
  170. package/dist/server/services/utils/configuration/attributes.js +1 -1
  171. package/dist/server/services/utils/configuration/attributes.js.map +1 -1
  172. package/dist/server/services/utils/configuration/attributes.mjs +1 -1
  173. package/dist/server/services/utils/configuration/attributes.mjs.map +1 -1
  174. package/dist/server/services/utils/configuration/layouts.js +1 -1
  175. package/dist/server/services/utils/configuration/layouts.js.map +1 -1
  176. package/dist/server/services/utils/configuration/layouts.mjs +1 -1
  177. package/dist/server/services/utils/configuration/layouts.mjs.map +1 -1
  178. package/dist/server/services/utils/configuration/metadatas.js +8 -0
  179. package/dist/server/services/utils/configuration/metadatas.js.map +1 -1
  180. package/dist/server/services/utils/configuration/metadatas.mjs +8 -0
  181. package/dist/server/services/utils/configuration/metadatas.mjs.map +1 -1
  182. package/dist/server/services/utils/populate.js +11 -0
  183. package/dist/server/services/utils/populate.js.map +1 -1
  184. package/dist/server/services/utils/populate.mjs +11 -0
  185. package/dist/server/services/utils/populate.mjs.map +1 -1
  186. package/dist/server/src/controllers/content-types.d.ts.map +1 -1
  187. package/dist/server/src/controllers/validation/index.d.ts +6 -1
  188. package/dist/server/src/controllers/validation/index.d.ts.map +1 -1
  189. package/dist/server/src/history/services/lifecycles.d.ts.map +1 -1
  190. package/dist/server/src/homepage/index.d.ts +2 -0
  191. package/dist/server/src/homepage/index.d.ts.map +1 -1
  192. package/dist/server/src/homepage/services/homepage.d.ts +3 -1
  193. package/dist/server/src/homepage/services/homepage.d.ts.map +1 -1
  194. package/dist/server/src/homepage/services/index.d.ts +2 -0
  195. package/dist/server/src/homepage/services/index.d.ts.map +1 -1
  196. package/dist/server/src/index.d.ts +3 -0
  197. package/dist/server/src/index.d.ts.map +1 -1
  198. package/dist/server/src/services/data-mapper.d.ts +1 -0
  199. package/dist/server/src/services/data-mapper.d.ts.map +1 -1
  200. package/dist/server/src/services/document-manager.d.ts.map +1 -1
  201. package/dist/server/src/services/document-metadata.d.ts.map +1 -1
  202. package/dist/server/src/services/index.d.ts +3 -0
  203. package/dist/server/src/services/index.d.ts.map +1 -1
  204. package/dist/server/src/services/utils/configuration/metadatas.d.ts.map +1 -1
  205. package/dist/server/src/services/utils/populate.d.ts.map +1 -1
  206. package/dist/shared/contracts/collection-types.d.ts +0 -1
  207. package/dist/shared/contracts/collection-types.d.ts.map +1 -1
  208. package/package.json +11 -8
@@ -19,10 +19,20 @@ var validation = require('../../utils/validation.js');
19
19
  var FormLayout = require('./components/FormLayout.js');
20
20
  var Header = require('./components/Header.js');
21
21
  var Panels = require('./components/Panels.js');
22
+ var data = require('./utils/data.js');
22
23
 
23
24
  /* -------------------------------------------------------------------------------------------------
24
25
  * EditViewPage
25
- * -----------------------------------------------------------------------------------------------*/ const EditViewPage = ()=>{
26
+ * -----------------------------------------------------------------------------------------------*/ // Needs to be wrapped in a component to have access to the form context via a hook.
27
+ // Using the Form component's render prop instead would cause unnecessary re-renders of Form children
28
+ const BlockerWrapper = ()=>{
29
+ const resetForm = strapiAdmin.useForm('BlockerWrapper', (state)=>state.resetForm);
30
+ // We reset the form to the published version to avoid errors like – https://strapi-inc.atlassian.net/browse/CONTENT-2284
31
+ return /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Blocker, {
32
+ onProceed: resetForm
33
+ });
34
+ };
35
+ const EditViewPage = ()=>{
26
36
  const location = reactRouterDom.useLocation();
27
37
  const [{ query: { status } }, setQuery] = strapiAdmin.useQueryParams({
28
38
  status: 'draft'
@@ -53,6 +63,7 @@ var Panels = require('./components/Panels.js');
53
63
  * document with varying params.
54
64
  */ const isCreatingDocument = !id && !isSingleType;
55
65
  const { isLoading: isLoadingLayout, edit: { layout, settings: { mainField } } } = useDocumentLayout.useDocumentLayout(model);
66
+ const pageTitle = getTitle(mainField);
56
67
  const { isLazyLoading } = useLazyComponents.useLazyComponents([]);
57
68
  const isLoading = isLoadingActionsRBAC || isLoadingDocument || isLoadingLayout || isLazyLoading;
58
69
  const initialValues = getInitialFormValues(isCreatingDocument);
@@ -83,102 +94,110 @@ var Panels = require('./components/Panels.js');
83
94
  paddingRight: 10,
84
95
  children: [
85
96
  /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Page.Title, {
86
- children: getTitle(mainField)
97
+ children: pageTitle
87
98
  }),
88
99
  /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Form, {
89
100
  disabled: hasDraftAndPublished && status === 'published',
90
101
  initialValues: initialValues,
91
102
  method: isCreatingDocument ? 'POST' : 'PUT',
92
103
  validate: (values, options)=>{
104
+ // removes hidden fields from the validation
105
+ // this is necessary because the yup schema doesn't know about the visibility conditions
106
+ // and we don't want to validate fields that are not visible
107
+ const { data: cleanedValues, removedAttributes } = data.handleInvisibleAttributes(values, {
108
+ schema,
109
+ initialValues,
110
+ components
111
+ });
93
112
  const yupSchema = validation.createYupSchema(schema?.attributes, components, {
94
113
  status,
114
+ removedAttributes,
95
115
  ...options
96
116
  });
97
- return yupSchema.validate(values, {
117
+ return yupSchema.validate(cleanedValues, {
98
118
  abortEarly: false
99
119
  });
100
120
  },
101
121
  initialErrors: location?.state?.forceValidation ? validateSync(initialValues, {}) : {},
102
- children: ({ resetForm })=>/*#__PURE__*/ jsxRuntime.jsxs(jsxRuntime.Fragment, {
103
- children: [
104
- /*#__PURE__*/ jsxRuntime.jsx(Header.Header, {
105
- isCreating: isCreatingDocument,
106
- status: hasDraftAndPublished ? getDocumentStatus(document, meta) : undefined,
107
- title: getTitle(mainField)
108
- }),
109
- /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Tabs.Root, {
110
- variant: "simple",
111
- value: status,
112
- onValueChange: handleTabChange,
113
- children: [
114
- /*#__PURE__*/ jsxRuntime.jsx(designSystem.Tabs.List, {
115
- "aria-label": formatMessage({
116
- id: translations.getTranslation('containers.edit.tabs.label'),
117
- defaultMessage: 'Document status'
118
- }),
119
- children: hasDraftAndPublished ? /*#__PURE__*/ jsxRuntime.jsxs(jsxRuntime.Fragment, {
120
- children: [
121
- /*#__PURE__*/ jsxRuntime.jsx(StatusTab, {
122
- value: "draft",
123
- children: formatMessage({
124
- id: translations.getTranslation('containers.edit.tabs.draft'),
125
- defaultMessage: 'draft'
126
- })
127
- }),
128
- /*#__PURE__*/ jsxRuntime.jsx(StatusTab, {
129
- disabled: !meta || meta.availableStatus.length === 0,
130
- value: "published",
131
- children: formatMessage({
132
- id: translations.getTranslation('containers.edit.tabs.published'),
133
- defaultMessage: 'published'
134
- })
135
- })
136
- ]
137
- }) : null
122
+ children: /*#__PURE__*/ jsxRuntime.jsxs(jsxRuntime.Fragment, {
123
+ children: [
124
+ /*#__PURE__*/ jsxRuntime.jsx(Header.Header, {
125
+ isCreating: isCreatingDocument,
126
+ status: hasDraftAndPublished ? getDocumentStatus(document, meta) : undefined,
127
+ title: pageTitle
128
+ }),
129
+ /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Tabs.Root, {
130
+ variant: "simple",
131
+ value: status,
132
+ onValueChange: handleTabChange,
133
+ children: [
134
+ /*#__PURE__*/ jsxRuntime.jsx(designSystem.Tabs.List, {
135
+ "aria-label": formatMessage({
136
+ id: translations.getTranslation('containers.edit.tabs.label'),
137
+ defaultMessage: 'Document status'
138
138
  }),
139
- /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Grid.Root, {
140
- paddingTop: 8,
141
- gap: 4,
139
+ children: hasDraftAndPublished ? /*#__PURE__*/ jsxRuntime.jsxs(jsxRuntime.Fragment, {
142
140
  children: [
143
- /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Grid.Item, {
144
- col: 9,
145
- s: 12,
146
- direction: "column",
147
- alignItems: "stretch",
148
- children: [
149
- /*#__PURE__*/ jsxRuntime.jsx(designSystem.Tabs.Content, {
141
+ /*#__PURE__*/ jsxRuntime.jsx(StatusTab, {
142
+ value: "draft",
143
+ children: formatMessage({
144
+ id: translations.getTranslation('containers.edit.tabs.draft'),
145
+ defaultMessage: 'draft'
146
+ })
147
+ }),
148
+ /*#__PURE__*/ jsxRuntime.jsx(StatusTab, {
149
+ disabled: !meta || meta.availableStatus.length === 0,
150
+ value: "published",
151
+ children: formatMessage({
152
+ id: translations.getTranslation('containers.edit.tabs.published'),
153
+ defaultMessage: 'published'
154
+ })
155
+ })
156
+ ]
157
+ }) : null
158
+ }),
159
+ /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Grid.Root, {
160
+ paddingTop: 8,
161
+ gap: 4,
162
+ children: [
163
+ /*#__PURE__*/ jsxRuntime.jsxs(designSystem.Grid.Item, {
164
+ col: 9,
165
+ s: 12,
166
+ direction: "column",
167
+ alignItems: "stretch",
168
+ children: [
169
+ /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.unstable_tours.contentManager.Fields, {
170
+ children: /*#__PURE__*/ jsxRuntime.jsx(designSystem.Tabs.Content, {
150
171
  value: "draft",
151
172
  children: /*#__PURE__*/ jsxRuntime.jsx(FormLayout.FormLayout, {
152
173
  layout: layout,
153
174
  document: doc
154
175
  })
155
- }),
156
- /*#__PURE__*/ jsxRuntime.jsx(designSystem.Tabs.Content, {
157
- value: "published",
158
- children: /*#__PURE__*/ jsxRuntime.jsx(FormLayout.FormLayout, {
159
- layout: layout,
160
- document: doc
161
- })
162
176
  })
163
- ]
164
- }),
165
- /*#__PURE__*/ jsxRuntime.jsx(designSystem.Grid.Item, {
166
- col: 3,
167
- s: 12,
168
- direction: "column",
169
- alignItems: "stretch",
170
- children: /*#__PURE__*/ jsxRuntime.jsx(Panels.Panels, {})
171
- })
172
- ]
173
- })
174
- ]
175
- }),
176
- /*#__PURE__*/ jsxRuntime.jsx(strapiAdmin.Blocker, {
177
- // We reset the form to the published version to avoid errors like – https://strapi-inc.atlassian.net/browse/CONTENT-2284
178
- onProceed: resetForm
179
- })
180
- ]
181
- })
177
+ }),
178
+ /*#__PURE__*/ jsxRuntime.jsx(designSystem.Tabs.Content, {
179
+ value: "published",
180
+ children: /*#__PURE__*/ jsxRuntime.jsx(FormLayout.FormLayout, {
181
+ layout: layout,
182
+ document: doc
183
+ })
184
+ })
185
+ ]
186
+ }),
187
+ /*#__PURE__*/ jsxRuntime.jsx(designSystem.Grid.Item, {
188
+ col: 3,
189
+ s: 12,
190
+ direction: "column",
191
+ alignItems: "stretch",
192
+ children: /*#__PURE__*/ jsxRuntime.jsx(Panels.Panels, {})
193
+ })
194
+ ]
195
+ })
196
+ ]
197
+ }),
198
+ /*#__PURE__*/ jsxRuntime.jsx(BlockerWrapper, {})
199
+ ]
200
+ })
182
201
  })
183
202
  ]
184
203
  });
@@ -1 +1 @@
1
- {"version":3,"file":"EditViewPage.js","sources":["../../../../admin/src/pages/EditView/EditViewPage.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport {\n Page,\n Blocker,\n Form,\n useRBAC,\n useNotification,\n useQueryParams,\n} from '@strapi/admin/strapi-admin';\nimport { Grid, Main, Tabs } from '@strapi/design-system';\nimport { useIntl } from 'react-intl';\nimport { useLocation, useParams } from 'react-router-dom';\nimport { styled } from 'styled-components';\n\nimport { SINGLE_TYPES } from '../../constants/collections';\nimport { PERMISSIONS } from '../../constants/plugin';\nimport { DocumentRBAC, useDocumentRBAC } from '../../features/DocumentRBAC';\nimport { useDoc, type UseDocument } from '../../hooks/useDocument';\nimport { useDocumentLayout } from '../../hooks/useDocumentLayout';\nimport { useLazyComponents } from '../../hooks/useLazyComponents';\nimport { useOnce } from '../../hooks/useOnce';\nimport { getTranslation } from '../../utils/translations';\nimport { createYupSchema } from '../../utils/validation';\n\nimport { FormLayout } from './components/FormLayout';\nimport { Header } from './components/Header';\nimport { Panels } from './components/Panels';\n\n/* -------------------------------------------------------------------------------------------------\n * EditViewPage\n * -----------------------------------------------------------------------------------------------*/\n\nconst EditViewPage = () => {\n const location = useLocation();\n const [\n {\n query: { status },\n },\n setQuery,\n ] = useQueryParams<{ status: 'draft' | 'published' }>({\n status: 'draft',\n });\n const { formatMessage } = useIntl();\n const { toggleNotification } = useNotification();\n\n const doc = useDoc();\n const {\n document,\n meta,\n isLoading: isLoadingDocument,\n schema,\n components,\n collectionType,\n id,\n model,\n hasError,\n getTitle,\n getInitialFormValues,\n } = doc;\n\n const hasDraftAndPublished = schema?.options?.draftAndPublish ?? false;\n\n useOnce(() => {\n /**\n * We only ever want to fire the notification once otherwise\n * whenever the app re-renders it'll pop up regardless of\n * what we do because the state comes from react-router-dom\n */\n if (location?.state && 'error' in location.state) {\n toggleNotification({\n type: 'danger',\n message: location.state.error,\n timeout: 5000,\n });\n }\n });\n\n const isLoadingActionsRBAC = useDocumentRBAC('EditViewPage', (state) => state.isLoading);\n\n const isSingleType = collectionType === SINGLE_TYPES;\n\n /**\n * single-types don't current have an id, but because they're a singleton\n * we can simply use the update operation to continuously update the same\n * document with varying params.\n */\n const isCreatingDocument = !id && !isSingleType;\n\n const {\n isLoading: isLoadingLayout,\n edit: {\n layout,\n settings: { mainField },\n },\n } = useDocumentLayout(model);\n\n const { isLazyLoading } = useLazyComponents([]);\n\n const isLoading = isLoadingActionsRBAC || isLoadingDocument || isLoadingLayout || isLazyLoading;\n\n const initialValues = getInitialFormValues(isCreatingDocument);\n\n if (isLoading && !document?.documentId) {\n return <Page.Loading />;\n }\n\n if (!initialValues || hasError) {\n return <Page.Error />;\n }\n\n const handleTabChange = (status: string) => {\n if (status === 'published' || status === 'draft') {\n setQuery({ status }, 'push', true);\n }\n };\n\n const validateSync = (values: Record<string, unknown>, options: Record<string, string>) => {\n const yupSchema = createYupSchema(schema?.attributes, components, {\n status,\n ...options,\n });\n\n return yupSchema.validateSync(values, { abortEarly: false });\n };\n\n return (\n <Main paddingLeft={10} paddingRight={10}>\n <Page.Title>{getTitle(mainField)}</Page.Title>\n <Form\n disabled={hasDraftAndPublished && status === 'published'}\n initialValues={initialValues}\n method={isCreatingDocument ? 'POST' : 'PUT'}\n validate={(values: Record<string, unknown>, options: Record<string, string>) => {\n const yupSchema = createYupSchema(schema?.attributes, components, {\n status,\n ...options,\n });\n\n return yupSchema.validate(values, { abortEarly: false });\n }}\n initialErrors={location?.state?.forceValidation ? validateSync(initialValues, {}) : {}}\n >\n {({ resetForm }) => (\n <>\n <Header\n isCreating={isCreatingDocument}\n status={hasDraftAndPublished ? getDocumentStatus(document, meta) : undefined}\n title={getTitle(mainField)}\n />\n <Tabs.Root variant=\"simple\" value={status} onValueChange={handleTabChange}>\n <Tabs.List\n aria-label={formatMessage({\n id: getTranslation('containers.edit.tabs.label'),\n defaultMessage: 'Document status',\n })}\n >\n {hasDraftAndPublished ? (\n <>\n <StatusTab value=\"draft\">\n {formatMessage({\n id: getTranslation('containers.edit.tabs.draft'),\n defaultMessage: 'draft',\n })}\n </StatusTab>\n <StatusTab\n disabled={!meta || meta.availableStatus.length === 0}\n value=\"published\"\n >\n {formatMessage({\n id: getTranslation('containers.edit.tabs.published'),\n defaultMessage: 'published',\n })}\n </StatusTab>\n </>\n ) : null}\n </Tabs.List>\n <Grid.Root paddingTop={8} gap={4}>\n <Grid.Item col={9} s={12} direction=\"column\" alignItems=\"stretch\">\n <Tabs.Content value=\"draft\">\n <FormLayout layout={layout} document={doc} />\n </Tabs.Content>\n <Tabs.Content value=\"published\">\n <FormLayout layout={layout} document={doc} />\n </Tabs.Content>\n </Grid.Item>\n <Grid.Item col={3} s={12} direction=\"column\" alignItems=\"stretch\">\n <Panels />\n </Grid.Item>\n </Grid.Root>\n </Tabs.Root>\n <Blocker\n // We reset the form to the published version to avoid errors like – https://strapi-inc.atlassian.net/browse/CONTENT-2284\n onProceed={resetForm}\n />\n </>\n )}\n </Form>\n </Main>\n );\n};\n\nconst StatusTab = styled(Tabs.Trigger)`\n text-transform: uppercase;\n`;\n\n/**\n * @internal\n * @description Returns the status of the document where its latest state takes priority,\n * this typically will be \"published\" unless a user has edited their draft in which we should\n * display \"modified\".\n */\nconst getDocumentStatus = (\n document: ReturnType<UseDocument>['document'],\n meta: ReturnType<UseDocument>['meta']\n): 'draft' | 'published' | 'modified' => {\n const docStatus = document?.status;\n const statuses = meta?.availableStatus ?? [];\n\n /**\n * Creating an entry\n */\n if (!docStatus) {\n return 'draft';\n }\n\n /**\n * We're viewing a draft, but the document could have a published version\n */\n if (docStatus === 'draft' && statuses.find((doc) => doc.publishedAt !== null)) {\n return 'published';\n }\n\n return docStatus;\n};\n\n/* -------------------------------------------------------------------------------------------------\n * ProtectedEditViewPage\n * -----------------------------------------------------------------------------------------------*/\n\nconst ProtectedEditViewPage = () => {\n const { slug = '' } = useParams<{\n slug: string;\n }>();\n const {\n permissions = [],\n isLoading,\n error,\n } = useRBAC(\n PERMISSIONS.map((action) => ({\n action,\n subject: slug,\n }))\n );\n\n if (isLoading) {\n return <Page.Loading />;\n }\n\n if (error || !slug) {\n return <Page.Error />;\n }\n\n return (\n <Page.Protect permissions={permissions}>\n {({ permissions }) => (\n <DocumentRBAC permissions={permissions}>\n <EditViewPage />\n </DocumentRBAC>\n )}\n </Page.Protect>\n );\n};\n\nexport { EditViewPage, ProtectedEditViewPage, getDocumentStatus };\n"],"names":["EditViewPage","location","useLocation","query","status","setQuery","useQueryParams","formatMessage","useIntl","toggleNotification","useNotification","doc","useDoc","document","meta","isLoading","isLoadingDocument","schema","components","collectionType","id","model","hasError","getTitle","getInitialFormValues","hasDraftAndPublished","options","draftAndPublish","useOnce","state","type","message","error","timeout","isLoadingActionsRBAC","useDocumentRBAC","isSingleType","SINGLE_TYPES","isCreatingDocument","isLoadingLayout","edit","layout","settings","mainField","useDocumentLayout","isLazyLoading","useLazyComponents","initialValues","documentId","_jsx","Page","Loading","Error","handleTabChange","validateSync","values","yupSchema","createYupSchema","attributes","abortEarly","_jsxs","Main","paddingLeft","paddingRight","Title","Form","disabled","method","validate","initialErrors","forceValidation","resetForm","_Fragment","Header","isCreating","getDocumentStatus","undefined","title","Tabs","Root","variant","value","onValueChange","List","aria-label","getTranslation","defaultMessage","StatusTab","availableStatus","length","Grid","paddingTop","gap","Item","col","s","direction","alignItems","Content","FormLayout","Panels","Blocker","onProceed","styled","Trigger","docStatus","statuses","find","publishedAt","ProtectedEditViewPage","slug","useParams","permissions","useRBAC","PERMISSIONS","map","action","subject","Protect","DocumentRBAC"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AA6BA;;AAEkG,2GAE5FA,YAAe,GAAA,IAAA;AACnB,IAAA,MAAMC,QAAWC,GAAAA,0BAAAA,EAAAA;IACjB,MAAM,CACJ,EACEC,KAAAA,EAAO,EAAEC,MAAM,EAAE,EAClB,EACDC,QACD,CAAA,GAAGC,0BAAkD,CAAA;QACpDF,MAAQ,EAAA;AACV,KAAA,CAAA;IACA,MAAM,EAAEG,aAAa,EAAE,GAAGC,iBAAAA,EAAAA;IAC1B,MAAM,EAAEC,kBAAkB,EAAE,GAAGC,2BAAAA,EAAAA;AAE/B,IAAA,MAAMC,GAAMC,GAAAA,kBAAAA,EAAAA;IACZ,MAAM,EACJC,QAAQ,EACRC,IAAI,EACJC,WAAWC,iBAAiB,EAC5BC,MAAM,EACNC,UAAU,EACVC,cAAc,EACdC,EAAE,EACFC,KAAK,EACLC,QAAQ,EACRC,QAAQ,EACRC,oBAAoB,EACrB,GAAGb,GAAAA;IAEJ,MAAMc,oBAAAA,GAAuBR,MAAQS,EAAAA,OAAAA,EAASC,eAAmB,IAAA,KAAA;IAEjEC,eAAQ,CAAA,IAAA;AACN;;;;AAIC,QACD,IAAI3B,QAAU4B,EAAAA,KAAAA,IAAS,OAAW5B,IAAAA,QAAAA,CAAS4B,KAAK,EAAE;YAChDpB,kBAAmB,CAAA;gBACjBqB,IAAM,EAAA,QAAA;gBACNC,OAAS9B,EAAAA,QAAAA,CAAS4B,KAAK,CAACG,KAAK;gBAC7BC,OAAS,EAAA;AACX,aAAA,CAAA;AACF;AACF,KAAA,CAAA;AAEA,IAAA,MAAMC,uBAAuBC,4BAAgB,CAAA,cAAA,EAAgB,CAACN,KAAAA,GAAUA,MAAMd,SAAS,CAAA;AAEvF,IAAA,MAAMqB,eAAejB,cAAmBkB,KAAAA,wBAAAA;AAExC;;;;AAIC,MACD,MAAMC,kBAAAA,GAAqB,CAAClB,EAAAA,IAAM,CAACgB,YAAAA;AAEnC,IAAA,MAAM,EACJrB,SAAAA,EAAWwB,eAAe,EAC1BC,MAAM,EACJC,MAAM,EACNC,QAAAA,EAAU,EAAEC,SAAS,EAAE,EACxB,EACF,GAAGC,mCAAkBvB,CAAAA,KAAAA,CAAAA;AAEtB,IAAA,MAAM,EAAEwB,aAAa,EAAE,GAAGC,oCAAkB,EAAE,CAAA;IAE9C,MAAM/B,SAAAA,GAAYmB,oBAAwBlB,IAAAA,iBAAAA,IAAqBuB,eAAmBM,IAAAA,aAAAA;AAElF,IAAA,MAAME,gBAAgBvB,oBAAqBc,CAAAA,kBAAAA,CAAAA;IAE3C,IAAIvB,SAAAA,IAAa,CAACF,QAAAA,EAAUmC,UAAY,EAAA;QACtC,qBAAOC,cAAA,CAACC,iBAAKC,OAAO,EAAA,EAAA,CAAA;AACtB;IAEA,IAAI,CAACJ,iBAAiBzB,QAAU,EAAA;QAC9B,qBAAO2B,cAAA,CAACC,iBAAKE,KAAK,EAAA,EAAA,CAAA;AACpB;AAEA,IAAA,MAAMC,kBAAkB,CAACjD,MAAAA,GAAAA;QACvB,IAAIA,MAAAA,KAAW,WAAeA,IAAAA,MAAAA,KAAW,OAAS,EAAA;YAChDC,QAAS,CAAA;AAAED,gBAAAA;AAAO,aAAA,EAAG,MAAQ,EAAA,IAAA,CAAA;AAC/B;AACF,KAAA;IAEA,MAAMkD,YAAAA,GAAe,CAACC,MAAiC7B,EAAAA,OAAAA,GAAAA;AACrD,QAAA,MAAM8B,SAAYC,GAAAA,0BAAAA,CAAgBxC,MAAQyC,EAAAA,UAAAA,EAAYxC,UAAY,EAAA;AAChEd,YAAAA,MAAAA;AACA,YAAA,GAAGsB;AACL,SAAA,CAAA;QAEA,OAAO8B,SAAAA,CAAUF,YAAY,CAACC,MAAQ,EAAA;YAAEI,UAAY,EAAA;AAAM,SAAA,CAAA;AAC5D,KAAA;AAEA,IAAA,qBACEC,eAACC,CAAAA,iBAAAA,EAAAA;QAAKC,WAAa,EAAA,EAAA;QAAIC,YAAc,EAAA,EAAA;;AACnC,0BAAAd,cAAA,CAACC,iBAAKc,KAAK,EAAA;0BAAEzC,QAASoB,CAAAA,SAAAA;;0BACtBM,cAACgB,CAAAA,gBAAAA,EAAAA;AACCC,gBAAAA,QAAAA,EAAUzC,wBAAwBrB,MAAW,KAAA,WAAA;gBAC7C2C,aAAeA,EAAAA,aAAAA;AACfoB,gBAAAA,MAAAA,EAAQ7B,qBAAqB,MAAS,GAAA,KAAA;AACtC8B,gBAAAA,QAAAA,EAAU,CAACb,MAAiC7B,EAAAA,OAAAA,GAAAA;AAC1C,oBAAA,MAAM8B,SAAYC,GAAAA,0BAAAA,CAAgBxC,MAAQyC,EAAAA,UAAAA,EAAYxC,UAAY,EAAA;AAChEd,wBAAAA,MAAAA;AACA,wBAAA,GAAGsB;AACL,qBAAA,CAAA;oBAEA,OAAO8B,SAAAA,CAAUY,QAAQ,CAACb,MAAQ,EAAA;wBAAEI,UAAY,EAAA;AAAM,qBAAA,CAAA;AACxD,iBAAA;AACAU,gBAAAA,aAAAA,EAAepE,UAAU4B,KAAOyC,EAAAA,eAAAA,GAAkBhB,aAAaP,aAAe,EAAA,MAAM,EAAC;0BAEpF,CAAC,EAAEwB,SAAS,EAAE,iBACbX,eAAA,CAAAY,mBAAA,EAAA;;0CACEvB,cAACwB,CAAAA,aAAAA,EAAAA;gCACCC,UAAYpC,EAAAA,kBAAAA;gCACZlC,MAAQqB,EAAAA,oBAAAA,GAAuBkD,iBAAkB9D,CAAAA,QAAAA,EAAUC,IAAQ8D,CAAAA,GAAAA,SAAAA;AACnEC,gCAAAA,KAAAA,EAAOtD,QAASoB,CAAAA,SAAAA;;AAElB,0CAAAiB,eAAA,CAACkB,kBAAKC,IAAI,EAAA;gCAACC,OAAQ,EAAA,QAAA;gCAASC,KAAO7E,EAAAA,MAAAA;gCAAQ8E,aAAe7B,EAAAA,eAAAA;;AACxD,kDAAAJ,cAAA,CAAC6B,kBAAKK,IAAI,EAAA;AACRC,wCAAAA,YAAAA,EAAY7E,aAAc,CAAA;AACxBa,4CAAAA,EAAAA,EAAIiE,2BAAe,CAAA,4BAAA,CAAA;4CACnBC,cAAgB,EAAA;AAClB,yCAAA,CAAA;kDAEC7D,oBACC,iBAAAmC,eAAA,CAAAY,mBAAA,EAAA;;8DACEvB,cAACsC,CAAAA,SAAAA,EAAAA;oDAAUN,KAAM,EAAA,OAAA;8DACd1E,aAAc,CAAA;AACba,wDAAAA,EAAAA,EAAIiE,2BAAe,CAAA,4BAAA,CAAA;wDACnBC,cAAgB,EAAA;AAClB,qDAAA;;8DAEFrC,cAACsC,CAAAA,SAAAA,EAAAA;AACCrB,oDAAAA,QAAAA,EAAU,CAACpD,IAAQA,IAAAA,IAAAA,CAAK0E,eAAe,CAACC,MAAM,KAAK,CAAA;oDACnDR,KAAM,EAAA,WAAA;8DAEL1E,aAAc,CAAA;AACba,wDAAAA,EAAAA,EAAIiE,2BAAe,CAAA,gCAAA,CAAA;wDACnBC,cAAgB,EAAA;AAClB,qDAAA;;;AAGF,yCAAA,CAAA,GAAA;;AAEN,kDAAA1B,eAAA,CAAC8B,kBAAKX,IAAI,EAAA;wCAACY,UAAY,EAAA,CAAA;wCAAGC,GAAK,EAAA,CAAA;;AAC7B,0DAAAhC,eAAA,CAAC8B,kBAAKG,IAAI,EAAA;gDAACC,GAAK,EAAA,CAAA;gDAAGC,CAAG,EAAA,EAAA;gDAAIC,SAAU,EAAA,QAAA;gDAASC,UAAW,EAAA,SAAA;;AACtD,kEAAAhD,cAAA,CAAC6B,kBAAKoB,OAAO,EAAA;wDAACjB,KAAM,EAAA,OAAA;AAClB,wDAAA,QAAA,gBAAAhC,cAACkD,CAAAA,qBAAAA,EAAAA;4DAAW1D,MAAQA,EAAAA,MAAAA;4DAAQ5B,QAAUF,EAAAA;;;AAExC,kEAAAsC,cAAA,CAAC6B,kBAAKoB,OAAO,EAAA;wDAACjB,KAAM,EAAA,WAAA;AAClB,wDAAA,QAAA,gBAAAhC,cAACkD,CAAAA,qBAAAA,EAAAA;4DAAW1D,MAAQA,EAAAA,MAAAA;4DAAQ5B,QAAUF,EAAAA;;;;;AAG1C,0DAAAsC,cAAA,CAACyC,kBAAKG,IAAI,EAAA;gDAACC,GAAK,EAAA,CAAA;gDAAGC,CAAG,EAAA,EAAA;gDAAIC,SAAU,EAAA,QAAA;gDAASC,UAAW,EAAA,SAAA;AACtD,gDAAA,QAAA,gBAAAhD,cAACmD,CAAAA,aAAAA,EAAAA,EAAAA;;;;;;0CAIPnD,cAACoD,CAAAA,mBAAAA,EAAAA;;gCAECC,SAAW/B,EAAAA;;;;;;;AAOzB;AAEA,MAAMgB,SAAYgB,GAAAA,uBAAAA,CAAOzB,iBAAK0B,CAAAA,OAAO,CAAC;;AAEtC,CAAC;AAED;;;;;IAMA,MAAM7B,iBAAoB,GAAA,CACxB9D,QACAC,EAAAA,IAAAA,GAAAA;AAEA,IAAA,MAAM2F,YAAY5F,QAAUT,EAAAA,MAAAA;IAC5B,MAAMsG,QAAAA,GAAW5F,IAAM0E,EAAAA,eAAAA,IAAmB,EAAE;AAE5C;;MAGA,IAAI,CAACiB,SAAW,EAAA;QACd,OAAO,OAAA;AACT;AAEA;;MAGA,IAAIA,SAAc,KAAA,OAAA,IAAWC,QAASC,CAAAA,IAAI,CAAC,CAAChG,GAAQA,GAAAA,GAAAA,CAAIiG,WAAW,KAAK,IAAO,CAAA,EAAA;QAC7E,OAAO,WAAA;AACT;IAEA,OAAOH,SAAAA;AACT;AAEA;;AAEkG,2GAE5FI,qBAAwB,GAAA,IAAA;AAC5B,IAAA,MAAM,EAAEC,IAAAA,GAAO,EAAE,EAAE,GAAGC,wBAAAA,EAAAA;AAGtB,IAAA,MAAM,EACJC,WAAAA,GAAc,EAAE,EAChBjG,SAAS,EACTiB,KAAK,EACN,GAAGiF,oBACFC,kBAAYC,CAAAA,GAAG,CAAC,CAACC,UAAY;AAC3BA,YAAAA,MAAAA;YACAC,OAASP,EAAAA;SACX,CAAA,CAAA,CAAA;AAGF,IAAA,IAAI/F,SAAW,EAAA;QACb,qBAAOkC,cAAA,CAACC,iBAAKC,OAAO,EAAA,EAAA,CAAA;AACtB;IAEA,IAAInB,KAAAA,IAAS,CAAC8E,IAAM,EAAA;QAClB,qBAAO7D,cAAA,CAACC,iBAAKE,KAAK,EAAA,EAAA,CAAA;AACpB;IAEA,qBACEH,cAAA,CAACC,iBAAKoE,OAAO,EAAA;QAACN,WAAaA,EAAAA,WAAAA;AACxB,QAAA,QAAA,EAAA,CAAC,EAAEA,WAAW,EAAE,iBACf/D,cAACsE,CAAAA,yBAAAA,EAAAA;gBAAaP,WAAaA,EAAAA,WAAAA;AACzB,gBAAA,QAAA,gBAAA/D,cAACjD,CAAAA,YAAAA,EAAAA,EAAAA;;;AAKX;;;;;;"}
1
+ {"version":3,"file":"EditViewPage.js","sources":["../../../../admin/src/pages/EditView/EditViewPage.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport {\n Page,\n Blocker,\n Form,\n useForm,\n useRBAC,\n useNotification,\n useQueryParams,\n unstable_tours,\n} from '@strapi/admin/strapi-admin';\nimport { Grid, Main, Tabs } from '@strapi/design-system';\nimport { useIntl } from 'react-intl';\nimport { useLocation, useParams } from 'react-router-dom';\nimport { styled } from 'styled-components';\n\nimport { SINGLE_TYPES } from '../../constants/collections';\nimport { PERMISSIONS } from '../../constants/plugin';\nimport { DocumentRBAC, useDocumentRBAC } from '../../features/DocumentRBAC';\nimport { useDoc, type UseDocument } from '../../hooks/useDocument';\nimport { useDocumentLayout } from '../../hooks/useDocumentLayout';\nimport { useLazyComponents } from '../../hooks/useLazyComponents';\nimport { useOnce } from '../../hooks/useOnce';\nimport { getTranslation } from '../../utils/translations';\nimport { createYupSchema } from '../../utils/validation';\n\nimport { FormLayout } from './components/FormLayout';\nimport { Header } from './components/Header';\nimport { Panels } from './components/Panels';\nimport { handleInvisibleAttributes } from './utils/data';\n\n/* -------------------------------------------------------------------------------------------------\n * EditViewPage\n * -----------------------------------------------------------------------------------------------*/\n\n// Needs to be wrapped in a component to have access to the form context via a hook.\n// Using the Form component's render prop instead would cause unnecessary re-renders of Form children\nconst BlockerWrapper = () => {\n const resetForm = useForm('BlockerWrapper', (state) => state.resetForm);\n\n // We reset the form to the published version to avoid errors like – https://strapi-inc.atlassian.net/browse/CONTENT-2284\n return <Blocker onProceed={resetForm} />;\n};\n\nconst EditViewPage = () => {\n const location = useLocation();\n const [\n {\n query: { status },\n },\n setQuery,\n ] = useQueryParams<{ status: 'draft' | 'published' }>({\n status: 'draft',\n });\n const { formatMessage } = useIntl();\n const { toggleNotification } = useNotification();\n\n const doc = useDoc();\n const {\n document,\n meta,\n isLoading: isLoadingDocument,\n schema,\n components,\n collectionType,\n id,\n model,\n hasError,\n getTitle,\n getInitialFormValues,\n } = doc;\n\n const hasDraftAndPublished = schema?.options?.draftAndPublish ?? false;\n\n useOnce(() => {\n /**\n * We only ever want to fire the notification once otherwise\n * whenever the app re-renders it'll pop up regardless of\n * what we do because the state comes from react-router-dom\n */\n if (location?.state && 'error' in location.state) {\n toggleNotification({\n type: 'danger',\n message: location.state.error,\n timeout: 5000,\n });\n }\n });\n\n const isLoadingActionsRBAC = useDocumentRBAC('EditViewPage', (state) => state.isLoading);\n\n const isSingleType = collectionType === SINGLE_TYPES;\n\n /**\n * single-types don't current have an id, but because they're a singleton\n * we can simply use the update operation to continuously update the same\n * document with varying params.\n */\n const isCreatingDocument = !id && !isSingleType;\n\n const {\n isLoading: isLoadingLayout,\n edit: {\n layout,\n settings: { mainField },\n },\n } = useDocumentLayout(model);\n const pageTitle = getTitle(mainField);\n\n const { isLazyLoading } = useLazyComponents([]);\n\n const isLoading = isLoadingActionsRBAC || isLoadingDocument || isLoadingLayout || isLazyLoading;\n\n const initialValues = getInitialFormValues(isCreatingDocument);\n\n if (isLoading && !document?.documentId) {\n return <Page.Loading />;\n }\n\n if (!initialValues || hasError) {\n return <Page.Error />;\n }\n\n const handleTabChange = (status: string) => {\n if (status === 'published' || status === 'draft') {\n setQuery({ status }, 'push', true);\n }\n };\n\n const validateSync = (values: Record<string, unknown>, options: Record<string, string>) => {\n const yupSchema = createYupSchema(schema?.attributes, components, {\n status,\n ...options,\n });\n\n return yupSchema.validateSync(values, { abortEarly: false });\n };\n\n return (\n <Main paddingLeft={10} paddingRight={10}>\n <Page.Title>{pageTitle}</Page.Title>\n <Form\n disabled={hasDraftAndPublished && status === 'published'}\n initialValues={initialValues}\n method={isCreatingDocument ? 'POST' : 'PUT'}\n validate={(values: Record<string, unknown>, options: Record<string, string>) => {\n // removes hidden fields from the validation\n // this is necessary because the yup schema doesn't know about the visibility conditions\n // and we don't want to validate fields that are not visible\n const { data: cleanedValues, removedAttributes } = handleInvisibleAttributes(values, {\n schema,\n initialValues,\n components,\n });\n\n const yupSchema = createYupSchema(schema?.attributes, components, {\n status,\n removedAttributes,\n ...options,\n });\n\n return yupSchema.validate(cleanedValues, { abortEarly: false });\n }}\n initialErrors={location?.state?.forceValidation ? validateSync(initialValues, {}) : {}}\n >\n <>\n <Header\n isCreating={isCreatingDocument}\n status={hasDraftAndPublished ? getDocumentStatus(document, meta) : undefined}\n title={pageTitle}\n />\n <Tabs.Root variant=\"simple\" value={status} onValueChange={handleTabChange}>\n <Tabs.List\n aria-label={formatMessage({\n id: getTranslation('containers.edit.tabs.label'),\n defaultMessage: 'Document status',\n })}\n >\n {hasDraftAndPublished ? (\n <>\n <StatusTab value=\"draft\">\n {formatMessage({\n id: getTranslation('containers.edit.tabs.draft'),\n defaultMessage: 'draft',\n })}\n </StatusTab>\n <StatusTab\n disabled={!meta || meta.availableStatus.length === 0}\n value=\"published\"\n >\n {formatMessage({\n id: getTranslation('containers.edit.tabs.published'),\n defaultMessage: 'published',\n })}\n </StatusTab>\n </>\n ) : null}\n </Tabs.List>\n <Grid.Root paddingTop={8} gap={4}>\n <Grid.Item col={9} s={12} direction=\"column\" alignItems=\"stretch\">\n <unstable_tours.contentManager.Fields>\n <Tabs.Content value=\"draft\">\n <FormLayout layout={layout} document={doc} />\n </Tabs.Content>\n </unstable_tours.contentManager.Fields>\n <Tabs.Content value=\"published\">\n <FormLayout layout={layout} document={doc} />\n </Tabs.Content>\n </Grid.Item>\n <Grid.Item col={3} s={12} direction=\"column\" alignItems=\"stretch\">\n <Panels />\n </Grid.Item>\n </Grid.Root>\n </Tabs.Root>\n <BlockerWrapper />\n </>\n </Form>\n </Main>\n );\n};\n\nconst StatusTab = styled(Tabs.Trigger)`\n text-transform: uppercase;\n`;\n\n/**\n * @internal\n * @description Returns the status of the document where its latest state takes priority,\n * this typically will be \"published\" unless a user has edited their draft in which we should\n * display \"modified\".\n */\nconst getDocumentStatus = (\n document: ReturnType<UseDocument>['document'],\n meta: ReturnType<UseDocument>['meta']\n): 'draft' | 'published' | 'modified' => {\n const docStatus = document?.status;\n const statuses = meta?.availableStatus ?? [];\n\n /**\n * Creating an entry\n */\n if (!docStatus) {\n return 'draft';\n }\n\n /**\n * We're viewing a draft, but the document could have a published version\n */\n if (docStatus === 'draft' && statuses.find((doc) => doc.publishedAt !== null)) {\n return 'published';\n }\n\n return docStatus;\n};\n\n/* -------------------------------------------------------------------------------------------------\n * ProtectedEditViewPage\n * -----------------------------------------------------------------------------------------------*/\n\nconst ProtectedEditViewPage = () => {\n const { slug = '' } = useParams<{\n slug: string;\n }>();\n const {\n permissions = [],\n isLoading,\n error,\n } = useRBAC(\n PERMISSIONS.map((action) => ({\n action,\n subject: slug,\n }))\n );\n\n if (isLoading) {\n return <Page.Loading />;\n }\n\n if (error || !slug) {\n return <Page.Error />;\n }\n\n return (\n <Page.Protect permissions={permissions}>\n {({ permissions }) => (\n <DocumentRBAC permissions={permissions}>\n <EditViewPage />\n </DocumentRBAC>\n )}\n </Page.Protect>\n );\n};\n\nexport { EditViewPage, ProtectedEditViewPage, getDocumentStatus };\n"],"names":["BlockerWrapper","resetForm","useForm","state","_jsx","Blocker","onProceed","EditViewPage","location","useLocation","query","status","setQuery","useQueryParams","formatMessage","useIntl","toggleNotification","useNotification","doc","useDoc","document","meta","isLoading","isLoadingDocument","schema","components","collectionType","id","model","hasError","getTitle","getInitialFormValues","hasDraftAndPublished","options","draftAndPublish","useOnce","type","message","error","timeout","isLoadingActionsRBAC","useDocumentRBAC","isSingleType","SINGLE_TYPES","isCreatingDocument","isLoadingLayout","edit","layout","settings","mainField","useDocumentLayout","pageTitle","isLazyLoading","useLazyComponents","initialValues","documentId","Page","Loading","Error","handleTabChange","validateSync","values","yupSchema","createYupSchema","attributes","abortEarly","_jsxs","Main","paddingLeft","paddingRight","Title","Form","disabled","method","validate","data","cleanedValues","removedAttributes","handleInvisibleAttributes","initialErrors","forceValidation","_Fragment","Header","isCreating","getDocumentStatus","undefined","title","Tabs","Root","variant","value","onValueChange","List","aria-label","getTranslation","defaultMessage","StatusTab","availableStatus","length","Grid","paddingTop","gap","Item","col","s","direction","alignItems","unstable_tours","contentManager","Fields","Content","FormLayout","Panels","styled","Trigger","docStatus","statuses","find","publishedAt","ProtectedEditViewPage","slug","useParams","permissions","useRBAC","PERMISSIONS","map","action","subject","Protect","DocumentRBAC"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
2
2
  import 'react';
3
- import { useQueryParams, useNotification, Page, Form, Blocker, useRBAC } from '@strapi/admin/strapi-admin';
3
+ import { useQueryParams, useNotification, Page, Form, unstable_tours, useRBAC, useForm, Blocker } from '@strapi/admin/strapi-admin';
4
4
  import { Tabs, Main, Grid } from '@strapi/design-system';
5
5
  import { useIntl } from 'react-intl';
6
6
  import { useLocation, useParams } from 'react-router-dom';
@@ -17,10 +17,20 @@ import { createYupSchema } from '../../utils/validation.mjs';
17
17
  import { FormLayout } from './components/FormLayout.mjs';
18
18
  import { Header } from './components/Header.mjs';
19
19
  import { Panels } from './components/Panels.mjs';
20
+ import { handleInvisibleAttributes } from './utils/data.mjs';
20
21
 
21
22
  /* -------------------------------------------------------------------------------------------------
22
23
  * EditViewPage
23
- * -----------------------------------------------------------------------------------------------*/ const EditViewPage = ()=>{
24
+ * -----------------------------------------------------------------------------------------------*/ // Needs to be wrapped in a component to have access to the form context via a hook.
25
+ // Using the Form component's render prop instead would cause unnecessary re-renders of Form children
26
+ const BlockerWrapper = ()=>{
27
+ const resetForm = useForm('BlockerWrapper', (state)=>state.resetForm);
28
+ // We reset the form to the published version to avoid errors like – https://strapi-inc.atlassian.net/browse/CONTENT-2284
29
+ return /*#__PURE__*/ jsx(Blocker, {
30
+ onProceed: resetForm
31
+ });
32
+ };
33
+ const EditViewPage = ()=>{
24
34
  const location = useLocation();
25
35
  const [{ query: { status } }, setQuery] = useQueryParams({
26
36
  status: 'draft'
@@ -51,6 +61,7 @@ import { Panels } from './components/Panels.mjs';
51
61
  * document with varying params.
52
62
  */ const isCreatingDocument = !id && !isSingleType;
53
63
  const { isLoading: isLoadingLayout, edit: { layout, settings: { mainField } } } = useDocumentLayout(model);
64
+ const pageTitle = getTitle(mainField);
54
65
  const { isLazyLoading } = useLazyComponents([]);
55
66
  const isLoading = isLoadingActionsRBAC || isLoadingDocument || isLoadingLayout || isLazyLoading;
56
67
  const initialValues = getInitialFormValues(isCreatingDocument);
@@ -81,102 +92,110 @@ import { Panels } from './components/Panels.mjs';
81
92
  paddingRight: 10,
82
93
  children: [
83
94
  /*#__PURE__*/ jsx(Page.Title, {
84
- children: getTitle(mainField)
95
+ children: pageTitle
85
96
  }),
86
97
  /*#__PURE__*/ jsx(Form, {
87
98
  disabled: hasDraftAndPublished && status === 'published',
88
99
  initialValues: initialValues,
89
100
  method: isCreatingDocument ? 'POST' : 'PUT',
90
101
  validate: (values, options)=>{
102
+ // removes hidden fields from the validation
103
+ // this is necessary because the yup schema doesn't know about the visibility conditions
104
+ // and we don't want to validate fields that are not visible
105
+ const { data: cleanedValues, removedAttributes } = handleInvisibleAttributes(values, {
106
+ schema,
107
+ initialValues,
108
+ components
109
+ });
91
110
  const yupSchema = createYupSchema(schema?.attributes, components, {
92
111
  status,
112
+ removedAttributes,
93
113
  ...options
94
114
  });
95
- return yupSchema.validate(values, {
115
+ return yupSchema.validate(cleanedValues, {
96
116
  abortEarly: false
97
117
  });
98
118
  },
99
119
  initialErrors: location?.state?.forceValidation ? validateSync(initialValues, {}) : {},
100
- children: ({ resetForm })=>/*#__PURE__*/ jsxs(Fragment, {
101
- children: [
102
- /*#__PURE__*/ jsx(Header, {
103
- isCreating: isCreatingDocument,
104
- status: hasDraftAndPublished ? getDocumentStatus(document, meta) : undefined,
105
- title: getTitle(mainField)
106
- }),
107
- /*#__PURE__*/ jsxs(Tabs.Root, {
108
- variant: "simple",
109
- value: status,
110
- onValueChange: handleTabChange,
111
- children: [
112
- /*#__PURE__*/ jsx(Tabs.List, {
113
- "aria-label": formatMessage({
114
- id: getTranslation('containers.edit.tabs.label'),
115
- defaultMessage: 'Document status'
116
- }),
117
- children: hasDraftAndPublished ? /*#__PURE__*/ jsxs(Fragment, {
118
- children: [
119
- /*#__PURE__*/ jsx(StatusTab, {
120
- value: "draft",
121
- children: formatMessage({
122
- id: getTranslation('containers.edit.tabs.draft'),
123
- defaultMessage: 'draft'
124
- })
125
- }),
126
- /*#__PURE__*/ jsx(StatusTab, {
127
- disabled: !meta || meta.availableStatus.length === 0,
128
- value: "published",
129
- children: formatMessage({
130
- id: getTranslation('containers.edit.tabs.published'),
131
- defaultMessage: 'published'
132
- })
133
- })
134
- ]
135
- }) : null
120
+ children: /*#__PURE__*/ jsxs(Fragment, {
121
+ children: [
122
+ /*#__PURE__*/ jsx(Header, {
123
+ isCreating: isCreatingDocument,
124
+ status: hasDraftAndPublished ? getDocumentStatus(document, meta) : undefined,
125
+ title: pageTitle
126
+ }),
127
+ /*#__PURE__*/ jsxs(Tabs.Root, {
128
+ variant: "simple",
129
+ value: status,
130
+ onValueChange: handleTabChange,
131
+ children: [
132
+ /*#__PURE__*/ jsx(Tabs.List, {
133
+ "aria-label": formatMessage({
134
+ id: getTranslation('containers.edit.tabs.label'),
135
+ defaultMessage: 'Document status'
136
136
  }),
137
- /*#__PURE__*/ jsxs(Grid.Root, {
138
- paddingTop: 8,
139
- gap: 4,
137
+ children: hasDraftAndPublished ? /*#__PURE__*/ jsxs(Fragment, {
140
138
  children: [
141
- /*#__PURE__*/ jsxs(Grid.Item, {
142
- col: 9,
143
- s: 12,
144
- direction: "column",
145
- alignItems: "stretch",
146
- children: [
147
- /*#__PURE__*/ jsx(Tabs.Content, {
139
+ /*#__PURE__*/ jsx(StatusTab, {
140
+ value: "draft",
141
+ children: formatMessage({
142
+ id: getTranslation('containers.edit.tabs.draft'),
143
+ defaultMessage: 'draft'
144
+ })
145
+ }),
146
+ /*#__PURE__*/ jsx(StatusTab, {
147
+ disabled: !meta || meta.availableStatus.length === 0,
148
+ value: "published",
149
+ children: formatMessage({
150
+ id: getTranslation('containers.edit.tabs.published'),
151
+ defaultMessage: 'published'
152
+ })
153
+ })
154
+ ]
155
+ }) : null
156
+ }),
157
+ /*#__PURE__*/ jsxs(Grid.Root, {
158
+ paddingTop: 8,
159
+ gap: 4,
160
+ children: [
161
+ /*#__PURE__*/ jsxs(Grid.Item, {
162
+ col: 9,
163
+ s: 12,
164
+ direction: "column",
165
+ alignItems: "stretch",
166
+ children: [
167
+ /*#__PURE__*/ jsx(unstable_tours.contentManager.Fields, {
168
+ children: /*#__PURE__*/ jsx(Tabs.Content, {
148
169
  value: "draft",
149
170
  children: /*#__PURE__*/ jsx(FormLayout, {
150
171
  layout: layout,
151
172
  document: doc
152
173
  })
153
- }),
154
- /*#__PURE__*/ jsx(Tabs.Content, {
155
- value: "published",
156
- children: /*#__PURE__*/ jsx(FormLayout, {
157
- layout: layout,
158
- document: doc
159
- })
160
174
  })
161
- ]
162
- }),
163
- /*#__PURE__*/ jsx(Grid.Item, {
164
- col: 3,
165
- s: 12,
166
- direction: "column",
167
- alignItems: "stretch",
168
- children: /*#__PURE__*/ jsx(Panels, {})
169
- })
170
- ]
171
- })
172
- ]
173
- }),
174
- /*#__PURE__*/ jsx(Blocker, {
175
- // We reset the form to the published version to avoid errors like – https://strapi-inc.atlassian.net/browse/CONTENT-2284
176
- onProceed: resetForm
177
- })
178
- ]
179
- })
175
+ }),
176
+ /*#__PURE__*/ jsx(Tabs.Content, {
177
+ value: "published",
178
+ children: /*#__PURE__*/ jsx(FormLayout, {
179
+ layout: layout,
180
+ document: doc
181
+ })
182
+ })
183
+ ]
184
+ }),
185
+ /*#__PURE__*/ jsx(Grid.Item, {
186
+ col: 3,
187
+ s: 12,
188
+ direction: "column",
189
+ alignItems: "stretch",
190
+ children: /*#__PURE__*/ jsx(Panels, {})
191
+ })
192
+ ]
193
+ })
194
+ ]
195
+ }),
196
+ /*#__PURE__*/ jsx(BlockerWrapper, {})
197
+ ]
198
+ })
180
199
  })
181
200
  ]
182
201
  });