@strapi/admin 5.8.1 → 5.10.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/_internal.js +86 -30
- package/dist/_internal.js.map +1 -1
- package/dist/_internal.mjs +85 -31
- package/dist/_internal.mjs.map +1 -1
- package/dist/admin/chunks/AdminSeatInfo-BfPqdNN0.js +116 -0
- package/dist/admin/chunks/AdminSeatInfo-BfPqdNN0.js.map +1 -0
- package/dist/admin/chunks/AdminSeatInfo-Cw1ujAsZ.mjs +114 -0
- package/dist/admin/chunks/AdminSeatInfo-Cw1ujAsZ.mjs.map +1 -0
- package/dist/admin/chunks/ApplicationInfoPage-Ch6hKH4Y.mjs +932 -0
- package/dist/admin/chunks/ApplicationInfoPage-Ch6hKH4Y.mjs.map +1 -0
- package/dist/admin/chunks/ApplicationInfoPage-DIiAE-tT.js +953 -0
- package/dist/admin/chunks/ApplicationInfoPage-DIiAE-tT.js.map +1 -0
- package/dist/admin/chunks/AuthResponse-DFS6gVO4.mjs +87 -0
- package/dist/admin/chunks/AuthResponse-DFS6gVO4.mjs.map +1 -0
- package/dist/admin/chunks/AuthResponse-DI-Q1kQL.js +108 -0
- package/dist/admin/chunks/AuthResponse-DI-Q1kQL.js.map +1 -0
- package/dist/admin/chunks/AuthenticatedLayout-BNWCtSH2.mjs +1223 -0
- package/dist/admin/chunks/AuthenticatedLayout-BNWCtSH2.mjs.map +1 -0
- package/dist/admin/chunks/AuthenticatedLayout-D067wUoO.js +1245 -0
- package/dist/admin/chunks/AuthenticatedLayout-D067wUoO.js.map +1 -0
- package/dist/admin/chunks/CreateActionEE-CSZxFkrZ.js +74 -0
- package/dist/admin/chunks/CreateActionEE-CSZxFkrZ.js.map +1 -0
- package/dist/admin/chunks/CreateActionEE-DZ6ApqOF.mjs +53 -0
- package/dist/admin/chunks/CreateActionEE-DZ6ApqOF.mjs.map +1 -0
- package/dist/admin/chunks/CreatePage-0PdN9Fyc.mjs +355 -0
- package/dist/admin/chunks/CreatePage-0PdN9Fyc.mjs.map +1 -0
- package/dist/admin/chunks/CreatePage-BK_ivKDk.js +378 -0
- package/dist/admin/chunks/CreatePage-BK_ivKDk.js.map +1 -0
- package/dist/admin/chunks/CreatePage-C8PMNi_P.js +57 -0
- package/dist/admin/chunks/CreatePage-C8PMNi_P.js.map +1 -0
- package/dist/admin/chunks/CreatePage-DojcQqvH.mjs +54 -0
- package/dist/admin/chunks/CreatePage-DojcQqvH.mjs.map +1 -0
- package/dist/admin/chunks/CreateView-BuN2a7bo.mjs +57 -0
- package/dist/admin/chunks/CreateView-BuN2a7bo.mjs.map +1 -0
- package/dist/admin/chunks/CreateView-DB0xD4f5.mjs +62 -0
- package/dist/admin/chunks/CreateView-DB0xD4f5.mjs.map +1 -0
- package/dist/admin/chunks/CreateView-DtccbWiR.js +59 -0
- package/dist/admin/chunks/CreateView-DtccbWiR.js.map +1 -0
- package/dist/admin/chunks/CreateView-ITRNGoQ6.js +64 -0
- package/dist/admin/chunks/CreateView-ITRNGoQ6.js.map +1 -0
- package/dist/admin/chunks/EditPage-BNZ90ISm.mjs +986 -0
- package/dist/admin/chunks/EditPage-BNZ90ISm.mjs.map +1 -0
- package/dist/admin/chunks/EditPage-BazkPM17.mjs +351 -0
- package/dist/admin/chunks/EditPage-BazkPM17.mjs.map +1 -0
- package/dist/admin/chunks/EditPage-DiDSR0tz.js +1010 -0
- package/dist/admin/chunks/EditPage-DiDSR0tz.js.map +1 -0
- package/dist/admin/chunks/EditPage-LRn1-C88.mjs +397 -0
- package/dist/admin/chunks/EditPage-LRn1-C88.mjs.map +1 -0
- package/dist/admin/chunks/EditPage-ibh8EtSv.js +420 -0
- package/dist/admin/chunks/EditPage-ibh8EtSv.js.map +1 -0
- package/dist/admin/chunks/EditPage-r043NYgB.js +374 -0
- package/dist/admin/chunks/EditPage-r043NYgB.js.map +1 -0
- package/dist/admin/chunks/EditView-CgMgqsza.mjs +398 -0
- package/dist/admin/chunks/EditView-CgMgqsza.mjs.map +1 -0
- package/dist/admin/chunks/EditView-DxmJI6e0.js +421 -0
- package/dist/admin/chunks/EditView-DxmJI6e0.js.map +1 -0
- package/dist/admin/chunks/EditViewPage-BE_u8pQP.mjs +1039 -0
- package/dist/admin/chunks/EditViewPage-BE_u8pQP.mjs.map +1 -0
- package/dist/admin/chunks/EditViewPage-Bz4GEIsc.js +1062 -0
- package/dist/admin/chunks/EditViewPage-Bz4GEIsc.js.map +1 -0
- package/dist/admin/chunks/EventsTable-CZY0aI5G.js +97 -0
- package/dist/admin/chunks/EventsTable-CZY0aI5G.js.map +1 -0
- package/dist/admin/chunks/EventsTable-CsFf4rOj.mjs +95 -0
- package/dist/admin/chunks/EventsTable-CsFf4rOj.mjs.map +1 -0
- package/dist/admin/chunks/HomePage-C2Sue0eX.mjs +55 -0
- package/dist/admin/chunks/HomePage-C2Sue0eX.mjs.map +1 -0
- package/dist/admin/chunks/HomePage-CFTx_SgI.mjs +567 -0
- package/dist/admin/chunks/HomePage-CFTx_SgI.mjs.map +1 -0
- package/dist/admin/chunks/HomePage-Df0YSqNE.js +589 -0
- package/dist/admin/chunks/HomePage-Df0YSqNE.js.map +1 -0
- package/dist/admin/chunks/HomePage-ebJLhO6a.js +57 -0
- package/dist/admin/chunks/HomePage-ebJLhO6a.js.map +1 -0
- package/dist/admin/chunks/InstalledPlugins-B4gyKUHh.mjs +174 -0
- package/dist/admin/chunks/InstalledPlugins-B4gyKUHh.mjs.map +1 -0
- package/dist/admin/chunks/InstalledPlugins-BtwwVsQ_.js +196 -0
- package/dist/admin/chunks/InstalledPlugins-BtwwVsQ_.js.map +1 -0
- package/dist/admin/chunks/Layout-BZTqa7oj.js +296 -0
- package/dist/admin/chunks/Layout-BZTqa7oj.js.map +1 -0
- package/dist/admin/chunks/Layout-B_xkPr1q.mjs +275 -0
- package/dist/admin/chunks/Layout-B_xkPr1q.mjs.map +1 -0
- package/dist/admin/chunks/ListPage-Beh8uBDE.mjs +610 -0
- package/dist/admin/chunks/ListPage-Beh8uBDE.mjs.map +1 -0
- package/dist/admin/chunks/ListPage-BtMdu1eQ.mjs +696 -0
- package/dist/admin/chunks/ListPage-BtMdu1eQ.mjs.map +1 -0
- package/dist/admin/chunks/ListPage-CENQarKY.mjs +452 -0
- package/dist/admin/chunks/ListPage-CENQarKY.mjs.map +1 -0
- package/dist/admin/chunks/ListPage-Czwak48Z.mjs +373 -0
- package/dist/admin/chunks/ListPage-Czwak48Z.mjs.map +1 -0
- package/dist/admin/chunks/ListPage-DgmOJv7H.js +632 -0
- package/dist/admin/chunks/ListPage-DgmOJv7H.js.map +1 -0
- package/dist/admin/chunks/ListPage-Du6Jt5wY.js +721 -0
- package/dist/admin/chunks/ListPage-Du6Jt5wY.js.map +1 -0
- package/dist/admin/chunks/ListPage-LqcmQd_Q.js +474 -0
- package/dist/admin/chunks/ListPage-LqcmQd_Q.js.map +1 -0
- package/dist/admin/chunks/ListPage-YW-UVjk3.js +57 -0
- package/dist/admin/chunks/ListPage-YW-UVjk3.js.map +1 -0
- package/dist/admin/chunks/ListPage-gKsEm3Px.js +395 -0
- package/dist/admin/chunks/ListPage-gKsEm3Px.js.map +1 -0
- package/dist/admin/chunks/ListPage-r9rW__R8.mjs +55 -0
- package/dist/admin/chunks/ListPage-r9rW__R8.mjs.map +1 -0
- package/dist/admin/chunks/ListView-BfwBUxHL.js +276 -0
- package/dist/admin/chunks/ListView-BfwBUxHL.js.map +1 -0
- package/dist/admin/chunks/ListView-Bys8EN-y.js +278 -0
- package/dist/admin/chunks/ListView-Bys8EN-y.js.map +1 -0
- package/dist/admin/chunks/ListView-CajksON_.mjs +255 -0
- package/dist/admin/chunks/ListView-CajksON_.mjs.map +1 -0
- package/dist/admin/chunks/ListView-Q2AO0JSX.mjs +253 -0
- package/dist/admin/chunks/ListView-Q2AO0JSX.mjs.map +1 -0
- package/dist/admin/chunks/Login-5ByBaKI3.mjs +93 -0
- package/dist/admin/chunks/Login-5ByBaKI3.mjs.map +1 -0
- package/dist/admin/chunks/Login-BpEOnVbU.js +95 -0
- package/dist/admin/chunks/Login-BpEOnVbU.js.map +1 -0
- package/dist/admin/chunks/MagicLinkEE-CiQG7NL3.mjs +66 -0
- package/dist/admin/chunks/MagicLinkEE-CiQG7NL3.mjs.map +1 -0
- package/dist/admin/chunks/MagicLinkEE-a-AbOB4s.js +68 -0
- package/dist/admin/chunks/MagicLinkEE-a-AbOB4s.js.map +1 -0
- package/dist/admin/chunks/MarketplacePage-BrHNQ8SG.mjs +1134 -0
- package/dist/admin/chunks/MarketplacePage-BrHNQ8SG.mjs.map +1 -0
- package/dist/admin/chunks/MarketplacePage-my1nDaHy.js +1158 -0
- package/dist/admin/chunks/MarketplacePage-my1nDaHy.js.map +1 -0
- package/dist/admin/chunks/ModalForm-Br-NALJ0.js +26 -0
- package/dist/admin/chunks/ModalForm-Br-NALJ0.js.map +1 -0
- package/dist/admin/chunks/ModalForm-CZ98aSC9.mjs +23 -0
- package/dist/admin/chunks/ModalForm-CZ98aSC9.mjs.map +1 -0
- package/dist/admin/chunks/Ornaments-CvdERnok.js +217 -0
- package/dist/admin/chunks/Ornaments-CvdERnok.js.map +1 -0
- package/dist/admin/chunks/Ornaments-DlP663hn.mjs +212 -0
- package/dist/admin/chunks/Ornaments-DlP663hn.mjs.map +1 -0
- package/dist/admin/chunks/Permissions-C7FA_7J9.js +2285 -0
- package/dist/admin/chunks/Permissions-C7FA_7J9.js.map +1 -0
- package/dist/admin/chunks/Permissions-CuLck8vw.mjs +2264 -0
- package/dist/admin/chunks/Permissions-CuLck8vw.mjs.map +1 -0
- package/dist/admin/chunks/PrivateRoute-BYKd2yE4.mjs +18 -0
- package/dist/admin/chunks/PrivateRoute-BYKd2yE4.mjs.map +1 -0
- package/dist/admin/chunks/PrivateRoute-BnxIlIDb.js +20 -0
- package/dist/admin/chunks/PrivateRoute-BnxIlIDb.js.map +1 -0
- package/dist/admin/chunks/ProfilePage-C8zWtYzY.js +520 -0
- package/dist/admin/chunks/ProfilePage-C8zWtYzY.js.map +1 -0
- package/dist/admin/chunks/ProfilePage-Do6nPMsx.mjs +498 -0
- package/dist/admin/chunks/ProfilePage-Do6nPMsx.mjs.map +1 -0
- package/dist/admin/chunks/PurchaseAuditLogs-BTAi887h.js +89 -0
- package/dist/admin/chunks/PurchaseAuditLogs-BTAi887h.js.map +1 -0
- package/dist/admin/chunks/PurchaseAuditLogs-McvZESGI.mjs +87 -0
- package/dist/admin/chunks/PurchaseAuditLogs-McvZESGI.mjs.map +1 -0
- package/dist/admin/chunks/PurchaseContentHistory-dfepsahq.js +89 -0
- package/dist/admin/chunks/PurchaseContentHistory-dfepsahq.js.map +1 -0
- package/dist/admin/chunks/PurchaseContentHistory-pb7RDvhZ.mjs +87 -0
- package/dist/admin/chunks/PurchaseContentHistory-pb7RDvhZ.mjs.map +1 -0
- package/dist/admin/chunks/PurchaseSingleSignOn-BUB9Irlt.mjs +87 -0
- package/dist/admin/chunks/PurchaseSingleSignOn-BUB9Irlt.mjs.map +1 -0
- package/dist/admin/chunks/PurchaseSingleSignOn-Dgal5RnY.js +89 -0
- package/dist/admin/chunks/PurchaseSingleSignOn-Dgal5RnY.js.map +1 -0
- package/dist/admin/chunks/RelativeTime-ChFKZs4z.js +76 -0
- package/dist/admin/chunks/RelativeTime-ChFKZs4z.js.map +1 -0
- package/dist/admin/chunks/RelativeTime-r7oMqUVy.mjs +55 -0
- package/dist/admin/chunks/RelativeTime-r7oMqUVy.mjs.map +1 -0
- package/dist/admin/chunks/SSOProviders-BC_OI8Id.js +107 -0
- package/dist/admin/chunks/SSOProviders-BC_OI8Id.js.map +1 -0
- package/dist/admin/chunks/SSOProviders-Dw_eYbX-.mjs +105 -0
- package/dist/admin/chunks/SSOProviders-Dw_eYbX-.mjs.map +1 -0
- package/dist/admin/chunks/SelectRoles-CG3Czm0u.mjs +124 -0
- package/dist/admin/chunks/SelectRoles-CG3Czm0u.mjs.map +1 -0
- package/dist/admin/chunks/SelectRoles-Clx1_4zB.js +128 -0
- package/dist/admin/chunks/SelectRoles-Clx1_4zB.js.map +1 -0
- package/dist/admin/chunks/SingleSignOnPage-Bqn13t3u.mjs +284 -0
- package/dist/admin/chunks/SingleSignOnPage-Bqn13t3u.mjs.map +1 -0
- package/dist/admin/chunks/SingleSignOnPage-DqHWnXWQ.js +306 -0
- package/dist/admin/chunks/SingleSignOnPage-DqHWnXWQ.js.map +1 -0
- package/dist/admin/chunks/Table-BHi0q5It.js +197 -0
- package/dist/admin/chunks/Table-BHi0q5It.js.map +1 -0
- package/dist/admin/chunks/Table-Ra6bYcx7.mjs +195 -0
- package/dist/admin/chunks/Table-Ra6bYcx7.mjs.map +1 -0
- package/dist/admin/chunks/Theme-CDaBfQ-7.mjs +1762 -0
- package/dist/admin/chunks/Theme-CDaBfQ-7.mjs.map +1 -0
- package/dist/admin/chunks/Theme-CFGbtvHi.js +1831 -0
- package/dist/admin/chunks/Theme-CFGbtvHi.js.map +1 -0
- package/dist/admin/chunks/TokenTypeSelect-BIRgChNx.mjs +367 -0
- package/dist/admin/chunks/TokenTypeSelect-BIRgChNx.mjs.map +1 -0
- package/dist/admin/chunks/TokenTypeSelect-EY1WftKo.js +394 -0
- package/dist/admin/chunks/TokenTypeSelect-EY1WftKo.js.map +1 -0
- package/dist/admin/chunks/UseCasePage-Dl-WfgYc.js +260 -0
- package/dist/admin/chunks/UseCasePage-Dl-WfgYc.js.map +1 -0
- package/dist/admin/chunks/UseCasePage-Y_h0Fbiv.mjs +237 -0
- package/dist/admin/chunks/UseCasePage-Y_h0Fbiv.mjs.map +1 -0
- package/dist/admin/chunks/admin-BBS7sDVu.mjs +407 -0
- package/dist/admin/chunks/admin-BBS7sDVu.mjs.map +1 -0
- package/dist/admin/chunks/admin-udBiOv2o.js +422 -0
- package/dist/admin/chunks/admin-udBiOv2o.js.map +1 -0
- package/dist/admin/chunks/apiTokens-Bl4j4xFt.mjs +79 -0
- package/dist/admin/chunks/apiTokens-Bl4j4xFt.mjs.map +1 -0
- package/dist/admin/chunks/apiTokens-C7CY0RRl.js +85 -0
- package/dist/admin/chunks/apiTokens-C7CY0RRl.js.map +1 -0
- package/dist/admin/chunks/ar-CKlv64GT.js +851 -0
- package/dist/admin/{ar-BX4l-gGG.js.map → chunks/ar-CKlv64GT.js.map} +1 -1
- package/dist/admin/chunks/ar-DIoaNhYi.mjs +832 -0
- package/dist/admin/{ar-7vbwrPth.mjs.map → chunks/ar-DIoaNhYi.mjs.map} +1 -1
- package/dist/admin/chunks/ca-CiTVrP0z.mjs +520 -0
- package/dist/admin/{ca-f06Q0InB.mjs.map → chunks/ca-CiTVrP0z.mjs.map} +1 -1
- package/dist/admin/chunks/ca-Dro6RjTq.js +536 -0
- package/dist/admin/{ml-CzFKbt9H.js.map → chunks/ca-Dro6RjTq.js.map} +1 -1
- package/dist/admin/chunks/constants-B8oOcJBB.mjs +5 -0
- package/dist/admin/chunks/constants-B8oOcJBB.mjs.map +1 -0
- package/dist/admin/chunks/constants-DClZ3JYF.js +163 -0
- package/dist/admin/chunks/constants-DClZ3JYF.js.map +1 -0
- package/dist/admin/chunks/constants-DoArvzRr.mjs +161 -0
- package/dist/admin/chunks/constants-DoArvzRr.mjs.map +1 -0
- package/dist/admin/chunks/constants-tbFuOuW4.js +8 -0
- package/dist/admin/chunks/constants-tbFuOuW4.js.map +1 -0
- package/dist/admin/chunks/cs-CrhAArjW.js +177 -0
- package/dist/admin/{cs-DeS9DzIq.js.map → chunks/cs-CrhAArjW.js.map} +1 -1
- package/dist/admin/chunks/cs-D7xysdyX.mjs +166 -0
- package/dist/admin/{cs-DrRkodPD.mjs.map → chunks/cs-D7xysdyX.mjs.map} +1 -1
- package/dist/admin/chunks/de--2g6Hiwv.js +530 -0
- package/dist/admin/{de-CxVS71Os.js.map → chunks/de--2g6Hiwv.js.map} +1 -1
- package/dist/admin/chunks/de-BWQ7SIyM.mjs +514 -0
- package/dist/admin/{de-D0NA2abW.mjs.map → chunks/de-BWQ7SIyM.mjs.map} +1 -1
- package/dist/admin/chunks/dk-7AZJZW29.mjs +434 -0
- package/dist/admin/{ja-Cc9Dg_QK.mjs.map → chunks/dk-7AZJZW29.mjs.map} +1 -1
- package/dist/admin/chunks/dk-DlX9Yc-Z.js +450 -0
- package/dist/admin/{ko-CS08pZ0z.js.map → chunks/dk-DlX9Yc-Z.js.map} +1 -1
- package/dist/admin/chunks/en-CJjqxA2Q.js +804 -0
- package/dist/admin/{en-BR2e5qX-.js.map → chunks/en-CJjqxA2Q.js.map} +1 -1
- package/dist/admin/chunks/en-CRu3-kTC.mjs +784 -0
- package/dist/admin/{en-CSPHZKTw.mjs.map → chunks/en-CRu3-kTC.mjs.map} +1 -1
- package/dist/admin/chunks/en-GB-CMP_CCZs.js +8 -0
- package/dist/admin/chunks/en-GB-CMP_CCZs.js.map +1 -0
- package/dist/admin/chunks/en-GB-DZyWkup_.mjs +6 -0
- package/dist/admin/chunks/en-GB-DZyWkup_.mjs.map +1 -0
- package/dist/admin/chunks/es-DlUN520X.mjs +602 -0
- package/dist/admin/{es-XEfESBGO.mjs.map → chunks/es-DlUN520X.mjs.map} +1 -1
- package/dist/admin/chunks/es-qJwzbuzj.js +620 -0
- package/dist/admin/{es-CeFZcM6R.js.map → chunks/es-qJwzbuzj.js.map} +1 -1
- package/dist/admin/chunks/eu-BjPzWjP-.mjs +625 -0
- package/dist/admin/{hu-DaDd6FHR.mjs.map → chunks/eu-BjPzWjP-.mjs.map} +1 -1
- package/dist/admin/chunks/eu-DLuO9QFa.js +643 -0
- package/dist/admin/chunks/eu-DLuO9QFa.js.map +1 -0
- package/dist/admin/chunks/fr-D-lfObnF.mjs +581 -0
- package/dist/admin/{fr-CndUnB7j.mjs.map → chunks/fr-D-lfObnF.mjs.map} +1 -1
- package/dist/admin/chunks/fr-l9CvkceZ.js +601 -0
- package/dist/admin/{fr-BMaOPAWr.js.map → chunks/fr-l9CvkceZ.js.map} +1 -1
- package/dist/admin/chunks/gu-BfN4U3Q0.js +436 -0
- package/dist/admin/{gu-Hc5YzUuw.js.map → chunks/gu-BfN4U3Q0.js.map} +1 -1
- package/dist/admin/chunks/gu-DMqR9PzV.mjs +429 -0
- package/dist/admin/{gu-CSS25C49.mjs.map → chunks/gu-DMqR9PzV.mjs.map} +1 -1
- package/dist/admin/chunks/he-DQnlLpI2.js +327 -0
- package/dist/admin/chunks/he-DQnlLpI2.js.map +1 -0
- package/dist/admin/chunks/he-DfIYPy4g.mjs +315 -0
- package/dist/admin/{he-C3w9omDw.mjs.map → chunks/he-DfIYPy4g.mjs.map} +1 -1
- package/dist/admin/chunks/hi-C1bRwQm3.mjs +519 -0
- package/dist/admin/{hi-DW2CutdA.mjs.map → chunks/hi-C1bRwQm3.mjs.map} +1 -1
- package/dist/admin/chunks/hi-CAYgw5fw.js +535 -0
- package/dist/admin/{pl-Bf4D5Q8_.js.map → chunks/hi-CAYgw5fw.js.map} +1 -1
- package/dist/admin/chunks/hu-CmA0pIab.js +643 -0
- package/dist/admin/chunks/hu-CmA0pIab.js.map +1 -0
- package/dist/admin/chunks/hu-DTUInqNe.mjs +625 -0
- package/dist/admin/{eu-CDMMTSys.mjs.map → chunks/hu-DTUInqNe.mjs.map} +1 -1
- package/dist/admin/chunks/id-C69myNeZ.js +301 -0
- package/dist/admin/{id-BX77nhRG.js.map → chunks/id-C69myNeZ.js.map} +1 -1
- package/dist/admin/chunks/id-CLj6OS01.mjs +290 -0
- package/dist/admin/{id-cH3Ovozx.mjs.map → chunks/id-CLj6OS01.mjs.map} +1 -1
- package/dist/admin/chunks/index-BUGouNML.mjs +7091 -0
- package/dist/admin/chunks/index-BUGouNML.mjs.map +1 -0
- package/dist/admin/chunks/index-D7OmC33R.js +7155 -0
- package/dist/admin/chunks/index-D7OmC33R.js.map +1 -0
- package/dist/admin/chunks/it-Bn9y0UG-.js +310 -0
- package/dist/admin/{it-Br3eqqDa.js.map → chunks/it-Bn9y0UG-.js.map} +1 -1
- package/dist/admin/chunks/it-CI4iXN-s.mjs +299 -0
- package/dist/admin/{it-T1rZP3NX.mjs.map → chunks/it-CI4iXN-s.mjs.map} +1 -1
- package/dist/admin/chunks/ja-DDL7fKfX.js +450 -0
- package/dist/admin/{dk-Dy9JFy9v.js.map → chunks/ja-DDL7fKfX.js.map} +1 -1
- package/dist/admin/chunks/ja-XD0qdvmh.mjs +434 -0
- package/dist/admin/{dk-Cv0jDfcZ.mjs.map → chunks/ja-XD0qdvmh.mjs.map} +1 -1
- package/dist/admin/chunks/ko-CAChQtgZ.mjs +433 -0
- package/dist/admin/{ko-D1e-SMHS.mjs.map → chunks/ko-CAChQtgZ.mjs.map} +1 -1
- package/dist/admin/chunks/ko-C_d9Ja0b.js +449 -0
- package/dist/admin/{ja-CmifbkZD.js.map → chunks/ko-C_d9Ja0b.js.map} +1 -1
- package/dist/admin/chunks/ml-BN6g97vL.js +535 -0
- package/dist/admin/chunks/ml-BN6g97vL.js.map +1 -0
- package/dist/admin/chunks/ml-OZdE-Rdf.mjs +519 -0
- package/dist/admin/{pl-B0hZgHvQ.mjs.map → chunks/ml-OZdE-Rdf.mjs.map} +1 -1
- package/dist/admin/chunks/ms-CWDO45lu.mjs +200 -0
- package/dist/admin/{pt-8dwKSOn3.mjs.map → chunks/ms-CWDO45lu.mjs.map} +1 -1
- package/dist/admin/chunks/ms-DSUp9TXl.js +211 -0
- package/dist/admin/{pt-CEcd6cjN.js.map → chunks/ms-DSUp9TXl.js.map} +1 -1
- package/dist/admin/chunks/nl-BRq2PB1q.mjs +621 -0
- package/dist/admin/{nl-CubaFTJw.mjs.map → chunks/nl-BRq2PB1q.mjs.map} +1 -1
- package/dist/admin/chunks/nl-Bc4mZOba.js +639 -0
- package/dist/admin/{sv-BqRXfruc.js.map → chunks/nl-Bc4mZOba.js.map} +1 -1
- package/dist/admin/chunks/no-BtzfHZUH.mjs +300 -0
- package/dist/admin/{no-9TbSG07o.mjs.map → chunks/no-BtzfHZUH.mjs.map} +1 -1
- package/dist/admin/chunks/no-D0VN_ZtA.js +311 -0
- package/dist/admin/{no-DU4xtEmk.js.map → chunks/no-D0VN_ZtA.js.map} +1 -1
- package/dist/admin/chunks/pl-BsvtDLRo.mjs +519 -0
- package/dist/admin/{ml-FLft_QIc.mjs.map → chunks/pl-BsvtDLRo.mjs.map} +1 -1
- package/dist/admin/chunks/pl-D7HFG_xo.js +535 -0
- package/dist/admin/chunks/pl-D7HFG_xo.js.map +1 -0
- package/dist/admin/chunks/pt-BR-B3KKuF2p.js +606 -0
- package/dist/admin/{pt-BR-BFq-a8-C.js.map → chunks/pt-BR-B3KKuF2p.js.map} +1 -1
- package/dist/admin/chunks/pt-BR-DBqHmqA5.mjs +588 -0
- package/dist/admin/{pt-BR-BDpWvCrQ.mjs.map → chunks/pt-BR-DBqHmqA5.mjs.map} +1 -1
- package/dist/admin/chunks/pt-DCyoSDGa.js +210 -0
- package/dist/admin/{ms-C-JB0-h1.js.map → chunks/pt-DCyoSDGa.js.map} +1 -1
- package/dist/admin/chunks/pt-wKaSOdHh.mjs +200 -0
- package/dist/admin/{ms-eMDSLvhl.mjs.map → chunks/pt-wKaSOdHh.mjs.map} +1 -1
- package/dist/admin/chunks/ru-C13N1yaO.mjs +745 -0
- package/dist/admin/{ru-C34i9wJx.mjs.map → chunks/ru-C13N1yaO.mjs.map} +1 -1
- package/dist/admin/chunks/ru-Dj1oAKC7.js +764 -0
- package/dist/admin/{ru-Dwf09uUc.js.map → chunks/ru-Dj1oAKC7.js.map} +1 -1
- package/dist/admin/chunks/sa-BS5xpa-V.mjs +519 -0
- package/dist/admin/chunks/sa-BS5xpa-V.mjs.map +1 -0
- package/dist/admin/chunks/sa-ftcoOyFZ.js +535 -0
- package/dist/admin/chunks/sa-ftcoOyFZ.js.map +1 -0
- package/dist/admin/chunks/selectors-2ohXQx5g.js +13 -0
- package/dist/admin/chunks/selectors-2ohXQx5g.js.map +1 -0
- package/dist/admin/chunks/selectors-PQdhPmzv.mjs +11 -0
- package/dist/admin/chunks/selectors-PQdhPmzv.mjs.map +1 -0
- package/dist/admin/chunks/sk-BkoiGl_d.js +501 -0
- package/dist/admin/{sk-CbJVofN-.js.map → chunks/sk-BkoiGl_d.js.map} +1 -1
- package/dist/admin/chunks/sk-Yv9s7dUn.mjs +483 -0
- package/dist/admin/{sk-DQ2qpsG2.mjs.map → chunks/sk-Yv9s7dUn.mjs.map} +1 -1
- package/dist/admin/chunks/sv-CYpSsbq3.js +638 -0
- package/dist/admin/{nl-gUEC_dKT.js.map → chunks/sv-CYpSsbq3.js.map} +1 -1
- package/dist/admin/chunks/sv-CaQpgtnl.mjs +620 -0
- package/dist/admin/{sv-D0vPVUAT.mjs.map → chunks/sv-CaQpgtnl.mjs.map} +1 -1
- package/dist/admin/chunks/th-D1Raa9T5.js +295 -0
- package/dist/admin/{th-CPx6wf0M.js.map → chunks/th-D1Raa9T5.js.map} +1 -1
- package/dist/admin/chunks/th-Mav5tUMF.mjs +284 -0
- package/dist/admin/{th-BG3IOCqV.mjs.map → chunks/th-Mav5tUMF.mjs.map} +1 -1
- package/dist/admin/chunks/tr-DZnC0Jye.mjs +581 -0
- package/dist/admin/{tr-Dq45DRRZ.mjs.map → chunks/tr-DZnC0Jye.mjs.map} +1 -1
- package/dist/admin/chunks/tr-KY2E7HZC.js +599 -0
- package/dist/admin/{tr-hC_m0V8Q.js.map → chunks/tr-KY2E7HZC.js.map} +1 -1
- package/dist/admin/chunks/transferTokens-9pdM-Bum.mjs +90 -0
- package/dist/admin/chunks/transferTokens-9pdM-Bum.mjs.map +1 -0
- package/dist/admin/chunks/transferTokens-oEFM8kkT.js +97 -0
- package/dist/admin/chunks/transferTokens-oEFM8kkT.js.map +1 -0
- package/dist/admin/chunks/uk-Cb6a0PAZ.mjs +201 -0
- package/dist/admin/{uk-Ud9QNfkB.mjs.map → chunks/uk-Cb6a0PAZ.mjs.map} +1 -1
- package/dist/admin/chunks/uk-gz16FlMw.js +212 -0
- package/dist/admin/chunks/uk-gz16FlMw.js.map +1 -0
- package/dist/admin/chunks/useAdminRoles-BEmkB0uj.mjs +32 -0
- package/dist/admin/chunks/useAdminRoles-BEmkB0uj.mjs.map +1 -0
- package/dist/admin/chunks/useAdminRoles-DwDqOIvp.js +53 -0
- package/dist/admin/chunks/useAdminRoles-DwDqOIvp.js.map +1 -0
- package/dist/admin/chunks/useEnterprise-Dy8wMNV5.mjs +38 -0
- package/dist/admin/chunks/useEnterprise-Dy8wMNV5.mjs.map +1 -0
- package/dist/admin/chunks/useEnterprise-IHd3AKd2.js +59 -0
- package/dist/admin/chunks/useEnterprise-IHd3AKd2.js.map +1 -0
- package/dist/admin/chunks/useLicenseLimitNotification-BMCQ8obE.js +96 -0
- package/dist/admin/chunks/useLicenseLimitNotification-BMCQ8obE.js.map +1 -0
- package/dist/admin/chunks/useLicenseLimitNotification-CGkazzao.mjs +75 -0
- package/dist/admin/chunks/useLicenseLimitNotification-CGkazzao.mjs.map +1 -0
- package/dist/admin/chunks/useLicenseLimits-D4XBewxi.mjs +29 -0
- package/dist/admin/chunks/useLicenseLimits-D4XBewxi.mjs.map +1 -0
- package/dist/admin/chunks/useLicenseLimits-JOHH8jfL.js +50 -0
- package/dist/admin/chunks/useLicenseLimits-JOHH8jfL.js.map +1 -0
- package/dist/admin/chunks/useOnce-CCEXokcy.js +28 -0
- package/dist/admin/chunks/useOnce-CCEXokcy.js.map +1 -0
- package/dist/admin/chunks/useOnce-EHSWW7FY.mjs +7 -0
- package/dist/admin/chunks/useOnce-EHSWW7FY.mjs.map +1 -0
- package/dist/admin/chunks/useWebhooks-CROc5Uno.js +117 -0
- package/dist/admin/chunks/useWebhooks-CROc5Uno.js.map +1 -0
- package/dist/admin/chunks/useWebhooks-DzJ3X-hd.mjs +115 -0
- package/dist/admin/chunks/useWebhooks-DzJ3X-hd.mjs.map +1 -0
- package/dist/admin/chunks/users-B3iOAYG-.mjs +39 -0
- package/dist/admin/chunks/users-B3iOAYG-.mjs.map +1 -0
- package/dist/admin/chunks/users-D-oKxjK9.js +42 -0
- package/dist/admin/chunks/users-D-oKxjK9.js.map +1 -0
- package/dist/admin/chunks/validation-DOQs6_Ay.mjs +52 -0
- package/dist/admin/chunks/validation-DOQs6_Ay.mjs.map +1 -0
- package/dist/admin/chunks/validation-ECrFbJ6K.js +73 -0
- package/dist/admin/chunks/validation-ECrFbJ6K.js.map +1 -0
- package/dist/admin/chunks/vi-BsRo_l_e.js +198 -0
- package/dist/admin/{vi-UeRpPdvI.js.map → chunks/vi-BsRo_l_e.js.map} +1 -1
- package/dist/admin/chunks/vi-r6WrFGyI.mjs +187 -0
- package/dist/admin/{vi-CGrr4ioy.mjs.map → chunks/vi-r6WrFGyI.mjs.map} +1 -1
- package/dist/admin/chunks/zh-B_FImn9T.js +640 -0
- package/dist/admin/{zh-Bhpup4vu.js.map → chunks/zh-B_FImn9T.js.map} +1 -1
- package/dist/admin/chunks/zh-CIjQrG_x.mjs +622 -0
- package/dist/admin/{zh-LqPg8hbL.mjs.map → chunks/zh-CIjQrG_x.mjs.map} +1 -1
- package/dist/admin/chunks/zh-Hans-BmHHqjob.mjs +716 -0
- package/dist/admin/{zh-Hans-C44LvcXE.mjs.map → chunks/zh-Hans-BmHHqjob.mjs.map} +1 -1
- package/dist/admin/chunks/zh-Hans-Bv055w0d.js +735 -0
- package/dist/admin/{zh-Hans-BlfT-iYf.js.map → chunks/zh-Hans-Bv055w0d.js.map} +1 -1
- package/dist/admin/ee.js +9 -4
- package/dist/admin/ee.js.map +1 -1
- package/dist/admin/ee.mjs +9 -2
- package/dist/admin/ee.mjs.map +1 -1
- package/dist/admin/index.js +41 -5
- package/dist/admin/index.js.map +1 -1
- package/dist/admin/index.mjs +40 -3
- package/dist/admin/index.mjs.map +1 -1
- package/dist/admin/src/App.d.ts +2 -2
- package/dist/admin/src/StrapiApp.d.ts +2 -2
- package/dist/admin/src/components/ConfirmDialog.d.ts +1 -1
- package/dist/admin/src/components/DragLayer.d.ts +1 -1
- package/dist/admin/src/components/Filters.d.ts +2 -2
- package/dist/admin/src/components/Form.d.ts +6 -5
- package/dist/admin/src/components/FormInputs/Boolean.d.ts +2 -1
- package/dist/admin/src/components/FormInputs/Checkbox.d.ts +2 -1
- package/dist/admin/src/components/FormInputs/Date.d.ts +1 -1
- package/dist/admin/src/components/FormInputs/DateTime.d.ts +2 -1
- package/dist/admin/src/components/FormInputs/Email.d.ts +3 -2
- package/dist/admin/src/components/FormInputs/Enumeration.d.ts +2 -1
- package/dist/admin/src/components/FormInputs/Json.d.ts +1 -1
- package/dist/admin/src/components/FormInputs/Number.d.ts +2 -1
- package/dist/admin/src/components/FormInputs/Password.d.ts +3 -2
- package/dist/admin/src/components/FormInputs/Renderer.d.ts +3 -2
- package/dist/admin/src/components/FormInputs/String.d.ts +3 -2
- package/dist/admin/src/components/FormInputs/Textarea.d.ts +3 -2
- package/dist/admin/src/components/FormInputs/Time.d.ts +2 -1
- package/dist/admin/src/components/FormInputs/types.d.ts +2 -2
- package/dist/admin/src/components/Layouts/HeaderLayout.d.ts +1 -1
- package/dist/admin/src/components/Layouts/Layout.d.ts +5 -5
- package/dist/admin/src/components/MainNav/NavLink.d.ts +1 -1
- package/dist/admin/src/components/MainNav/NavUser.d.ts +1 -1
- package/dist/admin/src/components/PageHelpers.d.ts +2 -2
- package/dist/admin/src/components/Pagination.d.ts +1 -1
- package/dist/admin/src/components/Providers.d.ts +2 -2
- package/dist/admin/src/components/RelativeTime.d.ts +1 -1
- package/dist/admin/src/components/Table.d.ts +1 -1
- package/dist/admin/src/components/Theme.d.ts +1 -1
- package/dist/admin/src/constants/filters.d.ts +2 -2
- package/dist/admin/src/constants.d.ts +1 -1
- package/dist/admin/src/core/apis/CustomFields.d.ts +2 -2
- package/dist/admin/src/core/apis/Plugin.d.ts +2 -0
- package/dist/admin/src/core/apis/rbac.d.ts +1 -1
- package/dist/admin/src/core/apis/router.d.ts +2 -2
- package/dist/admin/src/core/store/configure.d.ts +5 -5
- package/dist/admin/src/core/store/hooks.d.ts +7 -10
- package/dist/admin/src/core/utils/createHook.d.ts +1 -1
- package/dist/admin/src/features/AppInfo.d.ts +1 -1
- package/dist/admin/src/features/Auth.d.ts +2 -2
- package/dist/admin/src/features/BackButton.d.ts +2 -2
- package/dist/admin/src/features/Configuration.d.ts +2 -2
- package/dist/admin/src/features/StrapiApp.d.ts +3 -2
- package/dist/admin/src/features/Tracking.d.ts +1 -1
- package/dist/admin/src/hooks/useAPIErrorHandler.d.ts +1 -3
- package/dist/admin/src/hooks/useAdminRoles.d.ts +3 -3
- package/dist/admin/src/hooks/useContentTypes.d.ts +1 -1
- package/dist/admin/src/hooks/useElementOnScreen.d.ts +7 -0
- package/dist/admin/src/hooks/useFetchClient.d.ts +1 -1
- package/dist/admin/src/hooks/usePersistentState.d.ts +1 -1
- package/dist/admin/src/hooks/useQueryParams.d.ts +1 -1
- package/dist/admin/src/hooks/useSettingsMenu.d.ts +1 -1
- package/dist/admin/src/hooks/useThrottledCallback.d.ts +2 -1
- package/dist/admin/src/index.d.ts +3 -2
- package/dist/admin/src/layouts/UnauthenticatedLayout.d.ts +2 -2
- package/dist/admin/src/pages/Auth/components/ForgotPassword.d.ts +1 -1
- package/dist/admin/src/pages/Auth/components/Login.d.ts +1 -1
- package/dist/admin/src/pages/Auth/constants.d.ts +1 -1
- package/dist/admin/src/pages/Home/components/Widget.d.ts +1 -1
- package/dist/admin/src/pages/Marketplace/components/NpmPackageCard.d.ts +2 -2
- package/dist/admin/src/pages/Marketplace/components/NpmPackagesFilters.d.ts +2 -2
- package/dist/admin/src/pages/Marketplace/components/NpmPackagesGrid.d.ts +1 -1
- package/dist/admin/src/pages/Marketplace/components/PageHeader.d.ts +1 -1
- package/dist/admin/src/pages/Marketplace/hooks/useMarketplaceData.d.ts +3 -3
- package/dist/admin/src/pages/Settings/components/Tokens/FormHead.d.ts +1 -1
- package/dist/admin/src/pages/Settings/components/Tokens/LifeSpanInput.d.ts +2 -2
- package/dist/admin/src/pages/Settings/components/Tokens/Table.d.ts +1 -1
- package/dist/admin/src/pages/Settings/constants.d.ts +1 -1
- package/dist/admin/src/pages/Settings/pages/ApiTokens/EditView/apiTokenPermissions.d.ts +1 -1
- package/dist/admin/src/pages/Settings/pages/ApiTokens/EditView/components/FormApiTokenContainer.d.ts +2 -2
- package/dist/admin/src/pages/Settings/pages/ApiTokens/EditView/constants.d.ts +12 -12
- package/dist/admin/src/pages/Settings/pages/ApplicationInfo/utils/files.d.ts +1 -1
- package/dist/admin/src/pages/Settings/pages/Roles/components/CollapseLabel.d.ts +4 -3
- package/dist/admin/src/pages/Settings/pages/Roles/components/ConditionsButton.d.ts +2 -2
- package/dist/admin/src/pages/Settings/pages/Roles/components/ConditionsModal.d.ts +2 -2
- package/dist/admin/src/pages/Settings/pages/Roles/components/HiddenAction.d.ts +1 -1
- package/dist/admin/src/pages/Settings/pages/Roles/components/Permissions.d.ts +2 -2
- package/dist/admin/src/pages/Settings/pages/Roles/components/PluginsAndSettings.d.ts +1 -1
- package/dist/admin/src/pages/Settings/pages/Roles/components/RoleForm.d.ts +2 -2
- package/dist/admin/src/pages/Settings/pages/Roles/components/RoleRow.d.ts +1 -1
- package/dist/admin/src/pages/Settings/pages/Roles/components/RowLabelWithCheckbox.d.ts +1 -1
- package/dist/admin/src/pages/Settings/pages/Roles/hooks/usePermissionsDataManager.d.ts +3 -2
- package/dist/admin/src/pages/Settings/pages/Roles/utils/createArrayOfValues.d.ts +1 -1
- package/dist/admin/src/pages/Settings/pages/Roles/utils/forms.d.ts +3 -3
- package/dist/admin/src/pages/Settings/pages/Roles/utils/permissions.d.ts +2 -2
- package/dist/admin/src/pages/Settings/pages/Roles/utils/removeConditionKeyFromData.d.ts +1 -1
- package/dist/admin/src/pages/Settings/pages/Users/components/CreateActionCE.d.ts +1 -1
- package/dist/admin/src/pages/Settings/pages/Users/components/NewUserForm.d.ts +1 -1
- package/dist/admin/src/pages/Settings/pages/Users/utils/validation.d.ts +3 -3
- package/dist/admin/src/pages/Settings/pages/Webhooks/components/Events.d.ts +1 -1
- package/dist/admin/src/pages/Settings/pages/Webhooks/components/WebhookForm.d.ts +1 -1
- package/dist/admin/src/pages/Settings/pages/Webhooks/hooks/useWebhooks.d.ts +6 -6
- package/dist/admin/src/reducer.d.ts +2 -2
- package/dist/admin/src/render.d.ts +1 -1
- package/dist/admin/src/selectors.d.ts +6 -6
- package/dist/admin/src/services/admin.d.ts +6 -6
- package/dist/admin/src/services/api.d.ts +1 -1
- package/dist/admin/src/services/apiTokens.d.ts +1 -1
- package/dist/admin/src/services/auth.d.ts +22 -22
- package/dist/admin/src/services/contentApi.d.ts +1 -1
- package/dist/admin/src/services/contentManager.d.ts +6 -2
- package/dist/admin/src/services/homepage.d.ts +2 -2
- package/dist/admin/src/services/transferTokens.d.ts +1 -1
- package/dist/admin/src/services/users.d.ts +12 -12
- package/dist/admin/src/services/webhooks.d.ts +3 -3
- package/dist/admin/src/types/adminConfiguration.d.ts +1 -1
- package/dist/admin/src/types/forms.d.ts +3 -3
- package/dist/admin/src/types/permissions.d.ts +1 -1
- package/dist/admin/src/utils/arrays.d.ts +1 -1
- package/dist/admin/src/utils/baseQuery.d.ts +1 -2
- package/dist/admin/src/utils/getFetchClient.d.ts +2 -1
- package/dist/admin/src/utils/normalizeAPIError.d.ts +1 -1
- package/dist/admin/src/utils/users.d.ts +1 -1
- package/dist/admin/test.js +2288 -35360
- package/dist/admin/test.js.map +1 -1
- package/dist/admin/test.mjs +2254 -35313
- package/dist/admin/test.mjs.map +1 -1
- package/dist/admin/tests/server.d.ts +1 -1
- package/dist/admin/tests/utils.d.ts +6 -6
- package/dist/ee/admin/src/constants.d.ts +2 -2
- package/dist/ee/admin/src/hooks/useLicenseLimits.d.ts +2 -2
- package/dist/ee/admin/src/pages/SettingsPage/pages/AuditLogs/hooks/useAuditLogsData.d.ts +1 -1
- package/dist/ee/admin/src/pages/SettingsPage/pages/Users/components/CreateActionEE.d.ts +1 -1
- package/dist/ee/admin/src/pages/SettingsPage/pages/Users/components/MagicLinkEE.d.ts +1 -1
- package/dist/ee/admin/src/services/auditLogs.d.ts +1 -1
- package/dist/ee/server/src/index.d.ts +1 -1
- package/dist/ee/server/src/index.d.ts.map +1 -1
- package/dist/server/index.js +8567 -6648
- package/dist/server/index.js.map +1 -1
- package/dist/server/index.mjs +8747 -6815
- package/dist/server/index.mjs.map +1 -1
- package/dist/server/src/bootstrap.d.ts.map +1 -1
- package/dist/server/src/services/api-token.d.ts +2 -1
- package/dist/server/src/services/api-token.d.ts.map +1 -1
- package/dist/shared/contracts/admin.d.ts +1 -1
- package/dist/shared/contracts/api-token.d.ts +1 -1
- package/dist/shared/contracts/authentication.d.ts +2 -2
- package/dist/shared/contracts/content-api.d.ts +2 -2
- package/dist/shared/contracts/content-types.d.ts +1 -1
- package/dist/shared/contracts/homepage.d.ts +2 -2
- package/dist/shared/contracts/permissions.d.ts +1 -1
- package/dist/shared/contracts/roles.d.ts +2 -2
- package/dist/shared/contracts/shared.d.ts +1 -1
- package/dist/shared/contracts/user.d.ts +2 -2
- package/dist/shared/contracts/users.d.ts +2 -2
- package/dist/shared/contracts/webhooks.d.ts +1 -1
- package/package.json +18 -15
- package/dist/admin/AdminSeatInfo-Bpyschk4.mjs +0 -92
- package/dist/admin/AdminSeatInfo-Bpyschk4.mjs.map +0 -1
- package/dist/admin/AdminSeatInfo-DJY5XfV1.js +0 -96
- package/dist/admin/AdminSeatInfo-DJY5XfV1.js.map +0 -1
- package/dist/admin/ApplicationInfoPage-BNFbKMod.mjs +0 -646
- package/dist/admin/ApplicationInfoPage-BNFbKMod.mjs.map +0 -1
- package/dist/admin/ApplicationInfoPage-CxsCNlz3.js +0 -673
- package/dist/admin/ApplicationInfoPage-CxsCNlz3.js.map +0 -1
- package/dist/admin/AuthResponse-4S-gAOdq.js +0 -85
- package/dist/admin/AuthResponse-4S-gAOdq.js.map +0 -1
- package/dist/admin/AuthResponse-BI0D7fJC.mjs +0 -61
- package/dist/admin/AuthResponse-BI0D7fJC.mjs.map +0 -1
- package/dist/admin/AuthenticatedLayout-BQ6zs92s.mjs +0 -1166
- package/dist/admin/AuthenticatedLayout-BQ6zs92s.mjs.map +0 -1
- package/dist/admin/AuthenticatedLayout-Bibgqyfz.js +0 -1198
- package/dist/admin/AuthenticatedLayout-Bibgqyfz.js.map +0 -1
- package/dist/admin/CreateActionEE-CRTFGenF.js +0 -76
- package/dist/admin/CreateActionEE-CRTFGenF.js.map +0 -1
- package/dist/admin/CreateActionEE-JUvyeAny.mjs +0 -49
- package/dist/admin/CreateActionEE-JUvyeAny.mjs.map +0 -1
- package/dist/admin/CreatePage-BmRTDEX3.js +0 -268
- package/dist/admin/CreatePage-BmRTDEX3.js.map +0 -1
- package/dist/admin/CreatePage-C-0H2K5g.mjs +0 -13
- package/dist/admin/CreatePage-C-0H2K5g.mjs.map +0 -1
- package/dist/admin/CreatePage-CfCPPYGr.mjs +0 -242
- package/dist/admin/CreatePage-CfCPPYGr.mjs.map +0 -1
- package/dist/admin/CreatePage-DpKhGTvR.js +0 -18
- package/dist/admin/CreatePage-DpKhGTvR.js.map +0 -1
- package/dist/admin/CreateView-BdFf17_R.js +0 -17
- package/dist/admin/CreateView-BdFf17_R.js.map +0 -1
- package/dist/admin/CreateView-Bi-6vB0h.mjs +0 -13
- package/dist/admin/CreateView-Bi-6vB0h.mjs.map +0 -1
- package/dist/admin/CreateView-Dz-lQ9gG.js +0 -17
- package/dist/admin/CreateView-Dz-lQ9gG.js.map +0 -1
- package/dist/admin/CreateView-w-hcufyx.mjs +0 -13
- package/dist/admin/CreateView-w-hcufyx.mjs.map +0 -1
- package/dist/admin/EditPage-9xmFGD2A.js +0 -779
- package/dist/admin/EditPage-9xmFGD2A.js.map +0 -1
- package/dist/admin/EditPage-BBYkM2hO.js +0 -298
- package/dist/admin/EditPage-BBYkM2hO.js.map +0 -1
- package/dist/admin/EditPage-BRQERWrj.js +0 -359
- package/dist/admin/EditPage-BRQERWrj.js.map +0 -1
- package/dist/admin/EditPage-CtSQnW_9.mjs +0 -330
- package/dist/admin/EditPage-CtSQnW_9.mjs.map +0 -1
- package/dist/admin/EditPage-DxEBBqUH.mjs +0 -272
- package/dist/admin/EditPage-DxEBBqUH.mjs.map +0 -1
- package/dist/admin/EditPage-oamip13J.mjs +0 -754
- package/dist/admin/EditPage-oamip13J.mjs.map +0 -1
- package/dist/admin/EditView-BFkOmHoK.js +0 -357
- package/dist/admin/EditView-BFkOmHoK.js.map +0 -1
- package/dist/admin/EditView-Bgq7xkna.mjs +0 -331
- package/dist/admin/EditView-Bgq7xkna.mjs.map +0 -1
- package/dist/admin/EditViewPage-Ct7_0esK.js +0 -873
- package/dist/admin/EditViewPage-Ct7_0esK.js.map +0 -1
- package/dist/admin/EditViewPage-DwfsUz5e.mjs +0 -841
- package/dist/admin/EditViewPage-DwfsUz5e.mjs.map +0 -1
- package/dist/admin/EventsTable-CFc2X7Gu.mjs +0 -32
- package/dist/admin/EventsTable-CFc2X7Gu.mjs.map +0 -1
- package/dist/admin/EventsTable-Oc3pUQpI.js +0 -36
- package/dist/admin/EventsTable-Oc3pUQpI.js.map +0 -1
- package/dist/admin/HomePage-BWGS-AVh.mjs +0 -351
- package/dist/admin/HomePage-BWGS-AVh.mjs.map +0 -1
- package/dist/admin/HomePage-ClG3SLWJ.mjs +0 -11
- package/dist/admin/HomePage-ClG3SLWJ.mjs.map +0 -1
- package/dist/admin/HomePage-CzT2bcqG.js +0 -15
- package/dist/admin/HomePage-CzT2bcqG.js.map +0 -1
- package/dist/admin/HomePage-DDJaUkQv.js +0 -376
- package/dist/admin/HomePage-DDJaUkQv.js.map +0 -1
- package/dist/admin/InstalledPlugins-1a_nfRNU.mjs +0 -95
- package/dist/admin/InstalledPlugins-1a_nfRNU.mjs.map +0 -1
- package/dist/admin/InstalledPlugins-CEeH8nCT.js +0 -120
- package/dist/admin/InstalledPlugins-CEeH8nCT.js.map +0 -1
- package/dist/admin/Layout-BkiVSoVM.mjs +0 -215
- package/dist/admin/Layout-BkiVSoVM.mjs.map +0 -1
- package/dist/admin/Layout-Cz4fM6uC.js +0 -242
- package/dist/admin/Layout-Cz4fM6uC.js.map +0 -1
- package/dist/admin/ListPage-B4XxPT7g.mjs +0 -355
- package/dist/admin/ListPage-B4XxPT7g.mjs.map +0 -1
- package/dist/admin/ListPage-B5HILqUc.js +0 -380
- package/dist/admin/ListPage-B5HILqUc.js.map +0 -1
- package/dist/admin/ListPage-BG9wGseD.mjs +0 -11
- package/dist/admin/ListPage-BG9wGseD.mjs.map +0 -1
- package/dist/admin/ListPage-BuiNhhwD.js +0 -581
- package/dist/admin/ListPage-BuiNhhwD.js.map +0 -1
- package/dist/admin/ListPage-CLwCdNQh.mjs +0 -271
- package/dist/admin/ListPage-CLwCdNQh.mjs.map +0 -1
- package/dist/admin/ListPage-CWZ3JRp0.js +0 -15
- package/dist/admin/ListPage-CWZ3JRp0.js.map +0 -1
- package/dist/admin/ListPage-DpdV081q.js +0 -296
- package/dist/admin/ListPage-DpdV081q.js.map +0 -1
- package/dist/admin/ListPage-DwouFFiM.js +0 -505
- package/dist/admin/ListPage-DwouFFiM.js.map +0 -1
- package/dist/admin/ListPage-jlU2BRvA.mjs +0 -553
- package/dist/admin/ListPage-jlU2BRvA.mjs.map +0 -1
- package/dist/admin/ListPage-mHBjjWxk.mjs +0 -477
- package/dist/admin/ListPage-mHBjjWxk.mjs.map +0 -1
- package/dist/admin/ListView-B1Q51h0h.js +0 -237
- package/dist/admin/ListView-B1Q51h0h.js.map +0 -1
- package/dist/admin/ListView-BDpX6eAQ.mjs +0 -211
- package/dist/admin/ListView-BDpX6eAQ.mjs.map +0 -1
- package/dist/admin/ListView-BeQRnj-r.mjs +0 -200
- package/dist/admin/ListView-BeQRnj-r.mjs.map +0 -1
- package/dist/admin/ListView-OzgfbUQV.js +0 -226
- package/dist/admin/ListView-OzgfbUQV.js.map +0 -1
- package/dist/admin/Login-BCv1wfvK.mjs +0 -31
- package/dist/admin/Login-BCv1wfvK.mjs.map +0 -1
- package/dist/admin/Login-DhUOi3iK.js +0 -35
- package/dist/admin/Login-DhUOi3iK.js.map +0 -1
- package/dist/admin/MagicLinkEE-CDJs-_17.mjs +0 -27
- package/dist/admin/MagicLinkEE-CDJs-_17.mjs.map +0 -1
- package/dist/admin/MagicLinkEE-hIIxgUj5.js +0 -31
- package/dist/admin/MagicLinkEE-hIIxgUj5.js.map +0 -1
- package/dist/admin/MarketplacePage-Bu43TEkO.mjs +0 -978
- package/dist/admin/MarketplacePage-Bu43TEkO.mjs.map +0 -1
- package/dist/admin/MarketplacePage-DCOmTT67.js +0 -1008
- package/dist/admin/MarketplacePage-DCOmTT67.js.map +0 -1
- package/dist/admin/ModalForm-B9SUkQ1l.mjs +0 -23
- package/dist/admin/ModalForm-B9SUkQ1l.mjs.map +0 -1
- package/dist/admin/ModalForm-DukjfMMw.js +0 -28
- package/dist/admin/ModalForm-DukjfMMw.js.map +0 -1
- package/dist/admin/Ornaments-BFThxr2U.mjs +0 -209
- package/dist/admin/Ornaments-BFThxr2U.mjs.map +0 -1
- package/dist/admin/Ornaments-CID1aaLv.js +0 -214
- package/dist/admin/Ornaments-CID1aaLv.js.map +0 -1
- package/dist/admin/Permissions-Cmimrby0.js +0 -2063
- package/dist/admin/Permissions-Cmimrby0.js.map +0 -1
- package/dist/admin/Permissions-gB8QZDch.mjs +0 -2027
- package/dist/admin/Permissions-gB8QZDch.mjs.map +0 -1
- package/dist/admin/PrivateRoute-DIxYvSni.mjs +0 -20
- package/dist/admin/PrivateRoute-DIxYvSni.mjs.map +0 -1
- package/dist/admin/PrivateRoute-qahg_uiu.js +0 -22
- package/dist/admin/PrivateRoute-qahg_uiu.js.map +0 -1
- package/dist/admin/ProfilePage-XSJU4odV.js +0 -415
- package/dist/admin/ProfilePage-XSJU4odV.js.map +0 -1
- package/dist/admin/ProfilePage-YEeSFVCM.mjs +0 -387
- package/dist/admin/ProfilePage-YEeSFVCM.mjs.map +0 -1
- package/dist/admin/PurchaseAuditLogs-C9ATpq0U.mjs +0 -49
- package/dist/admin/PurchaseAuditLogs-C9ATpq0U.mjs.map +0 -1
- package/dist/admin/PurchaseAuditLogs-DwJextQY.js +0 -53
- package/dist/admin/PurchaseAuditLogs-DwJextQY.js.map +0 -1
- package/dist/admin/PurchaseContentHistory-Bo4cNL6e.js +0 -56
- package/dist/admin/PurchaseContentHistory-Bo4cNL6e.js.map +0 -1
- package/dist/admin/PurchaseContentHistory-CSlvXfkJ.mjs +0 -52
- package/dist/admin/PurchaseContentHistory-CSlvXfkJ.mjs.map +0 -1
- package/dist/admin/PurchaseSingleSignOn-CGpWKCKR.js +0 -56
- package/dist/admin/PurchaseSingleSignOn-CGpWKCKR.js.map +0 -1
- package/dist/admin/PurchaseSingleSignOn-ouZ_j9iQ.mjs +0 -52
- package/dist/admin/PurchaseSingleSignOn-ouZ_j9iQ.mjs.map +0 -1
- package/dist/admin/RelativeTime-BGJ1PWx_.mjs +0 -38
- package/dist/admin/RelativeTime-BGJ1PWx_.mjs.map +0 -1
- package/dist/admin/RelativeTime-DPLD3wf-.js +0 -60
- package/dist/admin/RelativeTime-DPLD3wf-.js.map +0 -1
- package/dist/admin/SSOProviders-BD7LHrkI.mjs +0 -58
- package/dist/admin/SSOProviders-BD7LHrkI.mjs.map +0 -1
- package/dist/admin/SSOProviders-nCeEldEQ.js +0 -60
- package/dist/admin/SSOProviders-nCeEldEQ.js.map +0 -1
- package/dist/admin/SelectRoles-CZmFcyVa.js +0 -115
- package/dist/admin/SelectRoles-CZmFcyVa.js.map +0 -1
- package/dist/admin/SelectRoles-CzMLJs9Y.mjs +0 -111
- package/dist/admin/SelectRoles-CzMLJs9Y.mjs.map +0 -1
- package/dist/admin/SingleSignOnPage-B3uoGuv6.js +0 -264
- package/dist/admin/SingleSignOnPage-B3uoGuv6.js.map +0 -1
- package/dist/admin/SingleSignOnPage-B9mLzjRi.mjs +0 -239
- package/dist/admin/SingleSignOnPage-B9mLzjRi.mjs.map +0 -1
- package/dist/admin/Table-BaOtQA2D.mjs +0 -145
- package/dist/admin/Table-BaOtQA2D.mjs.map +0 -1
- package/dist/admin/Table-DSGT_hBu.js +0 -147
- package/dist/admin/Table-DSGT_hBu.js.map +0 -1
- package/dist/admin/Theme-CTMU9Z8I.mjs +0 -1434
- package/dist/admin/Theme-CTMU9Z8I.mjs.map +0 -1
- package/dist/admin/Theme-DWGZX5tv.js +0 -1513
- package/dist/admin/Theme-DWGZX5tv.js.map +0 -1
- package/dist/admin/TokenTypeSelect-C3tCUMnJ.js +0 -402
- package/dist/admin/TokenTypeSelect-C3tCUMnJ.js.map +0 -1
- package/dist/admin/TokenTypeSelect-Yo2iuaB4.mjs +0 -374
- package/dist/admin/TokenTypeSelect-Yo2iuaB4.mjs.map +0 -1
- package/dist/admin/UseCasePage-CLhPiLE6.js +0 -161
- package/dist/admin/UseCasePage-CLhPiLE6.js.map +0 -1
- package/dist/admin/UseCasePage-eBhY0DSo.mjs +0 -135
- package/dist/admin/UseCasePage-eBhY0DSo.mjs.map +0 -1
- package/dist/admin/admin-DOzK8yjX.mjs +0 -322
- package/dist/admin/admin-DOzK8yjX.mjs.map +0 -1
- package/dist/admin/admin-DRnq5SAg.js +0 -343
- package/dist/admin/admin-DRnq5SAg.js.map +0 -1
- package/dist/admin/apiTokens-ByCd8ZnO.mjs +0 -57
- package/dist/admin/apiTokens-ByCd8ZnO.mjs.map +0 -1
- package/dist/admin/apiTokens-rbJHW5Y2.js +0 -63
- package/dist/admin/apiTokens-rbJHW5Y2.js.map +0 -1
- package/dist/admin/ar-7vbwrPth.mjs +0 -832
- package/dist/admin/ar-BX4l-gGG.js +0 -853
- package/dist/admin/ca-f06Q0InB.mjs +0 -520
- package/dist/admin/ca-lypqY0nt.js +0 -538
- package/dist/admin/ca-lypqY0nt.js.map +0 -1
- package/dist/admin/constants-CRj0ViV1.mjs +0 -5
- package/dist/admin/constants-CRj0ViV1.mjs.map +0 -1
- package/dist/admin/constants-D--w8C9k.js +0 -55
- package/dist/admin/constants-D--w8C9k.js.map +0 -1
- package/dist/admin/constants-DF68OPrs.js +0 -8
- package/dist/admin/constants-DF68OPrs.js.map +0 -1
- package/dist/admin/constants-DU7oNawe.mjs +0 -51
- package/dist/admin/constants-DU7oNawe.mjs.map +0 -1
- package/dist/admin/cs-DeS9DzIq.js +0 -179
- package/dist/admin/cs-DrRkodPD.mjs +0 -166
- package/dist/admin/de-CxVS71Os.js +0 -532
- package/dist/admin/de-D0NA2abW.mjs +0 -514
- package/dist/admin/dk-Cv0jDfcZ.mjs +0 -434
- package/dist/admin/dk-Dy9JFy9v.js +0 -452
- package/dist/admin/en-BR2e5qX-.js +0 -803
- package/dist/admin/en-CSPHZKTw.mjs +0 -781
- package/dist/admin/en-GB-Bke-WrFJ.js +0 -10
- package/dist/admin/en-GB-Bke-WrFJ.js.map +0 -1
- package/dist/admin/en-GB-Gv8lAy1p.mjs +0 -6
- package/dist/admin/en-GB-Gv8lAy1p.mjs.map +0 -1
- package/dist/admin/es-CeFZcM6R.js +0 -622
- package/dist/admin/es-XEfESBGO.mjs +0 -602
- package/dist/admin/eu-CDMMTSys.mjs +0 -625
- package/dist/admin/eu-CTGdmY94.js +0 -645
- package/dist/admin/eu-CTGdmY94.js.map +0 -1
- package/dist/admin/fr-BMaOPAWr.js +0 -601
- package/dist/admin/fr-CndUnB7j.mjs +0 -579
- package/dist/admin/gu-CSS25C49.mjs +0 -429
- package/dist/admin/gu-Hc5YzUuw.js +0 -438
- package/dist/admin/he-C3w9omDw.mjs +0 -315
- package/dist/admin/he-kuscdOPI.js +0 -329
- package/dist/admin/he-kuscdOPI.js.map +0 -1
- package/dist/admin/hi-ChZ-xy57.js +0 -537
- package/dist/admin/hi-ChZ-xy57.js.map +0 -1
- package/dist/admin/hi-DW2CutdA.mjs +0 -519
- package/dist/admin/hu-DaDd6FHR.mjs +0 -625
- package/dist/admin/hu-lwp6bYbA.js +0 -645
- package/dist/admin/hu-lwp6bYbA.js.map +0 -1
- package/dist/admin/id-BX77nhRG.js +0 -303
- package/dist/admin/id-cH3Ovozx.mjs +0 -290
- package/dist/admin/index-DLbx6g-v.js +0 -5465
- package/dist/admin/index-DLbx6g-v.js.map +0 -1
- package/dist/admin/index-DoNaXvrg.mjs +0 -5391
- package/dist/admin/index-DoNaXvrg.mjs.map +0 -1
- package/dist/admin/it-Br3eqqDa.js +0 -312
- package/dist/admin/it-T1rZP3NX.mjs +0 -299
- package/dist/admin/ja-Cc9Dg_QK.mjs +0 -434
- package/dist/admin/ja-CmifbkZD.js +0 -452
- package/dist/admin/ko-CS08pZ0z.js +0 -451
- package/dist/admin/ko-D1e-SMHS.mjs +0 -433
- package/dist/admin/ml-CzFKbt9H.js +0 -537
- package/dist/admin/ml-FLft_QIc.mjs +0 -519
- package/dist/admin/ms-C-JB0-h1.js +0 -213
- package/dist/admin/ms-eMDSLvhl.mjs +0 -200
- package/dist/admin/nl-CubaFTJw.mjs +0 -621
- package/dist/admin/nl-gUEC_dKT.js +0 -641
- package/dist/admin/no-9TbSG07o.mjs +0 -300
- package/dist/admin/no-DU4xtEmk.js +0 -313
- package/dist/admin/pl-B0hZgHvQ.mjs +0 -519
- package/dist/admin/pl-Bf4D5Q8_.js +0 -537
- package/dist/admin/pt-8dwKSOn3.mjs +0 -200
- package/dist/admin/pt-BR-BDpWvCrQ.mjs +0 -588
- package/dist/admin/pt-BR-BFq-a8-C.js +0 -608
- package/dist/admin/pt-CEcd6cjN.js +0 -212
- package/dist/admin/ru-C34i9wJx.mjs +0 -745
- package/dist/admin/ru-Dwf09uUc.js +0 -766
- package/dist/admin/sa--UlKNdfY.js +0 -537
- package/dist/admin/sa--UlKNdfY.js.map +0 -1
- package/dist/admin/sa-CHD-r_h-.mjs +0 -519
- package/dist/admin/sa-CHD-r_h-.mjs.map +0 -1
- package/dist/admin/selectors-BZApelK9.mjs +0 -6
- package/dist/admin/selectors-BZApelK9.mjs.map +0 -1
- package/dist/admin/selectors-BhMLvxvP.js +0 -8
- package/dist/admin/selectors-BhMLvxvP.js.map +0 -1
- package/dist/admin/sk-CbJVofN-.js +0 -503
- package/dist/admin/sk-DQ2qpsG2.mjs +0 -483
- package/dist/admin/sv-BqRXfruc.js +0 -640
- package/dist/admin/sv-D0vPVUAT.mjs +0 -620
- package/dist/admin/th-BG3IOCqV.mjs +0 -284
- package/dist/admin/th-CPx6wf0M.js +0 -297
- package/dist/admin/tr-Dq45DRRZ.mjs +0 -581
- package/dist/admin/tr-hC_m0V8Q.js +0 -601
- package/dist/admin/transferTokens-AcbwoJPr.js +0 -76
- package/dist/admin/transferTokens-AcbwoJPr.js.map +0 -1
- package/dist/admin/transferTokens-CQP13miB.mjs +0 -69
- package/dist/admin/transferTokens-CQP13miB.mjs.map +0 -1
- package/dist/admin/uk-DHmepDW6.js +0 -214
- package/dist/admin/uk-DHmepDW6.js.map +0 -1
- package/dist/admin/uk-Ud9QNfkB.mjs +0 -201
- package/dist/admin/useAdminRoles-DWhky7Ix.mjs +0 -28
- package/dist/admin/useAdminRoles-DWhky7Ix.mjs.map +0 -1
- package/dist/admin/useAdminRoles-rz3j-u2R.js +0 -50
- package/dist/admin/useAdminRoles-rz3j-u2R.js.map +0 -1
- package/dist/admin/useEnterprise-BGzVPL4w.mjs +0 -28
- package/dist/admin/useEnterprise-BGzVPL4w.mjs.map +0 -1
- package/dist/admin/useEnterprise-ijNnK53J.js +0 -50
- package/dist/admin/useEnterprise-ijNnK53J.js.map +0 -1
- package/dist/admin/useLicenseLimitNotification-CAQIrlP4.mjs +0 -80
- package/dist/admin/useLicenseLimitNotification-CAQIrlP4.mjs.map +0 -1
- package/dist/admin/useLicenseLimitNotification-bcc8RZRX.js +0 -105
- package/dist/admin/useLicenseLimitNotification-bcc8RZRX.js.map +0 -1
- package/dist/admin/useLicenseLimits-73hrs_pV.js +0 -45
- package/dist/admin/useLicenseLimits-73hrs_pV.js.map +0 -1
- package/dist/admin/useLicenseLimits-CcOoSJ8p.mjs +0 -23
- package/dist/admin/useLicenseLimits-CcOoSJ8p.mjs.map +0 -1
- package/dist/admin/useOnce-C7EQufL3.js +0 -29
- package/dist/admin/useOnce-C7EQufL3.js.map +0 -1
- package/dist/admin/useOnce-NHeEacbN.mjs +0 -7
- package/dist/admin/useOnce-NHeEacbN.mjs.map +0 -1
- package/dist/admin/useWebhooks-PMmtSF2F.mjs +0 -93
- package/dist/admin/useWebhooks-PMmtSF2F.mjs.map +0 -1
- package/dist/admin/useWebhooks-oYy_qRlY.js +0 -95
- package/dist/admin/useWebhooks-oYy_qRlY.js.map +0 -1
- package/dist/admin/users-8N93LH7R.mjs +0 -30
- package/dist/admin/users-8N93LH7R.mjs.map +0 -1
- package/dist/admin/users-DaPfjlwf.js +0 -33
- package/dist/admin/users-DaPfjlwf.js.map +0 -1
- package/dist/admin/validation-ABNr-9R6.js +0 -65
- package/dist/admin/validation-ABNr-9R6.js.map +0 -1
- package/dist/admin/validation-Zw14C1gy.mjs +0 -43
- package/dist/admin/validation-Zw14C1gy.mjs.map +0 -1
- package/dist/admin/vi-CGrr4ioy.mjs +0 -187
- package/dist/admin/vi-UeRpPdvI.js +0 -200
- package/dist/admin/zh-Bhpup4vu.js +0 -642
- package/dist/admin/zh-Hans-BlfT-iYf.js +0 -737
- package/dist/admin/zh-Hans-C44LvcXE.mjs +0 -716
- package/dist/admin/zh-LqPg8hbL.mjs +0 -622
- package/dist/package.json.d.ts +0 -193
|
@@ -1,1434 +0,0 @@
|
|
|
1
|
-
import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
|
|
2
|
-
import * as React from 'react';
|
|
3
|
-
import { useMemo, useCallback, useRef, useEffect } from 'react';
|
|
4
|
-
import { createContext as createContext$1 } from '@radix-ui/react-context';
|
|
5
|
-
import { useIntl, IntlProvider } from 'react-intl';
|
|
6
|
-
import { Flex, useCallbackRef, Alert, Link, Main, Loader, EmptyStateLayout, Box, DesignSystemProvider } from '@strapi/design-system';
|
|
7
|
-
import { WarningCircle } from '@strapi/icons';
|
|
8
|
-
import { EmptyPermissions, EmptyDocuments } from '@strapi/icons/symbols';
|
|
9
|
-
import { useLocation, useNavigate } from 'react-router-dom';
|
|
10
|
-
import { parse, stringify } from 'qs';
|
|
11
|
-
import { a as adminApi, e as useInitQuery, f as useTelemetryPropertiesQuery, g as useProjectSettingsQuery, h as useUpdateProjectSettingsMutation } from './admin-DOzK8yjX.mjs';
|
|
12
|
-
import clone from 'lodash/clone';
|
|
13
|
-
import toPath from 'lodash/toPath';
|
|
14
|
-
import isEqual from 'lodash/isEqual';
|
|
15
|
-
import axios from 'axios';
|
|
16
|
-
import { produce } from 'immer';
|
|
17
|
-
import get from 'lodash/get';
|
|
18
|
-
import set from 'lodash/set';
|
|
19
|
-
import * as ContextSelector from 'use-context-selector';
|
|
20
|
-
import defaultsDeep from 'lodash/defaultsDeep';
|
|
21
|
-
import { useStore, useDispatch, useSelector } from 'react-redux';
|
|
22
|
-
import { createGlobalStyle } from 'styled-components';
|
|
23
|
-
import { createSelector, createSlice } from '@reduxjs/toolkit';
|
|
24
|
-
|
|
25
|
-
class RBAC {
|
|
26
|
-
middlewares = [];
|
|
27
|
-
constructor() {
|
|
28
|
-
}
|
|
29
|
-
use(middleware) {
|
|
30
|
-
if (Array.isArray(middleware)) {
|
|
31
|
-
this.middlewares.push(...middleware);
|
|
32
|
-
} else {
|
|
33
|
-
this.middlewares.push(middleware);
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
run = async (ctx, permissions) => {
|
|
37
|
-
let index = 0;
|
|
38
|
-
const middlewaresToRun = this.middlewares.map((middleware) => middleware(ctx));
|
|
39
|
-
const next = async (permissions2) => {
|
|
40
|
-
if (index < this.middlewares.length) {
|
|
41
|
-
return middlewaresToRun[index++](next)(permissions2);
|
|
42
|
-
}
|
|
43
|
-
return permissions2;
|
|
44
|
-
};
|
|
45
|
-
return next(permissions);
|
|
46
|
-
};
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
function createContext(rootComponentName, defaultContext) {
|
|
50
|
-
const Context = ContextSelector.createContext(defaultContext);
|
|
51
|
-
const Provider = (props) => {
|
|
52
|
-
const { children, ...context } = props;
|
|
53
|
-
const value = React.useMemo(() => context, Object.values(context));
|
|
54
|
-
return /* @__PURE__ */ jsx(Context.Provider, { value, children });
|
|
55
|
-
};
|
|
56
|
-
const useContext = (consumerName, selector) => ContextSelector.useContextSelector(Context, (ctx) => {
|
|
57
|
-
if (ctx)
|
|
58
|
-
return selector(ctx);
|
|
59
|
-
throw new Error(`\`${consumerName}\` must be used within \`${rootComponentName}\``);
|
|
60
|
-
});
|
|
61
|
-
Provider.displayName = rootComponentName + "Provider";
|
|
62
|
-
return [Provider, useContext];
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
const useTypedDispatch = useDispatch;
|
|
66
|
-
const useTypedStore = useStore;
|
|
67
|
-
const useTypedSelector = useSelector;
|
|
68
|
-
const createTypedSelector = (selector) => createSelector((state) => state, selector);
|
|
69
|
-
|
|
70
|
-
const [StrapiAppProvider, useStrapiApp] = createContext("StrapiApp");
|
|
71
|
-
|
|
72
|
-
const useQueryParams = (initialParams) => {
|
|
73
|
-
const { search } = useLocation();
|
|
74
|
-
const navigate = useNavigate();
|
|
75
|
-
const query = useMemo(() => {
|
|
76
|
-
const searchQuery = search.startsWith("?") ? search.slice(1) : search;
|
|
77
|
-
if (!search && initialParams) {
|
|
78
|
-
return initialParams;
|
|
79
|
-
}
|
|
80
|
-
return { ...initialParams, ...parse(searchQuery) };
|
|
81
|
-
}, [search, initialParams]);
|
|
82
|
-
const setQuery = useCallback(
|
|
83
|
-
(nextParams, method = "push", replace = false) => {
|
|
84
|
-
let nextQuery = { ...query };
|
|
85
|
-
if (method === "remove") {
|
|
86
|
-
Object.keys(nextParams).forEach((key) => {
|
|
87
|
-
if (Object.prototype.hasOwnProperty.call(nextQuery, key)) {
|
|
88
|
-
delete nextQuery[key];
|
|
89
|
-
}
|
|
90
|
-
});
|
|
91
|
-
} else {
|
|
92
|
-
nextQuery = { ...query, ...nextParams };
|
|
93
|
-
}
|
|
94
|
-
navigate({ search: stringify(nextQuery, { encode: false }) }, { replace });
|
|
95
|
-
},
|
|
96
|
-
[navigate, query]
|
|
97
|
-
);
|
|
98
|
-
return [{ query, rawQuery: search }, setQuery];
|
|
99
|
-
};
|
|
100
|
-
|
|
101
|
-
const STORAGE_KEYS$1 = {
|
|
102
|
-
TOKEN: "jwtToken",
|
|
103
|
-
USER: "userInfo"
|
|
104
|
-
};
|
|
105
|
-
const THEME_LOCAL_STORAGE_KEY = "STRAPI_THEME";
|
|
106
|
-
const LANGUAGE_LOCAL_STORAGE_KEY = "strapi-admin-language";
|
|
107
|
-
const getStoredToken = () => {
|
|
108
|
-
const token = localStorage.getItem(STORAGE_KEYS$1.TOKEN) ?? sessionStorage.getItem(STORAGE_KEYS$1.TOKEN);
|
|
109
|
-
if (typeof token === "string") {
|
|
110
|
-
return JSON.parse(token);
|
|
111
|
-
}
|
|
112
|
-
return null;
|
|
113
|
-
};
|
|
114
|
-
const adminSlice = createSlice({
|
|
115
|
-
name: "admin",
|
|
116
|
-
initialState: () => {
|
|
117
|
-
return {
|
|
118
|
-
language: {
|
|
119
|
-
locale: "en",
|
|
120
|
-
localeNames: { en: "English" }
|
|
121
|
-
},
|
|
122
|
-
permissions: {},
|
|
123
|
-
theme: {
|
|
124
|
-
availableThemes: [],
|
|
125
|
-
currentTheme: localStorage.getItem(THEME_LOCAL_STORAGE_KEY) || "system"
|
|
126
|
-
},
|
|
127
|
-
token: null
|
|
128
|
-
};
|
|
129
|
-
},
|
|
130
|
-
reducers: {
|
|
131
|
-
setAppTheme(state, action) {
|
|
132
|
-
state.theme.currentTheme = action.payload;
|
|
133
|
-
window.localStorage.setItem(THEME_LOCAL_STORAGE_KEY, action.payload);
|
|
134
|
-
},
|
|
135
|
-
setAvailableThemes(state, action) {
|
|
136
|
-
state.theme.availableThemes = action.payload;
|
|
137
|
-
},
|
|
138
|
-
setLocale(state, action) {
|
|
139
|
-
state.language.locale = action.payload;
|
|
140
|
-
window.localStorage.setItem(LANGUAGE_LOCAL_STORAGE_KEY, action.payload);
|
|
141
|
-
document.documentElement.setAttribute("lang", action.payload);
|
|
142
|
-
},
|
|
143
|
-
setToken(state, action) {
|
|
144
|
-
state.token = action.payload;
|
|
145
|
-
},
|
|
146
|
-
login(state, action) {
|
|
147
|
-
const { token, persist } = action.payload;
|
|
148
|
-
if (!persist) {
|
|
149
|
-
window.sessionStorage.setItem(STORAGE_KEYS$1.TOKEN, JSON.stringify(token));
|
|
150
|
-
} else {
|
|
151
|
-
window.localStorage.setItem(STORAGE_KEYS$1.TOKEN, JSON.stringify(token));
|
|
152
|
-
}
|
|
153
|
-
state.token = token;
|
|
154
|
-
},
|
|
155
|
-
logout(state) {
|
|
156
|
-
state.token = null;
|
|
157
|
-
window.localStorage.removeItem(STORAGE_KEYS$1.TOKEN);
|
|
158
|
-
window.localStorage.removeItem(STORAGE_KEYS$1.USER);
|
|
159
|
-
window.sessionStorage.removeItem(STORAGE_KEYS$1.TOKEN);
|
|
160
|
-
window.sessionStorage.removeItem(STORAGE_KEYS$1.USER);
|
|
161
|
-
}
|
|
162
|
-
}
|
|
163
|
-
});
|
|
164
|
-
const reducer$1 = adminSlice.reducer;
|
|
165
|
-
const { setAppTheme, setAvailableThemes, setLocale, setToken, logout, login } = adminSlice.actions;
|
|
166
|
-
|
|
167
|
-
const authService = adminApi.enhanceEndpoints({
|
|
168
|
-
addTagTypes: ["User", "Me", "ProvidersOptions"]
|
|
169
|
-
}).injectEndpoints({
|
|
170
|
-
endpoints: (builder) => ({
|
|
171
|
-
/**
|
|
172
|
-
* ME
|
|
173
|
-
*/
|
|
174
|
-
getMe: builder.query({
|
|
175
|
-
query: () => ({
|
|
176
|
-
method: "GET",
|
|
177
|
-
url: "/admin/users/me"
|
|
178
|
-
}),
|
|
179
|
-
transformResponse(res) {
|
|
180
|
-
return res.data;
|
|
181
|
-
},
|
|
182
|
-
providesTags: (res) => res ? ["Me", { type: "User", id: res.id }] : ["Me"]
|
|
183
|
-
}),
|
|
184
|
-
getMyPermissions: builder.query({
|
|
185
|
-
query: () => ({
|
|
186
|
-
method: "GET",
|
|
187
|
-
url: "/admin/users/me/permissions"
|
|
188
|
-
}),
|
|
189
|
-
transformResponse(res) {
|
|
190
|
-
return res.data;
|
|
191
|
-
}
|
|
192
|
-
}),
|
|
193
|
-
updateMe: builder.mutation({
|
|
194
|
-
query: (body) => ({
|
|
195
|
-
method: "PUT",
|
|
196
|
-
url: "/admin/users/me",
|
|
197
|
-
data: body
|
|
198
|
-
}),
|
|
199
|
-
transformResponse(res) {
|
|
200
|
-
return res.data;
|
|
201
|
-
},
|
|
202
|
-
invalidatesTags: ["Me"]
|
|
203
|
-
}),
|
|
204
|
-
/**
|
|
205
|
-
* Permissions
|
|
206
|
-
*/
|
|
207
|
-
checkPermissions: builder.query({
|
|
208
|
-
query: (permissions) => ({
|
|
209
|
-
method: "POST",
|
|
210
|
-
url: "/admin/permissions/check",
|
|
211
|
-
data: permissions
|
|
212
|
-
})
|
|
213
|
-
}),
|
|
214
|
-
/**
|
|
215
|
-
* Auth methods
|
|
216
|
-
*/
|
|
217
|
-
login: builder.mutation({
|
|
218
|
-
query: (body) => ({
|
|
219
|
-
method: "POST",
|
|
220
|
-
url: "/admin/login",
|
|
221
|
-
data: body
|
|
222
|
-
}),
|
|
223
|
-
transformResponse(res) {
|
|
224
|
-
return res.data;
|
|
225
|
-
},
|
|
226
|
-
invalidatesTags: ["Me"]
|
|
227
|
-
}),
|
|
228
|
-
logout: builder.mutation({
|
|
229
|
-
query: () => ({
|
|
230
|
-
method: "POST",
|
|
231
|
-
url: "/admin/logout"
|
|
232
|
-
})
|
|
233
|
-
}),
|
|
234
|
-
resetPassword: builder.mutation({
|
|
235
|
-
query: (body) => ({
|
|
236
|
-
method: "POST",
|
|
237
|
-
url: "/admin/reset-password",
|
|
238
|
-
data: body
|
|
239
|
-
}),
|
|
240
|
-
transformResponse(res) {
|
|
241
|
-
return res.data;
|
|
242
|
-
}
|
|
243
|
-
}),
|
|
244
|
-
renewToken: builder.mutation({
|
|
245
|
-
query: (body) => ({
|
|
246
|
-
method: "POST",
|
|
247
|
-
url: "/admin/renew-token",
|
|
248
|
-
data: body
|
|
249
|
-
}),
|
|
250
|
-
transformResponse(res) {
|
|
251
|
-
return res.data;
|
|
252
|
-
}
|
|
253
|
-
}),
|
|
254
|
-
getRegistrationInfo: builder.query({
|
|
255
|
-
query: (registrationToken) => ({
|
|
256
|
-
url: "/admin/registration-info",
|
|
257
|
-
method: "GET",
|
|
258
|
-
config: {
|
|
259
|
-
params: {
|
|
260
|
-
registrationToken
|
|
261
|
-
}
|
|
262
|
-
}
|
|
263
|
-
}),
|
|
264
|
-
transformResponse(res) {
|
|
265
|
-
return res.data;
|
|
266
|
-
}
|
|
267
|
-
}),
|
|
268
|
-
registerAdmin: builder.mutation({
|
|
269
|
-
query: (body) => ({
|
|
270
|
-
method: "POST",
|
|
271
|
-
url: "/admin/register-admin",
|
|
272
|
-
data: body
|
|
273
|
-
}),
|
|
274
|
-
transformResponse(res) {
|
|
275
|
-
return res.data;
|
|
276
|
-
}
|
|
277
|
-
}),
|
|
278
|
-
registerUser: builder.mutation({
|
|
279
|
-
query: (body) => ({
|
|
280
|
-
method: "POST",
|
|
281
|
-
url: "/admin/register",
|
|
282
|
-
data: body
|
|
283
|
-
}),
|
|
284
|
-
transformResponse(res) {
|
|
285
|
-
return res.data;
|
|
286
|
-
}
|
|
287
|
-
}),
|
|
288
|
-
forgotPassword: builder.mutation({
|
|
289
|
-
query: (body) => ({
|
|
290
|
-
url: "/admin/forgot-password",
|
|
291
|
-
method: "POST",
|
|
292
|
-
data: body
|
|
293
|
-
})
|
|
294
|
-
}),
|
|
295
|
-
isSSOLocked: builder.query({
|
|
296
|
-
query: () => ({
|
|
297
|
-
url: "/admin/providers/isSSOLocked",
|
|
298
|
-
method: "GET"
|
|
299
|
-
}),
|
|
300
|
-
transformResponse(res) {
|
|
301
|
-
return res.data;
|
|
302
|
-
}
|
|
303
|
-
}),
|
|
304
|
-
getProviders: builder.query({
|
|
305
|
-
query: () => ({
|
|
306
|
-
url: "/admin/providers",
|
|
307
|
-
method: "GET"
|
|
308
|
-
})
|
|
309
|
-
}),
|
|
310
|
-
getProviderOptions: builder.query({
|
|
311
|
-
query: () => ({
|
|
312
|
-
url: "/admin/providers/options",
|
|
313
|
-
method: "GET"
|
|
314
|
-
}),
|
|
315
|
-
transformResponse(res) {
|
|
316
|
-
return res.data;
|
|
317
|
-
},
|
|
318
|
-
providesTags: ["ProvidersOptions"]
|
|
319
|
-
}),
|
|
320
|
-
updateProviderOptions: builder.mutation({
|
|
321
|
-
query: (body) => ({
|
|
322
|
-
url: "/admin/providers/options",
|
|
323
|
-
method: "PUT",
|
|
324
|
-
data: body
|
|
325
|
-
}),
|
|
326
|
-
transformResponse(res) {
|
|
327
|
-
return res.data;
|
|
328
|
-
},
|
|
329
|
-
invalidatesTags: ["ProvidersOptions"]
|
|
330
|
-
})
|
|
331
|
-
}),
|
|
332
|
-
overrideExisting: false
|
|
333
|
-
});
|
|
334
|
-
const {
|
|
335
|
-
useCheckPermissionsQuery,
|
|
336
|
-
useLazyCheckPermissionsQuery,
|
|
337
|
-
useGetMeQuery,
|
|
338
|
-
useLoginMutation,
|
|
339
|
-
useRenewTokenMutation,
|
|
340
|
-
useLogoutMutation,
|
|
341
|
-
useUpdateMeMutation,
|
|
342
|
-
useResetPasswordMutation,
|
|
343
|
-
useRegisterAdminMutation,
|
|
344
|
-
useRegisterUserMutation,
|
|
345
|
-
useGetRegistrationInfoQuery,
|
|
346
|
-
useForgotPasswordMutation,
|
|
347
|
-
useGetMyPermissionsQuery,
|
|
348
|
-
useIsSSOLockedQuery,
|
|
349
|
-
useGetProvidersQuery,
|
|
350
|
-
useGetProviderOptionsQuery,
|
|
351
|
-
useUpdateProviderOptionsMutation
|
|
352
|
-
} = authService;
|
|
353
|
-
|
|
354
|
-
const [Provider, useAuth] = createContext("Auth");
|
|
355
|
-
const STORAGE_KEYS = {
|
|
356
|
-
TOKEN: "jwtToken",
|
|
357
|
-
USER: "userInfo"
|
|
358
|
-
};
|
|
359
|
-
const AuthProvider = ({
|
|
360
|
-
children,
|
|
361
|
-
_defaultPermissions = [],
|
|
362
|
-
_disableRenewToken = false
|
|
363
|
-
}) => {
|
|
364
|
-
const dispatch = useTypedDispatch();
|
|
365
|
-
const runRbacMiddleware = useStrapiApp("AuthProvider", (state) => state.rbac.run);
|
|
366
|
-
const location = useLocation();
|
|
367
|
-
const [{ rawQuery }] = useQueryParams();
|
|
368
|
-
const token = useTypedSelector((state) => state.admin_app.token ?? null);
|
|
369
|
-
const { data: user, isLoading: isLoadingUser } = useGetMeQuery(void 0, {
|
|
370
|
-
/**
|
|
371
|
-
* If there's no token, we don't try to fetch
|
|
372
|
-
* the user data because it will fail.
|
|
373
|
-
*/
|
|
374
|
-
skip: !token
|
|
375
|
-
});
|
|
376
|
-
const {
|
|
377
|
-
data: userPermissions = _defaultPermissions,
|
|
378
|
-
refetch,
|
|
379
|
-
isUninitialized,
|
|
380
|
-
isLoading: isLoadingPermissions
|
|
381
|
-
} = useGetMyPermissionsQuery(void 0, {
|
|
382
|
-
skip: !token
|
|
383
|
-
});
|
|
384
|
-
const navigate = useNavigate();
|
|
385
|
-
const [loginMutation] = useLoginMutation();
|
|
386
|
-
const [renewTokenMutation] = useRenewTokenMutation();
|
|
387
|
-
const [logoutMutation] = useLogoutMutation();
|
|
388
|
-
const clearStateAndLogout = React.useCallback(() => {
|
|
389
|
-
dispatch(adminApi.util.resetApiState());
|
|
390
|
-
dispatch(logout());
|
|
391
|
-
navigate("/auth/login");
|
|
392
|
-
}, [dispatch, navigate]);
|
|
393
|
-
React.useEffect(() => {
|
|
394
|
-
if (token && !_disableRenewToken) {
|
|
395
|
-
renewTokenMutation({ token }).then((res) => {
|
|
396
|
-
if ("data" in res) {
|
|
397
|
-
dispatch(
|
|
398
|
-
login({
|
|
399
|
-
token: res.data.token
|
|
400
|
-
})
|
|
401
|
-
);
|
|
402
|
-
} else {
|
|
403
|
-
clearStateAndLogout();
|
|
404
|
-
}
|
|
405
|
-
});
|
|
406
|
-
}
|
|
407
|
-
}, [token, dispatch, renewTokenMutation, clearStateAndLogout, _disableRenewToken]);
|
|
408
|
-
React.useEffect(() => {
|
|
409
|
-
if (user) {
|
|
410
|
-
if (user.preferedLanguage) {
|
|
411
|
-
dispatch(setLocale(user.preferedLanguage));
|
|
412
|
-
}
|
|
413
|
-
}
|
|
414
|
-
}, [dispatch, user]);
|
|
415
|
-
React.useEffect(() => {
|
|
416
|
-
const handleUserStorageChange = (event) => {
|
|
417
|
-
if (event.key === STORAGE_KEYS.USER && event.newValue === null) {
|
|
418
|
-
clearStateAndLogout();
|
|
419
|
-
}
|
|
420
|
-
};
|
|
421
|
-
window.addEventListener("storage", handleUserStorageChange);
|
|
422
|
-
return () => {
|
|
423
|
-
window.removeEventListener("storage", handleUserStorageChange);
|
|
424
|
-
};
|
|
425
|
-
});
|
|
426
|
-
const login$1 = React.useCallback(
|
|
427
|
-
async ({ rememberMe, ...body }) => {
|
|
428
|
-
const res = await loginMutation(body);
|
|
429
|
-
if ("data" in res) {
|
|
430
|
-
const { token: token2 } = res.data;
|
|
431
|
-
dispatch(
|
|
432
|
-
login({
|
|
433
|
-
token: token2,
|
|
434
|
-
persist: rememberMe
|
|
435
|
-
})
|
|
436
|
-
);
|
|
437
|
-
}
|
|
438
|
-
return res;
|
|
439
|
-
},
|
|
440
|
-
[dispatch, loginMutation]
|
|
441
|
-
);
|
|
442
|
-
const logout$1 = React.useCallback(async () => {
|
|
443
|
-
await logoutMutation();
|
|
444
|
-
clearStateAndLogout();
|
|
445
|
-
}, [clearStateAndLogout, logoutMutation]);
|
|
446
|
-
const refetchPermissions = React.useCallback(async () => {
|
|
447
|
-
if (!isUninitialized) {
|
|
448
|
-
await refetch();
|
|
449
|
-
}
|
|
450
|
-
}, [isUninitialized, refetch]);
|
|
451
|
-
const [checkPermissions] = useLazyCheckPermissionsQuery();
|
|
452
|
-
const checkUserHasPermissions = React.useCallback(
|
|
453
|
-
async (permissions, passedPermissions, rawQueryContext) => {
|
|
454
|
-
if (!permissions || permissions.length === 0) {
|
|
455
|
-
return [{ action: "", subject: "" }];
|
|
456
|
-
}
|
|
457
|
-
const actualUserPermissions = passedPermissions ?? userPermissions;
|
|
458
|
-
const matchingPermissions = actualUserPermissions.filter(
|
|
459
|
-
(permission) => permissions.findIndex(
|
|
460
|
-
(perm) => perm.action === permission.action && perm.subject === permission.subject
|
|
461
|
-
) >= 0
|
|
462
|
-
);
|
|
463
|
-
const middlewaredPermissions = await runRbacMiddleware(
|
|
464
|
-
{
|
|
465
|
-
user,
|
|
466
|
-
permissions: userPermissions,
|
|
467
|
-
pathname: location.pathname,
|
|
468
|
-
search: (rawQueryContext || rawQuery).split("?")[1] ?? ""
|
|
469
|
-
},
|
|
470
|
-
matchingPermissions
|
|
471
|
-
);
|
|
472
|
-
const shouldCheckConditions = middlewaredPermissions.some(
|
|
473
|
-
(perm) => Array.isArray(perm.conditions) && perm.conditions.length > 0
|
|
474
|
-
);
|
|
475
|
-
if (!shouldCheckConditions) {
|
|
476
|
-
return middlewaredPermissions;
|
|
477
|
-
}
|
|
478
|
-
const { data, error } = await checkPermissions({
|
|
479
|
-
permissions: middlewaredPermissions.map((perm) => ({
|
|
480
|
-
action: perm.action,
|
|
481
|
-
subject: perm.subject
|
|
482
|
-
}))
|
|
483
|
-
});
|
|
484
|
-
if (error) {
|
|
485
|
-
throw error;
|
|
486
|
-
} else {
|
|
487
|
-
return middlewaredPermissions.filter((_, index) => data?.data[index] === true);
|
|
488
|
-
}
|
|
489
|
-
},
|
|
490
|
-
[checkPermissions, location.pathname, rawQuery, runRbacMiddleware, user, userPermissions]
|
|
491
|
-
);
|
|
492
|
-
const isLoading = isLoadingUser || isLoadingPermissions;
|
|
493
|
-
return /* @__PURE__ */ jsx(
|
|
494
|
-
Provider,
|
|
495
|
-
{
|
|
496
|
-
token,
|
|
497
|
-
user,
|
|
498
|
-
login: login$1,
|
|
499
|
-
logout: logout$1,
|
|
500
|
-
permissions: userPermissions,
|
|
501
|
-
checkUserHasPermissions,
|
|
502
|
-
refetchPermissions,
|
|
503
|
-
isLoading,
|
|
504
|
-
children
|
|
505
|
-
}
|
|
506
|
-
);
|
|
507
|
-
};
|
|
508
|
-
|
|
509
|
-
const NotificationsContext = React.createContext({
|
|
510
|
-
toggleNotification: () => {
|
|
511
|
-
}
|
|
512
|
-
});
|
|
513
|
-
const NotificationsProvider = ({ children }) => {
|
|
514
|
-
const notificationIdRef = React.useRef(0);
|
|
515
|
-
const [notifications, setNotifications] = React.useState([]);
|
|
516
|
-
const toggleNotification = React.useCallback(
|
|
517
|
-
({ type, message, link, timeout, blockTransition, onClose, title }) => {
|
|
518
|
-
setNotifications((s) => [
|
|
519
|
-
...s,
|
|
520
|
-
{
|
|
521
|
-
id: notificationIdRef.current++,
|
|
522
|
-
type,
|
|
523
|
-
message,
|
|
524
|
-
link,
|
|
525
|
-
timeout,
|
|
526
|
-
blockTransition,
|
|
527
|
-
onClose,
|
|
528
|
-
title
|
|
529
|
-
}
|
|
530
|
-
]);
|
|
531
|
-
},
|
|
532
|
-
[]
|
|
533
|
-
);
|
|
534
|
-
const clearNotification = React.useCallback((id) => {
|
|
535
|
-
setNotifications((s) => s.filter((n) => n.id !== id));
|
|
536
|
-
}, []);
|
|
537
|
-
const value = React.useMemo(() => ({ toggleNotification }), [toggleNotification]);
|
|
538
|
-
return /* @__PURE__ */ jsxs(NotificationsContext.Provider, { value, children: [
|
|
539
|
-
/* @__PURE__ */ jsx(
|
|
540
|
-
Flex,
|
|
541
|
-
{
|
|
542
|
-
left: "50%",
|
|
543
|
-
marginLeft: "-250px",
|
|
544
|
-
position: "fixed",
|
|
545
|
-
direction: "column",
|
|
546
|
-
alignItems: "stretch",
|
|
547
|
-
gap: 2,
|
|
548
|
-
top: `4.6rem`,
|
|
549
|
-
width: `50rem`,
|
|
550
|
-
zIndex: "notification",
|
|
551
|
-
children: notifications.map((notification) => {
|
|
552
|
-
return /* @__PURE__ */ jsx(
|
|
553
|
-
Notification,
|
|
554
|
-
{
|
|
555
|
-
...notification,
|
|
556
|
-
clearNotification
|
|
557
|
-
},
|
|
558
|
-
notification.id
|
|
559
|
-
);
|
|
560
|
-
})
|
|
561
|
-
}
|
|
562
|
-
),
|
|
563
|
-
children
|
|
564
|
-
] });
|
|
565
|
-
};
|
|
566
|
-
const Notification = ({
|
|
567
|
-
clearNotification,
|
|
568
|
-
blockTransition = false,
|
|
569
|
-
id,
|
|
570
|
-
link,
|
|
571
|
-
message,
|
|
572
|
-
onClose,
|
|
573
|
-
timeout = 2500,
|
|
574
|
-
title,
|
|
575
|
-
type
|
|
576
|
-
}) => {
|
|
577
|
-
const { formatMessage } = useIntl();
|
|
578
|
-
const onCloseCallback = useCallbackRef(onClose);
|
|
579
|
-
const handleClose = React.useCallback(() => {
|
|
580
|
-
onCloseCallback();
|
|
581
|
-
clearNotification(id);
|
|
582
|
-
}, [clearNotification, id, onCloseCallback]);
|
|
583
|
-
React.useEffect(() => {
|
|
584
|
-
if (!blockTransition) {
|
|
585
|
-
const timeoutReference = setTimeout(() => {
|
|
586
|
-
handleClose();
|
|
587
|
-
}, timeout);
|
|
588
|
-
return () => {
|
|
589
|
-
clearTimeout(timeoutReference);
|
|
590
|
-
};
|
|
591
|
-
}
|
|
592
|
-
}, [blockTransition, handleClose, timeout]);
|
|
593
|
-
let variant;
|
|
594
|
-
let alertTitle;
|
|
595
|
-
if (type === "info") {
|
|
596
|
-
variant = "default";
|
|
597
|
-
alertTitle = formatMessage({
|
|
598
|
-
id: "notification.default.title",
|
|
599
|
-
defaultMessage: "Information:"
|
|
600
|
-
});
|
|
601
|
-
} else if (type === "danger") {
|
|
602
|
-
variant = "danger";
|
|
603
|
-
alertTitle = formatMessage({
|
|
604
|
-
id: "notification.warning.title",
|
|
605
|
-
defaultMessage: "Warning:"
|
|
606
|
-
});
|
|
607
|
-
} else if (type === "warning") {
|
|
608
|
-
variant = "warning";
|
|
609
|
-
alertTitle = formatMessage({
|
|
610
|
-
id: "notification.warning.title",
|
|
611
|
-
defaultMessage: "Warning:"
|
|
612
|
-
});
|
|
613
|
-
} else {
|
|
614
|
-
variant = "success";
|
|
615
|
-
alertTitle = formatMessage({
|
|
616
|
-
id: "notification.success.title",
|
|
617
|
-
defaultMessage: "Success:"
|
|
618
|
-
});
|
|
619
|
-
}
|
|
620
|
-
if (title) {
|
|
621
|
-
alertTitle = title;
|
|
622
|
-
}
|
|
623
|
-
return /* @__PURE__ */ jsx(
|
|
624
|
-
Alert,
|
|
625
|
-
{
|
|
626
|
-
action: link ? /* @__PURE__ */ jsx(Link, { href: link.url, isExternal: true, children: link.label }) : void 0,
|
|
627
|
-
onClose: handleClose,
|
|
628
|
-
closeLabel: formatMessage({
|
|
629
|
-
id: "global.close",
|
|
630
|
-
defaultMessage: "Close"
|
|
631
|
-
}),
|
|
632
|
-
title: alertTitle,
|
|
633
|
-
variant,
|
|
634
|
-
children: message
|
|
635
|
-
}
|
|
636
|
-
);
|
|
637
|
-
};
|
|
638
|
-
/**
|
|
639
|
-
* @preserve
|
|
640
|
-
* @description Returns an object to interact with the notification
|
|
641
|
-
* system. The callbacks are wrapped in `useCallback` for a stable
|
|
642
|
-
* identity.
|
|
643
|
-
*
|
|
644
|
-
* @example
|
|
645
|
-
* ```tsx
|
|
646
|
-
* import { useNotification } from '@strapi/strapi/admin';
|
|
647
|
-
*
|
|
648
|
-
* const MyComponent = () => {
|
|
649
|
-
* const { toggleNotification } = useNotification();
|
|
650
|
-
*
|
|
651
|
-
* return <button onClick={() => toggleNotification({ message: 'Hello world!' })}>Click me</button>;
|
|
652
|
-
*/
|
|
653
|
-
const useNotification = () => React.useContext(NotificationsContext);
|
|
654
|
-
|
|
655
|
-
function getPrefixedId(message, callback) {
|
|
656
|
-
const prefixedMessage = `apiError.${message}`;
|
|
657
|
-
if (typeof callback === "function") {
|
|
658
|
-
return callback(prefixedMessage);
|
|
659
|
-
}
|
|
660
|
-
return prefixedMessage;
|
|
661
|
-
}
|
|
662
|
-
|
|
663
|
-
function normalizeError(error, { name, intlMessagePrefixCallback }) {
|
|
664
|
-
const { message } = error;
|
|
665
|
-
const normalizedError = {
|
|
666
|
-
id: getPrefixedId(message, intlMessagePrefixCallback),
|
|
667
|
-
defaultMessage: message,
|
|
668
|
-
name: error.name ?? name,
|
|
669
|
-
values: {}
|
|
670
|
-
};
|
|
671
|
-
if ("path" in error) {
|
|
672
|
-
normalizedError.values = { path: error.path.join(".") };
|
|
673
|
-
}
|
|
674
|
-
return normalizedError;
|
|
675
|
-
}
|
|
676
|
-
const validateErrorIsYupValidationError = (err) => typeof err.details === "object" && err.details !== null && "errors" in err.details;
|
|
677
|
-
function normalizeAPIError(apiError, intlMessagePrefixCallback) {
|
|
678
|
-
const error = apiError.response?.data?.error;
|
|
679
|
-
if (error) {
|
|
680
|
-
if (validateErrorIsYupValidationError(error)) {
|
|
681
|
-
return {
|
|
682
|
-
name: error.name,
|
|
683
|
-
message: error?.message || null,
|
|
684
|
-
errors: error.details.errors.map(
|
|
685
|
-
(err) => normalizeError(err, { name: error.name, intlMessagePrefixCallback })
|
|
686
|
-
)
|
|
687
|
-
};
|
|
688
|
-
}
|
|
689
|
-
return normalizeError(error, { intlMessagePrefixCallback });
|
|
690
|
-
}
|
|
691
|
-
return null;
|
|
692
|
-
}
|
|
693
|
-
|
|
694
|
-
function getIn(obj, key, def, pathStartIndex = 0) {
|
|
695
|
-
const path = toPath(key);
|
|
696
|
-
while (obj && pathStartIndex < path.length) {
|
|
697
|
-
obj = obj[path[pathStartIndex++]];
|
|
698
|
-
}
|
|
699
|
-
if (pathStartIndex !== path.length && !obj) {
|
|
700
|
-
return def;
|
|
701
|
-
}
|
|
702
|
-
return obj === void 0 ? def : obj;
|
|
703
|
-
}
|
|
704
|
-
const isObject = (obj) => obj !== null && typeof obj === "object" && !Array.isArray(obj);
|
|
705
|
-
const isInteger = (obj) => String(Math.floor(Number(obj))) === obj;
|
|
706
|
-
function setIn(obj, path, value) {
|
|
707
|
-
const res = clone(obj);
|
|
708
|
-
let resVal = res;
|
|
709
|
-
let i = 0;
|
|
710
|
-
const pathArray = toPath(path);
|
|
711
|
-
for (; i < pathArray.length - 1; i++) {
|
|
712
|
-
const currentPath = pathArray[i];
|
|
713
|
-
const currentObj = getIn(obj, pathArray.slice(0, i + 1));
|
|
714
|
-
if (currentObj && (isObject(currentObj) || Array.isArray(currentObj))) {
|
|
715
|
-
resVal = resVal[currentPath] = clone(currentObj);
|
|
716
|
-
} else {
|
|
717
|
-
const nextPath = pathArray[i + 1];
|
|
718
|
-
resVal = resVal[currentPath] = isInteger(nextPath) && Number(nextPath) >= 0 ? [] : {};
|
|
719
|
-
}
|
|
720
|
-
}
|
|
721
|
-
if ((i === 0 ? obj : resVal)[pathArray[i]] === value) {
|
|
722
|
-
return obj;
|
|
723
|
-
}
|
|
724
|
-
if (value === void 0) {
|
|
725
|
-
delete resVal[pathArray[i]];
|
|
726
|
-
} else {
|
|
727
|
-
resVal[pathArray[i]] = value;
|
|
728
|
-
}
|
|
729
|
-
if (i === 0 && value === void 0) {
|
|
730
|
-
delete res[pathArray[i]];
|
|
731
|
-
}
|
|
732
|
-
return res;
|
|
733
|
-
}
|
|
734
|
-
|
|
735
|
-
function useAPIErrorHandler(intlMessagePrefixCallback) {
|
|
736
|
-
const { formatMessage } = useIntl();
|
|
737
|
-
const formatError = React.useCallback(
|
|
738
|
-
(error) => {
|
|
739
|
-
try {
|
|
740
|
-
const formattedErr = formatAPIError(error, { intlMessagePrefixCallback, formatMessage });
|
|
741
|
-
if (!formattedErr) {
|
|
742
|
-
return formatFetchError(error, { intlMessagePrefixCallback, formatMessage });
|
|
743
|
-
}
|
|
744
|
-
return formattedErr;
|
|
745
|
-
} catch (_) {
|
|
746
|
-
throw new Error("formatAPIError: Unknown error:", error);
|
|
747
|
-
}
|
|
748
|
-
},
|
|
749
|
-
[formatMessage, intlMessagePrefixCallback]
|
|
750
|
-
);
|
|
751
|
-
return {
|
|
752
|
-
/**
|
|
753
|
-
* @alpha
|
|
754
|
-
* Convert ValidationErrors from the API into an object that can be used by forms.
|
|
755
|
-
*/
|
|
756
|
-
_unstableFormatValidationErrors: React.useCallback(
|
|
757
|
-
(error) => {
|
|
758
|
-
if (typeof error.details === "object" && error.details !== null) {
|
|
759
|
-
if ("errors" in error.details && Array.isArray(error.details.errors)) {
|
|
760
|
-
const validationErrors = error.details.errors;
|
|
761
|
-
return validationErrors.reduce((acc, err) => {
|
|
762
|
-
const { path, message } = err;
|
|
763
|
-
return setIn(acc, path.join("."), message);
|
|
764
|
-
}, {});
|
|
765
|
-
} else {
|
|
766
|
-
const details = error.details;
|
|
767
|
-
return Object.keys(details).reduce((acc, key) => {
|
|
768
|
-
const messages = details[key];
|
|
769
|
-
return {
|
|
770
|
-
...acc,
|
|
771
|
-
[key]: messages.join(", ")
|
|
772
|
-
};
|
|
773
|
-
}, {});
|
|
774
|
-
}
|
|
775
|
-
} else {
|
|
776
|
-
return {};
|
|
777
|
-
}
|
|
778
|
-
},
|
|
779
|
-
[]
|
|
780
|
-
),
|
|
781
|
-
/**
|
|
782
|
-
* @alpha
|
|
783
|
-
* This handles the errors given from `redux-toolkit`'s axios based baseQuery function.
|
|
784
|
-
*/
|
|
785
|
-
_unstableFormatAPIError: React.useCallback(
|
|
786
|
-
(error) => {
|
|
787
|
-
const err = {
|
|
788
|
-
response: {
|
|
789
|
-
data: {
|
|
790
|
-
error
|
|
791
|
-
}
|
|
792
|
-
}
|
|
793
|
-
};
|
|
794
|
-
if (!error.message) {
|
|
795
|
-
return "Unknown error occured.";
|
|
796
|
-
}
|
|
797
|
-
return formatError(err);
|
|
798
|
-
},
|
|
799
|
-
[formatError]
|
|
800
|
-
),
|
|
801
|
-
formatAPIError: formatError
|
|
802
|
-
};
|
|
803
|
-
}
|
|
804
|
-
function formatFetchError(error, { intlMessagePrefixCallback, formatMessage }) {
|
|
805
|
-
const { code, message } = error;
|
|
806
|
-
return formatMessage(
|
|
807
|
-
{
|
|
808
|
-
id: getPrefixedId(message, intlMessagePrefixCallback),
|
|
809
|
-
defaultMessage: message
|
|
810
|
-
},
|
|
811
|
-
{
|
|
812
|
-
code
|
|
813
|
-
}
|
|
814
|
-
);
|
|
815
|
-
}
|
|
816
|
-
function formatAPIError(error, { formatMessage, intlMessagePrefixCallback }) {
|
|
817
|
-
if (!formatMessage) {
|
|
818
|
-
throw new Error("The formatMessage callback is a mandatory argument.");
|
|
819
|
-
}
|
|
820
|
-
const normalizedError = normalizeAPIError(error, intlMessagePrefixCallback);
|
|
821
|
-
if (!normalizedError) {
|
|
822
|
-
return null;
|
|
823
|
-
}
|
|
824
|
-
if ("message" in normalizedError && normalizedError.message !== null) {
|
|
825
|
-
return normalizedError.message;
|
|
826
|
-
}
|
|
827
|
-
if ("errors" in normalizedError) {
|
|
828
|
-
return normalizedError.errors.map(({ id, defaultMessage, values }) => formatMessage({ id, defaultMessage }, values)).join("\n");
|
|
829
|
-
}
|
|
830
|
-
return formatMessage(normalizedError);
|
|
831
|
-
}
|
|
832
|
-
|
|
833
|
-
const PageMain = ({ children, ...restProps }) => {
|
|
834
|
-
return /* @__PURE__ */ jsx(Main, { ...restProps, children });
|
|
835
|
-
};
|
|
836
|
-
const Loading = ({ children = "Loading content." }) => {
|
|
837
|
-
return /* @__PURE__ */ jsx(PageMain, { height: "100vh", "aria-busy": true, children: /* @__PURE__ */ jsx(Flex, { alignItems: "center", height: "100%", justifyContent: "center", children: /* @__PURE__ */ jsx(Loader, { children }) }) });
|
|
838
|
-
};
|
|
839
|
-
const Error$1 = (props) => {
|
|
840
|
-
const { formatMessage } = useIntl();
|
|
841
|
-
return /* @__PURE__ */ jsx(PageMain, { height: "100%", children: /* @__PURE__ */ jsx(Flex, { alignItems: "center", height: "100%", justifyContent: "center", children: /* @__PURE__ */ jsx(
|
|
842
|
-
EmptyStateLayout,
|
|
843
|
-
{
|
|
844
|
-
icon: /* @__PURE__ */ jsx(WarningCircle, { width: "16rem" }),
|
|
845
|
-
content: formatMessage({
|
|
846
|
-
id: "anErrorOccurred",
|
|
847
|
-
defaultMessage: "Woops! Something went wrong. Please, try again."
|
|
848
|
-
}),
|
|
849
|
-
...props
|
|
850
|
-
}
|
|
851
|
-
) }) });
|
|
852
|
-
};
|
|
853
|
-
const NoPermissions = (props) => {
|
|
854
|
-
const { formatMessage } = useIntl();
|
|
855
|
-
return /* @__PURE__ */ jsx(PageMain, { height: "100%", children: /* @__PURE__ */ jsx(Flex, { alignItems: "center", height: "100%", justifyContent: "center", children: /* @__PURE__ */ jsx(Box, { minWidth: "50%", children: /* @__PURE__ */ jsx(
|
|
856
|
-
EmptyStateLayout,
|
|
857
|
-
{
|
|
858
|
-
icon: /* @__PURE__ */ jsx(EmptyPermissions, { width: "16rem" }),
|
|
859
|
-
content: formatMessage({
|
|
860
|
-
id: "app.components.EmptyStateLayout.content-permissions",
|
|
861
|
-
defaultMessage: "You don't have the permissions to access that content"
|
|
862
|
-
}),
|
|
863
|
-
...props
|
|
864
|
-
}
|
|
865
|
-
) }) }) });
|
|
866
|
-
};
|
|
867
|
-
const NoData = (props) => {
|
|
868
|
-
const { formatMessage } = useIntl();
|
|
869
|
-
return /* @__PURE__ */ jsx(PageMain, { height: "100%", background: "neutral100", children: /* @__PURE__ */ jsx(Flex, { alignItems: "center", height: "100%", width: "100%", justifyContent: "center", children: /* @__PURE__ */ jsx(Box, { minWidth: "50%", children: /* @__PURE__ */ jsx(
|
|
870
|
-
EmptyStateLayout,
|
|
871
|
-
{
|
|
872
|
-
icon: /* @__PURE__ */ jsx(EmptyDocuments, { width: "16rem" }),
|
|
873
|
-
action: props.action,
|
|
874
|
-
content: formatMessage({
|
|
875
|
-
id: "app.components.EmptyStateLayout.content-document",
|
|
876
|
-
defaultMessage: "No content found"
|
|
877
|
-
}),
|
|
878
|
-
...props
|
|
879
|
-
}
|
|
880
|
-
) }) }) });
|
|
881
|
-
};
|
|
882
|
-
const Protect = ({ permissions = [], children }) => {
|
|
883
|
-
const userPermissions = useAuth("Protect", (state) => state.permissions);
|
|
884
|
-
const { toggleNotification } = useNotification();
|
|
885
|
-
const { _unstableFormatAPIError: formatAPIError } = useAPIErrorHandler();
|
|
886
|
-
const matchingPermissions = userPermissions.filter(
|
|
887
|
-
(permission) => permissions.findIndex(
|
|
888
|
-
(perm) => perm.action === permission.action && perm.subject === permission.subject
|
|
889
|
-
) >= 0
|
|
890
|
-
);
|
|
891
|
-
const shouldCheckConditions = matchingPermissions.some(
|
|
892
|
-
(perm) => Array.isArray(perm.conditions) && perm.conditions.length > 0
|
|
893
|
-
);
|
|
894
|
-
const { isLoading, error, data } = useCheckPermissionsQuery(
|
|
895
|
-
{
|
|
896
|
-
permissions: matchingPermissions.map((perm) => ({
|
|
897
|
-
action: perm.action,
|
|
898
|
-
subject: perm.subject
|
|
899
|
-
}))
|
|
900
|
-
},
|
|
901
|
-
{
|
|
902
|
-
skip: !shouldCheckConditions
|
|
903
|
-
}
|
|
904
|
-
);
|
|
905
|
-
React.useEffect(() => {
|
|
906
|
-
if (error) {
|
|
907
|
-
toggleNotification({
|
|
908
|
-
type: "danger",
|
|
909
|
-
message: formatAPIError(error)
|
|
910
|
-
});
|
|
911
|
-
}
|
|
912
|
-
}, [error, formatAPIError, toggleNotification]);
|
|
913
|
-
if (isLoading) {
|
|
914
|
-
return /* @__PURE__ */ jsx(Loading, {});
|
|
915
|
-
}
|
|
916
|
-
if (error) {
|
|
917
|
-
return /* @__PURE__ */ jsx(Error$1, {});
|
|
918
|
-
}
|
|
919
|
-
const { data: permissionsData } = data || {};
|
|
920
|
-
const canAccess = shouldCheckConditions && permissionsData ? !permissionsData.includes(false) : matchingPermissions.length > 0;
|
|
921
|
-
if (!canAccess) {
|
|
922
|
-
return /* @__PURE__ */ jsx(NoPermissions, {});
|
|
923
|
-
}
|
|
924
|
-
return /* @__PURE__ */ jsx(Fragment, { children: typeof children === "function" ? children({ permissions: matchingPermissions }) : children });
|
|
925
|
-
};
|
|
926
|
-
const Title = ({ children: title }) => {
|
|
927
|
-
React.useEffect(() => {
|
|
928
|
-
document.title = `${title} | Strapi`;
|
|
929
|
-
}, [title]);
|
|
930
|
-
return null;
|
|
931
|
-
};
|
|
932
|
-
const Page = {
|
|
933
|
-
Error: Error$1,
|
|
934
|
-
Loading,
|
|
935
|
-
NoPermissions,
|
|
936
|
-
Protect,
|
|
937
|
-
NoData,
|
|
938
|
-
Main: PageMain,
|
|
939
|
-
Title
|
|
940
|
-
};
|
|
941
|
-
|
|
942
|
-
const once = (fn) => {
|
|
943
|
-
const func = fn;
|
|
944
|
-
let called = false;
|
|
945
|
-
if (typeof func !== "function") {
|
|
946
|
-
throw new TypeError(`once requires a function parameter`);
|
|
947
|
-
}
|
|
948
|
-
return (...args) => {
|
|
949
|
-
if (!called && process.env.NODE_ENV === "development") {
|
|
950
|
-
func(...args);
|
|
951
|
-
called = true;
|
|
952
|
-
}
|
|
953
|
-
};
|
|
954
|
-
};
|
|
955
|
-
|
|
956
|
-
const capitalise = (str) => str.charAt(0).toUpperCase() + str.slice(1);
|
|
957
|
-
|
|
958
|
-
const usePrev = (value) => {
|
|
959
|
-
const ref = useRef();
|
|
960
|
-
useEffect(() => {
|
|
961
|
-
ref.current = value;
|
|
962
|
-
}, [value]);
|
|
963
|
-
return ref.current;
|
|
964
|
-
};
|
|
965
|
-
|
|
966
|
-
const useRBAC = (permissionsToCheck = [], passedPermissions, rawQueryContext) => {
|
|
967
|
-
const isLoadingAuth = useAuth("useRBAC", (state) => state.isLoading);
|
|
968
|
-
const [isLoading, setIsLoading] = React.useState(true);
|
|
969
|
-
const [error, setError] = React.useState();
|
|
970
|
-
const [data, setData] = React.useState();
|
|
971
|
-
const warnOnce = React.useMemo(() => once(console.warn), []);
|
|
972
|
-
const actualPermissionsToCheck = React.useMemo(() => {
|
|
973
|
-
if (Array.isArray(permissionsToCheck)) {
|
|
974
|
-
return permissionsToCheck;
|
|
975
|
-
} else {
|
|
976
|
-
warnOnce(
|
|
977
|
-
"useRBAC: The first argument should be an array of permissions, not an object. This will be deprecated in the future."
|
|
978
|
-
);
|
|
979
|
-
return Object.values(permissionsToCheck).flat();
|
|
980
|
-
}
|
|
981
|
-
}, [permissionsToCheck, warnOnce]);
|
|
982
|
-
const defaultAllowedActions = React.useMemo(() => {
|
|
983
|
-
return actualPermissionsToCheck.reduce((acc, permission) => {
|
|
984
|
-
return {
|
|
985
|
-
...acc,
|
|
986
|
-
[getActionName(permission)]: false
|
|
987
|
-
};
|
|
988
|
-
}, {});
|
|
989
|
-
}, [actualPermissionsToCheck]);
|
|
990
|
-
const checkUserHasPermissions = useAuth("useRBAC", (state) => state.checkUserHasPermissions);
|
|
991
|
-
const permssionsChecked = usePrev(actualPermissionsToCheck);
|
|
992
|
-
const contextChecked = usePrev(rawQueryContext);
|
|
993
|
-
React.useEffect(() => {
|
|
994
|
-
if (!isEqual(permssionsChecked, actualPermissionsToCheck) || // TODO: also run this when the query context changes
|
|
995
|
-
contextChecked !== rawQueryContext) {
|
|
996
|
-
setIsLoading(true);
|
|
997
|
-
setData(void 0);
|
|
998
|
-
setError(void 0);
|
|
999
|
-
checkUserHasPermissions(actualPermissionsToCheck, passedPermissions, rawQueryContext).then((res) => {
|
|
1000
|
-
if (res) {
|
|
1001
|
-
setData(
|
|
1002
|
-
res.reduce((acc, permission) => {
|
|
1003
|
-
return {
|
|
1004
|
-
...acc,
|
|
1005
|
-
[getActionName(permission)]: true
|
|
1006
|
-
};
|
|
1007
|
-
}, {})
|
|
1008
|
-
);
|
|
1009
|
-
}
|
|
1010
|
-
}).catch((err) => {
|
|
1011
|
-
setError(err);
|
|
1012
|
-
}).finally(() => {
|
|
1013
|
-
setIsLoading(false);
|
|
1014
|
-
});
|
|
1015
|
-
}
|
|
1016
|
-
}, [
|
|
1017
|
-
actualPermissionsToCheck,
|
|
1018
|
-
checkUserHasPermissions,
|
|
1019
|
-
passedPermissions,
|
|
1020
|
-
permissionsToCheck,
|
|
1021
|
-
permssionsChecked,
|
|
1022
|
-
contextChecked,
|
|
1023
|
-
rawQueryContext
|
|
1024
|
-
]);
|
|
1025
|
-
const allowedActions = Object.entries({
|
|
1026
|
-
...defaultAllowedActions,
|
|
1027
|
-
...data
|
|
1028
|
-
}).reduce((acc, [name, allowed]) => {
|
|
1029
|
-
acc[`can${capitalise(name)}`] = allowed;
|
|
1030
|
-
return acc;
|
|
1031
|
-
}, {});
|
|
1032
|
-
return {
|
|
1033
|
-
allowedActions,
|
|
1034
|
-
permissions: actualPermissionsToCheck,
|
|
1035
|
-
isLoading: isLoading || isLoadingAuth,
|
|
1036
|
-
error
|
|
1037
|
-
};
|
|
1038
|
-
};
|
|
1039
|
-
const getActionName = (permission) => {
|
|
1040
|
-
const [action = ""] = permission.action.split(".").slice(-1);
|
|
1041
|
-
return action.split("-").map(capitalise).join("");
|
|
1042
|
-
};
|
|
1043
|
-
|
|
1044
|
-
const [AppInfoProvider, useAppInfo] = createContext("AppInfo", {});
|
|
1045
|
-
|
|
1046
|
-
const TrackingContext = React.createContext({
|
|
1047
|
-
uuid: false
|
|
1048
|
-
});
|
|
1049
|
-
const TrackingProvider = ({ children }) => {
|
|
1050
|
-
const token = useAuth("App", (state) => state.token);
|
|
1051
|
-
const { data: initData } = useInitQuery();
|
|
1052
|
-
const { uuid } = initData ?? {};
|
|
1053
|
-
const { data } = useTelemetryPropertiesQuery(void 0, {
|
|
1054
|
-
skip: !initData?.uuid || !token
|
|
1055
|
-
});
|
|
1056
|
-
React.useEffect(() => {
|
|
1057
|
-
if (uuid && data) {
|
|
1058
|
-
const event = "didInitializeAdministration";
|
|
1059
|
-
try {
|
|
1060
|
-
fetch("https://analytics.strapi.io/api/v2/track", {
|
|
1061
|
-
method: "POST",
|
|
1062
|
-
body: JSON.stringify({
|
|
1063
|
-
// This event is anonymous
|
|
1064
|
-
event,
|
|
1065
|
-
userId: "",
|
|
1066
|
-
eventPropeties: {},
|
|
1067
|
-
groupProperties: { ...data, projectId: uuid }
|
|
1068
|
-
}),
|
|
1069
|
-
headers: {
|
|
1070
|
-
"Content-Type": "application/json",
|
|
1071
|
-
"X-Strapi-Event": event
|
|
1072
|
-
}
|
|
1073
|
-
});
|
|
1074
|
-
} catch {
|
|
1075
|
-
}
|
|
1076
|
-
}
|
|
1077
|
-
}, [data, uuid]);
|
|
1078
|
-
const value = React.useMemo(
|
|
1079
|
-
() => ({
|
|
1080
|
-
uuid,
|
|
1081
|
-
telemetryProperties: data
|
|
1082
|
-
}),
|
|
1083
|
-
[uuid, data]
|
|
1084
|
-
);
|
|
1085
|
-
return /* @__PURE__ */ jsx(TrackingContext.Provider, { value, children });
|
|
1086
|
-
};
|
|
1087
|
-
const useTracking = () => {
|
|
1088
|
-
const { uuid, telemetryProperties } = React.useContext(TrackingContext);
|
|
1089
|
-
const userId = useAppInfo("useTracking", (state) => state.userId);
|
|
1090
|
-
const trackUsage = React.useCallback(
|
|
1091
|
-
async (event, properties) => {
|
|
1092
|
-
try {
|
|
1093
|
-
if (uuid && !window.strapi.telemetryDisabled) {
|
|
1094
|
-
const res = await axios.post(
|
|
1095
|
-
"https://analytics.strapi.io/api/v2/track",
|
|
1096
|
-
{
|
|
1097
|
-
event,
|
|
1098
|
-
userId,
|
|
1099
|
-
eventProperties: { ...properties },
|
|
1100
|
-
userProperties: {},
|
|
1101
|
-
groupProperties: {
|
|
1102
|
-
...telemetryProperties,
|
|
1103
|
-
projectId: uuid,
|
|
1104
|
-
projectType: window.strapi.projectType
|
|
1105
|
-
}
|
|
1106
|
-
},
|
|
1107
|
-
{
|
|
1108
|
-
headers: {
|
|
1109
|
-
"Content-Type": "application/json",
|
|
1110
|
-
"X-Strapi-Event": event
|
|
1111
|
-
}
|
|
1112
|
-
}
|
|
1113
|
-
);
|
|
1114
|
-
return res;
|
|
1115
|
-
}
|
|
1116
|
-
} catch (err) {
|
|
1117
|
-
}
|
|
1118
|
-
return null;
|
|
1119
|
-
},
|
|
1120
|
-
[telemetryProperties, userId, uuid]
|
|
1121
|
-
);
|
|
1122
|
-
return { trackUsage };
|
|
1123
|
-
};
|
|
1124
|
-
|
|
1125
|
-
const [ConfigurationContextProvider, useConfiguration] = createContext$1("ConfigurationContext");
|
|
1126
|
-
const ConfigurationProvider = ({
|
|
1127
|
-
children,
|
|
1128
|
-
defaultAuthLogo,
|
|
1129
|
-
defaultMenuLogo,
|
|
1130
|
-
showReleaseNotification = false,
|
|
1131
|
-
showTutorials = false
|
|
1132
|
-
}) => {
|
|
1133
|
-
const { trackUsage } = useTracking();
|
|
1134
|
-
const { formatMessage } = useIntl();
|
|
1135
|
-
const { toggleNotification } = useNotification();
|
|
1136
|
-
const { _unstableFormatAPIError: formatAPIError } = useAPIErrorHandler();
|
|
1137
|
-
const permissions = useTypedSelector(
|
|
1138
|
-
(state) => state.admin_app.permissions.settings?.["project-settings"]
|
|
1139
|
-
);
|
|
1140
|
-
const token = useAuth("ConfigurationProvider", (state) => state.token);
|
|
1141
|
-
const {
|
|
1142
|
-
allowedActions: { canRead }
|
|
1143
|
-
} = useRBAC(permissions);
|
|
1144
|
-
const {
|
|
1145
|
-
data: { authLogo: customAuthLogo, menuLogo: customMenuLogo } = {},
|
|
1146
|
-
error,
|
|
1147
|
-
isLoading
|
|
1148
|
-
} = useInitQuery();
|
|
1149
|
-
React.useEffect(() => {
|
|
1150
|
-
if (error) {
|
|
1151
|
-
toggleNotification({
|
|
1152
|
-
type: "danger",
|
|
1153
|
-
message: formatMessage({ id: "app.containers.App.notification.error.init" })
|
|
1154
|
-
});
|
|
1155
|
-
}
|
|
1156
|
-
}, [error, formatMessage, toggleNotification]);
|
|
1157
|
-
const { data, isSuccess } = useProjectSettingsQuery(void 0, {
|
|
1158
|
-
skip: !token || !canRead
|
|
1159
|
-
});
|
|
1160
|
-
const [updateProjectSettingsMutation] = useUpdateProjectSettingsMutation();
|
|
1161
|
-
const updateProjectSettings = React.useCallback(
|
|
1162
|
-
async (body) => {
|
|
1163
|
-
const formData = new FormData();
|
|
1164
|
-
Object.entries(body).forEach(([key, value]) => {
|
|
1165
|
-
if (value?.rawFile) {
|
|
1166
|
-
formData.append(key, value.rawFile);
|
|
1167
|
-
} else if (value === null) {
|
|
1168
|
-
formData.append(key, JSON.stringify(value));
|
|
1169
|
-
}
|
|
1170
|
-
});
|
|
1171
|
-
const res = await updateProjectSettingsMutation(formData);
|
|
1172
|
-
if ("data" in res) {
|
|
1173
|
-
const updatedMenuLogo = !!res.data.menuLogo && !!body.menuLogo?.rawFile;
|
|
1174
|
-
const updatedAuthLogo = !!res.data.authLogo && !!body.authLogo?.rawFile;
|
|
1175
|
-
if (updatedMenuLogo) {
|
|
1176
|
-
trackUsage("didChangeLogo", {
|
|
1177
|
-
logo: "menu"
|
|
1178
|
-
});
|
|
1179
|
-
}
|
|
1180
|
-
if (updatedAuthLogo) {
|
|
1181
|
-
trackUsage("didChangeLogo", {
|
|
1182
|
-
logo: "auth"
|
|
1183
|
-
});
|
|
1184
|
-
}
|
|
1185
|
-
toggleNotification({
|
|
1186
|
-
type: "success",
|
|
1187
|
-
message: formatMessage({ id: "app", defaultMessage: "Saved" })
|
|
1188
|
-
});
|
|
1189
|
-
} else {
|
|
1190
|
-
toggleNotification({
|
|
1191
|
-
type: "danger",
|
|
1192
|
-
message: formatAPIError(res.error)
|
|
1193
|
-
});
|
|
1194
|
-
}
|
|
1195
|
-
},
|
|
1196
|
-
[formatAPIError, formatMessage, toggleNotification, trackUsage, updateProjectSettingsMutation]
|
|
1197
|
-
);
|
|
1198
|
-
if (isLoading) {
|
|
1199
|
-
return /* @__PURE__ */ jsx(Page.Loading, {});
|
|
1200
|
-
}
|
|
1201
|
-
return /* @__PURE__ */ jsx(
|
|
1202
|
-
ConfigurationContextProvider,
|
|
1203
|
-
{
|
|
1204
|
-
showReleaseNotification,
|
|
1205
|
-
showTutorials,
|
|
1206
|
-
logos: {
|
|
1207
|
-
menu: {
|
|
1208
|
-
custom: isSuccess ? data?.menuLogo : {
|
|
1209
|
-
url: customMenuLogo ?? ""
|
|
1210
|
-
},
|
|
1211
|
-
default: defaultMenuLogo
|
|
1212
|
-
},
|
|
1213
|
-
auth: {
|
|
1214
|
-
custom: isSuccess ? data?.authLogo : {
|
|
1215
|
-
url: customAuthLogo ?? ""
|
|
1216
|
-
},
|
|
1217
|
-
default: defaultAuthLogo
|
|
1218
|
-
}
|
|
1219
|
-
},
|
|
1220
|
-
updateProjectSettings,
|
|
1221
|
-
children
|
|
1222
|
-
}
|
|
1223
|
-
);
|
|
1224
|
-
};
|
|
1225
|
-
|
|
1226
|
-
const GUIDED_TOUR_COMPLETED_STEPS = "GUIDED_TOUR_COMPLETED_STEPS";
|
|
1227
|
-
const GUIDED_TOUR_CURRENT_STEP = "GUIDED_TOUR_CURRENT_STEP";
|
|
1228
|
-
const GUIDED_TOUR_SKIPPED = "GUIDED_TOUR_SKIPPED";
|
|
1229
|
-
const [GuidedTourProviderImpl, useGuidedTour] = createContext("GuidedTour");
|
|
1230
|
-
const GuidedTourProvider = ({ children }) => {
|
|
1231
|
-
const [{ currentStep, guidedTourState, isGuidedTourVisible, isSkipped }, dispatch] = React.useReducer(reducer, initialState, initialiseState);
|
|
1232
|
-
const setCurrentStep = (step) => {
|
|
1233
|
-
if (step !== null) {
|
|
1234
|
-
const isStepAlreadyDone = get(guidedTourState, step);
|
|
1235
|
-
const [sectionName, stepName] = step.split(".");
|
|
1236
|
-
const sectionArray = Object.entries(guidedTourState[sectionName]);
|
|
1237
|
-
const currentStepIndex = sectionArray.findIndex(([key]) => key === stepName);
|
|
1238
|
-
const previousSteps = sectionArray.slice(0, currentStepIndex);
|
|
1239
|
-
const isStepToShow = previousSteps.every(([, sectionValue]) => sectionValue);
|
|
1240
|
-
if (isStepAlreadyDone || isSkipped || !isStepToShow) {
|
|
1241
|
-
return null;
|
|
1242
|
-
}
|
|
1243
|
-
}
|
|
1244
|
-
window.localStorage.setItem(GUIDED_TOUR_CURRENT_STEP, JSON.stringify(null));
|
|
1245
|
-
return dispatch({
|
|
1246
|
-
type: "SET_CURRENT_STEP",
|
|
1247
|
-
step
|
|
1248
|
-
});
|
|
1249
|
-
};
|
|
1250
|
-
const setGuidedTourVisibility = (value) => {
|
|
1251
|
-
dispatch({
|
|
1252
|
-
type: "SET_GUIDED_TOUR_VISIBILITY",
|
|
1253
|
-
value
|
|
1254
|
-
});
|
|
1255
|
-
};
|
|
1256
|
-
const setStepState = (currentStep2, value) => {
|
|
1257
|
-
addCompletedStep(currentStep2);
|
|
1258
|
-
dispatch({
|
|
1259
|
-
type: "SET_STEP_STATE",
|
|
1260
|
-
currentStep: currentStep2,
|
|
1261
|
-
value
|
|
1262
|
-
});
|
|
1263
|
-
};
|
|
1264
|
-
const startSection = (sectionName) => {
|
|
1265
|
-
const sectionSteps = guidedTourState[sectionName];
|
|
1266
|
-
if (sectionSteps) {
|
|
1267
|
-
const guidedTourArray = Object.entries(guidedTourState);
|
|
1268
|
-
const currentSectionIndex = guidedTourArray.findIndex(([key]) => key === sectionName);
|
|
1269
|
-
const previousSections = guidedTourArray.slice(0, currentSectionIndex);
|
|
1270
|
-
const isSectionToShow = previousSections.every(
|
|
1271
|
-
([, sectionValue]) => Object.values(sectionValue).every(Boolean)
|
|
1272
|
-
);
|
|
1273
|
-
const [firstStep] = Object.keys(sectionSteps);
|
|
1274
|
-
const isFirstStepDone = sectionSteps[firstStep];
|
|
1275
|
-
if (isSectionToShow && !currentStep && !isFirstStepDone) {
|
|
1276
|
-
setCurrentStep(`${sectionName}.${firstStep}`);
|
|
1277
|
-
}
|
|
1278
|
-
}
|
|
1279
|
-
};
|
|
1280
|
-
const setSkipped = (value) => {
|
|
1281
|
-
window.localStorage.setItem(GUIDED_TOUR_SKIPPED, JSON.stringify(value));
|
|
1282
|
-
dispatch({
|
|
1283
|
-
type: "SET_SKIPPED",
|
|
1284
|
-
value
|
|
1285
|
-
});
|
|
1286
|
-
};
|
|
1287
|
-
return /* @__PURE__ */ jsx(
|
|
1288
|
-
GuidedTourProviderImpl,
|
|
1289
|
-
{
|
|
1290
|
-
guidedTourState,
|
|
1291
|
-
currentStep,
|
|
1292
|
-
setCurrentStep,
|
|
1293
|
-
setGuidedTourVisibility,
|
|
1294
|
-
setSkipped,
|
|
1295
|
-
setStepState,
|
|
1296
|
-
startSection,
|
|
1297
|
-
isGuidedTourVisible,
|
|
1298
|
-
isSkipped,
|
|
1299
|
-
children
|
|
1300
|
-
}
|
|
1301
|
-
);
|
|
1302
|
-
};
|
|
1303
|
-
const initialState = {
|
|
1304
|
-
currentStep: null,
|
|
1305
|
-
guidedTourState: {
|
|
1306
|
-
contentTypeBuilder: {
|
|
1307
|
-
create: false,
|
|
1308
|
-
success: false
|
|
1309
|
-
},
|
|
1310
|
-
contentManager: {
|
|
1311
|
-
create: false,
|
|
1312
|
-
success: false
|
|
1313
|
-
},
|
|
1314
|
-
apiTokens: {
|
|
1315
|
-
create: false,
|
|
1316
|
-
success: false
|
|
1317
|
-
}
|
|
1318
|
-
},
|
|
1319
|
-
isGuidedTourVisible: false,
|
|
1320
|
-
isSkipped: false
|
|
1321
|
-
};
|
|
1322
|
-
const reducer = (state = initialState, action) => produce(state, (draftState) => {
|
|
1323
|
-
switch (action.type) {
|
|
1324
|
-
case "SET_CURRENT_STEP": {
|
|
1325
|
-
draftState.currentStep = action.step;
|
|
1326
|
-
break;
|
|
1327
|
-
}
|
|
1328
|
-
case "SET_STEP_STATE": {
|
|
1329
|
-
const [section, step] = action.currentStep.split(".");
|
|
1330
|
-
draftState.guidedTourState[section][step] = action.value;
|
|
1331
|
-
break;
|
|
1332
|
-
}
|
|
1333
|
-
case "SET_SKIPPED": {
|
|
1334
|
-
draftState.isSkipped = action.value;
|
|
1335
|
-
break;
|
|
1336
|
-
}
|
|
1337
|
-
case "SET_GUIDED_TOUR_VISIBILITY": {
|
|
1338
|
-
draftState.isGuidedTourVisible = action.value;
|
|
1339
|
-
break;
|
|
1340
|
-
}
|
|
1341
|
-
default: {
|
|
1342
|
-
return draftState;
|
|
1343
|
-
}
|
|
1344
|
-
}
|
|
1345
|
-
});
|
|
1346
|
-
const initialiseState = (initialState2) => {
|
|
1347
|
-
const copyInitialState = { ...initialState2 };
|
|
1348
|
-
const guidedTourLocaleStorage = JSON.parse(
|
|
1349
|
-
window.localStorage.getItem(GUIDED_TOUR_COMPLETED_STEPS) ?? "[]"
|
|
1350
|
-
);
|
|
1351
|
-
const currentStepLocaleStorage = JSON.parse(
|
|
1352
|
-
window.localStorage.getItem(GUIDED_TOUR_CURRENT_STEP) ?? "null"
|
|
1353
|
-
);
|
|
1354
|
-
const skippedLocaleStorage = JSON.parse(
|
|
1355
|
-
window.localStorage.getItem(GUIDED_TOUR_SKIPPED) ?? "null"
|
|
1356
|
-
);
|
|
1357
|
-
if (Array.isArray(guidedTourLocaleStorage)) {
|
|
1358
|
-
guidedTourLocaleStorage.forEach((step) => {
|
|
1359
|
-
const [sectionName, stepName] = step.split(".");
|
|
1360
|
-
set(copyInitialState, ["guidedTourState", sectionName, stepName], true);
|
|
1361
|
-
});
|
|
1362
|
-
}
|
|
1363
|
-
if (currentStepLocaleStorage) {
|
|
1364
|
-
const [sectionName, stepName] = currentStepLocaleStorage.split(".");
|
|
1365
|
-
set(copyInitialState, ["guidedTourState", sectionName, stepName], true);
|
|
1366
|
-
addCompletedStep(currentStepLocaleStorage);
|
|
1367
|
-
window.localStorage.setItem(GUIDED_TOUR_CURRENT_STEP, JSON.stringify(null));
|
|
1368
|
-
}
|
|
1369
|
-
if (skippedLocaleStorage !== null) {
|
|
1370
|
-
set(copyInitialState, "isSkipped", skippedLocaleStorage);
|
|
1371
|
-
}
|
|
1372
|
-
return copyInitialState;
|
|
1373
|
-
};
|
|
1374
|
-
const addCompletedStep = (completedStep) => {
|
|
1375
|
-
const currentSteps = JSON.parse(window.localStorage.getItem(GUIDED_TOUR_COMPLETED_STEPS) ?? "[]");
|
|
1376
|
-
if (!Array.isArray(currentSteps)) {
|
|
1377
|
-
return;
|
|
1378
|
-
}
|
|
1379
|
-
const isAlreadyStored = currentSteps.includes(completedStep);
|
|
1380
|
-
if (isAlreadyStored) {
|
|
1381
|
-
return;
|
|
1382
|
-
}
|
|
1383
|
-
window.localStorage.setItem(
|
|
1384
|
-
GUIDED_TOUR_COMPLETED_STEPS,
|
|
1385
|
-
JSON.stringify([...currentSteps, completedStep])
|
|
1386
|
-
);
|
|
1387
|
-
};
|
|
1388
|
-
|
|
1389
|
-
const LanguageProvider = ({ children, messages }) => {
|
|
1390
|
-
const locale = useTypedSelector((state) => state.admin_app.language.locale);
|
|
1391
|
-
const appMessages = defaultsDeep(messages[locale], messages.en);
|
|
1392
|
-
return /* @__PURE__ */ jsx(IntlProvider, { locale, defaultLocale: "en", messages: appMessages, textComponent: "span", children });
|
|
1393
|
-
};
|
|
1394
|
-
|
|
1395
|
-
const Theme = ({ children, themes }) => {
|
|
1396
|
-
const { currentTheme } = useTypedSelector((state) => state.admin_app.theme);
|
|
1397
|
-
const [systemTheme, setSystemTheme] = React.useState();
|
|
1398
|
-
const { locale } = useIntl();
|
|
1399
|
-
const dispatch = useDispatch();
|
|
1400
|
-
React.useEffect(() => {
|
|
1401
|
-
const themeWatcher = window.matchMedia("(prefers-color-scheme: dark)");
|
|
1402
|
-
setSystemTheme(themeWatcher.matches ? "dark" : "light");
|
|
1403
|
-
const listener = (event) => {
|
|
1404
|
-
setSystemTheme(event.matches ? "dark" : "light");
|
|
1405
|
-
};
|
|
1406
|
-
themeWatcher.addEventListener("change", listener);
|
|
1407
|
-
return () => {
|
|
1408
|
-
themeWatcher.removeEventListener("change", listener);
|
|
1409
|
-
};
|
|
1410
|
-
}, []);
|
|
1411
|
-
React.useEffect(() => {
|
|
1412
|
-
dispatch(setAvailableThemes(Object.keys(themes)));
|
|
1413
|
-
}, [dispatch, themes]);
|
|
1414
|
-
const computedThemeName = currentTheme === "system" ? systemTheme : currentTheme;
|
|
1415
|
-
return /* @__PURE__ */ jsxs(
|
|
1416
|
-
DesignSystemProvider,
|
|
1417
|
-
{
|
|
1418
|
-
locale,
|
|
1419
|
-
theme: themes?.[computedThemeName || "light"],
|
|
1420
|
-
children: [
|
|
1421
|
-
children,
|
|
1422
|
-
/* @__PURE__ */ jsx(GlobalStyle, {})
|
|
1423
|
-
]
|
|
1424
|
-
}
|
|
1425
|
-
);
|
|
1426
|
-
};
|
|
1427
|
-
const GlobalStyle = createGlobalStyle`
|
|
1428
|
-
body {
|
|
1429
|
-
background: ${({ theme }) => theme.colors.neutral100};
|
|
1430
|
-
}
|
|
1431
|
-
`;
|
|
1432
|
-
|
|
1433
|
-
export { AppInfoProvider as A, getIn as B, ConfigurationProvider as C, setIn as D, setLocale as E, useForgotPasswordMutation as F, GuidedTourProvider as G, useGetRegistrationInfoQuery as H, useRegisterAdminMutation as I, useRegisterUserMutation as J, useResetPasswordMutation as K, LanguageProvider as L, reducer$1 as M, NotificationsProvider as N, logout as O, Page as P, THEME_LOCAL_STORAGE_KEY as Q, RBAC as R, StrapiAppProvider as S, Theme as T, getStoredToken as U, useTypedStore as V, ConfigurationContextProvider as W, useNotification as a, useTypedSelector as b, useTracking as c, useTypedDispatch as d, useAPIErrorHandler as e, useUpdateMeMutation as f, useIsSSOLockedQuery as g, createTypedSelector as h, useGetProviderOptionsQuery as i, useUpdateProviderOptionsMutation as j, useRBAC as k, useGetProvidersQuery as l, useGuidedTour as m, useQueryParams as n, login as o, useAppInfo as p, useStrapiApp as q, useConfiguration as r, setAppTheme as s, capitalise as t, useAuth as u, isObject as v, createContext as w, AuthProvider as x, TrackingProvider as y, LANGUAGE_LOCAL_STORAGE_KEY as z };
|
|
1434
|
-
//# sourceMappingURL=Theme-CTMU9Z8I.mjs.map
|