@strapi/content-manager 0.0.0-next.39c0188c3aa01bec7b64b948211571d5159e811d → 0.0.0-next.3a1d87a9c3b1d4d89f741c6ecd7f501230fd8d76
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/CardDragPreview-C0QyJgRA.js +69 -0
- package/dist/_chunks/CardDragPreview-C0QyJgRA.js.map +1 -0
- package/dist/_chunks/CardDragPreview-DOxamsuj.mjs +70 -0
- package/dist/_chunks/CardDragPreview-DOxamsuj.mjs.map +1 -0
- package/dist/_chunks/ComponentConfigurationPage-DMxUlNOo.js +254 -0
- package/dist/_chunks/ComponentConfigurationPage-DMxUlNOo.js.map +1 -0
- package/dist/_chunks/ComponentConfigurationPage-baEkO-OV.mjs +236 -0
- package/dist/_chunks/ComponentConfigurationPage-baEkO-OV.mjs.map +1 -0
- package/dist/_chunks/ComponentIcon-CRbtQEUV.js +175 -0
- package/dist/_chunks/ComponentIcon-CRbtQEUV.js.map +1 -0
- package/dist/_chunks/ComponentIcon-u4bIXTFY.mjs +157 -0
- package/dist/_chunks/ComponentIcon-u4bIXTFY.mjs.map +1 -0
- package/dist/_chunks/EditConfigurationPage-CXxV7mKn.js +150 -0
- package/dist/_chunks/EditConfigurationPage-CXxV7mKn.js.map +1 -0
- package/dist/_chunks/EditConfigurationPage-YR8-4VCS.mjs +132 -0
- package/dist/_chunks/EditConfigurationPage-YR8-4VCS.mjs.map +1 -0
- package/dist/_chunks/EditViewPage-BfR6jAR6.js +209 -0
- package/dist/_chunks/EditViewPage-BfR6jAR6.js.map +1 -0
- package/dist/_chunks/EditViewPage-DFF7c27p.mjs +191 -0
- package/dist/_chunks/EditViewPage-DFF7c27p.mjs.map +1 -0
- package/dist/_chunks/FieldTypeIcon-CMlNO8PE.mjs +50 -0
- package/dist/_chunks/FieldTypeIcon-CMlNO8PE.mjs.map +1 -0
- package/dist/_chunks/FieldTypeIcon-Dnwq_IRF.js +49 -0
- package/dist/_chunks/FieldTypeIcon-Dnwq_IRF.js.map +1 -0
- package/dist/_chunks/Form-CjcMRP5A.js +778 -0
- package/dist/_chunks/Form-CjcMRP5A.js.map +1 -0
- package/dist/_chunks/Form-MSOSfGGN.mjs +758 -0
- package/dist/_chunks/Form-MSOSfGGN.mjs.map +1 -0
- package/dist/_chunks/History-BgZ7gVuF.js +1019 -0
- package/dist/_chunks/History-BgZ7gVuF.js.map +1 -0
- package/dist/_chunks/History-WOQNVho-.mjs +999 -0
- package/dist/_chunks/History-WOQNVho-.mjs.map +1 -0
- package/dist/_chunks/Input-BkKwZ6Qt.mjs +5585 -0
- package/dist/_chunks/Input-BkKwZ6Qt.mjs.map +1 -0
- package/dist/_chunks/Input-BwOibhc3.js +5617 -0
- package/dist/_chunks/Input-BwOibhc3.js.map +1 -0
- package/dist/_chunks/ListConfigurationPage-BeXfr6uW.mjs +633 -0
- package/dist/_chunks/ListConfigurationPage-BeXfr6uW.mjs.map +1 -0
- package/dist/_chunks/ListConfigurationPage-DnJ3nbwL.js +652 -0
- package/dist/_chunks/ListConfigurationPage-DnJ3nbwL.js.map +1 -0
- package/dist/_chunks/ListViewPage-CJFDudKl.js +877 -0
- package/dist/_chunks/ListViewPage-CJFDudKl.js.map +1 -0
- package/dist/_chunks/ListViewPage-VK2v44Q1.mjs +854 -0
- package/dist/_chunks/ListViewPage-VK2v44Q1.mjs.map +1 -0
- package/dist/_chunks/NoContentTypePage-T8ttty6K.mjs +51 -0
- package/dist/_chunks/NoContentTypePage-T8ttty6K.mjs.map +1 -0
- package/dist/_chunks/NoContentTypePage-en2PwWgI.js +51 -0
- package/dist/_chunks/NoContentTypePage-en2PwWgI.js.map +1 -0
- package/dist/_chunks/NoPermissionsPage-CcjILry3.js +23 -0
- package/dist/_chunks/NoPermissionsPage-CcjILry3.js.map +1 -0
- package/dist/_chunks/NoPermissionsPage-CokBHhhy.mjs +23 -0
- package/dist/_chunks/NoPermissionsPage-CokBHhhy.mjs.map +1 -0
- package/dist/_chunks/Preview-BF81YhRj.mjs +287 -0
- package/dist/_chunks/Preview-BF81YhRj.mjs.map +1 -0
- package/dist/_chunks/Preview-DgzAuzWQ.js +305 -0
- package/dist/_chunks/Preview-DgzAuzWQ.js.map +1 -0
- package/dist/_chunks/Relations-1O-JcM4t.js +747 -0
- package/dist/_chunks/Relations-1O-JcM4t.js.map +1 -0
- package/dist/_chunks/Relations-BncdhGCd.mjs +728 -0
- package/dist/_chunks/Relations-BncdhGCd.mjs.map +1 -0
- package/dist/_chunks/ar-BUUWXIYu.js +226 -0
- package/dist/{admin/chunks/ar-DckYq_WK.js.map → _chunks/ar-BUUWXIYu.js.map} +1 -1
- package/dist/_chunks/ar-CCEVvqGG.mjs +226 -0
- package/dist/_chunks/ar-CCEVvqGG.mjs.map +1 -0
- package/dist/_chunks/ca-5U32ON2v.mjs +201 -0
- package/dist/_chunks/ca-5U32ON2v.mjs.map +1 -0
- package/dist/_chunks/ca-Cmk45QO6.js +201 -0
- package/dist/{admin/chunks/de-CbImAUA5.js.map → _chunks/ca-Cmk45QO6.js.map} +1 -1
- package/dist/_chunks/cs-CM2aBUar.mjs +125 -0
- package/dist/_chunks/cs-CM2aBUar.mjs.map +1 -0
- package/dist/_chunks/cs-CkJy6B2v.js +125 -0
- package/dist/{admin/chunks/cs-C7OSYFQ7.js.map → _chunks/cs-CkJy6B2v.js.map} +1 -1
- package/dist/_chunks/de-C72KDNOl.mjs +199 -0
- package/dist/_chunks/de-C72KDNOl.mjs.map +1 -0
- package/dist/_chunks/de-CCEmbAah.js +199 -0
- package/dist/{admin/chunks/es-C8vLuvZL.js.map → _chunks/de-CCEmbAah.js.map} +1 -1
- package/dist/_chunks/en-BZaUty0m.mjs +311 -0
- package/dist/{admin/chunks/en-C1CjdAtC.js.map → _chunks/en-BZaUty0m.mjs.map} +1 -1
- package/dist/_chunks/en-CzCnBk4S.js +311 -0
- package/dist/{admin/chunks/en-LfhocNG2.js.map → _chunks/en-CzCnBk4S.js.map} +1 -1
- package/dist/_chunks/es-9K52xZIr.js +196 -0
- package/dist/{admin/chunks/de-5QRlDHyR.js.map → _chunks/es-9K52xZIr.js.map} +1 -1
- package/dist/_chunks/es-D34tqjMw.mjs +196 -0
- package/dist/_chunks/es-D34tqjMw.mjs.map +1 -0
- package/dist/_chunks/eu-CdALomew.mjs +202 -0
- package/dist/_chunks/eu-CdALomew.mjs.map +1 -0
- package/dist/_chunks/eu-VDH-3ovk.js +202 -0
- package/dist/_chunks/eu-VDH-3ovk.js.map +1 -0
- package/dist/_chunks/fr--pg5jUbt.mjs +216 -0
- package/dist/_chunks/fr--pg5jUbt.mjs.map +1 -0
- package/dist/_chunks/fr-B2Kyv8Z9.js +216 -0
- package/dist/_chunks/fr-B2Kyv8Z9.js.map +1 -0
- package/dist/_chunks/gu-BRmF601H.js +200 -0
- package/dist/_chunks/gu-BRmF601H.js.map +1 -0
- package/dist/_chunks/gu-CNpaMDpH.mjs +200 -0
- package/dist/_chunks/gu-CNpaMDpH.mjs.map +1 -0
- package/dist/_chunks/hi-CCJBptSq.js +200 -0
- package/dist/_chunks/hi-CCJBptSq.js.map +1 -0
- package/dist/_chunks/hi-Dwvd04m3.mjs +200 -0
- package/dist/_chunks/hi-Dwvd04m3.mjs.map +1 -0
- package/dist/{admin/chunks/hooks-D-sOYd1s.js → _chunks/hooks-BAaaKPS_.js} +3 -6
- package/dist/_chunks/hooks-BAaaKPS_.js.map +1 -0
- package/dist/_chunks/hooks-E5u1mcgM.mjs +8 -0
- package/dist/_chunks/hooks-E5u1mcgM.mjs.map +1 -0
- package/dist/_chunks/hu-CeYvaaO0.mjs +202 -0
- package/dist/_chunks/hu-CeYvaaO0.mjs.map +1 -0
- package/dist/_chunks/hu-sNV_yLYy.js +202 -0
- package/dist/_chunks/hu-sNV_yLYy.js.map +1 -0
- package/dist/_chunks/id-B5Ser98A.js +160 -0
- package/dist/{admin/chunks/it-BAHrwmYS.js.map → _chunks/id-B5Ser98A.js.map} +1 -1
- package/dist/_chunks/id-BtwA9WJT.mjs +160 -0
- package/dist/_chunks/id-BtwA9WJT.mjs.map +1 -0
- package/dist/_chunks/index-DiluOUp6.mjs +4423 -0
- package/dist/_chunks/index-DiluOUp6.mjs.map +1 -0
- package/dist/_chunks/index-EXJvmn4t.js +4442 -0
- package/dist/_chunks/index-EXJvmn4t.js.map +1 -0
- package/dist/_chunks/it-BrVPqaf1.mjs +162 -0
- package/dist/_chunks/it-BrVPqaf1.mjs.map +1 -0
- package/dist/_chunks/it-DkBIs7vD.js +162 -0
- package/dist/{admin/chunks/id-D7V5S1rB.js.map → _chunks/it-DkBIs7vD.js.map} +1 -1
- package/dist/_chunks/ja-7sfIbjxE.js +196 -0
- package/dist/{admin/chunks/it-CQFpa_Dc.js.map → _chunks/ja-7sfIbjxE.js.map} +1 -1
- package/dist/_chunks/ja-BHqhDq4V.mjs +196 -0
- package/dist/_chunks/ja-BHqhDq4V.mjs.map +1 -0
- package/dist/_chunks/ko-HVQRlfUI.mjs +195 -0
- package/dist/_chunks/ko-HVQRlfUI.mjs.map +1 -0
- package/dist/_chunks/ko-woFZPmLk.js +195 -0
- package/dist/{admin/chunks/es-DkoWSExG.js.map → _chunks/ko-woFZPmLk.js.map} +1 -1
- package/dist/_chunks/layout-4TbKVax8.js +488 -0
- package/dist/_chunks/layout-4TbKVax8.js.map +1 -0
- package/dist/_chunks/layout-mSwsYzxv.mjs +471 -0
- package/dist/_chunks/layout-mSwsYzxv.mjs.map +1 -0
- package/dist/_chunks/ml-BihZwQit.mjs +200 -0
- package/dist/_chunks/ml-BihZwQit.mjs.map +1 -0
- package/dist/_chunks/ml-C2W8N8k1.js +200 -0
- package/dist/_chunks/ml-C2W8N8k1.js.map +1 -0
- package/dist/_chunks/ms-BuFotyP_.js +144 -0
- package/dist/{admin/chunks/cs-BJFxwIWj.js.map → _chunks/ms-BuFotyP_.js.map} +1 -1
- package/dist/_chunks/ms-m_WjyWx7.mjs +144 -0
- package/dist/_chunks/ms-m_WjyWx7.mjs.map +1 -0
- package/dist/_chunks/nl-D4R9gHx5.mjs +202 -0
- package/dist/_chunks/nl-D4R9gHx5.mjs.map +1 -0
- package/dist/_chunks/nl-bbEOHChV.js +202 -0
- package/dist/_chunks/nl-bbEOHChV.js.map +1 -0
- package/dist/_chunks/objects-BcXOv6_9.js +47 -0
- package/dist/_chunks/objects-BcXOv6_9.js.map +1 -0
- package/dist/_chunks/objects-D6yBsdmx.mjs +45 -0
- package/dist/_chunks/objects-D6yBsdmx.mjs.map +1 -0
- package/dist/_chunks/pl-sbx9mSt_.mjs +199 -0
- package/dist/_chunks/pl-sbx9mSt_.mjs.map +1 -0
- package/dist/_chunks/pl-uzwG-hk7.js +199 -0
- package/dist/{admin/chunks/ca-DviY7mRj.js.map → _chunks/pl-uzwG-hk7.js.map} +1 -1
- package/dist/_chunks/pt-BR-BiOz37D9.js +201 -0
- package/dist/{admin/chunks/pt-BR-CcotyBGJ.js.map → _chunks/pt-BR-BiOz37D9.js.map} +1 -1
- package/dist/_chunks/pt-BR-C71iDxnh.mjs +201 -0
- package/dist/_chunks/pt-BR-C71iDxnh.mjs.map +1 -0
- package/dist/_chunks/pt-BsaFvS8-.mjs +95 -0
- package/dist/_chunks/pt-BsaFvS8-.mjs.map +1 -0
- package/dist/_chunks/pt-CeXQuq50.js +95 -0
- package/dist/_chunks/pt-CeXQuq50.js.map +1 -0
- package/dist/_chunks/relations--YOvQBqv.mjs +134 -0
- package/dist/_chunks/relations--YOvQBqv.mjs.map +1 -0
- package/dist/_chunks/relations-Ai6Izh7h.js +133 -0
- package/dist/_chunks/relations-Ai6Izh7h.js.map +1 -0
- package/dist/_chunks/ru-BE6A4Exp.mjs +231 -0
- package/dist/{admin/chunks/ar-DeQBSsfl.js.map → _chunks/ru-BE6A4Exp.mjs.map} +1 -1
- package/dist/_chunks/ru-BT3ybNny.js +231 -0
- package/dist/{admin/chunks/ru-CB4BUyQp.js.map → _chunks/ru-BT3ybNny.js.map} +1 -1
- package/dist/_chunks/sa-CcvkYInH.js +200 -0
- package/dist/_chunks/sa-CcvkYInH.js.map +1 -0
- package/dist/_chunks/sa-Dag0k-Z8.mjs +200 -0
- package/dist/_chunks/sa-Dag0k-Z8.mjs.map +1 -0
- package/dist/_chunks/sk-BFg-R8qJ.mjs +202 -0
- package/dist/_chunks/sk-BFg-R8qJ.mjs.map +1 -0
- package/dist/_chunks/sk-CvY09Xjv.js +202 -0
- package/dist/_chunks/sk-CvY09Xjv.js.map +1 -0
- package/dist/_chunks/sv-CUnfWGsh.mjs +202 -0
- package/dist/_chunks/sv-CUnfWGsh.mjs.map +1 -0
- package/dist/_chunks/sv-MYDuzgvT.js +202 -0
- package/dist/_chunks/sv-MYDuzgvT.js.map +1 -0
- package/dist/_chunks/th-BqbI8lIT.mjs +148 -0
- package/dist/_chunks/th-BqbI8lIT.mjs.map +1 -0
- package/dist/_chunks/th-D9_GfAjc.js +148 -0
- package/dist/{admin/chunks/ms-CvSC0OdG.js.map → _chunks/th-D9_GfAjc.js.map} +1 -1
- package/dist/_chunks/tr-CgeK3wJM.mjs +199 -0
- package/dist/_chunks/tr-CgeK3wJM.mjs.map +1 -0
- package/dist/_chunks/tr-D9UH-O_R.js +199 -0
- package/dist/_chunks/tr-D9UH-O_R.js.map +1 -0
- package/dist/_chunks/uk-C8EiqJY7.js +144 -0
- package/dist/{admin/chunks/ms-Bh09NFff.js.map → _chunks/uk-C8EiqJY7.js.map} +1 -1
- package/dist/_chunks/uk-CR-zDhAY.mjs +144 -0
- package/dist/_chunks/uk-CR-zDhAY.mjs.map +1 -0
- package/dist/_chunks/useDragAndDrop-BMtgCYzL.js +245 -0
- package/dist/_chunks/useDragAndDrop-BMtgCYzL.js.map +1 -0
- package/dist/_chunks/useDragAndDrop-DJ6jqvZN.mjs +228 -0
- package/dist/_chunks/useDragAndDrop-DJ6jqvZN.mjs.map +1 -0
- package/dist/_chunks/usePrev-CZGy2Vjf.mjs +29 -0
- package/dist/_chunks/usePrev-CZGy2Vjf.mjs.map +1 -0
- package/dist/_chunks/usePrev-D5J_2fEu.js +28 -0
- package/dist/_chunks/usePrev-D5J_2fEu.js.map +1 -0
- package/dist/_chunks/vi-CJlYDheJ.js +111 -0
- package/dist/{admin/chunks/vi-CvBGlTjr.js.map → _chunks/vi-CJlYDheJ.js.map} +1 -1
- package/dist/_chunks/vi-DUXIk_fw.mjs +111 -0
- package/dist/_chunks/vi-DUXIk_fw.mjs.map +1 -0
- package/dist/_chunks/zh-BWZspA60.mjs +209 -0
- package/dist/_chunks/zh-BWZspA60.mjs.map +1 -0
- package/dist/_chunks/zh-CQQfszqR.js +209 -0
- package/dist/{admin/chunks/ca-ClDTvatJ.js.map → _chunks/zh-CQQfszqR.js.map} +1 -1
- package/dist/_chunks/zh-Hans-9kOncHGw.js +952 -0
- package/dist/{admin/chunks/zh-Hans-CI0HKio3.js.map → _chunks/zh-Hans-9kOncHGw.js.map} +1 -1
- package/dist/_chunks/zh-Hans-BPQcRIyH.mjs +952 -0
- package/dist/{admin/chunks/zh-Hans-JVK9x7xr.js.map → _chunks/zh-Hans-BPQcRIyH.mjs.map} +1 -1
- package/dist/admin/index.js +4 -23
- package/dist/admin/index.js.map +1 -1
- package/dist/admin/index.mjs +13 -16
- package/dist/admin/index.mjs.map +1 -1
- package/dist/admin/src/history/services/historyVersion.d.ts +1 -1
- package/dist/admin/src/hooks/useDocument.d.ts +2 -2
- package/dist/admin/src/preview/components/PreviewContent.d.ts +1 -2
- package/dist/admin/src/preview/components/PreviewHeader.d.ts +1 -2
- package/dist/admin/src/preview/index.d.ts +3 -2
- package/dist/server/index.js +4396 -5468
- package/dist/server/index.js.map +1 -1
- package/dist/server/index.mjs +4368 -5442
- package/dist/server/index.mjs.map +1 -1
- package/dist/server/src/controllers/utils/metadata.d.ts +1 -1
- package/dist/server/src/controllers/utils/metadata.d.ts.map +1 -1
- package/dist/server/src/history/services/utils.d.ts.map +1 -1
- package/dist/server/src/services/utils/count.d.ts +1 -1
- package/dist/server/src/services/utils/count.d.ts.map +1 -1
- package/dist/server/src/services/utils/populate.d.ts +1 -1
- package/dist/server/src/services/utils/populate.d.ts.map +1 -1
- package/dist/shared/contracts/collection-types.d.ts +1 -0
- package/dist/shared/contracts/components.d.ts +1 -0
- package/dist/shared/contracts/content-types.d.ts +1 -0
- package/dist/shared/contracts/history-versions.d.ts +1 -0
- package/dist/shared/contracts/index.d.ts +1 -0
- package/dist/shared/contracts/init.d.ts +1 -0
- package/dist/shared/contracts/preview.d.ts +1 -0
- package/dist/shared/contracts/relations.d.ts +2 -1
- package/dist/shared/contracts/relations.d.ts.map +1 -1
- package/dist/shared/contracts/review-workflows.d.ts +1 -0
- package/dist/shared/contracts/single-types.d.ts +1 -0
- package/dist/shared/contracts/uid.d.ts +1 -0
- package/dist/shared/index.d.ts +1 -0
- package/dist/shared/index.js +24 -35
- package/dist/shared/index.js.map +1 -1
- package/dist/shared/index.mjs +25 -34
- package/dist/shared/index.mjs.map +1 -1
- package/package.json +10 -13
- package/dist/admin/chunks/CardDragPreview-DwuraT0K.js +0 -80
- package/dist/admin/chunks/CardDragPreview-DwuraT0K.js.map +0 -1
- package/dist/admin/chunks/CardDragPreview-_dubYgXO.js +0 -82
- package/dist/admin/chunks/CardDragPreview-_dubYgXO.js.map +0 -1
- package/dist/admin/chunks/ComponentConfigurationPage-Co2eC_-C.js +0 -276
- package/dist/admin/chunks/ComponentConfigurationPage-Co2eC_-C.js.map +0 -1
- package/dist/admin/chunks/ComponentConfigurationPage-Dj1bNvEF.js +0 -298
- package/dist/admin/chunks/ComponentConfigurationPage-Dj1bNvEF.js.map +0 -1
- package/dist/admin/chunks/ComponentIcon-BZcTc4rj.js +0 -153
- package/dist/admin/chunks/ComponentIcon-BZcTc4rj.js.map +0 -1
- package/dist/admin/chunks/ComponentIcon-C-EjOUPA.js +0 -176
- package/dist/admin/chunks/ComponentIcon-C-EjOUPA.js.map +0 -1
- package/dist/admin/chunks/EditConfigurationPage-Dm5woBp9.js +0 -180
- package/dist/admin/chunks/EditConfigurationPage-Dm5woBp9.js.map +0 -1
- package/dist/admin/chunks/EditConfigurationPage-zd9OLaVh.js +0 -158
- package/dist/admin/chunks/EditConfigurationPage-zd9OLaVh.js.map +0 -1
- package/dist/admin/chunks/EditViewPage-DsBKmSPb.js +0 -337
- package/dist/admin/chunks/EditViewPage-DsBKmSPb.js.map +0 -1
- package/dist/admin/chunks/EditViewPage-kAIaYTg0.js +0 -314
- package/dist/admin/chunks/EditViewPage-kAIaYTg0.js.map +0 -1
- package/dist/admin/chunks/FieldTypeIcon-BY6MrVF4.js +0 -56
- package/dist/admin/chunks/FieldTypeIcon-BY6MrVF4.js.map +0 -1
- package/dist/admin/chunks/FieldTypeIcon-Bxh-7Jin.js +0 -58
- package/dist/admin/chunks/FieldTypeIcon-Bxh-7Jin.js.map +0 -1
- package/dist/admin/chunks/Form-BO69oITe.js +0 -955
- package/dist/admin/chunks/Form-BO69oITe.js.map +0 -1
- package/dist/admin/chunks/Form-BPIhJKyf.js +0 -978
- package/dist/admin/chunks/Form-BPIhJKyf.js.map +0 -1
- package/dist/admin/chunks/History-BzvpM-Gw.js +0 -1357
- package/dist/admin/chunks/History-BzvpM-Gw.js.map +0 -1
- package/dist/admin/chunks/History-DBQ96jv2.js +0 -1380
- package/dist/admin/chunks/History-DBQ96jv2.js.map +0 -1
- package/dist/admin/chunks/Input-BlDcbhUC.js +0 -6755
- package/dist/admin/chunks/Input-BlDcbhUC.js.map +0 -1
- package/dist/admin/chunks/Input-Dh1MtWno.js +0 -6786
- package/dist/admin/chunks/Input-Dh1MtWno.js.map +0 -1
- package/dist/admin/chunks/ListConfigurationPage-8d3BsQIr.js +0 -818
- package/dist/admin/chunks/ListConfigurationPage-8d3BsQIr.js.map +0 -1
- package/dist/admin/chunks/ListConfigurationPage-DK0ARecn.js +0 -795
- package/dist/admin/chunks/ListConfigurationPage-DK0ARecn.js.map +0 -1
- package/dist/admin/chunks/ListViewPage-BF2q7N6W.js +0 -1132
- package/dist/admin/chunks/ListViewPage-BF2q7N6W.js.map +0 -1
- package/dist/admin/chunks/ListViewPage-CS1ED-vI.js +0 -1154
- package/dist/admin/chunks/ListViewPage-CS1ED-vI.js.map +0 -1
- package/dist/admin/chunks/NoContentTypePage-C5Qxz3I4.js +0 -59
- package/dist/admin/chunks/NoContentTypePage-C5Qxz3I4.js.map +0 -1
- package/dist/admin/chunks/NoContentTypePage-DjdXr1-j.js +0 -57
- package/dist/admin/chunks/NoContentTypePage-DjdXr1-j.js.map +0 -1
- package/dist/admin/chunks/NoPermissionsPage-BUwtKUEP.js +0 -36
- package/dist/admin/chunks/NoPermissionsPage-BUwtKUEP.js.map +0 -1
- package/dist/admin/chunks/NoPermissionsPage-C5dC0MtL.js +0 -38
- package/dist/admin/chunks/NoPermissionsPage-C5dC0MtL.js.map +0 -1
- package/dist/admin/chunks/Preview-C9kXTY6C.js +0 -531
- package/dist/admin/chunks/Preview-C9kXTY6C.js.map +0 -1
- package/dist/admin/chunks/Preview-DBvmhR7Q.js +0 -553
- package/dist/admin/chunks/Preview-DBvmhR7Q.js.map +0 -1
- package/dist/admin/chunks/Relations-Cn0atFpd.js +0 -827
- package/dist/admin/chunks/Relations-Cn0atFpd.js.map +0 -1
- package/dist/admin/chunks/Relations-XHxDKEvT.js +0 -853
- package/dist/admin/chunks/Relations-XHxDKEvT.js.map +0 -1
- package/dist/admin/chunks/ar-DckYq_WK.js +0 -222
- package/dist/admin/chunks/ar-DeQBSsfl.js +0 -227
- package/dist/admin/chunks/ca-ClDTvatJ.js +0 -202
- package/dist/admin/chunks/ca-DviY7mRj.js +0 -197
- package/dist/admin/chunks/cs-BJFxwIWj.js +0 -126
- package/dist/admin/chunks/cs-C7OSYFQ7.js +0 -122
- package/dist/admin/chunks/de-5QRlDHyR.js +0 -195
- package/dist/admin/chunks/de-CbImAUA5.js +0 -200
- package/dist/admin/chunks/en-C1CjdAtC.js +0 -313
- package/dist/admin/chunks/en-LfhocNG2.js +0 -308
- package/dist/admin/chunks/es-C8vLuvZL.js +0 -197
- package/dist/admin/chunks/es-DkoWSExG.js +0 -192
- package/dist/admin/chunks/eu-BG1xX7HK.js +0 -198
- package/dist/admin/chunks/eu-BG1xX7HK.js.map +0 -1
- package/dist/admin/chunks/eu-BJW3AvXu.js +0 -203
- package/dist/admin/chunks/eu-BJW3AvXu.js.map +0 -1
- package/dist/admin/chunks/fr-CFdRaRVj.js +0 -215
- package/dist/admin/chunks/fr-CFdRaRVj.js.map +0 -1
- package/dist/admin/chunks/fr-gQSilC7w.js +0 -220
- package/dist/admin/chunks/fr-gQSilC7w.js.map +0 -1
- package/dist/admin/chunks/gu-D5MMMXRs.js +0 -196
- package/dist/admin/chunks/gu-D5MMMXRs.js.map +0 -1
- package/dist/admin/chunks/gu-DPU4wyx7.js +0 -201
- package/dist/admin/chunks/gu-DPU4wyx7.js.map +0 -1
- package/dist/admin/chunks/hi-Dp4omeBb.js +0 -201
- package/dist/admin/chunks/hi-Dp4omeBb.js.map +0 -1
- package/dist/admin/chunks/hi-lp17SCjr.js +0 -196
- package/dist/admin/chunks/hi-lp17SCjr.js.map +0 -1
- package/dist/admin/chunks/hooks-D-sOYd1s.js.map +0 -1
- package/dist/admin/chunks/hooks-DMvik5y_.js +0 -7
- package/dist/admin/chunks/hooks-DMvik5y_.js.map +0 -1
- package/dist/admin/chunks/hu-CLka1U2C.js +0 -198
- package/dist/admin/chunks/hu-CLka1U2C.js.map +0 -1
- package/dist/admin/chunks/hu-CtFJuhTd.js +0 -203
- package/dist/admin/chunks/hu-CtFJuhTd.js.map +0 -1
- package/dist/admin/chunks/id-D7V5S1rB.js +0 -161
- package/dist/admin/chunks/id-USfY9m1g.js +0 -156
- package/dist/admin/chunks/id-USfY9m1g.js.map +0 -1
- package/dist/admin/chunks/index-BczuAULz.js +0 -5416
- package/dist/admin/chunks/index-BczuAULz.js.map +0 -1
- package/dist/admin/chunks/index-BkyR-Bnu.js +0 -5350
- package/dist/admin/chunks/index-BkyR-Bnu.js.map +0 -1
- package/dist/admin/chunks/it-BAHrwmYS.js +0 -158
- package/dist/admin/chunks/it-CQFpa_Dc.js +0 -163
- package/dist/admin/chunks/ja-BWKmBJFT.js +0 -192
- package/dist/admin/chunks/ja-BWKmBJFT.js.map +0 -1
- package/dist/admin/chunks/ja-jdQM-B79.js +0 -197
- package/dist/admin/chunks/ja-jdQM-B79.js.map +0 -1
- package/dist/admin/chunks/ko-CgADGBNt.js +0 -191
- package/dist/admin/chunks/ko-CgADGBNt.js.map +0 -1
- package/dist/admin/chunks/ko-k46sEyzt.js +0 -196
- package/dist/admin/chunks/ko-k46sEyzt.js.map +0 -1
- package/dist/admin/chunks/layout-DcDoRT8g.js +0 -618
- package/dist/admin/chunks/layout-DcDoRT8g.js.map +0 -1
- package/dist/admin/chunks/layout-fghBgRgX.js +0 -598
- package/dist/admin/chunks/layout-fghBgRgX.js.map +0 -1
- package/dist/admin/chunks/ml-CnhCfOn_.js +0 -196
- package/dist/admin/chunks/ml-CnhCfOn_.js.map +0 -1
- package/dist/admin/chunks/ml-DqxPwODx.js +0 -201
- package/dist/admin/chunks/ml-DqxPwODx.js.map +0 -1
- package/dist/admin/chunks/ms-Bh09NFff.js +0 -140
- package/dist/admin/chunks/ms-CvSC0OdG.js +0 -145
- package/dist/admin/chunks/nl-BEubhS8C.js +0 -203
- package/dist/admin/chunks/nl-BEubhS8C.js.map +0 -1
- package/dist/admin/chunks/nl-C8HYflTc.js +0 -198
- package/dist/admin/chunks/nl-C8HYflTc.js.map +0 -1
- package/dist/admin/chunks/objects-C3EebVVe.js +0 -76
- package/dist/admin/chunks/objects-C3EebVVe.js.map +0 -1
- package/dist/admin/chunks/objects-wl73iEma.js +0 -73
- package/dist/admin/chunks/objects-wl73iEma.js.map +0 -1
- package/dist/admin/chunks/pl-DWhGDzmM.js +0 -200
- package/dist/admin/chunks/pl-DWhGDzmM.js.map +0 -1
- package/dist/admin/chunks/pl-MFCZJZuZ.js +0 -195
- package/dist/admin/chunks/pl-MFCZJZuZ.js.map +0 -1
- package/dist/admin/chunks/pt-BR-CPtAXD-4.js +0 -202
- package/dist/admin/chunks/pt-BR-CPtAXD-4.js.map +0 -1
- package/dist/admin/chunks/pt-BR-CcotyBGJ.js +0 -197
- package/dist/admin/chunks/pt-BoPxN80n.js +0 -96
- package/dist/admin/chunks/pt-BoPxN80n.js.map +0 -1
- package/dist/admin/chunks/pt-HbmgeiYO.js +0 -93
- package/dist/admin/chunks/pt-HbmgeiYO.js.map +0 -1
- package/dist/admin/chunks/relations-CgaydhiM.js +0 -178
- package/dist/admin/chunks/relations-CgaydhiM.js.map +0 -1
- package/dist/admin/chunks/relations-DPVgU_rq.js +0 -173
- package/dist/admin/chunks/relations-DPVgU_rq.js.map +0 -1
- package/dist/admin/chunks/ru-C0op0ALG.js +0 -232
- package/dist/admin/chunks/ru-C0op0ALG.js.map +0 -1
- package/dist/admin/chunks/ru-CB4BUyQp.js +0 -230
- package/dist/admin/chunks/sa-B_FuPyMw.js +0 -201
- package/dist/admin/chunks/sa-B_FuPyMw.js.map +0 -1
- package/dist/admin/chunks/sa-n_aPA-pU.js +0 -196
- package/dist/admin/chunks/sa-n_aPA-pU.js.map +0 -1
- package/dist/admin/chunks/sk-D_iXML2C.js +0 -203
- package/dist/admin/chunks/sk-D_iXML2C.js.map +0 -1
- package/dist/admin/chunks/sk-tn_BDjE2.js +0 -198
- package/dist/admin/chunks/sk-tn_BDjE2.js.map +0 -1
- package/dist/admin/chunks/sv-BstBC1Yp.js +0 -203
- package/dist/admin/chunks/sv-BstBC1Yp.js.map +0 -1
- package/dist/admin/chunks/sv-cq4ZrQRd.js +0 -198
- package/dist/admin/chunks/sv-cq4ZrQRd.js.map +0 -1
- package/dist/admin/chunks/th-lXoOCqPC.js +0 -149
- package/dist/admin/chunks/th-lXoOCqPC.js.map +0 -1
- package/dist/admin/chunks/th-mUH7hEtc.js +0 -144
- package/dist/admin/chunks/th-mUH7hEtc.js.map +0 -1
- package/dist/admin/chunks/tr-CkS6sLIE.js +0 -200
- package/dist/admin/chunks/tr-CkS6sLIE.js.map +0 -1
- package/dist/admin/chunks/tr-Yt38daxh.js +0 -195
- package/dist/admin/chunks/tr-Yt38daxh.js.map +0 -1
- package/dist/admin/chunks/uk-B24MoTVg.js +0 -145
- package/dist/admin/chunks/uk-B24MoTVg.js.map +0 -1
- package/dist/admin/chunks/uk-Cpgmm7gE.js +0 -140
- package/dist/admin/chunks/uk-Cpgmm7gE.js.map +0 -1
- package/dist/admin/chunks/useDragAndDrop-HYwNDExe.js +0 -247
- package/dist/admin/chunks/useDragAndDrop-HYwNDExe.js.map +0 -1
- package/dist/admin/chunks/useDragAndDrop-gcqEJMnO.js +0 -271
- package/dist/admin/chunks/useDragAndDrop-gcqEJMnO.js.map +0 -1
- package/dist/admin/chunks/usePrev-Bjw2dhmq.js +0 -18
- package/dist/admin/chunks/usePrev-Bjw2dhmq.js.map +0 -1
- package/dist/admin/chunks/usePrev-DIYl-IAL.js +0 -21
- package/dist/admin/chunks/usePrev-DIYl-IAL.js.map +0 -1
- package/dist/admin/chunks/vi-BGr1X_HZ.js +0 -112
- package/dist/admin/chunks/vi-BGr1X_HZ.js.map +0 -1
- package/dist/admin/chunks/vi-CvBGlTjr.js +0 -108
- package/dist/admin/chunks/zh-BmF-sHaT.js +0 -205
- package/dist/admin/chunks/zh-BmF-sHaT.js.map +0 -1
- package/dist/admin/chunks/zh-DwFu_Kfj.js +0 -210
- package/dist/admin/chunks/zh-DwFu_Kfj.js.map +0 -1
- package/dist/admin/chunks/zh-Hans-CI0HKio3.js +0 -934
- package/dist/admin/chunks/zh-Hans-JVK9x7xr.js +0 -953
@@ -0,0 +1,245 @@
|
|
1
|
+
"use strict";
|
2
|
+
const React = require("react");
|
3
|
+
const reactDnd = require("react-dnd");
|
4
|
+
function _interopNamespace(e) {
|
5
|
+
if (e && e.__esModule) return e;
|
6
|
+
const n = Object.create(null, { [Symbol.toStringTag]: { value: "Module" } });
|
7
|
+
if (e) {
|
8
|
+
for (const k in e) {
|
9
|
+
if (k !== "default") {
|
10
|
+
const d = Object.getOwnPropertyDescriptor(e, k);
|
11
|
+
Object.defineProperty(n, k, d.get ? d : {
|
12
|
+
enumerable: true,
|
13
|
+
get: () => e[k]
|
14
|
+
});
|
15
|
+
}
|
16
|
+
}
|
17
|
+
}
|
18
|
+
n.default = e;
|
19
|
+
return Object.freeze(n);
|
20
|
+
}
|
21
|
+
const React__namespace = /* @__PURE__ */ _interopNamespace(React);
|
22
|
+
const ItemTypes = {
|
23
|
+
COMPONENT: "component",
|
24
|
+
EDIT_FIELD: "editField",
|
25
|
+
FIELD: "field",
|
26
|
+
DYNAMIC_ZONE: "dynamicZone",
|
27
|
+
RELATION: "relation",
|
28
|
+
BLOCKS: "blocks"
|
29
|
+
};
|
30
|
+
const useKeyboardDragAndDrop = (active, index, { onCancel, onDropItem, onGrabItem, onMoveItem }) => {
|
31
|
+
const [isSelected, setIsSelected] = React__namespace.useState(false);
|
32
|
+
const handleMove = (movement) => {
|
33
|
+
if (!isSelected) {
|
34
|
+
return;
|
35
|
+
}
|
36
|
+
if (typeof index === "number" && onMoveItem) {
|
37
|
+
if (movement === "UP") {
|
38
|
+
onMoveItem(index - 1, index);
|
39
|
+
} else if (movement === "DOWN") {
|
40
|
+
onMoveItem(index + 1, index);
|
41
|
+
}
|
42
|
+
}
|
43
|
+
};
|
44
|
+
const handleDragClick = () => {
|
45
|
+
if (isSelected) {
|
46
|
+
if (onDropItem) {
|
47
|
+
onDropItem(index);
|
48
|
+
}
|
49
|
+
setIsSelected(false);
|
50
|
+
} else {
|
51
|
+
if (onGrabItem) {
|
52
|
+
onGrabItem(index);
|
53
|
+
}
|
54
|
+
setIsSelected(true);
|
55
|
+
}
|
56
|
+
};
|
57
|
+
const handleCancel = () => {
|
58
|
+
if (isSelected) {
|
59
|
+
setIsSelected(false);
|
60
|
+
if (onCancel) {
|
61
|
+
onCancel(index);
|
62
|
+
}
|
63
|
+
}
|
64
|
+
};
|
65
|
+
const handleKeyDown = (e) => {
|
66
|
+
if (!active) {
|
67
|
+
return;
|
68
|
+
}
|
69
|
+
if (e.key === "Tab" && !isSelected) {
|
70
|
+
return;
|
71
|
+
}
|
72
|
+
e.preventDefault();
|
73
|
+
switch (e.key) {
|
74
|
+
case " ":
|
75
|
+
case "Enter":
|
76
|
+
handleDragClick();
|
77
|
+
break;
|
78
|
+
case "Escape":
|
79
|
+
handleCancel();
|
80
|
+
break;
|
81
|
+
case "ArrowDown":
|
82
|
+
case "ArrowRight":
|
83
|
+
handleMove("DOWN");
|
84
|
+
break;
|
85
|
+
case "ArrowUp":
|
86
|
+
case "ArrowLeft":
|
87
|
+
handleMove("UP");
|
88
|
+
break;
|
89
|
+
}
|
90
|
+
};
|
91
|
+
return handleKeyDown;
|
92
|
+
};
|
93
|
+
const DIRECTIONS = {
|
94
|
+
UPWARD: "upward",
|
95
|
+
DOWNWARD: "downward"
|
96
|
+
};
|
97
|
+
const DROP_SENSITIVITY = {
|
98
|
+
REGULAR: "regular",
|
99
|
+
IMMEDIATE: "immediate"
|
100
|
+
};
|
101
|
+
const useDragAndDrop = (active, {
|
102
|
+
type = "STRAPI_DND",
|
103
|
+
index,
|
104
|
+
item,
|
105
|
+
onStart,
|
106
|
+
onEnd,
|
107
|
+
onGrabItem,
|
108
|
+
onDropItem,
|
109
|
+
onCancel,
|
110
|
+
onMoveItem,
|
111
|
+
dropSensitivity = DROP_SENSITIVITY.REGULAR
|
112
|
+
}) => {
|
113
|
+
const objectRef = React__namespace.useRef(null);
|
114
|
+
const [{ handlerId, isOver }, dropRef] = reactDnd.useDrop({
|
115
|
+
accept: type,
|
116
|
+
collect(monitor) {
|
117
|
+
return {
|
118
|
+
handlerId: monitor.getHandlerId(),
|
119
|
+
isOver: monitor.isOver({ shallow: true })
|
120
|
+
};
|
121
|
+
},
|
122
|
+
drop(item2) {
|
123
|
+
const draggedIndex = item2.index;
|
124
|
+
const newIndex = index;
|
125
|
+
if (isOver && onDropItem) {
|
126
|
+
onDropItem(draggedIndex, newIndex);
|
127
|
+
}
|
128
|
+
},
|
129
|
+
hover(item2, monitor) {
|
130
|
+
if (!objectRef.current || !onMoveItem) {
|
131
|
+
return;
|
132
|
+
}
|
133
|
+
const dragIndex = item2.index;
|
134
|
+
const newIndex = index;
|
135
|
+
const hoverBoundingRect = objectRef.current?.getBoundingClientRect();
|
136
|
+
const hoverMiddleY = (hoverBoundingRect.bottom - hoverBoundingRect.top) / 2;
|
137
|
+
const clientOffset = monitor.getClientOffset();
|
138
|
+
if (!clientOffset) return;
|
139
|
+
const hoverClientY = clientOffset && clientOffset.y - hoverBoundingRect.top;
|
140
|
+
if (typeof dragIndex === "number" && typeof newIndex === "number") {
|
141
|
+
if (dragIndex === newIndex) {
|
142
|
+
return;
|
143
|
+
}
|
144
|
+
if (dropSensitivity === DROP_SENSITIVITY.REGULAR) {
|
145
|
+
if (dragIndex < newIndex && hoverClientY < hoverMiddleY) {
|
146
|
+
return;
|
147
|
+
}
|
148
|
+
if (dragIndex > newIndex && hoverClientY > hoverMiddleY) {
|
149
|
+
return;
|
150
|
+
}
|
151
|
+
}
|
152
|
+
onMoveItem(newIndex, dragIndex);
|
153
|
+
item2.index = newIndex;
|
154
|
+
} else {
|
155
|
+
if (Array.isArray(dragIndex) && Array.isArray(newIndex)) {
|
156
|
+
const minLength = Math.min(dragIndex.length, newIndex.length);
|
157
|
+
let areEqual = true;
|
158
|
+
let isLessThan = false;
|
159
|
+
let isGreaterThan = false;
|
160
|
+
for (let i = 0; i < minLength; i++) {
|
161
|
+
if (dragIndex[i] < newIndex[i]) {
|
162
|
+
isLessThan = true;
|
163
|
+
areEqual = false;
|
164
|
+
break;
|
165
|
+
} else if (dragIndex[i] > newIndex[i]) {
|
166
|
+
isGreaterThan = true;
|
167
|
+
areEqual = false;
|
168
|
+
break;
|
169
|
+
}
|
170
|
+
}
|
171
|
+
if (areEqual && dragIndex.length === newIndex.length) {
|
172
|
+
return;
|
173
|
+
}
|
174
|
+
if (dropSensitivity === DROP_SENSITIVITY.REGULAR) {
|
175
|
+
if (isLessThan && !isGreaterThan && hoverClientY < hoverMiddleY) {
|
176
|
+
return;
|
177
|
+
}
|
178
|
+
if (isGreaterThan && !isLessThan && hoverClientY > hoverMiddleY) {
|
179
|
+
return;
|
180
|
+
}
|
181
|
+
}
|
182
|
+
}
|
183
|
+
onMoveItem(newIndex, dragIndex);
|
184
|
+
item2.index = newIndex;
|
185
|
+
}
|
186
|
+
}
|
187
|
+
});
|
188
|
+
const getDragDirection = (monitor) => {
|
189
|
+
if (monitor && monitor.isDragging() && !monitor.didDrop() && monitor.getInitialClientOffset() && monitor.getClientOffset()) {
|
190
|
+
const deltaY = monitor.getInitialClientOffset().y - monitor.getClientOffset().y;
|
191
|
+
if (deltaY > 0) return DIRECTIONS.UPWARD;
|
192
|
+
if (deltaY < 0) return DIRECTIONS.DOWNWARD;
|
193
|
+
return null;
|
194
|
+
}
|
195
|
+
return null;
|
196
|
+
};
|
197
|
+
const [{ isDragging, direction }, dragRef, dragPreviewRef] = reactDnd.useDrag({
|
198
|
+
type,
|
199
|
+
item() {
|
200
|
+
if (onStart) {
|
201
|
+
onStart();
|
202
|
+
}
|
203
|
+
const { width } = objectRef.current?.getBoundingClientRect() ?? {};
|
204
|
+
return { index, width, ...item };
|
205
|
+
},
|
206
|
+
end() {
|
207
|
+
if (onEnd) {
|
208
|
+
onEnd();
|
209
|
+
}
|
210
|
+
},
|
211
|
+
canDrag: active,
|
212
|
+
/**
|
213
|
+
* This is useful when the item is in a virtualized list.
|
214
|
+
* However, if we don't have an ID then we want the libraries
|
215
|
+
* defaults to take care of this.
|
216
|
+
*/
|
217
|
+
isDragging: item?.id ? (monitor) => {
|
218
|
+
return item.id === monitor.getItem().id;
|
219
|
+
} : void 0,
|
220
|
+
collect: (monitor) => ({
|
221
|
+
isDragging: monitor.isDragging(),
|
222
|
+
initialOffset: monitor.getInitialClientOffset(),
|
223
|
+
currentOffset: monitor.getClientOffset(),
|
224
|
+
direction: getDragDirection(monitor)
|
225
|
+
})
|
226
|
+
});
|
227
|
+
const handleKeyDown = useKeyboardDragAndDrop(active, index, {
|
228
|
+
onGrabItem,
|
229
|
+
onDropItem,
|
230
|
+
onCancel,
|
231
|
+
onMoveItem
|
232
|
+
});
|
233
|
+
return [
|
234
|
+
{ handlerId, isDragging, handleKeyDown, isOverDropTarget: isOver, direction },
|
235
|
+
objectRef,
|
236
|
+
dropRef,
|
237
|
+
dragRef,
|
238
|
+
dragPreviewRef
|
239
|
+
];
|
240
|
+
};
|
241
|
+
exports.DIRECTIONS = DIRECTIONS;
|
242
|
+
exports.DROP_SENSITIVITY = DROP_SENSITIVITY;
|
243
|
+
exports.ItemTypes = ItemTypes;
|
244
|
+
exports.useDragAndDrop = useDragAndDrop;
|
245
|
+
//# sourceMappingURL=useDragAndDrop-BMtgCYzL.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"useDragAndDrop-BMtgCYzL.js","sources":["../../admin/src/constants/dragAndDrop.ts","../../admin/src/hooks/useKeyboardDragAndDrop.ts","../../admin/src/hooks/useDragAndDrop.ts"],"sourcesContent":["export const ItemTypes = {\n COMPONENT: 'component',\n EDIT_FIELD: 'editField',\n FIELD: 'field',\n DYNAMIC_ZONE: 'dynamicZone',\n RELATION: 'relation',\n BLOCKS: 'blocks',\n} as const;\n","import * as React from 'react';\n\nexport type UseKeyboardDragAndDropCallbacks<TIndex extends number | Array<number> = number> = {\n onCancel?: (index: TIndex) => void;\n onDropItem?: (currentIndex: TIndex, newIndex?: TIndex) => void;\n onGrabItem?: (index: TIndex) => void;\n onMoveItem?: (newIndex: TIndex, currentIndex: TIndex) => void;\n};\n\n/**\n * Utility hook designed to implement keyboard accessibile drag and drop by\n * returning an onKeyDown handler to be passed to the drag icon button.\n *\n * @internal - You should use `useDragAndDrop` instead.\n */\nexport const useKeyboardDragAndDrop = <TIndex extends number | Array<number> = number>(\n active: boolean,\n index: TIndex,\n { onCancel, onDropItem, onGrabItem, onMoveItem }: UseKeyboardDragAndDropCallbacks<TIndex>\n) => {\n const [isSelected, setIsSelected] = React.useState(false);\n\n const handleMove = (movement: 'UP' | 'DOWN') => {\n if (!isSelected) {\n return;\n }\n if (typeof index === 'number' && onMoveItem) {\n if (movement === 'UP') {\n onMoveItem((index - 1) as TIndex, index);\n } else if (movement === 'DOWN') {\n onMoveItem((index + 1) as TIndex, index);\n }\n }\n };\n\n const handleDragClick = () => {\n if (isSelected) {\n if (onDropItem) {\n onDropItem(index);\n }\n setIsSelected(false);\n } else {\n if (onGrabItem) {\n onGrabItem(index);\n }\n setIsSelected(true);\n }\n };\n\n const handleCancel = () => {\n if (isSelected) {\n setIsSelected(false);\n\n if (onCancel) {\n onCancel(index);\n }\n }\n };\n\n const handleKeyDown = <E extends Element>(e: React.KeyboardEvent<E>) => {\n if (!active) {\n return;\n }\n\n if (e.key === 'Tab' && !isSelected) {\n return;\n }\n\n e.preventDefault();\n\n switch (e.key) {\n case ' ':\n case 'Enter':\n handleDragClick();\n break;\n\n case 'Escape':\n handleCancel();\n break;\n\n case 'ArrowDown':\n case 'ArrowRight':\n handleMove('DOWN');\n break;\n\n case 'ArrowUp':\n case 'ArrowLeft':\n handleMove('UP');\n break;\n\n default:\n }\n };\n\n return handleKeyDown;\n};\n","import * as React from 'react';\n\nimport {\n useDrag,\n useDrop,\n type HandlerManager,\n type ConnectDragSource,\n type ConnectDropTarget,\n type ConnectDragPreview,\n type DragSourceMonitor,\n} from 'react-dnd';\n\nimport {\n useKeyboardDragAndDrop,\n type UseKeyboardDragAndDropCallbacks,\n} from './useKeyboardDragAndDrop';\n\nimport type { Data } from '@strapi/types';\n\nconst DIRECTIONS = {\n UPWARD: 'upward',\n DOWNWARD: 'downward',\n} as const;\n\nconst DROP_SENSITIVITY = {\n REGULAR: 'regular',\n IMMEDIATE: 'immediate',\n} as const;\n\ninterface UseDragAndDropOptions<\n TIndex extends number | Array<number> = number,\n TItem extends { index: TIndex } = { index: TIndex },\n> extends UseKeyboardDragAndDropCallbacks<TIndex> {\n type?: string;\n index: TIndex;\n item?: TItem;\n onStart?: () => void;\n onEnd?: () => void;\n dropSensitivity?: (typeof DROP_SENSITIVITY)[keyof typeof DROP_SENSITIVITY];\n}\n\ntype Identifier = ReturnType<HandlerManager['getHandlerId']>;\n\ntype UseDragAndDropReturn<E extends Element = HTMLElement> = [\n props: {\n handlerId: Identifier;\n isDragging: boolean;\n handleKeyDown: <E extends Element>(event: React.KeyboardEvent<E>) => void;\n isOverDropTarget: boolean;\n direction: (typeof DIRECTIONS)[keyof typeof DIRECTIONS] | null;\n },\n objectRef: React.RefObject<E>,\n dropRef: ConnectDropTarget,\n dragRef: ConnectDragSource,\n dragPreviewRef: ConnectDragPreview,\n];\n\ntype DropCollectedProps = {\n handlerId: Identifier;\n isOver: boolean;\n};\n\n/**\n * A utility hook abstracting the general drag and drop hooks from react-dnd.\n * Centralising the same behaviours and by default offering keyboard support.\n */\nconst useDragAndDrop = <\n TIndex extends number | Array<number>,\n TItem extends { index: TIndex; id?: Data.ID; [key: string]: unknown } = {\n index: TIndex;\n [key: string]: unknown;\n },\n E extends Element = HTMLElement,\n>(\n active: boolean,\n {\n type = 'STRAPI_DND',\n index,\n item,\n onStart,\n onEnd,\n onGrabItem,\n onDropItem,\n onCancel,\n onMoveItem,\n dropSensitivity = DROP_SENSITIVITY.REGULAR,\n }: UseDragAndDropOptions<TIndex, TItem>\n): UseDragAndDropReturn<E> => {\n const objectRef = React.useRef<E>(null);\n\n const [{ handlerId, isOver }, dropRef] = useDrop<TItem, void, DropCollectedProps>({\n accept: type,\n collect(monitor) {\n return {\n handlerId: monitor.getHandlerId(),\n isOver: monitor.isOver({ shallow: true }),\n };\n },\n drop(item) {\n const draggedIndex = item.index;\n const newIndex = index;\n\n if (isOver && onDropItem) {\n onDropItem(draggedIndex, newIndex);\n }\n },\n hover(item, monitor) {\n if (!objectRef.current || !onMoveItem) {\n return;\n }\n\n const dragIndex = item.index;\n const newIndex = index;\n\n const hoverBoundingRect = objectRef.current?.getBoundingClientRect();\n const hoverMiddleY = (hoverBoundingRect.bottom - hoverBoundingRect.top) / 2;\n const clientOffset = monitor.getClientOffset();\n if (!clientOffset) return;\n\n const hoverClientY = clientOffset && clientOffset.y - hoverBoundingRect.top;\n if (typeof dragIndex === 'number' && typeof newIndex === 'number') {\n if (dragIndex === newIndex) {\n // Don't replace items with themselves\n return;\n }\n\n if (dropSensitivity === DROP_SENSITIVITY.REGULAR) {\n // Dragging downwards\n if (dragIndex < newIndex && hoverClientY < hoverMiddleY) {\n return;\n }\n\n // Dragging upwards\n if (dragIndex > newIndex && hoverClientY > hoverMiddleY) {\n return;\n }\n }\n\n // Time to actually perform the action\n onMoveItem(newIndex, dragIndex);\n item.index = newIndex;\n } else {\n // Using numbers as indices doesn't work for nested list items with path like [1, 1, 0]\n if (Array.isArray(dragIndex) && Array.isArray(newIndex)) {\n // Indices comparison to find item position in nested list\n const minLength = Math.min(dragIndex.length, newIndex.length);\n let areEqual = true;\n let isLessThan = false;\n let isGreaterThan = false;\n\n for (let i = 0; i < minLength; i++) {\n if (dragIndex[i] < newIndex[i]) {\n isLessThan = true;\n areEqual = false;\n break;\n } else if (dragIndex[i] > newIndex[i]) {\n isGreaterThan = true;\n areEqual = false;\n break;\n }\n }\n\n // Don't replace items with themselves\n if (areEqual && dragIndex.length === newIndex.length) {\n return;\n }\n\n if (dropSensitivity === DROP_SENSITIVITY.REGULAR) {\n // Dragging downwards\n if (isLessThan && !isGreaterThan && hoverClientY < hoverMiddleY) {\n return;\n }\n\n // Dragging upwards\n if (isGreaterThan && !isLessThan && hoverClientY > hoverMiddleY) {\n return;\n }\n }\n }\n\n onMoveItem(newIndex, dragIndex);\n item.index = newIndex;\n }\n },\n });\n\n const getDragDirection = (monitor: DragSourceMonitor<TItem, void>) => {\n if (\n monitor &&\n monitor.isDragging() &&\n !monitor.didDrop() &&\n monitor.getInitialClientOffset() &&\n monitor.getClientOffset()\n ) {\n const deltaY = monitor.getInitialClientOffset()!.y - monitor.getClientOffset()!.y;\n\n if (deltaY > 0) return DIRECTIONS.UPWARD;\n\n if (deltaY < 0) return DIRECTIONS.DOWNWARD;\n\n return null;\n }\n\n return null;\n };\n\n const [{ isDragging, direction }, dragRef, dragPreviewRef] = useDrag({\n type,\n item() {\n if (onStart) {\n onStart();\n }\n\n /**\n * This will be attached and it helps define the preview sizes\n * when a component is flexy e.g. Relations\n */\n const { width } = objectRef.current?.getBoundingClientRect() ?? {};\n\n return { index, width, ...item };\n },\n end() {\n if (onEnd) {\n onEnd();\n }\n },\n canDrag: active,\n /**\n * This is useful when the item is in a virtualized list.\n * However, if we don't have an ID then we want the libraries\n * defaults to take care of this.\n */\n isDragging: item?.id\n ? (monitor) => {\n return item.id === monitor.getItem().id;\n }\n : undefined,\n collect: (monitor) => ({\n isDragging: monitor.isDragging(),\n initialOffset: monitor.getInitialClientOffset(),\n currentOffset: monitor.getClientOffset(),\n direction: getDragDirection(monitor),\n }),\n });\n\n const handleKeyDown = useKeyboardDragAndDrop(active, index, {\n onGrabItem,\n onDropItem,\n onCancel,\n onMoveItem,\n });\n\n return [\n { handlerId, isDragging, handleKeyDown, isOverDropTarget: isOver, direction },\n objectRef,\n dropRef,\n dragRef,\n dragPreviewRef,\n ];\n};\n\nexport {\n useDragAndDrop,\n UseDragAndDropReturn,\n UseDragAndDropOptions,\n DIRECTIONS,\n DROP_SENSITIVITY,\n};\n"],"names":["React","useDrop","item","useDrag"],"mappings":"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"}
|
@@ -0,0 +1,228 @@
|
|
1
|
+
import * as React from "react";
|
2
|
+
import { useDrop, useDrag } from "react-dnd";
|
3
|
+
const ItemTypes = {
|
4
|
+
COMPONENT: "component",
|
5
|
+
EDIT_FIELD: "editField",
|
6
|
+
FIELD: "field",
|
7
|
+
DYNAMIC_ZONE: "dynamicZone",
|
8
|
+
RELATION: "relation",
|
9
|
+
BLOCKS: "blocks"
|
10
|
+
};
|
11
|
+
const useKeyboardDragAndDrop = (active, index, { onCancel, onDropItem, onGrabItem, onMoveItem }) => {
|
12
|
+
const [isSelected, setIsSelected] = React.useState(false);
|
13
|
+
const handleMove = (movement) => {
|
14
|
+
if (!isSelected) {
|
15
|
+
return;
|
16
|
+
}
|
17
|
+
if (typeof index === "number" && onMoveItem) {
|
18
|
+
if (movement === "UP") {
|
19
|
+
onMoveItem(index - 1, index);
|
20
|
+
} else if (movement === "DOWN") {
|
21
|
+
onMoveItem(index + 1, index);
|
22
|
+
}
|
23
|
+
}
|
24
|
+
};
|
25
|
+
const handleDragClick = () => {
|
26
|
+
if (isSelected) {
|
27
|
+
if (onDropItem) {
|
28
|
+
onDropItem(index);
|
29
|
+
}
|
30
|
+
setIsSelected(false);
|
31
|
+
} else {
|
32
|
+
if (onGrabItem) {
|
33
|
+
onGrabItem(index);
|
34
|
+
}
|
35
|
+
setIsSelected(true);
|
36
|
+
}
|
37
|
+
};
|
38
|
+
const handleCancel = () => {
|
39
|
+
if (isSelected) {
|
40
|
+
setIsSelected(false);
|
41
|
+
if (onCancel) {
|
42
|
+
onCancel(index);
|
43
|
+
}
|
44
|
+
}
|
45
|
+
};
|
46
|
+
const handleKeyDown = (e) => {
|
47
|
+
if (!active) {
|
48
|
+
return;
|
49
|
+
}
|
50
|
+
if (e.key === "Tab" && !isSelected) {
|
51
|
+
return;
|
52
|
+
}
|
53
|
+
e.preventDefault();
|
54
|
+
switch (e.key) {
|
55
|
+
case " ":
|
56
|
+
case "Enter":
|
57
|
+
handleDragClick();
|
58
|
+
break;
|
59
|
+
case "Escape":
|
60
|
+
handleCancel();
|
61
|
+
break;
|
62
|
+
case "ArrowDown":
|
63
|
+
case "ArrowRight":
|
64
|
+
handleMove("DOWN");
|
65
|
+
break;
|
66
|
+
case "ArrowUp":
|
67
|
+
case "ArrowLeft":
|
68
|
+
handleMove("UP");
|
69
|
+
break;
|
70
|
+
}
|
71
|
+
};
|
72
|
+
return handleKeyDown;
|
73
|
+
};
|
74
|
+
const DIRECTIONS = {
|
75
|
+
UPWARD: "upward",
|
76
|
+
DOWNWARD: "downward"
|
77
|
+
};
|
78
|
+
const DROP_SENSITIVITY = {
|
79
|
+
REGULAR: "regular",
|
80
|
+
IMMEDIATE: "immediate"
|
81
|
+
};
|
82
|
+
const useDragAndDrop = (active, {
|
83
|
+
type = "STRAPI_DND",
|
84
|
+
index,
|
85
|
+
item,
|
86
|
+
onStart,
|
87
|
+
onEnd,
|
88
|
+
onGrabItem,
|
89
|
+
onDropItem,
|
90
|
+
onCancel,
|
91
|
+
onMoveItem,
|
92
|
+
dropSensitivity = DROP_SENSITIVITY.REGULAR
|
93
|
+
}) => {
|
94
|
+
const objectRef = React.useRef(null);
|
95
|
+
const [{ handlerId, isOver }, dropRef] = useDrop({
|
96
|
+
accept: type,
|
97
|
+
collect(monitor) {
|
98
|
+
return {
|
99
|
+
handlerId: monitor.getHandlerId(),
|
100
|
+
isOver: monitor.isOver({ shallow: true })
|
101
|
+
};
|
102
|
+
},
|
103
|
+
drop(item2) {
|
104
|
+
const draggedIndex = item2.index;
|
105
|
+
const newIndex = index;
|
106
|
+
if (isOver && onDropItem) {
|
107
|
+
onDropItem(draggedIndex, newIndex);
|
108
|
+
}
|
109
|
+
},
|
110
|
+
hover(item2, monitor) {
|
111
|
+
if (!objectRef.current || !onMoveItem) {
|
112
|
+
return;
|
113
|
+
}
|
114
|
+
const dragIndex = item2.index;
|
115
|
+
const newIndex = index;
|
116
|
+
const hoverBoundingRect = objectRef.current?.getBoundingClientRect();
|
117
|
+
const hoverMiddleY = (hoverBoundingRect.bottom - hoverBoundingRect.top) / 2;
|
118
|
+
const clientOffset = monitor.getClientOffset();
|
119
|
+
if (!clientOffset) return;
|
120
|
+
const hoverClientY = clientOffset && clientOffset.y - hoverBoundingRect.top;
|
121
|
+
if (typeof dragIndex === "number" && typeof newIndex === "number") {
|
122
|
+
if (dragIndex === newIndex) {
|
123
|
+
return;
|
124
|
+
}
|
125
|
+
if (dropSensitivity === DROP_SENSITIVITY.REGULAR) {
|
126
|
+
if (dragIndex < newIndex && hoverClientY < hoverMiddleY) {
|
127
|
+
return;
|
128
|
+
}
|
129
|
+
if (dragIndex > newIndex && hoverClientY > hoverMiddleY) {
|
130
|
+
return;
|
131
|
+
}
|
132
|
+
}
|
133
|
+
onMoveItem(newIndex, dragIndex);
|
134
|
+
item2.index = newIndex;
|
135
|
+
} else {
|
136
|
+
if (Array.isArray(dragIndex) && Array.isArray(newIndex)) {
|
137
|
+
const minLength = Math.min(dragIndex.length, newIndex.length);
|
138
|
+
let areEqual = true;
|
139
|
+
let isLessThan = false;
|
140
|
+
let isGreaterThan = false;
|
141
|
+
for (let i = 0; i < minLength; i++) {
|
142
|
+
if (dragIndex[i] < newIndex[i]) {
|
143
|
+
isLessThan = true;
|
144
|
+
areEqual = false;
|
145
|
+
break;
|
146
|
+
} else if (dragIndex[i] > newIndex[i]) {
|
147
|
+
isGreaterThan = true;
|
148
|
+
areEqual = false;
|
149
|
+
break;
|
150
|
+
}
|
151
|
+
}
|
152
|
+
if (areEqual && dragIndex.length === newIndex.length) {
|
153
|
+
return;
|
154
|
+
}
|
155
|
+
if (dropSensitivity === DROP_SENSITIVITY.REGULAR) {
|
156
|
+
if (isLessThan && !isGreaterThan && hoverClientY < hoverMiddleY) {
|
157
|
+
return;
|
158
|
+
}
|
159
|
+
if (isGreaterThan && !isLessThan && hoverClientY > hoverMiddleY) {
|
160
|
+
return;
|
161
|
+
}
|
162
|
+
}
|
163
|
+
}
|
164
|
+
onMoveItem(newIndex, dragIndex);
|
165
|
+
item2.index = newIndex;
|
166
|
+
}
|
167
|
+
}
|
168
|
+
});
|
169
|
+
const getDragDirection = (monitor) => {
|
170
|
+
if (monitor && monitor.isDragging() && !monitor.didDrop() && monitor.getInitialClientOffset() && monitor.getClientOffset()) {
|
171
|
+
const deltaY = monitor.getInitialClientOffset().y - monitor.getClientOffset().y;
|
172
|
+
if (deltaY > 0) return DIRECTIONS.UPWARD;
|
173
|
+
if (deltaY < 0) return DIRECTIONS.DOWNWARD;
|
174
|
+
return null;
|
175
|
+
}
|
176
|
+
return null;
|
177
|
+
};
|
178
|
+
const [{ isDragging, direction }, dragRef, dragPreviewRef] = useDrag({
|
179
|
+
type,
|
180
|
+
item() {
|
181
|
+
if (onStart) {
|
182
|
+
onStart();
|
183
|
+
}
|
184
|
+
const { width } = objectRef.current?.getBoundingClientRect() ?? {};
|
185
|
+
return { index, width, ...item };
|
186
|
+
},
|
187
|
+
end() {
|
188
|
+
if (onEnd) {
|
189
|
+
onEnd();
|
190
|
+
}
|
191
|
+
},
|
192
|
+
canDrag: active,
|
193
|
+
/**
|
194
|
+
* This is useful when the item is in a virtualized list.
|
195
|
+
* However, if we don't have an ID then we want the libraries
|
196
|
+
* defaults to take care of this.
|
197
|
+
*/
|
198
|
+
isDragging: item?.id ? (monitor) => {
|
199
|
+
return item.id === monitor.getItem().id;
|
200
|
+
} : void 0,
|
201
|
+
collect: (monitor) => ({
|
202
|
+
isDragging: monitor.isDragging(),
|
203
|
+
initialOffset: monitor.getInitialClientOffset(),
|
204
|
+
currentOffset: monitor.getClientOffset(),
|
205
|
+
direction: getDragDirection(monitor)
|
206
|
+
})
|
207
|
+
});
|
208
|
+
const handleKeyDown = useKeyboardDragAndDrop(active, index, {
|
209
|
+
onGrabItem,
|
210
|
+
onDropItem,
|
211
|
+
onCancel,
|
212
|
+
onMoveItem
|
213
|
+
});
|
214
|
+
return [
|
215
|
+
{ handlerId, isDragging, handleKeyDown, isOverDropTarget: isOver, direction },
|
216
|
+
objectRef,
|
217
|
+
dropRef,
|
218
|
+
dragRef,
|
219
|
+
dragPreviewRef
|
220
|
+
];
|
221
|
+
};
|
222
|
+
export {
|
223
|
+
DROP_SENSITIVITY as D,
|
224
|
+
ItemTypes as I,
|
225
|
+
DIRECTIONS as a,
|
226
|
+
useDragAndDrop as u
|
227
|
+
};
|
228
|
+
//# sourceMappingURL=useDragAndDrop-DJ6jqvZN.mjs.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"useDragAndDrop-DJ6jqvZN.mjs","sources":["../../admin/src/constants/dragAndDrop.ts","../../admin/src/hooks/useKeyboardDragAndDrop.ts","../../admin/src/hooks/useDragAndDrop.ts"],"sourcesContent":["export const ItemTypes = {\n COMPONENT: 'component',\n EDIT_FIELD: 'editField',\n FIELD: 'field',\n DYNAMIC_ZONE: 'dynamicZone',\n RELATION: 'relation',\n BLOCKS: 'blocks',\n} as const;\n","import * as React from 'react';\n\nexport type UseKeyboardDragAndDropCallbacks<TIndex extends number | Array<number> = number> = {\n onCancel?: (index: TIndex) => void;\n onDropItem?: (currentIndex: TIndex, newIndex?: TIndex) => void;\n onGrabItem?: (index: TIndex) => void;\n onMoveItem?: (newIndex: TIndex, currentIndex: TIndex) => void;\n};\n\n/**\n * Utility hook designed to implement keyboard accessibile drag and drop by\n * returning an onKeyDown handler to be passed to the drag icon button.\n *\n * @internal - You should use `useDragAndDrop` instead.\n */\nexport const useKeyboardDragAndDrop = <TIndex extends number | Array<number> = number>(\n active: boolean,\n index: TIndex,\n { onCancel, onDropItem, onGrabItem, onMoveItem }: UseKeyboardDragAndDropCallbacks<TIndex>\n) => {\n const [isSelected, setIsSelected] = React.useState(false);\n\n const handleMove = (movement: 'UP' | 'DOWN') => {\n if (!isSelected) {\n return;\n }\n if (typeof index === 'number' && onMoveItem) {\n if (movement === 'UP') {\n onMoveItem((index - 1) as TIndex, index);\n } else if (movement === 'DOWN') {\n onMoveItem((index + 1) as TIndex, index);\n }\n }\n };\n\n const handleDragClick = () => {\n if (isSelected) {\n if (onDropItem) {\n onDropItem(index);\n }\n setIsSelected(false);\n } else {\n if (onGrabItem) {\n onGrabItem(index);\n }\n setIsSelected(true);\n }\n };\n\n const handleCancel = () => {\n if (isSelected) {\n setIsSelected(false);\n\n if (onCancel) {\n onCancel(index);\n }\n }\n };\n\n const handleKeyDown = <E extends Element>(e: React.KeyboardEvent<E>) => {\n if (!active) {\n return;\n }\n\n if (e.key === 'Tab' && !isSelected) {\n return;\n }\n\n e.preventDefault();\n\n switch (e.key) {\n case ' ':\n case 'Enter':\n handleDragClick();\n break;\n\n case 'Escape':\n handleCancel();\n break;\n\n case 'ArrowDown':\n case 'ArrowRight':\n handleMove('DOWN');\n break;\n\n case 'ArrowUp':\n case 'ArrowLeft':\n handleMove('UP');\n break;\n\n default:\n }\n };\n\n return handleKeyDown;\n};\n","import * as React from 'react';\n\nimport {\n useDrag,\n useDrop,\n type HandlerManager,\n type ConnectDragSource,\n type ConnectDropTarget,\n type ConnectDragPreview,\n type DragSourceMonitor,\n} from 'react-dnd';\n\nimport {\n useKeyboardDragAndDrop,\n type UseKeyboardDragAndDropCallbacks,\n} from './useKeyboardDragAndDrop';\n\nimport type { Data } from '@strapi/types';\n\nconst DIRECTIONS = {\n UPWARD: 'upward',\n DOWNWARD: 'downward',\n} as const;\n\nconst DROP_SENSITIVITY = {\n REGULAR: 'regular',\n IMMEDIATE: 'immediate',\n} as const;\n\ninterface UseDragAndDropOptions<\n TIndex extends number | Array<number> = number,\n TItem extends { index: TIndex } = { index: TIndex },\n> extends UseKeyboardDragAndDropCallbacks<TIndex> {\n type?: string;\n index: TIndex;\n item?: TItem;\n onStart?: () => void;\n onEnd?: () => void;\n dropSensitivity?: (typeof DROP_SENSITIVITY)[keyof typeof DROP_SENSITIVITY];\n}\n\ntype Identifier = ReturnType<HandlerManager['getHandlerId']>;\n\ntype UseDragAndDropReturn<E extends Element = HTMLElement> = [\n props: {\n handlerId: Identifier;\n isDragging: boolean;\n handleKeyDown: <E extends Element>(event: React.KeyboardEvent<E>) => void;\n isOverDropTarget: boolean;\n direction: (typeof DIRECTIONS)[keyof typeof DIRECTIONS] | null;\n },\n objectRef: React.RefObject<E>,\n dropRef: ConnectDropTarget,\n dragRef: ConnectDragSource,\n dragPreviewRef: ConnectDragPreview,\n];\n\ntype DropCollectedProps = {\n handlerId: Identifier;\n isOver: boolean;\n};\n\n/**\n * A utility hook abstracting the general drag and drop hooks from react-dnd.\n * Centralising the same behaviours and by default offering keyboard support.\n */\nconst useDragAndDrop = <\n TIndex extends number | Array<number>,\n TItem extends { index: TIndex; id?: Data.ID; [key: string]: unknown } = {\n index: TIndex;\n [key: string]: unknown;\n },\n E extends Element = HTMLElement,\n>(\n active: boolean,\n {\n type = 'STRAPI_DND',\n index,\n item,\n onStart,\n onEnd,\n onGrabItem,\n onDropItem,\n onCancel,\n onMoveItem,\n dropSensitivity = DROP_SENSITIVITY.REGULAR,\n }: UseDragAndDropOptions<TIndex, TItem>\n): UseDragAndDropReturn<E> => {\n const objectRef = React.useRef<E>(null);\n\n const [{ handlerId, isOver }, dropRef] = useDrop<TItem, void, DropCollectedProps>({\n accept: type,\n collect(monitor) {\n return {\n handlerId: monitor.getHandlerId(),\n isOver: monitor.isOver({ shallow: true }),\n };\n },\n drop(item) {\n const draggedIndex = item.index;\n const newIndex = index;\n\n if (isOver && onDropItem) {\n onDropItem(draggedIndex, newIndex);\n }\n },\n hover(item, monitor) {\n if (!objectRef.current || !onMoveItem) {\n return;\n }\n\n const dragIndex = item.index;\n const newIndex = index;\n\n const hoverBoundingRect = objectRef.current?.getBoundingClientRect();\n const hoverMiddleY = (hoverBoundingRect.bottom - hoverBoundingRect.top) / 2;\n const clientOffset = monitor.getClientOffset();\n if (!clientOffset) return;\n\n const hoverClientY = clientOffset && clientOffset.y - hoverBoundingRect.top;\n if (typeof dragIndex === 'number' && typeof newIndex === 'number') {\n if (dragIndex === newIndex) {\n // Don't replace items with themselves\n return;\n }\n\n if (dropSensitivity === DROP_SENSITIVITY.REGULAR) {\n // Dragging downwards\n if (dragIndex < newIndex && hoverClientY < hoverMiddleY) {\n return;\n }\n\n // Dragging upwards\n if (dragIndex > newIndex && hoverClientY > hoverMiddleY) {\n return;\n }\n }\n\n // Time to actually perform the action\n onMoveItem(newIndex, dragIndex);\n item.index = newIndex;\n } else {\n // Using numbers as indices doesn't work for nested list items with path like [1, 1, 0]\n if (Array.isArray(dragIndex) && Array.isArray(newIndex)) {\n // Indices comparison to find item position in nested list\n const minLength = Math.min(dragIndex.length, newIndex.length);\n let areEqual = true;\n let isLessThan = false;\n let isGreaterThan = false;\n\n for (let i = 0; i < minLength; i++) {\n if (dragIndex[i] < newIndex[i]) {\n isLessThan = true;\n areEqual = false;\n break;\n } else if (dragIndex[i] > newIndex[i]) {\n isGreaterThan = true;\n areEqual = false;\n break;\n }\n }\n\n // Don't replace items with themselves\n if (areEqual && dragIndex.length === newIndex.length) {\n return;\n }\n\n if (dropSensitivity === DROP_SENSITIVITY.REGULAR) {\n // Dragging downwards\n if (isLessThan && !isGreaterThan && hoverClientY < hoverMiddleY) {\n return;\n }\n\n // Dragging upwards\n if (isGreaterThan && !isLessThan && hoverClientY > hoverMiddleY) {\n return;\n }\n }\n }\n\n onMoveItem(newIndex, dragIndex);\n item.index = newIndex;\n }\n },\n });\n\n const getDragDirection = (monitor: DragSourceMonitor<TItem, void>) => {\n if (\n monitor &&\n monitor.isDragging() &&\n !monitor.didDrop() &&\n monitor.getInitialClientOffset() &&\n monitor.getClientOffset()\n ) {\n const deltaY = monitor.getInitialClientOffset()!.y - monitor.getClientOffset()!.y;\n\n if (deltaY > 0) return DIRECTIONS.UPWARD;\n\n if (deltaY < 0) return DIRECTIONS.DOWNWARD;\n\n return null;\n }\n\n return null;\n };\n\n const [{ isDragging, direction }, dragRef, dragPreviewRef] = useDrag({\n type,\n item() {\n if (onStart) {\n onStart();\n }\n\n /**\n * This will be attached and it helps define the preview sizes\n * when a component is flexy e.g. Relations\n */\n const { width } = objectRef.current?.getBoundingClientRect() ?? {};\n\n return { index, width, ...item };\n },\n end() {\n if (onEnd) {\n onEnd();\n }\n },\n canDrag: active,\n /**\n * This is useful when the item is in a virtualized list.\n * However, if we don't have an ID then we want the libraries\n * defaults to take care of this.\n */\n isDragging: item?.id\n ? (monitor) => {\n return item.id === monitor.getItem().id;\n }\n : undefined,\n collect: (monitor) => ({\n isDragging: monitor.isDragging(),\n initialOffset: monitor.getInitialClientOffset(),\n currentOffset: monitor.getClientOffset(),\n direction: getDragDirection(monitor),\n }),\n });\n\n const handleKeyDown = useKeyboardDragAndDrop(active, index, {\n onGrabItem,\n onDropItem,\n onCancel,\n onMoveItem,\n });\n\n return [\n { handlerId, isDragging, handleKeyDown, isOverDropTarget: isOver, direction },\n objectRef,\n dropRef,\n dragRef,\n dragPreviewRef,\n ];\n};\n\nexport {\n useDragAndDrop,\n UseDragAndDropReturn,\n UseDragAndDropOptions,\n DIRECTIONS,\n DROP_SENSITIVITY,\n};\n"],"names":["item"],"mappings":"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"}
|
@@ -0,0 +1,29 @@
|
|
1
|
+
import { useState, useEffect, useRef } from "react";
|
2
|
+
const prefixFileUrlWithBackendUrl = (fileURL) => {
|
3
|
+
return !!fileURL && fileURL.startsWith("/") ? `${window.strapi.backendURL}${fileURL}` : fileURL;
|
4
|
+
};
|
5
|
+
function useDebounce(value, delay) {
|
6
|
+
const [debouncedValue, setDebouncedValue] = useState(value);
|
7
|
+
useEffect(() => {
|
8
|
+
const handler = setTimeout(() => {
|
9
|
+
setDebouncedValue(value);
|
10
|
+
}, delay);
|
11
|
+
return () => {
|
12
|
+
clearTimeout(handler);
|
13
|
+
};
|
14
|
+
}, [value, delay]);
|
15
|
+
return debouncedValue;
|
16
|
+
}
|
17
|
+
const usePrev = (value) => {
|
18
|
+
const ref = useRef();
|
19
|
+
useEffect(() => {
|
20
|
+
ref.current = value;
|
21
|
+
}, [value]);
|
22
|
+
return ref.current;
|
23
|
+
};
|
24
|
+
export {
|
25
|
+
usePrev as a,
|
26
|
+
prefixFileUrlWithBackendUrl as p,
|
27
|
+
useDebounce as u
|
28
|
+
};
|
29
|
+
//# sourceMappingURL=usePrev-CZGy2Vjf.mjs.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"usePrev-CZGy2Vjf.mjs","sources":["../../admin/src/utils/urls.ts","../../admin/src/hooks/useDebounce.ts","../../admin/src/hooks/usePrev.ts"],"sourcesContent":["const prefixFileUrlWithBackendUrl = (fileURL?: string): string | undefined => {\n return !!fileURL && fileURL.startsWith('/') ? `${window.strapi.backendURL}${fileURL}` : fileURL;\n};\n\nexport { prefixFileUrlWithBackendUrl };\n","import { useEffect, useState } from 'react';\n\nexport function useDebounce<TValue>(value: TValue, delay: number): TValue {\n const [debouncedValue, setDebouncedValue] = useState(value);\n\n useEffect(() => {\n const handler = setTimeout(() => {\n setDebouncedValue(value);\n }, delay);\n\n return () => {\n clearTimeout(handler);\n };\n }, [value, delay]);\n\n return debouncedValue;\n}\n","import { useEffect, useRef } from 'react';\n\nexport const usePrev = <T>(value: T): T | undefined => {\n const ref = useRef<T>();\n\n useEffect(() => {\n ref.current = value;\n }, [value]);\n\n return ref.current;\n};\n"],"names":[],"mappings":";AAAM,MAAA,8BAA8B,CAAC,YAAyC;AAC5E,SAAO,CAAC,CAAC,WAAW,QAAQ,WAAW,GAAG,IAAI,GAAG,OAAO,OAAO,UAAU,GAAG,OAAO,KAAK;AAC1F;ACAgB,SAAA,YAAoB,OAAe,OAAuB;AACxE,QAAM,CAAC,gBAAgB,iBAAiB,IAAI,SAAS,KAAK;AAE1D,YAAU,MAAM;AACR,UAAA,UAAU,WAAW,MAAM;AAC/B,wBAAkB,KAAK;AAAA,OACtB,KAAK;AAER,WAAO,MAAM;AACX,mBAAa,OAAO;AAAA,IACtB;AAAA,EAAA,GACC,CAAC,OAAO,KAAK,CAAC;AAEV,SAAA;AACT;ACda,MAAA,UAAU,CAAI,UAA4B;AACrD,QAAM,MAAM,OAAU;AAEtB,YAAU,MAAM;AACd,QAAI,UAAU;AAAA,EAAA,GACb,CAAC,KAAK,CAAC;AAEV,SAAO,IAAI;AACb;"}
|
@@ -0,0 +1,28 @@
|
|
1
|
+
"use strict";
|
2
|
+
const React = require("react");
|
3
|
+
const prefixFileUrlWithBackendUrl = (fileURL) => {
|
4
|
+
return !!fileURL && fileURL.startsWith("/") ? `${window.strapi.backendURL}${fileURL}` : fileURL;
|
5
|
+
};
|
6
|
+
function useDebounce(value, delay) {
|
7
|
+
const [debouncedValue, setDebouncedValue] = React.useState(value);
|
8
|
+
React.useEffect(() => {
|
9
|
+
const handler = setTimeout(() => {
|
10
|
+
setDebouncedValue(value);
|
11
|
+
}, delay);
|
12
|
+
return () => {
|
13
|
+
clearTimeout(handler);
|
14
|
+
};
|
15
|
+
}, [value, delay]);
|
16
|
+
return debouncedValue;
|
17
|
+
}
|
18
|
+
const usePrev = (value) => {
|
19
|
+
const ref = React.useRef();
|
20
|
+
React.useEffect(() => {
|
21
|
+
ref.current = value;
|
22
|
+
}, [value]);
|
23
|
+
return ref.current;
|
24
|
+
};
|
25
|
+
exports.prefixFileUrlWithBackendUrl = prefixFileUrlWithBackendUrl;
|
26
|
+
exports.useDebounce = useDebounce;
|
27
|
+
exports.usePrev = usePrev;
|
28
|
+
//# sourceMappingURL=usePrev-D5J_2fEu.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"usePrev-D5J_2fEu.js","sources":["../../admin/src/utils/urls.ts","../../admin/src/hooks/useDebounce.ts","../../admin/src/hooks/usePrev.ts"],"sourcesContent":["const prefixFileUrlWithBackendUrl = (fileURL?: string): string | undefined => {\n return !!fileURL && fileURL.startsWith('/') ? `${window.strapi.backendURL}${fileURL}` : fileURL;\n};\n\nexport { prefixFileUrlWithBackendUrl };\n","import { useEffect, useState } from 'react';\n\nexport function useDebounce<TValue>(value: TValue, delay: number): TValue {\n const [debouncedValue, setDebouncedValue] = useState(value);\n\n useEffect(() => {\n const handler = setTimeout(() => {\n setDebouncedValue(value);\n }, delay);\n\n return () => {\n clearTimeout(handler);\n };\n }, [value, delay]);\n\n return debouncedValue;\n}\n","import { useEffect, useRef } from 'react';\n\nexport const usePrev = <T>(value: T): T | undefined => {\n const ref = useRef<T>();\n\n useEffect(() => {\n ref.current = value;\n }, [value]);\n\n return ref.current;\n};\n"],"names":["useState","useEffect","useRef"],"mappings":";;AAAM,MAAA,8BAA8B,CAAC,YAAyC;AAC5E,SAAO,CAAC,CAAC,WAAW,QAAQ,WAAW,GAAG,IAAI,GAAG,OAAO,OAAO,UAAU,GAAG,OAAO,KAAK;AAC1F;ACAgB,SAAA,YAAoB,OAAe,OAAuB;AACxE,QAAM,CAAC,gBAAgB,iBAAiB,IAAIA,MAAAA,SAAS,KAAK;AAE1DC,QAAAA,UAAU,MAAM;AACR,UAAA,UAAU,WAAW,MAAM;AAC/B,wBAAkB,KAAK;AAAA,OACtB,KAAK;AAER,WAAO,MAAM;AACX,mBAAa,OAAO;AAAA,IACtB;AAAA,EAAA,GACC,CAAC,OAAO,KAAK,CAAC;AAEV,SAAA;AACT;ACda,MAAA,UAAU,CAAI,UAA4B;AACrD,QAAM,MAAMC,MAAAA,OAAU;AAEtBD,QAAAA,UAAU,MAAM;AACd,QAAI,UAAU;AAAA,EAAA,GACb,CAAC,KAAK,CAAC;AAEV,SAAO,IAAI;AACb;;;;"}
|