@strapi/admin 4.25.10 → 4.25.12
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/_chunks/{AdminSeatInfo-Md5oKgdi.mjs → AdminSeatInfo-LsX5JLTX.mjs} +3 -3
- package/dist/_chunks/{AdminSeatInfo-Md5oKgdi.mjs.map → AdminSeatInfo-LsX5JLTX.mjs.map} +1 -1
- package/dist/_chunks/{AdminSeatInfo-6zKyZssa.js → AdminSeatInfo-lWb40pfG.js} +3 -3
- package/dist/_chunks/{AdminSeatInfo-6zKyZssa.js.map → AdminSeatInfo-lWb40pfG.js.map} +1 -1
- package/dist/_chunks/{AuthenticatedApp-Qy5uXoF3.js → AuthenticatedApp-dcHtbq_R.js} +20 -20
- package/dist/_chunks/{AuthenticatedApp-Qy5uXoF3.js.map → AuthenticatedApp-dcHtbq_R.js.map} +1 -1
- package/dist/_chunks/{AuthenticatedApp-MPoeoIOU.mjs → AuthenticatedApp-uuHA_S_x.mjs} +20 -20
- package/dist/_chunks/{AuthenticatedApp-MPoeoIOU.mjs.map → AuthenticatedApp-uuHA_S_x.mjs.map} +1 -1
- package/dist/_chunks/{CreateActionEE-FAHFAEmB.mjs → CreateActionEE-6bwrsKVR.mjs} +2 -2
- package/dist/_chunks/{CreateActionEE-FAHFAEmB.mjs.map → CreateActionEE-6bwrsKVR.mjs.map} +1 -1
- package/dist/_chunks/{CreateActionEE-upWBCmFE.js → CreateActionEE-xQwjED4v.js} +2 -2
- package/dist/_chunks/{CreateActionEE-upWBCmFE.js.map → CreateActionEE-xQwjED4v.js.map} +1 -1
- package/dist/_chunks/{CreatePage-X7AwX0nX.js → CreatePage-Bx3ADzvw.js} +6 -6
- package/dist/_chunks/{CreatePage-X7AwX0nX.js.map → CreatePage-Bx3ADzvw.js.map} +1 -1
- package/dist/_chunks/{CreatePage-hzhKSiJ0.mjs → CreatePage-OVRB-rR0.mjs} +6 -6
- package/dist/_chunks/{CreatePage-hzhKSiJ0.mjs.map → CreatePage-OVRB-rR0.mjs.map} +1 -1
- package/dist/_chunks/{CreatePage-x78bBThb.mjs → CreatePage-QeShDfja.mjs} +8 -8
- package/dist/_chunks/{CreatePage-x78bBThb.mjs.map → CreatePage-QeShDfja.mjs.map} +1 -1
- package/dist/_chunks/{CreatePage-0azPmoEO.js → CreatePage-XGYGLeZC.js} +3 -3
- package/dist/_chunks/{CreatePage-0azPmoEO.js.map → CreatePage-XGYGLeZC.js.map} +1 -1
- package/dist/_chunks/{CreatePage-GlDbH1lS.js → CreatePage-axH-tVyR.js} +8 -8
- package/dist/_chunks/{CreatePage-GlDbH1lS.js.map → CreatePage-axH-tVyR.js.map} +1 -1
- package/dist/_chunks/{CreatePage-wy4nvb2g.mjs → CreatePage-xuUUZC7P.mjs} +3 -3
- package/dist/_chunks/{CreatePage-wy4nvb2g.mjs.map → CreatePage-xuUUZC7P.mjs.map} +1 -1
- package/dist/_chunks/{CreateView-7FP7qeFz.js → CreateView-NRP7fjOK.js} +6 -6
- package/dist/_chunks/{CreateView-7FP7qeFz.js.map → CreateView-NRP7fjOK.js.map} +1 -1
- package/dist/_chunks/{CreateView-lrGthjNo.mjs → CreateView-jsnGO5_c.mjs} +6 -6
- package/dist/_chunks/{CreateView-lrGthjNo.mjs.map → CreateView-jsnGO5_c.mjs.map} +1 -1
- package/dist/_chunks/{CreateView-1pa9tRAV.js → CreateView-jzNzSUYh.js} +6 -6
- package/dist/_chunks/{CreateView-1pa9tRAV.js.map → CreateView-jzNzSUYh.js.map} +1 -1
- package/dist/_chunks/{CreateView-Xs06-Who.mjs → CreateView-v2RV10oV.mjs} +6 -6
- package/dist/_chunks/{CreateView-Xs06-Who.mjs.map → CreateView-v2RV10oV.mjs.map} +1 -1
- package/dist/_chunks/{EditPage-4DJ3Tjlb.js → EditPage-61DfFSGh.js} +9 -9
- package/dist/_chunks/{EditPage-4DJ3Tjlb.js.map → EditPage-61DfFSGh.js.map} +1 -1
- package/dist/_chunks/{EditPage-QI0u5f-m.mjs → EditPage-InmAfXiJ.mjs} +4 -4
- package/dist/_chunks/{EditPage-QI0u5f-m.mjs.map → EditPage-InmAfXiJ.mjs.map} +1 -1
- package/dist/_chunks/{EditPage-bT_J6RPv.js → EditPage-PFEjHgaO.js} +4 -4
- package/dist/_chunks/{EditPage-bT_J6RPv.js.map → EditPage-PFEjHgaO.js.map} +1 -1
- package/dist/_chunks/{EditPage-b1mM_YNY.js → EditPage-UlUcQ1wD.js} +6 -6
- package/dist/_chunks/{EditPage-b1mM_YNY.js.map → EditPage-UlUcQ1wD.js.map} +1 -1
- package/dist/_chunks/{EditPage-uqR-CSI7.js → EditPage-XZgiSgG-.js} +6 -6
- package/dist/_chunks/{EditPage-uqR-CSI7.js.map → EditPage-XZgiSgG-.js.map} +1 -1
- package/dist/_chunks/{EditPage-jP3J_b-g.mjs → EditPage-f6lBxKS9.mjs} +6 -6
- package/dist/_chunks/{EditPage-jP3J_b-g.mjs.map → EditPage-f6lBxKS9.mjs.map} +1 -1
- package/dist/_chunks/{EditPage-po_MJGqG.mjs → EditPage-rC_QVTV-.mjs} +6 -6
- package/dist/_chunks/{EditPage-po_MJGqG.mjs.map → EditPage-rC_QVTV-.mjs.map} +1 -1
- package/dist/_chunks/{EditPage-lpcjU1iO.mjs → EditPage-wSyKaf4-.mjs} +9 -9
- package/dist/_chunks/{EditPage-lpcjU1iO.mjs.map → EditPage-wSyKaf4-.mjs.map} +1 -1
- package/dist/_chunks/{EditView-OkrQPrNV.mjs → EditView-H6xfEAER.mjs} +4 -4
- package/dist/_chunks/{EditView-OkrQPrNV.mjs.map → EditView-H6xfEAER.mjs.map} +1 -1
- package/dist/_chunks/{EditView-ZqREhMRs.js → EditView-em4Ek_OF.js} +4 -4
- package/dist/_chunks/{EditView-ZqREhMRs.js.map → EditView-em4Ek_OF.js.map} +1 -1
- package/dist/_chunks/{EditViewPage-y6-QEPXe.js → EditViewPage-Fcmc97TP.js} +4 -4
- package/dist/_chunks/{EditViewPage-y6-QEPXe.js.map → EditViewPage-Fcmc97TP.js.map} +1 -1
- package/dist/_chunks/{EditViewPage-M2aXbEr9.mjs → EditViewPage-GFvCHjJG.mjs} +4 -4
- package/dist/_chunks/{EditViewPage-M2aXbEr9.mjs.map → EditViewPage-GFvCHjJG.mjs.map} +1 -1
- package/dist/_chunks/{EventsTable-DiHkzjty.mjs → EventsTable-Upp2rgu0.mjs} +6 -6
- package/dist/_chunks/{EventsTable-DiHkzjty.mjs.map → EventsTable-Upp2rgu0.mjs.map} +1 -1
- package/dist/_chunks/{EventsTable-v1WZ_gi9.js → EventsTable-mNAC-4YF.js} +6 -6
- package/dist/_chunks/{EventsTable-v1WZ_gi9.js.map → EventsTable-mNAC-4YF.js.map} +1 -1
- package/dist/_chunks/{HomePage-TYvBggdQ.mjs → HomePage-GgR9cnmf.mjs} +6 -6
- package/dist/_chunks/{HomePage-TYvBggdQ.mjs.map → HomePage-GgR9cnmf.mjs.map} +1 -1
- package/dist/_chunks/{HomePage-p5SWGQgz.js → HomePage-jeVu6my6.js} +5 -5
- package/dist/_chunks/{HomePage-p5SWGQgz.js.map → HomePage-jeVu6my6.js.map} +1 -1
- package/dist/_chunks/{HomePage-qF-dEV8u.js → HomePage-v6UjRRzu.js} +6 -6
- package/dist/_chunks/{HomePage-qF-dEV8u.js.map → HomePage-v6UjRRzu.js.map} +1 -1
- package/dist/_chunks/{HomePage-n1fwbnez.mjs → HomePage-xsPMkGuZ.mjs} +5 -5
- package/dist/_chunks/{HomePage-n1fwbnez.mjs.map → HomePage-xsPMkGuZ.mjs.map} +1 -1
- package/dist/_chunks/{InformationBoxEE-zUIffb4F.js → InformationBoxEE-1PzQBJUD.js} +3 -3
- package/dist/_chunks/{InformationBoxEE-zUIffb4F.js.map → InformationBoxEE-1PzQBJUD.js.map} +1 -1
- package/dist/_chunks/{InformationBoxEE-7zOeWUFf.mjs → InformationBoxEE-33cdxFRT.mjs} +3 -3
- package/dist/_chunks/{InformationBoxEE-7zOeWUFf.mjs.map → InformationBoxEE-33cdxFRT.mjs.map} +1 -1
- package/dist/_chunks/{InstalledPluginsPage-4oPT9TZu.mjs → InstalledPluginsPage-HMXfWFWP.mjs} +3 -3
- package/dist/_chunks/{InstalledPluginsPage-4oPT9TZu.mjs.map → InstalledPluginsPage-HMXfWFWP.mjs.map} +1 -1
- package/dist/_chunks/{InstalledPluginsPage-2Vr4BFUf.js → InstalledPluginsPage-tGDGwJvg.js} +3 -3
- package/dist/_chunks/{InstalledPluginsPage-2Vr4BFUf.js.map → InstalledPluginsPage-tGDGwJvg.js.map} +1 -1
- package/dist/_chunks/{Layout-cW_d_wLg.js → Layout-Gon3bQDq.js} +2 -2
- package/dist/_chunks/{Layout-cW_d_wLg.js.map → Layout-Gon3bQDq.js.map} +1 -1
- package/dist/_chunks/{Layout-jwPGTxyo.mjs → Layout-IC0zMhWz.mjs} +2 -2
- package/dist/_chunks/{Layout-jwPGTxyo.mjs.map → Layout-IC0zMhWz.mjs.map} +1 -1
- package/dist/_chunks/{ListPage-U-CCr8z2.js → ListPage-5K5CYx-_.js} +7 -7
- package/dist/_chunks/{ListPage-U-CCr8z2.js.map → ListPage-5K5CYx-_.js.map} +1 -1
- package/dist/_chunks/{ListPage-mYq4GXDx.mjs → ListPage-AlByWrUr.mjs} +2 -2
- package/dist/_chunks/{ListPage-mYq4GXDx.mjs.map → ListPage-AlByWrUr.mjs.map} +1 -1
- package/dist/_chunks/{ListPage-XuUYNFON.mjs → ListPage-KEvx-Z_R.mjs} +4 -4
- package/dist/_chunks/{ListPage-XuUYNFON.mjs.map → ListPage-KEvx-Z_R.mjs.map} +1 -1
- package/dist/_chunks/{ListPage-USWD7OAn.mjs → ListPage-KlRw_ZCO.mjs} +6 -6
- package/dist/_chunks/{ListPage-USWD7OAn.mjs.map → ListPage-KlRw_ZCO.mjs.map} +1 -1
- package/dist/_chunks/{ListPage-iMHN5Q_L.js → ListPage-OLgUPcos.js} +6 -6
- package/dist/_chunks/{ListPage-iMHN5Q_L.js.map → ListPage-OLgUPcos.js.map} +1 -1
- package/dist/_chunks/{ListPage-gQmALRcv.js → ListPage-Tn29eXSD.js} +3 -3
- package/dist/_chunks/{ListPage-gQmALRcv.js.map → ListPage-Tn29eXSD.js.map} +1 -1
- package/dist/_chunks/{ListPage-um6bRMmX.mjs → ListPage-Uq9V_7D4.mjs} +7 -7
- package/dist/_chunks/{ListPage-um6bRMmX.mjs.map → ListPage-Uq9V_7D4.mjs.map} +1 -1
- package/dist/_chunks/{ListPage-tQZAAMZ2.mjs → ListPage-YlaXETmz.mjs} +8 -8
- package/dist/_chunks/{ListPage-tQZAAMZ2.mjs.map → ListPage-YlaXETmz.mjs.map} +1 -1
- package/dist/_chunks/{ListPage-boe-QdwP.mjs → ListPage-iaCuBHNm.mjs} +3 -3
- package/dist/_chunks/{ListPage-boe-QdwP.mjs.map → ListPage-iaCuBHNm.mjs.map} +1 -1
- package/dist/_chunks/{ListPage-cf0xg9Vl.js → ListPage-k_Twen8H.js} +2 -2
- package/dist/_chunks/{ListPage-cf0xg9Vl.js.map → ListPage-k_Twen8H.js.map} +1 -1
- package/dist/_chunks/{ListPage-yrF1oGFd.js → ListPage-le_IfRji.js} +8 -8
- package/dist/_chunks/{ListPage-yrF1oGFd.js.map → ListPage-le_IfRji.js.map} +1 -1
- package/dist/_chunks/{ListPage-kxukYyMR.js → ListPage-q4ClW_vX.js} +4 -4
- package/dist/_chunks/{ListPage-kxukYyMR.js.map → ListPage-q4ClW_vX.js.map} +1 -1
- package/dist/_chunks/{ListView-1y2gjseP.js → ListView-6ZaiQfbq.js} +3 -3
- package/dist/_chunks/{ListView-1y2gjseP.js.map → ListView-6ZaiQfbq.js.map} +1 -1
- package/dist/_chunks/{ListView-8aqFHxwk.js → ListView-ALzt2yvO.js} +3 -3
- package/dist/_chunks/{ListView-8aqFHxwk.js.map → ListView-ALzt2yvO.js.map} +1 -1
- package/dist/_chunks/{ListView-1TZSzm0E.mjs → ListView-qQm2VF5T.mjs} +3 -3
- package/dist/_chunks/{ListView-1TZSzm0E.mjs.map → ListView-qQm2VF5T.mjs.map} +1 -1
- package/dist/_chunks/{ListView-Y8xl3SNS.mjs → ListView-v6E9_FOj.mjs} +3 -3
- package/dist/_chunks/{ListView-Y8xl3SNS.mjs.map → ListView-v6E9_FOj.mjs.map} +1 -1
- package/dist/_chunks/{Login-MvF-l7Jf.mjs → Login-3cM7_8qX.mjs} +2 -2
- package/dist/_chunks/{Login-MvF-l7Jf.mjs.map → Login-3cM7_8qX.mjs.map} +1 -1
- package/dist/_chunks/{Login-39PECWHo.js → Login-xfuvPWXc.js} +2 -2
- package/dist/_chunks/{Login-39PECWHo.js.map → Login-xfuvPWXc.js.map} +1 -1
- package/dist/_chunks/{MagicLinkEE-RZbU7-RH.js → MagicLinkEE-3kRJTEcy.js} +4 -4
- package/dist/_chunks/{MagicLinkEE-RZbU7-RH.js.map → MagicLinkEE-3kRJTEcy.js.map} +1 -1
- package/dist/_chunks/{MagicLinkEE-2SgSsQ9D.mjs → MagicLinkEE-_51rikA-.mjs} +4 -4
- package/dist/_chunks/{MagicLinkEE-2SgSsQ9D.mjs.map → MagicLinkEE-_51rikA-.mjs.map} +1 -1
- package/dist/_chunks/{MarketplacePage-avpto0An.mjs → MarketplacePage--u8ZGSq_.mjs} +8 -4
- package/dist/_chunks/MarketplacePage--u8ZGSq_.mjs.map +1 -0
- package/dist/_chunks/{MarketplacePage-wE94Wh4I.js → MarketplacePage-lkF7oa0I.js} +8 -4
- package/dist/_chunks/MarketplacePage-lkF7oa0I.js.map +1 -0
- package/dist/_chunks/{Permissions-UlAp5vXm.mjs → Permissions-SmZNoiHV.mjs} +2 -2
- package/dist/_chunks/{Permissions-UlAp5vXm.mjs.map → Permissions-SmZNoiHV.mjs.map} +1 -1
- package/dist/_chunks/{Permissions-1Q5T7SVl.js → Permissions-ypU-Ykok.js} +2 -2
- package/dist/_chunks/{Permissions-1Q5T7SVl.js.map → Permissions-ypU-Ykok.js.map} +1 -1
- package/dist/_chunks/{ProfilePage-g36T4a0Q.mjs → ProfilePage-Fsev4mM6.mjs} +3 -3
- package/dist/_chunks/{ProfilePage-g36T4a0Q.mjs.map → ProfilePage-Fsev4mM6.mjs.map} +1 -1
- package/dist/_chunks/{ProfilePage-efqbtTP9.js → ProfilePage-yc90qx9N.js} +3 -3
- package/dist/_chunks/{ProfilePage-efqbtTP9.js.map → ProfilePage-yc90qx9N.js.map} +1 -1
- package/dist/_chunks/{ReviewWorkflowsColumn-23m0Jbcb.mjs → ReviewWorkflowsColumn---n7-OOg.mjs} +2 -2
- package/dist/_chunks/{ReviewWorkflowsColumn-23m0Jbcb.mjs.map → ReviewWorkflowsColumn---n7-OOg.mjs.map} +1 -1
- package/dist/_chunks/{ReviewWorkflowsColumn-1rphvuAX.js → ReviewWorkflowsColumn-SqRXp26T.js} +2 -2
- package/dist/_chunks/{ReviewWorkflowsColumn-1rphvuAX.js.map → ReviewWorkflowsColumn-SqRXp26T.js.map} +1 -1
- package/dist/_chunks/{SelectRoles-EMflJoZf.js → SelectRoles-mQ7o3Xdz.js} +3 -3
- package/dist/_chunks/{SelectRoles-EMflJoZf.js.map → SelectRoles-mQ7o3Xdz.js.map} +1 -1
- package/dist/_chunks/{SelectRoles-EcNeQDtr.mjs → SelectRoles-qiH9P1a4.mjs} +3 -3
- package/dist/_chunks/{SelectRoles-EcNeQDtr.mjs.map → SelectRoles-qiH9P1a4.mjs.map} +1 -1
- package/dist/_chunks/{SettingsPage-pbZQYRba.js → SettingsPage-7Hs3vZLi.js} +21 -21
- package/dist/_chunks/{SettingsPage-pbZQYRba.js.map → SettingsPage-7Hs3vZLi.js.map} +1 -1
- package/dist/_chunks/{SettingsPage-ctRMOKpC.mjs → SettingsPage-vBDRsmgr.mjs} +21 -21
- package/dist/_chunks/{SettingsPage-ctRMOKpC.mjs.map → SettingsPage-vBDRsmgr.mjs.map} +1 -1
- package/dist/_chunks/{SingleSignOnPage-0PwZElsW.js → SingleSignOnPage-db6LFEhG.js} +3 -3
- package/dist/_chunks/{SingleSignOnPage-0PwZElsW.js.map → SingleSignOnPage-db6LFEhG.js.map} +1 -1
- package/dist/_chunks/{SingleSignOnPage-hF18NC0F.mjs → SingleSignOnPage-o_vOpneN.mjs} +3 -3
- package/dist/_chunks/{SingleSignOnPage-hF18NC0F.mjs.map → SingleSignOnPage-o_vOpneN.mjs.map} +1 -1
- package/dist/_chunks/{TokenTypeSelect-VOdl0ZmL.mjs → TokenTypeSelect-CzQ9sgKe.mjs} +2 -2
- package/dist/_chunks/{TokenTypeSelect-VOdl0ZmL.mjs.map → TokenTypeSelect-CzQ9sgKe.mjs.map} +1 -1
- package/dist/_chunks/{TokenTypeSelect-OKSX2lfX.js → TokenTypeSelect-lneRPzgZ.js} +2 -2
- package/dist/_chunks/{TokenTypeSelect-OKSX2lfX.js.map → TokenTypeSelect-lneRPzgZ.js.map} +1 -1
- package/dist/_chunks/{apiTokens-yJQ8-8xC.mjs → apiTokens-KJ7z37sn.mjs} +2 -2
- package/dist/_chunks/{apiTokens-yJQ8-8xC.mjs.map → apiTokens-KJ7z37sn.mjs.map} +1 -1
- package/dist/_chunks/{apiTokens-EVFBWYmA.js → apiTokens-_oBux8OH.js} +2 -2
- package/dist/_chunks/{apiTokens-EVFBWYmA.js.map → apiTokens-_oBux8OH.js.map} +1 -1
- package/dist/_chunks/{constants-FtFKsXD2.mjs → constants-36Qk1-zg.mjs} +2 -2
- package/dist/_chunks/{constants-FtFKsXD2.mjs.map → constants-36Qk1-zg.mjs.map} +1 -1
- package/dist/_chunks/{constants-6DC4IjBd.mjs → constants-S5jEkTwv.mjs} +6 -6
- package/dist/_chunks/{constants-6DC4IjBd.mjs.map → constants-S5jEkTwv.mjs.map} +1 -1
- package/dist/_chunks/{constants-iyl1t6wG.js → constants-ZsYiqzjH.js} +2 -2
- package/dist/_chunks/{constants-iyl1t6wG.js.map → constants-ZsYiqzjH.js.map} +1 -1
- package/dist/_chunks/{constants-0ftEXoFj.mjs → constants-jobVw9ef.mjs} +2 -2
- package/dist/_chunks/{constants-0ftEXoFj.mjs.map → constants-jobVw9ef.mjs.map} +1 -1
- package/dist/_chunks/{constants-s0SKq0VB.js → constants-p9SX5ZRW.js} +4 -4
- package/dist/_chunks/{constants-s0SKq0VB.js.map → constants-p9SX5ZRW.js.map} +1 -1
- package/dist/_chunks/{constants-5cTkDbEw.mjs → constants-qT9ydrF4.mjs} +4 -4
- package/dist/_chunks/{constants-5cTkDbEw.mjs.map → constants-qT9ydrF4.mjs.map} +1 -1
- package/dist/_chunks/{constants-XwCwfaxY.js → constants-qdwBAV2q.js} +2 -2
- package/dist/_chunks/{constants-XwCwfaxY.js.map → constants-qdwBAV2q.js.map} +1 -1
- package/dist/_chunks/{constants-GrxlpuUW.js → constants-t_9nRwWX.js} +6 -6
- package/dist/_chunks/{constants-GrxlpuUW.js.map → constants-t_9nRwWX.js.map} +1 -1
- package/dist/_chunks/hr-_CdBFPv8.js +1035 -0
- package/dist/_chunks/hr-_CdBFPv8.js.map +1 -0
- package/dist/_chunks/hr-fj72XD8M.mjs +1035 -0
- package/dist/_chunks/hr-fj72XD8M.mjs.map +1 -0
- package/dist/_chunks/{index-eT0CIaDr.mjs → index-5APqHalY.mjs} +15 -14
- package/dist/_chunks/index-5APqHalY.mjs.map +1 -0
- package/dist/_chunks/{index-Ts0i8jmH.js → index-6Sc5WXVm.js} +15 -14
- package/dist/_chunks/index-6Sc5WXVm.js.map +1 -0
- package/dist/_chunks/{reviewWorkflows-VYHOVjTk.js → reviewWorkflows-e6PQdbSQ.js} +2 -2
- package/dist/_chunks/{reviewWorkflows-VYHOVjTk.js.map → reviewWorkflows-e6PQdbSQ.js.map} +1 -1
- package/dist/_chunks/{reviewWorkflows-X4opVwyZ.mjs → reviewWorkflows-jTq0-ru_.mjs} +2 -2
- package/dist/_chunks/{reviewWorkflows-X4opVwyZ.mjs.map → reviewWorkflows-jTq0-ru_.mjs.map} +1 -1
- package/dist/_chunks/{transferTokens-XbqoKHA6.js → transferTokens-RodNUSkZ.js} +2 -2
- package/dist/_chunks/{transferTokens-XbqoKHA6.js.map → transferTokens-RodNUSkZ.js.map} +1 -1
- package/dist/_chunks/{transferTokens-tZFQBBDc.mjs → transferTokens-fG2HDg9L.mjs} +2 -2
- package/dist/_chunks/{transferTokens-tZFQBBDc.mjs.map → transferTokens-fG2HDg9L.mjs.map} +1 -1
- package/dist/_chunks/{useAdminRoles-lZ7mEYnT.mjs → useAdminRoles-Cq-Jo9JN.mjs} +2 -2
- package/dist/_chunks/{useAdminRoles-lZ7mEYnT.mjs.map → useAdminRoles-Cq-Jo9JN.mjs.map} +1 -1
- package/dist/_chunks/{useAdminRoles-MjR-VmL_.js → useAdminRoles-NK85Ubl6.js} +2 -2
- package/dist/_chunks/{useAdminRoles-MjR-VmL_.js.map → useAdminRoles-NK85Ubl6.js.map} +1 -1
- package/dist/_chunks/{useContentTypes-dP0t6DnS.js → useContentTypes-TNy5IgDA.js} +2 -2
- package/dist/_chunks/{useContentTypes-dP0t6DnS.js.map → useContentTypes-TNy5IgDA.js.map} +1 -1
- package/dist/_chunks/{useContentTypes-buqO4eWt.mjs → useContentTypes-ntRevdbC.mjs} +2 -2
- package/dist/_chunks/{useContentTypes-buqO4eWt.mjs.map → useContentTypes-ntRevdbC.mjs.map} +1 -1
- package/dist/_chunks/{useLicenseLimitNotification-HG-BNi8G.js → useLicenseLimitNotification-Xc91BJJS.js} +2 -2
- package/dist/_chunks/{useLicenseLimitNotification-HG-BNi8G.js.map → useLicenseLimitNotification-Xc91BJJS.js.map} +1 -1
- package/dist/_chunks/{useLicenseLimitNotification-QwULiYn5.mjs → useLicenseLimitNotification-jJkfnFtx.mjs} +2 -2
- package/dist/_chunks/{useLicenseLimitNotification-QwULiYn5.mjs.map → useLicenseLimitNotification-jJkfnFtx.mjs.map} +1 -1
- package/dist/_chunks/{useReviewWorkflows-vusjQAH8.js → useReviewWorkflows-VKYz5UQI.js} +2 -2
- package/dist/_chunks/{useReviewWorkflows-vusjQAH8.js.map → useReviewWorkflows-VKYz5UQI.js.map} +1 -1
- package/dist/_chunks/{useReviewWorkflows-Xn3L8MI8.mjs → useReviewWorkflows-cihmlaGu.mjs} +2 -2
- package/dist/_chunks/{useReviewWorkflows-Xn3L8MI8.mjs.map → useReviewWorkflows-cihmlaGu.mjs.map} +1 -1
- package/dist/_chunks/{useWebhooks-FgW5WF9_.mjs → useWebhooks-aUDEVeLF.mjs} +2 -2
- package/dist/_chunks/{useWebhooks-FgW5WF9_.mjs.map → useWebhooks-aUDEVeLF.mjs.map} +1 -1
- package/dist/_chunks/{useWebhooks-yfZ95LU8.js → useWebhooks-zJLYIi4z.js} +2 -2
- package/dist/_chunks/{useWebhooks-yfZ95LU8.js.map → useWebhooks-zJLYIi4z.js.map} +1 -1
- package/dist/_chunks/{validateWorkflow-4DkGfvCG.js → validateWorkflow-WQCJkOfK.js} +2 -2
- package/dist/_chunks/{validateWorkflow-4DkGfvCG.js.map → validateWorkflow-WQCJkOfK.js.map} +1 -1
- package/dist/_chunks/{validateWorkflow-JGLqIx3z.mjs → validateWorkflow-mU9FqIYY.mjs} +2 -2
- package/dist/_chunks/{validateWorkflow-JGLqIx3z.mjs.map → validateWorkflow-mU9FqIYY.mjs.map} +1 -1
- package/dist/admin/index.js +1 -1
- package/dist/admin/index.mjs +1 -1
- package/dist/admin/src/translations/languageNativeNames.d.ts +1 -0
- package/package.json +12 -12
- package/dist/_chunks/MarketplacePage-avpto0An.mjs.map +0 -1
- package/dist/_chunks/MarketplacePage-wE94Wh4I.js.map +0 -1
- package/dist/_chunks/index-Ts0i8jmH.js.map +0 -1
- package/dist/_chunks/index-eT0CIaDr.mjs.map +0 -1
package/dist/_chunks/{validateWorkflow-JGLqIx3z.mjs.map → validateWorkflow-mU9FqIYY.mjs.map}
RENAMED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"validateWorkflow-JGLqIx3z.mjs","sources":["../../admin/src/hooks/useInjectReducer.ts","../../ee/admin/src/pages/SettingsPage/pages/ReviewWorkflows/actions.ts","../../ee/admin/src/pages/SettingsPage/pages/ReviewWorkflows/components/AddStage.tsx","../../ee/admin/src/pages/SettingsPage/pages/ReviewWorkflows/reducer.ts","../../ee/admin/src/pages/SettingsPage/pages/ReviewWorkflows/selectors.ts","../../ee/admin/src/pages/SettingsPage/pages/ReviewWorkflows/components/Stage.tsx","../../ee/admin/src/pages/SettingsPage/pages/ReviewWorkflows/components/Stages.tsx","../../ee/admin/src/pages/SettingsPage/pages/ReviewWorkflows/components/WorkflowAttributes.tsx","../../ee/admin/src/pages/SettingsPage/pages/ReviewWorkflows/utils/validateWorkflow.ts"],"sourcesContent":["import { useEffect } from 'react';\n\nimport { Reducer } from '@reduxjs/toolkit';\n\nimport { useTypedStore } from '../core/store/hooks';\n\n/**\n * Inject a new reducer into the global redux-store.\n *\n * @export\n * @param {string} namespace - Store namespace of the injected reducer\n * @param {Function} reducer - Reducer function\n * @return void\n */\n\nexport function useInjectReducer(namespace: string, reducer: Reducer) {\n const store = useTypedStore();\n\n useEffect(() => {\n store.injectReducer(namespace, reducer);\n }, [store, namespace, reducer]);\n}\n","import { Contracts } from '@strapi/plugin-content-manager/_internal/shared';\n\nimport { Stage, Workflow } from '../../../../../../../shared/contracts/review-workflows';\nimport { Permission, SanitizedAdminRole } from '../../../../../../../shared/contracts/shared';\n\nimport {\n ACTION_ADD_STAGE,\n ACTION_CLONE_STAGE,\n ACTION_DELETE_STAGE,\n ACTION_RESET_WORKFLOW,\n ACTION_SET_CONTENT_TYPES,\n ACTION_SET_IS_LOADING,\n ACTION_SET_ROLES,\n ACTION_SET_WORKFLOW,\n ACTION_SET_WORKFLOWS,\n ACTION_UPDATE_STAGE,\n ACTION_UPDATE_STAGES,\n ACTION_UPDATE_STAGE_POSITION,\n ACTION_UPDATE_WORKFLOW,\n} from './constants';\n\nexport function cloneStage(id: number) {\n return {\n type: ACTION_CLONE_STAGE,\n payload: { id },\n };\n}\n\nexport function setWorkflow({ workflow }: { workflow: Workflow | null }) {\n return {\n type: ACTION_SET_WORKFLOW,\n payload: workflow,\n };\n}\n\nexport function setWorkflows({ workflows }: { workflows: Workflow[] }) {\n return {\n type: ACTION_SET_WORKFLOWS,\n payload: workflows,\n };\n}\n\nexport function deleteStage(stageId: number) {\n return {\n type: ACTION_DELETE_STAGE,\n payload: {\n stageId,\n },\n };\n}\n\nexport function addStage(stage: Partial<Stage>) {\n return {\n type: ACTION_ADD_STAGE,\n payload: stage,\n };\n}\n\nexport interface PartialStage extends Omit<Stage, 'permissions'> {\n permissions?: Partial<Permission>[];\n}\n\nexport function updateStage(stageId: number, payload: Partial<PartialStage>) {\n return {\n type: ACTION_UPDATE_STAGE,\n payload: {\n stageId,\n ...payload,\n },\n };\n}\n\nexport function updateStages(payload: Partial<PartialStage>) {\n return {\n type: ACTION_UPDATE_STAGES,\n payload,\n };\n}\n\nexport function updateStagePosition(oldIndex: number, newIndex: number) {\n return {\n type: ACTION_UPDATE_STAGE_POSITION,\n payload: {\n newIndex,\n oldIndex,\n },\n };\n}\n\nexport function updateWorkflow(payload: Partial<Workflow>) {\n return {\n type: ACTION_UPDATE_WORKFLOW,\n payload,\n };\n}\n\nexport function resetWorkflow() {\n return {\n type: ACTION_RESET_WORKFLOW,\n };\n}\n\nexport function setContentTypes(payload: {\n collectionTypes?: Contracts.ContentTypes.ContentType[];\n singleTypes?: Contracts.ContentTypes.ContentType[];\n}) {\n return {\n type: ACTION_SET_CONTENT_TYPES,\n payload,\n };\n}\n\nexport function setRoles(payload?: (SanitizedAdminRole & { usersCount?: number | undefined })[]) {\n return {\n type: ACTION_SET_ROLES,\n payload,\n };\n}\n\nexport function setIsLoading(isLoading: boolean) {\n return {\n type: ACTION_SET_IS_LOADING,\n payload: isLoading,\n };\n}\n","import React from 'react';\n\nimport { Box, ButtonProps, Flex, Typography } from '@strapi/design-system';\nimport { PlusCircle } from '@strapi/icons';\nimport PropTypes from 'prop-types';\nimport styled from 'styled-components';\n\nconst StyledAddIcon = styled(PlusCircle)`\n > circle {\n fill: ${({ theme }) => theme.colors.neutral150};\n }\n > path {\n fill: ${({ theme }) => theme.colors.neutral600};\n }\n`;\n\nconst StyledButton = styled(Box)`\n border-radius: 26px;\n\n svg {\n height: ${({ theme }) => theme.spaces[6]};\n width: ${({ theme }) => theme.spaces[6]};\n\n > path {\n fill: ${({ theme }) => theme.colors.neutral600};\n }\n }\n\n &:hover {\n color: ${({ theme }) => theme.colors.primary600} !important;\n ${Typography} {\n color: ${({ theme }) => theme.colors.primary600} !important;\n }\n\n ${StyledAddIcon} {\n > circle {\n fill: ${({ theme }) => theme.colors.primary600};\n }\n > path {\n fill: ${({ theme }) => theme.colors.neutral100};\n }\n }\n }\n\n &:active {\n ${Typography} {\n color: ${({ theme }) => theme.colors.primary600};\n }\n\n ${StyledAddIcon} {\n > circle {\n fill: ${({ theme }) => theme.colors.primary600};\n }\n > path {\n fill: ${({ theme }) => theme.colors.neutral100};\n }\n }\n }\n`;\n\nexport const AddStage = ({ children, ...props }: ButtonProps) => {\n return (\n <StyledButton\n as=\"button\"\n background=\"neutral0\"\n border=\"neutral150\"\n paddingBottom={3}\n paddingLeft={4}\n paddingRight={4}\n paddingTop={3}\n shadow=\"filterShadow\"\n {...props}\n >\n <Flex gap={2}>\n <StyledAddIcon aria-hidden />\n\n <Typography variant=\"pi\" fontWeight=\"bold\" textColor=\"neutral500\">\n {children}\n </Typography>\n </Flex>\n </StyledButton>\n );\n};\n\nAddStage.propTypes = {\n children: PropTypes.node.isRequired,\n};\n","import { Schema } from '@strapi/types';\nimport { createDraft, produce } from 'immer';\n\nimport {\n Stage,\n StagePermission,\n Workflow,\n} from '../../../../../../../shared/contracts/review-workflows';\nimport { AdminRole } from '../../../../../../../shared/contracts/shared';\n\nimport {\n ACTION_ADD_STAGE,\n ACTION_CLONE_STAGE,\n ACTION_DELETE_STAGE,\n ACTION_RESET_WORKFLOW,\n ACTION_SET_CONTENT_TYPES,\n ACTION_SET_IS_LOADING,\n ACTION_SET_ROLES,\n ACTION_SET_WORKFLOW,\n ACTION_SET_WORKFLOWS,\n ACTION_UPDATE_STAGE,\n ACTION_UPDATE_STAGES,\n ACTION_UPDATE_STAGE_POSITION,\n ACTION_UPDATE_WORKFLOW,\n STAGE_COLOR_DEFAULT,\n} from './constants';\n\nexport type CurrentWorkflow = Partial<\n Pick<Workflow, 'name' | 'contentTypes' | 'stages' | 'id'> & {\n permissions?: StagePermission[];\n }\n>;\n\nexport type PartialWorkflow = Omit<CurrentWorkflow, 'stages'> & { stages?: Partial<Stage>[] };\n\nexport interface ServerState {\n contentTypes?: {\n collectionTypes: Schema.CollectionType[];\n singleTypes: Schema.SingleType[];\n };\n roles?: AdminRole[];\n workflow?: PartialWorkflow | null;\n workflows?: Workflow[];\n}\n\n// This isn't something we should do.\n// TODO: Revamp the way we are handling this temp key for delete or create\nexport type StageWithTempKey = Stage & { __temp_key__?: number };\nexport interface ClientState {\n currentWorkflow: {\n data: Partial<Omit<CurrentWorkflow, 'stages'> & { stages: StageWithTempKey[] }>;\n };\n isLoading?: boolean;\n}\n\nexport type State = {\n serverState: ServerState;\n clientState: ClientState;\n};\n\nexport const initialState: State = {\n serverState: {\n contentTypes: {\n collectionTypes: [],\n singleTypes: [],\n },\n roles: [],\n workflow: null,\n workflows: [],\n },\n clientState: {\n currentWorkflow: {\n data: {\n name: '',\n contentTypes: [],\n stages: [],\n permissions: undefined,\n },\n },\n isLoading: true,\n },\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function reducer(state: State = initialState, action: { type: string; payload?: any }) {\n return produce(state, (draft) => {\n const { payload } = action;\n\n switch (action.type) {\n case ACTION_SET_CONTENT_TYPES: {\n draft.serverState.contentTypes = payload;\n break;\n }\n\n case ACTION_SET_IS_LOADING: {\n draft.clientState.isLoading = payload;\n break;\n }\n\n case ACTION_SET_ROLES: {\n draft.serverState.roles = payload;\n break;\n }\n\n case ACTION_SET_WORKFLOW: {\n const workflow: Workflow = payload;\n\n if (workflow) {\n draft.serverState.workflow = workflow;\n draft.clientState.currentWorkflow.data = {\n ...workflow,\n stages: workflow.stages.map((stage) => ({\n ...stage,\n // A safety net in case a stage does not have a color assigned;\n // this should not happen\n color: stage?.color ?? STAGE_COLOR_DEFAULT,\n })),\n };\n }\n break;\n }\n\n case ACTION_SET_WORKFLOWS: {\n draft.serverState.workflows = payload;\n break;\n }\n\n case ACTION_RESET_WORKFLOW: {\n draft.clientState = initialState.clientState;\n draft.serverState = createDraft(initialState.serverState);\n break;\n }\n\n case ACTION_DELETE_STAGE: {\n const { stageId } = payload;\n const { currentWorkflow } = state.clientState;\n\n draft.clientState.currentWorkflow.data.stages = currentWorkflow.data.stages?.filter(\n (stage) => (stage?.id ?? stage.__temp_key__) !== stageId\n );\n\n break;\n }\n\n case ACTION_ADD_STAGE: {\n const { currentWorkflow } = state.clientState;\n\n if (!currentWorkflow.data) {\n draft.clientState.currentWorkflow.data = {\n stages: [],\n };\n }\n\n const newTempKey = getMaxTempKey(draft.clientState.currentWorkflow.data.stages);\n\n draft.clientState.currentWorkflow.data.stages?.push({\n ...payload,\n color: payload?.color ?? STAGE_COLOR_DEFAULT,\n __temp_key__: newTempKey,\n });\n\n break;\n }\n\n case ACTION_CLONE_STAGE: {\n const { currentWorkflow } = state.clientState;\n const { id } = payload;\n\n const sourceStageIndex = currentWorkflow.data.stages?.findIndex(\n (stage) => (stage?.id ?? stage?.__temp_key__) === id\n );\n\n if (sourceStageIndex !== undefined && sourceStageIndex !== -1) {\n const sourceStage = currentWorkflow.data.stages?.[sourceStageIndex];\n\n draft.clientState.currentWorkflow.data.stages?.splice(sourceStageIndex + 1, 0, {\n ...sourceStage,\n // @ts-expect-error - We are handling temporary (unsaved) duplicated stages with temporary keys and undefined ids. It should be revamp imo\n id: undefined,\n __temp_key__: getMaxTempKey(draft.clientState.currentWorkflow.data.stages),\n });\n }\n\n break;\n }\n\n case ACTION_UPDATE_STAGE: {\n const { currentWorkflow } = state.clientState;\n const { stageId, ...modified } = payload;\n\n draft.clientState.currentWorkflow.data.stages = currentWorkflow.data.stages?.map((stage) =>\n (stage.id ?? stage.__temp_key__) === stageId\n ? {\n ...stage,\n ...modified,\n }\n : stage\n );\n\n break;\n }\n\n case ACTION_UPDATE_STAGES: {\n const { currentWorkflow } = state.clientState;\n\n draft.clientState.currentWorkflow.data.stages = currentWorkflow.data.stages?.map(\n (stage) => ({\n ...stage,\n ...payload,\n })\n );\n\n break;\n }\n\n case ACTION_UPDATE_STAGE_POSITION: {\n const {\n currentWorkflow: {\n data: { stages },\n },\n } = state.clientState;\n const { newIndex, oldIndex } = payload;\n\n if (stages && newIndex >= 0 && newIndex < stages.length) {\n const stage = stages[oldIndex];\n const newStages = [...stages];\n\n newStages.splice(oldIndex, 1);\n newStages.splice(newIndex, 0, stage);\n\n draft.clientState.currentWorkflow.data.stages = newStages;\n }\n\n break;\n }\n\n case ACTION_UPDATE_WORKFLOW: {\n draft.clientState.currentWorkflow.data = {\n ...draft.clientState.currentWorkflow.data,\n ...payload,\n };\n\n break;\n }\n\n default:\n break;\n }\n });\n}\n\nconst getMaxTempKey = (stages: StageWithTempKey[] = []): number => {\n const ids = stages.map((stage) => Number(stage.id ?? stage.__temp_key__));\n\n /**\n * If there are no ids it will return 0 as the max value\n * because the max value is -1.\n */\n return Math.max(...ids, -1) + 1;\n};\n","import { createSelector } from '@reduxjs/toolkit';\nimport isEqual from 'lodash/isEqual';\n\nimport { RootState } from '../../../../../../../admin/src/core/store/configure';\nimport { Stage } from '../../../../../../../shared/contracts/review-workflows';\n\nimport { REDUX_NAMESPACE } from './constants';\nimport { State, initialState } from './reducer';\n\ninterface Store extends RootState {\n [REDUX_NAMESPACE]: State;\n}\n\nexport const selectNamespace = (state: Store) => state[REDUX_NAMESPACE] ?? initialState;\n\nexport const selectContentTypes = createSelector(\n selectNamespace,\n ({ serverState: { contentTypes } }) => contentTypes\n);\n\nexport const selectRoles = createSelector(selectNamespace, ({ serverState: { roles } }) => roles);\n\nexport const selectCurrentWorkflow = createSelector(\n selectNamespace,\n ({ clientState: { currentWorkflow } }) => currentWorkflow.data\n);\n\nexport const selectWorkflows = createSelector(\n selectNamespace,\n ({ serverState: { workflows } }) => workflows\n);\n\nexport const selectIsWorkflowDirty = createSelector(\n selectNamespace,\n ({ serverState, clientState: { currentWorkflow } }) =>\n !isEqual(serverState.workflow, currentWorkflow.data)\n);\n\nexport const selectHasDeletedServerStages = createSelector(\n selectNamespace,\n ({ serverState, clientState: { currentWorkflow } }) =>\n !(serverState.workflow?.stages ?? []).every(\n (stage: Partial<Stage>) => !!currentWorkflow.data.stages?.find(({ id }) => id === stage.id)\n )\n);\n\nexport const selectIsLoading = createSelector(\n selectNamespace,\n ({ clientState: { isLoading } }) => isLoading\n);\n\nexport const selectServerState = createSelector(selectNamespace, ({ serverState }) => serverState);\n","import * as React from 'react';\n\nimport {\n Accordion,\n AccordionContent,\n AccordionToggle,\n Box,\n Flex,\n Grid,\n GridItem,\n IconButton,\n MultiSelect,\n MultiSelectGroup,\n MultiSelectOption,\n SingleSelect,\n SingleSelectOption,\n TextInput,\n Typography,\n VisuallyHidden,\n} from '@strapi/design-system';\nimport { Menu, MenuItem } from '@strapi/design-system/v2';\nimport {\n ConfirmDialog,\n useNotification,\n NotAllowedInput,\n useTracking,\n} from '@strapi/helper-plugin';\nimport { Duplicate, Drag, More } from '@strapi/icons';\nimport { useField } from 'formik';\nimport { getEmptyImage } from 'react-dnd-html5-backend';\nimport { useIntl } from 'react-intl';\nimport { useDispatch, useSelector } from 'react-redux';\nimport styled from 'styled-components';\n\nimport { useDragAndDrop } from '../../../../../../../../admin/src/content-manager/hooks/useDragAndDrop';\nimport { composeRefs } from '../../../../../../../../admin/src/content-manager/utils/refs';\nimport { StagePermission } from '../../../../../../../../shared/contracts/review-workflows';\nimport {\n cloneStage,\n deleteStage,\n updateStage,\n updateStagePosition,\n updateStages,\n} from '../actions';\nimport { DRAG_DROP_TYPES } from '../constants';\nimport { selectRoles } from '../selectors';\nimport { getAvailableStageColors, getStageColorByHex } from '../utils/colors';\n\nconst NestedOption = styled(MultiSelectOption)`\n padding-left: ${({ theme }) => theme.spaces[7]};\n`;\n\n// Grow the size of the permission Select\nconst PermissionWrapper = styled(Flex)`\n > * {\n flex-grow: 1;\n }\n`;\n\nconst DeleteMenuItem = styled(MenuItem)`\n color: ${({ theme }) => theme.colors.danger600};\n`;\n\n// Removing the font-size from the child-span aligns the\n// more icon vertically\nconst ContextMenuTrigger = styled(Menu.Trigger)`\n :hover,\n :focus {\n background-color: ${({ theme }) => theme.colors.neutral100};\n }\n\n > span {\n font-size: 0;\n }\n`;\n\n// As soon as either `as` or `forwardedAs` is set, the component\n// resets some styles and e.g. the `hasBorder` prop no longer works,\n// which is why this bit of CSS has been added manually ¯\\_(ツ)_/¯\nconst DragIconButton = styled(IconButton)`\n align-items: center;\n border-radius: ${({ theme }) => theme.borderRadius};\n display: flex;\n justify-content: center;\n\n :hover,\n :focus {\n background-color: ${({ theme }) => theme.colors.neutral100};\n }\n\n svg {\n height: auto;\n width: ${({ theme }) => theme.spaces[3]}};\n }\n`;\n\nconst AVAILABLE_COLORS = getAvailableStageColors();\n\nconst StageDropPreview = () => {\n return (\n <Box\n background=\"primary100\"\n borderStyle=\"dashed\"\n borderColor=\"primary600\"\n borderWidth=\"1px\"\n display=\"block\"\n hasRadius\n padding={6}\n shadow=\"tableShadow\"\n />\n );\n};\n\nexport type StageProps = {\n id: number;\n index: number;\n canDelete: boolean;\n canReorder: boolean;\n canUpdate: boolean;\n isOpen: boolean;\n stagesCount: number;\n};\n\nexport const Stage = ({\n id,\n index,\n canDelete,\n canReorder,\n canUpdate,\n isOpen: isOpenDefault = false,\n stagesCount,\n}: StageProps) => {\n const getItemPos = (index: number) => `${index + 1} of ${stagesCount}`;\n\n const handleGrabStage = (index: number) => {\n setLiveText(\n formatMessage(\n {\n id: 'dnd.grab-item',\n defaultMessage: `{item}, grabbed. Current position in list: {position}. Press up and down arrow to change position, Spacebar to drop, Escape to cancel.`,\n },\n {\n item: nameField.value,\n position: getItemPos(index),\n }\n )\n );\n };\n\n const handleDropStage = (index: number) => {\n setLiveText(\n formatMessage(\n {\n id: 'dnd.drop-item',\n defaultMessage: `{item}, dropped. Final position in list: {position}.`,\n },\n {\n item: nameField.value,\n position: getItemPos(index),\n }\n )\n );\n };\n\n const handleCancelDragStage = () => {\n setLiveText(\n formatMessage(\n {\n id: 'dnd.cancel-item',\n defaultMessage: '{item}, dropped. Re-order cancelled.',\n },\n {\n item: nameField.value,\n }\n )\n );\n };\n\n const handleMoveStage = (newIndex: number, oldIndex: number) => {\n setLiveText(\n formatMessage(\n {\n id: 'dnd.reorder',\n defaultMessage: '{item}, moved. New position in list: {position}.',\n },\n {\n item: nameField.value,\n position: getItemPos(newIndex),\n }\n )\n );\n\n dispatch(updateStagePosition(oldIndex, newIndex));\n };\n\n const handleApplyPermissionsToAllStages = () => {\n setIsApplyAllConfirmationOpen(true);\n };\n\n const [liveText, setLiveText] = React.useState(null);\n const { formatMessage } = useIntl();\n const { trackUsage } = useTracking();\n const dispatch = useDispatch();\n const toggleNotification = useNotification();\n const [isOpen, setIsOpen] = React.useState(isOpenDefault);\n const [isApplyAllConfirmationOpen, setIsApplyAllConfirmationOpen] = React.useState(false);\n const [nameField, nameMeta, nameHelper] = useField(`stages.${index}.name`);\n const [colorField, colorMeta, colorHelper] = useField(`stages.${index}.color`);\n const [permissionsField, permissionsMeta, permissionsHelper] = useField<\n Partial<StagePermission>[]\n >(`stages.${index}.permissions`);\n const roles = useSelector(selectRoles);\n const [{ handlerId, isDragging, handleKeyDown }, stageRef, dropRef, dragRef, dragPreviewRef] =\n useDragAndDrop(canReorder, {\n index,\n item: {\n index,\n name: nameField.value,\n },\n onGrabItem: handleGrabStage,\n onDropItem: handleDropStage,\n onMoveItem: handleMoveStage,\n onCancel: handleCancelDragStage,\n type: DRAG_DROP_TYPES.STAGE,\n });\n\n const composedRef = composeRefs(stageRef, dropRef);\n\n const colorOptions = AVAILABLE_COLORS.map(({ hex, name }) => ({\n value: hex,\n label: formatMessage(\n {\n id: 'Settings.review-workflows.stage.color.name',\n defaultMessage: '{name}',\n },\n { name }\n ),\n color: hex,\n }));\n\n const { themeColorName } = getStageColorByHex(colorField.value) ?? {};\n\n const filteredRoles = roles\n // Super admins always have permissions to do everything and therefore\n // there is no point for this role to show up in the role combobox\n ?.filter((role) => role.code !== 'strapi-super-admin');\n\n React.useEffect(() => {\n dragPreviewRef(getEmptyImage(), { captureDraggingState: false });\n }, [dragPreviewRef, index]);\n\n return (\n <Box ref={(ref) => composedRef(ref!)}>\n {liveText && <VisuallyHidden aria-live=\"assertive\">{liveText}</VisuallyHidden>}\n\n {isDragging ? (\n <StageDropPreview />\n ) : (\n <Accordion\n size=\"S\"\n variant=\"primary\"\n onToggle={() => {\n setIsOpen(!isOpen);\n\n if (!isOpen) {\n trackUsage('willEditStage');\n }\n }}\n expanded={isOpen}\n shadow=\"tableShadow\"\n error={nameMeta.error ?? colorMeta?.error ?? permissionsMeta?.error}\n hasErrorMessage={false}\n >\n <AccordionToggle\n title={nameField.value}\n togglePosition=\"left\"\n action={\n (canDelete || canUpdate) && (\n <Flex>\n <Menu.Root>\n <ContextMenuTrigger size=\"S\" endIcon={null} paddingLeft={2} paddingRight={2}>\n <More aria-hidden focusable={false} />\n <VisuallyHidden as=\"span\">\n {formatMessage({\n id: '[tbdb].components.DynamicZone.more-actions',\n defaultMessage: 'More actions',\n })}\n </VisuallyHidden>\n </ContextMenuTrigger>\n {/* z-index needs to be as big as the one defined for the wrapper in Stages, otherwise the menu\n * disappears behind the accordion\n */}\n <Menu.Content popoverPlacement=\"bottom-end\" zIndex={2}>\n <Menu.SubRoot>\n {canUpdate && (\n <MenuItem onClick={() => dispatch(cloneStage(id))}>\n {formatMessage({\n id: 'Settings.review-workflows.stage.delete',\n defaultMessage: 'Duplicate stage',\n })}\n </MenuItem>\n )}\n\n {canDelete && (\n <DeleteMenuItem onClick={() => dispatch(deleteStage(id))}>\n {formatMessage({\n id: 'Settings.review-workflows.stage.delete',\n defaultMessage: 'Delete',\n })}\n </DeleteMenuItem>\n )}\n </Menu.SubRoot>\n </Menu.Content>\n </Menu.Root>\n\n {canUpdate && (\n <DragIconButton\n background=\"transparent\"\n // @ts-expect-error - forwardedAs needs to be defined as string in the IconButton props\n forwardedAs=\"div\"\n hasRadius\n role=\"button\"\n noBorder\n tabIndex={0}\n data-handler-id={handlerId}\n ref={dragRef}\n label={formatMessage({\n id: 'Settings.review-workflows.stage.drag',\n defaultMessage: 'Drag',\n })}\n onClick={(e) => e.stopPropagation()}\n onKeyDown={handleKeyDown}\n >\n <Drag />\n </DragIconButton>\n )}\n </Flex>\n )\n }\n />\n <AccordionContent padding={6} background=\"neutral0\" hasRadius>\n <Grid gap={4}>\n <GridItem col={6}>\n <TextInput\n {...nameField}\n id={nameField.name}\n disabled={!canUpdate}\n label={formatMessage({\n id: 'Settings.review-workflows.stage.name.label',\n defaultMessage: 'Stage name',\n })}\n error={nameMeta.error ?? false}\n onChange={(event) => {\n nameHelper.setValue(event.target.value);\n dispatch(updateStage(id, { name: event.target.value }));\n }}\n required\n />\n </GridItem>\n\n <GridItem col={6}>\n <SingleSelect\n disabled={!canUpdate}\n error={colorMeta?.error ?? false}\n id={colorField.name}\n required\n label={formatMessage({\n id: 'content-manager.reviewWorkflows.stage.color',\n defaultMessage: 'Color',\n })}\n onChange={(value) => {\n colorHelper.setValue(value);\n dispatch(updateStage(id, { color: String(value) }));\n }}\n value={colorField.value.toUpperCase()}\n startIcon={\n <Flex\n as=\"span\"\n height={2}\n background={colorField.value}\n // @ts-expect-error - transparent doesn't exist in theme.colors\n borderColor={themeColorName === 'neutral0' ? 'neutral150' : 'transparent'}\n hasRadius\n shrink={0}\n width={2}\n />\n }\n >\n {colorOptions.map(({ value, label, color }) => {\n const { themeColorName } = getStageColorByHex(color) || {};\n\n return (\n <SingleSelectOption\n value={value}\n key={value}\n startIcon={\n <Flex\n as=\"span\"\n height={2}\n background={color}\n // @ts-expect-error - transparent doesn't exist in theme.colors\n borderColor={\n themeColorName === 'neutral0' ? 'neutral150' : 'transparent'\n }\n hasRadius\n shrink={0}\n width={2}\n />\n }\n >\n {label}\n </SingleSelectOption>\n );\n })}\n </SingleSelect>\n </GridItem>\n\n <GridItem col={6}>\n {filteredRoles?.length === 0 ? (\n <NotAllowedInput\n description={{\n id: 'Settings.review-workflows.stage.permissions.noPermissions.description',\n defaultMessage: 'You don’t have the permission to see roles',\n }}\n intlLabel={{\n id: 'Settings.review-workflows.stage.permissions.label',\n defaultMessage: 'Roles that can change this stage',\n }}\n name={permissionsField.name}\n />\n ) : (\n <Flex alignItems=\"flex-end\" gap={3}>\n <PermissionWrapper grow={1}>\n <MultiSelect\n {...permissionsField}\n disabled={!canUpdate}\n error={permissionsMeta.error ?? false}\n id={permissionsField.name}\n label={formatMessage({\n id: 'Settings.review-workflows.stage.permissions.label',\n defaultMessage: 'Roles that can change this stage',\n })}\n onChange={(values) => {\n // Because the select components expects strings for values, but\n // the yup schema validates we are sending full permission objects to the API,\n // we must coerce the string value back to an object\n const permissions = values.map((value) => ({\n role: parseInt(value, 10),\n action: 'admin::review-workflows.stage.transition',\n }));\n\n permissionsHelper.setValue(permissions);\n dispatch(updateStage(id, { permissions }));\n }}\n placeholder={formatMessage({\n id: 'Settings.review-workflows.stage.permissions.placeholder',\n defaultMessage: 'Select a role',\n })}\n required\n // The Select component expects strings for values\n value={(permissionsField.value ?? []).map(\n (permission) => `${permission.role}`\n )}\n withTags\n >\n <MultiSelectGroup\n label={formatMessage({\n id: 'Settings.review-workflows.stage.permissions.allRoles.label',\n defaultMessage: 'All roles',\n })}\n values={filteredRoles?.map((r) => `${r.id}`)}\n >\n {filteredRoles?.map((role) => {\n return (\n <NestedOption key={role.id} value={`${role.id}`}>\n {role.name}\n </NestedOption>\n );\n })}\n </MultiSelectGroup>\n </MultiSelect>\n </PermissionWrapper>\n\n <IconButton\n disabled={!canUpdate}\n icon={<Duplicate />}\n label={formatMessage({\n id: 'Settings.review-workflows.stage.permissions.apply.label',\n defaultMessage: 'Apply to all stages',\n })}\n size=\"L\"\n variant=\"secondary\"\n onClick={() => handleApplyPermissionsToAllStages()}\n />\n </Flex>\n )}\n </GridItem>\n </Grid>\n </AccordionContent>\n </Accordion>\n )}\n\n <ConfirmDialog.Root\n iconRightButton={null}\n isOpen={isApplyAllConfirmationOpen}\n onToggleDialog={() => setIsApplyAllConfirmationOpen(false)}\n onConfirm={() => {\n dispatch(updateStages({ permissions: permissionsField.value }));\n setIsApplyAllConfirmationOpen(false);\n toggleNotification({\n type: 'success',\n message: formatMessage({\n id: 'Settings.review-workflows.page.edit.confirm.stages.permissions.copy.success',\n defaultMessage: 'Applied roles to all other stages of the workflow',\n }),\n });\n }}\n variantRightButton=\"default\"\n >\n <ConfirmDialog.Body>\n <Typography textAlign=\"center\" variant=\"omega\">\n {formatMessage({\n id: 'Settings.review-workflows.page.edit.confirm.stages.permissions.copy',\n defaultMessage:\n 'Roles that can change that stage will be applied to all the other stages.',\n })}\n </Typography>\n </ConfirmDialog.Body>\n </ConfirmDialog.Root>\n </Box>\n );\n};\n","import React from 'react';\n\nimport { Box, Flex } from '@strapi/design-system';\nimport { useTracking } from '@strapi/helper-plugin';\nimport { useIntl } from 'react-intl';\nimport { useDispatch } from 'react-redux';\nimport styled from 'styled-components';\n\nimport { Stage as StageType } from '../../../../../../../../shared/contracts/review-workflows';\nimport { addStage } from '../actions';\n\nimport { AddStage } from './AddStage';\nimport { Stage } from './Stage';\n\nconst Background = styled(Box)`\n transform: translateX(-50%);\n`;\n\nexport type StagesProps = {\n canDelete?: boolean;\n canUpdate?: boolean;\n stages?: StageType[];\n};\n\nexport const Stages = ({ canDelete = true, canUpdate = true, stages = [] }: StagesProps) => {\n const { formatMessage } = useIntl();\n const dispatch = useDispatch();\n const { trackUsage } = useTracking();\n\n return (\n <Flex direction=\"column\" gap={6} width=\"100%\">\n <Box position=\"relative\" width=\"100%\">\n <Background\n background=\"neutral200\"\n height=\"100%\"\n left=\"50%\"\n position=\"absolute\"\n top=\"0\"\n width={2}\n zIndex={1}\n />\n\n <Flex\n direction=\"column\"\n alignItems=\"stretch\"\n gap={6}\n zIndex={2}\n position=\"relative\"\n as=\"ol\"\n >\n {stages.map((stage, index) => {\n // @ts-expect-error - temp key should be fixed in order to use another value\n const id = Number(stage?.id ?? stage.__temp_key__);\n\n return (\n <Box key={`stage-${id}`} as=\"li\">\n <Stage\n id={id}\n index={index}\n isOpen={!stage.id}\n canDelete={stages.length > 1 && canDelete}\n canReorder={stages.length > 1}\n canUpdate={canUpdate}\n stagesCount={stages.length}\n />\n </Box>\n );\n })}\n </Flex>\n </Box>\n\n {canUpdate && (\n <AddStage\n type=\"button\"\n onClick={() => {\n dispatch(addStage({ name: '' }));\n trackUsage('willCreateStage');\n }}\n >\n {formatMessage({\n id: 'Settings.review-workflows.stage.add',\n defaultMessage: 'Add new stage',\n })}\n </AddStage>\n )}\n </Flex>\n );\n};\n","import * as React from 'react';\n\nimport {\n Grid,\n GridItem,\n MultiSelect,\n MultiSelectGroup,\n MultiSelectOption,\n TextInput,\n Typography,\n} from '@strapi/design-system';\nimport { useCollator } from '@strapi/helper-plugin';\nimport { useField } from 'formik';\nimport { useIntl } from 'react-intl';\nimport { useDispatch, useSelector } from 'react-redux';\nimport styled from 'styled-components';\n\nimport { updateWorkflow } from '../actions';\nimport { selectContentTypes, selectCurrentWorkflow, selectWorkflows } from '../selectors';\n\nconst NestedOption = styled(MultiSelectOption)`\n padding-left: ${({ theme }) => theme.spaces[7]};\n`;\n\nconst ContentTypeTakeNotice = styled(Typography)`\n font-style: italic;\n`;\n\nexport type WorkflowAttributesProps = {\n canUpdate?: boolean;\n};\n\nexport const WorkflowAttributes = ({ canUpdate = true }: WorkflowAttributesProps) => {\n const { formatMessage, locale } = useIntl();\n const dispatch = useDispatch();\n const contentTypes = useSelector(selectContentTypes);\n const currentWorkflow = useSelector(selectCurrentWorkflow);\n const workflows = useSelector(selectWorkflows);\n const [nameField, nameMeta, nameHelper] = useField('name');\n const [contentTypesField, contentTypesMeta, contentTypesHelper] = useField('contentTypes');\n const formatter = useCollator(locale, {\n sensitivity: 'base',\n });\n\n return (\n <Grid background=\"neutral0\" hasRadius gap={4} padding={6} shadow=\"tableShadow\">\n <GridItem col={6}>\n <TextInput\n {...nameField}\n id={nameField.name}\n disabled={!canUpdate}\n label={formatMessage({\n id: 'Settings.review-workflows.workflow.name.label',\n defaultMessage: 'Workflow Name',\n })}\n error={nameMeta.error ?? false}\n onChange={(event) => {\n dispatch(updateWorkflow({ name: event.target.value }));\n nameHelper.setValue(event.target.value);\n }}\n required\n />\n </GridItem>\n\n {contentTypes && (\n <GridItem col={6}>\n <MultiSelect\n {...contentTypesField}\n customizeContent={(value) =>\n formatMessage(\n {\n id: 'Settings.review-workflows.workflow.contentTypes.displayValue',\n defaultMessage:\n '{count} {count, plural, one {content type} other {content types}} selected',\n },\n { count: value?.length }\n )\n }\n disabled={!canUpdate}\n error={contentTypesMeta.error ?? false}\n id={contentTypesField.name}\n label={formatMessage({\n id: 'Settings.review-workflows.workflow.contentTypes.label',\n defaultMessage: 'Associated to',\n })}\n onChange={(values) => {\n dispatch(updateWorkflow({ contentTypes: values }));\n contentTypesHelper.setValue(values);\n }}\n placeholder={formatMessage({\n id: 'Settings.review-workflows.workflow.contentTypes.placeholder',\n defaultMessage: 'Select',\n })}\n >\n {[\n ...(contentTypes.collectionTypes.length > 0\n ? [\n {\n label: formatMessage({\n id: 'Settings.review-workflows.workflow.contentTypes.collectionTypes.label',\n defaultMessage: 'Collection Types',\n }),\n children: [...contentTypes.collectionTypes]\n .sort((a, b) => formatter.compare(a.info.displayName, b.info.displayName))\n .map((contentType) => ({\n label: contentType.info.displayName,\n value: contentType.uid,\n })),\n },\n ]\n : []),\n\n ...(contentTypes.singleTypes.length > 0\n ? [\n {\n label: formatMessage({\n id: 'Settings.review-workflows.workflow.contentTypes.singleTypes.label',\n defaultMessage: 'Single Types',\n }),\n children: [...contentTypes.singleTypes].map((contentType) => ({\n label: contentType.info.displayName,\n value: contentType.uid,\n })),\n },\n ]\n : []),\n ].map((opt) => {\n if ('children' in opt) {\n return (\n <MultiSelectGroup\n key={opt.label}\n label={opt.label}\n values={opt.children.map((child) => child.value.toString())}\n >\n {opt.children.map((child) => {\n const { name: assignedWorkflowName } =\n workflows?.find(\n (workflow) =>\n ((currentWorkflow && workflow.id !== currentWorkflow.id) ||\n !currentWorkflow) &&\n workflow.contentTypes.includes(child.value)\n ) ?? {};\n\n return (\n <NestedOption key={child.value} value={child.value}>\n <Typography>\n {\n // @ts-expect-error - formatMessage options doesn't expect to be a React component but that's what we need actually for the <i> and <em> components\n formatMessage(\n {\n id: 'Settings.review-workflows.workflow.contentTypes.assigned.notice',\n defaultMessage:\n '{label} {name, select, undefined {} other {<i>(assigned to <em>{name}</em> workflow)</i>}}',\n },\n {\n label: child.label,\n name: assignedWorkflowName,\n em: (...children) => (\n <Typography as=\"em\" fontWeight=\"bold\">\n {children}\n </Typography>\n ),\n i: (...children) => (\n <ContentTypeTakeNotice>{children}</ContentTypeTakeNotice>\n ),\n }\n )\n }\n </Typography>\n </NestedOption>\n );\n })}\n </MultiSelectGroup>\n );\n }\n })}\n </MultiSelect>\n </GridItem>\n )}\n </Grid>\n );\n};\n","import set from 'lodash/set';\nimport { IntlFormatters } from 'react-intl';\nimport * as yup from 'yup';\n\nimport { Stage } from '../../../../../../../../shared/contracts/review-workflows';\nimport { PartialWorkflow } from '../reducer';\n\nexport async function validateWorkflow({\n values,\n formatMessage,\n}: { values: PartialWorkflow } & Pick<IntlFormatters, 'formatMessage'>) {\n const schema = yup.object({\n contentTypes: yup.array().of(yup.string()),\n name: yup\n .string()\n .max(\n 255,\n formatMessage({\n id: 'Settings.review-workflows.validation.name.max-length',\n defaultMessage: 'Name can not be longer than 255 characters',\n })\n )\n .required(),\n\n stages: yup\n .array()\n .of(\n yup.object().shape({\n name: yup\n .string()\n .required(\n formatMessage({\n id: 'Settings.review-workflows.validation.stage.name',\n defaultMessage: 'Name is required',\n })\n )\n .max(\n 255,\n formatMessage({\n id: 'Settings.review-workflows.validation.stage.max-length',\n defaultMessage: 'Name can not be longer than 255 characters',\n })\n )\n .test(\n 'unique-name',\n formatMessage({\n id: 'Settings.review-workflows.validation.stage.duplicate',\n defaultMessage: 'Stage name must be unique',\n }),\n function (stageName) {\n const {\n options: { context },\n } = this;\n\n return (\n context?.stages.filter((stage: Stage) => stage.name === stageName).length === 1\n );\n }\n ),\n color: yup\n .string()\n .required(\n formatMessage({\n id: 'Settings.review-workflows.validation.stage.color',\n defaultMessage: 'Color is required',\n })\n )\n .matches(/^#(?:[0-9a-fA-F]{3}){1,2}$/i),\n\n permissions: yup\n .array(\n yup.object({\n role: yup\n .number()\n .strict()\n .typeError(\n formatMessage({\n id: 'Settings.review-workflows.validation.stage.permissions.role.number',\n defaultMessage: 'Role must be of type number',\n })\n )\n .required(),\n action: yup.string().required({\n id: 'Settings.review-workflows.validation.stage.permissions.action.required',\n defaultMessage: 'Action is a required argument',\n }),\n })\n )\n .strict(),\n })\n )\n .min(1),\n });\n\n try {\n await schema.validate(values, { abortEarly: false, context: values });\n\n return true;\n } catch (error) {\n const errors = {};\n\n if (error instanceof yup.ValidationError) {\n error.inner.forEach((error) => {\n if (error.path) set(errors, error.path, error.message);\n });\n }\n\n return errors;\n }\n}\n"],"names":["reducer","NestedOption","index","themeColorName","error"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"validateWorkflow-mU9FqIYY.mjs","sources":["../../admin/src/hooks/useInjectReducer.ts","../../ee/admin/src/pages/SettingsPage/pages/ReviewWorkflows/actions.ts","../../ee/admin/src/pages/SettingsPage/pages/ReviewWorkflows/components/AddStage.tsx","../../ee/admin/src/pages/SettingsPage/pages/ReviewWorkflows/reducer.ts","../../ee/admin/src/pages/SettingsPage/pages/ReviewWorkflows/selectors.ts","../../ee/admin/src/pages/SettingsPage/pages/ReviewWorkflows/components/Stage.tsx","../../ee/admin/src/pages/SettingsPage/pages/ReviewWorkflows/components/Stages.tsx","../../ee/admin/src/pages/SettingsPage/pages/ReviewWorkflows/components/WorkflowAttributes.tsx","../../ee/admin/src/pages/SettingsPage/pages/ReviewWorkflows/utils/validateWorkflow.ts"],"sourcesContent":["import { useEffect } from 'react';\n\nimport { Reducer } from '@reduxjs/toolkit';\n\nimport { useTypedStore } from '../core/store/hooks';\n\n/**\n * Inject a new reducer into the global redux-store.\n *\n * @export\n * @param {string} namespace - Store namespace of the injected reducer\n * @param {Function} reducer - Reducer function\n * @return void\n */\n\nexport function useInjectReducer(namespace: string, reducer: Reducer) {\n const store = useTypedStore();\n\n useEffect(() => {\n store.injectReducer(namespace, reducer);\n }, [store, namespace, reducer]);\n}\n","import { Contracts } from '@strapi/plugin-content-manager/_internal/shared';\n\nimport { Stage, Workflow } from '../../../../../../../shared/contracts/review-workflows';\nimport { Permission, SanitizedAdminRole } from '../../../../../../../shared/contracts/shared';\n\nimport {\n ACTION_ADD_STAGE,\n ACTION_CLONE_STAGE,\n ACTION_DELETE_STAGE,\n ACTION_RESET_WORKFLOW,\n ACTION_SET_CONTENT_TYPES,\n ACTION_SET_IS_LOADING,\n ACTION_SET_ROLES,\n ACTION_SET_WORKFLOW,\n ACTION_SET_WORKFLOWS,\n ACTION_UPDATE_STAGE,\n ACTION_UPDATE_STAGES,\n ACTION_UPDATE_STAGE_POSITION,\n ACTION_UPDATE_WORKFLOW,\n} from './constants';\n\nexport function cloneStage(id: number) {\n return {\n type: ACTION_CLONE_STAGE,\n payload: { id },\n };\n}\n\nexport function setWorkflow({ workflow }: { workflow: Workflow | null }) {\n return {\n type: ACTION_SET_WORKFLOW,\n payload: workflow,\n };\n}\n\nexport function setWorkflows({ workflows }: { workflows: Workflow[] }) {\n return {\n type: ACTION_SET_WORKFLOWS,\n payload: workflows,\n };\n}\n\nexport function deleteStage(stageId: number) {\n return {\n type: ACTION_DELETE_STAGE,\n payload: {\n stageId,\n },\n };\n}\n\nexport function addStage(stage: Partial<Stage>) {\n return {\n type: ACTION_ADD_STAGE,\n payload: stage,\n };\n}\n\nexport interface PartialStage extends Omit<Stage, 'permissions'> {\n permissions?: Partial<Permission>[];\n}\n\nexport function updateStage(stageId: number, payload: Partial<PartialStage>) {\n return {\n type: ACTION_UPDATE_STAGE,\n payload: {\n stageId,\n ...payload,\n },\n };\n}\n\nexport function updateStages(payload: Partial<PartialStage>) {\n return {\n type: ACTION_UPDATE_STAGES,\n payload,\n };\n}\n\nexport function updateStagePosition(oldIndex: number, newIndex: number) {\n return {\n type: ACTION_UPDATE_STAGE_POSITION,\n payload: {\n newIndex,\n oldIndex,\n },\n };\n}\n\nexport function updateWorkflow(payload: Partial<Workflow>) {\n return {\n type: ACTION_UPDATE_WORKFLOW,\n payload,\n };\n}\n\nexport function resetWorkflow() {\n return {\n type: ACTION_RESET_WORKFLOW,\n };\n}\n\nexport function setContentTypes(payload: {\n collectionTypes?: Contracts.ContentTypes.ContentType[];\n singleTypes?: Contracts.ContentTypes.ContentType[];\n}) {\n return {\n type: ACTION_SET_CONTENT_TYPES,\n payload,\n };\n}\n\nexport function setRoles(payload?: (SanitizedAdminRole & { usersCount?: number | undefined })[]) {\n return {\n type: ACTION_SET_ROLES,\n payload,\n };\n}\n\nexport function setIsLoading(isLoading: boolean) {\n return {\n type: ACTION_SET_IS_LOADING,\n payload: isLoading,\n };\n}\n","import React from 'react';\n\nimport { Box, ButtonProps, Flex, Typography } from '@strapi/design-system';\nimport { PlusCircle } from '@strapi/icons';\nimport PropTypes from 'prop-types';\nimport styled from 'styled-components';\n\nconst StyledAddIcon = styled(PlusCircle)`\n > circle {\n fill: ${({ theme }) => theme.colors.neutral150};\n }\n > path {\n fill: ${({ theme }) => theme.colors.neutral600};\n }\n`;\n\nconst StyledButton = styled(Box)`\n border-radius: 26px;\n\n svg {\n height: ${({ theme }) => theme.spaces[6]};\n width: ${({ theme }) => theme.spaces[6]};\n\n > path {\n fill: ${({ theme }) => theme.colors.neutral600};\n }\n }\n\n &:hover {\n color: ${({ theme }) => theme.colors.primary600} !important;\n ${Typography} {\n color: ${({ theme }) => theme.colors.primary600} !important;\n }\n\n ${StyledAddIcon} {\n > circle {\n fill: ${({ theme }) => theme.colors.primary600};\n }\n > path {\n fill: ${({ theme }) => theme.colors.neutral100};\n }\n }\n }\n\n &:active {\n ${Typography} {\n color: ${({ theme }) => theme.colors.primary600};\n }\n\n ${StyledAddIcon} {\n > circle {\n fill: ${({ theme }) => theme.colors.primary600};\n }\n > path {\n fill: ${({ theme }) => theme.colors.neutral100};\n }\n }\n }\n`;\n\nexport const AddStage = ({ children, ...props }: ButtonProps) => {\n return (\n <StyledButton\n as=\"button\"\n background=\"neutral0\"\n border=\"neutral150\"\n paddingBottom={3}\n paddingLeft={4}\n paddingRight={4}\n paddingTop={3}\n shadow=\"filterShadow\"\n {...props}\n >\n <Flex gap={2}>\n <StyledAddIcon aria-hidden />\n\n <Typography variant=\"pi\" fontWeight=\"bold\" textColor=\"neutral500\">\n {children}\n </Typography>\n </Flex>\n </StyledButton>\n );\n};\n\nAddStage.propTypes = {\n children: PropTypes.node.isRequired,\n};\n","import { Schema } from '@strapi/types';\nimport { createDraft, produce } from 'immer';\n\nimport {\n Stage,\n StagePermission,\n Workflow,\n} from '../../../../../../../shared/contracts/review-workflows';\nimport { AdminRole } from '../../../../../../../shared/contracts/shared';\n\nimport {\n ACTION_ADD_STAGE,\n ACTION_CLONE_STAGE,\n ACTION_DELETE_STAGE,\n ACTION_RESET_WORKFLOW,\n ACTION_SET_CONTENT_TYPES,\n ACTION_SET_IS_LOADING,\n ACTION_SET_ROLES,\n ACTION_SET_WORKFLOW,\n ACTION_SET_WORKFLOWS,\n ACTION_UPDATE_STAGE,\n ACTION_UPDATE_STAGES,\n ACTION_UPDATE_STAGE_POSITION,\n ACTION_UPDATE_WORKFLOW,\n STAGE_COLOR_DEFAULT,\n} from './constants';\n\nexport type CurrentWorkflow = Partial<\n Pick<Workflow, 'name' | 'contentTypes' | 'stages' | 'id'> & {\n permissions?: StagePermission[];\n }\n>;\n\nexport type PartialWorkflow = Omit<CurrentWorkflow, 'stages'> & { stages?: Partial<Stage>[] };\n\nexport interface ServerState {\n contentTypes?: {\n collectionTypes: Schema.CollectionType[];\n singleTypes: Schema.SingleType[];\n };\n roles?: AdminRole[];\n workflow?: PartialWorkflow | null;\n workflows?: Workflow[];\n}\n\n// This isn't something we should do.\n// TODO: Revamp the way we are handling this temp key for delete or create\nexport type StageWithTempKey = Stage & { __temp_key__?: number };\nexport interface ClientState {\n currentWorkflow: {\n data: Partial<Omit<CurrentWorkflow, 'stages'> & { stages: StageWithTempKey[] }>;\n };\n isLoading?: boolean;\n}\n\nexport type State = {\n serverState: ServerState;\n clientState: ClientState;\n};\n\nexport const initialState: State = {\n serverState: {\n contentTypes: {\n collectionTypes: [],\n singleTypes: [],\n },\n roles: [],\n workflow: null,\n workflows: [],\n },\n clientState: {\n currentWorkflow: {\n data: {\n name: '',\n contentTypes: [],\n stages: [],\n permissions: undefined,\n },\n },\n isLoading: true,\n },\n};\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport function reducer(state: State = initialState, action: { type: string; payload?: any }) {\n return produce(state, (draft) => {\n const { payload } = action;\n\n switch (action.type) {\n case ACTION_SET_CONTENT_TYPES: {\n draft.serverState.contentTypes = payload;\n break;\n }\n\n case ACTION_SET_IS_LOADING: {\n draft.clientState.isLoading = payload;\n break;\n }\n\n case ACTION_SET_ROLES: {\n draft.serverState.roles = payload;\n break;\n }\n\n case ACTION_SET_WORKFLOW: {\n const workflow: Workflow = payload;\n\n if (workflow) {\n draft.serverState.workflow = workflow;\n draft.clientState.currentWorkflow.data = {\n ...workflow,\n stages: workflow.stages.map((stage) => ({\n ...stage,\n // A safety net in case a stage does not have a color assigned;\n // this should not happen\n color: stage?.color ?? STAGE_COLOR_DEFAULT,\n })),\n };\n }\n break;\n }\n\n case ACTION_SET_WORKFLOWS: {\n draft.serverState.workflows = payload;\n break;\n }\n\n case ACTION_RESET_WORKFLOW: {\n draft.clientState = initialState.clientState;\n draft.serverState = createDraft(initialState.serverState);\n break;\n }\n\n case ACTION_DELETE_STAGE: {\n const { stageId } = payload;\n const { currentWorkflow } = state.clientState;\n\n draft.clientState.currentWorkflow.data.stages = currentWorkflow.data.stages?.filter(\n (stage) => (stage?.id ?? stage.__temp_key__) !== stageId\n );\n\n break;\n }\n\n case ACTION_ADD_STAGE: {\n const { currentWorkflow } = state.clientState;\n\n if (!currentWorkflow.data) {\n draft.clientState.currentWorkflow.data = {\n stages: [],\n };\n }\n\n const newTempKey = getMaxTempKey(draft.clientState.currentWorkflow.data.stages);\n\n draft.clientState.currentWorkflow.data.stages?.push({\n ...payload,\n color: payload?.color ?? STAGE_COLOR_DEFAULT,\n __temp_key__: newTempKey,\n });\n\n break;\n }\n\n case ACTION_CLONE_STAGE: {\n const { currentWorkflow } = state.clientState;\n const { id } = payload;\n\n const sourceStageIndex = currentWorkflow.data.stages?.findIndex(\n (stage) => (stage?.id ?? stage?.__temp_key__) === id\n );\n\n if (sourceStageIndex !== undefined && sourceStageIndex !== -1) {\n const sourceStage = currentWorkflow.data.stages?.[sourceStageIndex];\n\n draft.clientState.currentWorkflow.data.stages?.splice(sourceStageIndex + 1, 0, {\n ...sourceStage,\n // @ts-expect-error - We are handling temporary (unsaved) duplicated stages with temporary keys and undefined ids. It should be revamp imo\n id: undefined,\n __temp_key__: getMaxTempKey(draft.clientState.currentWorkflow.data.stages),\n });\n }\n\n break;\n }\n\n case ACTION_UPDATE_STAGE: {\n const { currentWorkflow } = state.clientState;\n const { stageId, ...modified } = payload;\n\n draft.clientState.currentWorkflow.data.stages = currentWorkflow.data.stages?.map((stage) =>\n (stage.id ?? stage.__temp_key__) === stageId\n ? {\n ...stage,\n ...modified,\n }\n : stage\n );\n\n break;\n }\n\n case ACTION_UPDATE_STAGES: {\n const { currentWorkflow } = state.clientState;\n\n draft.clientState.currentWorkflow.data.stages = currentWorkflow.data.stages?.map(\n (stage) => ({\n ...stage,\n ...payload,\n })\n );\n\n break;\n }\n\n case ACTION_UPDATE_STAGE_POSITION: {\n const {\n currentWorkflow: {\n data: { stages },\n },\n } = state.clientState;\n const { newIndex, oldIndex } = payload;\n\n if (stages && newIndex >= 0 && newIndex < stages.length) {\n const stage = stages[oldIndex];\n const newStages = [...stages];\n\n newStages.splice(oldIndex, 1);\n newStages.splice(newIndex, 0, stage);\n\n draft.clientState.currentWorkflow.data.stages = newStages;\n }\n\n break;\n }\n\n case ACTION_UPDATE_WORKFLOW: {\n draft.clientState.currentWorkflow.data = {\n ...draft.clientState.currentWorkflow.data,\n ...payload,\n };\n\n break;\n }\n\n default:\n break;\n }\n });\n}\n\nconst getMaxTempKey = (stages: StageWithTempKey[] = []): number => {\n const ids = stages.map((stage) => Number(stage.id ?? stage.__temp_key__));\n\n /**\n * If there are no ids it will return 0 as the max value\n * because the max value is -1.\n */\n return Math.max(...ids, -1) + 1;\n};\n","import { createSelector } from '@reduxjs/toolkit';\nimport isEqual from 'lodash/isEqual';\n\nimport { RootState } from '../../../../../../../admin/src/core/store/configure';\nimport { Stage } from '../../../../../../../shared/contracts/review-workflows';\n\nimport { REDUX_NAMESPACE } from './constants';\nimport { State, initialState } from './reducer';\n\ninterface Store extends RootState {\n [REDUX_NAMESPACE]: State;\n}\n\nexport const selectNamespace = (state: Store) => state[REDUX_NAMESPACE] ?? initialState;\n\nexport const selectContentTypes = createSelector(\n selectNamespace,\n ({ serverState: { contentTypes } }) => contentTypes\n);\n\nexport const selectRoles = createSelector(selectNamespace, ({ serverState: { roles } }) => roles);\n\nexport const selectCurrentWorkflow = createSelector(\n selectNamespace,\n ({ clientState: { currentWorkflow } }) => currentWorkflow.data\n);\n\nexport const selectWorkflows = createSelector(\n selectNamespace,\n ({ serverState: { workflows } }) => workflows\n);\n\nexport const selectIsWorkflowDirty = createSelector(\n selectNamespace,\n ({ serverState, clientState: { currentWorkflow } }) =>\n !isEqual(serverState.workflow, currentWorkflow.data)\n);\n\nexport const selectHasDeletedServerStages = createSelector(\n selectNamespace,\n ({ serverState, clientState: { currentWorkflow } }) =>\n !(serverState.workflow?.stages ?? []).every(\n (stage: Partial<Stage>) => !!currentWorkflow.data.stages?.find(({ id }) => id === stage.id)\n )\n);\n\nexport const selectIsLoading = createSelector(\n selectNamespace,\n ({ clientState: { isLoading } }) => isLoading\n);\n\nexport const selectServerState = createSelector(selectNamespace, ({ serverState }) => serverState);\n","import * as React from 'react';\n\nimport {\n Accordion,\n AccordionContent,\n AccordionToggle,\n Box,\n Flex,\n Grid,\n GridItem,\n IconButton,\n MultiSelect,\n MultiSelectGroup,\n MultiSelectOption,\n SingleSelect,\n SingleSelectOption,\n TextInput,\n Typography,\n VisuallyHidden,\n} from '@strapi/design-system';\nimport { Menu, MenuItem } from '@strapi/design-system/v2';\nimport {\n ConfirmDialog,\n useNotification,\n NotAllowedInput,\n useTracking,\n} from '@strapi/helper-plugin';\nimport { Duplicate, Drag, More } from '@strapi/icons';\nimport { useField } from 'formik';\nimport { getEmptyImage } from 'react-dnd-html5-backend';\nimport { useIntl } from 'react-intl';\nimport { useDispatch, useSelector } from 'react-redux';\nimport styled from 'styled-components';\n\nimport { useDragAndDrop } from '../../../../../../../../admin/src/content-manager/hooks/useDragAndDrop';\nimport { composeRefs } from '../../../../../../../../admin/src/content-manager/utils/refs';\nimport { StagePermission } from '../../../../../../../../shared/contracts/review-workflows';\nimport {\n cloneStage,\n deleteStage,\n updateStage,\n updateStagePosition,\n updateStages,\n} from '../actions';\nimport { DRAG_DROP_TYPES } from '../constants';\nimport { selectRoles } from '../selectors';\nimport { getAvailableStageColors, getStageColorByHex } from '../utils/colors';\n\nconst NestedOption = styled(MultiSelectOption)`\n padding-left: ${({ theme }) => theme.spaces[7]};\n`;\n\n// Grow the size of the permission Select\nconst PermissionWrapper = styled(Flex)`\n > * {\n flex-grow: 1;\n }\n`;\n\nconst DeleteMenuItem = styled(MenuItem)`\n color: ${({ theme }) => theme.colors.danger600};\n`;\n\n// Removing the font-size from the child-span aligns the\n// more icon vertically\nconst ContextMenuTrigger = styled(Menu.Trigger)`\n :hover,\n :focus {\n background-color: ${({ theme }) => theme.colors.neutral100};\n }\n\n > span {\n font-size: 0;\n }\n`;\n\n// As soon as either `as` or `forwardedAs` is set, the component\n// resets some styles and e.g. the `hasBorder` prop no longer works,\n// which is why this bit of CSS has been added manually ¯\\_(ツ)_/¯\nconst DragIconButton = styled(IconButton)`\n align-items: center;\n border-radius: ${({ theme }) => theme.borderRadius};\n display: flex;\n justify-content: center;\n\n :hover,\n :focus {\n background-color: ${({ theme }) => theme.colors.neutral100};\n }\n\n svg {\n height: auto;\n width: ${({ theme }) => theme.spaces[3]}};\n }\n`;\n\nconst AVAILABLE_COLORS = getAvailableStageColors();\n\nconst StageDropPreview = () => {\n return (\n <Box\n background=\"primary100\"\n borderStyle=\"dashed\"\n borderColor=\"primary600\"\n borderWidth=\"1px\"\n display=\"block\"\n hasRadius\n padding={6}\n shadow=\"tableShadow\"\n />\n );\n};\n\nexport type StageProps = {\n id: number;\n index: number;\n canDelete: boolean;\n canReorder: boolean;\n canUpdate: boolean;\n isOpen: boolean;\n stagesCount: number;\n};\n\nexport const Stage = ({\n id,\n index,\n canDelete,\n canReorder,\n canUpdate,\n isOpen: isOpenDefault = false,\n stagesCount,\n}: StageProps) => {\n const getItemPos = (index: number) => `${index + 1} of ${stagesCount}`;\n\n const handleGrabStage = (index: number) => {\n setLiveText(\n formatMessage(\n {\n id: 'dnd.grab-item',\n defaultMessage: `{item}, grabbed. Current position in list: {position}. Press up and down arrow to change position, Spacebar to drop, Escape to cancel.`,\n },\n {\n item: nameField.value,\n position: getItemPos(index),\n }\n )\n );\n };\n\n const handleDropStage = (index: number) => {\n setLiveText(\n formatMessage(\n {\n id: 'dnd.drop-item',\n defaultMessage: `{item}, dropped. Final position in list: {position}.`,\n },\n {\n item: nameField.value,\n position: getItemPos(index),\n }\n )\n );\n };\n\n const handleCancelDragStage = () => {\n setLiveText(\n formatMessage(\n {\n id: 'dnd.cancel-item',\n defaultMessage: '{item}, dropped. Re-order cancelled.',\n },\n {\n item: nameField.value,\n }\n )\n );\n };\n\n const handleMoveStage = (newIndex: number, oldIndex: number) => {\n setLiveText(\n formatMessage(\n {\n id: 'dnd.reorder',\n defaultMessage: '{item}, moved. New position in list: {position}.',\n },\n {\n item: nameField.value,\n position: getItemPos(newIndex),\n }\n )\n );\n\n dispatch(updateStagePosition(oldIndex, newIndex));\n };\n\n const handleApplyPermissionsToAllStages = () => {\n setIsApplyAllConfirmationOpen(true);\n };\n\n const [liveText, setLiveText] = React.useState(null);\n const { formatMessage } = useIntl();\n const { trackUsage } = useTracking();\n const dispatch = useDispatch();\n const toggleNotification = useNotification();\n const [isOpen, setIsOpen] = React.useState(isOpenDefault);\n const [isApplyAllConfirmationOpen, setIsApplyAllConfirmationOpen] = React.useState(false);\n const [nameField, nameMeta, nameHelper] = useField(`stages.${index}.name`);\n const [colorField, colorMeta, colorHelper] = useField(`stages.${index}.color`);\n const [permissionsField, permissionsMeta, permissionsHelper] = useField<\n Partial<StagePermission>[]\n >(`stages.${index}.permissions`);\n const roles = useSelector(selectRoles);\n const [{ handlerId, isDragging, handleKeyDown }, stageRef, dropRef, dragRef, dragPreviewRef] =\n useDragAndDrop(canReorder, {\n index,\n item: {\n index,\n name: nameField.value,\n },\n onGrabItem: handleGrabStage,\n onDropItem: handleDropStage,\n onMoveItem: handleMoveStage,\n onCancel: handleCancelDragStage,\n type: DRAG_DROP_TYPES.STAGE,\n });\n\n const composedRef = composeRefs(stageRef, dropRef);\n\n const colorOptions = AVAILABLE_COLORS.map(({ hex, name }) => ({\n value: hex,\n label: formatMessage(\n {\n id: 'Settings.review-workflows.stage.color.name',\n defaultMessage: '{name}',\n },\n { name }\n ),\n color: hex,\n }));\n\n const { themeColorName } = getStageColorByHex(colorField.value) ?? {};\n\n const filteredRoles = roles\n // Super admins always have permissions to do everything and therefore\n // there is no point for this role to show up in the role combobox\n ?.filter((role) => role.code !== 'strapi-super-admin');\n\n React.useEffect(() => {\n dragPreviewRef(getEmptyImage(), { captureDraggingState: false });\n }, [dragPreviewRef, index]);\n\n return (\n <Box ref={(ref) => composedRef(ref!)}>\n {liveText && <VisuallyHidden aria-live=\"assertive\">{liveText}</VisuallyHidden>}\n\n {isDragging ? (\n <StageDropPreview />\n ) : (\n <Accordion\n size=\"S\"\n variant=\"primary\"\n onToggle={() => {\n setIsOpen(!isOpen);\n\n if (!isOpen) {\n trackUsage('willEditStage');\n }\n }}\n expanded={isOpen}\n shadow=\"tableShadow\"\n error={nameMeta.error ?? colorMeta?.error ?? permissionsMeta?.error}\n hasErrorMessage={false}\n >\n <AccordionToggle\n title={nameField.value}\n togglePosition=\"left\"\n action={\n (canDelete || canUpdate) && (\n <Flex>\n <Menu.Root>\n <ContextMenuTrigger size=\"S\" endIcon={null} paddingLeft={2} paddingRight={2}>\n <More aria-hidden focusable={false} />\n <VisuallyHidden as=\"span\">\n {formatMessage({\n id: '[tbdb].components.DynamicZone.more-actions',\n defaultMessage: 'More actions',\n })}\n </VisuallyHidden>\n </ContextMenuTrigger>\n {/* z-index needs to be as big as the one defined for the wrapper in Stages, otherwise the menu\n * disappears behind the accordion\n */}\n <Menu.Content popoverPlacement=\"bottom-end\" zIndex={2}>\n <Menu.SubRoot>\n {canUpdate && (\n <MenuItem onClick={() => dispatch(cloneStage(id))}>\n {formatMessage({\n id: 'Settings.review-workflows.stage.delete',\n defaultMessage: 'Duplicate stage',\n })}\n </MenuItem>\n )}\n\n {canDelete && (\n <DeleteMenuItem onClick={() => dispatch(deleteStage(id))}>\n {formatMessage({\n id: 'Settings.review-workflows.stage.delete',\n defaultMessage: 'Delete',\n })}\n </DeleteMenuItem>\n )}\n </Menu.SubRoot>\n </Menu.Content>\n </Menu.Root>\n\n {canUpdate && (\n <DragIconButton\n background=\"transparent\"\n // @ts-expect-error - forwardedAs needs to be defined as string in the IconButton props\n forwardedAs=\"div\"\n hasRadius\n role=\"button\"\n noBorder\n tabIndex={0}\n data-handler-id={handlerId}\n ref={dragRef}\n label={formatMessage({\n id: 'Settings.review-workflows.stage.drag',\n defaultMessage: 'Drag',\n })}\n onClick={(e) => e.stopPropagation()}\n onKeyDown={handleKeyDown}\n >\n <Drag />\n </DragIconButton>\n )}\n </Flex>\n )\n }\n />\n <AccordionContent padding={6} background=\"neutral0\" hasRadius>\n <Grid gap={4}>\n <GridItem col={6}>\n <TextInput\n {...nameField}\n id={nameField.name}\n disabled={!canUpdate}\n label={formatMessage({\n id: 'Settings.review-workflows.stage.name.label',\n defaultMessage: 'Stage name',\n })}\n error={nameMeta.error ?? false}\n onChange={(event) => {\n nameHelper.setValue(event.target.value);\n dispatch(updateStage(id, { name: event.target.value }));\n }}\n required\n />\n </GridItem>\n\n <GridItem col={6}>\n <SingleSelect\n disabled={!canUpdate}\n error={colorMeta?.error ?? false}\n id={colorField.name}\n required\n label={formatMessage({\n id: 'content-manager.reviewWorkflows.stage.color',\n defaultMessage: 'Color',\n })}\n onChange={(value) => {\n colorHelper.setValue(value);\n dispatch(updateStage(id, { color: String(value) }));\n }}\n value={colorField.value.toUpperCase()}\n startIcon={\n <Flex\n as=\"span\"\n height={2}\n background={colorField.value}\n // @ts-expect-error - transparent doesn't exist in theme.colors\n borderColor={themeColorName === 'neutral0' ? 'neutral150' : 'transparent'}\n hasRadius\n shrink={0}\n width={2}\n />\n }\n >\n {colorOptions.map(({ value, label, color }) => {\n const { themeColorName } = getStageColorByHex(color) || {};\n\n return (\n <SingleSelectOption\n value={value}\n key={value}\n startIcon={\n <Flex\n as=\"span\"\n height={2}\n background={color}\n // @ts-expect-error - transparent doesn't exist in theme.colors\n borderColor={\n themeColorName === 'neutral0' ? 'neutral150' : 'transparent'\n }\n hasRadius\n shrink={0}\n width={2}\n />\n }\n >\n {label}\n </SingleSelectOption>\n );\n })}\n </SingleSelect>\n </GridItem>\n\n <GridItem col={6}>\n {filteredRoles?.length === 0 ? (\n <NotAllowedInput\n description={{\n id: 'Settings.review-workflows.stage.permissions.noPermissions.description',\n defaultMessage: 'You don’t have the permission to see roles',\n }}\n intlLabel={{\n id: 'Settings.review-workflows.stage.permissions.label',\n defaultMessage: 'Roles that can change this stage',\n }}\n name={permissionsField.name}\n />\n ) : (\n <Flex alignItems=\"flex-end\" gap={3}>\n <PermissionWrapper grow={1}>\n <MultiSelect\n {...permissionsField}\n disabled={!canUpdate}\n error={permissionsMeta.error ?? false}\n id={permissionsField.name}\n label={formatMessage({\n id: 'Settings.review-workflows.stage.permissions.label',\n defaultMessage: 'Roles that can change this stage',\n })}\n onChange={(values) => {\n // Because the select components expects strings for values, but\n // the yup schema validates we are sending full permission objects to the API,\n // we must coerce the string value back to an object\n const permissions = values.map((value) => ({\n role: parseInt(value, 10),\n action: 'admin::review-workflows.stage.transition',\n }));\n\n permissionsHelper.setValue(permissions);\n dispatch(updateStage(id, { permissions }));\n }}\n placeholder={formatMessage({\n id: 'Settings.review-workflows.stage.permissions.placeholder',\n defaultMessage: 'Select a role',\n })}\n required\n // The Select component expects strings for values\n value={(permissionsField.value ?? []).map(\n (permission) => `${permission.role}`\n )}\n withTags\n >\n <MultiSelectGroup\n label={formatMessage({\n id: 'Settings.review-workflows.stage.permissions.allRoles.label',\n defaultMessage: 'All roles',\n })}\n values={filteredRoles?.map((r) => `${r.id}`)}\n >\n {filteredRoles?.map((role) => {\n return (\n <NestedOption key={role.id} value={`${role.id}`}>\n {role.name}\n </NestedOption>\n );\n })}\n </MultiSelectGroup>\n </MultiSelect>\n </PermissionWrapper>\n\n <IconButton\n disabled={!canUpdate}\n icon={<Duplicate />}\n label={formatMessage({\n id: 'Settings.review-workflows.stage.permissions.apply.label',\n defaultMessage: 'Apply to all stages',\n })}\n size=\"L\"\n variant=\"secondary\"\n onClick={() => handleApplyPermissionsToAllStages()}\n />\n </Flex>\n )}\n </GridItem>\n </Grid>\n </AccordionContent>\n </Accordion>\n )}\n\n <ConfirmDialog.Root\n iconRightButton={null}\n isOpen={isApplyAllConfirmationOpen}\n onToggleDialog={() => setIsApplyAllConfirmationOpen(false)}\n onConfirm={() => {\n dispatch(updateStages({ permissions: permissionsField.value }));\n setIsApplyAllConfirmationOpen(false);\n toggleNotification({\n type: 'success',\n message: formatMessage({\n id: 'Settings.review-workflows.page.edit.confirm.stages.permissions.copy.success',\n defaultMessage: 'Applied roles to all other stages of the workflow',\n }),\n });\n }}\n variantRightButton=\"default\"\n >\n <ConfirmDialog.Body>\n <Typography textAlign=\"center\" variant=\"omega\">\n {formatMessage({\n id: 'Settings.review-workflows.page.edit.confirm.stages.permissions.copy',\n defaultMessage:\n 'Roles that can change that stage will be applied to all the other stages.',\n })}\n </Typography>\n </ConfirmDialog.Body>\n </ConfirmDialog.Root>\n </Box>\n );\n};\n","import React from 'react';\n\nimport { Box, Flex } from '@strapi/design-system';\nimport { useTracking } from '@strapi/helper-plugin';\nimport { useIntl } from 'react-intl';\nimport { useDispatch } from 'react-redux';\nimport styled from 'styled-components';\n\nimport { Stage as StageType } from '../../../../../../../../shared/contracts/review-workflows';\nimport { addStage } from '../actions';\n\nimport { AddStage } from './AddStage';\nimport { Stage } from './Stage';\n\nconst Background = styled(Box)`\n transform: translateX(-50%);\n`;\n\nexport type StagesProps = {\n canDelete?: boolean;\n canUpdate?: boolean;\n stages?: StageType[];\n};\n\nexport const Stages = ({ canDelete = true, canUpdate = true, stages = [] }: StagesProps) => {\n const { formatMessage } = useIntl();\n const dispatch = useDispatch();\n const { trackUsage } = useTracking();\n\n return (\n <Flex direction=\"column\" gap={6} width=\"100%\">\n <Box position=\"relative\" width=\"100%\">\n <Background\n background=\"neutral200\"\n height=\"100%\"\n left=\"50%\"\n position=\"absolute\"\n top=\"0\"\n width={2}\n zIndex={1}\n />\n\n <Flex\n direction=\"column\"\n alignItems=\"stretch\"\n gap={6}\n zIndex={2}\n position=\"relative\"\n as=\"ol\"\n >\n {stages.map((stage, index) => {\n // @ts-expect-error - temp key should be fixed in order to use another value\n const id = Number(stage?.id ?? stage.__temp_key__);\n\n return (\n <Box key={`stage-${id}`} as=\"li\">\n <Stage\n id={id}\n index={index}\n isOpen={!stage.id}\n canDelete={stages.length > 1 && canDelete}\n canReorder={stages.length > 1}\n canUpdate={canUpdate}\n stagesCount={stages.length}\n />\n </Box>\n );\n })}\n </Flex>\n </Box>\n\n {canUpdate && (\n <AddStage\n type=\"button\"\n onClick={() => {\n dispatch(addStage({ name: '' }));\n trackUsage('willCreateStage');\n }}\n >\n {formatMessage({\n id: 'Settings.review-workflows.stage.add',\n defaultMessage: 'Add new stage',\n })}\n </AddStage>\n )}\n </Flex>\n );\n};\n","import * as React from 'react';\n\nimport {\n Grid,\n GridItem,\n MultiSelect,\n MultiSelectGroup,\n MultiSelectOption,\n TextInput,\n Typography,\n} from '@strapi/design-system';\nimport { useCollator } from '@strapi/helper-plugin';\nimport { useField } from 'formik';\nimport { useIntl } from 'react-intl';\nimport { useDispatch, useSelector } from 'react-redux';\nimport styled from 'styled-components';\n\nimport { updateWorkflow } from '../actions';\nimport { selectContentTypes, selectCurrentWorkflow, selectWorkflows } from '../selectors';\n\nconst NestedOption = styled(MultiSelectOption)`\n padding-left: ${({ theme }) => theme.spaces[7]};\n`;\n\nconst ContentTypeTakeNotice = styled(Typography)`\n font-style: italic;\n`;\n\nexport type WorkflowAttributesProps = {\n canUpdate?: boolean;\n};\n\nexport const WorkflowAttributes = ({ canUpdate = true }: WorkflowAttributesProps) => {\n const { formatMessage, locale } = useIntl();\n const dispatch = useDispatch();\n const contentTypes = useSelector(selectContentTypes);\n const currentWorkflow = useSelector(selectCurrentWorkflow);\n const workflows = useSelector(selectWorkflows);\n const [nameField, nameMeta, nameHelper] = useField('name');\n const [contentTypesField, contentTypesMeta, contentTypesHelper] = useField('contentTypes');\n const formatter = useCollator(locale, {\n sensitivity: 'base',\n });\n\n return (\n <Grid background=\"neutral0\" hasRadius gap={4} padding={6} shadow=\"tableShadow\">\n <GridItem col={6}>\n <TextInput\n {...nameField}\n id={nameField.name}\n disabled={!canUpdate}\n label={formatMessage({\n id: 'Settings.review-workflows.workflow.name.label',\n defaultMessage: 'Workflow Name',\n })}\n error={nameMeta.error ?? false}\n onChange={(event) => {\n dispatch(updateWorkflow({ name: event.target.value }));\n nameHelper.setValue(event.target.value);\n }}\n required\n />\n </GridItem>\n\n {contentTypes && (\n <GridItem col={6}>\n <MultiSelect\n {...contentTypesField}\n customizeContent={(value) =>\n formatMessage(\n {\n id: 'Settings.review-workflows.workflow.contentTypes.displayValue',\n defaultMessage:\n '{count} {count, plural, one {content type} other {content types}} selected',\n },\n { count: value?.length }\n )\n }\n disabled={!canUpdate}\n error={contentTypesMeta.error ?? false}\n id={contentTypesField.name}\n label={formatMessage({\n id: 'Settings.review-workflows.workflow.contentTypes.label',\n defaultMessage: 'Associated to',\n })}\n onChange={(values) => {\n dispatch(updateWorkflow({ contentTypes: values }));\n contentTypesHelper.setValue(values);\n }}\n placeholder={formatMessage({\n id: 'Settings.review-workflows.workflow.contentTypes.placeholder',\n defaultMessage: 'Select',\n })}\n >\n {[\n ...(contentTypes.collectionTypes.length > 0\n ? [\n {\n label: formatMessage({\n id: 'Settings.review-workflows.workflow.contentTypes.collectionTypes.label',\n defaultMessage: 'Collection Types',\n }),\n children: [...contentTypes.collectionTypes]\n .sort((a, b) => formatter.compare(a.info.displayName, b.info.displayName))\n .map((contentType) => ({\n label: contentType.info.displayName,\n value: contentType.uid,\n })),\n },\n ]\n : []),\n\n ...(contentTypes.singleTypes.length > 0\n ? [\n {\n label: formatMessage({\n id: 'Settings.review-workflows.workflow.contentTypes.singleTypes.label',\n defaultMessage: 'Single Types',\n }),\n children: [...contentTypes.singleTypes].map((contentType) => ({\n label: contentType.info.displayName,\n value: contentType.uid,\n })),\n },\n ]\n : []),\n ].map((opt) => {\n if ('children' in opt) {\n return (\n <MultiSelectGroup\n key={opt.label}\n label={opt.label}\n values={opt.children.map((child) => child.value.toString())}\n >\n {opt.children.map((child) => {\n const { name: assignedWorkflowName } =\n workflows?.find(\n (workflow) =>\n ((currentWorkflow && workflow.id !== currentWorkflow.id) ||\n !currentWorkflow) &&\n workflow.contentTypes.includes(child.value)\n ) ?? {};\n\n return (\n <NestedOption key={child.value} value={child.value}>\n <Typography>\n {\n // @ts-expect-error - formatMessage options doesn't expect to be a React component but that's what we need actually for the <i> and <em> components\n formatMessage(\n {\n id: 'Settings.review-workflows.workflow.contentTypes.assigned.notice',\n defaultMessage:\n '{label} {name, select, undefined {} other {<i>(assigned to <em>{name}</em> workflow)</i>}}',\n },\n {\n label: child.label,\n name: assignedWorkflowName,\n em: (...children) => (\n <Typography as=\"em\" fontWeight=\"bold\">\n {children}\n </Typography>\n ),\n i: (...children) => (\n <ContentTypeTakeNotice>{children}</ContentTypeTakeNotice>\n ),\n }\n )\n }\n </Typography>\n </NestedOption>\n );\n })}\n </MultiSelectGroup>\n );\n }\n })}\n </MultiSelect>\n </GridItem>\n )}\n </Grid>\n );\n};\n","import set from 'lodash/set';\nimport { IntlFormatters } from 'react-intl';\nimport * as yup from 'yup';\n\nimport { Stage } from '../../../../../../../../shared/contracts/review-workflows';\nimport { PartialWorkflow } from '../reducer';\n\nexport async function validateWorkflow({\n values,\n formatMessage,\n}: { values: PartialWorkflow } & Pick<IntlFormatters, 'formatMessage'>) {\n const schema = yup.object({\n contentTypes: yup.array().of(yup.string()),\n name: yup\n .string()\n .max(\n 255,\n formatMessage({\n id: 'Settings.review-workflows.validation.name.max-length',\n defaultMessage: 'Name can not be longer than 255 characters',\n })\n )\n .required(),\n\n stages: yup\n .array()\n .of(\n yup.object().shape({\n name: yup\n .string()\n .required(\n formatMessage({\n id: 'Settings.review-workflows.validation.stage.name',\n defaultMessage: 'Name is required',\n })\n )\n .max(\n 255,\n formatMessage({\n id: 'Settings.review-workflows.validation.stage.max-length',\n defaultMessage: 'Name can not be longer than 255 characters',\n })\n )\n .test(\n 'unique-name',\n formatMessage({\n id: 'Settings.review-workflows.validation.stage.duplicate',\n defaultMessage: 'Stage name must be unique',\n }),\n function (stageName) {\n const {\n options: { context },\n } = this;\n\n return (\n context?.stages.filter((stage: Stage) => stage.name === stageName).length === 1\n );\n }\n ),\n color: yup\n .string()\n .required(\n formatMessage({\n id: 'Settings.review-workflows.validation.stage.color',\n defaultMessage: 'Color is required',\n })\n )\n .matches(/^#(?:[0-9a-fA-F]{3}){1,2}$/i),\n\n permissions: yup\n .array(\n yup.object({\n role: yup\n .number()\n .strict()\n .typeError(\n formatMessage({\n id: 'Settings.review-workflows.validation.stage.permissions.role.number',\n defaultMessage: 'Role must be of type number',\n })\n )\n .required(),\n action: yup.string().required({\n id: 'Settings.review-workflows.validation.stage.permissions.action.required',\n defaultMessage: 'Action is a required argument',\n }),\n })\n )\n .strict(),\n })\n )\n .min(1),\n });\n\n try {\n await schema.validate(values, { abortEarly: false, context: values });\n\n return true;\n } catch (error) {\n const errors = {};\n\n if (error instanceof yup.ValidationError) {\n error.inner.forEach((error) => {\n if (error.path) set(errors, error.path, error.message);\n });\n }\n\n return errors;\n }\n}\n"],"names":["reducer","NestedOption","index","themeColorName","error"],"mappings":"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"}
|
package/dist/admin/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
-
const index = require("../_chunks/index-
|
|
3
|
+
const index = require("../_chunks/index-6Sc5WXVm.js");
|
|
4
4
|
require("react/jsx-runtime");
|
|
5
5
|
require("@strapi/helper-plugin");
|
|
6
6
|
require("react-dom/client");
|
package/dist/admin/index.mjs
CHANGED
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@strapi/admin",
|
|
3
|
-
"version": "4.25.
|
|
3
|
+
"version": "4.25.12",
|
|
4
4
|
"description": "Strapi Admin",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -73,13 +73,13 @@
|
|
|
73
73
|
"@radix-ui/react-toolbar": "1.0.4",
|
|
74
74
|
"@reduxjs/toolkit": "1.9.7",
|
|
75
75
|
"@strapi/design-system": "1.19.0",
|
|
76
|
-
"@strapi/helper-plugin": "4.25.
|
|
76
|
+
"@strapi/helper-plugin": "4.25.12",
|
|
77
77
|
"@strapi/icons": "1.19.0",
|
|
78
|
-
"@strapi/permissions": "4.25.
|
|
79
|
-
"@strapi/provider-audit-logs-local": "4.25.
|
|
80
|
-
"@strapi/types": "4.25.
|
|
81
|
-
"@strapi/typescript-utils": "4.25.
|
|
82
|
-
"@strapi/utils": "4.25.
|
|
78
|
+
"@strapi/permissions": "4.25.12",
|
|
79
|
+
"@strapi/provider-audit-logs-local": "4.25.12",
|
|
80
|
+
"@strapi/types": "4.25.12",
|
|
81
|
+
"@strapi/typescript-utils": "4.25.12",
|
|
82
|
+
"@strapi/utils": "4.25.12",
|
|
83
83
|
"@vitejs/plugin-react-swc": "3.5.0",
|
|
84
84
|
"axios": "1.7.4",
|
|
85
85
|
"bcryptjs": "2.4.3",
|
|
@@ -170,11 +170,11 @@
|
|
|
170
170
|
"yup": "0.32.9"
|
|
171
171
|
},
|
|
172
172
|
"devDependencies": {
|
|
173
|
-
"@strapi/admin-test-utils": "4.25.
|
|
174
|
-
"@strapi/data-transfer": "4.25.
|
|
173
|
+
"@strapi/admin-test-utils": "4.25.12",
|
|
174
|
+
"@strapi/data-transfer": "4.25.12",
|
|
175
175
|
"@strapi/pack-up": "4.23.0",
|
|
176
|
-
"@strapi/plugin-content-manager": "4.25.
|
|
177
|
-
"@strapi/strapi": "4.25.
|
|
176
|
+
"@strapi/plugin-content-manager": "4.25.12",
|
|
177
|
+
"@strapi/strapi": "4.25.12",
|
|
178
178
|
"@testing-library/dom": "9.2.0",
|
|
179
179
|
"@testing-library/react": "14.0.0",
|
|
180
180
|
"@testing-library/user-event": "14.4.3",
|
|
@@ -224,5 +224,5 @@
|
|
|
224
224
|
}
|
|
225
225
|
}
|
|
226
226
|
},
|
|
227
|
-
"gitHead": "
|
|
227
|
+
"gitHead": "1cdadce1eebb93015d97ed11348f3a3c2c3f355d"
|
|
228
228
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"MarketplacePage-avpto0An.mjs","sources":["../../admin/src/pages/Marketplace/components/NpmPackagesFilters.tsx","../../admin/src/pages/Marketplace/components/NpmPackageCard.tsx","../../admin/src/pages/Marketplace/components/NpmPackagesGrid.tsx","../../admin/src/pages/Marketplace/components/PageHeader.tsx","../../admin/src/pages/Marketplace/components/OfflineLayout.tsx","../../admin/src/pages/Marketplace/components/SortSelect.tsx","../../admin/src/pages/Marketplace/hooks/useMarketplaceData.ts","../../admin/src/pages/Marketplace/hooks/useNavigatorOnline.ts","../../admin/src/pages/Marketplace/MarketplacePage.tsx"],"sourcesContent":["import * as React from 'react';\n\nimport {\n Box,\n Button,\n Tag,\n MultiSelect,\n MultiSelectOption,\n MultiSelectProps,\n Popover,\n Flex,\n} from '@strapi/design-system';\nimport { Cross, Filter } from '@strapi/icons';\nimport { useIntl } from 'react-intl';\nimport styled from 'styled-components';\n\nimport type { Categories, Collections, FilterTypes } from '../hooks/useMarketplaceData';\nimport type { NpmPackageType, MarketplacePageQuery } from '../MarketplacePage';\n\ninterface NpmPackagesFiltersProps {\n handleSelectClear: (type: FilterTypes) => void;\n handleSelectChange: (update: Partial<MarketplacePageQuery>) => void;\n npmPackageType: NpmPackageType;\n possibleCategories: Partial<Record<Categories, number>>;\n possibleCollections: Partial<Record<Collections, number>>;\n query: MarketplacePageQuery;\n}\n\nconst NpmPackagesFilters = ({\n handleSelectClear,\n handleSelectChange,\n npmPackageType,\n possibleCategories,\n possibleCollections,\n query,\n}: NpmPackagesFiltersProps) => {\n const [isVisible, setIsVisible] = React.useState(false);\n const buttonRef = React.useRef<HTMLButtonElement>(null!);\n const { formatMessage } = useIntl();\n\n const handleToggle = () => setIsVisible((prev) => !prev);\n\n const handleTagRemove = (tagToRemove: string, filterType: FilterTypes) => {\n const update = {\n [filterType]: (query[filterType] ?? []).filter((previousTag) => previousTag !== tagToRemove),\n };\n\n handleSelectChange(update);\n };\n\n return (\n <>\n <Box paddingTop={1} paddingBottom={1}>\n <ButtonToggle\n variant=\"tertiary\"\n ref={buttonRef}\n startIcon={<Filter />}\n onClick={handleToggle}\n size=\"S\"\n >\n {formatMessage({ id: 'app.utils.filters', defaultMessage: 'Filters' })}\n </ButtonToggle>\n {isVisible && (\n <Popover source={buttonRef} onDismiss={handleToggle} padding={3} spacing={4}>\n <FiltersFlex direction=\"column\" alignItems=\"stretch\" gap={1}>\n <FilterSelect\n message={formatMessage({\n id: 'admin.pages.MarketPlacePage.filters.collections',\n defaultMessage: 'Collections',\n })}\n value={query?.collections || []}\n onChange={(newCollections) => {\n const update = { collections: newCollections };\n handleSelectChange(update);\n }}\n onClear={() => handleSelectClear('collections')}\n possibleFilters={possibleCollections}\n customizeContent={(values) =>\n formatMessage(\n {\n id: 'admin.pages.MarketPlacePage.filters.collectionsSelected',\n defaultMessage:\n '{count, plural, =0 {No collections} one {# collection} other {# collections}} selected',\n },\n { count: values?.length ?? 0 }\n )\n }\n />\n {npmPackageType === 'plugin' && (\n <FilterSelect\n message={formatMessage({\n id: 'admin.pages.MarketPlacePage.filters.categories',\n defaultMessage: 'Categories',\n })}\n value={query?.categories || []}\n onChange={(newCategories) => {\n const update = { categories: newCategories };\n handleSelectChange(update);\n }}\n onClear={() => handleSelectClear('categories')}\n possibleFilters={possibleCategories}\n customizeContent={(values) =>\n formatMessage(\n {\n id: 'admin.pages.MarketPlacePage.filters.categoriesSelected',\n defaultMessage:\n '{count, plural, =0 {No categories} one {# category} other {# categories}} selected',\n },\n { count: values?.length ?? 0 }\n )\n }\n />\n )}\n </FiltersFlex>\n </Popover>\n )}\n </Box>\n {query.collections?.map((collection) => (\n <Box key={collection} padding={1}>\n <Tag icon={<Cross />} onClick={() => handleTagRemove(collection, 'collections')}>\n {collection}\n </Tag>\n </Box>\n ))}\n {npmPackageType === 'plugin' &&\n query.categories?.map((category) => (\n <Box key={category} padding={1}>\n <Tag icon={<Cross />} onClick={() => handleTagRemove(category, 'categories')}>\n {category}\n </Tag>\n </Box>\n ))}\n </>\n );\n};\n\nconst ButtonToggle = styled(Button)`\n height: ${({ theme }) => theme.sizes.input.S};\n`;\n\nconst FiltersFlex = styled(Flex)`\n /* Hide the label, every input needs a label. */\n label {\n border: 0;\n clip: rect(0 0 0 0);\n height: 1px;\n margin: -1px;\n overflow: hidden;\n padding: 0;\n position: absolute;\n width: 1px;\n }\n`;\n\n/* -------------------------------------------------------------------------------------------------\n * FilterSelect\n * -----------------------------------------------------------------------------------------------*/\n\ninterface FilterSelectProps\n extends Pick<MultiSelectProps, 'customizeContent' | 'onClear' | 'onChange' | 'value'> {\n message: string;\n possibleFilters:\n | NpmPackagesFiltersProps['possibleCategories']\n | NpmPackagesFiltersProps['possibleCollections'];\n}\n\nconst FilterSelect = ({\n message,\n value,\n onChange,\n possibleFilters,\n onClear,\n customizeContent,\n}: FilterSelectProps) => {\n return (\n <MultiSelect\n data-testid={`${message}-button`}\n label={message}\n placeholder={message}\n size=\"M\"\n onChange={onChange}\n onClear={onClear}\n value={value}\n customizeContent={customizeContent}\n >\n {Object.entries(possibleFilters).map(([filterName, count]) => {\n return (\n <MultiSelectOption\n data-testid={`${filterName}-${count}`}\n key={filterName}\n value={filterName}\n >\n {`${filterName} (${count})`}\n </MultiSelectOption>\n );\n })}\n </MultiSelect>\n );\n};\n\nexport { NpmPackagesFilters };\nexport type { NpmPackagesFiltersProps };\n","import { Box, Flex, Icon, Tooltip, Typography, Divider, Button } from '@strapi/design-system';\nimport { LinkButton } from '@strapi/design-system/v2';\nimport {\n useTracking,\n pxToRem,\n AppInfoContextValue,\n useNotification,\n useClipboard,\n} from '@strapi/helper-plugin';\nimport { CheckCircle, ExternalLink, Download, Github, Star, Check, Duplicate } from '@strapi/icons';\nimport pluralize from 'pluralize';\nimport { useIntl } from 'react-intl';\nimport * as semver from 'semver';\nimport styled from 'styled-components';\n\nimport StrapiLogo from '../../../assets/images/logo-strapi-2022.svg';\n\nimport type { Plugin, Provider } from '../hooks/useMarketplaceData';\nimport type { NpmPackageType } from '../MarketplacePage';\n\n// Custom component to have an ellipsis after the 2nd line\nconst EllipsisText = styled(Typography)`\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 2;\n overflow: hidden;\n`;\n\ninterface NpmPackageCardProps extends Pick<AppInfoContextValue, 'useYarn'> {\n npmPackage: Plugin | Provider;\n isInstalled: boolean;\n isInDevelopmentMode: AppInfoContextValue['autoReload'];\n npmPackageType: NpmPackageType;\n strapiAppVersion: AppInfoContextValue['strapiVersion'];\n}\n\nconst NpmPackageCard = ({\n npmPackage,\n isInstalled,\n useYarn,\n isInDevelopmentMode,\n npmPackageType,\n strapiAppVersion,\n}: NpmPackageCardProps) => {\n const { attributes } = npmPackage;\n const { formatMessage } = useIntl();\n const { trackUsage } = useTracking();\n\n const commandToCopy = useYarn\n ? `yarn add ${attributes.npmPackageName}`\n : `npm install ${attributes.npmPackageName}`;\n\n const madeByStrapiMessage = formatMessage({\n id: 'admin.pages.MarketPlacePage.plugin.tooltip.madeByStrapi',\n defaultMessage: 'Made by Strapi',\n });\n\n const npmPackageHref = `https://market.strapi.io/${pluralize.plural(npmPackageType)}/${\n attributes.slug\n }`;\n\n return (\n <Flex\n direction=\"column\"\n justifyContent=\"space-between\"\n paddingTop={4}\n paddingRight={4}\n paddingBottom={4}\n paddingLeft={4}\n hasRadius\n background=\"neutral0\"\n shadow=\"tableShadow\"\n height=\"100%\"\n alignItems=\"normal\"\n data-testid=\"npm-package-card\"\n >\n <Box>\n <Flex direction=\"row\" justifyContent=\"space-between\" alignItems=\"flex-start\">\n <Box\n as=\"img\"\n src={attributes.logo.url}\n alt={`${attributes.name} logo`}\n hasRadius\n width={11}\n height={11}\n />\n <PackageStats\n githubStars={attributes.githubStars}\n npmDownloads={attributes.npmDownloads}\n npmPackageType={npmPackageType}\n />\n </Flex>\n <Box paddingTop={4}>\n <Typography as=\"h3\" variant=\"delta\">\n <Flex alignItems=\"center\">\n {attributes.name}\n {attributes.validated && !attributes.madeByStrapi && (\n <Tooltip\n description={formatMessage({\n id: 'admin.pages.MarketPlacePage.plugin.tooltip.verified',\n defaultMessage: 'Plugin verified by Strapi',\n })}\n >\n <Flex>\n <Icon as={CheckCircle} marginLeft={2} color=\"success600\" />\n </Flex>\n </Tooltip>\n )}\n {attributes.madeByStrapi && (\n <Tooltip description={madeByStrapiMessage}>\n <Flex>\n <Box\n as=\"img\"\n src={StrapiLogo}\n alt={madeByStrapiMessage}\n marginLeft={1}\n width={6}\n height=\"auto\"\n />\n </Flex>\n </Tooltip>\n )}\n </Flex>\n </Typography>\n </Box>\n <Box paddingTop={2}>\n <EllipsisText as=\"p\" variant=\"omega\" textColor=\"neutral600\">\n {attributes.description}\n </EllipsisText>\n </Box>\n </Box>\n\n <Flex gap={2} style={{ alignSelf: 'flex-end' }} paddingTop={6}>\n <LinkButton\n size=\"S\"\n href={npmPackageHref}\n isExternal\n endIcon={<ExternalLink />}\n aria-label={formatMessage(\n {\n id: 'admin.pages.MarketPlacePage.plugin.info.label',\n defaultMessage: 'Learn more about {pluginName}',\n },\n { pluginName: attributes.name }\n )}\n variant=\"tertiary\"\n onClick={() => trackUsage('didPluginLearnMore')}\n >\n {formatMessage({\n id: 'admin.pages.MarketPlacePage.plugin.info.text',\n defaultMessage: 'More',\n })}\n </LinkButton>\n <InstallPluginButton\n isInstalled={isInstalled}\n isInDevelopmentMode={isInDevelopmentMode}\n commandToCopy={commandToCopy}\n strapiAppVersion={strapiAppVersion}\n strapiPeerDepVersion={attributes.strapiVersion}\n pluginName={attributes.name}\n />\n </Flex>\n </Flex>\n );\n};\n\n/* -------------------------------------------------------------------------------------------------\n * InstallPluginButton\n * -----------------------------------------------------------------------------------------------*/\n\ninterface InstallPluginButtonProps\n extends Pick<NpmPackageCardProps, 'isInstalled' | 'isInDevelopmentMode' | 'strapiAppVersion'> {\n commandToCopy: string;\n pluginName: string;\n strapiPeerDepVersion?: string;\n}\n\nconst InstallPluginButton = ({\n isInstalled,\n isInDevelopmentMode,\n commandToCopy,\n strapiAppVersion,\n strapiPeerDepVersion,\n pluginName,\n}: InstallPluginButtonProps) => {\n const toggleNotification = useNotification();\n const { formatMessage } = useIntl();\n const { trackUsage } = useTracking();\n const { copy } = useClipboard();\n\n const handleCopy = async () => {\n const didCopy = await copy(commandToCopy);\n\n if (didCopy) {\n trackUsage('willInstallPlugin');\n toggleNotification({\n type: 'success',\n message: { id: 'admin.pages.MarketPlacePage.plugin.copy.success' },\n });\n }\n };\n\n // Already installed\n if (isInstalled) {\n return (\n <Box paddingLeft={4}>\n <Icon as={Check} marginRight={2} width={12} height={12} color=\"success600\" />\n <Typography variant=\"omega\" textColor=\"success600\" fontWeight=\"bold\">\n {formatMessage({\n id: 'admin.pages.MarketPlacePage.plugin.installed',\n defaultMessage: 'Installed',\n })}\n </Typography>\n </Box>\n );\n }\n\n // In development, show install button\n if (isInDevelopmentMode) {\n return (\n <CardButton\n strapiAppVersion={strapiAppVersion}\n strapiPeerDepVersion={strapiPeerDepVersion}\n handleCopy={handleCopy}\n pluginName={pluginName}\n />\n );\n }\n\n // Not in development and plugin not installed already. Show nothing\n return null;\n};\n\n/* -------------------------------------------------------------------------------------------------\n * CardButton\n * -----------------------------------------------------------------------------------------------*/\n\ninterface CardButtonProps\n extends Pick<NpmPackageCardProps, 'strapiAppVersion'>,\n Pick<InstallPluginButtonProps, 'strapiPeerDepVersion' | 'pluginName'> {\n handleCopy: () => void;\n}\n\nconst CardButton = ({\n strapiPeerDepVersion,\n strapiAppVersion,\n handleCopy,\n pluginName,\n}: CardButtonProps) => {\n const { formatMessage } = useIntl();\n const versionRange = semver.validRange(strapiPeerDepVersion);\n const isCompatible = semver.satisfies(strapiAppVersion ?? '', versionRange ?? '');\n\n const installMessage = formatMessage({\n id: 'admin.pages.MarketPlacePage.plugin.copy',\n defaultMessage: 'Copy install command',\n });\n\n // Only plugins receive a strapiAppVersion\n if (strapiAppVersion) {\n if (!versionRange || !isCompatible) {\n return (\n <Tooltip\n data-testid={`tooltip-${pluginName}`}\n description={\n !versionRange\n ? formatMessage(\n {\n id: 'admin.pages.MarketPlacePage.plugin.version.null',\n defaultMessage:\n 'Unable to verify compatibility with your Strapi version: \"{strapiAppVersion}\"',\n },\n { strapiAppVersion }\n )\n : formatMessage(\n {\n id: 'admin.pages.MarketPlacePage.plugin.version',\n defaultMessage:\n 'Update your Strapi version: \"{strapiAppVersion}\" to: \"{versionRange}\"',\n },\n {\n strapiAppVersion,\n versionRange,\n }\n )\n }\n >\n <Button\n size=\"S\"\n startIcon={<Duplicate />}\n variant=\"secondary\"\n onClick={handleCopy}\n disabled={!isCompatible}\n >\n {installMessage}\n </Button>\n </Tooltip>\n );\n }\n }\n\n return (\n <Button size=\"S\" startIcon={<Duplicate />} variant=\"secondary\" onClick={handleCopy}>\n {installMessage}\n </Button>\n );\n};\n\n/* -------------------------------------------------------------------------------------------------\n * PackageStats\n * -----------------------------------------------------------------------------------------------*/\n\ninterface PackageStatsProps {\n githubStars?: number;\n npmDownloads?: number;\n npmPackageType: NpmPackageType;\n}\n\nconst PackageStats = ({ githubStars = 0, npmDownloads = 0, npmPackageType }: PackageStatsProps) => {\n const { formatMessage } = useIntl();\n\n return (\n <Flex gap={1}>\n {!!githubStars && (\n <>\n <Icon as={Github} height={pxToRem(12)} width={pxToRem(12)} aria-hidden />\n <Icon as={Star} height={pxToRem(12)} width={pxToRem(12)} color=\"warning500\" aria-hidden />\n <p\n aria-label={formatMessage(\n {\n id: `admin.pages.MarketPlacePage.${npmPackageType}.githubStars`,\n defaultMessage: `This {package} was starred {starsCount} on GitHub`,\n },\n {\n starsCount: githubStars,\n package: npmPackageType,\n }\n )}\n >\n <Typography variant=\"pi\" textColor=\"neutral800\">\n {githubStars}\n </Typography>\n </p>\n <VerticalDivider unsetMargin={false} />\n </>\n )}\n <Icon as={Download} height={pxToRem(12)} width={pxToRem(12)} aria-hidden />\n <p\n aria-label={formatMessage(\n {\n id: `admin.pages.MarketPlacePage.${npmPackageType}.downloads`,\n defaultMessage: `This {package} has {downloadsCount} weekly downloads`,\n },\n {\n downloadsCount: npmDownloads,\n package: npmPackageType,\n }\n )}\n >\n <Typography variant=\"pi\" textColor=\"neutral800\">\n {npmDownloads}\n </Typography>\n </p>\n </Flex>\n );\n};\n\nconst VerticalDivider = styled(Divider)`\n width: ${pxToRem(12)};\n transform: rotate(90deg);\n`;\n\nexport { NpmPackageCard };\nexport type { NpmPackageCardProps };\n","import {\n Box,\n Flex,\n Grid,\n GridItem,\n GridLayout,\n Icon,\n Loader,\n Typography,\n} from '@strapi/design-system';\nimport { AnErrorOccurred, AppInfoContextValue } from '@strapi/helper-plugin';\nimport { EmptyDocuments } from '@strapi/icons';\nimport { useIntl } from 'react-intl';\nimport styled from 'styled-components';\n\nimport { NpmPackageCard, NpmPackageCardProps } from './NpmPackageCard';\n\nimport type { Plugin, Provider } from '../hooks/useMarketplaceData';\n\ninterface NpmPackagesGridProps extends Pick<NpmPackageCardProps, 'npmPackageType' | 'useYarn'> {\n debouncedSearch: string;\n installedPackageNames: string[];\n isInDevelopmentMode: AppInfoContextValue['autoReload'];\n npmPackages?: Array<Plugin | Provider>;\n status: 'idle' | 'loading' | 'error' | 'success';\n strapiAppVersion?: NpmPackageCardProps['strapiAppVersion'];\n}\n\nconst NpmPackagesGrid = ({\n status,\n npmPackages = [],\n installedPackageNames = [],\n useYarn,\n isInDevelopmentMode,\n npmPackageType,\n strapiAppVersion,\n debouncedSearch,\n}: NpmPackagesGridProps) => {\n const { formatMessage } = useIntl();\n\n if (status === 'error') {\n return (\n <Flex paddingTop={8}>\n <AnErrorOccurred />\n </Flex>\n );\n }\n\n if (status === 'loading') {\n return (\n <Flex justifyContent=\"center\" paddingTop={8}>\n <Loader>Loading content...</Loader>\n </Flex>\n );\n }\n\n const emptySearchMessage = formatMessage(\n {\n id: 'admin.pages.MarketPlacePage.search.empty',\n defaultMessage: 'No result for \"{target}\"',\n },\n { target: debouncedSearch }\n );\n\n if (npmPackages.length === 0) {\n return (\n <Box position=\"relative\">\n <GridLayout>\n {Array(12)\n .fill(null)\n .map((_, idx) => (\n <EmptyPluginCard key={idx} height=\"234px\" hasRadius />\n ))}\n </GridLayout>\n <Box position=\"absolute\" top={11} width=\"100%\">\n <Flex alignItems=\"center\" justifyContent=\"center\" direction=\"column\">\n <Icon as={EmptyDocuments} color={undefined} width=\"160px\" height=\"88px\" />\n <Box paddingTop={6}>\n <Typography variant=\"delta\" as=\"p\" textColor=\"neutral600\">\n {emptySearchMessage}\n </Typography>\n </Box>\n </Flex>\n </Box>\n </Box>\n );\n }\n\n return (\n <Grid gap={4}>\n {npmPackages.map((npmPackage) => (\n <GridItem col={4} s={6} xs={12} style={{ height: '100%' }} key={npmPackage.id}>\n <NpmPackageCard\n npmPackage={npmPackage}\n isInstalled={installedPackageNames.includes(npmPackage.attributes.npmPackageName)}\n useYarn={useYarn}\n isInDevelopmentMode={isInDevelopmentMode}\n npmPackageType={npmPackageType}\n strapiAppVersion={strapiAppVersion}\n />\n </GridItem>\n ))}\n </Grid>\n );\n};\n\nconst EmptyPluginCard = styled(Box)`\n background: ${({ theme }) =>\n `linear-gradient(180deg, rgba(234, 234, 239, 0) 0%, ${theme.colors.neutral150} 100%)`};\n opacity: 0.33;\n`;\n\nexport { NpmPackagesGrid };\n","import { HeaderLayout } from '@strapi/design-system';\nimport { LinkButton } from '@strapi/design-system/v2';\nimport { useTracking } from '@strapi/helper-plugin';\nimport { Upload } from '@strapi/icons';\nimport { useIntl } from 'react-intl';\n\nimport type { NpmPackageType } from '../MarketplacePage';\n\ninterface PageHeaderProps {\n isOnline?: boolean;\n npmPackageType?: NpmPackageType;\n}\n\nconst PageHeader = ({ isOnline, npmPackageType = 'plugin' }: PageHeaderProps) => {\n const { formatMessage } = useIntl();\n const { trackUsage } = useTracking();\n\n const tracking = npmPackageType === 'provider' ? 'didSubmitProvider' : 'didSubmitPlugin';\n\n return (\n <HeaderLayout\n title={formatMessage({\n id: 'global.marketplace',\n defaultMessage: 'Marketplace',\n })}\n subtitle={formatMessage({\n id: 'admin.pages.MarketPlacePage.subtitle',\n defaultMessage: 'Get more out of Strapi',\n })}\n primaryAction={\n isOnline && (\n <LinkButton\n startIcon={<Upload />}\n variant=\"tertiary\"\n href={`https://market.strapi.io/submit-${npmPackageType}`}\n onClick={() => trackUsage(tracking)}\n isExternal\n >\n {formatMessage({\n id: `admin.pages.MarketPlacePage.submit.${npmPackageType}.link`,\n defaultMessage: `Submit ${npmPackageType}`,\n })}\n </LinkButton>\n )\n }\n />\n );\n};\n\nexport { PageHeader };\nexport type { PageHeaderProps };\n","import { Box, Flex, Layout, Main, Typography } from '@strapi/design-system';\nimport { pxToRem } from '@strapi/helper-plugin';\nimport { useIntl } from 'react-intl';\n\nimport { PageHeader } from './PageHeader';\n\nconst OfflineLayout = () => {\n const { formatMessage } = useIntl();\n\n return (\n <Layout>\n <Main>\n <PageHeader />\n <Flex\n width=\"100%\"\n direction=\"column\"\n alignItems=\"center\"\n justifyContent=\"center\"\n paddingTop={pxToRem(120)}\n >\n <Box paddingBottom={2}>\n <Typography textColor=\"neutral700\" variant=\"alpha\">\n {formatMessage({\n id: 'admin.pages.MarketPlacePage.offline.title',\n defaultMessage: 'You are offline',\n })}\n </Typography>\n </Box>\n <Box paddingBottom={6}>\n <Typography textColor=\"neutral700\" variant=\"epsilon\">\n {formatMessage({\n id: 'admin.pages.MarketPlacePage.offline.subtitle',\n defaultMessage: 'You need to be connected to the Internet to access Strapi Market.',\n })}\n </Typography>\n </Box>\n <svg\n width=\"88\"\n height=\"88\"\n viewBox=\"0 0 88 88\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <rect x=\".5\" y=\".5\" width=\"87\" height=\"87\" rx=\"43.5\" fill=\"#F0F0FF\" />\n <path\n d=\"M34 39.3h-4c-2.6 0-4.7 1-6.6 2.8a9 9 0 0 0-2.7 6.6 9 9 0 0 0 2.7 6.6A9 9 0 0 0 30 58h22.8L34 39.3Zm-11-11 3-3 39 39-3 3-4.7-4.6H30a13.8 13.8 0 0 1-14-14c0-3.8 1.3-7 4-9.7 2.6-2.7 5.7-4.2 9.5-4.3L23 28.2Zm38.2 11.1c3 .2 5.5 1.5 7.6 3.7A11 11 0 0 1 72 51c0 4-1.6 7.2-5 9.5l-3.3-3.4a6.5 6.5 0 0 0 3.6-6.1c0-1.9-.7-3.5-2-5-1.5-1.3-3.1-2-5-2h-3.5v-1.2c0-3.6-1.2-6.6-3.7-9a13 13 0 0 0-15-2.3L34.6 28a17 17 0 0 1 20.3 1.5c3.5 2.7 5.5 6 6.3 10Z\"\n fill=\"#4945FF\"\n />\n <rect x=\".5\" y=\".5\" width=\"87\" height=\"87\" rx=\"43.5\" stroke=\"#D9D8FF\" />\n </svg>\n </Flex>\n </Main>\n </Layout>\n );\n};\n\nexport { OfflineLayout };\n","import { Box, SingleSelectOption, SingleSelect } from '@strapi/design-system';\nimport { useIntl } from 'react-intl';\nimport styled from 'styled-components';\n\nconst SORT_TYPES = {\n 'name:asc': {\n selected: {\n id: 'admin.pages.MarketPlacePage.sort.alphabetical.selected',\n defaultMessage: 'Sort by alphabetical order',\n },\n option: {\n id: 'admin.pages.MarketPlacePage.sort.alphabetical',\n defaultMessage: 'Alphabetical order',\n },\n },\n 'submissionDate:desc': {\n selected: {\n id: 'admin.pages.MarketPlacePage.sort.newest.selected',\n defaultMessage: 'Sort by newest',\n },\n option: {\n id: 'admin.pages.MarketPlacePage.sort.newest',\n defaultMessage: 'Newest',\n },\n },\n 'githubStars:desc': {\n selected: {\n id: 'admin.pages.MarketPlacePage.sort.githubStars.selected',\n defaultMessage: 'Sort by GitHub stars',\n },\n option: {\n id: 'admin.pages.MarketPlacePage.sort.githubStars',\n defaultMessage: 'Number of GitHub stars',\n },\n },\n 'npmDownloads:desc': {\n selected: {\n id: 'admin.pages.MarketPlacePage.sort.npmDownloads.selected',\n defaultMessage: 'Sort by npm downloads',\n },\n option: {\n id: 'admin.pages.MarketPlacePage.sort.npmDownloads',\n defaultMessage: 'Number of downloads',\n },\n },\n} as const;\n\ninterface SortSelectProps {\n sortQuery: keyof typeof SORT_TYPES;\n handleSelectChange: (payload: { sort: string }) => void;\n}\n\nconst SortSelect = ({ sortQuery, handleSelectChange }: SortSelectProps) => {\n const { formatMessage } = useIntl();\n\n return (\n <SelectWrapper>\n <SingleSelect\n size=\"S\"\n id=\"sort-by-select\"\n value={sortQuery}\n customizeContent={() => formatMessage(SORT_TYPES[sortQuery].selected)}\n onChange={(sortName) => {\n // @ts-expect-error – in V2 design-system we'll only ever return strings.\n handleSelectChange({ sort: sortName });\n }}\n label={formatMessage({\n id: 'admin.pages.MarketPlacePage.sort.label',\n defaultMessage: 'Sort by',\n })}\n >\n {Object.entries(SORT_TYPES).map(([sortName, messages]) => {\n return (\n <SingleSelectOption key={sortName} value={sortName}>\n {formatMessage(messages.option)}\n </SingleSelectOption>\n );\n })}\n </SingleSelect>\n </SelectWrapper>\n );\n};\n\nconst SelectWrapper = styled(Box)`\n font-weight: ${({ theme }) => theme.fontWeights.semiBold};\n\n span {\n font-size: ${({ theme }) => theme.fontSizes[1]};\n }\n\n /* Hide the label, every input needs a label. */\n label {\n border: 0;\n clip: rect(0 0 0 0);\n height: 1px;\n margin: -1px;\n overflow: hidden;\n padding: 0;\n position: absolute;\n width: 1px;\n }\n`;\n\nexport { SortSelect };\nexport type { SortSelectProps };\n","import { useNotifyAT } from '@strapi/design-system';\nimport { useNotification } from '@strapi/helper-plugin';\nimport * as qs from 'qs';\nimport { useIntl } from 'react-intl';\nimport { useQuery } from 'react-query';\n\nimport type { MarketplacePageQuery, NpmPackageType, TabQuery } from '../MarketplacePage';\n\nconst MARKETPLACE_API_URL = 'https://market-api.strapi.io';\n\ninterface UseMarketplaceDataParams {\n npmPackageType: NpmPackageType;\n debouncedSearch: string;\n query?: MarketplacePageQuery;\n tabQuery: TabQuery;\n}\n\ntype Collections =\n | 'Verified'\n | 'Made by the community'\n | 'Made by Strapi'\n | 'Made by official partners';\n\ntype Categories = 'Custom fields' | 'Deployment' | 'Monitoring';\n\ntype FilterTypes = 'categories' | 'collections';\n\ninterface Plugin {\n id: string;\n attributes: {\n name: string;\n description: string;\n slug: string;\n npmPackageName: string;\n npmPackageUrl: string;\n npmDownloads: number;\n repositoryUrl: string;\n githubStars: number;\n logo: {\n url: string;\n };\n developerName: string;\n validated: boolean;\n madeByStrapi: boolean;\n strapiCompatibility: string;\n submissionDate: string;\n collections: Collections[];\n categories: Categories[];\n strapiVersion: string;\n screenshots: Array<{\n url: string;\n }>;\n };\n}\n\ninterface Provider {\n id: string;\n attributes: {\n name: string;\n description: string;\n slug: string;\n npmPackageName: string;\n npmPackageUrl: string;\n npmDownloads: number;\n repositoryUrl: string;\n githubStars: number;\n pluginName: string;\n logo: {\n url: string;\n };\n developerName: string;\n validated: boolean;\n madeByStrapi: boolean;\n strapiCompatibility: string;\n strapiVersion?: never;\n submissionDate: string;\n collections: Collections[];\n };\n}\n\ninterface MarketplaceMeta {\n collections: Record<Collections, number>;\n pagination: {\n page: number;\n pageSize: number;\n pageCount: number;\n total: number;\n };\n}\n\ninterface MarketplaceResponse<TData extends Plugin | Provider> {\n data: TData[];\n meta: TData extends Provider\n ? MarketplaceMeta\n : MarketplaceMeta & { categories: Record<Categories, number> };\n}\n\nfunction useMarketplaceData({\n npmPackageType,\n debouncedSearch,\n query,\n tabQuery,\n}: UseMarketplaceDataParams) {\n const { notifyStatus } = useNotifyAT();\n const { formatMessage } = useIntl();\n const toggleNotification = useNotification();\n const marketplaceTitle = formatMessage({\n id: 'global.marketplace',\n defaultMessage: 'Marketplace',\n });\n\n const notifyMarketplaceLoad = () => {\n notifyStatus(\n formatMessage(\n {\n id: 'app.utils.notify.data-loaded',\n defaultMessage: 'The {target} has loaded',\n },\n { target: marketplaceTitle }\n )\n );\n };\n\n const paginationParams = {\n page: query?.page || 1,\n pageSize: query?.pageSize || 24,\n };\n\n const pluginParams = {\n ...tabQuery.plugin,\n pagination: paginationParams,\n search: debouncedSearch,\n };\n\n const { data: pluginsResponse, status: pluginsStatus } = useQuery(\n ['marketplace', 'plugins', pluginParams],\n async () => {\n try {\n const queryString = qs.stringify(pluginParams);\n const res = await fetch(`${MARKETPLACE_API_URL}/plugins?${queryString}`);\n\n if (!res.ok) {\n throw new Error('Failed to fetch marketplace plugins.');\n }\n\n const data = (await res.json()) as MarketplaceResponse<Plugin>;\n\n return data;\n } catch (error) {\n // silence\n }\n\n return null;\n },\n {\n onSuccess() {\n notifyMarketplaceLoad();\n },\n onError() {\n toggleNotification({\n type: 'warning',\n message: { id: 'notification.error', defaultMessage: 'An error occured' },\n });\n },\n }\n );\n\n const providerParams = {\n ...tabQuery.provider,\n pagination: paginationParams,\n search: debouncedSearch,\n };\n\n const { data: providersResponse, status: providersStatus } = useQuery(\n ['marketplace', 'providers', providerParams],\n async () => {\n const queryString = qs.stringify(providerParams);\n const res = await fetch(`${MARKETPLACE_API_URL}/providers?${queryString}`);\n\n if (!res.ok) {\n throw new Error('Failed to fetch marketplace providers.');\n }\n\n const data = (await res.json()) as MarketplaceResponse<Provider>;\n\n return data;\n },\n {\n onSuccess() {\n notifyMarketplaceLoad();\n },\n onError() {\n toggleNotification({\n type: 'warning',\n message: { id: 'notification.error', defaultMessage: 'An error occured' },\n });\n },\n }\n );\n\n const npmPackageTypeResponse = npmPackageType === 'plugin' ? pluginsResponse : providersResponse;\n\n const possibleCollections = npmPackageTypeResponse?.meta.collections ?? {};\n const possibleCategories = pluginsResponse?.meta.categories ?? {};\n\n const { pagination } = npmPackageTypeResponse?.meta ?? {};\n\n return {\n pluginsResponse,\n providersResponse,\n pluginsStatus,\n providersStatus,\n possibleCollections,\n possibleCategories,\n pagination,\n };\n}\n\nexport { useMarketplaceData };\nexport type {\n MarketplaceResponse,\n Plugin,\n Provider,\n MarketplaceMeta,\n Collections,\n Categories,\n FilterTypes,\n UseMarketplaceDataParams,\n};\n","import * as React from 'react';\n\n/**\n * For more details about this hook see:\n * https://www.30secondsofcode.org/react/s/use-navigator-on-line\n */\nexport const useNavigatorOnline = (): boolean => {\n const onlineStatus =\n typeof navigator !== 'undefined' && typeof navigator.onLine === 'boolean'\n ? navigator.onLine\n : true;\n\n const [isOnline, setIsOnline] = React.useState(onlineStatus);\n\n const setOnline = () => setIsOnline(true);\n const setOffline = () => setIsOnline(false);\n\n React.useEffect(() => {\n window.addEventListener('online', setOnline);\n window.addEventListener('offline', setOffline);\n\n return () => {\n window.removeEventListener('online', setOnline);\n window.removeEventListener('offline', setOffline);\n };\n }, []);\n\n return isOnline;\n};\n","import * as React from 'react';\n\nimport {\n Box,\n ContentLayout,\n Flex,\n Icon,\n Layout,\n Main,\n Searchbar,\n Tab,\n TabGroup,\n TabPanel,\n TabPanels,\n Tabs,\n} from '@strapi/design-system';\nimport {\n CheckPagePermissions,\n ContentBox,\n PageSizeURLQuery,\n PaginationURLQuery,\n useAppInfo,\n useFocusWhenNavigate,\n useNotification,\n useQueryParams,\n useTracking,\n} from '@strapi/helper-plugin';\nimport { ExternalLink, GlassesSquare } from '@strapi/icons';\nimport { Helmet } from 'react-helmet';\nimport { useIntl } from 'react-intl';\nimport { useSelector } from 'react-redux';\n\nimport { useDebounce } from '../../hooks/useDebounce';\nimport { selectAdminPermissions } from '../../selectors';\n\nimport { NpmPackagesFilters } from './components/NpmPackagesFilters';\nimport { NpmPackagesGrid } from './components/NpmPackagesGrid';\nimport { OfflineLayout } from './components/OfflineLayout';\nimport { PageHeader } from './components/PageHeader';\nimport { SortSelect, SortSelectProps } from './components/SortSelect';\nimport { FilterTypes, useMarketplaceData } from './hooks/useMarketplaceData';\nimport { useNavigatorOnline } from './hooks/useNavigatorOnline';\n\ntype NpmPackageType = 'plugin' | 'provider';\n\ninterface MarketplacePageQuery {\n collections?: string[];\n categories?: string[];\n npmPackageType?: NpmPackageType;\n page?: number;\n pageSize?: number;\n search?: string;\n sort?: SortSelectProps['sortQuery'];\n}\n\ninterface TabQuery {\n plugin: MarketplacePageQuery;\n provider: MarketplacePageQuery;\n}\n\nconst MarketplacePage = () => {\n const tabRef = React.useRef<any>(null);\n const { formatMessage } = useIntl();\n const { trackUsage } = useTracking();\n const toggleNotification = useNotification();\n const [{ query }, setQuery] = useQueryParams<MarketplacePageQuery>();\n const debouncedSearch = useDebounce(query?.search, 500) || '';\n\n const { autoReload: isInDevelopmentMode, dependencies, useYarn, strapiVersion } = useAppInfo();\n const isOnline = useNavigatorOnline();\n\n const npmPackageType = query?.npmPackageType || 'plugin';\n\n const [tabQuery, setTabQuery] = React.useState<TabQuery>({\n plugin: npmPackageType === 'plugin' ? { ...query } : {},\n provider: npmPackageType === 'provider' ? { ...query } : {},\n });\n\n useFocusWhenNavigate();\n\n React.useEffect(() => {\n trackUsage('didGoToMarketplace');\n }, [trackUsage]);\n\n React.useEffect(() => {\n if (!isInDevelopmentMode) {\n toggleNotification({\n type: 'info',\n message: {\n id: 'admin.pages.MarketPlacePage.production',\n defaultMessage: 'Manage plugins from the development environment',\n },\n });\n }\n }, [toggleNotification, isInDevelopmentMode]);\n\n const {\n pluginsResponse,\n providersResponse,\n pluginsStatus,\n providersStatus,\n possibleCollections,\n possibleCategories,\n pagination,\n } = useMarketplaceData({ npmPackageType, debouncedSearch, query, tabQuery });\n\n const indexOfNpmPackageType = ['plugin', 'provider'].indexOf(npmPackageType);\n\n // TODO: Replace this solution with v2 of the Design System\n // Check if the active tab index changes and call the handler of the ref to update the tab group component\n React.useEffect(() => {\n if (tabRef.current) {\n tabRef.current._handlers.setSelectedTabIndex(indexOfNpmPackageType);\n }\n }, [indexOfNpmPackageType]);\n\n if (!isOnline) {\n return <OfflineLayout />;\n }\n\n const handleTabChange = (selected: number) => {\n const selectedTab = selected === 0 ? 'plugin' : 'provider';\n const hasTabQuery = tabQuery[selectedTab] && Object.keys(tabQuery[selectedTab]).length;\n\n if (hasTabQuery) {\n setQuery({\n // Keep filters and search\n ...tabQuery[selectedTab],\n search: query?.search || '',\n // Set tab and reset page\n npmPackageType: selectedTab,\n page: 1,\n });\n } else {\n setQuery({\n // Set tab\n npmPackageType: selectedTab,\n // Clear filters\n collections: [],\n categories: [],\n sort: 'name:asc',\n page: 1,\n // Keep search\n search: query?.search || '',\n });\n }\n };\n\n const handleSelectChange = (update: Partial<MarketplacePageQuery>) => {\n setQuery({ ...update, page: 1 });\n setTabQuery((prev) => ({\n ...prev,\n [npmPackageType]: { ...prev[npmPackageType], ...update },\n }));\n };\n\n const handleSelectClear = (filterType: FilterTypes) => {\n setQuery({ [filterType]: [], page: undefined }, 'remove');\n setTabQuery((prev) => ({ ...prev, [npmPackageType]: {} }));\n };\n\n const handleSortSelectChange: SortSelectProps['handleSelectChange'] = ({ sort }) =>\n // @ts-expect-error - this is a narrowing issue.\n handleSelectChange({ sort });\n\n // Check if plugins and providers are installed already\n const installedPackageNames = Object.keys(dependencies ?? {});\n\n return (\n <Layout>\n <Main>\n <Helmet\n title={formatMessage({\n id: 'admin.pages.MarketPlacePage.helmet',\n defaultMessage: 'Marketplace - Plugins',\n })}\n />\n <PageHeader isOnline={isOnline} npmPackageType={npmPackageType} />\n <ContentLayout>\n <TabGroup\n label={formatMessage({\n id: 'admin.pages.MarketPlacePage.tab-group.label',\n defaultMessage: 'Plugins and Providers for Strapi',\n })}\n id=\"tabs\"\n variant=\"simple\"\n initialSelectedTabIndex={indexOfNpmPackageType}\n onTabChange={handleTabChange}\n ref={tabRef}\n >\n <Flex justifyContent=\"space-between\" paddingBottom={4}>\n <Tabs>\n <Tab>\n {formatMessage({\n id: 'admin.pages.MarketPlacePage.plugins',\n defaultMessage: 'Plugins',\n })}{' '}\n {pluginsResponse ? `(${pluginsResponse.meta.pagination.total})` : '...'}\n </Tab>\n <Tab>\n {formatMessage({\n id: 'admin.pages.MarketPlacePage.providers',\n defaultMessage: 'Providers',\n })}{' '}\n {providersResponse ? `(${providersResponse.meta.pagination.total})` : '...'}\n </Tab>\n </Tabs>\n <Box width=\"25%\">\n <Searchbar\n name=\"searchbar\"\n onClear={() => setQuery({ search: '', page: 1 })}\n value={query?.search}\n onChange={(e) => setQuery({ search: e.target.value, page: 1 })}\n clearLabel={formatMessage({\n id: 'admin.pages.MarketPlacePage.search.clear',\n defaultMessage: 'Clear the search',\n })}\n placeholder={formatMessage({\n id: 'admin.pages.MarketPlacePage.search.placeholder',\n defaultMessage: 'Search',\n })}\n >\n {formatMessage({\n id: 'admin.pages.MarketPlacePage.search.placeholder',\n defaultMessage: 'Search',\n })}\n </Searchbar>\n </Box>\n </Flex>\n <Flex paddingBottom={4} gap={2}>\n <SortSelect\n sortQuery={query?.sort || 'name:asc'}\n handleSelectChange={handleSortSelectChange}\n />\n <NpmPackagesFilters\n npmPackageType={npmPackageType}\n possibleCollections={possibleCollections}\n possibleCategories={possibleCategories}\n query={query || {}}\n handleSelectChange={handleSelectChange}\n handleSelectClear={handleSelectClear}\n />\n </Flex>\n\n <TabPanels>\n {/* Plugins panel */}\n <TabPanel>\n <NpmPackagesGrid\n npmPackages={pluginsResponse?.data}\n status={pluginsStatus}\n installedPackageNames={installedPackageNames}\n useYarn={useYarn}\n isInDevelopmentMode={isInDevelopmentMode}\n npmPackageType=\"plugin\"\n strapiAppVersion={strapiVersion}\n debouncedSearch={debouncedSearch}\n />\n </TabPanel>\n {/* Providers panel */}\n <TabPanel>\n <NpmPackagesGrid\n npmPackages={providersResponse?.data}\n status={providersStatus}\n installedPackageNames={installedPackageNames}\n useYarn={useYarn}\n isInDevelopmentMode={isInDevelopmentMode}\n npmPackageType=\"provider\"\n debouncedSearch={debouncedSearch}\n />\n </TabPanel>\n </TabPanels>\n </TabGroup>\n {pagination ? (\n <Box paddingTop={4}>\n <Flex alignItems=\"flex-end\" justifyContent=\"space-between\">\n <PageSizeURLQuery options={['12', '24', '50', '100']} defaultValue=\"24\" />\n <PaginationURLQuery pagination={pagination} />\n </Flex>\n </Box>\n ) : null}\n <Box paddingTop={8}>\n <a\n href=\"https://strapi.canny.io/plugin-requests\"\n target=\"_blank\"\n rel=\"noopener noreferrer nofollow\"\n style={{ textDecoration: 'none' }}\n onClick={() => trackUsage('didMissMarketplacePlugin')}\n >\n <ContentBox\n title={formatMessage({\n id: 'admin.pages.MarketPlacePage.missingPlugin.title',\n defaultMessage: 'Documentation',\n })}\n subtitle={formatMessage({\n id: 'admin.pages.MarketPlacePage.missingPlugin.description',\n defaultMessage:\n \"Tell us what plugin you are looking for and we'll let our community plugin developers know in case they are in search for inspiration!\",\n })}\n icon={<GlassesSquare />}\n iconBackground=\"alternative100\"\n endAction={\n <Icon as={ExternalLink} color=\"neutral600\" width={3} height={3} marginLeft={2} />\n }\n />\n </a>\n </Box>\n </ContentLayout>\n </Main>\n </Layout>\n );\n};\n\nconst ProtectedMarketplacePage = () => {\n const permissions = useSelector(selectAdminPermissions);\n\n return (\n // @ts-expect-error – the selector is not typed.\n <CheckPagePermissions permissions={permissions.marketplace.main}>\n <MarketplacePage />\n </CheckPagePermissions>\n );\n};\n\nexport { MarketplacePage, ProtectedMarketplacePage };\nexport type { NpmPackageType, MarketplacePageQuery, TabQuery };\n"],"names":[],"mappings":"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"}
|