@strapi/admin 5.0.0-beta.4 → 5.0.0-beta.6
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/admin/{AdminSeatInfo-H5eNy3Gq.js → AdminSeatInfo-G2ipQTLk.js} +5 -14
- package/dist/admin/AdminSeatInfo-G2ipQTLk.js.map +1 -0
- package/dist/admin/{AdminSeatInfo-jPH1stsB.mjs → AdminSeatInfo-ZrJlIt8M.mjs} +7 -16
- package/dist/admin/AdminSeatInfo-ZrJlIt8M.mjs.map +1 -0
- package/dist/admin/{ApplicationInfoPage-QiVVy6LS.mjs → ApplicationInfoPage-TImAEuc3.mjs} +9 -18
- package/dist/admin/ApplicationInfoPage-TImAEuc3.mjs.map +1 -0
- package/dist/admin/{ApplicationInfoPage-leY1AEgo.js → ApplicationInfoPage-dc0ReC0D.js} +7 -16
- package/dist/admin/ApplicationInfoPage-dc0ReC0D.js.map +1 -0
- package/dist/admin/{AuthResponse-kdo9DYPT.js → AuthResponse-J1Y_hbtY.js} +19 -8
- package/dist/admin/AuthResponse-J1Y_hbtY.js.map +1 -0
- package/dist/admin/{AuthResponse-5G-7aJDM.mjs → AuthResponse-wfOnX6GO.mjs} +19 -5
- package/dist/admin/AuthResponse-wfOnX6GO.mjs.map +1 -0
- package/dist/admin/{AuthenticatedLayout-Aibt647F.js → AuthenticatedLayout-TNbTifIA.js} +156 -50
- package/dist/admin/AuthenticatedLayout-TNbTifIA.js.map +1 -0
- package/dist/admin/{AuthenticatedLayout-UPRVctuH.mjs → AuthenticatedLayout-eMLYKMgW.mjs} +158 -52
- package/dist/admin/AuthenticatedLayout-eMLYKMgW.mjs.map +1 -0
- package/dist/admin/{ContentBox-PbS25I_4.mjs → ContentBox-DjmNTcxv.mjs} +3 -3
- package/dist/admin/ContentBox-DjmNTcxv.mjs.map +1 -0
- package/dist/admin/{ContentBox-xqJCP2BC.js → ContentBox-Mzcpnn32.js} +3 -3
- package/dist/admin/ContentBox-Mzcpnn32.js.map +1 -0
- package/dist/admin/{CreateActionEE-TcGdWjIN.mjs → CreateActionEE-Qdz4UDPf.mjs} +6 -14
- package/dist/admin/CreateActionEE-Qdz4UDPf.mjs.map +1 -0
- package/dist/admin/{CreateActionEE-2DKYzbq_.js → CreateActionEE-_i5qXWEG.js} +3 -11
- package/dist/admin/CreateActionEE-_i5qXWEG.js.map +1 -0
- package/dist/admin/{CreatePage-EngKiM_9.js → CreatePage-03MgCK7Z.js} +5 -5
- package/dist/admin/{CreatePage-EngKiM_9.js.map → CreatePage-03MgCK7Z.js.map} +1 -1
- package/dist/admin/{CreatePage-dhyIsOBI.mjs → CreatePage-07P5-Zjt.mjs} +3 -3
- package/dist/admin/{CreatePage-dhyIsOBI.mjs.map → CreatePage-07P5-Zjt.mjs.map} +1 -1
- package/dist/admin/{CreatePage-h5o6e7Ls.js → CreatePage-f3faA3vG.js} +3 -3
- package/dist/admin/{CreatePage-h5o6e7Ls.js.map → CreatePage-f3faA3vG.js.map} +1 -1
- package/dist/admin/{CreatePage-S7eVTkzK.mjs → CreatePage-uTwt_c8J.mjs} +6 -6
- package/dist/admin/{CreatePage-S7eVTkzK.mjs.map → CreatePage-uTwt_c8J.mjs.map} +1 -1
- package/dist/admin/{CreateView-YBUhPBBg.mjs → CreateView-87aPv9QV.mjs} +3 -3
- package/dist/admin/{CreateView-YBUhPBBg.mjs.map → CreateView-87aPv9QV.mjs.map} +1 -1
- package/dist/admin/{CreateView-HQFmuEYU.mjs → CreateView-T8hLqvog.mjs} +3 -3
- package/dist/admin/{CreateView-HQFmuEYU.mjs.map → CreateView-T8hLqvog.mjs.map} +1 -1
- package/dist/admin/{CreateView-8qevpt9o.js → CreateView-UemGfFqI.js} +3 -3
- package/dist/admin/{CreateView-8qevpt9o.js.map → CreateView-UemGfFqI.js.map} +1 -1
- package/dist/admin/{CreateView-chaJt-l6.js → CreateView-o5-hvd4h.js} +3 -3
- package/dist/admin/{CreateView-chaJt-l6.js.map → CreateView-o5-hvd4h.js.map} +1 -1
- package/dist/admin/{EditPage-OcSrQNeJ.mjs → EditPage-F3yH0Fy6.mjs} +6 -6
- package/dist/admin/{EditPage-OcSrQNeJ.mjs.map → EditPage-F3yH0Fy6.mjs.map} +1 -1
- package/dist/admin/{EditPage-pk60xOuF.js → EditPage-Ly5MBiuB.js} +5 -5
- package/dist/admin/{EditPage-pk60xOuF.js.map → EditPage-Ly5MBiuB.js.map} +1 -1
- package/dist/admin/{EditPage-3zbE4Ls0.js → EditPage-UqMDbMvJ.js} +7 -7
- package/dist/admin/{EditPage-3zbE4Ls0.js.map → EditPage-UqMDbMvJ.js.map} +1 -1
- package/dist/admin/{EditPage-KxrcV7mh.mjs → EditPage-XSz7Wpt8.mjs} +8 -8
- package/dist/admin/{EditPage-KxrcV7mh.mjs.map → EditPage-XSz7Wpt8.mjs.map} +1 -1
- package/dist/admin/{EditPage-H9aQSaaH.js → EditPage-YqW1NIMp.js} +15 -28
- package/dist/admin/EditPage-YqW1NIMp.js.map +1 -0
- package/dist/admin/{EditPage-oenQhubv.mjs → EditPage-lyFePXWl.mjs} +18 -31
- package/dist/admin/EditPage-lyFePXWl.mjs.map +1 -0
- package/dist/admin/{EditView-BiqoDvKZ.js → EditView-bRFkRKAz.js} +4 -4
- package/dist/admin/{EditView-BiqoDvKZ.js.map → EditView-bRFkRKAz.js.map} +1 -1
- package/dist/admin/{EditView-dHW8NJN4.mjs → EditView-r0lx661I.mjs} +6 -6
- package/dist/admin/{EditView-dHW8NJN4.mjs.map → EditView-r0lx661I.mjs.map} +1 -1
- package/dist/admin/{EditViewPage-O9_heFiZ.mjs → EditViewPage-f5dHmqdT.mjs} +6 -6
- package/dist/admin/{EditViewPage-O9_heFiZ.mjs.map → EditViewPage-f5dHmqdT.mjs.map} +1 -1
- package/dist/admin/{EditViewPage-OMo0nfgm.js → EditViewPage-tAsn6QS9.js} +4 -4
- package/dist/admin/{EditViewPage-OMo0nfgm.js.map → EditViewPage-tAsn6QS9.js.map} +1 -1
- package/dist/admin/{EventsTable-Xh9FIU87.mjs → EventsTable-2C605_qQ.mjs} +2 -2
- package/dist/admin/{EventsTable-Xh9FIU87.mjs.map → EventsTable-2C605_qQ.mjs.map} +1 -1
- package/dist/admin/{EventsTable-1IsAibDQ.js → EventsTable-4h6LoAp-.js} +2 -2
- package/dist/admin/{EventsTable-1IsAibDQ.js.map → EventsTable-4h6LoAp-.js.map} +1 -1
- package/dist/admin/{HomePage-oNgvRlya.mjs → HomePage-4FySTCJU.mjs} +3 -3
- package/dist/admin/{HomePage-oNgvRlya.mjs.map → HomePage-4FySTCJU.mjs.map} +1 -1
- package/dist/admin/{HomePage-Xf5Ghz92.js → HomePage-UTnZwpp-.js} +36 -28
- package/dist/admin/HomePage-UTnZwpp-.js.map +1 -0
- package/dist/admin/{HomePage-OeCZ2DCC.js → HomePage-Uuww2J1B.js} +3 -3
- package/dist/admin/{HomePage-OeCZ2DCC.js.map → HomePage-Uuww2J1B.js.map} +1 -1
- package/dist/admin/{HomePage-D-bJ3jts.mjs → HomePage-ZF3T0k2r.mjs} +27 -19
- package/dist/admin/HomePage-ZF3T0k2r.mjs.map +1 -0
- package/dist/admin/{InstalledPluginsPage-s_PGIc3_.mjs → InstalledPluginsPage-eOXi3oTN.mjs} +4 -4
- package/dist/admin/{InstalledPluginsPage-s_PGIc3_.mjs.map → InstalledPluginsPage-eOXi3oTN.mjs.map} +1 -1
- package/dist/admin/{InstalledPluginsPage-ZIPyDrzh.js → InstalledPluginsPage-o43CGz2w.js} +3 -3
- package/dist/admin/{InstalledPluginsPage-ZIPyDrzh.js.map → InstalledPluginsPage-o43CGz2w.js.map} +1 -1
- package/dist/admin/{Layout-BuMuReXo.js → Layout-XxmAreH1.js} +11 -12
- package/dist/admin/Layout-XxmAreH1.js.map +1 -0
- package/dist/admin/{Layout-lSZESFtG.mjs → Layout-mnn4_IJp.mjs} +8 -9
- package/dist/admin/Layout-mnn4_IJp.mjs.map +1 -0
- package/dist/admin/{ListPage-fE2OLTTE.mjs → ListPage-5g8MtUEB.mjs} +5 -6
- package/dist/admin/ListPage-5g8MtUEB.mjs.map +1 -0
- package/dist/admin/{ListPage-6O-9Hx-B.js → ListPage-6Ukzm--I.js} +3 -3
- package/dist/admin/{ListPage-6O-9Hx-B.js.map → ListPage-6Ukzm--I.js.map} +1 -1
- package/dist/admin/{ListPage-xo4o9urf.mjs → ListPage-AFDAiR9X.mjs} +7 -7
- package/dist/admin/{ListPage-xo4o9urf.mjs.map → ListPage-AFDAiR9X.mjs.map} +1 -1
- package/dist/admin/{ListPage-a9qp7eE2.mjs → ListPage-Gj1OS6PX.mjs} +3 -3
- package/dist/admin/{ListPage-a9qp7eE2.mjs.map → ListPage-Gj1OS6PX.mjs.map} +1 -1
- package/dist/admin/{ListPage-vVa7B6wq.js → ListPage-NTxNcftS.js} +10 -11
- package/dist/admin/ListPage-NTxNcftS.js.map +1 -0
- package/dist/admin/{ListPage-6HUcvFyL.js → ListPage-Pi_dzfDr.js} +7 -7
- package/dist/admin/{ListPage-6HUcvFyL.js.map → ListPage-Pi_dzfDr.js.map} +1 -1
- package/dist/admin/{ListPage-brwMJDfa.js → ListPage-URtxfNJ4.js} +4 -5
- package/dist/admin/ListPage-URtxfNJ4.js.map +1 -0
- package/dist/admin/{ListPage-nGtmXc03.mjs → ListPage-eNkUD3v_.mjs} +12 -13
- package/dist/admin/ListPage-eNkUD3v_.mjs.map +1 -0
- package/dist/admin/{ListPage-A2MPjJxi.js → ListPage-hln8fKzE.js} +7 -8
- package/dist/admin/ListPage-hln8fKzE.js.map +1 -0
- package/dist/admin/{ListPage-1HhDIdVj.mjs → ListPage-kdjzZ2al.mjs} +7 -8
- package/dist/admin/ListPage-kdjzZ2al.mjs.map +1 -0
- package/dist/admin/{ListView-9exyBSMW.mjs → ListView-FBh2WTHx.mjs} +10 -10
- package/dist/admin/ListView-FBh2WTHx.mjs.map +1 -0
- package/dist/admin/{ListView-upndjhrB.js → ListView-f2wVT21J.js} +9 -9
- package/dist/admin/ListView-f2wVT21J.js.map +1 -0
- package/dist/admin/{ListView-VjkXS0Tf.js → ListView-pYVBJ4lg.js} +8 -8
- package/dist/admin/ListView-pYVBJ4lg.js.map +1 -0
- package/dist/admin/{ListView-2uHZ2TWm.mjs → ListView-uwPF62w6.mjs} +9 -9
- package/dist/admin/ListView-uwPF62w6.mjs.map +1 -0
- package/dist/admin/{Login-lAG7DHV7.js → Login-3rLFPliB.js} +4 -4
- package/dist/admin/{Login-lAG7DHV7.js.map → Login-3rLFPliB.js.map} +1 -1
- package/dist/admin/{Login-h0-a1KH5.mjs → Login-FSNzATl0.mjs} +4 -4
- package/dist/admin/{Login-h0-a1KH5.mjs.map → Login-FSNzATl0.mjs.map} +1 -1
- package/dist/admin/{MagicLinkEE-ApwIgTej.js → MagicLinkEE-bccsKKbJ.js} +3 -3
- package/dist/admin/{MagicLinkEE-ApwIgTej.js.map → MagicLinkEE-bccsKKbJ.js.map} +1 -1
- package/dist/admin/{MagicLinkEE-kjtWcwj6.mjs → MagicLinkEE-czAdOuTH.mjs} +3 -3
- package/dist/admin/{MagicLinkEE-kjtWcwj6.mjs.map → MagicLinkEE-czAdOuTH.mjs.map} +1 -1
- package/dist/admin/{MarketplacePage-mbqZ9JDl.mjs → MarketplacePage-kNQPkoZK.mjs} +54 -49
- package/dist/admin/MarketplacePage-kNQPkoZK.mjs.map +1 -0
- package/dist/admin/{MarketplacePage-hNQbTtRI.js → MarketplacePage-sSTqINSu.js} +55 -50
- package/dist/admin/MarketplacePage-sSTqINSu.js.map +1 -0
- package/dist/admin/{Ornaments-RhzFP9rf.js → Ornaments-UTssGzOw.js} +8 -8
- package/dist/admin/{Ornaments-RhzFP9rf.js.map → Ornaments-UTssGzOw.js.map} +1 -1
- package/dist/admin/{Ornaments-izqdN6fh.mjs → Ornaments-h_LCCr5P.mjs} +8 -8
- package/dist/admin/{Ornaments-izqdN6fh.mjs.map → Ornaments-h_LCCr5P.mjs.map} +1 -1
- package/dist/admin/{Permissions-v5pxfHqR.js → Permissions-NlSnXUKO.js} +19 -20
- package/dist/admin/Permissions-NlSnXUKO.js.map +1 -0
- package/dist/admin/{Permissions-RNmyxA77.mjs → Permissions-aU1eesjP.mjs} +20 -21
- package/dist/admin/Permissions-aU1eesjP.mjs.map +1 -0
- package/dist/admin/{PrivateRoute-KAM10GGM.js → PrivateRoute-nJgGpBXP.js} +2 -2
- package/dist/admin/{PrivateRoute-KAM10GGM.js.map → PrivateRoute-nJgGpBXP.js.map} +1 -1
- package/dist/admin/{PrivateRoute-wDu6Vo0N.mjs → PrivateRoute-zZ7p1pc9.mjs} +2 -2
- package/dist/admin/{PrivateRoute-wDu6Vo0N.mjs.map → PrivateRoute-zZ7p1pc9.mjs.map} +1 -1
- package/dist/admin/{ProfilePage-bDOjI8F-.mjs → ProfilePage-T2kC_KoM.mjs} +5 -5
- package/dist/admin/{ProfilePage-bDOjI8F-.mjs.map → ProfilePage-T2kC_KoM.mjs.map} +1 -1
- package/dist/admin/{ProfilePage-ivIjdblf.js → ProfilePage-jU98pa61.js} +4 -4
- package/dist/admin/{ProfilePage-ivIjdblf.js.map → ProfilePage-jU98pa61.js.map} +1 -1
- package/dist/admin/{PurchaseAuditLogs-tS_tVSGI.js → PurchaseAuditLogs-GreHFPSR.js} +4 -4
- package/dist/admin/PurchaseAuditLogs-GreHFPSR.js.map +1 -0
- package/dist/admin/{PurchaseAuditLogs-8_4PcW7P.mjs → PurchaseAuditLogs-_1tVWtNF.mjs} +5 -5
- package/dist/admin/PurchaseAuditLogs-_1tVWtNF.mjs.map +1 -0
- package/dist/admin/{PurchaseSingleSignOn-9SV6-fYs.js → PurchaseSingleSignOn-6t4xuNBd.js} +4 -4
- package/dist/admin/PurchaseSingleSignOn-6t4xuNBd.js.map +1 -0
- package/dist/admin/{PurchaseSingleSignOn--gblfVu6.mjs → PurchaseSingleSignOn-VUU-U4wi.mjs} +5 -5
- package/dist/admin/PurchaseSingleSignOn-VUU-U4wi.mjs.map +1 -0
- package/dist/admin/{SSOProviders-JTam8pNP.js → SSOProviders-FZwT7RmU.js} +3 -3
- package/dist/admin/{SSOProviders-JTam8pNP.js.map → SSOProviders-FZwT7RmU.js.map} +1 -1
- package/dist/admin/{SSOProviders-f1OPn1AH.mjs → SSOProviders-GcYDRAyn.mjs} +3 -3
- package/dist/admin/{SSOProviders-f1OPn1AH.mjs.map → SSOProviders-GcYDRAyn.mjs.map} +1 -1
- package/dist/admin/{SelectRoles-8cfbyMVr.mjs → SelectRoles--ys30CdN.mjs} +5 -5
- package/dist/admin/{SelectRoles-8cfbyMVr.mjs.map → SelectRoles--ys30CdN.mjs.map} +1 -1
- package/dist/admin/{SelectRoles-ZZPSrkZE.js → SelectRoles-EdE6yfsj.js} +5 -5
- package/dist/admin/{SelectRoles-ZZPSrkZE.js.map → SelectRoles-EdE6yfsj.js.map} +1 -1
- package/dist/admin/{SingleSignOnPage-Ots_q1kK.mjs → SingleSignOnPage-Y-brfYQ1.mjs} +8 -8
- package/dist/admin/SingleSignOnPage-Y-brfYQ1.mjs.map +1 -0
- package/dist/admin/{SingleSignOnPage-dKN-oVc8.js → SingleSignOnPage-nv121JbB.js} +6 -6
- package/dist/admin/SingleSignOnPage-nv121JbB.js.map +1 -0
- package/dist/admin/{Table-ILoLTYT2.mjs → Table--He5qeQG.mjs} +6 -7
- package/dist/admin/Table--He5qeQG.mjs.map +1 -0
- package/dist/admin/{Table-rh1Goj9B.js → Table-HXu3Nz4W.js} +6 -7
- package/dist/admin/Table-HXu3Nz4W.js.map +1 -0
- package/dist/admin/{TokenTypeSelect-oUpUNcrP.mjs → TokenTypeSelect-kgKThMAL.mjs} +9 -9
- package/dist/admin/TokenTypeSelect-kgKThMAL.mjs.map +1 -0
- package/dist/admin/{TokenTypeSelect-Bc6Gx5Og.js → TokenTypeSelect-yY2kwTyO.js} +7 -7
- package/dist/admin/TokenTypeSelect-yY2kwTyO.js.map +1 -0
- package/dist/admin/{UseCasePage-NYPLK0s5.js → UseCasePage-6_WRtTwv.js} +7 -7
- package/dist/admin/UseCasePage-6_WRtTwv.js.map +1 -0
- package/dist/admin/{UseCasePage-siicRv21.mjs → UseCasePage-bfP-fDoW.mjs} +8 -8
- package/dist/admin/UseCasePage-bfP-fDoW.mjs.map +1 -0
- package/dist/admin/{admin-DUKhYsmP.mjs → admin-5SXhE_nJ.mjs} +2 -2
- package/dist/admin/{admin-DUKhYsmP.mjs.map → admin-5SXhE_nJ.mjs.map} +1 -1
- package/dist/admin/{apiTokens-dBRuo1wd.mjs → apiTokens-bNRitXGF.mjs} +2 -2
- package/dist/admin/{apiTokens-dBRuo1wd.mjs.map → apiTokens-bNRitXGF.mjs.map} +1 -1
- package/dist/admin/{constants-wYcX8us0.js → constants-qdY4HMAg.js} +5 -6
- package/dist/admin/constants-qdY4HMAg.js.map +1 -0
- package/dist/admin/{constants-GoVT0wVo.mjs → constants-wnw4TGwG.mjs} +5 -6
- package/dist/admin/constants-wnw4TGwG.mjs.map +1 -0
- package/dist/admin/ee.mjs +1 -1
- package/dist/admin/{en-qvX6GTOD.mjs → en-D7rooMTs.mjs} +2 -1
- package/dist/admin/{en-qvX6GTOD.mjs.map → en-D7rooMTs.mjs.map} +1 -1
- package/dist/admin/{en-2FB7x9Rq.js → en-zVbLVH-h.js} +2 -1
- package/dist/admin/{en-2FB7x9Rq.js.map → en-zVbLVH-h.js.map} +1 -1
- package/dist/admin/{index-i37IN_fH.mjs → index-7fPlAzj6.mjs} +50 -54
- package/dist/admin/index-7fPlAzj6.mjs.map +1 -0
- package/dist/admin/{index-e8PHZx2A.js → index-FJLgZ-Wg.js} +61 -65
- package/dist/admin/index-FJLgZ-Wg.js.map +1 -0
- package/dist/admin/index.js +2 -2
- package/dist/admin/index.mjs +3 -3
- package/dist/admin/{rbac-sYT_mXH0.mjs → rbac-uVd0RAE5.mjs} +10 -10
- package/dist/admin/rbac-uVd0RAE5.mjs.map +1 -0
- package/dist/admin/{rbac-WZsv1761.js → rbac-xgYdpUSq.js} +8 -8
- package/dist/admin/rbac-xgYdpUSq.js.map +1 -0
- package/dist/admin/{selectors-3gRe5pAj.mjs → selectors-AvywwQRm.mjs} +2 -2
- package/dist/admin/{selectors-3gRe5pAj.mjs.map → selectors-AvywwQRm.mjs.map} +1 -1
- package/dist/admin/{selectors-CiTVxP8O.js → selectors-C62Wf5On.js} +2 -2
- package/dist/admin/{selectors-CiTVxP8O.js.map → selectors-C62Wf5On.js.map} +1 -1
- package/dist/admin/src/components/MainNav/NavBrand.d.ts +1 -0
- package/dist/admin/src/components/MainNav/NavLink.d.ts +22 -0
- package/dist/admin/src/features/BackButton.d.ts +1 -1
- package/dist/admin/src/pages/Settings/pages/Roles/components/CollapseLabel.d.ts +26 -25
- package/dist/admin/src/pages/Settings/pages/Roles/utils/constants.d.ts +3 -3
- package/dist/admin/test.js +3 -3
- package/dist/admin/test.js.map +1 -1
- package/dist/admin/test.mjs +4 -4
- package/dist/admin/test.mjs.map +1 -1
- package/dist/admin/{transferTokens-OLPKYcY_.mjs → transferTokens-ngan7vz6.mjs} +2 -2
- package/dist/admin/{transferTokens-OLPKYcY_.mjs.map → transferTokens-ngan7vz6.mjs.map} +1 -1
- package/dist/admin/{useAdminRoles-qJLjTITl.mjs → useAdminRoles-X4pwDHaW.mjs} +2 -2
- package/dist/admin/{useAdminRoles-qJLjTITl.mjs.map → useAdminRoles-X4pwDHaW.mjs.map} +1 -1
- package/dist/admin/{useAdminRoles-JOPnwG5K.js → useAdminRoles-yjN2uT_o.js} +2 -2
- package/dist/admin/{useAdminRoles-JOPnwG5K.js.map → useAdminRoles-yjN2uT_o.js.map} +1 -1
- package/dist/admin/{useLicenseLimitNotification-aTNbD3xK.mjs → useLicenseLimitNotification-T2LoOH4B.mjs} +3 -3
- package/dist/admin/{useLicenseLimitNotification-aTNbD3xK.mjs.map → useLicenseLimitNotification-T2LoOH4B.mjs.map} +1 -1
- package/dist/admin/{useLicenseLimitNotification-0UWeCY_u.js → useLicenseLimitNotification-wrxezW0C.js} +2 -2
- package/dist/admin/{useLicenseLimitNotification-0UWeCY_u.js.map → useLicenseLimitNotification-wrxezW0C.js.map} +1 -1
- package/dist/admin/{useLicenseLimits-F7K-YWAE.mjs → useLicenseLimits-fKc9uCtd.mjs} +2 -2
- package/dist/admin/{useLicenseLimits-F7K-YWAE.mjs.map → useLicenseLimits-fKc9uCtd.mjs.map} +1 -1
- package/dist/admin/{useWebhooks-7BXPSMHG.mjs → useWebhooks-8VWSFqNg.mjs} +2 -2
- package/dist/admin/{useWebhooks-7BXPSMHG.mjs.map → useWebhooks-8VWSFqNg.mjs.map} +1 -1
- package/dist/admin/{validation-man-qOMc.mjs → validation-p2q0MWxi.mjs} +2 -2
- package/dist/admin/{validation-man-qOMc.mjs.map → validation-p2q0MWxi.mjs.map} +1 -1
- package/dist/admin/{validation-mliIGlD0.js → validation-rsP4iH1U.js} +2 -2
- package/dist/admin/{validation-mliIGlD0.js.map → validation-rsP4iH1U.js.map} +1 -1
- package/dist/ee/admin/src/utils/cookies.d.ts +2 -0
- package/dist/package.json.d.ts +12 -13
- package/dist/server/index.js +1 -1
- package/dist/server/index.js.map +1 -1
- package/dist/server/index.mjs +1 -1
- package/dist/server/index.mjs.map +1 -1
- package/dist/server/src/controllers/admin.d.ts.map +1 -1
- package/package.json +13 -14
- package/dist/admin/AdminSeatInfo-H5eNy3Gq.js.map +0 -1
- package/dist/admin/AdminSeatInfo-jPH1stsB.mjs.map +0 -1
- package/dist/admin/ApplicationInfoPage-QiVVy6LS.mjs.map +0 -1
- package/dist/admin/ApplicationInfoPage-leY1AEgo.js.map +0 -1
- package/dist/admin/AuthResponse-5G-7aJDM.mjs.map +0 -1
- package/dist/admin/AuthResponse-kdo9DYPT.js.map +0 -1
- package/dist/admin/AuthenticatedLayout-Aibt647F.js.map +0 -1
- package/dist/admin/AuthenticatedLayout-UPRVctuH.mjs.map +0 -1
- package/dist/admin/ContentBox-PbS25I_4.mjs.map +0 -1
- package/dist/admin/ContentBox-xqJCP2BC.js.map +0 -1
- package/dist/admin/CreateActionEE-2DKYzbq_.js.map +0 -1
- package/dist/admin/CreateActionEE-TcGdWjIN.mjs.map +0 -1
- package/dist/admin/EditPage-H9aQSaaH.js.map +0 -1
- package/dist/admin/EditPage-oenQhubv.mjs.map +0 -1
- package/dist/admin/HomePage-D-bJ3jts.mjs.map +0 -1
- package/dist/admin/HomePage-Xf5Ghz92.js.map +0 -1
- package/dist/admin/Layout-BuMuReXo.js.map +0 -1
- package/dist/admin/Layout-lSZESFtG.mjs.map +0 -1
- package/dist/admin/ListPage-1HhDIdVj.mjs.map +0 -1
- package/dist/admin/ListPage-A2MPjJxi.js.map +0 -1
- package/dist/admin/ListPage-brwMJDfa.js.map +0 -1
- package/dist/admin/ListPage-fE2OLTTE.mjs.map +0 -1
- package/dist/admin/ListPage-nGtmXc03.mjs.map +0 -1
- package/dist/admin/ListPage-vVa7B6wq.js.map +0 -1
- package/dist/admin/ListView-2uHZ2TWm.mjs.map +0 -1
- package/dist/admin/ListView-9exyBSMW.mjs.map +0 -1
- package/dist/admin/ListView-VjkXS0Tf.js.map +0 -1
- package/dist/admin/ListView-upndjhrB.js.map +0 -1
- package/dist/admin/MarketplacePage-hNQbTtRI.js.map +0 -1
- package/dist/admin/MarketplacePage-mbqZ9JDl.mjs.map +0 -1
- package/dist/admin/Permissions-RNmyxA77.mjs.map +0 -1
- package/dist/admin/Permissions-v5pxfHqR.js.map +0 -1
- package/dist/admin/PurchaseAuditLogs-8_4PcW7P.mjs.map +0 -1
- package/dist/admin/PurchaseAuditLogs-tS_tVSGI.js.map +0 -1
- package/dist/admin/PurchaseSingleSignOn--gblfVu6.mjs.map +0 -1
- package/dist/admin/PurchaseSingleSignOn-9SV6-fYs.js.map +0 -1
- package/dist/admin/SingleSignOnPage-Ots_q1kK.mjs.map +0 -1
- package/dist/admin/SingleSignOnPage-dKN-oVc8.js.map +0 -1
- package/dist/admin/Table-ILoLTYT2.mjs.map +0 -1
- package/dist/admin/Table-rh1Goj9B.js.map +0 -1
- package/dist/admin/TokenTypeSelect-Bc6Gx5Og.js.map +0 -1
- package/dist/admin/TokenTypeSelect-oUpUNcrP.mjs.map +0 -1
- package/dist/admin/UseCasePage-NYPLK0s5.js.map +0 -1
- package/dist/admin/UseCasePage-siicRv21.mjs.map +0 -1
- package/dist/admin/constants-GoVT0wVo.mjs.map +0 -1
- package/dist/admin/constants-wYcX8us0.js.map +0 -1
- package/dist/admin/index-e8PHZx2A.js.map +0 -1
- package/dist/admin/index-i37IN_fH.mjs.map +0 -1
- package/dist/admin/rbac-WZsv1761.js.map +0 -1
- package/dist/admin/rbac-sYT_mXH0.mjs.map +0 -1
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { jsx } from 'react/jsx-runtime';
|
|
2
2
|
import { useIntl } from 'react-intl';
|
|
3
|
-
import { t as useClipboard, k as getBasename, v as useField } from './index-
|
|
3
|
+
import { t as useClipboard, k as getBasename, v as useField } from './index-7fPlAzj6.mjs';
|
|
4
4
|
import { IconButton, MultiSelect, MultiSelectOption } from '@strapi/design-system';
|
|
5
5
|
import { Duplicate, Loader as Loader$1 } from '@strapi/icons';
|
|
6
|
-
import { C as ContentBox } from './ContentBox-
|
|
7
|
-
import { u as useNotification } from './rbac-
|
|
6
|
+
import { C as ContentBox } from './ContentBox-DjmNTcxv.mjs';
|
|
7
|
+
import { u as useNotification } from './rbac-uVd0RAE5.mjs';
|
|
8
8
|
import styled, { keyframes } from 'styled-components';
|
|
9
|
-
import { u as useAdminRoles } from './useAdminRoles-
|
|
9
|
+
import { u as useAdminRoles } from './useAdminRoles-X4pwDHaW.mjs';
|
|
10
10
|
|
|
11
11
|
const MagicLinkWrapper = ({ children, target }) => {
|
|
12
12
|
const { toggleNotification } = useNotification();
|
|
@@ -103,4 +103,4 @@ const LoadingWrapper = styled.div`
|
|
|
103
103
|
const Loader = () => /* @__PURE__ */ jsx(LoadingWrapper, { children: /* @__PURE__ */ jsx(Loader$1, {}) });
|
|
104
104
|
|
|
105
105
|
export { MagicLinkCE as M, SelectRoles as S, MagicLinkWrapper as a };
|
|
106
|
-
//# sourceMappingURL=SelectRoles
|
|
106
|
+
//# sourceMappingURL=SelectRoles--ys30CdN.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SelectRoles
|
|
1
|
+
{"version":3,"file":"SelectRoles--ys30CdN.mjs","sources":["../../admin/src/pages/Settings/pages/Users/components/MagicLinkWrapper.tsx","../../admin/src/pages/Settings/pages/Users/components/MagicLinkCE.tsx","../../admin/src/pages/Settings/pages/Users/components/SelectRoles.tsx"],"sourcesContent":["import { IconButton } from '@strapi/design-system';\nimport { Duplicate } from '@strapi/icons';\nimport { useIntl } from 'react-intl';\n\nimport { ContentBox } from '../../../../../components/ContentBox';\nimport { useNotification } from '../../../../../features/Notifications';\nimport { useClipboard } from '../../../../../hooks/useClipboard';\n\ninterface MagicLinkWrapperProps {\n children: string;\n target: string;\n}\n\nconst MagicLinkWrapper = ({ children, target }: MagicLinkWrapperProps) => {\n const { toggleNotification } = useNotification();\n const { formatMessage } = useIntl();\n const { copy } = useClipboard();\n\n const copyLabel = formatMessage({\n id: 'app.component.CopyToClipboard.label',\n defaultMessage: 'Copy to clipboard',\n });\n\n const handleClick = async () => {\n const didCopy = await copy(target);\n\n if (didCopy) {\n toggleNotification({\n type: 'info',\n message: formatMessage({ id: 'notification.link-copied' }),\n });\n }\n };\n\n return (\n <ContentBox\n endAction={\n <IconButton label={copyLabel} noBorder icon={<Duplicate />} onClick={handleClick} />\n }\n title={target}\n titleEllipsis\n subtitle={children}\n icon={<span style={{ fontSize: 32 }}>✉️</span>}\n iconBackground=\"neutral100\"\n />\n );\n};\n\nexport { MagicLinkWrapper };\nexport type { MagicLinkWrapperProps };\n","import { useIntl } from 'react-intl';\n\nimport { getBasename } from '../../../../../core/utils/basename';\n\nimport { MagicLinkWrapper } from './MagicLinkWrapper';\n\ninterface MagicLinkCEProps {\n registrationToken: string;\n}\n\nconst MagicLinkCE = ({ registrationToken }: MagicLinkCEProps) => {\n const { formatMessage } = useIntl();\n const target = `${\n window.location.origin\n }${getBasename()}/auth/register?registrationToken=${registrationToken}`;\n\n return (\n <MagicLinkWrapper target={target}>\n {formatMessage({\n id: 'app.components.Users.MagicLink.connect',\n defaultMessage: 'Copy and share this link to give access to this user',\n })}\n </MagicLinkWrapper>\n );\n};\n\nexport { MagicLinkCE };\nexport type { MagicLinkCEProps };\n","import { MultiSelect, MultiSelectOption } from '@strapi/design-system';\nimport { Loader as LoadingIcon } from '@strapi/icons';\nimport { useIntl } from 'react-intl';\nimport styled, { keyframes } from 'styled-components';\n\nimport { useField } from '../../../../../components/Form';\nimport { useAdminRoles } from '../../../../../hooks/useAdminRoles';\n\ninterface SelectRolesProps {\n disabled?: boolean;\n}\n\nconst SelectRoles = ({ disabled }: SelectRolesProps) => {\n const { isLoading, roles } = useAdminRoles();\n\n const { formatMessage } = useIntl();\n const { value = [], onChange, error } = useField<string[]>('roles');\n\n const label = formatMessage({\n id: 'app.components.Users.ModalCreateBody.block-title.roles',\n defaultMessage: \"User's roles\",\n });\n const hint = formatMessage({\n id: 'app.components.Users.ModalCreateBody.block-title.roles.description',\n defaultMessage: 'A user can have one or several roles',\n });\n const placeholder = formatMessage({\n id: 'app.components.Select.placeholder',\n defaultMessage: 'Select',\n });\n\n return (\n <MultiSelect\n id=\"roles\"\n disabled={disabled}\n error={error}\n hint={hint}\n label={label}\n name=\"roles\"\n onChange={(v) => {\n onChange('roles', v);\n }}\n placeholder={placeholder}\n startIcon={isLoading ? <Loader /> : undefined}\n value={value.map((v) => v.toString())}\n withTags\n required\n >\n {roles.map((role) => {\n return (\n <MultiSelectOption key={role.id} value={role.id.toString()}>\n {formatMessage({\n id: `global.${role.code}`,\n defaultMessage: role.name,\n })}\n </MultiSelectOption>\n );\n })}\n </MultiSelect>\n );\n};\n\nconst rotation = keyframes`\n from {\n transform: rotate(0deg);\n }\n to {\n transform: rotate(359deg);\n }\n`;\n\nconst LoadingWrapper = styled.div`\n animation: ${rotation} 2s infinite linear;\n`;\n\nconst Loader = () => (\n <LoadingWrapper>\n <LoadingIcon />\n </LoadingWrapper>\n);\n\nexport { SelectRoles };\n"],"names":["LoadingIcon"],"mappings":"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"}
|
|
@@ -2,13 +2,13 @@
|
|
|
2
2
|
|
|
3
3
|
const jsxRuntime = require('react/jsx-runtime');
|
|
4
4
|
const reactIntl = require('react-intl');
|
|
5
|
-
const index = require('./index-
|
|
5
|
+
const index = require('./index-FJLgZ-Wg.js');
|
|
6
6
|
const designSystem = require('@strapi/design-system');
|
|
7
7
|
const icons = require('@strapi/icons');
|
|
8
|
-
const ContentBox = require('./ContentBox-
|
|
9
|
-
const rbac = require('./rbac-
|
|
8
|
+
const ContentBox = require('./ContentBox-Mzcpnn32.js');
|
|
9
|
+
const rbac = require('./rbac-xgYdpUSq.js');
|
|
10
10
|
const styled = require('styled-components');
|
|
11
|
-
const useAdminRoles = require('./useAdminRoles-
|
|
11
|
+
const useAdminRoles = require('./useAdminRoles-yjN2uT_o.js');
|
|
12
12
|
|
|
13
13
|
const _interopDefault = e => e && e.__esModule ? e : { default: e };
|
|
14
14
|
|
|
@@ -111,4 +111,4 @@ const Loader = () => /* @__PURE__ */ jsxRuntime.jsx(LoadingWrapper, { children:
|
|
|
111
111
|
exports.MagicLinkCE = MagicLinkCE;
|
|
112
112
|
exports.MagicLinkWrapper = MagicLinkWrapper;
|
|
113
113
|
exports.SelectRoles = SelectRoles;
|
|
114
|
-
//# sourceMappingURL=SelectRoles-
|
|
114
|
+
//# sourceMappingURL=SelectRoles-EdE6yfsj.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SelectRoles-
|
|
1
|
+
{"version":3,"file":"SelectRoles-EdE6yfsj.js","sources":["../../admin/src/pages/Settings/pages/Users/components/MagicLinkWrapper.tsx","../../admin/src/pages/Settings/pages/Users/components/MagicLinkCE.tsx","../../admin/src/pages/Settings/pages/Users/components/SelectRoles.tsx"],"sourcesContent":["import { IconButton } from '@strapi/design-system';\nimport { Duplicate } from '@strapi/icons';\nimport { useIntl } from 'react-intl';\n\nimport { ContentBox } from '../../../../../components/ContentBox';\nimport { useNotification } from '../../../../../features/Notifications';\nimport { useClipboard } from '../../../../../hooks/useClipboard';\n\ninterface MagicLinkWrapperProps {\n children: string;\n target: string;\n}\n\nconst MagicLinkWrapper = ({ children, target }: MagicLinkWrapperProps) => {\n const { toggleNotification } = useNotification();\n const { formatMessage } = useIntl();\n const { copy } = useClipboard();\n\n const copyLabel = formatMessage({\n id: 'app.component.CopyToClipboard.label',\n defaultMessage: 'Copy to clipboard',\n });\n\n const handleClick = async () => {\n const didCopy = await copy(target);\n\n if (didCopy) {\n toggleNotification({\n type: 'info',\n message: formatMessage({ id: 'notification.link-copied' }),\n });\n }\n };\n\n return (\n <ContentBox\n endAction={\n <IconButton label={copyLabel} noBorder icon={<Duplicate />} onClick={handleClick} />\n }\n title={target}\n titleEllipsis\n subtitle={children}\n icon={<span style={{ fontSize: 32 }}>✉️</span>}\n iconBackground=\"neutral100\"\n />\n );\n};\n\nexport { MagicLinkWrapper };\nexport type { MagicLinkWrapperProps };\n","import { useIntl } from 'react-intl';\n\nimport { getBasename } from '../../../../../core/utils/basename';\n\nimport { MagicLinkWrapper } from './MagicLinkWrapper';\n\ninterface MagicLinkCEProps {\n registrationToken: string;\n}\n\nconst MagicLinkCE = ({ registrationToken }: MagicLinkCEProps) => {\n const { formatMessage } = useIntl();\n const target = `${\n window.location.origin\n }${getBasename()}/auth/register?registrationToken=${registrationToken}`;\n\n return (\n <MagicLinkWrapper target={target}>\n {formatMessage({\n id: 'app.components.Users.MagicLink.connect',\n defaultMessage: 'Copy and share this link to give access to this user',\n })}\n </MagicLinkWrapper>\n );\n};\n\nexport { MagicLinkCE };\nexport type { MagicLinkCEProps };\n","import { MultiSelect, MultiSelectOption } from '@strapi/design-system';\nimport { Loader as LoadingIcon } from '@strapi/icons';\nimport { useIntl } from 'react-intl';\nimport styled, { keyframes } from 'styled-components';\n\nimport { useField } from '../../../../../components/Form';\nimport { useAdminRoles } from '../../../../../hooks/useAdminRoles';\n\ninterface SelectRolesProps {\n disabled?: boolean;\n}\n\nconst SelectRoles = ({ disabled }: SelectRolesProps) => {\n const { isLoading, roles } = useAdminRoles();\n\n const { formatMessage } = useIntl();\n const { value = [], onChange, error } = useField<string[]>('roles');\n\n const label = formatMessage({\n id: 'app.components.Users.ModalCreateBody.block-title.roles',\n defaultMessage: \"User's roles\",\n });\n const hint = formatMessage({\n id: 'app.components.Users.ModalCreateBody.block-title.roles.description',\n defaultMessage: 'A user can have one or several roles',\n });\n const placeholder = formatMessage({\n id: 'app.components.Select.placeholder',\n defaultMessage: 'Select',\n });\n\n return (\n <MultiSelect\n id=\"roles\"\n disabled={disabled}\n error={error}\n hint={hint}\n label={label}\n name=\"roles\"\n onChange={(v) => {\n onChange('roles', v);\n }}\n placeholder={placeholder}\n startIcon={isLoading ? <Loader /> : undefined}\n value={value.map((v) => v.toString())}\n withTags\n required\n >\n {roles.map((role) => {\n return (\n <MultiSelectOption key={role.id} value={role.id.toString()}>\n {formatMessage({\n id: `global.${role.code}`,\n defaultMessage: role.name,\n })}\n </MultiSelectOption>\n );\n })}\n </MultiSelect>\n );\n};\n\nconst rotation = keyframes`\n from {\n transform: rotate(0deg);\n }\n to {\n transform: rotate(359deg);\n }\n`;\n\nconst LoadingWrapper = styled.div`\n animation: ${rotation} 2s infinite linear;\n`;\n\nconst Loader = () => (\n <LoadingWrapper>\n <LoadingIcon />\n </LoadingWrapper>\n);\n\nexport { SelectRoles };\n"],"names":["useNotification","useIntl","useClipboard","jsx","ContentBox","IconButton","Duplicate","getBasename","useAdminRoles","useField","MultiSelect","MultiSelectOption","keyframes","styled","LoadingIcon"],"mappings":"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"}
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
2
|
-
import { Layout, HeaderLayout, Button, ContentLayout, Flex, Typography, Grid, GridItem, ToggleInput,
|
|
2
|
+
import { Layout, HeaderLayout, Button, ContentLayout, Flex, Typography, Grid, GridItem, ToggleInput, SingleSelect, SingleSelectOption, MultiSelect, MultiSelectOption } from '@strapi/design-system';
|
|
3
3
|
import { Check } from '@strapi/icons';
|
|
4
4
|
import { Formik, Form } from 'formik';
|
|
5
5
|
import { useIntl } from 'react-intl';
|
|
6
6
|
import * as yup from 'yup';
|
|
7
|
-
import { b as useTypedSelector, P as Page, u as useNotification, f as useAPIErrorHandler, i as useGetProviderOptionsQuery, j as useUpdateProviderOptionsMutation, k as useRBAC } from './rbac-
|
|
8
|
-
import { u as useAdminRoles } from './useAdminRoles-
|
|
9
|
-
import { i as isBaseQueryError } from './admin-
|
|
10
|
-
import { e as errorsTrads } from './index-
|
|
7
|
+
import { b as useTypedSelector, P as Page, u as useNotification, f as useAPIErrorHandler, i as useGetProviderOptionsQuery, j as useUpdateProviderOptionsMutation, k as useRBAC } from './rbac-uVd0RAE5.mjs';
|
|
8
|
+
import { u as useAdminRoles } from './useAdminRoles-X4pwDHaW.mjs';
|
|
9
|
+
import { i as isBaseQueryError } from './admin-5SXhE_nJ.mjs';
|
|
10
|
+
import { e as errorsTrads } from './index-7fPlAzj6.mjs';
|
|
11
11
|
|
|
12
12
|
const schema = yup.object().shape({
|
|
13
13
|
autoRegister: yup.bool().required(errorsTrads.required.id),
|
|
@@ -158,7 +158,7 @@ const SingleSignOnPage = () => {
|
|
|
158
158
|
}
|
|
159
159
|
) }),
|
|
160
160
|
/* @__PURE__ */ jsx(GridItem, { col: 6, s: 12, children: /* @__PURE__ */ jsx(
|
|
161
|
-
|
|
161
|
+
SingleSelect,
|
|
162
162
|
{
|
|
163
163
|
disabled: !canUpdate,
|
|
164
164
|
hint: formatMessage({
|
|
@@ -180,7 +180,7 @@ const SingleSignOnPage = () => {
|
|
|
180
180
|
defaultMessage: "Choose here"
|
|
181
181
|
}),
|
|
182
182
|
value: values.defaultRole,
|
|
183
|
-
children: roles.map(({ id, name }) => /* @__PURE__ */ jsx(
|
|
183
|
+
children: roles.map(({ id, name }) => /* @__PURE__ */ jsx(SingleSelectOption, { value: id.toString(), children: name }, id))
|
|
184
184
|
}
|
|
185
185
|
) }),
|
|
186
186
|
/* @__PURE__ */ jsx(GridItem, { col: 6, s: 12, children: /* @__PURE__ */ jsx(
|
|
@@ -231,4 +231,4 @@ const ProtectedSSO = () => {
|
|
|
231
231
|
};
|
|
232
232
|
|
|
233
233
|
export { ProtectedSSO, SingleSignOnPage };
|
|
234
|
-
//# sourceMappingURL=SingleSignOnPage-
|
|
234
|
+
//# sourceMappingURL=SingleSignOnPage-Y-brfYQ1.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SingleSignOnPage-Y-brfYQ1.mjs","sources":["../../ee/admin/src/pages/SettingsPage/pages/SingleSignOnPage.tsx"],"sourcesContent":["import {\n Button,\n ContentLayout,\n Flex,\n Grid,\n GridItem,\n HeaderLayout,\n Layout,\n MultiSelect,\n MultiSelectOption,\n SingleSelectOption,\n SingleSelect,\n ToggleInput,\n Typography,\n} from '@strapi/design-system';\nimport { Check } from '@strapi/icons';\nimport { Formik, Form, FormikHelpers } from 'formik';\nimport { useIntl } from 'react-intl';\nimport * as yup from 'yup';\n\nimport { Page } from '../../../../../../admin/src/components/PageHelpers';\nimport { useTypedSelector } from '../../../../../../admin/src/core/store/hooks';\nimport { useNotification } from '../../../../../../admin/src/features/Notifications';\nimport { useAdminRoles } from '../../../../../../admin/src/hooks/useAdminRoles';\nimport { useAPIErrorHandler } from '../../../../../../admin/src/hooks/useAPIErrorHandler';\nimport { useRBAC } from '../../../../../../admin/src/hooks/useRBAC';\nimport {\n useGetProviderOptionsQuery,\n useUpdateProviderOptionsMutation,\n} from '../../../../../../admin/src/services/auth';\nimport { isBaseQueryError } from '../../../../../../admin/src/utils/baseQuery';\nimport { translatedErrors } from '../../../../../../admin/src/utils/translatedErrors';\nimport { ProvidersOptions } from '../../../../../../shared/contracts/admin';\n\nconst schema = yup.object().shape({\n autoRegister: yup.bool().required(translatedErrors.required.id),\n defaultRole: yup.mixed().when('autoRegister', (value, initSchema) => {\n return value ? initSchema.required(translatedErrors.required.id) : initSchema.nullable();\n }),\n ssoLockedRoles: yup\n .array()\n .nullable()\n .of(\n yup.mixed().when('ssoLockedRoles', (value, initSchema) => {\n return value ? initSchema.required(translatedErrors.required.id) : initSchema.nullable();\n })\n ),\n});\n\nexport const SingleSignOnPage = () => {\n const { formatMessage } = useIntl();\n const permissions = useTypedSelector((state) => state.admin_app.permissions);\n const { toggleNotification } = useNotification();\n const {\n _unstableFormatAPIError: formatAPIError,\n _unstableFormatValidationErrors: formatValidationErrors,\n } = useAPIErrorHandler();\n\n const { isLoading: isLoadingProviderOptions, data } = useGetProviderOptionsQuery();\n\n const [updateProviderOptions, { isLoading: isSubmittingForm }] =\n useUpdateProviderOptionsMutation();\n\n const {\n isLoading: isLoadingPermissions,\n allowedActions: { canUpdate, canRead: canReadRoles },\n } = useRBAC({\n ...permissions.settings?.sso,\n readRoles: permissions.settings?.roles.read ?? [],\n });\n\n const { roles, isLoading: isLoadingRoles } = useAdminRoles(undefined, {\n skip: !canReadRoles,\n });\n\n const handleSubmit = async (\n body: ProvidersOptions.Request['body'],\n formik: FormikHelpers<ProvidersOptions.Request['body']>\n ) => {\n try {\n const res = await updateProviderOptions(body);\n\n if ('error' in res) {\n if (isBaseQueryError(res.error) && res.error.name === 'ValidationError') {\n formik.setErrors(formatValidationErrors(res.error));\n } else {\n toggleNotification({\n type: 'danger',\n message: formatAPIError(res.error),\n });\n }\n\n return;\n }\n\n toggleNotification({\n type: 'success',\n message: formatMessage({ id: 'notification.success.saved' }),\n });\n } catch (err) {\n toggleNotification({\n type: 'danger',\n message: formatMessage({\n id: 'notification.error',\n defaultMessage: 'An error occurred, please try again.',\n }),\n });\n }\n };\n\n const isLoadingData = isLoadingRoles || isLoadingPermissions || isLoadingProviderOptions;\n\n return (\n <Layout>\n <Page.Title>\n {formatMessage(\n { id: 'Settings.PageTitle', defaultMessage: 'Settings - {name}' },\n {\n name: 'SSO',\n }\n )}\n </Page.Title>\n <Page.Main aria-busy={isSubmittingForm || isLoadingData} tabIndex={-1}>\n <Formik\n onSubmit={handleSubmit}\n initialValues={\n data || {\n autoRegister: false,\n defaultRole: null,\n ssoLockedRoles: null,\n }\n }\n validationSchema={schema}\n validateOnChange={false}\n enableReinitialize\n >\n {({ handleChange, isSubmitting, values, setFieldValue, dirty, errors }) => (\n <Form>\n <HeaderLayout\n primaryAction={\n <Button\n disabled={!dirty}\n loading={isSubmitting}\n startIcon={<Check />}\n type=\"submit\"\n size=\"L\"\n >\n {formatMessage({\n id: 'global.save',\n defaultMessage: 'Save',\n })}\n </Button>\n }\n title={formatMessage({\n id: 'Settings.sso.title',\n defaultMessage: 'Single Sign-On',\n })}\n subtitle={formatMessage({\n id: 'Settings.sso.description',\n defaultMessage: 'Configure the settings for the Single Sign-On feature.',\n })}\n />\n <ContentLayout>\n {isSubmitting || isLoadingData ? (\n <Page.Loading />\n ) : (\n <Flex\n direction=\"column\"\n alignItems=\"stretch\"\n gap={4}\n background=\"neutral0\"\n padding={6}\n shadow=\"filterShadow\"\n hasRadius\n >\n <Typography variant=\"delta\" as=\"h2\">\n {formatMessage({\n id: 'global.settings',\n defaultMessage: 'Settings',\n })}\n </Typography>\n <Grid gap={4}>\n <GridItem col={6} s={12}>\n <ToggleInput\n disabled={!canUpdate}\n checked={values.autoRegister}\n hint={formatMessage({\n id: 'Settings.sso.form.registration.description',\n defaultMessage: 'Create new user on SSO login if no account exists',\n })}\n label={formatMessage({\n id: 'Settings.sso.form.registration.label',\n defaultMessage: 'Auto-registration',\n })}\n name=\"autoRegister\"\n offLabel={formatMessage({\n id: 'app.components.ToggleCheckbox.off-label',\n defaultMessage: 'Off',\n })}\n onLabel={formatMessage({\n id: 'app.components.ToggleCheckbox.on-label',\n defaultMessage: 'On',\n })}\n onChange={handleChange}\n />\n </GridItem>\n <GridItem col={6} s={12}>\n <SingleSelect\n disabled={!canUpdate}\n hint={formatMessage({\n id: 'Settings.sso.form.defaultRole.description',\n defaultMessage:\n 'It will attach the new authenticated user to the selected role',\n })}\n error={\n errors.defaultRole\n ? formatMessage({\n id: errors.defaultRole,\n defaultMessage: errors.defaultRole,\n })\n : ''\n }\n label={formatMessage({\n id: 'Settings.sso.form.defaultRole.label',\n defaultMessage: 'Default role',\n })}\n name=\"defaultRole\"\n onChange={(value) =>\n handleChange({ target: { name: 'defaultRole', value } })\n }\n placeholder={formatMessage({\n id: 'components.InputSelect.option.placeholder',\n defaultMessage: 'Choose here',\n })}\n value={values.defaultRole}\n >\n {roles.map(({ id, name }) => (\n <SingleSelectOption key={id} value={id.toString()}>\n {name}\n </SingleSelectOption>\n ))}\n </SingleSelect>\n </GridItem>\n <GridItem col={6} s={12}>\n <MultiSelect\n disabled={!canUpdate}\n hint={formatMessage({\n id: 'Settings.sso.form.localAuthenticationLock.description',\n defaultMessage:\n 'Select the roles for which you want to disable the local authentication',\n })}\n error={\n errors.ssoLockedRoles\n ? formatMessage({\n id: errors.ssoLockedRoles,\n defaultMessage: errors.ssoLockedRoles,\n })\n : ''\n }\n label={formatMessage({\n id: 'Settings.sso.form.localAuthenticationLock.label',\n defaultMessage: 'Local authentication lock-out',\n })}\n name=\"ssoLockedRoles\"\n onChange={(value) =>\n handleChange({\n target: {\n value,\n name: 'ssoLockedRoles',\n },\n })\n }\n placeholder={formatMessage({\n id: 'components.InputSelect.option.placeholder',\n defaultMessage: 'Choose here',\n })}\n onClear={() => setFieldValue('ssoLockedRoles', [])}\n value={values.ssoLockedRoles || []}\n withTags\n >\n {roles.map(({ id, name }) => (\n <MultiSelectOption key={id} value={id.toString()}>\n {name}\n </MultiSelectOption>\n ))}\n </MultiSelect>\n </GridItem>\n </Grid>\n </Flex>\n )}\n </ContentLayout>\n </Form>\n )}\n </Formik>\n </Page.Main>\n </Layout>\n );\n};\n\nexport const ProtectedSSO = () => {\n const permissions = useTypedSelector((state) => state.admin_app.permissions.settings?.sso?.main);\n\n return (\n <Page.Protect permissions={permissions}>\n <SingleSignOnPage />\n </Page.Protect>\n );\n};\n"],"names":["translatedErrors"],"mappings":"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"}
|
|
@@ -8,10 +8,10 @@ const icons = require('@strapi/icons');
|
|
|
8
8
|
const formik = require('formik');
|
|
9
9
|
const reactIntl = require('react-intl');
|
|
10
10
|
const yup = require('yup');
|
|
11
|
-
const rbac = require('./rbac-
|
|
12
|
-
const useAdminRoles = require('./useAdminRoles-
|
|
11
|
+
const rbac = require('./rbac-xgYdpUSq.js');
|
|
12
|
+
const useAdminRoles = require('./useAdminRoles-yjN2uT_o.js');
|
|
13
13
|
const admin = require('./admin-vlKSOeHB.js');
|
|
14
|
-
const index = require('./index-
|
|
14
|
+
const index = require('./index-FJLgZ-Wg.js');
|
|
15
15
|
|
|
16
16
|
function _interopNamespace(e) {
|
|
17
17
|
if (e && e.__esModule) return e;
|
|
@@ -182,7 +182,7 @@ const SingleSignOnPage = () => {
|
|
|
182
182
|
}
|
|
183
183
|
) }),
|
|
184
184
|
/* @__PURE__ */ jsxRuntime.jsx(designSystem.GridItem, { col: 6, s: 12, children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
185
|
-
designSystem.
|
|
185
|
+
designSystem.SingleSelect,
|
|
186
186
|
{
|
|
187
187
|
disabled: !canUpdate,
|
|
188
188
|
hint: formatMessage({
|
|
@@ -204,7 +204,7 @@ const SingleSignOnPage = () => {
|
|
|
204
204
|
defaultMessage: "Choose here"
|
|
205
205
|
}),
|
|
206
206
|
value: values.defaultRole,
|
|
207
|
-
children: roles.map(({ id, name }) => /* @__PURE__ */ jsxRuntime.jsx(designSystem.
|
|
207
|
+
children: roles.map(({ id, name }) => /* @__PURE__ */ jsxRuntime.jsx(designSystem.SingleSelectOption, { value: id.toString(), children: name }, id))
|
|
208
208
|
}
|
|
209
209
|
) }),
|
|
210
210
|
/* @__PURE__ */ jsxRuntime.jsx(designSystem.GridItem, { col: 6, s: 12, children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
@@ -256,4 +256,4 @@ const ProtectedSSO = () => {
|
|
|
256
256
|
|
|
257
257
|
exports.ProtectedSSO = ProtectedSSO;
|
|
258
258
|
exports.SingleSignOnPage = SingleSignOnPage;
|
|
259
|
-
//# sourceMappingURL=SingleSignOnPage-
|
|
259
|
+
//# sourceMappingURL=SingleSignOnPage-nv121JbB.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SingleSignOnPage-nv121JbB.js","sources":["../../ee/admin/src/pages/SettingsPage/pages/SingleSignOnPage.tsx"],"sourcesContent":["import {\n Button,\n ContentLayout,\n Flex,\n Grid,\n GridItem,\n HeaderLayout,\n Layout,\n MultiSelect,\n MultiSelectOption,\n SingleSelectOption,\n SingleSelect,\n ToggleInput,\n Typography,\n} from '@strapi/design-system';\nimport { Check } from '@strapi/icons';\nimport { Formik, Form, FormikHelpers } from 'formik';\nimport { useIntl } from 'react-intl';\nimport * as yup from 'yup';\n\nimport { Page } from '../../../../../../admin/src/components/PageHelpers';\nimport { useTypedSelector } from '../../../../../../admin/src/core/store/hooks';\nimport { useNotification } from '../../../../../../admin/src/features/Notifications';\nimport { useAdminRoles } from '../../../../../../admin/src/hooks/useAdminRoles';\nimport { useAPIErrorHandler } from '../../../../../../admin/src/hooks/useAPIErrorHandler';\nimport { useRBAC } from '../../../../../../admin/src/hooks/useRBAC';\nimport {\n useGetProviderOptionsQuery,\n useUpdateProviderOptionsMutation,\n} from '../../../../../../admin/src/services/auth';\nimport { isBaseQueryError } from '../../../../../../admin/src/utils/baseQuery';\nimport { translatedErrors } from '../../../../../../admin/src/utils/translatedErrors';\nimport { ProvidersOptions } from '../../../../../../shared/contracts/admin';\n\nconst schema = yup.object().shape({\n autoRegister: yup.bool().required(translatedErrors.required.id),\n defaultRole: yup.mixed().when('autoRegister', (value, initSchema) => {\n return value ? initSchema.required(translatedErrors.required.id) : initSchema.nullable();\n }),\n ssoLockedRoles: yup\n .array()\n .nullable()\n .of(\n yup.mixed().when('ssoLockedRoles', (value, initSchema) => {\n return value ? initSchema.required(translatedErrors.required.id) : initSchema.nullable();\n })\n ),\n});\n\nexport const SingleSignOnPage = () => {\n const { formatMessage } = useIntl();\n const permissions = useTypedSelector((state) => state.admin_app.permissions);\n const { toggleNotification } = useNotification();\n const {\n _unstableFormatAPIError: formatAPIError,\n _unstableFormatValidationErrors: formatValidationErrors,\n } = useAPIErrorHandler();\n\n const { isLoading: isLoadingProviderOptions, data } = useGetProviderOptionsQuery();\n\n const [updateProviderOptions, { isLoading: isSubmittingForm }] =\n useUpdateProviderOptionsMutation();\n\n const {\n isLoading: isLoadingPermissions,\n allowedActions: { canUpdate, canRead: canReadRoles },\n } = useRBAC({\n ...permissions.settings?.sso,\n readRoles: permissions.settings?.roles.read ?? [],\n });\n\n const { roles, isLoading: isLoadingRoles } = useAdminRoles(undefined, {\n skip: !canReadRoles,\n });\n\n const handleSubmit = async (\n body: ProvidersOptions.Request['body'],\n formik: FormikHelpers<ProvidersOptions.Request['body']>\n ) => {\n try {\n const res = await updateProviderOptions(body);\n\n if ('error' in res) {\n if (isBaseQueryError(res.error) && res.error.name === 'ValidationError') {\n formik.setErrors(formatValidationErrors(res.error));\n } else {\n toggleNotification({\n type: 'danger',\n message: formatAPIError(res.error),\n });\n }\n\n return;\n }\n\n toggleNotification({\n type: 'success',\n message: formatMessage({ id: 'notification.success.saved' }),\n });\n } catch (err) {\n toggleNotification({\n type: 'danger',\n message: formatMessage({\n id: 'notification.error',\n defaultMessage: 'An error occurred, please try again.',\n }),\n });\n }\n };\n\n const isLoadingData = isLoadingRoles || isLoadingPermissions || isLoadingProviderOptions;\n\n return (\n <Layout>\n <Page.Title>\n {formatMessage(\n { id: 'Settings.PageTitle', defaultMessage: 'Settings - {name}' },\n {\n name: 'SSO',\n }\n )}\n </Page.Title>\n <Page.Main aria-busy={isSubmittingForm || isLoadingData} tabIndex={-1}>\n <Formik\n onSubmit={handleSubmit}\n initialValues={\n data || {\n autoRegister: false,\n defaultRole: null,\n ssoLockedRoles: null,\n }\n }\n validationSchema={schema}\n validateOnChange={false}\n enableReinitialize\n >\n {({ handleChange, isSubmitting, values, setFieldValue, dirty, errors }) => (\n <Form>\n <HeaderLayout\n primaryAction={\n <Button\n disabled={!dirty}\n loading={isSubmitting}\n startIcon={<Check />}\n type=\"submit\"\n size=\"L\"\n >\n {formatMessage({\n id: 'global.save',\n defaultMessage: 'Save',\n })}\n </Button>\n }\n title={formatMessage({\n id: 'Settings.sso.title',\n defaultMessage: 'Single Sign-On',\n })}\n subtitle={formatMessage({\n id: 'Settings.sso.description',\n defaultMessage: 'Configure the settings for the Single Sign-On feature.',\n })}\n />\n <ContentLayout>\n {isSubmitting || isLoadingData ? (\n <Page.Loading />\n ) : (\n <Flex\n direction=\"column\"\n alignItems=\"stretch\"\n gap={4}\n background=\"neutral0\"\n padding={6}\n shadow=\"filterShadow\"\n hasRadius\n >\n <Typography variant=\"delta\" as=\"h2\">\n {formatMessage({\n id: 'global.settings',\n defaultMessage: 'Settings',\n })}\n </Typography>\n <Grid gap={4}>\n <GridItem col={6} s={12}>\n <ToggleInput\n disabled={!canUpdate}\n checked={values.autoRegister}\n hint={formatMessage({\n id: 'Settings.sso.form.registration.description',\n defaultMessage: 'Create new user on SSO login if no account exists',\n })}\n label={formatMessage({\n id: 'Settings.sso.form.registration.label',\n defaultMessage: 'Auto-registration',\n })}\n name=\"autoRegister\"\n offLabel={formatMessage({\n id: 'app.components.ToggleCheckbox.off-label',\n defaultMessage: 'Off',\n })}\n onLabel={formatMessage({\n id: 'app.components.ToggleCheckbox.on-label',\n defaultMessage: 'On',\n })}\n onChange={handleChange}\n />\n </GridItem>\n <GridItem col={6} s={12}>\n <SingleSelect\n disabled={!canUpdate}\n hint={formatMessage({\n id: 'Settings.sso.form.defaultRole.description',\n defaultMessage:\n 'It will attach the new authenticated user to the selected role',\n })}\n error={\n errors.defaultRole\n ? formatMessage({\n id: errors.defaultRole,\n defaultMessage: errors.defaultRole,\n })\n : ''\n }\n label={formatMessage({\n id: 'Settings.sso.form.defaultRole.label',\n defaultMessage: 'Default role',\n })}\n name=\"defaultRole\"\n onChange={(value) =>\n handleChange({ target: { name: 'defaultRole', value } })\n }\n placeholder={formatMessage({\n id: 'components.InputSelect.option.placeholder',\n defaultMessage: 'Choose here',\n })}\n value={values.defaultRole}\n >\n {roles.map(({ id, name }) => (\n <SingleSelectOption key={id} value={id.toString()}>\n {name}\n </SingleSelectOption>\n ))}\n </SingleSelect>\n </GridItem>\n <GridItem col={6} s={12}>\n <MultiSelect\n disabled={!canUpdate}\n hint={formatMessage({\n id: 'Settings.sso.form.localAuthenticationLock.description',\n defaultMessage:\n 'Select the roles for which you want to disable the local authentication',\n })}\n error={\n errors.ssoLockedRoles\n ? formatMessage({\n id: errors.ssoLockedRoles,\n defaultMessage: errors.ssoLockedRoles,\n })\n : ''\n }\n label={formatMessage({\n id: 'Settings.sso.form.localAuthenticationLock.label',\n defaultMessage: 'Local authentication lock-out',\n })}\n name=\"ssoLockedRoles\"\n onChange={(value) =>\n handleChange({\n target: {\n value,\n name: 'ssoLockedRoles',\n },\n })\n }\n placeholder={formatMessage({\n id: 'components.InputSelect.option.placeholder',\n defaultMessage: 'Choose here',\n })}\n onClear={() => setFieldValue('ssoLockedRoles', [])}\n value={values.ssoLockedRoles || []}\n withTags\n >\n {roles.map(({ id, name }) => (\n <MultiSelectOption key={id} value={id.toString()}>\n {name}\n </MultiSelectOption>\n ))}\n </MultiSelect>\n </GridItem>\n </Grid>\n </Flex>\n )}\n </ContentLayout>\n </Form>\n )}\n </Formik>\n </Page.Main>\n </Layout>\n );\n};\n\nexport const ProtectedSSO = () => {\n const permissions = useTypedSelector((state) => state.admin_app.permissions.settings?.sso?.main);\n\n return (\n <Page.Protect permissions={permissions}>\n <SingleSignOnPage />\n </Page.Protect>\n );\n};\n"],"names":["yup","translatedErrors","useIntl","useTypedSelector","useNotification","useAPIErrorHandler","useGetProviderOptionsQuery","useUpdateProviderOptionsMutation","useRBAC","useAdminRoles","isBaseQueryError","Layout","jsx","Page","Formik","jsxs","Form","HeaderLayout","Button","Check","ContentLayout","Flex","Typography","Grid","GridItem","ToggleInput","SingleSelect","SingleSelectOption","MultiSelect","MultiSelectOption"],"mappings":"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"}
|
|
@@ -1,14 +1,13 @@
|
|
|
1
1
|
import { jsx, jsxs } from 'react/jsx-runtime';
|
|
2
2
|
import * as React from 'react';
|
|
3
|
-
import { useCollator, Typography, Flex, Box, IconButton } from '@strapi/design-system';
|
|
4
|
-
import { Link } from '@strapi/design-system/v2';
|
|
3
|
+
import { Link, useCollator, Typography, Flex, Box, IconButton } from '@strapi/design-system';
|
|
5
4
|
import { Trash, Pencil } from '@strapi/icons';
|
|
6
5
|
import { useIntl } from 'react-intl';
|
|
7
6
|
import { useNavigate, NavLink } from 'react-router-dom';
|
|
8
7
|
import styled from 'styled-components';
|
|
9
|
-
import { m as useQueryParams, T as Table$1, C as ConfirmDialog } from './index-
|
|
8
|
+
import { m as useQueryParams, T as Table$1, C as ConfirmDialog } from './index-7fPlAzj6.mjs';
|
|
10
9
|
import { intervalToDuration, isPast } from 'date-fns';
|
|
11
|
-
import { d as useTracking } from './rbac-
|
|
10
|
+
import { d as useTracking } from './rbac-uVd0RAE5.mjs';
|
|
12
11
|
|
|
13
12
|
const intervals = ["years", "months", "days", "hours", "minutes", "seconds"];
|
|
14
13
|
const RelativeTime = React.forwardRef(
|
|
@@ -72,8 +71,8 @@ const Table = ({
|
|
|
72
71
|
/* @__PURE__ */ jsx(Table$1.Empty, {}),
|
|
73
72
|
/* @__PURE__ */ jsx(Table$1.Loading, {}),
|
|
74
73
|
/* @__PURE__ */ jsx(Table$1.Body, { children: sortedTokens.map((token) => /* @__PURE__ */ jsxs(Table$1.Row, { onClick: handleRowClick(token.id), children: [
|
|
75
|
-
/* @__PURE__ */ jsx(Table$1.Cell, { maxWidth:
|
|
76
|
-
/* @__PURE__ */ jsx(Table$1.Cell, { maxWidth:
|
|
74
|
+
/* @__PURE__ */ jsx(Table$1.Cell, { maxWidth: "25rem", children: /* @__PURE__ */ jsx(Typography, { textColor: "neutral800", fontWeight: "bold", ellipsis: true, children: token.name }) }),
|
|
75
|
+
/* @__PURE__ */ jsx(Table$1.Cell, { maxWidth: "25rem", children: /* @__PURE__ */ jsx(Typography, { textColor: "neutral800", ellipsis: true, children: token.description }) }),
|
|
77
76
|
/* @__PURE__ */ jsx(Table$1.Cell, { children: /* @__PURE__ */ jsx(Typography, { textColor: "neutral800", children: /* @__PURE__ */ jsx(RelativeTime, { timestamp: new Date(token.createdAt) }) }) }),
|
|
78
77
|
/* @__PURE__ */ jsx(Table$1.Cell, { children: token.lastUsedAt && /* @__PURE__ */ jsx(Typography, { textColor: "neutral800", children: /* @__PURE__ */ jsx(
|
|
79
78
|
RelativeTime,
|
|
@@ -193,4 +192,4 @@ const UpdateButton = ({ tokenName, tokenId }) => {
|
|
|
193
192
|
};
|
|
194
193
|
|
|
195
194
|
export { Table as T };
|
|
196
|
-
//# sourceMappingURL=Table
|
|
195
|
+
//# sourceMappingURL=Table--He5qeQG.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Table--He5qeQG.mjs","sources":["../../admin/src/components/RelativeTime.tsx","../../admin/src/pages/Settings/components/Tokens/Table.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport { Duration, intervalToDuration, isPast } from 'date-fns';\nimport { useIntl } from 'react-intl';\n\nconst intervals: Array<keyof Duration> = ['years', 'months', 'days', 'hours', 'minutes', 'seconds'];\n\ninterface CustomInterval {\n unit: keyof Duration;\n text: string;\n threshold: number;\n}\n\ninterface RelativeTimeProps extends React.ComponentPropsWithoutRef<'time'> {\n timestamp: Date;\n customIntervals?: CustomInterval[];\n}\n\n/**\n * Displays the relative time between a given timestamp and the current time.\n * You can display a custom message for given time intervals by passing an array of custom intervals.\n *\n * @example\n * ```jsx\n * <caption>Display \"last hour\" if the timestamp is less than an hour ago</caption>\n * <RelativeTime\n * timestamp={new Date('2021-01-01')}\n * customIntervals={[\n * { unit: 'hours', threshold: 1, text: 'last hour' },\n * ]}\n * ```\n */\nconst RelativeTime = React.forwardRef<HTMLTimeElement, RelativeTimeProps>(\n ({ timestamp, customIntervals = [], ...restProps }, forwardedRef) => {\n const { formatRelativeTime, formatDate, formatTime } = useIntl();\n\n /**\n * TODO: make this auto-update, like a clock.\n */\n const interval = intervalToDuration({\n start: timestamp,\n end: Date.now(),\n // see https://github.com/date-fns/date-fns/issues/2891 – No idea why it's all partial it returns it every time.\n }) as Required<Duration>;\n\n const unit = intervals.find((intervalUnit) => {\n return interval[intervalUnit] > 0 && Object.keys(interval).includes(intervalUnit);\n })!;\n\n const relativeTime = isPast(timestamp) ? -interval[unit] : interval[unit];\n\n // Display custom text if interval is less than the threshold\n const customInterval = customIntervals.find(\n (custom) => interval[custom.unit] < custom.threshold\n );\n\n const displayText = customInterval\n ? customInterval.text\n : formatRelativeTime(relativeTime, unit, { numeric: 'auto' });\n\n return (\n <time\n ref={forwardedRef}\n dateTime={timestamp.toISOString()}\n role=\"time\"\n title={`${formatDate(timestamp)} ${formatTime(timestamp)}`}\n {...restProps}\n >\n {displayText}\n </time>\n );\n }\n);\n\nexport { RelativeTime };\nexport type { CustomInterval, RelativeTimeProps };\n","import * as React from 'react';\n\nimport { Box, Flex, IconButton, Typography, useCollator, Link } from '@strapi/design-system';\nimport { Pencil, Trash } from '@strapi/icons';\nimport { useIntl } from 'react-intl';\nimport { NavLink, useNavigate } from 'react-router-dom';\nimport styled from 'styled-components';\n\nimport { ApiToken } from '../../../../../../shared/contracts/api-token';\nimport { SanitizedTransferToken } from '../../../../../../shared/contracts/transfer';\nimport { ConfirmDialog } from '../../../../components/ConfirmDialog';\nimport { RelativeTime } from '../../../../components/RelativeTime';\nimport { Table as TableImpl } from '../../../../components/Table';\nimport { useTracking } from '../../../../features/Tracking';\nimport { useQueryParams } from '../../../../hooks/useQueryParams';\n\nimport type { Data } from '@strapi/types';\n\n/* -------------------------------------------------------------------------------------------------\n * Table\n * -----------------------------------------------------------------------------------------------*/\n\ninterface TableProps\n extends Pick<TableImpl.Props<SanitizedTransferToken | ApiToken>, 'headers' | 'isLoading'> {\n onConfirmDelete: (id: Data.ID) => void;\n permissions: {\n canRead: boolean;\n canDelete: boolean;\n canUpdate: boolean;\n };\n tokens: SanitizedTransferToken[] | ApiToken[];\n tokenType: 'api-token' | 'transfer-token';\n}\n\nconst Table = ({\n permissions,\n headers = [],\n isLoading = false,\n tokens = [],\n onConfirmDelete,\n tokenType,\n}: TableProps) => {\n const [{ query }] = useQueryParams<{ sort?: string }>();\n const { formatMessage, locale } = useIntl();\n const [, sortOrder] = query && query.sort ? query.sort.split(':') : [undefined, 'ASC'];\n const navigate = useNavigate();\n const { trackUsage } = useTracking();\n const formatter = useCollator(locale);\n\n const sortedTokens = [...tokens].sort((a, b) => {\n return sortOrder === 'DESC'\n ? formatter.compare(b.name, a.name)\n : formatter.compare(a.name, b.name);\n });\n\n const { canDelete, canUpdate, canRead } = permissions;\n\n const handleRowClick = (id: Data.ID) => () => {\n if (canRead) {\n trackUsage('willEditTokenFromList', {\n tokenType,\n });\n navigate(id.toString());\n }\n };\n\n return (\n <TableImpl.Root headers={headers} rows={sortedTokens} isLoading={isLoading}>\n <TableImpl.Content>\n <TableImpl.Head>\n {headers.map((header) => (\n <TableImpl.HeaderCell key={header.name} {...header} />\n ))}\n </TableImpl.Head>\n <TableImpl.Empty />\n <TableImpl.Loading />\n <TableImpl.Body>\n {sortedTokens.map((token) => (\n <TableImpl.Row key={token.id} onClick={handleRowClick(token.id)}>\n <TableImpl.Cell maxWidth=\"25rem\">\n <Typography textColor=\"neutral800\" fontWeight=\"bold\" ellipsis>\n {token.name}\n </Typography>\n </TableImpl.Cell>\n <TableImpl.Cell maxWidth=\"25rem\">\n <Typography textColor=\"neutral800\" ellipsis>\n {token.description}\n </Typography>\n </TableImpl.Cell>\n <TableImpl.Cell>\n <Typography textColor=\"neutral800\">\n {/* @ts-expect-error One of the tokens doesn't have createdAt */}\n <RelativeTime timestamp={new Date(token.createdAt)} />\n </Typography>\n </TableImpl.Cell>\n <TableImpl.Cell>\n {token.lastUsedAt && (\n <Typography textColor=\"neutral800\">\n <RelativeTime\n timestamp={new Date(token.lastUsedAt)}\n customIntervals={[\n {\n unit: 'hours',\n threshold: 1,\n text: formatMessage({\n id: 'Settings.apiTokens.lastHour',\n defaultMessage: 'last hour',\n }),\n },\n ]}\n />\n </Typography>\n )}\n </TableImpl.Cell>\n {canUpdate || canRead || canDelete ? (\n <TableImpl.Cell>\n <Flex justifyContent=\"end\">\n {canUpdate && <UpdateButton tokenName={token.name} tokenId={token.id} />}\n {canDelete && (\n <DeleteButton\n tokenName={token.name}\n onClickDelete={() => onConfirmDelete?.(token.id)}\n tokenType={tokenType}\n />\n )}\n </Flex>\n </TableImpl.Cell>\n ) : null}\n </TableImpl.Row>\n ))}\n </TableImpl.Body>\n </TableImpl.Content>\n </TableImpl.Root>\n );\n};\n\n/* -------------------------------------------------------------------------------------------------\n * CRUD Buttons\n * -----------------------------------------------------------------------------------------------*/\n\nconst MESSAGES_MAP = {\n edit: {\n id: 'app.component.table.edit',\n defaultMessage: 'Edit {target}',\n },\n read: {\n id: 'app.component.table.read',\n defaultMessage: 'Read {target}',\n },\n};\n\ninterface DefaultButtonProps {\n tokenName: string;\n tokenId: Data.ID;\n buttonType?: 'edit' | 'read';\n children: React.ReactNode;\n}\n\nconst DefaultButton = ({\n tokenName,\n tokenId,\n buttonType = 'edit',\n children,\n}: DefaultButtonProps) => {\n const { formatMessage } = useIntl();\n\n return (\n <LinkStyled\n forwardedAs={NavLink}\n to={tokenId.toString()}\n title={formatMessage(MESSAGES_MAP[buttonType], { target: tokenName })}\n >\n {children}\n </LinkStyled>\n );\n};\n\nconst LinkStyled = styled(Link)`\n svg {\n path {\n fill: ${({ theme }) => theme.colors.neutral500};\n }\n }\n\n &:hover,\n &:focus {\n svg {\n path {\n fill: ${({ theme }) => theme.colors.neutral800};\n }\n }\n }\n`;\n\ninterface DeleteButtonProps extends Pick<ButtonProps, 'tokenName'>, Pick<TableProps, 'tokenType'> {\n onClickDelete: () => void;\n}\n\nconst DeleteButton = ({ tokenName, onClickDelete, tokenType }: DeleteButtonProps) => {\n const { formatMessage } = useIntl();\n const { trackUsage } = useTracking();\n const [showConfirmDialog, setShowConfirmDialog] = React.useState(false);\n const handleClickDelete = () => {\n setShowConfirmDialog(false);\n trackUsage('willDeleteToken', {\n tokenType,\n });\n onClickDelete();\n };\n\n return (\n <Box paddingLeft={1} onClick={(e) => e.stopPropagation()}>\n <IconButton\n onClick={() => {\n setShowConfirmDialog(true);\n }}\n label={formatMessage(\n {\n id: 'global.delete-target',\n defaultMessage: 'Delete {target}',\n },\n { target: `${tokenName}` }\n )}\n name=\"delete\"\n borderWidth={0}\n icon={<Trash />}\n />\n <ConfirmDialog\n onClose={() => setShowConfirmDialog(false)}\n onConfirm={handleClickDelete}\n isOpen={showConfirmDialog}\n />\n </Box>\n );\n};\n\ninterface ButtonProps {\n tokenName: string;\n tokenId: Data.ID;\n}\n\nconst UpdateButton = ({ tokenName, tokenId }: ButtonProps) => {\n return (\n <DefaultButton tokenName={tokenName} tokenId={tokenId}>\n <Pencil width={12} />\n </DefaultButton>\n );\n};\n\nexport { Table };\nexport type { TableProps };\n"],"names":["TableImpl"],"mappings":"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"}
|
|
@@ -3,14 +3,13 @@
|
|
|
3
3
|
const jsxRuntime = require('react/jsx-runtime');
|
|
4
4
|
const React = require('react');
|
|
5
5
|
const designSystem = require('@strapi/design-system');
|
|
6
|
-
const v2 = require('@strapi/design-system/v2');
|
|
7
6
|
const icons = require('@strapi/icons');
|
|
8
7
|
const reactIntl = require('react-intl');
|
|
9
8
|
const reactRouterDom = require('react-router-dom');
|
|
10
9
|
const styled = require('styled-components');
|
|
11
|
-
const index = require('./index-
|
|
10
|
+
const index = require('./index-FJLgZ-Wg.js');
|
|
12
11
|
const dateFns = require('date-fns');
|
|
13
|
-
const rbac = require('./rbac-
|
|
12
|
+
const rbac = require('./rbac-xgYdpUSq.js');
|
|
14
13
|
|
|
15
14
|
const _interopDefault = e => e && e.__esModule ? e : { default: e };
|
|
16
15
|
|
|
@@ -97,8 +96,8 @@ const Table = ({
|
|
|
97
96
|
/* @__PURE__ */ jsxRuntime.jsx(index.Table.Empty, {}),
|
|
98
97
|
/* @__PURE__ */ jsxRuntime.jsx(index.Table.Loading, {}),
|
|
99
98
|
/* @__PURE__ */ jsxRuntime.jsx(index.Table.Body, { children: sortedTokens.map((token) => /* @__PURE__ */ jsxRuntime.jsxs(index.Table.Row, { onClick: handleRowClick(token.id), children: [
|
|
100
|
-
/* @__PURE__ */ jsxRuntime.jsx(index.Table.Cell, { maxWidth:
|
|
101
|
-
/* @__PURE__ */ jsxRuntime.jsx(index.Table.Cell, { maxWidth:
|
|
99
|
+
/* @__PURE__ */ jsxRuntime.jsx(index.Table.Cell, { maxWidth: "25rem", children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { textColor: "neutral800", fontWeight: "bold", ellipsis: true, children: token.name }) }),
|
|
100
|
+
/* @__PURE__ */ jsxRuntime.jsx(index.Table.Cell, { maxWidth: "25rem", children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { textColor: "neutral800", ellipsis: true, children: token.description }) }),
|
|
102
101
|
/* @__PURE__ */ jsxRuntime.jsx(index.Table.Cell, { children: /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { textColor: "neutral800", children: /* @__PURE__ */ jsxRuntime.jsx(RelativeTime, { timestamp: new Date(token.createdAt) }) }) }),
|
|
103
102
|
/* @__PURE__ */ jsxRuntime.jsx(index.Table.Cell, { children: token.lastUsedAt && /* @__PURE__ */ jsxRuntime.jsx(designSystem.Typography, { textColor: "neutral800", children: /* @__PURE__ */ jsxRuntime.jsx(
|
|
104
103
|
RelativeTime,
|
|
@@ -157,7 +156,7 @@ const DefaultButton = ({
|
|
|
157
156
|
}
|
|
158
157
|
);
|
|
159
158
|
};
|
|
160
|
-
const LinkStyled = styled__default.default(
|
|
159
|
+
const LinkStyled = styled__default.default(designSystem.Link)`
|
|
161
160
|
svg {
|
|
162
161
|
path {
|
|
163
162
|
fill: ${({ theme }) => theme.colors.neutral500};
|
|
@@ -218,4 +217,4 @@ const UpdateButton = ({ tokenName, tokenId }) => {
|
|
|
218
217
|
};
|
|
219
218
|
|
|
220
219
|
exports.Table = Table;
|
|
221
|
-
//# sourceMappingURL=Table-
|
|
220
|
+
//# sourceMappingURL=Table-HXu3Nz4W.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Table-HXu3Nz4W.js","sources":["../../admin/src/components/RelativeTime.tsx","../../admin/src/pages/Settings/components/Tokens/Table.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport { Duration, intervalToDuration, isPast } from 'date-fns';\nimport { useIntl } from 'react-intl';\n\nconst intervals: Array<keyof Duration> = ['years', 'months', 'days', 'hours', 'minutes', 'seconds'];\n\ninterface CustomInterval {\n unit: keyof Duration;\n text: string;\n threshold: number;\n}\n\ninterface RelativeTimeProps extends React.ComponentPropsWithoutRef<'time'> {\n timestamp: Date;\n customIntervals?: CustomInterval[];\n}\n\n/**\n * Displays the relative time between a given timestamp and the current time.\n * You can display a custom message for given time intervals by passing an array of custom intervals.\n *\n * @example\n * ```jsx\n * <caption>Display \"last hour\" if the timestamp is less than an hour ago</caption>\n * <RelativeTime\n * timestamp={new Date('2021-01-01')}\n * customIntervals={[\n * { unit: 'hours', threshold: 1, text: 'last hour' },\n * ]}\n * ```\n */\nconst RelativeTime = React.forwardRef<HTMLTimeElement, RelativeTimeProps>(\n ({ timestamp, customIntervals = [], ...restProps }, forwardedRef) => {\n const { formatRelativeTime, formatDate, formatTime } = useIntl();\n\n /**\n * TODO: make this auto-update, like a clock.\n */\n const interval = intervalToDuration({\n start: timestamp,\n end: Date.now(),\n // see https://github.com/date-fns/date-fns/issues/2891 – No idea why it's all partial it returns it every time.\n }) as Required<Duration>;\n\n const unit = intervals.find((intervalUnit) => {\n return interval[intervalUnit] > 0 && Object.keys(interval).includes(intervalUnit);\n })!;\n\n const relativeTime = isPast(timestamp) ? -interval[unit] : interval[unit];\n\n // Display custom text if interval is less than the threshold\n const customInterval = customIntervals.find(\n (custom) => interval[custom.unit] < custom.threshold\n );\n\n const displayText = customInterval\n ? customInterval.text\n : formatRelativeTime(relativeTime, unit, { numeric: 'auto' });\n\n return (\n <time\n ref={forwardedRef}\n dateTime={timestamp.toISOString()}\n role=\"time\"\n title={`${formatDate(timestamp)} ${formatTime(timestamp)}`}\n {...restProps}\n >\n {displayText}\n </time>\n );\n }\n);\n\nexport { RelativeTime };\nexport type { CustomInterval, RelativeTimeProps };\n","import * as React from 'react';\n\nimport { Box, Flex, IconButton, Typography, useCollator, Link } from '@strapi/design-system';\nimport { Pencil, Trash } from '@strapi/icons';\nimport { useIntl } from 'react-intl';\nimport { NavLink, useNavigate } from 'react-router-dom';\nimport styled from 'styled-components';\n\nimport { ApiToken } from '../../../../../../shared/contracts/api-token';\nimport { SanitizedTransferToken } from '../../../../../../shared/contracts/transfer';\nimport { ConfirmDialog } from '../../../../components/ConfirmDialog';\nimport { RelativeTime } from '../../../../components/RelativeTime';\nimport { Table as TableImpl } from '../../../../components/Table';\nimport { useTracking } from '../../../../features/Tracking';\nimport { useQueryParams } from '../../../../hooks/useQueryParams';\n\nimport type { Data } from '@strapi/types';\n\n/* -------------------------------------------------------------------------------------------------\n * Table\n * -----------------------------------------------------------------------------------------------*/\n\ninterface TableProps\n extends Pick<TableImpl.Props<SanitizedTransferToken | ApiToken>, 'headers' | 'isLoading'> {\n onConfirmDelete: (id: Data.ID) => void;\n permissions: {\n canRead: boolean;\n canDelete: boolean;\n canUpdate: boolean;\n };\n tokens: SanitizedTransferToken[] | ApiToken[];\n tokenType: 'api-token' | 'transfer-token';\n}\n\nconst Table = ({\n permissions,\n headers = [],\n isLoading = false,\n tokens = [],\n onConfirmDelete,\n tokenType,\n}: TableProps) => {\n const [{ query }] = useQueryParams<{ sort?: string }>();\n const { formatMessage, locale } = useIntl();\n const [, sortOrder] = query && query.sort ? query.sort.split(':') : [undefined, 'ASC'];\n const navigate = useNavigate();\n const { trackUsage } = useTracking();\n const formatter = useCollator(locale);\n\n const sortedTokens = [...tokens].sort((a, b) => {\n return sortOrder === 'DESC'\n ? formatter.compare(b.name, a.name)\n : formatter.compare(a.name, b.name);\n });\n\n const { canDelete, canUpdate, canRead } = permissions;\n\n const handleRowClick = (id: Data.ID) => () => {\n if (canRead) {\n trackUsage('willEditTokenFromList', {\n tokenType,\n });\n navigate(id.toString());\n }\n };\n\n return (\n <TableImpl.Root headers={headers} rows={sortedTokens} isLoading={isLoading}>\n <TableImpl.Content>\n <TableImpl.Head>\n {headers.map((header) => (\n <TableImpl.HeaderCell key={header.name} {...header} />\n ))}\n </TableImpl.Head>\n <TableImpl.Empty />\n <TableImpl.Loading />\n <TableImpl.Body>\n {sortedTokens.map((token) => (\n <TableImpl.Row key={token.id} onClick={handleRowClick(token.id)}>\n <TableImpl.Cell maxWidth=\"25rem\">\n <Typography textColor=\"neutral800\" fontWeight=\"bold\" ellipsis>\n {token.name}\n </Typography>\n </TableImpl.Cell>\n <TableImpl.Cell maxWidth=\"25rem\">\n <Typography textColor=\"neutral800\" ellipsis>\n {token.description}\n </Typography>\n </TableImpl.Cell>\n <TableImpl.Cell>\n <Typography textColor=\"neutral800\">\n {/* @ts-expect-error One of the tokens doesn't have createdAt */}\n <RelativeTime timestamp={new Date(token.createdAt)} />\n </Typography>\n </TableImpl.Cell>\n <TableImpl.Cell>\n {token.lastUsedAt && (\n <Typography textColor=\"neutral800\">\n <RelativeTime\n timestamp={new Date(token.lastUsedAt)}\n customIntervals={[\n {\n unit: 'hours',\n threshold: 1,\n text: formatMessage({\n id: 'Settings.apiTokens.lastHour',\n defaultMessage: 'last hour',\n }),\n },\n ]}\n />\n </Typography>\n )}\n </TableImpl.Cell>\n {canUpdate || canRead || canDelete ? (\n <TableImpl.Cell>\n <Flex justifyContent=\"end\">\n {canUpdate && <UpdateButton tokenName={token.name} tokenId={token.id} />}\n {canDelete && (\n <DeleteButton\n tokenName={token.name}\n onClickDelete={() => onConfirmDelete?.(token.id)}\n tokenType={tokenType}\n />\n )}\n </Flex>\n </TableImpl.Cell>\n ) : null}\n </TableImpl.Row>\n ))}\n </TableImpl.Body>\n </TableImpl.Content>\n </TableImpl.Root>\n );\n};\n\n/* -------------------------------------------------------------------------------------------------\n * CRUD Buttons\n * -----------------------------------------------------------------------------------------------*/\n\nconst MESSAGES_MAP = {\n edit: {\n id: 'app.component.table.edit',\n defaultMessage: 'Edit {target}',\n },\n read: {\n id: 'app.component.table.read',\n defaultMessage: 'Read {target}',\n },\n};\n\ninterface DefaultButtonProps {\n tokenName: string;\n tokenId: Data.ID;\n buttonType?: 'edit' | 'read';\n children: React.ReactNode;\n}\n\nconst DefaultButton = ({\n tokenName,\n tokenId,\n buttonType = 'edit',\n children,\n}: DefaultButtonProps) => {\n const { formatMessage } = useIntl();\n\n return (\n <LinkStyled\n forwardedAs={NavLink}\n to={tokenId.toString()}\n title={formatMessage(MESSAGES_MAP[buttonType], { target: tokenName })}\n >\n {children}\n </LinkStyled>\n );\n};\n\nconst LinkStyled = styled(Link)`\n svg {\n path {\n fill: ${({ theme }) => theme.colors.neutral500};\n }\n }\n\n &:hover,\n &:focus {\n svg {\n path {\n fill: ${({ theme }) => theme.colors.neutral800};\n }\n }\n }\n`;\n\ninterface DeleteButtonProps extends Pick<ButtonProps, 'tokenName'>, Pick<TableProps, 'tokenType'> {\n onClickDelete: () => void;\n}\n\nconst DeleteButton = ({ tokenName, onClickDelete, tokenType }: DeleteButtonProps) => {\n const { formatMessage } = useIntl();\n const { trackUsage } = useTracking();\n const [showConfirmDialog, setShowConfirmDialog] = React.useState(false);\n const handleClickDelete = () => {\n setShowConfirmDialog(false);\n trackUsage('willDeleteToken', {\n tokenType,\n });\n onClickDelete();\n };\n\n return (\n <Box paddingLeft={1} onClick={(e) => e.stopPropagation()}>\n <IconButton\n onClick={() => {\n setShowConfirmDialog(true);\n }}\n label={formatMessage(\n {\n id: 'global.delete-target',\n defaultMessage: 'Delete {target}',\n },\n { target: `${tokenName}` }\n )}\n name=\"delete\"\n borderWidth={0}\n icon={<Trash />}\n />\n <ConfirmDialog\n onClose={() => setShowConfirmDialog(false)}\n onConfirm={handleClickDelete}\n isOpen={showConfirmDialog}\n />\n </Box>\n );\n};\n\ninterface ButtonProps {\n tokenName: string;\n tokenId: Data.ID;\n}\n\nconst UpdateButton = ({ tokenName, tokenId }: ButtonProps) => {\n return (\n <DefaultButton tokenName={tokenName} tokenId={tokenId}>\n <Pencil width={12} />\n </DefaultButton>\n );\n};\n\nexport { Table };\nexport type { TableProps };\n"],"names":["React","useIntl","intervalToDuration","isPast","jsx","useQueryParams","useNavigate","useTracking","useCollator","TableImpl","jsxs","Typography","Flex","NavLink","styled","Link","Box","IconButton","Trash","ConfirmDialog","Pencil"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAKA,MAAM,YAAmC,CAAC,OAAA,EAAS,UAAU,MAAQ,EAAA,OAAA,EAAS,WAAW,SAAS,CAAA,CAAA;AA2BlG,MAAM,eAAeA,gBAAM,CAAA,UAAA;AAAA,EACzB,CAAC,EAAE,SAAW,EAAA,eAAA,GAAkB,EAAI,EAAA,GAAG,SAAU,EAAA,EAAG,YAAiB,KAAA;AACnE,IAAA,MAAM,EAAE,kBAAA,EAAoB,UAAY,EAAA,UAAA,KAAeC,iBAAQ,EAAA,CAAA;AAK/D,IAAA,MAAM,WAAWC,0BAAmB,CAAA;AAAA,MAClC,KAAO,EAAA,SAAA;AAAA,MACP,GAAA,EAAK,KAAK,GAAI,EAAA;AAAA;AAAA,KAEf,CAAA,CAAA;AAED,IAAA,MAAM,IAAO,GAAA,SAAA,CAAU,IAAK,CAAA,CAAC,YAAiB,KAAA;AAC5C,MAAO,OAAA,QAAA,CAAS,YAAY,CAAI,GAAA,CAAA,IAAK,OAAO,IAAK,CAAA,QAAQ,CAAE,CAAA,QAAA,CAAS,YAAY,CAAA,CAAA;AAAA,KACjF,CAAA,CAAA;AAED,IAAM,MAAA,YAAA,GAAeC,eAAO,SAAS,CAAA,GAAI,CAAC,QAAS,CAAA,IAAI,CAAI,GAAA,QAAA,CAAS,IAAI,CAAA,CAAA;AAGxE,IAAA,MAAM,iBAAiB,eAAgB,CAAA,IAAA;AAAA,MACrC,CAAC,MAAW,KAAA,QAAA,CAAS,MAAO,CAAA,IAAI,IAAI,MAAO,CAAA,SAAA;AAAA,KAC7C,CAAA;AAEA,IAAM,MAAA,WAAA,GAAc,cAChB,GAAA,cAAA,CAAe,IACf,GAAA,kBAAA,CAAmB,cAAc,IAAM,EAAA,EAAE,OAAS,EAAA,MAAA,EAAQ,CAAA,CAAA;AAE9D,IACE,uBAAAC,cAAA;AAAA,MAAC,MAAA;AAAA,MAAA;AAAA,QACC,GAAK,EAAA,YAAA;AAAA,QACL,QAAA,EAAU,UAAU,WAAY,EAAA;AAAA,QAChC,IAAK,EAAA,MAAA;AAAA,QACL,KAAA,EAAO,GAAG,UAAW,CAAA,SAAS,CAAC,CAAI,CAAA,EAAA,UAAA,CAAW,SAAS,CAAC,CAAA,CAAA;AAAA,QACvD,GAAG,SAAA;AAAA,QAEH,QAAA,EAAA,WAAA;AAAA,OAAA;AAAA,KACH,CAAA;AAAA,GAEJ;AACF,CAAA;;ACtCA,MAAM,QAAQ,CAAC;AAAA,EACb,WAAA;AAAA,EACA,UAAU,EAAC;AAAA,EACX,SAAY,GAAA,KAAA;AAAA,EACZ,SAAS,EAAC;AAAA,EACV,eAAA;AAAA,EACA,SAAA;AACF,CAAkB,KAAA;AAChB,EAAA,MAAM,CAAC,EAAE,KAAM,EAAC,IAAIC,oBAAkC,EAAA,CAAA;AACtD,EAAA,MAAM,EAAE,aAAA,EAAe,MAAO,EAAA,GAAIJ,iBAAQ,EAAA,CAAA;AAC1C,EAAA,MAAM,GAAG,SAAS,CAAA,GAAI,SAAS,KAAM,CAAA,IAAA,GAAO,KAAM,CAAA,IAAA,CAAK,KAAM,CAAA,GAAG,CAAI,GAAA,CAAC,QAAW,KAAK,CAAA,CAAA;AACrF,EAAA,MAAM,WAAWK,0BAAY,EAAA,CAAA;AAC7B,EAAM,MAAA,EAAE,UAAW,EAAA,GAAIC,gBAAY,EAAA,CAAA;AACnC,EAAM,MAAA,SAAA,GAAYC,yBAAY,MAAM,CAAA,CAAA;AAEpC,EAAM,MAAA,YAAA,GAAe,CAAC,GAAG,MAAM,EAAE,IAAK,CAAA,CAAC,GAAG,CAAM,KAAA;AAC9C,IAAA,OAAO,SAAc,KAAA,MAAA,GACjB,SAAU,CAAA,OAAA,CAAQ,EAAE,IAAM,EAAA,CAAA,CAAE,IAAI,CAAA,GAChC,SAAU,CAAA,OAAA,CAAQ,CAAE,CAAA,IAAA,EAAM,EAAE,IAAI,CAAA,CAAA;AAAA,GACrC,CAAA,CAAA;AAED,EAAA,MAAM,EAAE,SAAA,EAAW,SAAW,EAAA,OAAA,EAAY,GAAA,WAAA,CAAA;AAE1C,EAAM,MAAA,cAAA,GAAiB,CAAC,EAAA,KAAgB,MAAM;AAC5C,IAAA,IAAI,OAAS,EAAA;AACX,MAAA,UAAA,CAAW,uBAAyB,EAAA;AAAA,QAClC,SAAA;AAAA,OACD,CAAA,CAAA;AACD,MAAS,QAAA,CAAA,EAAA,CAAG,UAAU,CAAA,CAAA;AAAA,KACxB;AAAA,GACF,CAAA;AAEA,EACE,uBAAAJ,cAAA,CAACK,WAAU,CAAA,IAAA,EAAV,EAAe,OAAA,EAAkB,IAAM,EAAA,YAAA,EAAc,SACpD,EAAA,QAAA,kBAAAC,eAAA,CAACD,WAAU,CAAA,OAAA,EAAV,EACC,QAAA,EAAA;AAAA,oBAAAL,cAAA,CAACK,YAAU,IAAV,EAAA,EACE,QAAQ,EAAA,OAAA,CAAA,GAAA,CAAI,CAAC,MACZ,qBAAAL,cAAA,CAACK,WAAU,CAAA,UAAA,EAAV,EAAwC,GAAG,MAAA,EAAA,EAAjB,MAAO,CAAA,IAAkB,CACrD,CACH,EAAA,CAAA;AAAA,oBACAL,cAAA,CAACK,WAAU,CAAA,KAAA,EAAV,EAAgB,CAAA;AAAA,oBACjBL,cAAA,CAACK,WAAU,CAAA,OAAA,EAAV,EAAkB,CAAA;AAAA,mCAClBA,WAAU,CAAA,IAAA,EAAV,EACE,QAAA,EAAA,YAAA,CAAa,IAAI,CAAC,KAAA,qBAChBC,eAAA,CAAAD,WAAA,CAAU,KAAV,EAA6B,OAAA,EAAS,cAAe,CAAA,KAAA,CAAM,EAAE,CAC5D,EAAA,QAAA,EAAA;AAAA,sBAAAL,cAAA,CAACK,WAAU,CAAA,IAAA,EAAV,EAAe,QAAA,EAAS,SACvB,QAAC,kBAAAL,cAAA,CAAAO,uBAAA,EAAA,EAAW,SAAU,EAAA,YAAA,EAAa,YAAW,MAAO,EAAA,QAAA,EAAQ,IAC1D,EAAA,QAAA,EAAA,KAAA,CAAM,MACT,CACF,EAAA,CAAA;AAAA,sBACCP,cAAA,CAAAK,WAAA,CAAU,IAAV,EAAA,EAAe,UAAS,OACvB,EAAA,QAAA,kBAAAL,cAAA,CAACO,uBAAW,EAAA,EAAA,SAAA,EAAU,YAAa,EAAA,QAAA,EAAQ,IACxC,EAAA,QAAA,EAAA,KAAA,CAAM,aACT,CACF,EAAA,CAAA;AAAA,qCACCF,WAAU,CAAA,IAAA,EAAV,EACC,QAAA,kBAAAL,cAAA,CAACO,2BAAW,SAAU,EAAA,YAAA,EAEpB,QAAC,kBAAAP,cAAA,CAAA,YAAA,EAAA,EAAa,WAAW,IAAI,IAAA,CAAK,MAAM,SAAS,CAAA,EAAG,GACtD,CACF,EAAA,CAAA;AAAA,sBACAA,cAAA,CAACK,YAAU,IAAV,EAAA,EACE,gBAAM,UACL,oBAAAL,cAAA,CAACO,uBAAW,EAAA,EAAA,SAAA,EAAU,YACpB,EAAA,QAAA,kBAAAP,cAAA;AAAA,QAAC,YAAA;AAAA,QAAA;AAAA,UACC,SAAW,EAAA,IAAI,IAAK,CAAA,KAAA,CAAM,UAAU,CAAA;AAAA,UACpC,eAAiB,EAAA;AAAA,YACf;AAAA,cACE,IAAM,EAAA,OAAA;AAAA,cACN,SAAW,EAAA,CAAA;AAAA,cACX,MAAM,aAAc,CAAA;AAAA,gBAClB,EAAI,EAAA,6BAAA;AAAA,gBACJ,cAAgB,EAAA,WAAA;AAAA,eACjB,CAAA;AAAA,aACH;AAAA,WACF;AAAA,SAAA;AAAA,SAEJ,CAEJ,EAAA,CAAA;AAAA,MACC,SAAA,IAAa,OAAW,IAAA,SAAA,mBACtBA,cAAA,CAAAK,WAAA,CAAU,MAAV,EACC,QAAA,kBAAAC,eAAA,CAACE,iBAAK,EAAA,EAAA,cAAA,EAAe,KAClB,EAAA,QAAA,EAAA;AAAA,QAAA,SAAA,mCAAc,YAAa,EAAA,EAAA,SAAA,EAAW,MAAM,IAAM,EAAA,OAAA,EAAS,MAAM,EAAI,EAAA,CAAA;AAAA,QACrE,SACC,oBAAAR,cAAA;AAAA,UAAC,YAAA;AAAA,UAAA;AAAA,YACC,WAAW,KAAM,CAAA,IAAA;AAAA,YACjB,aAAe,EAAA,MAAM,eAAkB,GAAA,KAAA,CAAM,EAAE,CAAA;AAAA,YAC/C,SAAA;AAAA,WAAA;AAAA,SACF;AAAA,OAAA,EAEJ,GACF,CACE,GAAA,IAAA;AAAA,KAjDc,EAAA,EAAA,KAAA,CAAM,EAkD1B,CACD,CACH,EAAA,CAAA;AAAA,GAAA,EACF,CACF,EAAA,CAAA,CAAA;AAEJ,EAAA;AAMA,MAAM,YAAe,GAAA;AAAA,EACnB,IAAM,EAAA;AAAA,IACJ,EAAI,EAAA,0BAAA;AAAA,IACJ,cAAgB,EAAA,eAAA;AAAA,GAClB;AAAA,EACA,IAAM,EAAA;AAAA,IACJ,EAAI,EAAA,0BAAA;AAAA,IACJ,cAAgB,EAAA,eAAA;AAAA,GAClB;AACF,CAAA,CAAA;AASA,MAAM,gBAAgB,CAAC;AAAA,EACrB,SAAA;AAAA,EACA,OAAA;AAAA,EACA,UAAa,GAAA,MAAA;AAAA,EACb,QAAA;AACF,CAA0B,KAAA;AACxB,EAAM,MAAA,EAAE,aAAc,EAAA,GAAIH,iBAAQ,EAAA,CAAA;AAElC,EACE,uBAAAG,cAAA;AAAA,IAAC,UAAA;AAAA,IAAA;AAAA,MACC,WAAa,EAAAS,sBAAA;AAAA,MACb,EAAA,EAAI,QAAQ,QAAS,EAAA;AAAA,MACrB,KAAA,EAAO,cAAc,YAAa,CAAA,UAAU,GAAG,EAAE,MAAA,EAAQ,WAAW,CAAA;AAAA,MAEnE,QAAA;AAAA,KAAA;AAAA,GACH,CAAA;AAEJ,CAAA,CAAA;AAEA,MAAM,UAAA,GAAaC,wBAAOC,iBAAI,CAAA,CAAA;AAAA;AAAA;AAAA,YAAA,EAGhB,CAAC,EAAE,KAAA,EAAY,KAAA,KAAA,CAAM,OAAO,UAAU,CAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,cAAA,EAQpC,CAAC,EAAE,KAAA,EAAY,KAAA,KAAA,CAAM,OAAO,UAAU,CAAA;AAAA;AAAA;AAAA;AAAA,CAAA,CAAA;AAUtD,MAAM,eAAe,CAAC,EAAE,SAAW,EAAA,aAAA,EAAe,WAAmC,KAAA;AACnF,EAAM,MAAA,EAAE,aAAc,EAAA,GAAId,iBAAQ,EAAA,CAAA;AAClC,EAAM,MAAA,EAAE,UAAW,EAAA,GAAIM,gBAAY,EAAA,CAAA;AACnC,EAAA,MAAM,CAAC,iBAAmB,EAAA,oBAAoB,CAAI,GAAAP,gBAAA,CAAM,SAAS,KAAK,CAAA,CAAA;AACtE,EAAA,MAAM,oBAAoB,MAAM;AAC9B,IAAA,oBAAA,CAAqB,KAAK,CAAA,CAAA;AAC1B,IAAA,UAAA,CAAW,iBAAmB,EAAA;AAAA,MAC5B,SAAA;AAAA,KACD,CAAA,CAAA;AACD,IAAc,aAAA,EAAA,CAAA;AAAA,GAChB,CAAA;AAEA,EACE,uBAAAU,eAAA,CAACM,oBAAI,WAAa,EAAA,CAAA,EAAG,SAAS,CAAC,CAAA,KAAM,CAAE,CAAA,eAAA,EACrC,EAAA,QAAA,EAAA;AAAA,oBAAAZ,cAAA;AAAA,MAACa,uBAAA;AAAA,MAAA;AAAA,QACC,SAAS,MAAM;AACb,UAAA,oBAAA,CAAqB,IAAI,CAAA,CAAA;AAAA,SAC3B;AAAA,QACA,KAAO,EAAA,aAAA;AAAA,UACL;AAAA,YACE,EAAI,EAAA,sBAAA;AAAA,YACJ,cAAgB,EAAA,iBAAA;AAAA,WAClB;AAAA,UACA,EAAE,MAAA,EAAQ,CAAG,EAAA,SAAS,CAAG,CAAA,EAAA;AAAA,SAC3B;AAAA,QACA,IAAK,EAAA,QAAA;AAAA,QACL,WAAa,EAAA,CAAA;AAAA,QACb,IAAA,iCAAOC,WAAM,EAAA,EAAA,CAAA;AAAA,OAAA;AAAA,KACf;AAAA,oBACAd,cAAA;AAAA,MAACe,mBAAA;AAAA,MAAA;AAAA,QACC,OAAA,EAAS,MAAM,oBAAA,CAAqB,KAAK,CAAA;AAAA,QACzC,SAAW,EAAA,iBAAA;AAAA,QACX,MAAQ,EAAA,iBAAA;AAAA,OAAA;AAAA,KACV;AAAA,GACF,EAAA,CAAA,CAAA;AAEJ,CAAA,CAAA;AAOA,MAAM,YAAe,GAAA,CAAC,EAAE,SAAA,EAAW,SAA2B,KAAA;AAC5D,EACE,uBAAAf,cAAA,CAAC,iBAAc,SAAsB,EAAA,OAAA,EACnC,yCAACgB,YAAO,EAAA,EAAA,KAAA,EAAO,IAAI,CACrB,EAAA,CAAA,CAAA;AAEJ,CAAA;;;;"}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
|
|
2
2
|
import * as React from 'react';
|
|
3
3
|
import { HeaderLayout, Flex, Button, IconButton, SingleSelect, SingleSelectOption, Typography, Textarea, TextInput } from '@strapi/design-system';
|
|
4
|
-
import { Check,
|
|
4
|
+
import { Check, ArrowClockwise, Duplicate, Key } from '@strapi/icons';
|
|
5
5
|
import { useIntl } from 'react-intl';
|
|
6
|
-
import { B as BackButton, C as ConfirmDialog, t as useClipboard } from './index-
|
|
7
|
-
import { u as useNotification, f as useAPIErrorHandler, d as useTracking } from './rbac-
|
|
8
|
-
import {
|
|
9
|
-
import { C as ContentBox } from './ContentBox-
|
|
6
|
+
import { B as BackButton, C as ConfirmDialog, t as useClipboard } from './index-7fPlAzj6.mjs';
|
|
7
|
+
import { u as useNotification, f as useAPIErrorHandler, d as useTracking } from './rbac-uVd0RAE5.mjs';
|
|
8
|
+
import { c as useRegenerateTokenMutation } from './admin-5SXhE_nJ.mjs';
|
|
9
|
+
import { C as ContentBox } from './ContentBox-DjmNTcxv.mjs';
|
|
10
10
|
import { format, addDays } from 'date-fns';
|
|
11
11
|
import * as locales from 'date-fns/locale';
|
|
12
12
|
|
|
@@ -50,7 +50,7 @@ const Regenerate = ({ onRegenerate, url }) => {
|
|
|
50
50
|
/* @__PURE__ */ jsx(
|
|
51
51
|
Button,
|
|
52
52
|
{
|
|
53
|
-
startIcon: /* @__PURE__ */ jsx(
|
|
53
|
+
startIcon: /* @__PURE__ */ jsx(ArrowClockwise, {}),
|
|
54
54
|
type: "button",
|
|
55
55
|
size: "S",
|
|
56
56
|
variant: "tertiary",
|
|
@@ -74,7 +74,7 @@ const Regenerate = ({ onRegenerate, url }) => {
|
|
|
74
74
|
endAction: /* @__PURE__ */ jsx(
|
|
75
75
|
Button,
|
|
76
76
|
{
|
|
77
|
-
startIcon: /* @__PURE__ */ jsx(
|
|
77
|
+
startIcon: /* @__PURE__ */ jsx(ArrowClockwise, {}),
|
|
78
78
|
loading: isLoadingConfirmation,
|
|
79
79
|
onClick: handleConfirmRegeneration,
|
|
80
80
|
children: formatMessage({
|
|
@@ -178,7 +178,7 @@ const TokenBox = ({ token, tokenType }) => {
|
|
|
178
178
|
onClick: handleClick(token),
|
|
179
179
|
borderWidth: 0,
|
|
180
180
|
icon: /* @__PURE__ */ jsx(Duplicate, {}),
|
|
181
|
-
style: { padding: 0, height: "
|
|
181
|
+
style: { padding: 0, height: "1.6rem" }
|
|
182
182
|
}
|
|
183
183
|
) }),
|
|
184
184
|
title: token || formatMessage({
|
|
@@ -355,4 +355,4 @@ const TokenTypeSelect = ({
|
|
|
355
355
|
};
|
|
356
356
|
|
|
357
357
|
export { FormHead as F, LifeSpanInput as L, TokenBox as T, TokenName as a, TokenDescription as b, TokenTypeSelect as c };
|
|
358
|
-
//# sourceMappingURL=TokenTypeSelect-
|
|
358
|
+
//# sourceMappingURL=TokenTypeSelect-kgKThMAL.mjs.map
|