@strapi/plugin-documentation 5.0.0-beta.1 → 5.0.0-beta.11

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 (196) hide show
  1. package/dist/_chunks/{App-o4uH8gaQ.js → App-Cmiagsr-.js} +27 -40
  2. package/dist/_chunks/App-Cmiagsr-.js.map +1 -0
  3. package/dist/_chunks/{App-ig-uE4do.mjs → App-pk6g9tYL.mjs} +27 -38
  4. package/dist/_chunks/App-pk6g9tYL.mjs.map +1 -0
  5. package/dist/_chunks/{Settings-3hsPOP_b.mjs → Settings-CqLmbMfv.mjs} +80 -62
  6. package/dist/_chunks/Settings-CqLmbMfv.mjs.map +1 -0
  7. package/dist/_chunks/{Settings-XmOzLTUn.js → Settings-MmkmHoxg.js} +80 -64
  8. package/dist/_chunks/Settings-MmkmHoxg.js.map +1 -0
  9. package/dist/_chunks/{ar-4yWQcJB-.js → ar-CkqTE6jh.js} +1 -1
  10. package/dist/_chunks/ar-CkqTE6jh.js.map +1 -0
  11. package/dist/_chunks/{ar-dlnabvQE.mjs → ar-ckp9T43y.mjs} +1 -1
  12. package/dist/_chunks/ar-ckp9T43y.mjs.map +1 -0
  13. package/dist/_chunks/{cs-knLCHelx.js → cs-BbyKo6Hc.js} +1 -1
  14. package/dist/_chunks/cs-BbyKo6Hc.js.map +1 -0
  15. package/dist/_chunks/{cs-x2Pr-Y38.mjs → cs-ciLYCxgd.mjs} +1 -1
  16. package/dist/_chunks/cs-ciLYCxgd.mjs.map +1 -0
  17. package/dist/_chunks/{de-D0HJjv1r.js → de-CHwC0A85.js} +1 -1
  18. package/dist/_chunks/de-CHwC0A85.js.map +1 -0
  19. package/dist/_chunks/{de-10J3uf4y.mjs → de-DqkAUMvP.mjs} +1 -1
  20. package/dist/_chunks/de-DqkAUMvP.mjs.map +1 -0
  21. package/dist/_chunks/{dk-_8JEfZdj.mjs → dk-DgCq8mF-.mjs} +1 -1
  22. package/dist/_chunks/dk-DgCq8mF-.mjs.map +1 -0
  23. package/dist/_chunks/{dk-OGCIxZ4f.js → dk-qlI2J6S0.js} +1 -1
  24. package/dist/_chunks/dk-qlI2J6S0.js.map +1 -0
  25. package/dist/_chunks/{en-YgFnjikD.js → en-Cfq2Inmo.js} +1 -1
  26. package/dist/_chunks/en-Cfq2Inmo.js.map +1 -0
  27. package/dist/_chunks/{en-V4ac9UMW.mjs → en-DfCC9sZn.mjs} +1 -1
  28. package/dist/_chunks/en-DfCC9sZn.mjs.map +1 -0
  29. package/dist/_chunks/{es-f_rfLY5r.mjs → es-CEiXVnsb.mjs} +1 -1
  30. package/dist/_chunks/es-CEiXVnsb.mjs.map +1 -0
  31. package/dist/_chunks/{es-5fRDaTSK.js → es-DH1GVZe7.js} +1 -1
  32. package/dist/_chunks/es-DH1GVZe7.js.map +1 -0
  33. package/dist/_chunks/{fr-qviymkcR.js → fr-B1x-Nj5w.js} +1 -1
  34. package/dist/_chunks/fr-B1x-Nj5w.js.map +1 -0
  35. package/dist/_chunks/{fr-L2xRpd2l.mjs → fr-BlX-v4UF.mjs} +1 -1
  36. package/dist/_chunks/fr-BlX-v4UF.mjs.map +1 -0
  37. package/dist/_chunks/getTrad-AjYeGjZg.mjs +51 -0
  38. package/dist/_chunks/getTrad-AjYeGjZg.mjs.map +1 -0
  39. package/dist/_chunks/getTrad-CPA7x4Cg.js +50 -0
  40. package/dist/_chunks/getTrad-CPA7x4Cg.js.map +1 -0
  41. package/dist/_chunks/{id-l-r-lPDE.mjs → id-CPOl6_EU.mjs} +1 -1
  42. package/dist/_chunks/id-CPOl6_EU.mjs.map +1 -0
  43. package/dist/_chunks/{id-caKGgafZ.js → id-D3yFE72d.js} +1 -1
  44. package/dist/_chunks/id-D3yFE72d.js.map +1 -0
  45. package/dist/_chunks/{index-MKWIGajW.mjs → index-BTFWrNiz.mjs} +1 -1
  46. package/dist/_chunks/{index-MKWIGajW.mjs.map → index-BTFWrNiz.mjs.map} +1 -1
  47. package/dist/_chunks/index-Bjeq6z8p.js +100 -0
  48. package/dist/_chunks/index-Bjeq6z8p.js.map +1 -0
  49. package/dist/_chunks/index-CEoG11hQ.mjs +101 -0
  50. package/dist/_chunks/index-CEoG11hQ.mjs.map +1 -0
  51. package/dist/_chunks/{index-WbbYm9_u.js → index-CYcTK1eg.js} +1 -1
  52. package/dist/_chunks/{index-WbbYm9_u.js.map → index-CYcTK1eg.js.map} +1 -1
  53. package/dist/_chunks/{it-nCSZoaet.mjs → it-DWJI563z.mjs} +1 -1
  54. package/dist/_chunks/it-DWJI563z.mjs.map +1 -0
  55. package/dist/_chunks/{it-e3T319Va.js → it-WuNBIqG8.js} +1 -1
  56. package/dist/_chunks/it-WuNBIqG8.js.map +1 -0
  57. package/dist/_chunks/{ko-pUwRxmfG.mjs → ko-CFzSHayG.mjs} +1 -1
  58. package/dist/_chunks/ko-CFzSHayG.mjs.map +1 -0
  59. package/dist/_chunks/{ko-nWCOH-TF.js → ko-De5iYa_O.js} +1 -1
  60. package/dist/_chunks/ko-De5iYa_O.js.map +1 -0
  61. package/dist/_chunks/{login-HAajOKpu.js → login-EQSKn2h7.js} +1 -1
  62. package/dist/_chunks/{login-HAajOKpu.js.map → login-EQSKn2h7.js.map} +1 -1
  63. package/dist/_chunks/{login-slUa679p.mjs → login-KS59cQ6U.mjs} +1 -1
  64. package/dist/_chunks/{login-slUa679p.mjs.map → login-KS59cQ6U.mjs.map} +1 -1
  65. package/dist/_chunks/{ms-8e8SEhhY.mjs → ms-CUgPFo4U.mjs} +1 -1
  66. package/dist/_chunks/ms-CUgPFo4U.mjs.map +1 -0
  67. package/dist/_chunks/{ms-CSGAOmvV.js → ms-DQfa3FDx.js} +1 -1
  68. package/dist/_chunks/ms-DQfa3FDx.js.map +1 -0
  69. package/dist/_chunks/{nl-82NK6g7v.js → nl-BZHlqphk.js} +1 -1
  70. package/dist/_chunks/nl-BZHlqphk.js.map +1 -0
  71. package/dist/_chunks/{nl-RjdbZWuM.mjs → nl-B_7CHwVD.mjs} +1 -1
  72. package/dist/_chunks/nl-B_7CHwVD.mjs.map +1 -0
  73. package/dist/_chunks/{pl-UMuW3iDh.js → pl-DDl5i_mP.js} +1 -1
  74. package/dist/_chunks/pl-DDl5i_mP.js.map +1 -0
  75. package/dist/_chunks/{pl-sh4sAKA8.mjs → pl-DwLr8sw9.mjs} +1 -1
  76. package/dist/_chunks/pl-DwLr8sw9.mjs.map +1 -0
  77. package/dist/_chunks/{pt-2sEtQifY.js → pt-4GQ8ermL.js} +1 -1
  78. package/dist/_chunks/pt-4GQ8ermL.js.map +1 -0
  79. package/dist/_chunks/{pt-BR-G0-nWgFV.js → pt-BR-D24CJ0qp.js} +1 -1
  80. package/dist/_chunks/pt-BR-D24CJ0qp.js.map +1 -0
  81. package/dist/_chunks/{pt-BR-uX3O_t0X.mjs → pt-BR-MVXc6V9P.mjs} +1 -1
  82. package/dist/_chunks/pt-BR-MVXc6V9P.mjs.map +1 -0
  83. package/dist/_chunks/{pt-GqKRRnNe.mjs → pt-C2N9fdeh.mjs} +1 -1
  84. package/dist/_chunks/pt-C2N9fdeh.mjs.map +1 -0
  85. package/dist/_chunks/{ru-dQr7xFOb.mjs → ru-BddeNlU0.mjs} +1 -1
  86. package/dist/_chunks/ru-BddeNlU0.mjs.map +1 -0
  87. package/dist/_chunks/{ru-wJyWus4I.js → ru-QwZYcU6K.js} +1 -1
  88. package/dist/_chunks/ru-QwZYcU6K.js.map +1 -0
  89. package/dist/_chunks/{sk-nreoyD6V.mjs → sk-BmT4uZTG.mjs} +1 -1
  90. package/dist/_chunks/sk-BmT4uZTG.mjs.map +1 -0
  91. package/dist/_chunks/{sk-mcEz1PMW.js → sk-DgAXilB1.js} +1 -1
  92. package/dist/_chunks/sk-DgAXilB1.js.map +1 -0
  93. package/dist/_chunks/{sv-V86KaP9y.js → sv-CCLcAo3U.js} +1 -1
  94. package/dist/_chunks/sv-CCLcAo3U.js.map +1 -0
  95. package/dist/_chunks/{sv-kIUD_46v.mjs → sv-D_-KBtcw.mjs} +1 -1
  96. package/dist/_chunks/sv-D_-KBtcw.mjs.map +1 -0
  97. package/dist/_chunks/{th-pZN4HdUY.js → th-BhgV1BbW.js} +1 -1
  98. package/dist/_chunks/th-BhgV1BbW.js.map +1 -0
  99. package/dist/_chunks/{th-IcmZ0Yif.mjs → th-DkuoSGii.mjs} +1 -1
  100. package/dist/_chunks/th-DkuoSGii.mjs.map +1 -0
  101. package/dist/_chunks/{tr-fCijT6nA.js → tr-BysnAErC.js} +1 -1
  102. package/dist/_chunks/tr-BysnAErC.js.map +1 -0
  103. package/dist/_chunks/{tr-CkXew0gQ.mjs → tr-l-xxK4Yk.mjs} +1 -1
  104. package/dist/_chunks/tr-l-xxK4Yk.mjs.map +1 -0
  105. package/dist/_chunks/{uk-TEHpQuls.js → uk-CNlbntFx.js} +1 -1
  106. package/dist/_chunks/uk-CNlbntFx.js.map +1 -0
  107. package/dist/_chunks/{uk-E8Js7gDb.mjs → uk-Cpmsxyku.mjs} +1 -1
  108. package/dist/_chunks/uk-Cpmsxyku.mjs.map +1 -0
  109. package/dist/_chunks/{vi-k1R3Y3mS.mjs → vi-ClWGrFm9.mjs} +1 -1
  110. package/dist/_chunks/vi-ClWGrFm9.mjs.map +1 -0
  111. package/dist/_chunks/{vi-Nxtm0xZz.js → vi-_ib0GmNl.js} +1 -1
  112. package/dist/_chunks/vi-_ib0GmNl.js.map +1 -0
  113. package/dist/_chunks/{zh-Vd3mfBR-.mjs → zh-Glkg1L2g.mjs} +1 -1
  114. package/dist/_chunks/zh-Glkg1L2g.mjs.map +1 -0
  115. package/dist/_chunks/{zh-Hans-tFSnVett.js → zh-Hans-L_5U2KqC.js} +1 -1
  116. package/dist/_chunks/zh-Hans-L_5U2KqC.js.map +1 -0
  117. package/dist/_chunks/{zh-Hans-FdUTcggu.mjs → zh-Hans-XLMwjASk.mjs} +1 -1
  118. package/dist/_chunks/zh-Hans-XLMwjASk.mjs.map +1 -0
  119. package/dist/_chunks/{zh-bgauBZz8.js → zh-aEZZdkOu.js} +1 -1
  120. package/dist/_chunks/zh-aEZZdkOu.js.map +1 -0
  121. package/dist/admin/index.js +1 -1
  122. package/dist/admin/index.mjs +2 -2
  123. package/dist/admin/src/services/api.d.ts +5 -17
  124. package/dist/admin/src/utils/baseQuery.d.ts +4 -19
  125. package/dist/server/index.js +7 -7
  126. package/dist/server/index.js.map +1 -1
  127. package/dist/server/index.mjs +7 -7
  128. package/dist/server/index.mjs.map +1 -1
  129. package/dist/server/src/middlewares/documentation.d.ts.map +1 -1
  130. package/dist/server/src/services/__mocks__/mock-strapi-data.d.ts +2 -2
  131. package/dist/server/src/services/__mocks__/mock-strapi-data.d.ts.map +1 -1
  132. package/dist/server/src/services/documentation.d.ts.map +1 -1
  133. package/dist/server/src/services/helpers/utils/loop-content-type-names.d.ts.map +1 -1
  134. package/dist/server/src/services/override.d.ts.map +1 -1
  135. package/dist/server/src/utils.d.ts.map +1 -1
  136. package/package.json +25 -23
  137. package/dist/_chunks/App-ig-uE4do.mjs.map +0 -1
  138. package/dist/_chunks/App-o4uH8gaQ.js.map +0 -1
  139. package/dist/_chunks/Settings-3hsPOP_b.mjs.map +0 -1
  140. package/dist/_chunks/Settings-XmOzLTUn.js.map +0 -1
  141. package/dist/_chunks/ar-4yWQcJB-.js.map +0 -1
  142. package/dist/_chunks/ar-dlnabvQE.mjs.map +0 -1
  143. package/dist/_chunks/cs-knLCHelx.js.map +0 -1
  144. package/dist/_chunks/cs-x2Pr-Y38.mjs.map +0 -1
  145. package/dist/_chunks/de-10J3uf4y.mjs.map +0 -1
  146. package/dist/_chunks/de-D0HJjv1r.js.map +0 -1
  147. package/dist/_chunks/dk-OGCIxZ4f.js.map +0 -1
  148. package/dist/_chunks/dk-_8JEfZdj.mjs.map +0 -1
  149. package/dist/_chunks/en-V4ac9UMW.mjs.map +0 -1
  150. package/dist/_chunks/en-YgFnjikD.js.map +0 -1
  151. package/dist/_chunks/es-5fRDaTSK.js.map +0 -1
  152. package/dist/_chunks/es-f_rfLY5r.mjs.map +0 -1
  153. package/dist/_chunks/fr-L2xRpd2l.mjs.map +0 -1
  154. package/dist/_chunks/fr-qviymkcR.js.map +0 -1
  155. package/dist/_chunks/getTrad-bnElvR8_.js +0 -5
  156. package/dist/_chunks/getTrad-bnElvR8_.js.map +0 -1
  157. package/dist/_chunks/getTrad-md7Tjpcv.mjs +0 -6
  158. package/dist/_chunks/getTrad-md7Tjpcv.mjs.map +0 -1
  159. package/dist/_chunks/id-caKGgafZ.js.map +0 -1
  160. package/dist/_chunks/id-l-r-lPDE.mjs.map +0 -1
  161. package/dist/_chunks/index-jpDwTC-Q.mjs +0 -205
  162. package/dist/_chunks/index-jpDwTC-Q.mjs.map +0 -1
  163. package/dist/_chunks/index-vNbIS1u2.js +0 -204
  164. package/dist/_chunks/index-vNbIS1u2.js.map +0 -1
  165. package/dist/_chunks/it-e3T319Va.js.map +0 -1
  166. package/dist/_chunks/it-nCSZoaet.mjs.map +0 -1
  167. package/dist/_chunks/ko-nWCOH-TF.js.map +0 -1
  168. package/dist/_chunks/ko-pUwRxmfG.mjs.map +0 -1
  169. package/dist/_chunks/ms-8e8SEhhY.mjs.map +0 -1
  170. package/dist/_chunks/ms-CSGAOmvV.js.map +0 -1
  171. package/dist/_chunks/nl-82NK6g7v.js.map +0 -1
  172. package/dist/_chunks/nl-RjdbZWuM.mjs.map +0 -1
  173. package/dist/_chunks/pl-UMuW3iDh.js.map +0 -1
  174. package/dist/_chunks/pl-sh4sAKA8.mjs.map +0 -1
  175. package/dist/_chunks/pt-2sEtQifY.js.map +0 -1
  176. package/dist/_chunks/pt-BR-G0-nWgFV.js.map +0 -1
  177. package/dist/_chunks/pt-BR-uX3O_t0X.mjs.map +0 -1
  178. package/dist/_chunks/pt-GqKRRnNe.mjs.map +0 -1
  179. package/dist/_chunks/ru-dQr7xFOb.mjs.map +0 -1
  180. package/dist/_chunks/ru-wJyWus4I.js.map +0 -1
  181. package/dist/_chunks/sk-mcEz1PMW.js.map +0 -1
  182. package/dist/_chunks/sk-nreoyD6V.mjs.map +0 -1
  183. package/dist/_chunks/sv-V86KaP9y.js.map +0 -1
  184. package/dist/_chunks/sv-kIUD_46v.mjs.map +0 -1
  185. package/dist/_chunks/th-IcmZ0Yif.mjs.map +0 -1
  186. package/dist/_chunks/th-pZN4HdUY.js.map +0 -1
  187. package/dist/_chunks/tr-CkXew0gQ.mjs.map +0 -1
  188. package/dist/_chunks/tr-fCijT6nA.js.map +0 -1
  189. package/dist/_chunks/uk-E8Js7gDb.mjs.map +0 -1
  190. package/dist/_chunks/uk-TEHpQuls.js.map +0 -1
  191. package/dist/_chunks/vi-Nxtm0xZz.js.map +0 -1
  192. package/dist/_chunks/vi-k1R3Y3mS.mjs.map +0 -1
  193. package/dist/_chunks/zh-Hans-FdUTcggu.mjs.map +0 -1
  194. package/dist/_chunks/zh-Hans-tFSnVett.js.map +0 -1
  195. package/dist/_chunks/zh-Vd3mfBR-.mjs.map +0 -1
  196. package/dist/_chunks/zh-bgauBZz8.js.map +0 -1
@@ -5,13 +5,10 @@ const React = require("react");
5
5
  const designSystem = require("@strapi/design-system");
6
6
  const icons = require("@strapi/icons");
7
7
  const admin = require("@strapi/strapi/admin");
8
- const reactHelmet = require("react-helmet");
9
8
  const reactIntl = require("react-intl");
10
- const styled = require("styled-components");
11
- const index = require("./index-vNbIS1u2.js");
12
- const getTrad = require("./getTrad-bnElvR8_.js");
13
- require("axios");
14
- const _interopDefault = (e) => e && e.__esModule ? e : { default: e };
9
+ const styledComponents = require("styled-components");
10
+ const index = require("./index-Bjeq6z8p.js");
11
+ const getTrad = require("./getTrad-CPA7x4Cg.js");
15
12
  function _interopNamespace(e) {
16
13
  if (e && e.__esModule)
17
14
  return e;
@@ -31,17 +28,17 @@ function _interopNamespace(e) {
31
28
  return Object.freeze(n);
32
29
  }
33
30
  const React__namespace = /* @__PURE__ */ _interopNamespace(React);
34
- const styled__default = /* @__PURE__ */ _interopDefault(styled);
35
31
  const App = () => {
36
32
  const { formatMessage } = reactIntl.useIntl();
37
33
  const { toggleNotification } = admin.useNotification();
38
34
  const { formatAPIError } = admin.useAPIErrorHandler();
39
- const { data, isLoading, isError } = index.useGetInfosQuery();
40
- const [regenerate] = index.useRegenerateDocMutation();
41
- const [deleteVersion] = index.useDeleteVersionMutation();
35
+ const { data, isLoading: isLoadingInfo, isError } = getTrad.useGetInfoQuery();
36
+ const [regenerate] = getTrad.useRegenerateDocMutation();
37
+ const [deleteVersion] = getTrad.useDeleteVersionMutation();
42
38
  const [showConfirmDelete, setShowConfirmDelete] = React__namespace.useState(false);
43
39
  const [versionToDelete, setVersionToDelete] = React__namespace.useState();
44
- const { allowedActions } = admin.useRBAC(index.PERMISSIONS);
40
+ const { allowedActions, isLoading: isLoadingRBAC } = admin.useRBAC(index.PERMISSIONS);
41
+ const isLoading = isLoadingInfo || isLoadingRBAC;
45
42
  const colCount = 4;
46
43
  const rowCount = (data?.docVersions?.length || 0) + 1;
47
44
  const handleRegenerateDoc = (version) => {
@@ -60,9 +57,6 @@ const App = () => {
60
57
  });
61
58
  });
62
59
  };
63
- const handleShowConfirmDelete = () => {
64
- setShowConfirmDelete(!showConfirmDelete);
65
- };
66
60
  const handleConfirmDelete = async () => {
67
61
  if (!versionToDelete) {
68
62
  return;
@@ -97,11 +91,11 @@ const App = () => {
97
91
  if (isError) {
98
92
  return /* @__PURE__ */ jsxRuntime.jsx(admin.Page.Error, {});
99
93
  }
100
- return /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Layout, { children: [
101
- /* @__PURE__ */ jsxRuntime.jsx(reactHelmet.Helmet, { title }),
94
+ return /* @__PURE__ */ jsxRuntime.jsxs(admin.Layouts.Root, { children: [
95
+ /* @__PURE__ */ jsxRuntime.jsx(admin.Page.Title, { children: title }),
102
96
  /* @__PURE__ */ jsxRuntime.jsxs(admin.Page.Main, { children: [
103
97
  /* @__PURE__ */ jsxRuntime.jsx(
104
- designSystem.HeaderLayout,
98
+ admin.Layouts.Header,
105
99
  {
106
100
  title,
107
101
  subtitle: formatMessage({
@@ -111,7 +105,7 @@ const App = () => {
111
105
  primaryAction: /* @__PURE__ */ jsxRuntime.jsx(
112
106
  OpenDocLink,
113
107
  {
114
- disabled: !allowedActions.canOpen || !data?.currentVersion || !data?.prefix,
108
+ disabled: !allowedActions.canRead || !data?.currentVersion || !data?.prefix,
115
109
  href: createDocumentationHref(`${data?.prefix}/v${data?.currentVersion}`),
116
110
  startIcon: /* @__PURE__ */ jsxRuntime.jsx(icons.Eye, {}),
117
111
  children: formatMessage({
@@ -122,7 +116,7 @@ const App = () => {
122
116
  )
123
117
  }
124
118
  ),
125
- /* @__PURE__ */ jsxRuntime.jsx(designSystem.ContentLayout, { children: data?.docVersions.length ? /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Table, { colCount, rowCount, children: [
119
+ /* @__PURE__ */ jsxRuntime.jsx(admin.Layouts.Content, { children: data?.docVersions.length ? /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Table, { colCount, rowCount, children: [
126
120
  /* @__PURE__ */ jsxRuntime.jsx(designSystem.Thead, { children: /* @__PURE__ */ jsxRuntime.jsxs(designSystem.Tr, { children: [
127
121
  /* @__PURE__ */ jsxRuntime.jsx(designSystem.Th, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { variant: "sigma", textColor: "neutral600", children: formatMessage({
128
122
  id: getTrad.getTrad("pages.PluginPage.table.version"),
@@ -140,11 +134,10 @@ const App = () => {
140
134
  /* @__PURE__ */ jsxRuntime.jsx(
141
135
  designSystem.IconButton,
142
136
  {
143
- forwardedAs: "a",
144
- disabled: !allowedActions.canOpen,
137
+ tag: "a",
138
+ disabled: !allowedActions.canRead,
145
139
  href: createDocumentationHref(`${data.prefix}/v${doc.version}`),
146
- noBorder: true,
147
- icon: /* @__PURE__ */ jsxRuntime.jsx(icons.Eye, {}),
140
+ borderWidth: 0,
148
141
  target: "_blank",
149
142
  rel: "noopener noreferrer",
150
143
  label: formatMessage(
@@ -153,54 +146,48 @@ const App = () => {
153
146
  defaultMessage: "Open {target}"
154
147
  },
155
148
  { target: `${doc.version}` }
156
- )
149
+ ),
150
+ children: /* @__PURE__ */ jsxRuntime.jsx(icons.Eye, {})
157
151
  }
158
152
  ),
159
153
  allowedActions.canRegenerate ? /* @__PURE__ */ jsxRuntime.jsx(
160
154
  designSystem.IconButton,
161
155
  {
162
156
  onClick: () => handleRegenerateDoc(doc.version),
163
- noBorder: true,
164
- icon: /* @__PURE__ */ jsxRuntime.jsx(icons.Refresh, {}),
157
+ borderWidth: 0,
165
158
  label: formatMessage(
166
159
  {
167
160
  id: getTrad.getTrad("pages.PluginPage.table.icon.regenerate"),
168
161
  defaultMessage: "Regenerate {target}"
169
162
  },
170
163
  { target: `${doc.version}` }
171
- )
164
+ ),
165
+ children: /* @__PURE__ */ jsxRuntime.jsx(icons.ArrowClockwise, {})
172
166
  }
173
167
  ) : null,
174
168
  allowedActions.canUpdate && doc.version !== data.currentVersion ? /* @__PURE__ */ jsxRuntime.jsx(
175
169
  designSystem.IconButton,
176
170
  {
177
171
  onClick: () => handleClickDelete(doc.version),
178
- noBorder: true,
179
- icon: /* @__PURE__ */ jsxRuntime.jsx(icons.Trash, {}),
172
+ borderWidth: 0,
180
173
  label: formatMessage(
181
174
  {
182
175
  id: "global.delete-target",
183
176
  defaultMessage: "Delete {target}"
184
177
  },
185
178
  { target: `${doc.version}` }
186
- )
179
+ ),
180
+ children: /* @__PURE__ */ jsxRuntime.jsx(icons.Trash, {})
187
181
  }
188
182
  ) : null
189
183
  ] }) })
190
184
  ] }, doc.version)) })
191
185
  ] }) : /* @__PURE__ */ jsxRuntime.jsx(designSystem.EmptyStateLayout, { content: "", icon: null }) }),
192
- /* @__PURE__ */ jsxRuntime.jsx(
193
- admin.ConfirmDialog,
194
- {
195
- onConfirm: handleConfirmDelete,
196
- onClose: handleShowConfirmDelete,
197
- isOpen: showConfirmDelete
198
- }
199
- )
186
+ /* @__PURE__ */ jsxRuntime.jsx(designSystem.Dialog.Root, { open: showConfirmDelete, onOpenChange: setShowConfirmDelete, children: /* @__PURE__ */ jsxRuntime.jsx(admin.ConfirmDialog, { onConfirm: handleConfirmDelete }) })
200
187
  ] })
201
188
  ] });
202
189
  };
203
- const OpenDocLink = styled__default.default(designSystem.LinkButton)`
190
+ const OpenDocLink = styledComponents.styled(designSystem.LinkButton)`
204
191
  text-decoration: none;
205
192
  `;
206
193
  const createDocumentationHref = (path) => {
@@ -213,4 +200,4 @@ const createDocumentationHref = (path) => {
213
200
  return `${window.strapi.backendURL}/${path}`;
214
201
  };
215
202
  exports.App = App;
216
- //# sourceMappingURL=App-o4uH8gaQ.js.map
203
+ //# sourceMappingURL=App-Cmiagsr-.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"App-Cmiagsr-.js","sources":["../../admin/src/pages/App.tsx"],"sourcesContent":["/* eslint-disable import/no-default-export */\nimport * as React from 'react';\n\nimport {\n LinkButton,\n Flex,\n IconButton,\n Table,\n Tbody,\n Td,\n Th,\n Thead,\n Tr,\n Typography,\n EmptyStateLayout,\n Dialog,\n} from '@strapi/design-system';\nimport { Eye as Show, ArrowClockwise as Reload, Trash } from '@strapi/icons';\nimport {\n ConfirmDialog,\n useRBAC,\n Page,\n useAPIErrorHandler,\n useNotification,\n Layouts,\n} from '@strapi/strapi/admin';\nimport { useIntl } from 'react-intl';\nimport { styled } from 'styled-components';\n\nimport { PERMISSIONS } from '../constants';\nimport {\n useGetInfoQuery,\n useRegenerateDocMutation,\n useDeleteVersionMutation,\n} from '../services/api';\nimport { getTrad } from '../utils';\n\nconst App = () => {\n const { formatMessage } = useIntl();\n const { toggleNotification } = useNotification();\n const { formatAPIError } = useAPIErrorHandler();\n const { data, isLoading: isLoadingInfo, isError } = useGetInfoQuery();\n const [regenerate] = useRegenerateDocMutation();\n const [deleteVersion] = useDeleteVersionMutation();\n const [showConfirmDelete, setShowConfirmDelete] = React.useState<boolean>(false);\n const [versionToDelete, setVersionToDelete] = React.useState<string>();\n const { allowedActions, isLoading: isLoadingRBAC } = useRBAC(PERMISSIONS);\n\n const isLoading = isLoadingInfo || isLoadingRBAC;\n\n const colCount = 4;\n const rowCount = (data?.docVersions?.length || 0) + 1;\n\n const handleRegenerateDoc = (version: string) => {\n regenerate({ version })\n .unwrap()\n .then(() => {\n toggleNotification({\n type: 'success',\n message: formatMessage({\n id: getTrad('notification.generate.success'),\n defaultMessage: 'Successfully generated documentation',\n }),\n });\n })\n .catch((err) => {\n toggleNotification({\n type: 'warning',\n message: formatAPIError(err),\n });\n });\n };\n\n const handleShowConfirmDelete = () => {\n setShowConfirmDelete(!showConfirmDelete);\n };\n\n const handleConfirmDelete = async () => {\n if (!versionToDelete) {\n // nothing to delete\n return;\n }\n\n await deleteVersion({ version: versionToDelete })\n .unwrap()\n .then(() => {\n toggleNotification({\n type: 'success',\n message: formatMessage({\n id: getTrad('notification.delete.success'),\n defaultMessage: 'Successfully deleted documentation',\n }),\n });\n })\n .catch((err) => {\n toggleNotification({\n type: 'warning',\n message: formatAPIError(err),\n });\n });\n\n setShowConfirmDelete(!showConfirmDelete);\n };\n\n const handleClickDelete = (version: string) => {\n setVersionToDelete(version);\n setShowConfirmDelete(!showConfirmDelete);\n };\n\n const title = formatMessage({\n id: getTrad('plugin.name'),\n defaultMessage: 'Documentation',\n });\n\n if (isLoading) {\n return <Page.Loading />;\n }\n\n if (isError) {\n return <Page.Error />;\n }\n\n return (\n <Layouts.Root>\n <Page.Title>{title}</Page.Title>\n <Page.Main>\n <Layouts.Header\n title={title}\n subtitle={formatMessage({\n id: getTrad('pages.PluginPage.header.description'),\n defaultMessage: 'Configure the documentation plugin',\n })}\n primaryAction={\n <OpenDocLink\n disabled={!allowedActions.canRead || !data?.currentVersion || !data?.prefix}\n href={createDocumentationHref(`${data?.prefix}/v${data?.currentVersion}`)}\n startIcon={<Show />}\n >\n {formatMessage({\n id: getTrad('pages.PluginPage.Button.open'),\n defaultMessage: 'Open Documentation',\n })}\n </OpenDocLink>\n }\n />\n <Layouts.Content>\n {data?.docVersions.length ? (\n <Table colCount={colCount} rowCount={rowCount}>\n <Thead>\n <Tr>\n <Th>\n <Typography variant=\"sigma\" textColor=\"neutral600\">\n {formatMessage({\n id: getTrad('pages.PluginPage.table.version'),\n defaultMessage: 'Version',\n })}\n </Typography>\n </Th>\n <Th>\n <Typography variant=\"sigma\" textColor=\"neutral600\">\n {formatMessage({\n id: getTrad('pages.PluginPage.table.generated'),\n defaultMessage: 'Last Generated',\n })}\n </Typography>\n </Th>\n </Tr>\n </Thead>\n <Tbody>\n {data.docVersions\n .slice(0)\n .sort((a, b) => (a.generatedDate < b.generatedDate ? 1 : -1))\n .map((doc) => (\n <Tr key={doc.version}>\n <Td width=\"50%\">\n <Typography>{doc.version}</Typography>\n </Td>\n <Td width=\"50%\">\n <Typography>{doc.generatedDate}</Typography>\n </Td>\n <Td>\n <Flex justifyContent=\"end\" onClick={(e) => e.stopPropagation()}>\n <IconButton\n tag=\"a\"\n disabled={!allowedActions.canRead}\n href={createDocumentationHref(`${data.prefix}/v${doc.version}`)}\n borderWidth={0}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n label={formatMessage(\n {\n id: getTrad('pages.PluginPage.table.icon.show'),\n defaultMessage: 'Open {target}',\n },\n { target: `${doc.version}` }\n )}\n >\n <Show />\n </IconButton>\n {allowedActions.canRegenerate ? (\n <IconButton\n onClick={() => handleRegenerateDoc(doc.version)}\n borderWidth={0}\n label={formatMessage(\n {\n id: getTrad('pages.PluginPage.table.icon.regenerate'),\n defaultMessage: 'Regenerate {target}',\n },\n { target: `${doc.version}` }\n )}\n >\n <Reload />\n </IconButton>\n ) : null}\n {allowedActions.canUpdate && doc.version !== data.currentVersion ? (\n <IconButton\n onClick={() => handleClickDelete(doc.version)}\n borderWidth={0}\n label={formatMessage(\n {\n id: 'global.delete-target',\n defaultMessage: 'Delete {target}',\n },\n { target: `${doc.version}` }\n )}\n >\n <Trash />\n </IconButton>\n ) : null}\n </Flex>\n </Td>\n </Tr>\n ))}\n </Tbody>\n </Table>\n ) : (\n <EmptyStateLayout content=\"\" icon={null} />\n )}\n </Layouts.Content>\n <Dialog.Root open={showConfirmDelete} onOpenChange={setShowConfirmDelete}>\n <ConfirmDialog onConfirm={handleConfirmDelete} />\n </Dialog.Root>\n </Page.Main>\n </Layouts.Root>\n );\n};\n\n/**\n * TODO: should this be fixed in the DS?\n */\nconst OpenDocLink = styled(LinkButton)`\n text-decoration: none;\n`;\n\nconst createDocumentationHref = (path: string) => {\n if (path.startsWith('http')) {\n return path;\n }\n\n if (path.startsWith('/')) {\n return `${window.strapi.backendURL}${path}`;\n }\n\n return `${window.strapi.backendURL}/${path}`;\n};\n\nexport { App };\n"],"names":["useIntl","useNotification","useAPIErrorHandler","useGetInfoQuery","useRegenerateDocMutation","useDeleteVersionMutation","React","useRBAC","PERMISSIONS","getTrad","jsx","Page","jsxs","Layouts","Show","Table","Thead","Tr","Th","Typography","Tbody","Td","Flex","IconButton","Reload","Trash","EmptyStateLayout","Dialog","ConfirmDialog","styled","LinkButton"],"mappings":"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"}
@@ -1,24 +1,23 @@
1
1
  import { jsx, jsxs } from "react/jsx-runtime";
2
2
  import * as React from "react";
3
- import { Layout, HeaderLayout, ContentLayout, Table, Thead, Tr, Th, Typography, Tbody, Td, Flex, IconButton, EmptyStateLayout, LinkButton } from "@strapi/design-system";
4
- import { Eye, Refresh, Trash } from "@strapi/icons";
5
- import { useNotification, useAPIErrorHandler, useRBAC, Page, ConfirmDialog } from "@strapi/strapi/admin";
6
- import { Helmet } from "react-helmet";
3
+ import { Table, Thead, Tr, Th, Typography, Tbody, Td, Flex, IconButton, EmptyStateLayout, Dialog, LinkButton } from "@strapi/design-system";
4
+ import { Eye, ArrowClockwise, Trash } from "@strapi/icons";
5
+ import { useNotification, useAPIErrorHandler, useRBAC, Page, Layouts, ConfirmDialog } from "@strapi/strapi/admin";
7
6
  import { useIntl } from "react-intl";
8
- import styled from "styled-components";
9
- import { u as useGetInfosQuery, a as useRegenerateDocMutation, b as useDeleteVersionMutation, P as PERMISSIONS } from "./index-jpDwTC-Q.mjs";
10
- import { g as getTrad } from "./getTrad-md7Tjpcv.mjs";
11
- import "axios";
7
+ import { styled } from "styled-components";
8
+ import { P as PERMISSIONS } from "./index-CEoG11hQ.mjs";
9
+ import { u as useGetInfoQuery, a as useRegenerateDocMutation, b as useDeleteVersionMutation, g as getTrad } from "./getTrad-AjYeGjZg.mjs";
12
10
  const App = () => {
13
11
  const { formatMessage } = useIntl();
14
12
  const { toggleNotification } = useNotification();
15
13
  const { formatAPIError } = useAPIErrorHandler();
16
- const { data, isLoading, isError } = useGetInfosQuery();
14
+ const { data, isLoading: isLoadingInfo, isError } = useGetInfoQuery();
17
15
  const [regenerate] = useRegenerateDocMutation();
18
16
  const [deleteVersion] = useDeleteVersionMutation();
19
17
  const [showConfirmDelete, setShowConfirmDelete] = React.useState(false);
20
18
  const [versionToDelete, setVersionToDelete] = React.useState();
21
- const { allowedActions } = useRBAC(PERMISSIONS);
19
+ const { allowedActions, isLoading: isLoadingRBAC } = useRBAC(PERMISSIONS);
20
+ const isLoading = isLoadingInfo || isLoadingRBAC;
22
21
  const colCount = 4;
23
22
  const rowCount = (data?.docVersions?.length || 0) + 1;
24
23
  const handleRegenerateDoc = (version) => {
@@ -37,9 +36,6 @@ const App = () => {
37
36
  });
38
37
  });
39
38
  };
40
- const handleShowConfirmDelete = () => {
41
- setShowConfirmDelete(!showConfirmDelete);
42
- };
43
39
  const handleConfirmDelete = async () => {
44
40
  if (!versionToDelete) {
45
41
  return;
@@ -74,11 +70,11 @@ const App = () => {
74
70
  if (isError) {
75
71
  return /* @__PURE__ */ jsx(Page.Error, {});
76
72
  }
77
- return /* @__PURE__ */ jsxs(Layout, { children: [
78
- /* @__PURE__ */ jsx(Helmet, { title }),
73
+ return /* @__PURE__ */ jsxs(Layouts.Root, { children: [
74
+ /* @__PURE__ */ jsx(Page.Title, { children: title }),
79
75
  /* @__PURE__ */ jsxs(Page.Main, { children: [
80
76
  /* @__PURE__ */ jsx(
81
- HeaderLayout,
77
+ Layouts.Header,
82
78
  {
83
79
  title,
84
80
  subtitle: formatMessage({
@@ -88,7 +84,7 @@ const App = () => {
88
84
  primaryAction: /* @__PURE__ */ jsx(
89
85
  OpenDocLink,
90
86
  {
91
- disabled: !allowedActions.canOpen || !data?.currentVersion || !data?.prefix,
87
+ disabled: !allowedActions.canRead || !data?.currentVersion || !data?.prefix,
92
88
  href: createDocumentationHref(`${data?.prefix}/v${data?.currentVersion}`),
93
89
  startIcon: /* @__PURE__ */ jsx(Eye, {}),
94
90
  children: formatMessage({
@@ -99,7 +95,7 @@ const App = () => {
99
95
  )
100
96
  }
101
97
  ),
102
- /* @__PURE__ */ jsx(ContentLayout, { children: data?.docVersions.length ? /* @__PURE__ */ jsxs(Table, { colCount, rowCount, children: [
98
+ /* @__PURE__ */ jsx(Layouts.Content, { children: data?.docVersions.length ? /* @__PURE__ */ jsxs(Table, { colCount, rowCount, children: [
103
99
  /* @__PURE__ */ jsx(Thead, { children: /* @__PURE__ */ jsxs(Tr, { children: [
104
100
  /* @__PURE__ */ jsx(Th, { children: /* @__PURE__ */ jsx(Typography, { variant: "sigma", textColor: "neutral600", children: formatMessage({
105
101
  id: getTrad("pages.PluginPage.table.version"),
@@ -117,11 +113,10 @@ const App = () => {
117
113
  /* @__PURE__ */ jsx(
118
114
  IconButton,
119
115
  {
120
- forwardedAs: "a",
121
- disabled: !allowedActions.canOpen,
116
+ tag: "a",
117
+ disabled: !allowedActions.canRead,
122
118
  href: createDocumentationHref(`${data.prefix}/v${doc.version}`),
123
- noBorder: true,
124
- icon: /* @__PURE__ */ jsx(Eye, {}),
119
+ borderWidth: 0,
125
120
  target: "_blank",
126
121
  rel: "noopener noreferrer",
127
122
  label: formatMessage(
@@ -130,50 +125,44 @@ const App = () => {
130
125
  defaultMessage: "Open {target}"
131
126
  },
132
127
  { target: `${doc.version}` }
133
- )
128
+ ),
129
+ children: /* @__PURE__ */ jsx(Eye, {})
134
130
  }
135
131
  ),
136
132
  allowedActions.canRegenerate ? /* @__PURE__ */ jsx(
137
133
  IconButton,
138
134
  {
139
135
  onClick: () => handleRegenerateDoc(doc.version),
140
- noBorder: true,
141
- icon: /* @__PURE__ */ jsx(Refresh, {}),
136
+ borderWidth: 0,
142
137
  label: formatMessage(
143
138
  {
144
139
  id: getTrad("pages.PluginPage.table.icon.regenerate"),
145
140
  defaultMessage: "Regenerate {target}"
146
141
  },
147
142
  { target: `${doc.version}` }
148
- )
143
+ ),
144
+ children: /* @__PURE__ */ jsx(ArrowClockwise, {})
149
145
  }
150
146
  ) : null,
151
147
  allowedActions.canUpdate && doc.version !== data.currentVersion ? /* @__PURE__ */ jsx(
152
148
  IconButton,
153
149
  {
154
150
  onClick: () => handleClickDelete(doc.version),
155
- noBorder: true,
156
- icon: /* @__PURE__ */ jsx(Trash, {}),
151
+ borderWidth: 0,
157
152
  label: formatMessage(
158
153
  {
159
154
  id: "global.delete-target",
160
155
  defaultMessage: "Delete {target}"
161
156
  },
162
157
  { target: `${doc.version}` }
163
- )
158
+ ),
159
+ children: /* @__PURE__ */ jsx(Trash, {})
164
160
  }
165
161
  ) : null
166
162
  ] }) })
167
163
  ] }, doc.version)) })
168
164
  ] }) : /* @__PURE__ */ jsx(EmptyStateLayout, { content: "", icon: null }) }),
169
- /* @__PURE__ */ jsx(
170
- ConfirmDialog,
171
- {
172
- onConfirm: handleConfirmDelete,
173
- onClose: handleShowConfirmDelete,
174
- isOpen: showConfirmDelete
175
- }
176
- )
165
+ /* @__PURE__ */ jsx(Dialog.Root, { open: showConfirmDelete, onOpenChange: setShowConfirmDelete, children: /* @__PURE__ */ jsx(ConfirmDialog, { onConfirm: handleConfirmDelete }) })
177
166
  ] })
178
167
  ] });
179
168
  };
@@ -192,4 +181,4 @@ const createDocumentationHref = (path) => {
192
181
  export {
193
182
  App
194
183
  };
195
- //# sourceMappingURL=App-ig-uE4do.mjs.map
184
+ //# sourceMappingURL=App-pk6g9tYL.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"App-pk6g9tYL.mjs","sources":["../../admin/src/pages/App.tsx"],"sourcesContent":["/* eslint-disable import/no-default-export */\nimport * as React from 'react';\n\nimport {\n LinkButton,\n Flex,\n IconButton,\n Table,\n Tbody,\n Td,\n Th,\n Thead,\n Tr,\n Typography,\n EmptyStateLayout,\n Dialog,\n} from '@strapi/design-system';\nimport { Eye as Show, ArrowClockwise as Reload, Trash } from '@strapi/icons';\nimport {\n ConfirmDialog,\n useRBAC,\n Page,\n useAPIErrorHandler,\n useNotification,\n Layouts,\n} from '@strapi/strapi/admin';\nimport { useIntl } from 'react-intl';\nimport { styled } from 'styled-components';\n\nimport { PERMISSIONS } from '../constants';\nimport {\n useGetInfoQuery,\n useRegenerateDocMutation,\n useDeleteVersionMutation,\n} from '../services/api';\nimport { getTrad } from '../utils';\n\nconst App = () => {\n const { formatMessage } = useIntl();\n const { toggleNotification } = useNotification();\n const { formatAPIError } = useAPIErrorHandler();\n const { data, isLoading: isLoadingInfo, isError } = useGetInfoQuery();\n const [regenerate] = useRegenerateDocMutation();\n const [deleteVersion] = useDeleteVersionMutation();\n const [showConfirmDelete, setShowConfirmDelete] = React.useState<boolean>(false);\n const [versionToDelete, setVersionToDelete] = React.useState<string>();\n const { allowedActions, isLoading: isLoadingRBAC } = useRBAC(PERMISSIONS);\n\n const isLoading = isLoadingInfo || isLoadingRBAC;\n\n const colCount = 4;\n const rowCount = (data?.docVersions?.length || 0) + 1;\n\n const handleRegenerateDoc = (version: string) => {\n regenerate({ version })\n .unwrap()\n .then(() => {\n toggleNotification({\n type: 'success',\n message: formatMessage({\n id: getTrad('notification.generate.success'),\n defaultMessage: 'Successfully generated documentation',\n }),\n });\n })\n .catch((err) => {\n toggleNotification({\n type: 'warning',\n message: formatAPIError(err),\n });\n });\n };\n\n const handleShowConfirmDelete = () => {\n setShowConfirmDelete(!showConfirmDelete);\n };\n\n const handleConfirmDelete = async () => {\n if (!versionToDelete) {\n // nothing to delete\n return;\n }\n\n await deleteVersion({ version: versionToDelete })\n .unwrap()\n .then(() => {\n toggleNotification({\n type: 'success',\n message: formatMessage({\n id: getTrad('notification.delete.success'),\n defaultMessage: 'Successfully deleted documentation',\n }),\n });\n })\n .catch((err) => {\n toggleNotification({\n type: 'warning',\n message: formatAPIError(err),\n });\n });\n\n setShowConfirmDelete(!showConfirmDelete);\n };\n\n const handleClickDelete = (version: string) => {\n setVersionToDelete(version);\n setShowConfirmDelete(!showConfirmDelete);\n };\n\n const title = formatMessage({\n id: getTrad('plugin.name'),\n defaultMessage: 'Documentation',\n });\n\n if (isLoading) {\n return <Page.Loading />;\n }\n\n if (isError) {\n return <Page.Error />;\n }\n\n return (\n <Layouts.Root>\n <Page.Title>{title}</Page.Title>\n <Page.Main>\n <Layouts.Header\n title={title}\n subtitle={formatMessage({\n id: getTrad('pages.PluginPage.header.description'),\n defaultMessage: 'Configure the documentation plugin',\n })}\n primaryAction={\n <OpenDocLink\n disabled={!allowedActions.canRead || !data?.currentVersion || !data?.prefix}\n href={createDocumentationHref(`${data?.prefix}/v${data?.currentVersion}`)}\n startIcon={<Show />}\n >\n {formatMessage({\n id: getTrad('pages.PluginPage.Button.open'),\n defaultMessage: 'Open Documentation',\n })}\n </OpenDocLink>\n }\n />\n <Layouts.Content>\n {data?.docVersions.length ? (\n <Table colCount={colCount} rowCount={rowCount}>\n <Thead>\n <Tr>\n <Th>\n <Typography variant=\"sigma\" textColor=\"neutral600\">\n {formatMessage({\n id: getTrad('pages.PluginPage.table.version'),\n defaultMessage: 'Version',\n })}\n </Typography>\n </Th>\n <Th>\n <Typography variant=\"sigma\" textColor=\"neutral600\">\n {formatMessage({\n id: getTrad('pages.PluginPage.table.generated'),\n defaultMessage: 'Last Generated',\n })}\n </Typography>\n </Th>\n </Tr>\n </Thead>\n <Tbody>\n {data.docVersions\n .slice(0)\n .sort((a, b) => (a.generatedDate < b.generatedDate ? 1 : -1))\n .map((doc) => (\n <Tr key={doc.version}>\n <Td width=\"50%\">\n <Typography>{doc.version}</Typography>\n </Td>\n <Td width=\"50%\">\n <Typography>{doc.generatedDate}</Typography>\n </Td>\n <Td>\n <Flex justifyContent=\"end\" onClick={(e) => e.stopPropagation()}>\n <IconButton\n tag=\"a\"\n disabled={!allowedActions.canRead}\n href={createDocumentationHref(`${data.prefix}/v${doc.version}`)}\n borderWidth={0}\n target=\"_blank\"\n rel=\"noopener noreferrer\"\n label={formatMessage(\n {\n id: getTrad('pages.PluginPage.table.icon.show'),\n defaultMessage: 'Open {target}',\n },\n { target: `${doc.version}` }\n )}\n >\n <Show />\n </IconButton>\n {allowedActions.canRegenerate ? (\n <IconButton\n onClick={() => handleRegenerateDoc(doc.version)}\n borderWidth={0}\n label={formatMessage(\n {\n id: getTrad('pages.PluginPage.table.icon.regenerate'),\n defaultMessage: 'Regenerate {target}',\n },\n { target: `${doc.version}` }\n )}\n >\n <Reload />\n </IconButton>\n ) : null}\n {allowedActions.canUpdate && doc.version !== data.currentVersion ? (\n <IconButton\n onClick={() => handleClickDelete(doc.version)}\n borderWidth={0}\n label={formatMessage(\n {\n id: 'global.delete-target',\n defaultMessage: 'Delete {target}',\n },\n { target: `${doc.version}` }\n )}\n >\n <Trash />\n </IconButton>\n ) : null}\n </Flex>\n </Td>\n </Tr>\n ))}\n </Tbody>\n </Table>\n ) : (\n <EmptyStateLayout content=\"\" icon={null} />\n )}\n </Layouts.Content>\n <Dialog.Root open={showConfirmDelete} onOpenChange={setShowConfirmDelete}>\n <ConfirmDialog onConfirm={handleConfirmDelete} />\n </Dialog.Root>\n </Page.Main>\n </Layouts.Root>\n );\n};\n\n/**\n * TODO: should this be fixed in the DS?\n */\nconst OpenDocLink = styled(LinkButton)`\n text-decoration: none;\n`;\n\nconst createDocumentationHref = (path: string) => {\n if (path.startsWith('http')) {\n return path;\n }\n\n if (path.startsWith('/')) {\n return `${window.strapi.backendURL}${path}`;\n }\n\n return `${window.strapi.backendURL}/${path}`;\n};\n\nexport { App };\n"],"names":["Show","Reload"],"mappings":"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"}
@@ -1,25 +1,27 @@
1
1
  import { jsx, jsxs } from "react/jsx-runtime";
2
- import { FieldAction, HeaderLayout, Button, ContentLayout, Box, Flex, Typography, Grid, GridItem, ToggleInput, TextInput, Main } from "@strapi/design-system";
3
- import { translatedErrors, useRBAC, useNotification, useAPIErrorHandler, Page } from "@strapi/strapi/admin";
2
+ import { Field, Button, Box, Flex, Typography, Grid, Toggle, TextInput, Main } from "@strapi/design-system";
3
+ import { translatedErrors, useRBAC, Layouts, useNotification, useAPIErrorHandler, Page } from "@strapi/strapi/admin";
4
4
  import { useIntl } from "react-intl";
5
5
  import * as React from "react";
6
6
  import { Check, Eye, EyeStriked } from "@strapi/icons";
7
7
  import { Formik, Form } from "formik";
8
- import styled from "styled-components";
8
+ import { styled } from "styled-components";
9
9
  import * as yup from "yup";
10
- import { P as PERMISSIONS, u as useGetInfosQuery, c as useUpdateSettingsMutation, i as isBaseQueryError } from "./index-jpDwTC-Q.mjs";
11
- import { g as getTrad } from "./getTrad-md7Tjpcv.mjs";
12
- import "axios";
10
+ import { P as PERMISSIONS } from "./index-CEoG11hQ.mjs";
11
+ import { g as getTrad, u as useGetInfoQuery, c as useUpdateSettingsMutation } from "./getTrad-AjYeGjZg.mjs";
12
+ const isBaseQueryError = (error) => {
13
+ return error.name !== void 0;
14
+ };
13
15
  const schema = yup.object().shape({
14
16
  restrictedAccess: yup.boolean(),
15
17
  password: yup.string().when("restrictedAccess", (value, initSchema) => {
16
18
  return value ? initSchema.required(translatedErrors.required.id) : initSchema;
17
19
  })
18
20
  });
19
- const FieldActionWrapper = styled(FieldAction)`
21
+ const FieldActionWrapper = styled(Field.Action)`
20
22
  svg {
21
- height: 1rem;
22
- width: 1rem;
23
+ height: 1.6rem;
24
+ width: 1.6rem;
23
25
  path {
24
26
  fill: ${({ theme }) => theme.colors.neutral600};
25
27
  }
@@ -51,7 +53,7 @@ const SettingsForm = ({ data, onSubmit }) => {
51
53
  }) => {
52
54
  return /* @__PURE__ */ jsxs(Form, { noValidate: true, onSubmit: handleSubmit, children: [
53
55
  /* @__PURE__ */ jsx(
54
- HeaderLayout,
56
+ Layouts.Header,
55
57
  {
56
58
  title: formatMessage({
57
59
  id: getTrad("plugin.name"),
@@ -75,7 +77,7 @@ const SettingsForm = ({ data, onSubmit }) => {
75
77
  )
76
78
  }
77
79
  ),
78
- /* @__PURE__ */ jsx(ContentLayout, { children: /* @__PURE__ */ jsx(
80
+ /* @__PURE__ */ jsx(Layouts.Content, { children: /* @__PURE__ */ jsx(
79
81
  Box,
80
82
  {
81
83
  background: "neutral0",
@@ -86,71 +88,87 @@ const SettingsForm = ({ data, onSubmit }) => {
86
88
  paddingLeft: 7,
87
89
  paddingRight: 7,
88
90
  children: /* @__PURE__ */ jsxs(Flex, { direction: "column", alignItems: "stretch", gap: 4, children: [
89
- /* @__PURE__ */ jsx(Typography, { variant: "delta", as: "h2", children: formatMessage({
91
+ /* @__PURE__ */ jsx(Typography, { variant: "delta", tag: "h2", children: formatMessage({
90
92
  id: "global.settings",
91
93
  defaultMessage: "Settings"
92
94
  }) }),
93
- /* @__PURE__ */ jsxs(Grid, { gap: 4, children: [
94
- /* @__PURE__ */ jsx(GridItem, { col: 6, s: 12, children: /* @__PURE__ */ jsx(
95
- ToggleInput,
95
+ /* @__PURE__ */ jsxs(Grid.Root, { gap: 4, children: [
96
+ /* @__PURE__ */ jsx(Grid.Item, { col: 6, s: 12, children: /* @__PURE__ */ jsxs(
97
+ Field.Root,
96
98
  {
97
99
  name: "restrictedAccess",
98
- label: formatMessage({
99
- id: getTrad("pages.SettingsPage.toggle.label"),
100
- defaultMessage: "Restricted Access"
101
- }),
102
100
  hint: formatMessage({
103
101
  id: getTrad("pages.SettingsPage.toggle.hint"),
104
102
  defaultMessage: "Make the documentation endpoint private"
105
103
  }),
106
- checked: values.restrictedAccess,
107
- onChange: () => {
108
- if (values.restrictedAccess === true) {
109
- setFieldValue("password", "", false);
110
- setFieldTouched("password", false, false);
111
- setFieldError("password", void 0);
112
- }
113
- setFieldValue("restrictedAccess", !values.restrictedAccess, false);
114
- },
115
- onLabel: "On",
116
- offLabel: "Off"
104
+ children: [
105
+ /* @__PURE__ */ jsx(Field.Label, { children: formatMessage({
106
+ id: getTrad("pages.SettingsPage.toggle.label"),
107
+ defaultMessage: "Restricted Access"
108
+ }) }),
109
+ /* @__PURE__ */ jsx(
110
+ Toggle,
111
+ {
112
+ checked: values.restrictedAccess,
113
+ onChange: () => {
114
+ if (values.restrictedAccess === true) {
115
+ setFieldValue("password", "", false);
116
+ setFieldTouched("password", false, false);
117
+ setFieldError("password", void 0);
118
+ }
119
+ setFieldValue("restrictedAccess", !values.restrictedAccess, false);
120
+ },
121
+ onLabel: "On",
122
+ offLabel: "Off"
123
+ }
124
+ ),
125
+ /* @__PURE__ */ jsx(Field.Hint, {})
126
+ ]
117
127
  }
118
128
  ) }),
119
- values.restrictedAccess && /* @__PURE__ */ jsx(GridItem, { col: 6, s: 12, children: /* @__PURE__ */ jsx(
120
- TextInput,
129
+ values.restrictedAccess && /* @__PURE__ */ jsx(Grid.Item, { col: 6, s: 12, children: /* @__PURE__ */ jsxs(
130
+ Field.Root,
121
131
  {
122
- label: formatMessage({
123
- id: "global.password",
124
- defaultMessage: "Password"
125
- }),
126
132
  name: "password",
127
- placeholder: "**********",
128
- type: passwordShown ? "text" : "password",
129
- value: values.password,
130
- onChange: handleChange,
131
133
  error: errors.password ? formatMessage({
132
134
  id: errors.password,
133
135
  defaultMessage: errors.password
134
136
  }) : void 0,
135
- endAction: /* @__PURE__ */ jsx(
136
- FieldActionWrapper,
137
- {
138
- onClick: (e) => {
139
- e.stopPropagation();
140
- setPasswordShown((prev) => !prev);
141
- },
142
- label: formatMessage(
143
- passwordShown ? {
144
- id: "Auth.form.password.show-password",
145
- defaultMessage: "Show password"
146
- } : {
147
- id: "Auth.form.password.hide-password",
148
- defaultMessage: "Hide password"
149
- }
150
- ),
151
- children: passwordShown ? /* @__PURE__ */ jsx(Eye, {}) : /* @__PURE__ */ jsx(EyeStriked, {})
152
- }
153
- )
137
+ children: [
138
+ /* @__PURE__ */ jsx(Field.Label, { children: formatMessage({
139
+ id: "global.password",
140
+ defaultMessage: "Password"
141
+ }) }),
142
+ /* @__PURE__ */ jsx(
143
+ TextInput,
144
+ {
145
+ placeholder: "**********",
146
+ type: passwordShown ? "text" : "password",
147
+ value: values.password,
148
+ onChange: handleChange,
149
+ endAction: /* @__PURE__ */ jsx(
150
+ FieldActionWrapper,
151
+ {
152
+ onClick: (e) => {
153
+ e.stopPropagation();
154
+ setPasswordShown((prev) => !prev);
155
+ },
156
+ label: formatMessage(
157
+ passwordShown ? {
158
+ id: "Auth.form.password.show-password",
159
+ defaultMessage: "Show password"
160
+ } : {
161
+ id: "Auth.form.password.hide-password",
162
+ defaultMessage: "Hide password"
163
+ }
164
+ ),
165
+ children: passwordShown ? /* @__PURE__ */ jsx(Eye, {}) : /* @__PURE__ */ jsx(EyeStriked, {})
166
+ }
167
+ )
168
+ }
169
+ ),
170
+ /* @__PURE__ */ jsx(Field.Error, {})
171
+ ]
154
172
  }
155
173
  ) })
156
174
  ] })
@@ -169,7 +187,7 @@ const SettingsPage = () => {
169
187
  _unstableFormatAPIError: formatAPIError,
170
188
  _unstableFormatValidationErrors: formatValidationErrors
171
189
  } = useAPIErrorHandler();
172
- const { data, isError, isLoading } = useGetInfosQuery();
190
+ const { data, isError, isLoading, isFetching } = useGetInfoQuery();
173
191
  const [updateSettings] = useUpdateSettingsMutation();
174
192
  const onUpdateSettings = async (body, formik) => {
175
193
  return updateSettings({ body }).unwrap().then(() => {
@@ -191,7 +209,7 @@ const SettingsPage = () => {
191
209
  }
192
210
  });
193
211
  };
194
- if (isLoading) {
212
+ if (isLoading || isFetching) {
195
213
  return /* @__PURE__ */ jsx(Page.Loading, {});
196
214
  }
197
215
  if (isError) {
@@ -202,4 +220,4 @@ const SettingsPage = () => {
202
220
  export {
203
221
  SettingsPage
204
222
  };
205
- //# sourceMappingURL=Settings-3hsPOP_b.mjs.map
223
+ //# sourceMappingURL=Settings-CqLmbMfv.mjs.map